@helia/block-brokers 3.0.4-c04dbf5 → 3.0.4-efdefc1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.min.js CHANGED
@@ -1,5 +1,5 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.HeliaBlockBrokers = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var HeliaBlockBrokers=(()=>{var po=Object.create;var he=Object.defineProperty;var mo=Object.getOwnPropertyDescriptor;var go=Object.getOwnPropertyNames;var wo=Object.getPrototypeOf,bo=Object.prototype.hasOwnProperty;var fe=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),q=(r,t)=>{for(var e in t)he(r,e,{get:t[e],enumerable:!0})},Bn=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of go(t))!bo.call(r,s)&&s!==e&&he(r,s,{get:()=>t[s],enumerable:!(n=mo(t,s))||n.enumerable});return r};var dr=(r,t,e)=>(e=r!=null?po(wo(r)):{},Bn(t||!r||!r.__esModule?he(e,"default",{value:r,enumerable:!0}):e,r)),xo=r=>Bn(he({},"__esModule",{value:!0}),r);var As=fe((re,Ve)=>{(function(r,t){"use strict";var e={version:"3.0.0",x86:{},x64:{},inputValidation:!0};function n(a){if(!Array.isArray(a)&&!ArrayBuffer.isView(a))return!1;for(var h=0;h<a.length;h++)if(!Number.isInteger(a[h])||a[h]<0||a[h]>255)return!1;return!0}function s(a,h){return(a&65535)*h+(((a>>>16)*h&65535)<<16)}function o(a,h){return a<<h|a>>>32-h}function i(a){return a^=a>>>16,a=s(a,2246822507),a^=a>>>13,a=s(a,3266489909),a^=a>>>16,a}function c(a,h){a=[a[0]>>>16,a[0]&65535,a[1]>>>16,a[1]&65535],h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535];var p=[0,0,0,0];return p[3]+=a[3]+h[3],p[2]+=p[3]>>>16,p[3]&=65535,p[2]+=a[2]+h[2],p[1]+=p[2]>>>16,p[2]&=65535,p[1]+=a[1]+h[1],p[0]+=p[1]>>>16,p[1]&=65535,p[0]+=a[0]+h[0],p[0]&=65535,[p[0]<<16|p[1],p[2]<<16|p[3]]}function l(a,h){a=[a[0]>>>16,a[0]&65535,a[1]>>>16,a[1]&65535],h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535];var p=[0,0,0,0];return p[3]+=a[3]*h[3],p[2]+=p[3]>>>16,p[3]&=65535,p[2]+=a[2]*h[3],p[1]+=p[2]>>>16,p[2]&=65535,p[2]+=a[3]*h[2],p[1]+=p[2]>>>16,p[2]&=65535,p[1]+=a[1]*h[3],p[0]+=p[1]>>>16,p[1]&=65535,p[1]+=a[2]*h[2],p[0]+=p[1]>>>16,p[1]&=65535,p[1]+=a[3]*h[1],p[0]+=p[1]>>>16,p[1]&=65535,p[0]+=a[0]*h[3]+a[1]*h[2]+a[2]*h[1]+a[3]*h[0],p[0]&=65535,[p[0]<<16|p[1],p[2]<<16|p[3]]}function u(a,h){return h%=64,h===32?[a[1],a[0]]:h<32?[a[0]<<h|a[1]>>>32-h,a[1]<<h|a[0]>>>32-h]:(h-=32,[a[1]<<h|a[0]>>>32-h,a[0]<<h|a[1]>>>32-h])}function d(a,h){return h%=64,h===0?a:h<32?[a[0]<<h|a[1]>>>32-h,a[1]<<h]:[a[1]<<h-32,0]}function f(a,h){return[a[0]^h[0],a[1]^h[1]]}function y(a){return a=f(a,[0,a[0]>>>1]),a=l(a,[4283543511,3981806797]),a=f(a,[0,a[0]>>>1]),a=l(a,[3301882366,444984403]),a=f(a,[0,a[0]>>>1]),a}e.x86.hash32=function(a,h){if(e.inputValidation&&!n(a))return t;h=h||0;for(var p=a.length%4,E=a.length-p,m=h,g=0,w=3432918353,x=461845907,v=0;v<E;v=v+4)g=a[v]|a[v+1]<<8|a[v+2]<<16|a[v+3]<<24,g=s(g,w),g=o(g,15),g=s(g,x),m^=g,m=o(m,13),m=s(m,5)+3864292196;switch(g=0,p){case 3:g^=a[v+2]<<16;case 2:g^=a[v+1]<<8;case 1:g^=a[v],g=s(g,w),g=o(g,15),g=s(g,x),m^=g}return m^=a.length,m=i(m),m>>>0},e.x86.hash128=function(a,h){if(e.inputValidation&&!n(a))return t;h=h||0;for(var p=a.length%16,E=a.length-p,m=h,g=h,w=h,x=h,v=0,S=0,b=0,D=0,nt=597399067,ce=2869860233,le=951274213,ue=2716044179,A=0;A<E;A=A+16)v=a[A]|a[A+1]<<8|a[A+2]<<16|a[A+3]<<24,S=a[A+4]|a[A+5]<<8|a[A+6]<<16|a[A+7]<<24,b=a[A+8]|a[A+9]<<8|a[A+10]<<16|a[A+11]<<24,D=a[A+12]|a[A+13]<<8|a[A+14]<<16|a[A+15]<<24,v=s(v,nt),v=o(v,15),v=s(v,ce),m^=v,m=o(m,19),m+=g,m=s(m,5)+1444728091,S=s(S,ce),S=o(S,16),S=s(S,le),g^=S,g=o(g,17),g+=w,g=s(g,5)+197830471,b=s(b,le),b=o(b,17),b=s(b,ue),w^=b,w=o(w,15),w+=x,w=s(w,5)+2530024501,D=s(D,ue),D=o(D,18),D=s(D,nt),x^=D,x=o(x,13),x+=m,x=s(x,5)+850148119;switch(v=0,S=0,b=0,D=0,p){case 15:D^=a[A+14]<<16;case 14:D^=a[A+13]<<8;case 13:D^=a[A+12],D=s(D,ue),D=o(D,18),D=s(D,nt),x^=D;case 12:b^=a[A+11]<<24;case 11:b^=a[A+10]<<16;case 10:b^=a[A+9]<<8;case 9:b^=a[A+8],b=s(b,le),b=o(b,17),b=s(b,ue),w^=b;case 8:S^=a[A+7]<<24;case 7:S^=a[A+6]<<16;case 6:S^=a[A+5]<<8;case 5:S^=a[A+4],S=s(S,ce),S=o(S,16),S=s(S,le),g^=S;case 4:v^=a[A+3]<<24;case 3:v^=a[A+2]<<16;case 2:v^=a[A+1]<<8;case 1:v^=a[A],v=s(v,nt),v=o(v,15),v=s(v,ce),m^=v}return m^=a.length,g^=a.length,w^=a.length,x^=a.length,m+=g,m+=w,m+=x,g+=m,w+=m,x+=m,m=i(m),g=i(g),w=i(w),x=i(x),m+=g,m+=w,m+=x,g+=m,w+=m,x+=m,("00000000"+(m>>>0).toString(16)).slice(-8)+("00000000"+(g>>>0).toString(16)).slice(-8)+("00000000"+(w>>>0).toString(16)).slice(-8)+("00000000"+(x>>>0).toString(16)).slice(-8)},e.x64.hash128=function(a,h){if(e.inputValidation&&!n(a))return t;h=h||0;for(var p=a.length%16,E=a.length-p,m=[0,h],g=[0,h],w=[0,0],x=[0,0],v=[2277735313,289559509],S=[1291169091,658871167],b=0;b<E;b=b+16)w=[a[b+4]|a[b+5]<<8|a[b+6]<<16|a[b+7]<<24,a[b]|a[b+1]<<8|a[b+2]<<16|a[b+3]<<24],x=[a[b+12]|a[b+13]<<8|a[b+14]<<16|a[b+15]<<24,a[b+8]|a[b+9]<<8|a[b+10]<<16|a[b+11]<<24],w=l(w,v),w=u(w,31),w=l(w,S),m=f(m,w),m=u(m,27),m=c(m,g),m=c(l(m,[0,5]),[0,1390208809]),x=l(x,S),x=u(x,33),x=l(x,v),g=f(g,x),g=u(g,31),g=c(g,m),g=c(l(g,[0,5]),[0,944331445]);switch(w=[0,0],x=[0,0],p){case 15:x=f(x,d([0,a[b+14]],48));case 14:x=f(x,d([0,a[b+13]],40));case 13:x=f(x,d([0,a[b+12]],32));case 12:x=f(x,d([0,a[b+11]],24));case 11:x=f(x,d([0,a[b+10]],16));case 10:x=f(x,d([0,a[b+9]],8));case 9:x=f(x,[0,a[b+8]]),x=l(x,S),x=u(x,33),x=l(x,v),g=f(g,x);case 8:w=f(w,d([0,a[b+7]],56));case 7:w=f(w,d([0,a[b+6]],48));case 6:w=f(w,d([0,a[b+5]],40));case 5:w=f(w,d([0,a[b+4]],32));case 4:w=f(w,d([0,a[b+3]],24));case 3:w=f(w,d([0,a[b+2]],16));case 2:w=f(w,d([0,a[b+1]],8));case 1:w=f(w,[0,a[b]]),w=l(w,v),w=u(w,31),w=l(w,S),m=f(m,w)}return m=f(m,[0,a.length]),g=f(g,[0,a.length]),m=c(m,g),g=c(g,m),m=y(m),g=y(g),m=c(m,g),g=c(g,m),("00000000"+(m[0]>>>0).toString(16)).slice(-8)+("00000000"+(m[1]>>>0).toString(16)).slice(-8)+("00000000"+(g[0]>>>0).toString(16)).slice(-8)+("00000000"+(g[1]>>>0).toString(16)).slice(-8)},typeof re<"u"?(typeof Ve<"u"&&Ve.exports&&(re=Ve.exports=e),re.murmurHash3=e):typeof define=="function"&&define.amd?define([],function(){return e}):(e._murmurHash3=r.murmurHash3,e.noConflict=function(){return r.murmurHash3=e._murmurHash3,e._murmurHash3=t,e.noConflict=t,e},r.murmurHash3=e)})(re)});var Is=fe((yh,Ls)=>{Ls.exports=As()});var Ps=fe((ef,Ds)=>{Ds.exports=function(r){if(!r)throw Error("hashlru must have a max value, of type number, greater than 0");var t=0,e=Object.create(null),n=Object.create(null);function s(o,i){e[o]=i,t++,t>=r&&(t=0,n=e,e=Object.create(null))}return{has:function(o){return e[o]!==void 0||n[o]!==void 0},remove:function(o){e[o]!==void 0&&(e[o]=void 0),n[o]!==void 0&&(n[o]=void 0)},get:function(o){var i=e[o];if(i!==void 0)return i;if((i=n[o])!==void 0)return s(o,i),i},set:function(o,i){e[o]!==void 0?e[o]=i:s(o,i)},clear:function(){e=Object.create(null),n=Object.create(null)}}}});var Bs=fe(se=>{(function(){var r,t,e,n,s,o,i,c;c=function(l){var u,d,f,y;return u=(l&255<<24)>>>24,d=(l&255<<16)>>>16,f=(l&65280)>>>8,y=l&255,[u,d,f,y].join(".")},i=function(l){var u,d,f,y,a,h;for(u=[],f=y=0;y<=3&&l.length!==0;f=++y){if(f>0){if(l[0]!==".")throw new Error("Invalid IP");l=l.substring(1)}h=t(l),a=h[0],d=h[1],l=l.substring(d),u.push(a)}if(l.length!==0)throw new Error("Invalid IP");switch(u.length){case 1:if(u[0]>4294967295)throw new Error("Invalid IP");return u[0]>>>0;case 2:if(u[0]>255||u[1]>16777215)throw new Error("Invalid IP");return(u[0]<<24|u[1])>>>0;case 3:if(u[0]>255||u[1]>255||u[2]>65535)throw new Error("Invalid IP");return(u[0]<<24|u[1]<<16|u[2])>>>0;case 4:if(u[0]>255||u[1]>255||u[2]>255||u[3]>255)throw new Error("Invalid IP");return(u[0]<<24|u[1]<<16|u[2]<<8|u[3])>>>0;default:throw new Error("Invalid IP")}},e=function(l){return l.charCodeAt(0)},n=e("0"),o=e("a"),s=e("A"),t=function(l){var u,d,f,y,a;for(y=0,u=10,d="9",f=0,l.length>1&&l[f]==="0"&&(l[f+1]==="x"||l[f+1]==="X"?(f+=2,u=16):"0"<=l[f+1]&&l[f+1]<="9"&&(f++,u=8,d="7")),a=f;f<l.length;){if("0"<=l[f]&&l[f]<=d)y=y*u+(e(l[f])-n)>>>0;else if(u===16)if("a"<=l[f]&&l[f]<="f")y=y*u+(10+e(l[f])-o)>>>0;else if("A"<=l[f]&&l[f]<="F")y=y*u+(10+e(l[f])-s)>>>0;else break;else break;if(y>4294967295)throw new Error("too large");f++}if(f===a)throw new Error("empty octet");return[y,f]},r=function(){function l(u,d){var f,y,a,h;if(typeof u!="string")throw new Error("Missing `net' parameter");if(d||(h=u.split("/",2),u=h[0],d=h[1]),d||(d=32),typeof d=="string"&&d.indexOf(".")>-1){try{this.maskLong=i(d)}catch(p){throw f=p,new Error("Invalid mask: "+d)}for(y=a=32;a>=0;y=--a)if(this.maskLong===4294967295<<32-y>>>0){this.bitmask=y;break}}else if(d||d===0)this.bitmask=parseInt(d,10),this.maskLong=0,this.bitmask>0&&(this.maskLong=4294967295<<32-this.bitmask>>>0);else throw new Error("Invalid mask: empty");try{this.netLong=(i(u)&this.maskLong)>>>0}catch(p){throw f=p,new Error("Invalid net address: "+u)}if(!(this.bitmask<=32))throw new Error("Invalid mask for ip4: "+d);this.size=Math.pow(2,32-this.bitmask),this.base=c(this.netLong),this.mask=c(this.maskLong),this.hostmask=c(~this.maskLong),this.first=this.bitmask<=30?c(this.netLong+1):this.base,this.last=this.bitmask<=30?c(this.netLong+this.size-2):c(this.netLong+this.size-1),this.broadcast=this.bitmask<=30?c(this.netLong+this.size-1):void 0}return l.prototype.contains=function(u){return typeof u=="string"&&(u.indexOf("/")>0||u.split(".").length!==4)&&(u=new l(u)),u instanceof l?this.contains(u.base)&&this.contains(u.broadcast||u.last):(i(u)&this.maskLong)>>>0===(this.netLong&this.maskLong)>>>0},l.prototype.next=function(u){return u==null&&(u=1),new l(c(this.netLong+this.size*u),this.mask)},l.prototype.forEach=function(u){var d,f,y;for(y=i(this.first),f=i(this.last),d=0;y<=f;)u(c(y),y,d),d++,y++},l.prototype.toString=function(){return this.base+"/"+this.bitmask},l}(),se.ip2long=i,se.long2ip=c,se.Netmask=r}).call(se)});var nc={};q(nc,{bitswap:()=>Fs,trustlessGateway:()=>fo});var st=class extends Error{static name="AbortError";constructor(t="The operation was aborted"){super(t),this.name="AbortError"}};var Lt=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}};var de=class extends Error{static name="UnsupportedProtocolError";constructor(t="Unsupported protocol error"){super(t),this.name="UnsupportedProtocolError"}};var pe=class extends Error{static name="TimeoutError";constructor(t="Timed out"){super(t),this.name="TimeoutError"}},me=class extends Error{static name="NotStartedError";constructor(t="Not started"){super(t),this.name="NotStartedError"}};var W=(r,...t)=>{try{[...t]}catch{}};var tt=class extends EventTarget{#t=new Map;constructor(){super(),W(1/0,this)}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let s=this.#t.get(t);s==null&&(s=[],this.#t.set(t,s)),s.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let s=this.#t.get(t);s!=null&&(s=s.filter(({callback:o})=>o!==e),this.#t.set(t,s))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:s})=>!s),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new CustomEvent(t,e))}};function Rn(r){let t=new globalThis.AbortController;function e(){t.abort();for(let o of r)o?.removeEventListener!=null&&o.removeEventListener("abort",e)}for(let o of r){if(o?.aborted===!0){e();break}o?.addEventListener!=null&&o.addEventListener("abort",e)}function n(){for(let o of r)o?.removeEventListener!=null&&o.removeEventListener("abort",e)}let s=t.signal;return s.clear=n,s}function K(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var ge=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},It=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new ge(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new ge(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var pr=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Tt(r={}){return yo(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function yo(r,t){t=t??{};let e=t.onEnd,n=new It,s,o,i,c=K(),l=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((E,m)=>{o=g=>{o=null,n.push(g);try{E(r(n))}catch(w){m(w)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{c.resolve(),c=K()})}},u=E=>o!=null?o(E):(n.push(E),s),d=E=>(n=new It,o!=null?o({error:E}):(n.push({error:E}),s)),f=E=>{if(i)return s;if(t?.objectMode!==!0&&E?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return u({done:!1,value:E})},y=E=>i?s:(i=!0,E!=null?d(E):u({done:!0})),a=()=>(n=new It,y(),{done:!0}),h=E=>(y(E),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:l,return:a,throw:h,push:f,end:y,get readableLength(){return n.size},onEmpty:async E=>{let m=E?.signal;if(m?.throwIfAborted(),n.isEmpty())return;let g,w;m!=null&&(g=new Promise((x,v)=>{w=()=>{v(new pr)},m.addEventListener("abort",w)}));try{await Promise.race([c.promise,g])}finally{w!=null&&m!=null&&m?.removeEventListener("abort",w)}}},e==null)return s;let p=s;return s={[Symbol.asyncIterator](){return this},next(){return p.next()},throw(E){return p.throw(E),e!=null&&(e(E),e=void 0),{done:!0}},return(){return p.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(E){return p.end(E),e!=null&&(e(E),e=void 0),s},get readableLength(){return p.readableLength},onEmpty:E=>p.onEmpty(E)},s}var mr=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=e??"ABORT_ERR"}};async function J(r,t,e,n){let s=new mr(n?.errorMessage,n?.errorCode);return e?.aborted===!0?Promise.reject(s):new Promise((o,i)=>{function c(){e?.removeEventListener("abort",d),r.removeEventListener(t,l),n?.errorEvent!=null&&r.removeEventListener(n.errorEvent,u)}let l=f=>{try{if(n?.filter?.(f)===!1)return}catch(y){c(),i(y);return}c(),o(f)},u=f=>{c(),i(f.detail)},d=()=>{c(),i(s)};e?.addEventListener("abort",d),r.addEventListener(t,l),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,u)})}var we=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};async function On(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new we(e?.errorMessage,e?.errorCode,e?.errorName));let n,s=new we(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((o,i)=>{n=()=>{i(s)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var be=class{deferred;signal;constructor(t){this.signal=t,this.deferred=K(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new st)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function vo(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var xe=class{id;fn;options;recipients;status;timeline;controller;constructor(t,e){this.id=vo(),this.status="queued",this.fn=t,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,W(1/0,this.controller.signal),this.onAbort=this.onAbort.bind(this)}abort(t){this.controller.abort(t)}onAbort(){this.recipients.reduce((e,n)=>e&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new st),this.cleanup())}async join(t={}){let e=new be(t.signal);return this.recipients.push(e),t.signal?.addEventListener("abort",this.onAbort),e.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let t=await On(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(e=>{e.deferred.resolve(t)}),this.status="complete"}catch(t){this.recipients.forEach(e=>{e.deferred.reject(t)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(t=>{t.cleanup(),t.signal?.removeEventListener("abort",this.onAbort)})}};var Dt=class extends tt{concurrency;queue;pending;sort;constructor(t={}){super(),this.concurrency=t.concurrency??Number.POSITIVE_INFINITY,this.pending=0,t.metricName!=null&&t.metrics?.registerMetricGroup(t.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.sort=t.sort,this.queue=[]}tryToStartAnother(){if(this.size===0)return queueMicrotask(()=>{this.safeDispatchEvent("empty")}),this.running===0&&queueMicrotask(()=>{this.safeDispatchEvent("idle")}),!1;if(this.pending<this.concurrency){let t;for(let e of this.queue)if(e.status==="queued"){t=e;break}return t==null?!1:(this.safeDispatchEvent("active"),this.pending++,t.run().finally(()=>{for(let e=0;e<this.queue.length;e++)if(this.queue[e]===t){this.queue.splice(e,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(t){this.queue.push(t),this.sort!=null&&this.queue.sort(this.sort)}async add(t,e){e?.signal?.throwIfAborted();let n=new xe(t,e);return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),n.join(e).then(s=>(this.safeDispatchEvent("completed",{detail:s}),this.safeDispatchEvent("success",{detail:{job:n,result:s}}),s)).catch(s=>{if(n.status==="queued"){for(let o=0;o<this.queue.length;o++)if(this.queue[o]===n){this.queue.splice(o,1);break}}throw this.safeDispatchEvent("error",{detail:s}),this.safeDispatchEvent("failure",{detail:{job:n,error:s}}),s})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(t=>{t.abort(new st)}),this.clear()}async onEmpty(t){this.size!==0&&await J(this,"empty",t?.signal)}async onSizeLessThan(t,e){this.size<t||await J(this,"next",e?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await J(this,"idle",t?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(t){t?.signal?.throwIfAborted();let e=Tt({objectMode:!0}),n=l=>{l!=null?this.abort():this.clear(),e.end(l)},s=l=>{l.detail!=null&&e.push(l.detail)},o=l=>{n(l.detail)},i=()=>{n()},c=()=>{n(new st("Queue aborted"))};this.addEventListener("completed",s),this.addEventListener("error",o),this.addEventListener("idle",i),t?.signal?.addEventListener("abort",c);try{yield*e}finally{this.removeEventListener("completed",s),this.removeEventListener("error",o),this.removeEventListener("idle",i),t?.signal?.removeEventListener("abort",c),n()}}};var ye=class extends Dt{has(t){return this.find(t)!=null}find(t){return this.queue.find(e=>t.equals(e.options.peerId))}};function Eo(r){return r[Symbol.asyncIterator]!=null}function ko(r){if(Eo(r))return(async()=>{for await(let t of r);})();for(let t of r);}var gr=ko;function R(r=0){return new Uint8Array(r)}function O(r=0){return new Uint8Array(r)}var So=Math.pow(2,7),Ao=Math.pow(2,14),Lo=Math.pow(2,21),wr=Math.pow(2,28),br=Math.pow(2,35),xr=Math.pow(2,42),yr=Math.pow(2,49),I=128,$=127;function P(r){if(r<So)return 1;if(r<Ao)return 2;if(r<Lo)return 3;if(r<wr)return 4;if(r<br)return 5;if(r<xr)return 6;if(r<yr)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function vr(r,t,e=0){switch(P(r)){case 8:t[e++]=r&255|I,r/=128;case 7:t[e++]=r&255|I,r/=128;case 6:t[e++]=r&255|I,r/=128;case 5:t[e++]=r&255|I,r/=128;case 4:t[e++]=r&255|I,r>>>=7;case 3:t[e++]=r&255|I,r>>>=7;case 2:t[e++]=r&255|I,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Io(r,t,e=0){switch(P(r)){case 8:t.set(e++,r&255|I),r/=128;case 7:t.set(e++,r&255|I),r/=128;case 6:t.set(e++,r&255|I),r/=128;case 5:t.set(e++,r&255|I),r/=128;case 4:t.set(e++,r&255|I),r>>>=7;case 3:t.set(e++,r&255|I),r>>>=7;case 2:t.set(e++,r&255|I),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Er(r,t){let e=r[t],n=0;if(n+=e&$,e<I||(e=r[t+1],n+=(e&$)<<7,e<I)||(e=r[t+2],n+=(e&$)<<14,e<I)||(e=r[t+3],n+=(e&$)<<21,e<I)||(e=r[t+4],n+=(e&$)*wr,e<I)||(e=r[t+5],n+=(e&$)*br,e<I)||(e=r[t+6],n+=(e&$)*xr,e<I)||(e=r[t+7],n+=(e&$)*yr,e<I))return n;throw new RangeError("Could not decode varint")}function To(r,t){let e=r.get(t),n=0;if(n+=e&$,e<I||(e=r.get(t+1),n+=(e&$)<<7,e<I)||(e=r.get(t+2),n+=(e&$)<<14,e<I)||(e=r.get(t+3),n+=(e&$)<<21,e<I)||(e=r.get(t+4),n+=(e&$)*wr,e<I)||(e=r.get(t+5),n+=(e&$)*br,e<I)||(e=r.get(t+6),n+=(e&$)*xr,e<I)||(e=r.get(t+7),n+=(e&$)*yr,e<I))return n;throw new RangeError("Could not decode varint")}function et(r,t,e=0){return t==null&&(t=O(P(r))),t instanceof Uint8Array?vr(r,t,e):Io(r,t,e)}function Z(r,t=0){return r instanceof Uint8Array?Er(r,t):To(r,t)}function Q(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=O(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function ot(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}var zn=Symbol.for("@achingbrain/uint8arraylist");function $n(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function Ee(r){return!!r?.[zn]}var ht=class r{bufs;length;[zn]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(Ee(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(Ee(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=$n(this.bufs,t);return e.buf[e.index]}set(t,e){let n=$n(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(Ee(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return Q(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Q(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],c=s,l=c+i.byteLength;if(s=l,t>=l)continue;let u=t>=c&&t<l,d=e>c&&e<=l;if(u&&d){if(t===c&&e===l){n.push(i);break}let f=t-c;n.push(i.subarray(f,f+(e-t)));break}if(u){if(t===0){n.push(i);continue}n.push(i.subarray(t-c));continue}if(d){if(e===l){n.push(i);break}n.push(i.subarray(0,e-c));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!Ee(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let f=0;f<o;f++)i[f]=-1;for(let f=0;f<s;f++)i[n[f]]=f;let c=i,l=this.byteLength-n.byteLength,u=n.byteLength-1,d;for(let f=e;f<=l;f+=d){d=0;for(let y=u;y>=0;y--){let a=this.get(f+y);if(n[y]!==a){d=Math.max(1,y-c[a]);break}}if(d===0)return f}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=O(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=R(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=R(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=R(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=O(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=R(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=R(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=R(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=R(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=R(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!ot(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};function ke(r){return r[Symbol.asyncIterator]!=null}var Se=r=>{let t=P(r),e=O(t);return et(r,e),Se.bytes=t,e};Se.bytes=0;function Ae(r,t){t=t??{};let e=t.lengthEncoder??Se;function*n(s){let o=e(s.byteLength);o instanceof Uint8Array?yield o:yield*o,s instanceof Uint8Array?yield s:yield*s}return ke(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}Ae.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Se;return new ht(e(r.byteLength),r)};var Le=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Ie=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Te=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},qt=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Do=8,Po=1024*1024*4,mt;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(mt||(mt={}));var kr=r=>{let t=Z(r);return kr.bytes=P(t),t};kr.bytes=0;function Wt(r,t){let e=new ht,n=mt.LENGTH,s=-1,o=t?.lengthDecoder??kr,i=t?.maxLengthLength??Do,c=t?.maxDataLength??Po;function*l(){for(;e.byteLength>0;){if(n===mt.LENGTH)try{if(s=o(e),s<0)throw new Le("Invalid message length");if(s>c)throw new Ie("Message length too long");let u=o.bytes;e.consume(u),t?.onLength!=null&&t.onLength(s),n=mt.DATA}catch(u){if(u instanceof RangeError){if(e.byteLength>i)throw new Te("Message length length too long");break}throw u}if(n===mt.DATA){if(e.byteLength<s)break;let u=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(u),yield u,n=mt.LENGTH}}}return ke(r)?async function*(){for await(let u of r)e.append(u),yield*l();if(e.byteLength>0)throw new qt("Unexpected end of input")}():function*(){for(let u of r)e.append(u),yield*l();if(e.byteLength>0)throw new qt("Unexpected end of input")}()}Wt.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:o,value:i}=await r.next(e);if(o===!0)return;i!=null&&(yield i)}catch(o){if(o.code==="ERR_UNDER_READ")return{done:!0,value:null};throw o}finally{e=1}}();return Wt(n,{...t??{},onLength:o=>{e=o}})};function Uo(r){let[t,e]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>t.next(),push:s=>{n.push(s)},next:()=>n.length>0?{done:!1,value:n.shift()}:t.next(),[e](){return this}}}var Vn=Uo;function Co(r){return r[Symbol.asyncIterator]!=null}function Mo(r,t){let e=0;if(Co(r))return async function*(){for await(let l of r)yield t(l,e++)}();let n=Vn(r),{value:s,done:o}=n.next();if(o===!0)return function*(){}();let i=t(s,e++);if(typeof i.then=="function")return async function*(){yield await i;for await(let l of n)yield t(l,e++)}();let c=t;return function*(){yield i;for(let l of n)yield c(l,e++)}()}var Hn=Mo;function Fo(r){return r[Symbol.asyncIterator]!=null}function No(...r){let t=[];for(let e of r)Fo(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Tt({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let s of n)e.push(s)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var qn=No;function Ar(r,...t){if(r==null)throw new Error("Empty pipeline");if(Sr(r)){let n=r;r=()=>n.source}else if(Gn(r)||Wn(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Sr(e[e.length-1])&&(e[e.length-1]=e[e.length-1].sink),e.length>2)for(let n=1;n<e.length-1;n++)Sr(e[n])&&(e[n]=Ro(e[n]));return Bo(...e)}var Bo=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},Wn=r=>r?.[Symbol.asyncIterator]!=null,Gn=r=>r?.[Symbol.iterator]!=null,Sr=r=>r==null?!1:r.sink!=null&&r.source!=null,Ro=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Tt({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(Wn(o))s=async function*(){yield*o,n.end()};else if(Gn(o))s=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return qn(n,s())}return r.source};function Oo(r){return r[Symbol.asyncIterator]!=null}function $o(r,t){return Oo(r)?async function*(){let e=0;if(!(t<1)){for await(let n of r)if(yield n,e++,e===t)return}}():function*(){let e=0;if(!(t<1)){for(let n of r)if(yield n,e++,e===t)return}}()}var Xn=$o;var rt=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};var Gt="/ipfs/bitswap/1.2.0";var Lr=new Float32Array([-0]),ft=new Uint8Array(Lr.buffer);function Qn(r,t,e){Lr[0]=r,t[e]=ft[0],t[e+1]=ft[1],t[e+2]=ft[2],t[e+3]=ft[3]}function jn(r,t){return ft[0]=r[t],ft[1]=r[t+1],ft[2]=r[t+2],ft[3]=r[t+3],Lr[0]}var Ir=new Float64Array([-0]),z=new Uint8Array(Ir.buffer);function Kn(r,t,e){Ir[0]=r,t[e]=z[0],t[e+1]=z[1],t[e+2]=z[2],t[e+3]=z[3],t[e+4]=z[4],t[e+5]=z[5],t[e+6]=z[6],t[e+7]=z[7]}function Jn(r,t){return z[0]=r[t],z[1]=r[t+1],z[2]=r[t+2],z[3]=r[t+3],z[4]=r[t+4],z[5]=r[t+5],z[6]=r[t+6],z[7]=r[t+7],Ir[0]}var zo=BigInt(Number.MAX_SAFE_INTEGER),Vo=BigInt(Number.MIN_SAFE_INTEGER),G=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return gt;if(t<zo&&t>Vo)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Zn&&(s=0n,++n>Zn&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return gt;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):gt}},gt=new G(0,0);gt.toBigInt=function(){return 0n};gt.zzEncode=gt.zzDecode=function(){return this};gt.length=function(){return 1};var Zn=4294967296n;function Yn(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function ts(r,t,e){if(e-t<1)return"";let s,o=[],i=0,c;for(;t<e;)c=r[t++],c<128?o[i++]=c:c>191&&c<224?o[i++]=(c&31)<<6|r[t++]&63:c>239&&c<365?(c=((c&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,o[i++]=55296+(c>>10),o[i++]=56320+(c&1023)):o[i++]=(c&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function Tr(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Y(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function De(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Dr=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Y(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Y(this,4);return De(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Y(this,4);return De(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Y(this,4);let t=jn(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Y(this,4);let t=Jn(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Y(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return ts(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Y(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Y(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new G(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Y(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Y(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Y(this,8);let t=De(this.buf,this.pos+=4),e=De(this.buf,this.pos+=4);return new G(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Er(this.buf,this.pos);return this.pos+=P(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Pr(r){return new Dr(r instanceof Uint8Array?r:r.subarray())}function wt(r,t,e){let n=Pr(r);return t.decode(n,void 0,e)}var Fr={};q(Fr,{base10:()=>Qo});var vl=new Uint8Array(0);function rs(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function it(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function ns(r){return new TextEncoder().encode(r)}function ss(r){return new TextDecoder().decode(r)}function Ho(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var c=r.length,l=r.charAt(0),u=Math.log(c)/Math.log(256),d=Math.log(256)/Math.log(c);function f(h){if(h instanceof Uint8Array||(ArrayBuffer.isView(h)?h=new Uint8Array(h.buffer,h.byteOffset,h.byteLength):Array.isArray(h)&&(h=Uint8Array.from(h))),!(h instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(h.length===0)return"";for(var p=0,E=0,m=0,g=h.length;m!==g&&h[m]===0;)m++,p++;for(var w=(g-m)*d+1>>>0,x=new Uint8Array(w);m!==g;){for(var v=h[m],S=0,b=w-1;(v!==0||S<E)&&b!==-1;b--,S++)v+=256*x[b]>>>0,x[b]=v%c>>>0,v=v/c>>>0;if(v!==0)throw new Error("Non-zero carry");E=S,m++}for(var D=w-E;D!==w&&x[D]===0;)D++;for(var nt=l.repeat(p);D<w;++D)nt+=r.charAt(x[D]);return nt}function y(h){if(typeof h!="string")throw new TypeError("Expected String");if(h.length===0)return new Uint8Array;var p=0;if(h[p]!==" "){for(var E=0,m=0;h[p]===l;)E++,p++;for(var g=(h.length-p)*u+1>>>0,w=new Uint8Array(g);h[p];){var x=e[h.charCodeAt(p)];if(x===255)return;for(var v=0,S=g-1;(x!==0||v<m)&&S!==-1;S--,v++)x+=c*w[S]>>>0,w[S]=x%256>>>0,x=x/256>>>0;if(x!==0)throw new Error("Non-zero carry");m=v,p++}if(h[p]!==" "){for(var b=g-m;b!==g&&w[b]===0;)b++;for(var D=new Uint8Array(E+(g-b)),nt=E;b!==g;)D[nt++]=w[b++];return D}}}function a(h){var p=y(h);if(p)return p;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:y,decode:a}}var qo=Ho,Wo=qo,is=Wo;var _r=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Ur=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return as(this,t)}},Cr=class{decoders;constructor(t){this.decoders=t}or(t){return as(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function as(r,t){return new Cr({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Mr=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new _r(t,e,n),this.decoder=new Ur(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Pt({name:r,prefix:t,encode:e,decode:n}){return new Mr(r,t,e,n)}function dt({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=is(e,r);return Pt({prefix:t,name:r,encode:n,decode:o=>it(s(o))})}function Go(r,t,e,n){let s={};for(let d=0;d<t.length;++d)s[t[d]]=d;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),c=0,l=0,u=0;for(let d=0;d<o;++d){let f=s[r[d]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);l=l<<e|f,c+=e,c>=8&&(c-=8,i[u++]=255&l>>c)}if(c>=e||255&l<<8-c)throw new SyntaxError("Unexpected end of data");return i}function Xo(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,c=0;for(let l=0;l<r.length;++l)for(c=c<<8|r[l],i+=8;i>e;)i-=e,o+=t[s&c>>i];if(i!==0&&(o+=t[s&c<<e-i]),n)for(;o.length*e&7;)o+="=";return o}function M({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Pt({prefix:t,name:r,encode(s){return Xo(s,n,e)},decode(s){return Go(s,n,e,r)}})}var Qo=dt({prefix:"9",name:"base10",alphabet:"0123456789"});var Nr={};q(Nr,{base16:()=>jo,base16upper:()=>Ko});var jo=M({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Ko=M({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Br={};q(Br,{base2:()=>Jo});var Jo=M({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Rr={};q(Rr,{base256emoji:()=>ri});var cs=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),Zo=cs.reduce((r,t,e)=>(r[e]=t,r),[]),Yo=cs.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function ti(r){return r.reduce((t,e)=>(t+=Zo[e],t),"")}function ei(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=Yo[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var ri=Pt({prefix:"\u{1F680}",name:"base256emoji",encode:ti,decode:ei});var Or={};q(Or,{base32:()=>at,base32hex:()=>ii,base32hexpad:()=>ci,base32hexpadupper:()=>li,base32hexupper:()=>ai,base32pad:()=>si,base32padupper:()=>oi,base32upper:()=>ni,base32z:()=>ui});var at=M({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ni=M({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),si=M({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),oi=M({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),ii=M({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),ai=M({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),ci=M({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),li=M({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),ui=M({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var $r={};q($r,{base36:()=>Xt,base36upper:()=>hi});var Xt=dt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),hi=dt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var zr={};q(zr,{base58btc:()=>B,base58flickr:()=>fi});var B=dt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),fi=dt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Hr={};q(Hr,{base64:()=>ct,base64pad:()=>di,base64url:()=>Vr,base64urlpad:()=>pi});var ct=M({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),di=M({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Vr=M({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),pi=M({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var qr={};q(qr,{base8:()=>mi});var mi=M({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Wr={};q(Wr,{identity:()=>gi});var gi=Pt({prefix:"\0",name:"identity",encode:r=>ss(r),decode:r=>ns(r)});var Bl=new TextEncoder,Rl=new TextDecoder;var Xr={};q(Xr,{identity:()=>Oi});var xi=hs,ls=128,yi=127,vi=~yi,Ei=Math.pow(2,31);function hs(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Ei;)t[e++]=r&255|ls,r/=128;for(;r&vi;)t[e++]=r&255|ls,r>>>=7;return t[e]=r|0,hs.bytes=e-n+1,t}var ki=Gr,Si=128,us=127;function Gr(r,n){var e=0,n=n||0,s=0,o=n,i,c=r.length;do{if(o>=c)throw Gr.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&us)<<s:(i&us)*Math.pow(2,s),s+=7}while(i>=Si);return Gr.bytes=o-n,e}var Ai=Math.pow(2,7),Li=Math.pow(2,14),Ii=Math.pow(2,21),Ti=Math.pow(2,28),Di=Math.pow(2,35),Pi=Math.pow(2,42),_i=Math.pow(2,49),Ui=Math.pow(2,56),Ci=Math.pow(2,63),Mi=function(r){return r<Ai?1:r<Li?2:r<Ii?3:r<Ti?4:r<Di?5:r<Pi?6:r<_i?7:r<Ui?8:r<Ci?9:10},Fi={encode:xi,decode:ki,encodingLength:Mi},Ni=Fi,Qt=Ni;function jt(r,t=0){return[Qt.decode(r,t),Qt.decode.bytes]}function _t(r,t,e=0){return Qt.encode(r,t,e),t}function Ut(r){return Qt.encodingLength(r)}function bt(r,t){let e=t.byteLength,n=Ut(r),s=n+Ut(e),o=new Uint8Array(s+e);return _t(r,o,0),_t(e,o,n),o.set(t,s),new Ct(r,e,t,o)}function Kt(r){let t=it(r),[e,n]=jt(t),[s,o]=jt(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Ct(e,s,i,t)}function fs(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&rs(r.bytes,e.bytes)}}var Ct=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var ds=0,Bi="identity",ps=it;function Ri(r){return bt(ds,ps(r))}var Oi={code:ds,name:Bi,encode:ps,digest:Ri};var Kr={};q(Kr,{sha256:()=>_e,sha512:()=>$i});function jr({name:r,code:t,encode:e}){return new Qr(r,t,e)}var Qr=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?bt(this.code,e):e.then(n=>bt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function gs(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var _e=jr({name:"sha2-256",code:18,encode:gs("SHA-256")}),$i=jr({name:"sha2-512",code:19,encode:gs("SHA-512")});function ws(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Vi(e,Jr(r),t??B.encoder);default:return Hi(e,Jr(r),t??at.encoder)}}var bs=new WeakMap;function Jr(r){let t=bs.get(r);if(t==null){let e=new Map;return bs.set(r,e),e}return t}var X=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==Jt)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==qi)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=bt(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&fs(t.multihash,n.multihash)}toString(t){return ws(this,t)}toJSON(){return{"/":ws(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??xs(n,s,o.bytes))}else if(e[Wi]===!0){let{version:n,multihash:s,code:o}=e,i=Kt(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==Jt)throw new Error(`Version 0 CID must use dag-pb (code: ${Jt}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=xs(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Jt,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=it(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new Ct(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[f,y]=jt(t.subarray(e));return e+=y,f},s=n(),o=Jt;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,c=n(),l=n(),u=e+l,d=u-i;return{version:s,codec:o,multihashCode:c,digestSize:l,multihashSize:d,size:u}}static parse(t,e){let[n,s]=zi(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Jr(o).set(n,t),o}};function zi(r,t){switch(r[0]){case"Q":{let e=t??B;return[B.prefix,e.decode(`${B.prefix}${r}`)]}case B.prefix:{let e=t??B;return[B.prefix,e.decode(r)]}case at.prefix:{let e=t??at;return[at.prefix,e.decode(r)]}case Xt.prefix:{let e=t??Xt;return[Xt.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Vi(r,t,e){let{prefix:n}=e;if(n!==B.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function Hi(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var Jt=112,qi=18;function xs(r,t,e){let n=Ut(r),s=n+Ut(t),o=new Uint8Array(s+e.byteLength);return _t(r,o,0),_t(t,o,n),o.set(e,s),o}var Wi=Symbol.for("@ipld/js-cid/CID");var Zt={...Wr,...Br,...qr,...Fr,...Nr,...Or,...$r,...zr,...Hr,...Rr},iu={...Kr,...Xr};function vs(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var ys=vs("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Zr=vs("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=O(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Gi={utf8:ys,"utf-8":ys,hex:Zt.base16,latin1:Zr,ascii:Zr,binary:Zr,...Zt},Ue=Gi;function pt(r,t="utf8"){let e=Ue[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Yr(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return O(i);s+i>t&&(n=O(t),s=0);let c=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),c}}var yt=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function tn(){}var rn=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Xi=Yr();function Qi(r){return globalThis.Buffer!=null?O(r):Xi(r)}var te=class{len;head;tail;states;constructor(){this.len=0,this.head=new yt(tn,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new yt(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new nn((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(Ce,10,G.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=G.fromBigInt(t);return this._push(Ce,e.length(),e)}uint64Number(t){return this._push(vr,P(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=G.fromBigInt(t).zzEncode();return this._push(Ce,e.length(),e)}sint64Number(t){let e=G.fromNumber(t).zzEncode();return this._push(Ce,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(en,1,t?1:0)}fixed32(t){return this._push(Yt,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=G.fromBigInt(t);return this._push(Yt,4,e.lo)._push(Yt,4,e.hi)}fixed64Number(t){let e=G.fromNumber(t);return this._push(Yt,4,e.lo)._push(Yt,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Qn,4,t)}double(t){return this._push(Kn,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(en,1,0):this.uint32(e)._push(Ki,e,t)}string(t){let e=Yn(t);return e!==0?this.uint32(e)._push(Tr,e,t):this._push(en,1,0)}fork(){return this.states=new rn(this),this.head=this.tail=new yt(tn,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new yt(tn,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=Qi(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function en(r,t,e){t[e]=r&255}function ji(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var nn=class extends yt{next;constructor(t,e){super(ji,t,e),this.next=void 0}};function Ce(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Yt(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Ki(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(te.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Ji,t,r),this},te.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Zi,t,r),this});function Ji(r,t,e){t.set(r,e)}function Zi(r,t,e){r.length<40?Tr(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(pt(r),e)}function sn(){return new te}function vt(r,t){let e=sn();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Mt;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(Mt||(Mt={}));function Me(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Fe(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let c=t(o);i.int32(c)},n=function(o){let i=o.int32();return t(i)};return Me("enum",Mt.VARINT,e,n)}function Et(r,t){return Me("message",Mt.LENGTH_DELIMITED,r,t)}var Ft=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var F;(function(r){r.WantBlock="WantBlock",r.WantHave="WantHave"})(F||(F={}));var on;(function(r){r[r.WantBlock=0]="WantBlock",r[r.WantHave=1]="WantHave"})(on||(on={}));(function(r){r.codec=()=>Fe(on)})(F||(F={}));var Nt;(function(r){let t;r.codec=()=>(t==null&&(t=Et((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.cid!=null&&e.cid.byteLength>0&&(n.uint32(10),n.bytes(e.cid)),e.priority!=null&&e.priority!==0&&(n.uint32(16),n.int32(e.priority)),e.cancel!=null&&(n.uint32(24),n.bool(e.cancel)),e.wantType!=null&&(n.uint32(32),F.codec().encode(e.wantType,n)),e.sendDontHave!=null&&(n.uint32(40),n.bool(e.sendDontHave)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={cid:R(0),priority:0},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let c=e.uint32();switch(c>>>3){case 1:{o.cid=e.bytes();break}case 2:{o.priority=e.int32();break}case 3:{o.cancel=e.bool();break}case 4:{o.wantType=F.codec().decode(e);break}case 5:{o.sendDontHave=e.bool();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>vt(e,r.codec()),r.decode=(e,n)=>wt(e,r.codec(),n)})(Nt||(Nt={}));var Ne;(function(r){let t;r.codec=()=>(t==null&&(t=Et((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.entries!=null)for(let o of e.entries)n.uint32(10),Nt.codec().encode(o,n);e.full!=null&&(n.uint32(16),n.bool(e.full)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={entries:[]},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let c=e.uint32();switch(c>>>3){case 1:{if(s.limits?.entries!=null&&o.entries.length===s.limits.entries)throw new Ft('Decode error - map field "entries" had too many elements');o.entries.push(Nt.codec().decode(e,e.uint32(),{limits:s.limits?.entries$}));break}case 2:{o.full=e.bool();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>vt(e,r.codec()),r.decode=(e,n)=>wt(e,r.codec(),n)})(Ne||(Ne={}));var Bt;(function(r){let t;r.codec=()=>(t==null&&(t=Et((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.prefix!=null&&e.prefix.byteLength>0&&(n.uint32(10),n.bytes(e.prefix)),e.data!=null&&e.data.byteLength>0&&(n.uint32(18),n.bytes(e.data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={prefix:R(0),data:R(0)},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let c=e.uint32();switch(c>>>3){case 1:{o.prefix=e.bytes();break}case 2:{o.data=e.bytes();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>vt(e,r.codec()),r.decode=(e,n)=>wt(e,r.codec(),n)})(Bt||(Bt={}));var j;(function(r){r.HaveBlock="HaveBlock",r.DontHaveBlock="DontHaveBlock"})(j||(j={}));var Be;(function(r){r[r.HaveBlock=0]="HaveBlock",r[r.DontHaveBlock=1]="DontHaveBlock"})(Be||(Be={}));(function(r){r.codec=()=>Fe(Be)})(j||(j={}));var Rt;(function(r){let t;r.codec=()=>(t==null&&(t=Et((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.cid!=null&&e.cid.byteLength>0&&(n.uint32(10),n.bytes(e.cid)),e.type!=null&&Be[e.type]!==0&&(n.uint32(16),j.codec().encode(e.type,n)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={cid:R(0),type:j.HaveBlock},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let c=e.uint32();switch(c>>>3){case 1:{o.cid=e.bytes();break}case 2:{o.type=j.codec().decode(e);break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>vt(e,r.codec()),r.decode=(e,n)=>wt(e,r.codec(),n)})(Rt||(Rt={}));var kt;(function(r){let t;r.codec=()=>(t==null&&(t=Et((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.wantlist!=null&&(n.uint32(10),Ne.codec().encode(e.wantlist,n)),e.blocks!=null)for(let o of e.blocks)n.uint32(26),Bt.codec().encode(o,n);if(e.blockPresences!=null)for(let o of e.blockPresences)n.uint32(34),Rt.codec().encode(o,n);e.pendingBytes!=null&&e.pendingBytes!==0&&(n.uint32(40),n.int32(e.pendingBytes)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={blocks:[],blockPresences:[],pendingBytes:0},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let c=e.uint32();switch(c>>>3){case 1:{o.wantlist=Ne.codec().decode(e,e.uint32(),{limits:s.limits?.wantlist});break}case 3:{if(s.limits?.blocks!=null&&o.blocks.length===s.limits.blocks)throw new Ft('Decode error - map field "blocks" had too many elements');o.blocks.push(Bt.codec().decode(e,e.uint32(),{limits:s.limits?.blocks$}));break}case 4:{if(s.limits?.blockPresences!=null&&o.blockPresences.length===s.limits.blockPresences)throw new Ft('Decode error - map field "blockPresences" had too many elements');o.blockPresences.push(Rt.codec().decode(e,e.uint32(),{limits:s.limits?.blockPresences$}));break}case 5:{o.pendingBytes=e.int32();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>vt(e,r.codec()),r.decode=(e,n)=>wt(e,r.codec(),n)})(kt||(kt={}));function Es(r,t){for(let[e,n]of t.wantlist.entries()){let s=r.wantlist.get(e);s!=null&&(s.priority>n.priority&&(n.priority=s.priority),n.cancel=n.cancel??s.cancel,n.wantType=n.wantType??s.wantType,n.sendDontHave=n.sendDontHave??s.sendDontHave),r.wantlist.set(e,n)}for(let[e,n]of t.blockPresences.entries())r.blockPresences.set(e,n);for(let[e,n]of t.blocks.entries())r.blocks.set(e,n);return t.full&&!r.full&&(r.full=!0),r}var Re=class extends Error{static name="BlockTooLargeError";constructor(t="Block too large"){super(t),this.name="BlockTooLargeError"}};var Yi=4193648,ta=Yi+16;function*ks(r,t){let e=[...r.wantlist.values()],n=[...r.blockPresences.values()],s=[...r.blocks.values()],o=0,i=0,c=0,l=!1;for(;;){let u={wantlist:{full:r.full??!1,entries:[]},blockPresences:[],blocks:[],pendingBytes:0},d=kt.encode(u).byteLength,{added:f,hasMore:y,newSize:a}=an(s,u.blocks,c,t,d,ea);c+=f,d=a;let h=y;({added:f,hasMore:y,newSize:a}=an(n,u.blockPresences,i,t,d,ra)),i+=f,d=a;let p=y;if({added:f,hasMore:y,newSize:a}=an(e,u.wantlist.entries,o,t,d,na),o+=f,d=a,l=!h&&!p&&!y,l||(u.wantlist.full=!1),yield kt.encode(u),l)break}}function an(r,t,e,n,s,o){let i=0,c=!1;for(let l=e;l<r.length;l++){let u=r[l],d=o(u);if(d>ta)throw new Re("Cannot send block as after encoding it is over the max message size");let f=s+d;if(f>n){c=!0;break}t.push(u),i++,s=f}return{hasMore:c,added:i,newSize:s}}function ea(r){return cn(3,Bt.encode(r))}function ra(r){return cn(4,Rt.encode(r))}function na(r){return cn(1,Nt.encode(r))}function cn(r,t){let e=P(r),n=P(t.byteLength);return e+n+t.byteLength}var Oe=class extends tt{log;libp2p;routing;protocols;running;maxInboundStreams;maxOutboundStreams;messageReceiveTimeout;registrarIds;metrics;sendQueue;runOnLimitedConnections;maxOutgoingMessageSize;maxIncomingMessageSize;constructor(t,e={}){super(),this.log=t.logger.forComponent("helia:bitswap:network"),this.libp2p=t.libp2p,this.routing=t.routing,this.protocols=e.protocols??[Gt],this.registrarIds=[],this.running=!1,this._onStream=this._onStream.bind(this),this.maxInboundStreams=e.maxInboundStreams??1024,this.maxOutboundStreams=e.maxOutboundStreams??1024,this.messageReceiveTimeout=e.messageReceiveTimeout??5e3,this.runOnLimitedConnections=e.runOnLimitedConnections??!1,this.maxIncomingMessageSize=e.maxIncomingMessageSize??4194304,this.maxOutgoingMessageSize=e.maxOutgoingMessageSize??e.maxIncomingMessageSize??4194304,this.metrics={blocksSent:t.metrics?.registerCounter("helia_bitswap_sent_blocks_total"),dataSent:t.metrics?.registerCounter("helia_bitswap_sent_data_bytes_total")},this.sendQueue=new ye({concurrency:e.messageSendConcurrency??50,metrics:t.metrics,metricName:"helia_bitswap_message_send_queue"}),this.sendQueue.addEventListener("error",n=>{this.log.error("error sending wantlist to peer",n.detail)})}async start(){if(this.running)return;this.running=!0,await this.libp2p.handle(this.protocols,this._onStream,{maxInboundStreams:this.maxInboundStreams,maxOutboundStreams:this.maxOutboundStreams,runOnLimitedConnection:this.runOnLimitedConnections});let t={onConnect:e=>{this.safeDispatchEvent("peer:connected",{detail:e})},onDisconnect:e=>{this.safeDispatchEvent("peer:disconnected",{detail:e})}};this.registrarIds=[];for(let e of this.protocols)this.registrarIds.push(await this.libp2p.register(e,t));this.libp2p.getConnections().forEach(e=>{this.safeDispatchEvent("peer:connected",{detail:e.remotePeer})})}async stop(){if(this.running=!1,await this.libp2p.unhandle(this.protocols),this.registrarIds!=null){for(let t of this.registrarIds)this.libp2p.unregister(t);this.registrarIds=[]}}_onStream(t){if(!this.running)return;let{stream:e,connection:n}=t;Promise.resolve().then(async()=>{this.log("incoming new bitswap %s stream from %p",e.protocol,n.remotePeer);let s=()=>{e.status==="open"?e.abort(new pe(`Incoming Bitswap stream timed out after ${this.messageReceiveTimeout}ms`)):this.log("stream aborted with status %s",e.status)},o=AbortSignal.timeout(this.messageReceiveTimeout);W(1/0,o),o.addEventListener("abort",s),await e.closeWrite(),await Ar(e,i=>Wt(i,{maxDataLength:this.maxIncomingMessageSize}),async i=>{for await(let c of i)try{let l=kt.decode(c);this.log("incoming new bitswap %s message from %p on stream",e.protocol,n.remotePeer,e.id),this.safeDispatchEvent("bitswap:message",{detail:{peer:n.remotePeer,message:l}}),o.removeEventListener("abort",s),o=AbortSignal.timeout(this.messageReceiveTimeout),W(1/0,o),o.addEventListener("abort",s)}catch(l){this.log.error("error reading incoming bitswap message from %p on stream",n.remotePeer,e.id,l),e.abort(l);break}})}).catch(s=>{this.log.error("error handling incoming stream from %p",n.remotePeer,s),e.abort(s)})}async*findProviders(t,e){e?.onProgress?.(new rt("bitswap:network:find-providers",t));for await(let n of this.routing.findProviders(t,e))await this.libp2p.isDialable(n.multiaddrs,{runOnLimitedConnection:this.runOnLimitedConnections})&&(yield n)}async findAndConnect(t,e){await gr(Hn(Xn(this.findProviders(t,e),e?.maxProviders??3),async n=>this.connectTo(n.id,e))).catch(n=>{this.log.error(n)})}async sendMessage(t,e,n){if(!this.running)throw new Error("network isn't running");let s=this.sendQueue.queue.find(o=>t.equals(o.options.peerId)&&o.status==="queued");if(s!=null){s.options.message=Es(s.options.message,e),await s.join({signal:n?.signal});return}await this.sendQueue.add(async o=>{let i=o?.message;if(i==null)throw new Lt("No message to send");this.log("sendMessage to %p",t),o?.onProgress?.(new rt("bitswap:network:send-wantlist",t));let c=await this.libp2p.dialProtocol(t,Gt,o);await c.closeRead();try{await Ar(ks(i,this.maxOutgoingMessageSize),l=>Ae(l),c),await c.close(o)}catch(l){o?.onProgress?.(new rt("bitswap:network:send-wantlist:error",{peer:t,error:l})),this.log.error("error sending message to %p",t,l),c.abort(l)}this._updateSentStats(i.blocks)},{peerId:t,signal:n?.signal,message:e})}async connectTo(t,e){if(!this.running)throw new me("Network isn't running");e?.onProgress?.(new rt("bitswap:network:dial",t));let[n]=await Promise.all([this.libp2p.dial(t,e),J(this.libp2p,"peer:identify",e?.signal,{filter:s=>{if(!s.detail.peerId.equals(t))return!1;if(s.detail.protocols.includes(Gt))return!0;throw new de(`${t} did not support ${Gt}`)}})]);return n}_updateSentStats(t){let e=0;for(let n of t.values())e+=n.data.byteLength;this.metrics.dataSent?.increment(e),this.metrics.blocksSent?.increment(t.size)}};var St=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var ih=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var ah={}.toString;function Ss(r=32){if(St&&typeof St.getRandomValues=="function")return St.getRandomValues(new Uint8Array(r));if(St&&typeof St.randomBytes=="function")return St.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function U(r,t="utf8"){let e=Ue[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function $e(r){if(isNaN(r)||r<=0)throw new Lt("random bytes length must be a Number bigger than 0");return Ss(r)}function ze(r,t){let e={[Symbol.iterator]:()=>e,next:()=>{let n=r.next(),s=n.value;return n.done===!0||s==null?{done:!0,value:void 0}:{done:!1,value:t(s)}}};return e}var ee=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[e,n]of t.entries())this.map.set(e.toString(),{key:e,value:n})}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){return this.map.delete(t.toString())}entries(){return ze(this.map.entries(),t=>[t[1].key,t[1].value])}forEach(t){this.map.forEach((e,n)=>{t(e.value,e.key,this)})}get(t){return this.map.get(t.toString())?.value}has(t){return this.map.has(t.toString())}set(t,e){this.map.set(t.toString(),{key:t,value:e})}keys(){return ze(this.map.values(),t=>t.key)}values(){return ze(this.map.values(),t=>t.value)}get size(){return this.map.size}};var ln=class extends ee{metric;constructor(t){super();let{name:e,metrics:n}=t;this.metric=n.registerMetric(e),this.updateComponentMetric()}set(t,e){return super.set(t,e),this.updateComponentMetric(),this}delete(t){let e=super.delete(t);return this.updateComponentMetric(),e}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function ne(r){let{name:t,metrics:e}=r,n;return e!=null?n=new ln({name:t,metrics:e}):n=new ee,n}var lt=class{full;pendingBytes;wantlist;blocks;blockPresences;constructor(t=!1,e=0){this.full=t,this.wantlist=new Map,this.blocks=new Map,this.blockPresences=new Map,this.pendingBytes=0}addWantlistEntry(t,e){let n=ct.encode(t.multihash.bytes);this.wantlist.set(n,e)}addBlockPresence(t,e){let n=ct.encode(t.multihash.bytes);this.blockPresences.set(n,e)}addBlock(t,e){let n=ct.encode(t.multihash.bytes);this.blocks.set(n,e)}};function fa(r){let t=new Uint8Array(r.reduce((n,s)=>n+P(s),0)),e=0;for(let n of r)t=et(n,t,e),e+=P(n);return t}var Ts=fa;function un(r){return Ts([r.version,r.code,r.multihash.code,r.multihash.digest.byteLength])}var He=class{peerId;blockstore;network;wants;exchangeCount;bytesSent;bytesReceived;lastExchange;maxSizeReplaceHasWithBlock;log;constructor(t,e){this.peerId=t.peerId,this.blockstore=t.blockstore,this.network=t.network,this.wants=new Map,this.log=t.logger.forComponent(`helia:bitswap:ledger:${t.peerId}`),this.exchangeCount=0,this.bytesSent=0,this.bytesReceived=0,this.maxSizeReplaceHasWithBlock=e.maxSizeReplaceHasWithBlock??1024}sentBytes(t){this.exchangeCount++,this.lastExchange=new Date().getTime(),this.bytesSent+=t}receivedBytes(t){this.exchangeCount++,this.lastExchange=new Date().getTime(),this.bytesReceived+=t}debtRatio(){return this.bytesSent/(this.bytesReceived+1)}async sendBlocksToPeer(t){let e=new lt,n=new Set;for(let[s,o]of this.wants.entries())try{let i=await this.blockstore.get(o.cid,t);o.wantType===F.WantHave?i.byteLength<this.maxSizeReplaceHasWithBlock?(this.log("sending have and block for %c",o.cid),n.add(s),e.addBlock(o.cid,{data:i,prefix:un(o.cid)})):(this.log("sending have for %c",o.cid),e.addBlockPresence(o.cid,{cid:o.cid.bytes,type:j.HaveBlock})):(this.log("sending block for %c",o.cid),n.add(s),e.addBlock(o.cid,{data:i,prefix:un(o.cid)}))}catch(i){if(i.name!=="NotFoundError")throw i;if(this.log("do not have block for %c",o.cid),!o.sendDontHave||o.sentDontHave===!0)continue;o.sentDontHave=!0,e.addBlockPresence(o.cid,{cid:o.cid.bytes,type:j.DontHaveBlock})}if(e.blocks.size>0||e.blockPresences.size>0){this.log("sending message"),await this.network.sendMessage(this.peerId,e,t),this.log("sent message"),this.sentBytes([...e.blocks.values()].reduce((s,o)=>s+o.data.byteLength,0));for(let s of n)this.wants.delete(s)}}};var qe=class{blockstore;network;ledgerMap;maxSizeReplaceHasWithBlock;log;logger;constructor(t,e={}){this.blockstore=t.blockstore,this.network=t.network,this.maxSizeReplaceHasWithBlock=e.maxSizeReplaceHasWithBlock,this.log=t.logger.forComponent("helia:bitswap:peer-want-lists"),this.logger=t.logger,this.ledgerMap=ne({name:"helia_bitswap_ledger_map",metrics:t.metrics}),this.network.addEventListener("bitswap:message",n=>{this.receiveMessage(n.detail.peer,n.detail.message).catch(s=>{this.log.error("error receiving bitswap message from %p",n.detail.peer,s)})}),this.network.addEventListener("peer:disconnected",n=>{this.peerDisconnected(n.detail)})}ledgerForPeer(t){let e=this.ledgerMap.get(t);if(e!=null)return{peer:e.peerId,value:e.debtRatio(),sent:e.bytesSent,received:e.bytesReceived,exchanged:e.exchangeCount}}wantListForPeer(t){let e=this.ledgerMap.get(t);if(e!=null)return[...e.wants.values()]}peers(){return Array.from(this.ledgerMap.values()).map(t=>t.peerId)}async receiveMessage(t,e){let n=this.ledgerMap.get(t);if(n==null&&(n=new He({peerId:t,blockstore:this.blockstore,network:this.network,logger:this.logger},{maxSizeReplaceHasWithBlock:this.maxSizeReplaceHasWithBlock}),this.ledgerMap.set(t,n)),n.receivedBytes(e.blocks?.reduce((s,o)=>s+o.data.byteLength,0)??0),e.wantlist!=null){e.wantlist.full===!0&&n.wants.clear();for(let s of e.wantlist.entries){let o=X.decode(s.cid),i=U(o.multihash.bytes,"base64");s.cancel===!0?(this.log("peer %p cancelled want of block for %c",t,o),n.wants.delete(i)):(s.wantType===F.WantHave?this.log("peer %p wanted block presence for %c",t,o):this.log("peer %p wanted block for %c",t,o),n.wants.set(i,{cid:o,priority:s.priority,wantType:s.wantType??F.WantBlock,sendDontHave:s.sendDontHave??!1}))}}this.log("send blocks to peer"),await n.sendBlocksToPeer()}async receivedBlock(t,e){let n=U(t.multihash.bytes,"base64"),s=[];for(let o of this.ledgerMap.values())o.wants.has(n)&&s.push(o);await Promise.all(s.map(async o=>o.sendBlocksToPeer(e)))}peerDisconnected(t){this.ledgerMap.delete(t)}};var ma=dr(Ps(),1);var Ot;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(Ot||(Ot={}));var We=class extends Error{static name="InsufficientProvidersError";constructor(t="Insufficient providers found"){super(t),this.name="InsufficientProvidersError"}};var hn=dr(Is(),1);var ga=Math.LN2*Math.LN2,Ge=class r{static create(t,e=.005){let n=wa(t,e);return new r(n)}seeds;bits;buffer;constructor(t={}){t.seeds!=null?this.seeds=t.seeds:this.seeds=ba(t.hashes??8),this.bits=t.bits??1024,this.buffer=R(Math.ceil(this.bits/8))}add(t){typeof t=="string"&&(t=pt(t));for(let e=0;e<this.seeds.length;e++){let s=hn.default.x86.hash32(t,this.seeds[e])%this.bits;this.setbit(s)}}has(t){typeof t=="string"&&(t=pt(t));for(let e=0;e<this.seeds.length;e++){let s=hn.default.x86.hash32(t,this.seeds[e])%this.bits;if(!this.getbit(s))return!1}return!0}clear(){this.buffer.fill(0)}setbit(t){let e=0,n=t;for(;n>7;)e++,n-=8;let s=this.buffer[e];s|=1<<n,this.buffer[e]=s}getbit(t){let e=0,n=t;for(;n>7;)e++,n-=8;return(this.buffer[e]&1<<n)!==0}};function wa(r,t=.005){let e=Math.round(-1*r*Math.log(t)/ga),n=Math.round(e/r*Math.LN2);return{bits:e,hashes:n}}function ba(r){let t,e,n=[];for(let s=0;s<r;s++)for(t=new ht($e(4)),n[s]=t.getUint32(0,!0),e=0;e<s;e++)if(n[s]===n[e]){s--;break}return n}var At=class extends tt{intialPeerSearchComplete;requests;name;log;logger;minProviders;maxProviders;providers;evictionFilter;constructor(t,e){super(),W(1/0,this),this.name=e.name,this.logger=t.logger,this.log=t.logger.forComponent(this.name),this.requests=new Map,this.minProviders=e.minProviders??1,this.maxProviders=e.maxProviders??5,this.providers=[],this.evictionFilter=Ge.create(this.maxProviders)}async retrieve(t,e={}){let n=ct.encode(t.multihash.bytes),s=this.requests.get(n);if(s!=null)return this.log("join existing request for %c",t),s;let o=K();if(this.requests.set(n,o.promise),this.providers.length===0){let u=!1;this.intialPeerSearchComplete==null&&(u=!0,this.log=this.logger.forComponent(`${this.name}:${t}`),this.intialPeerSearchComplete=this.findProviders(t,this.minProviders,e)),await this.intialPeerSearchComplete,u&&this.log("found initial session peers for %c",t)}let i=!1,c=new Dt({concurrency:this.maxProviders});c.addEventListener("error",()=>{}),c.addEventListener("failure",u=>{this.log.error("error querying provider %o, evicting from session",u.detail.job.options.provider,u.detail.error),this.evict(u.detail.job.options.provider)}),c.addEventListener("success",u=>{i=!0,o.resolve(u.detail.result)}),c.addEventListener("idle",()=>{i||e.signal?.aborted===!0||Promise.resolve().then(async()=>{this.log("no session peers had block for for %c, finding new providers",t);for(let u=0;u<this.minProviders&&this.providers.length!==0;u++){let d=this.providers[Math.floor(Math.random()*this.providers.length)];this.evict(d)}await this.findProviders(t,this.minProviders,e),this.log("found new providers re-retrieving %c",t),this.requests.delete(n),o.resolve(await this.retrieve(t,e))}).catch(u=>{this.log.error("could not find new providers for %c",t,u),o.reject(u)})});let l=u=>{c.add(async()=>this.queryProvider(t,u.detail,e),{provider:u.detail}).catch(d=>{e.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c",t,d)})};this.addEventListener("provider",l),Promise.all([...this.providers].map(async u=>c.add(async()=>this.queryProvider(t,u,e),{provider:u}))).catch(u=>{e.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c",t,u)});try{return await o.promise}finally{this.removeEventListener("provider",l),c.clear(),this.requests.delete(n)}}evict(t){this.evictionFilter.add(this.toEvictionKey(t));let e=this.providers.findIndex(n=>this.equals(n,t));e!==-1&&this.providers.splice(e,1)}isEvicted(t){return this.evictionFilter.has(this.toEvictionKey(t))}hasProvider(t){return!!(this.providers.find(e=>this.equals(e,t))!=null||this.isEvicted(t))}async findProviders(t,e,n){let s=K(),o=0;return Promise.resolve().then(async()=>{this.log("finding %d-%d new provider(s) for %c",e,this.maxProviders,t);for await(let i of this.findNewProviders(t,n)){if(o===this.maxProviders||n.signal?.aborted===!0)break;if(!this.hasProvider(i)&&(this.log("found %d/%d new providers",o,this.maxProviders),this.providers.push(i),this.safeDispatchEvent("provider",{detail:i}),o++,o===e&&(this.log("session is ready"),s.resolve()),this.providers.length===this.maxProviders)){this.log("found max session peers",o);break}}if(this.log("found %d/%d new session peers",o,this.maxProviders),o<e)throw new We(`Found ${o} of ${e} ${this.name} providers for ${t}`)}).catch(i=>{this.log.error("error searching routing for potential session peers for %c",t,i.errors??i),s.reject(i)}),s.promise}};var fn=class extends At{wantList;network;constructor(t,e){super(t,{...e,name:"helia:bitswap:session"}),this.wantList=t.wantList,this.network=t.network}async queryProvider(t,e,n){this.log("sending WANT-BLOCK for %c to %p",t,e);let s=await this.wantList.wantSessionBlock(t,e,n);if(this.log("%p %s %c",e,s.has?"has":"does not have",t),s.has&&s.block!=null)return s.block;throw new Error("Provider did not have block")}async*findNewProviders(t,e={}){for await(let n of this.network.findProviders(t,e))yield n.id}toEvictionKey(t){return t.toMultihash().bytes}equals(t,e){return t.equals(e)}};function _s(r,t){return new fn(r,t)}var Xe=class{blocksReceived;duplicateBlocksReceived;dataReceived;duplicateDataReceived;constructor(t){this.blocksReceived=t.metrics?.registerMetricGroup("helia_bitswap_received_blocks"),this.duplicateBlocksReceived=t.metrics?.registerMetricGroup("helia_bitswap_duplicate_received_blocks"),this.dataReceived=t.metrics?.registerMetricGroup("helia_bitswap_data_received_bytes"),this.duplicateDataReceived=t.metrics?.registerMetricGroup("helia_bitswap_duplicate_data_received_bytes")}updateBlocksReceived(t=1,e){let n={global:t};e!=null&&(n[e.toString()]=t),this.blocksReceived?.increment(n)}updateDuplicateBlocksReceived(t=1,e){let n={global:t};e!=null&&(n[e.toString()]=t),this.duplicateBlocksReceived?.increment(n)}updateDataReceived(t,e){let n={global:t};e!=null&&(n[e.toString()]=t),this.dataReceived?.increment(n)}updateDuplicateDataReceived(t,e){let n={global:t};e!=null&&(n[e.toString()]=t),this.duplicateDataReceived?.increment(n)}};var dn=class extends Map{metric;constructor(t){super();let{name:e,metrics:n}=t;this.metric=n.registerMetric(e),this.updateComponentMetric()}set(t,e){return super.set(t,e),this.updateComponentMetric(),this}delete(t){let e=super.delete(t);return this.updateComponentMetric(),e}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function Us(r){let{name:t,metrics:e}=r,n;return e!=null?n=new dn({name:t,metrics:e}):n=new Map,n}function va(r){if(!(r instanceof Uint8Array))throw new Error("arg needs to be a Uint8Array");let t=[];for(;r.length>0;){let e=Z(r);t.push(e),r=r.slice(P(e))}return t}var Cs=va;var Qe=class extends tt{peers;wants;network;log;sendMessagesDelay;sendMessagesTimeout;hashLoader;sendingMessages;constructor(t,e={}){super(),W(1/0,this),this.peers=ne({name:"helia_bitswap_peers",metrics:t.metrics}),this.wants=Us({name:"helia_bitswap_wantlist",metrics:t.metrics}),this.network=t.network,this.sendMessagesDelay=e.sendMessagesDelay??10,this.log=t.logger.forComponent("helia:bitswap:wantlist"),this.hashLoader=e.hashLoader,this.network.addEventListener("bitswap:message",n=>{this.receiveMessage(n.detail.peer,n.detail.message).catch(s=>{this.log.error("error receiving bitswap message from %p",n.detail.peer,s)})}),this.network.addEventListener("peer:connected",n=>{this.peerConnected(n.detail).catch(s=>{this.log.error("error processing newly connected bitswap peer %p",n.detail,s)})}),this.network.addEventListener("peer:disconnected",n=>{this.peerDisconnected(n.detail)})}async addEntry(t,e){let n=U(t.multihash.bytes,"base64"),s=this.wants.get(n);s==null&&(s={cid:t,priority:e.priority??1,wantType:e.wantType??F.WantBlock,cancel:!1,sendDontHave:!0},this.wants.set(n,s)),s.wantType===F.WantHave&&e.wantType===F.WantBlock&&(s.wantType=F.WantBlock),await this.sendMessagesDebounced();try{return e.wantType===F.WantBlock?(await J(this,"block",e?.signal,{filter:c=>ot(t.multihash.digest,c.detail.cid.multihash.digest),errorMessage:"Want was aborted"})).detail:(await J(this,"presence",e?.signal,{filter:i=>ot(t.multihash.digest,i.detail.cid.multihash.digest),errorMessage:"Want was aborted"})).detail}finally{e.signal?.aborted===!0&&(this.log("want for %c was aborted, cancelling want",t),s.cancel=!0,await this.sendMessagesDebounced())}}async sendMessagesDebounced(){await this.sendingMessages?.promise,clearTimeout(this.sendMessagesTimeout),this.sendMessagesTimeout=setTimeout(()=>{this.sendMessages().catch(t=>{this.log("error sending messages to peers",t)})},this.sendMessagesDelay)}async sendMessages(){this.sendingMessages=K(),await Promise.all([...this.peers.entries()].map(async([t,e])=>{let n=new Set,s=new lt;for(let[o,i]of this.wants.entries())e.has(o)||i.cancel||(n.add(o),s.addWantlistEntry(i.cid,{cid:i.cid.bytes,priority:i.priority,wantType:i.wantType,cancel:i.cancel,sendDontHave:i.sendDontHave}));if(s.wantlist.size!==0)try{await this.network.sendMessage(t,s);for(let o of n)e.add(o)}catch(o){this.log.error("error sending full wantlist to new peer",o)}})).catch(t=>{this.log.error("error sending messages",t)});for(let[t,e]of this.wants)if(e.cancel){this.wants.delete(t);for(let n of this.peers.values())n.delete(t)}this.sendingMessages.resolve()}has(t){let e=U(t.multihash.bytes,"base64");return this.wants.has(e)}async wantSessionPresence(t,e,n={}){let s=new lt;return s.addWantlistEntry(t,{cid:t.bytes,sendDontHave:!0,wantType:F.WantHave,priority:1}),await this.network.sendMessage(e,s),(await J(this,"presence",n.signal,{filter:i=>e.equals(i.detail.sender)&&ot(t.multihash.digest,i.detail.cid.multihash.digest)})).detail}async wantBlock(t,e={}){return this.addEntry(t,{...e,wantType:F.WantBlock})}async wantSessionBlock(t,e,n={}){let s=new lt;return s.addWantlistEntry(t,{cid:t.bytes,sendDontHave:!0,wantType:F.WantBlock,priority:1}),await this.network.sendMessage(e,s),(await J(this,"presence",n.signal,{filter:i=>e.equals(i.detail.sender)&&ot(t.multihash.digest,i.detail.cid.multihash.digest)})).detail}async receivedBlock(t,e){let n=U(t.multihash.bytes,"base64"),s=this.wants.get(n);s!=null&&(s.cancel=!0,await this.sendMessagesDebounced())}async receiveMessage(t,e){this.log("received message from %p with %d blocks",t,e.blocks.length);let n=!1;for(let s of e.blocks){if(s.prefix==null||s.data==null)continue;let o=Cs(s.prefix),i=o[0],c=o[1],l=o[2],u=l===_e.code?_e:await this.hashLoader?.getHasher(l);if(u==null){this.log.error("unknown hash algorithm",l);continue}let d=u.digest(s.data);d.then!=null&&(d=await d);let f=X.create(i===0?0:1,c,d);this.log("received block from %p for %c",t,f),this.safeDispatchEvent("block",{detail:{sender:t,cid:f,block:s.data}}),this.safeDispatchEvent("presence",{detail:{sender:t,cid:f,has:!0,block:s.data}});let y=U(f.multihash.bytes,"base64"),a=this.wants.get(y);a!=null&&(a.cancel=!0,n=!0)}for(let{cid:s,type:o}of e.blockPresences){let i=X.decode(s);this.log("received %s from %p for %c",o,t,i),this.safeDispatchEvent("presence",{detail:{sender:t,cid:i,has:o===j.HaveBlock}})}n&&await this.sendMessagesDebounced()}async peerConnected(t){let e=new Set,n=new lt(!0);for(let[s,o]of this.wants.entries())o.cancel||(e.add(s),n.addWantlistEntry(o.cid,{cid:o.cid.bytes,priority:1,wantType:F.WantBlock,cancel:!1,sendDontHave:!1}));if(n.wantlist.size===0){this.peers.set(t,e);return}try{await this.network.sendMessage(t,n),this.peers.set(t,e)}catch(s){this.log.error("error sending full wantlist to new peer %p",t,s)}}peerDisconnected(t){this.peers.delete(t)}start(){}stop(){this.peers.clear(),clearTimeout(this.sendMessagesTimeout)}};var je=class{log;logger;stats;network;blockstore;peerWantLists;wantList;constructor(t,e={}){this.logger=t.logger,this.log=t.logger.forComponent("helia:bitswap"),this.blockstore=t.blockstore,this.stats=new Xe(t),this.network=new Oe(t,e),this.peerWantLists=new qe({...t,network:this.network},e),this.wantList=new Qe({...t,network:this.network},e)}createSession(t={}){return _s({wantList:this.wantList,network:this.network,logger:this.logger},t)}async want(t,e={}){let n=new AbortController,s=Rn([n.signal,e.signal]);W(1/0,n.signal,s),this.network.findAndConnect(t,{...e,signal:s}).catch(o=>{n.signal.aborted||this.log.error("error during finding and connect for cid %c",t,o)});try{return(await this.wantList.wantBlock(t,{...e,signal:s})).block}finally{n.abort(),s.clear()}}async notify(t,e,n={}){await Promise.all([this.peerWantLists.receivedBlock(t,n),this.wantList.receivedBlock(t,n)])}getWantlist(){return[...this.wantList.wants.values()].filter(t=>!t.cancel).map(t=>({cid:t.cid,priority:t.priority,wantType:t.wantType}))}getPeerWantlist(t){return this.peerWantLists.wantListForPeer(t)}async start(){this.wantList.start(),await this.network.start()}async stop(){this.wantList.stop(),await this.network.stop()}};var Ms=(r,t={})=>new je(r,t);var pn=class{bitswap;started;constructor(t,e={}){let{getHasher:n}=t;this.bitswap=Ms(t,{hashLoader:{getHasher:async s=>n(s)},...e}),this.started=!1}isStarted(){return this.started}async start(){await this.bitswap.start(),this.started=!0}async stop(){await this.bitswap.stop(),this.started=!1}async announce(t,e,n){await this.bitswap.notify(t,e,n)}async retrieve(t,e={}){return this.bitswap.want(t,e)}createSession(t){let e=this.bitswap.createSession(t);return{announce:async(n,s,o)=>{await this.bitswap.notify(n,s,o)},retrieve:async(n,s)=>e.retrieve(n,s)}}};function Fs(r={}){return t=>new pn(t,r)}var Ke=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,s){return this.readAtomically(()=>{let o=0,i=0,c=this.peekChar();if(c===void 0)return;let l=c==="0",u=2**(8*s)-1;for(;;){let d=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let y=Number.parseInt(f,t);if(!Number.isNaN(y))return y});if(d===void 0)break;if(o*=t,o+=d,o>u||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&l&&i>1?void 0:o})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let s=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[s]=i[0],e[s+1]=i[1],e[s+2]=i[2],e[s+3]=i[3],[s+4,!0]}let o=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(o===void 0)return[s,!1];e[s]=o>>8,e[s+1]=o&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,s]=t(e);if(n===16)return e;if(s||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let o=new Uint8Array(14),i=16-(n+2),[c]=t(o.subarray(0,i));return e.set(o.subarray(0,c),16-c),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Ns=45,Ea=15,$t=new Ke;function mn(r){if(!(r.length>Ea))return $t.new(r).parseWith(()=>$t.readIPv4Addr())}function gn(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Ns))return $t.new(r).parseWith(()=>$t.readIPv6Addr())}function Je(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Ns))return $t.new(r).parseWith(()=>$t.readIPAddr())}function zt(r){return!!mn(r)}function Vt(r){return!!gn(r)}function Ze(r){return!!Je(r)}var Rs=dr(Bs(),1),ka=["0.0.0.0/8","10.0.0.0/8","100.64.0.0/10","127.0.0.0/8","169.254.0.0/16","172.16.0.0/12","192.0.0.0/24","192.0.0.0/29","192.0.0.8/32","192.0.0.9/32","192.0.0.10/32","192.0.0.170/32","192.0.0.171/32","192.0.2.0/24","192.31.196.0/24","192.52.193.0/24","192.88.99.0/24","192.168.0.0/16","192.175.48.0/24","198.18.0.0/15","198.51.100.0/24","203.0.113.0/24","240.0.0.0/4","255.255.255.255/32"],Sa=ka.map(r=>new Rs.Netmask(r));function wn(r){for(let t of Sa)if(t.contains(r))return!0;return!1}function Aa(r){return/^::ffff:([0-9a-fA-F]{1,4}):([0-9a-fA-F]{1,4})$/.test(r)}function La(r){let t=r.split(":");if(t.length<2)return!1;let e=t[t.length-1].padStart(4,"0"),n=t[t.length-2].padStart(4,"0"),s=`${parseInt(n.substring(0,2),16)}.${parseInt(n.substring(2),16)}.${parseInt(e.substring(0,2),16)}.${parseInt(e.substring(2),16)}`;return wn(s)}function Ia(r){return/^::ffff:([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)}function Ta(r){let t=r.split(":"),e=t[t.length-1];return wn(e)}function Da(r){return/^::$/.test(r)||/^::1$/.test(r)||/^64:ff9b::([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)||/^100::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001:2[0-9a-fA-F]:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001:db8:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2002:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^f[c-d]([0-9a-fA-F]{2,2}):/i.test(r)||/^fe[8-9a-bA-B][0-9a-fA-F]:/i.test(r)||/^ff([0-9a-fA-F]{2,2}):/i.test(r)}function Os(r){return zt(r)?wn(r):Aa(r)?La(r):Ia(r)?Ta(r):Vt(r)?Da(r):void 0}var Td=parseInt("0xFFFF",16),Dd=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Vs=zt,Ma=Vt,bn=function(r){let t=0;if(r=r.toString().trim(),Vs(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(Ma(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let o=Vs(e[n]),i;o&&(i=bn(e[n]),e[n]=U(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,U(i.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let o=[n,1];for(n=9-e.length;n>0;n--)o.push("0");e.splice.apply(e,o)}let s=new Uint8Array(t+16);for(n=0;n<e.length;n++){let o=parseInt(e[n],16);s[t++]=o>>8&255,s[t++]=o&255}return s}throw new Error("invalid ip address")},Hs=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let s=[];for(let o=0;o<e;o++)s.push(r[t+o]);return s.join(".")}if(e===16){let s=[];for(let o=0;o<e;o+=2)s.push(n.getUint16(t+o).toString(16));return s.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var Ht={},xn={},Na=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[481,-1,"http-path"],[777,-1,"memory"]];Na.forEach(r=>{let t=Ba(...r);xn[t.code]=t,Ht[t.name]=t});function Ba(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function k(r){if(typeof r=="number"){if(xn[r]!=null)return xn[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(Ht[r]!=null)return Ht[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var up=k("ip4"),hp=k("ip6"),fp=k("ipcidr");function kn(r,t){switch(k(r).code){case 4:case 41:return Oa(t);case 42:return En(t);case 6:case 273:case 33:case 132:return Gs(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return En(t);case 421:return Ha(t);case 444:return Ws(t);case 445:return Ws(t);case 466:return Va(t);case 481:return globalThis.encodeURIComponent(En(t));default:return U(t,"base16")}}function Sn(r,t){switch(k(r).code){case 4:return qs(t);case 41:return qs(t);case 42:return vn(t);case 6:case 273:case 33:case 132:return An(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return vn(t);case 421:return $a(t);case 444:return qa(t);case 445:return Wa(t);case 466:return za(t);case 481:return vn(globalThis.decodeURIComponent(t));default:return pt(t,"base16")}}var yn=Object.values(Zt).map(r=>r.decoder),Ra=function(){let r=yn[0].or(yn[1]);return yn.slice(2).forEach(t=>r=r.or(t)),r}();function qs(r){if(!Ze(r))throw new Error("invalid ip address");return bn(r)}function Oa(r){let t=Hs(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!Ze(t))throw new Error("invalid ip address");return t}function An(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Gs(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function vn(r){let t=pt(r),e=Uint8Array.from(et(t.length));return Q([e,t],e.length+t.length)}function En(r){let t=Z(r);if(r=r.slice(P(t)),r.length!==t)throw new Error("inconsistent lengths");return U(r)}function $a(r){let t;r[0]==="Q"||r[0]==="1"?t=Kt(B.decode(`z${r}`)).bytes:t=X.parse(r).multihash.bytes;let e=Uint8Array.from(et(t.length));return Q([e,t],e.length+t.length)}function za(r){let t=Ra.decode(r),e=Uint8Array.from(et(t.length));return Q([e,t],e.length+t.length)}function Va(r){let t=Z(r),e=r.slice(P(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+U(e,"base64url")}function Ha(r){let t=Z(r),e=r.slice(P(t));if(e.length!==t)throw new Error("inconsistent lengths");return U(e,"base58btc")}function qa(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let e=at.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=An(n);return Q([e,s],e.length+s.length)}function Wa(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let e=at.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=An(n);return Q([e,s],e.length+s.length)}function Ws(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=U(t,"base32"),s=Gs(e);return`${n}:${s}`}function Xs(r){r=Ln(r);let t=[],e=[],n=null,s=r.split("/").slice(1);if(s.length===1&&s[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let o=0;o<s.length;o++){let i=s[o],c=k(i);if(c.size===0){t.push([c.code]),e.push([c.code]);continue}if(o++,o>=s.length)throw js("invalid address: "+r);if(c.path===!0){n=Ln(s.slice(o).join("/")),t.push([c.code,Sn(c.code,n)]),e.push([c.code,n]);break}let l=Sn(c.code,s[o]);t.push([c.code,l]),e.push([c.code,kn(c.code,l)])}return{string:Qs(e),bytes:Tn(t),tuples:t,stringTuples:e,path:n}}function In(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let o=Z(r,s),i=P(o),c=k(o),l=Ga(c,r.slice(s+i));if(l===0){t.push([o]),e.push([o]),s+=i;continue}let u=r.slice(s+i,s+i+l);if(s+=l+i,s>r.length)throw js("Invalid address Uint8Array: "+U(r,"base16"));t.push([o,u]);let d=kn(o,u);if(e.push([o,d]),c.path===!0){n=d;break}}return{bytes:Uint8Array.from(r),string:Qs(e),tuples:t,stringTuples:e,path:n}}function Qs(r){let t=[];return r.map(e=>{let n=k(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Ln(t.join("/"))}function Tn(r){return Q(r.map(t=>{let e=k(t[0]),n=Uint8Array.from(et(e.code));return t.length>1&&t[1]!=null&&(n=Q([n,t[1]])),n}))}function Ga(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Z(t instanceof Uint8Array?t:Uint8Array.from(t));return e+P(e)}}function Ln(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function js(r){return new Error("Error parsing address: "+r)}var Xa=Symbol.for("nodejs.util.inspect.custom"),Pn=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Qa=[k("dns").code,k("dns4").code,k("dns6").code,k("dnsaddr").code],Dn=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},Ye=class r{bytes;#t;#e;#r;#n;[Pn]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=In(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Xs(t)}else if(Js(t))e=In(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#t=e.string,this.#e=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#t}toJSON(){return this.toString()}toOptions(){let t,e,n,s,o="",i=k("tcp"),c=k("udp"),l=k("ip4"),u=k("ip6"),d=k("dns6"),f=k("ip6zone");for(let[a,h]of this.stringTuples())a===f.code&&(o=`%${h??""}`),Qa.includes(a)&&(e=i.name,s=443,n=`${h??""}${o}`,t=a===d.code?6:4),(a===i.code||a===c.code)&&(e=k(a).name,s=parseInt(h??"")),(a===l.code||a===u.code)&&(e=k(a).name,n=`${h??""}${o}`,t=a===u.code?6:4);if(t==null||e==null||n==null||s==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:s}}protos(){return this.#e.map(([t])=>Object.assign({},k(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>k(t).name)}tuples(){return this.#e}stringTuples(){return this.#r}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),s=n.lastIndexOf(e);if(s<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,s))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(Tn(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,s])=>{n===Ht.p2p.code&&t.push([n,s]),n===Ht["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?U(B.decode(`z${n}`),"base58btc"):U(X.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return ot(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(o=>o.resolvable);if(e==null)return[this];let n=Ks.get(e.name);if(n==null)throw new Dn(`no available resolver for ${e.name}`);return(await n(this,t)).map(o=>oe(o))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[Xa](){return`Multiaddr(${this.#t})`}};var Ks=new Map;function Js(r){return!!r?.[Pn]}function oe(r){return new Ye(r)}var ja=r=>r.toString().split("/").slice(1),ie=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),L=r=>({match:t=>ie(e=>e===r).match(t),pattern:r}),rr=()=>({match:r=>ie(t=>typeof t=="string").match(r),pattern:"{string}"}),nr=()=>({match:r=>ie(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),C=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{B.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),tr=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Vr.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),_=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),V=(...r)=>({match:t=>{let e;for(let n of r){let s=n.match(t);s!==!1&&(e==null||s.length<e.length)&&(e=s)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),T=(...r)=>({match:t=>{for(let e of r){let n=e.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${r.map(t=>t.pattern).join(", ")})`});function N(...r){function t(s){let o=ja(s);for(let i of r){let c=i.match(o);if(c===!1)return!1;o=c}return o}function e(s){return t(s)!==!1}function n(s){let o=t(s);return o===!1?!1:o.length===0}return{matches:e,exactMatch:n}}var sr=T(L("dns4"),rr()),or=T(L("dns6"),rr()),ir=T(L("dnsaddr"),rr()),Un=T(L("dns"),rr()),$p=N(sr,_(C())),zp=N(or,_(C())),Vp=N(ir,_(C())),Zs=N(V(Un,ir,sr,or),_(C())),Ys=T(L("ip4"),ie(zt)),to=T(L("ip6"),ie(Vt)),Cn=V(Ys,to),ut=V(Cn,Un,sr,or,ir),Hp=N(V(Cn,T(V(Un,ir,sr,or),_(C())))),qp=N(Ys),Wp=N(to),Gp=N(Cn),Mn=T(ut,L("tcp"),nr()),ae=T(ut,L("udp"),nr()),Xp=N(T(Mn,_(C()))),Qp=N(ae),Fn=T(ae,L("quic")),ar=T(ae,L("quic-v1")),Ka=V(Fn,ar),jp=N(Fn),Kp=N(ar),_n=V(ut,Mn,ae,Fn,ar),eo=V(T(_n,L("ws"),_(C()))),Jp=N(eo),ro=V(T(_n,L("wss"),_(C())),T(_n,L("tls"),L("ws"),_(C()))),Zp=N(ro),no=T(ae,L("webrtc-direct"),_(tr()),_(tr()),_(C())),Yp=N(no),so=T(ar,L("webtransport"),_(tr()),_(tr()),_(C())),tm=N(so),er=V(eo,ro,T(Mn,_(C())),T(Ka,_(C())),T(ut,_(C())),no,so,C()),em=N(er),Ja=T(er,L("p2p-circuit"),C()),rm=N(Ja),Za=V(T(er,L("p2p-circuit"),L("webrtc"),_(C())),T(er,L("webrtc"),_(C())),L("webrtc")),nm=N(Za),Ya=V(T(ut,L("tcp"),nr(),L("http"),_(C())),T(ut,L("http"),_(C()))),oo=N(Ya),tc=V(T(ut,L("tcp"),V(T(L("443"),L("http")),T(nr(),L("https"))),_(C())),T(ut,L("tls"),L("http"),_(C())),T(ut,L("https"),_(C()))),io=N(tc);var ec=[k("tcp").code,k("dns").code,k("dnsaddr").code,k("dns4").code,k("dns6").code];function ao(r){let t;try{t=k("sni").code}catch{return null}for(let[e,n]of r)if(e===t&&n!==void 0)return n;return null}function co(r){return r.some(([t,e])=>t===k("tls").code)}function H(r,t,e){let n=lo[k(r).name];if(n===void 0)throw new Error(`Can't interpret protocol ${k(r).name}`);let s=n(t,e);return r===k("ip6").code?`[${s}]`:s}var lo={ip4:(r,t)=>r,ip6:(r,t)=>t.length===0?r:`[${r}]`,tcp:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`tcp://${H(e[0],e[1]??"",t)}:${r}`},udp:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`udp://${H(e[0],e[1]??"",t)}:${r}`},dnsaddr:(r,t)=>r,dns4:(r,t)=>r,dns6:(r,t)=>r,dns:(r,t)=>r,ipfs:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${H(e[0],e[1]??"",t)}/ipfs/${r}`},p2p:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${H(e[0],e[1]??"",t)}/p2p/${r}`},http:(r,t)=>{let e=co(t),n=ao(t);if(e&&n!==null)return`https://${n}`;let s=e?"https://":"http://",o=t.pop();if(o===void 0)throw new Error("Unexpected end of multiaddr");let i=H(o[0],o[1]??"",t);return i=i.replace("tcp://",""),`${s}${i}`},"http-path":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");let n=H(e[0],e[1]??"",t),s=decodeURIComponent(r);return`${n}/${s}`},tls:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return H(e[0],e[1]??"",t)},sni:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return H(e[0],e[1]??"",t)},https:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");let n=H(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`https://${n}`},ws:(r,t)=>{let e=co(t),n=ao(t);if(e&&n!==null)return`wss://${n}`;let s=e?"wss://":"ws://",o=t.pop();if(o===void 0)throw new Error("Unexpected end of multiaddr");let i=H(o[0],o[1]??"",t);return i=i.replace("tcp://",""),`${s}${i}`},wss:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");let n=H(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`wss://${n}`},"p2p-websocket-star":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${H(e[0],e[1]??"",t)}/p2p-websocket-star`},"p2p-webrtc-star":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${H(e[0],e[1]??"",t)}/p2p-webrtc-star`},"p2p-webrtc-direct":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${H(e[0],e[1]??"",t)}/p2p-webrtc-direct`}};function uo(r,t){let n=oe(r).stringTuples(),s=n.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let o=k(s[0]),i=lo[o.name];if(i==null)throw new Error(`No interpreter found for ${o.name}`);let c=i(s[1]??"",n);return t?.assumeHttp!==!1&&ec.includes(s[0])&&(c=c.replace(/^.*:\/\//,""),s[1]==="443"?c=`https://${c}`:c=`http://${c}`),(c.startsWith("http://")||c.startsWith("https://"))&&(c=new URL(c).toString(),c.endsWith("/")&&(c=c.substring(0,c.length-1))),c}var cr=class{url;#t=0;#e=0;#r=0;#n=0;#s=new Map;log;constructor(t,e){this.url=t instanceof URL?t:new URL(t),this.log=e.forComponent(`helia:trustless-gateway-block-broker:${this.url.hostname}`)}#o(t){let e=t.multihash.bytes;return ct.encode(e)}async getRawBlock(t,e){let n=new URL(this.url.toString());if(n.pathname=`/ipfs/${t.toString()}`,n.search="?format=raw",e?.aborted===!0)throw new Error(`Signal to fetch raw block for CID ${t} from gateway ${this.url} was aborted prior to fetch`);let s=this.#o(t),o=new AbortController,i=()=>{o.abort()};e?.addEventListener("abort",i);try{let c=this.#s.get(s);return c==null&&(this.#t++,c=fetch(n.toString(),{signal:o.signal,headers:{Accept:"application/vnd.ipld.raw"},cache:"force-cache"}).then(async l=>{if(this.log("GET %s %d",n,l.status),!l.ok)throw this.#e++,new Error(`unable to fetch raw block for CID ${t} from gateway ${this.url}`);return this.#n++,new Uint8Array(await l.arrayBuffer())}),this.#s.set(s,c)),await c}catch{throw e?.aborted===!0?new Error(`fetching raw block for CID ${t} from gateway ${this.url} was aborted`):(this.#e++,new Error(`unable to fetch raw block for CID ${t}`))}finally{e?.removeEventListener("abort",i),this.#s.delete(s)}}reliability(){return this.#t===0?1:this.#r>0?-1/0:this.#n/(this.#t+this.#e*3)}incrementInvalidBlocks(){this.#r++}getStats(){return{attempts:this.#t,errors:this.#e,invalidBlocks:this.#r,successes:this.#n,pendingResponses:this.#s.size}}};function rc(r,t,e){return r.filter(n=>{if(io.matches(n)||t&&oo.matches(n))return e||Zs.matches(n)?!0:Os(n.toOptions().host)===!1;if(!t&&e){let{host:s}=n.toOptions();if(s==="127.0.0.1"||s==="localhost"||s.endsWith(".localhost"))return!0}return!1})}async function*lr(r,t,e,n,s,o){for await(let i of t.findProviders(r,o)){let c=rc(i.multiaddrs,n,s);if(c.length===0)continue;let l=uo(c[0]);yield new cr(l,e)}}var Nn=class extends At{routing;allowInsecure;allowLocal;constructor(t,e){super(t,{...e,name:"helia:trustless-gateway:session"}),this.routing=t.routing,this.allowInsecure=e.allowInsecure??ur,this.allowLocal=e.allowLocal??hr}async queryProvider(t,e,n){this.log("fetching BLOCK for %c from %s",t,e.url);let s=await e.getRawBlock(t,n.signal);return this.log.trace("got block for %c from %s",t,e.url),await n.validateFn?.(s),s}async*findNewProviders(t,e={}){yield*lr(t,this.routing,this.logger,this.allowInsecure,this.allowLocal,e)}toEvictionKey(t){return t.url.toString()}equals(t,e){return t.url.toString()===e.url.toString()}};function ho(r,t){return new Nn(r,t)}var fr=class{allowInsecure;allowLocal;routing;log;logger;constructor(t,e={}){this.log=t.logger.forComponent("helia:trustless-gateway-block-broker"),this.logger=t.logger,this.routing=t.routing,this.allowInsecure=e.allowInsecure??ur,this.allowLocal=e.allowLocal??hr}async retrieve(t,e={}){let n=[];for await(let s of lr(t,this.routing,this.logger,this.allowInsecure,this.allowLocal,e)){this.log("getting block for %c from %s",t,s.url);try{let o=await s.getRawBlock(t,e.signal);this.log.trace("got block for %c from %s",t,s.url);try{await e.validateFn?.(o)}catch(i){this.log.error("failed to validate block for %c from %s",t,s.url,i);continue}return o}catch(o){if(this.log.error("failed to get block for %c from %s",t,s.url,o),o instanceof Error?n.push(o):n.push(new Error(`Unable to fetch raw block for CID ${t} from gateway ${s.url}`)),e.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",t,s.url);break}}}throw n.length>0?new AggregateError(n,`Unable to fetch raw block for CID ${t} from any gateway`):new Error(`Unable to fetch raw block for CID ${t} from any gateway`)}createSession(t={}){return ho({logger:this.logger,routing:this.routing},{...t,allowLocal:this.allowLocal,allowInsecure:this.allowInsecure})}};var ur=!1,hr=!1;function fo(r={}){return t=>new fr(t,r)}return xo(nc);})();
2
+ "use strict";var HeliaBlockBrokers=(()=>{var mo=Object.create;var he=Object.defineProperty;var go=Object.getOwnPropertyDescriptor;var wo=Object.getOwnPropertyNames;var bo=Object.getPrototypeOf,xo=Object.prototype.hasOwnProperty;var fe=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),q=(r,t)=>{for(var e in t)he(r,e,{get:t[e],enumerable:!0})},Rn=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of wo(t))!xo.call(r,s)&&s!==e&&he(r,s,{get:()=>t[s],enumerable:!(n=go(t,s))||n.enumerable});return r};var pr=(r,t,e)=>(e=r!=null?mo(bo(r)):{},Rn(t||!r||!r.__esModule?he(e,"default",{value:r,enumerable:!0}):e,r)),yo=r=>Rn(he({},"__esModule",{value:!0}),r);var Ls=fe((re,He)=>{(function(r,t){"use strict";var e={version:"3.0.0",x86:{},x64:{},inputValidation:!0};function n(a){if(!Array.isArray(a)&&!ArrayBuffer.isView(a))return!1;for(var h=0;h<a.length;h++)if(!Number.isInteger(a[h])||a[h]<0||a[h]>255)return!1;return!0}function s(a,h){return(a&65535)*h+(((a>>>16)*h&65535)<<16)}function o(a,h){return a<<h|a>>>32-h}function i(a){return a^=a>>>16,a=s(a,2246822507),a^=a>>>13,a=s(a,3266489909),a^=a>>>16,a}function c(a,h){a=[a[0]>>>16,a[0]&65535,a[1]>>>16,a[1]&65535],h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535];var p=[0,0,0,0];return p[3]+=a[3]+h[3],p[2]+=p[3]>>>16,p[3]&=65535,p[2]+=a[2]+h[2],p[1]+=p[2]>>>16,p[2]&=65535,p[1]+=a[1]+h[1],p[0]+=p[1]>>>16,p[1]&=65535,p[0]+=a[0]+h[0],p[0]&=65535,[p[0]<<16|p[1],p[2]<<16|p[3]]}function l(a,h){a=[a[0]>>>16,a[0]&65535,a[1]>>>16,a[1]&65535],h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535];var p=[0,0,0,0];return p[3]+=a[3]*h[3],p[2]+=p[3]>>>16,p[3]&=65535,p[2]+=a[2]*h[3],p[1]+=p[2]>>>16,p[2]&=65535,p[2]+=a[3]*h[2],p[1]+=p[2]>>>16,p[2]&=65535,p[1]+=a[1]*h[3],p[0]+=p[1]>>>16,p[1]&=65535,p[1]+=a[2]*h[2],p[0]+=p[1]>>>16,p[1]&=65535,p[1]+=a[3]*h[1],p[0]+=p[1]>>>16,p[1]&=65535,p[0]+=a[0]*h[3]+a[1]*h[2]+a[2]*h[1]+a[3]*h[0],p[0]&=65535,[p[0]<<16|p[1],p[2]<<16|p[3]]}function u(a,h){return h%=64,h===32?[a[1],a[0]]:h<32?[a[0]<<h|a[1]>>>32-h,a[1]<<h|a[0]>>>32-h]:(h-=32,[a[1]<<h|a[0]>>>32-h,a[0]<<h|a[1]>>>32-h])}function d(a,h){return h%=64,h===0?a:h<32?[a[0]<<h|a[1]>>>32-h,a[1]<<h]:[a[1]<<h-32,0]}function f(a,h){return[a[0]^h[0],a[1]^h[1]]}function y(a){return a=f(a,[0,a[0]>>>1]),a=l(a,[4283543511,3981806797]),a=f(a,[0,a[0]>>>1]),a=l(a,[3301882366,444984403]),a=f(a,[0,a[0]>>>1]),a}e.x86.hash32=function(a,h){if(e.inputValidation&&!n(a))return t;h=h||0;for(var p=a.length%4,E=a.length-p,m=h,g=0,w=3432918353,x=461845907,v=0;v<E;v=v+4)g=a[v]|a[v+1]<<8|a[v+2]<<16|a[v+3]<<24,g=s(g,w),g=o(g,15),g=s(g,x),m^=g,m=o(m,13),m=s(m,5)+3864292196;switch(g=0,p){case 3:g^=a[v+2]<<16;case 2:g^=a[v+1]<<8;case 1:g^=a[v],g=s(g,w),g=o(g,15),g=s(g,x),m^=g}return m^=a.length,m=i(m),m>>>0},e.x86.hash128=function(a,h){if(e.inputValidation&&!n(a))return t;h=h||0;for(var p=a.length%16,E=a.length-p,m=h,g=h,w=h,x=h,v=0,S=0,b=0,D=0,nt=597399067,ce=2869860233,le=951274213,ue=2716044179,A=0;A<E;A=A+16)v=a[A]|a[A+1]<<8|a[A+2]<<16|a[A+3]<<24,S=a[A+4]|a[A+5]<<8|a[A+6]<<16|a[A+7]<<24,b=a[A+8]|a[A+9]<<8|a[A+10]<<16|a[A+11]<<24,D=a[A+12]|a[A+13]<<8|a[A+14]<<16|a[A+15]<<24,v=s(v,nt),v=o(v,15),v=s(v,ce),m^=v,m=o(m,19),m+=g,m=s(m,5)+1444728091,S=s(S,ce),S=o(S,16),S=s(S,le),g^=S,g=o(g,17),g+=w,g=s(g,5)+197830471,b=s(b,le),b=o(b,17),b=s(b,ue),w^=b,w=o(w,15),w+=x,w=s(w,5)+2530024501,D=s(D,ue),D=o(D,18),D=s(D,nt),x^=D,x=o(x,13),x+=m,x=s(x,5)+850148119;switch(v=0,S=0,b=0,D=0,p){case 15:D^=a[A+14]<<16;case 14:D^=a[A+13]<<8;case 13:D^=a[A+12],D=s(D,ue),D=o(D,18),D=s(D,nt),x^=D;case 12:b^=a[A+11]<<24;case 11:b^=a[A+10]<<16;case 10:b^=a[A+9]<<8;case 9:b^=a[A+8],b=s(b,le),b=o(b,17),b=s(b,ue),w^=b;case 8:S^=a[A+7]<<24;case 7:S^=a[A+6]<<16;case 6:S^=a[A+5]<<8;case 5:S^=a[A+4],S=s(S,ce),S=o(S,16),S=s(S,le),g^=S;case 4:v^=a[A+3]<<24;case 3:v^=a[A+2]<<16;case 2:v^=a[A+1]<<8;case 1:v^=a[A],v=s(v,nt),v=o(v,15),v=s(v,ce),m^=v}return m^=a.length,g^=a.length,w^=a.length,x^=a.length,m+=g,m+=w,m+=x,g+=m,w+=m,x+=m,m=i(m),g=i(g),w=i(w),x=i(x),m+=g,m+=w,m+=x,g+=m,w+=m,x+=m,("00000000"+(m>>>0).toString(16)).slice(-8)+("00000000"+(g>>>0).toString(16)).slice(-8)+("00000000"+(w>>>0).toString(16)).slice(-8)+("00000000"+(x>>>0).toString(16)).slice(-8)},e.x64.hash128=function(a,h){if(e.inputValidation&&!n(a))return t;h=h||0;for(var p=a.length%16,E=a.length-p,m=[0,h],g=[0,h],w=[0,0],x=[0,0],v=[2277735313,289559509],S=[1291169091,658871167],b=0;b<E;b=b+16)w=[a[b+4]|a[b+5]<<8|a[b+6]<<16|a[b+7]<<24,a[b]|a[b+1]<<8|a[b+2]<<16|a[b+3]<<24],x=[a[b+12]|a[b+13]<<8|a[b+14]<<16|a[b+15]<<24,a[b+8]|a[b+9]<<8|a[b+10]<<16|a[b+11]<<24],w=l(w,v),w=u(w,31),w=l(w,S),m=f(m,w),m=u(m,27),m=c(m,g),m=c(l(m,[0,5]),[0,1390208809]),x=l(x,S),x=u(x,33),x=l(x,v),g=f(g,x),g=u(g,31),g=c(g,m),g=c(l(g,[0,5]),[0,944331445]);switch(w=[0,0],x=[0,0],p){case 15:x=f(x,d([0,a[b+14]],48));case 14:x=f(x,d([0,a[b+13]],40));case 13:x=f(x,d([0,a[b+12]],32));case 12:x=f(x,d([0,a[b+11]],24));case 11:x=f(x,d([0,a[b+10]],16));case 10:x=f(x,d([0,a[b+9]],8));case 9:x=f(x,[0,a[b+8]]),x=l(x,S),x=u(x,33),x=l(x,v),g=f(g,x);case 8:w=f(w,d([0,a[b+7]],56));case 7:w=f(w,d([0,a[b+6]],48));case 6:w=f(w,d([0,a[b+5]],40));case 5:w=f(w,d([0,a[b+4]],32));case 4:w=f(w,d([0,a[b+3]],24));case 3:w=f(w,d([0,a[b+2]],16));case 2:w=f(w,d([0,a[b+1]],8));case 1:w=f(w,[0,a[b]]),w=l(w,v),w=u(w,31),w=l(w,S),m=f(m,w)}return m=f(m,[0,a.length]),g=f(g,[0,a.length]),m=c(m,g),g=c(g,m),m=y(m),g=y(g),m=c(m,g),g=c(g,m),("00000000"+(m[0]>>>0).toString(16)).slice(-8)+("00000000"+(m[1]>>>0).toString(16)).slice(-8)+("00000000"+(g[0]>>>0).toString(16)).slice(-8)+("00000000"+(g[1]>>>0).toString(16)).slice(-8)},typeof re<"u"?(typeof He<"u"&&He.exports&&(re=He.exports=e),re.murmurHash3=e):typeof define=="function"&&define.amd?define([],function(){return e}):(e._murmurHash3=r.murmurHash3,e.noConflict=function(){return r.murmurHash3=e._murmurHash3,e._murmurHash3=t,e.noConflict=t,e},r.murmurHash3=e)})(re)});var Ts=fe((kh,Is)=>{Is.exports=Ls()});var _s=fe((sf,Ps)=>{Ps.exports=function(r){if(!r)throw Error("hashlru must have a max value, of type number, greater than 0");var t=0,e=Object.create(null),n=Object.create(null);function s(o,i){e[o]=i,t++,t>=r&&(t=0,n=e,e=Object.create(null))}return{has:function(o){return e[o]!==void 0||n[o]!==void 0},remove:function(o){e[o]!==void 0&&(e[o]=void 0),n[o]!==void 0&&(n[o]=void 0)},get:function(o){var i=e[o];if(i!==void 0)return i;if((i=n[o])!==void 0)return s(o,i),i},set:function(o,i){e[o]!==void 0?e[o]=i:s(o,i)},clear:function(){e=Object.create(null),n=Object.create(null)}}}});var Rs=fe(se=>{(function(){var r,t,e,n,s,o,i,c;c=function(l){var u,d,f,y;return u=(l&255<<24)>>>24,d=(l&255<<16)>>>16,f=(l&65280)>>>8,y=l&255,[u,d,f,y].join(".")},i=function(l){var u,d,f,y,a,h;for(u=[],f=y=0;y<=3&&l.length!==0;f=++y){if(f>0){if(l[0]!==".")throw new Error("Invalid IP");l=l.substring(1)}h=t(l),a=h[0],d=h[1],l=l.substring(d),u.push(a)}if(l.length!==0)throw new Error("Invalid IP");switch(u.length){case 1:if(u[0]>4294967295)throw new Error("Invalid IP");return u[0]>>>0;case 2:if(u[0]>255||u[1]>16777215)throw new Error("Invalid IP");return(u[0]<<24|u[1])>>>0;case 3:if(u[0]>255||u[1]>255||u[2]>65535)throw new Error("Invalid IP");return(u[0]<<24|u[1]<<16|u[2])>>>0;case 4:if(u[0]>255||u[1]>255||u[2]>255||u[3]>255)throw new Error("Invalid IP");return(u[0]<<24|u[1]<<16|u[2]<<8|u[3])>>>0;default:throw new Error("Invalid IP")}},e=function(l){return l.charCodeAt(0)},n=e("0"),o=e("a"),s=e("A"),t=function(l){var u,d,f,y,a;for(y=0,u=10,d="9",f=0,l.length>1&&l[f]==="0"&&(l[f+1]==="x"||l[f+1]==="X"?(f+=2,u=16):"0"<=l[f+1]&&l[f+1]<="9"&&(f++,u=8,d="7")),a=f;f<l.length;){if("0"<=l[f]&&l[f]<=d)y=y*u+(e(l[f])-n)>>>0;else if(u===16)if("a"<=l[f]&&l[f]<="f")y=y*u+(10+e(l[f])-o)>>>0;else if("A"<=l[f]&&l[f]<="F")y=y*u+(10+e(l[f])-s)>>>0;else break;else break;if(y>4294967295)throw new Error("too large");f++}if(f===a)throw new Error("empty octet");return[y,f]},r=function(){function l(u,d){var f,y,a,h;if(typeof u!="string")throw new Error("Missing `net' parameter");if(d||(h=u.split("/",2),u=h[0],d=h[1]),d||(d=32),typeof d=="string"&&d.indexOf(".")>-1){try{this.maskLong=i(d)}catch(p){throw f=p,new Error("Invalid mask: "+d)}for(y=a=32;a>=0;y=--a)if(this.maskLong===4294967295<<32-y>>>0){this.bitmask=y;break}}else if(d||d===0)this.bitmask=parseInt(d,10),this.maskLong=0,this.bitmask>0&&(this.maskLong=4294967295<<32-this.bitmask>>>0);else throw new Error("Invalid mask: empty");try{this.netLong=(i(u)&this.maskLong)>>>0}catch(p){throw f=p,new Error("Invalid net address: "+u)}if(!(this.bitmask<=32))throw new Error("Invalid mask for ip4: "+d);this.size=Math.pow(2,32-this.bitmask),this.base=c(this.netLong),this.mask=c(this.maskLong),this.hostmask=c(~this.maskLong),this.first=this.bitmask<=30?c(this.netLong+1):this.base,this.last=this.bitmask<=30?c(this.netLong+this.size-2):c(this.netLong+this.size-1),this.broadcast=this.bitmask<=30?c(this.netLong+this.size-1):void 0}return l.prototype.contains=function(u){return typeof u=="string"&&(u.indexOf("/")>0||u.split(".").length!==4)&&(u=new l(u)),u instanceof l?this.contains(u.base)&&this.contains(u.broadcast||u.last):(i(u)&this.maskLong)>>>0===(this.netLong&this.maskLong)>>>0},l.prototype.next=function(u){return u==null&&(u=1),new l(c(this.netLong+this.size*u),this.mask)},l.prototype.forEach=function(u){var d,f,y;for(y=i(this.first),f=i(this.last),d=0;y<=f;)u(c(y),y,d),d++,y++},l.prototype.toString=function(){return this.base+"/"+this.bitmask},l}(),se.ip2long=i,se.long2ip=c,se.Netmask=r}).call(se)});var sc={};q(sc,{bitswap:()=>Ns,trustlessGateway:()=>po});var st=class extends Error{static name="AbortError";constructor(t="The operation was aborted"){super(t),this.name="AbortError"}};var Lt=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}};var de=class extends Error{static name="UnsupportedProtocolError";constructor(t="Unsupported protocol error"){super(t),this.name="UnsupportedProtocolError"}};var pe=class extends Error{static name="TimeoutError";constructor(t="Timed out"){super(t),this.name="TimeoutError"}},me=class extends Error{static name="NotStartedError";constructor(t="Not started"){super(t),this.name="NotStartedError"}};var W=(r,...t)=>{try{[...t]}catch{}};var tt=class extends EventTarget{#t=new Map;constructor(){super(),W(1/0,this)}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let s=this.#t.get(t);s==null&&(s=[],this.#t.set(t,s)),s.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let s=this.#t.get(t);s!=null&&(s=s.filter(({callback:o})=>o!==e),this.#t.set(t,s))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:s})=>!s),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new CustomEvent(t,e))}};function On(r){let t=new globalThis.AbortController;function e(){t.abort();for(let o of r)o?.removeEventListener!=null&&o.removeEventListener("abort",e)}for(let o of r){if(o?.aborted===!0){e();break}o?.addEventListener!=null&&o.addEventListener("abort",e)}function n(){for(let o of r)o?.removeEventListener!=null&&o.removeEventListener("abort",e)}let s=t.signal;return s.clear=n,s}function K(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var ge=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},It=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new ge(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new ge(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var mr=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Tt(r={}){return vo(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function vo(r,t){t=t??{};let e=t.onEnd,n=new It,s,o,i,c=K(),l=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((E,m)=>{o=g=>{o=null,n.push(g);try{E(r(n))}catch(w){m(w)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{c.resolve(),c=K()})}},u=E=>o!=null?o(E):(n.push(E),s),d=E=>(n=new It,o!=null?o({error:E}):(n.push({error:E}),s)),f=E=>{if(i)return s;if(t?.objectMode!==!0&&E?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return u({done:!1,value:E})},y=E=>i?s:(i=!0,E!=null?d(E):u({done:!0})),a=()=>(n=new It,y(),{done:!0}),h=E=>(y(E),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:l,return:a,throw:h,push:f,end:y,get readableLength(){return n.size},onEmpty:async E=>{let m=E?.signal;if(m?.throwIfAborted(),n.isEmpty())return;let g,w;m!=null&&(g=new Promise((x,v)=>{w=()=>{v(new mr)},m.addEventListener("abort",w)}));try{await Promise.race([c.promise,g])}finally{w!=null&&m!=null&&m?.removeEventListener("abort",w)}}},e==null)return s;let p=s;return s={[Symbol.asyncIterator](){return this},next(){return p.next()},throw(E){return p.throw(E),e!=null&&(e(E),e=void 0),{done:!0}},return(){return p.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(E){return p.end(E),e!=null&&(e(E),e=void 0),s},get readableLength(){return p.readableLength},onEmpty:E=>p.onEmpty(E)},s}var gr=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=e??"ABORT_ERR"}};async function J(r,t,e,n){let s=new gr(n?.errorMessage,n?.errorCode);return e?.aborted===!0?Promise.reject(s):new Promise((o,i)=>{function c(){e?.removeEventListener("abort",d),r.removeEventListener(t,l),n?.errorEvent!=null&&r.removeEventListener(n.errorEvent,u)}let l=f=>{try{if(n?.filter?.(f)===!1)return}catch(y){c(),i(y);return}c(),o(f)},u=f=>{c(),i(f.detail)},d=()=>{c(),i(s)};e?.addEventListener("abort",d),r.addEventListener(t,l),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,u)})}var we=class extends Error{static name="QueueFullError";constructor(t="The queue was full"){super(t),this.name="QueueFullError"}};var be=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};async function $n(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new be(e?.errorMessage,e?.errorCode,e?.errorName));let n,s=new be(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((o,i)=>{n=()=>{i(s)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var xe=class{deferred;signal;constructor(t){this.signal=t,this.deferred=K(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new st)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function Eo(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var ye=class{id;fn;options;recipients;status;timeline;controller;constructor(t,e){this.id=Eo(),this.status="queued",this.fn=t,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,W(1/0,this.controller.signal),this.onAbort=this.onAbort.bind(this)}abort(t){this.controller.abort(t)}onAbort(){this.recipients.reduce((e,n)=>e&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new st),this.cleanup())}async join(t={}){let e=new xe(t.signal);return this.recipients.push(e),t.signal?.addEventListener("abort",this.onAbort),e.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let t=await $n(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(e=>{e.deferred.resolve(t)}),this.status="complete"}catch(t){this.recipients.forEach(e=>{e.deferred.reject(t)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(t=>{t.cleanup(),t.signal?.removeEventListener("abort",this.onAbort)})}};var Dt=class extends tt{concurrency;maxSize;queue;pending;sort;constructor(t={}){super(),this.concurrency=t.concurrency??Number.POSITIVE_INFINITY,this.maxSize=t.maxSize??Number.POSITIVE_INFINITY,this.pending=0,t.metricName!=null&&t.metrics?.registerMetricGroup(t.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.sort=t.sort,this.queue=[]}tryToStartAnother(){if(this.size===0)return queueMicrotask(()=>{this.safeDispatchEvent("empty")}),this.running===0&&queueMicrotask(()=>{this.safeDispatchEvent("idle")}),!1;if(this.pending<this.concurrency){let t;for(let e of this.queue)if(e.status==="queued"){t=e;break}return t==null?!1:(this.safeDispatchEvent("active"),this.pending++,t.run().finally(()=>{for(let e=0;e<this.queue.length;e++)if(this.queue[e]===t){this.queue.splice(e,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(t){this.queue.push(t),this.sort!=null&&this.queue.sort(this.sort)}async add(t,e){if(e?.signal?.throwIfAborted(),this.size===this.maxSize)throw new we;let n=new ye(t,e);return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),n.join(e).then(s=>(this.safeDispatchEvent("completed",{detail:s}),this.safeDispatchEvent("success",{detail:{job:n,result:s}}),s)).catch(s=>{if(n.status==="queued"){for(let o=0;o<this.queue.length;o++)if(this.queue[o]===n){this.queue.splice(o,1);break}}throw this.safeDispatchEvent("error",{detail:s}),this.safeDispatchEvent("failure",{detail:{job:n,error:s}}),s})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(t=>{t.abort(new st)}),this.clear()}async onEmpty(t){this.size!==0&&await J(this,"empty",t?.signal)}async onSizeLessThan(t,e){this.size<t||await J(this,"next",e?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await J(this,"idle",t?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(t){t?.signal?.throwIfAborted();let e=Tt({objectMode:!0}),n=l=>{l!=null?this.abort():this.clear(),e.end(l)},s=l=>{l.detail!=null&&e.push(l.detail)},o=l=>{n(l.detail)},i=()=>{n()},c=()=>{n(new st("Queue aborted"))};this.addEventListener("completed",s),this.addEventListener("error",o),this.addEventListener("idle",i),t?.signal?.addEventListener("abort",c);try{yield*e}finally{this.removeEventListener("completed",s),this.removeEventListener("error",o),this.removeEventListener("idle",i),t?.signal?.removeEventListener("abort",c),n()}}};var ve=class extends Dt{has(t){return this.find(t)!=null}find(t){return this.queue.find(e=>t.equals(e.options.peerId))}};function ko(r){return r[Symbol.asyncIterator]!=null}function So(r){if(ko(r))return(async()=>{for await(let t of r);})();for(let t of r);}var wr=So;function R(r=0){return new Uint8Array(r)}function O(r=0){return new Uint8Array(r)}var Ao=Math.pow(2,7),Lo=Math.pow(2,14),Io=Math.pow(2,21),br=Math.pow(2,28),xr=Math.pow(2,35),yr=Math.pow(2,42),vr=Math.pow(2,49),I=128,$=127;function P(r){if(r<Ao)return 1;if(r<Lo)return 2;if(r<Io)return 3;if(r<br)return 4;if(r<xr)return 5;if(r<yr)return 6;if(r<vr)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Er(r,t,e=0){switch(P(r)){case 8:t[e++]=r&255|I,r/=128;case 7:t[e++]=r&255|I,r/=128;case 6:t[e++]=r&255|I,r/=128;case 5:t[e++]=r&255|I,r/=128;case 4:t[e++]=r&255|I,r>>>=7;case 3:t[e++]=r&255|I,r>>>=7;case 2:t[e++]=r&255|I,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function To(r,t,e=0){switch(P(r)){case 8:t.set(e++,r&255|I),r/=128;case 7:t.set(e++,r&255|I),r/=128;case 6:t.set(e++,r&255|I),r/=128;case 5:t.set(e++,r&255|I),r/=128;case 4:t.set(e++,r&255|I),r>>>=7;case 3:t.set(e++,r&255|I),r>>>=7;case 2:t.set(e++,r&255|I),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function kr(r,t){let e=r[t],n=0;if(n+=e&$,e<I||(e=r[t+1],n+=(e&$)<<7,e<I)||(e=r[t+2],n+=(e&$)<<14,e<I)||(e=r[t+3],n+=(e&$)<<21,e<I)||(e=r[t+4],n+=(e&$)*br,e<I)||(e=r[t+5],n+=(e&$)*xr,e<I)||(e=r[t+6],n+=(e&$)*yr,e<I)||(e=r[t+7],n+=(e&$)*vr,e<I))return n;throw new RangeError("Could not decode varint")}function Do(r,t){let e=r.get(t),n=0;if(n+=e&$,e<I||(e=r.get(t+1),n+=(e&$)<<7,e<I)||(e=r.get(t+2),n+=(e&$)<<14,e<I)||(e=r.get(t+3),n+=(e&$)<<21,e<I)||(e=r.get(t+4),n+=(e&$)*br,e<I)||(e=r.get(t+5),n+=(e&$)*xr,e<I)||(e=r.get(t+6),n+=(e&$)*yr,e<I)||(e=r.get(t+7),n+=(e&$)*vr,e<I))return n;throw new RangeError("Could not decode varint")}function et(r,t,e=0){return t==null&&(t=O(P(r))),t instanceof Uint8Array?Er(r,t,e):To(r,t,e)}function Z(r,t=0){return r instanceof Uint8Array?kr(r,t):Do(r,t)}function Q(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=O(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function ot(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}var Vn=Symbol.for("@achingbrain/uint8arraylist");function zn(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function ke(r){return!!r?.[Vn]}var ht=class r{bufs;length;[Vn]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(ke(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(ke(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=zn(this.bufs,t);return e.buf[e.index]}set(t,e){let n=zn(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(ke(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return Q(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:Q(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],c=s,l=c+i.byteLength;if(s=l,t>=l)continue;let u=t>=c&&t<l,d=e>c&&e<=l;if(u&&d){if(t===c&&e===l){n.push(i);break}let f=t-c;n.push(i.subarray(f,f+(e-t)));break}if(u){if(t===0){n.push(i);continue}n.push(i.subarray(t-c));continue}if(d){if(e===l){n.push(i);break}n.push(i.subarray(0,e-c));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!ke(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let f=0;f<o;f++)i[f]=-1;for(let f=0;f<s;f++)i[n[f]]=f;let c=i,l=this.byteLength-n.byteLength,u=n.byteLength-1,d;for(let f=e;f<=l;f+=d){d=0;for(let y=u;y>=0;y--){let a=this.get(f+y);if(n[y]!==a){d=Math.max(1,y-c[a]);break}}if(d===0)return f}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=O(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=R(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=R(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=R(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=O(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=R(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=R(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=R(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=R(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=R(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!ot(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};function Se(r){return r[Symbol.asyncIterator]!=null}var Ae=r=>{let t=P(r),e=O(t);return et(r,e),Ae.bytes=t,e};Ae.bytes=0;function Le(r,t){t=t??{};let e=t.lengthEncoder??Ae;function*n(s){let o=e(s.byteLength);o instanceof Uint8Array?yield o:yield*o,s instanceof Uint8Array?yield s:yield*s}return Se(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}Le.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Ae;return new ht(e(r.byteLength),r)};var Ie=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Te=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},De=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},qt=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Po=8,_o=1024*1024*4,mt;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(mt||(mt={}));var Sr=r=>{let t=Z(r);return Sr.bytes=P(t),t};Sr.bytes=0;function Wt(r,t){let e=new ht,n=mt.LENGTH,s=-1,o=t?.lengthDecoder??Sr,i=t?.maxLengthLength??Po,c=t?.maxDataLength??_o;function*l(){for(;e.byteLength>0;){if(n===mt.LENGTH)try{if(s=o(e),s<0)throw new Ie("Invalid message length");if(s>c)throw new Te("Message length too long");let u=o.bytes;e.consume(u),t?.onLength!=null&&t.onLength(s),n=mt.DATA}catch(u){if(u instanceof RangeError){if(e.byteLength>i)throw new De("Message length length too long");break}throw u}if(n===mt.DATA){if(e.byteLength<s)break;let u=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(u),yield u,n=mt.LENGTH}}}return Se(r)?async function*(){for await(let u of r)e.append(u),yield*l();if(e.byteLength>0)throw new qt("Unexpected end of input")}():function*(){for(let u of r)e.append(u),yield*l();if(e.byteLength>0)throw new qt("Unexpected end of input")}()}Wt.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:o,value:i}=await r.next(e);if(o===!0)return;i!=null&&(yield i)}catch(o){if(o.code==="ERR_UNDER_READ")return{done:!0,value:null};throw o}finally{e=1}}();return Wt(n,{...t??{},onLength:o=>{e=o}})};function Co(r){let[t,e]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>t.next(),push:s=>{n.push(s)},next:()=>n.length>0?{done:!1,value:n.shift()}:t.next(),[e](){return this}}}var Hn=Co;function Mo(r){return r[Symbol.asyncIterator]!=null}function Fo(r,t){let e=0;if(Mo(r))return async function*(){for await(let l of r)yield t(l,e++)}();let n=Hn(r),{value:s,done:o}=n.next();if(o===!0)return function*(){}();let i=t(s,e++);if(typeof i.then=="function")return async function*(){yield await i;for await(let l of n)yield t(l,e++)}();let c=t;return function*(){yield i;for(let l of n)yield c(l,e++)}()}var qn=Fo;function No(r){return r[Symbol.asyncIterator]!=null}function Bo(...r){let t=[];for(let e of r)No(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Tt({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let s of n)e.push(s)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var Wn=Bo;function Lr(r,...t){if(r==null)throw new Error("Empty pipeline");if(Ar(r)){let n=r;r=()=>n.source}else if(Xn(r)||Gn(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Ar(e[e.length-1])&&(e[e.length-1]=e[e.length-1].sink),e.length>2)for(let n=1;n<e.length-1;n++)Ar(e[n])&&(e[n]=Oo(e[n]));return Ro(...e)}var Ro=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},Gn=r=>r?.[Symbol.asyncIterator]!=null,Xn=r=>r?.[Symbol.iterator]!=null,Ar=r=>r==null?!1:r.sink!=null&&r.source!=null,Oo=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Tt({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(Gn(o))s=async function*(){yield*o,n.end()};else if(Xn(o))s=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Wn(n,s())}return r.source};function $o(r){return r[Symbol.asyncIterator]!=null}function zo(r,t){return $o(r)?async function*(){let e=0;if(!(t<1)){for await(let n of r)if(yield n,e++,e===t)return}}():function*(){let e=0;if(!(t<1)){for(let n of r)if(yield n,e++,e===t)return}}()}var Qn=zo;var rt=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};var Gt="/ipfs/bitswap/1.2.0";var Ir=new Float32Array([-0]),ft=new Uint8Array(Ir.buffer);function jn(r,t,e){Ir[0]=r,t[e]=ft[0],t[e+1]=ft[1],t[e+2]=ft[2],t[e+3]=ft[3]}function Kn(r,t){return ft[0]=r[t],ft[1]=r[t+1],ft[2]=r[t+2],ft[3]=r[t+3],Ir[0]}var Tr=new Float64Array([-0]),z=new Uint8Array(Tr.buffer);function Jn(r,t,e){Tr[0]=r,t[e]=z[0],t[e+1]=z[1],t[e+2]=z[2],t[e+3]=z[3],t[e+4]=z[4],t[e+5]=z[5],t[e+6]=z[6],t[e+7]=z[7]}function Zn(r,t){return z[0]=r[t],z[1]=r[t+1],z[2]=r[t+2],z[3]=r[t+3],z[4]=r[t+4],z[5]=r[t+5],z[6]=r[t+6],z[7]=r[t+7],Tr[0]}var Vo=BigInt(Number.MAX_SAFE_INTEGER),Ho=BigInt(Number.MIN_SAFE_INTEGER),G=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return gt;if(t<Vo&&t>Ho)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,s=t-(n<<32n);return e&&(n=~n|0n,s=~s|0n,++s>Yn&&(s=0n,++n>Yn&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return gt;let e=t<0;e&&(t=-t);let n=t>>>0,s=(t-n)/4294967296>>>0;return e&&(s=~s>>>0,n=~n>>>0,++n>4294967295&&(n=0,++s>4294967295&&(s=0))),new r(n,s)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):gt}},gt=new G(0,0);gt.toBigInt=function(){return 0n};gt.zzEncode=gt.zzDecode=function(){return this};gt.length=function(){return 1};var Yn=4294967296n;function ts(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function es(r,t,e){if(e-t<1)return"";let s,o=[],i=0,c;for(;t<e;)c=r[t++],c<128?o[i++]=c:c>191&&c<224?o[i++]=(c&31)<<6|r[t++]&63:c>239&&c<365?(c=((c&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,o[i++]=55296+(c>>10),o[i++]=56320+(c&1023)):o[i++]=(c&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((s??(s=[])).push(String.fromCharCode.apply(String,o)),i=0);return s!=null?(i>0&&s.push(String.fromCharCode.apply(String,o.slice(0,i))),s.join("")):String.fromCharCode.apply(String,o.slice(0,i))}function Dr(r,t,e){let n=e,s,o;for(let i=0;i<r.length;++i)s=r.charCodeAt(i),s<128?t[e++]=s:s<2048?(t[e++]=s>>6|192,t[e++]=s&63|128):(s&64512)===55296&&((o=r.charCodeAt(i+1))&64512)===56320?(s=65536+((s&1023)<<10)+(o&1023),++i,t[e++]=s>>18|240,t[e++]=s>>12&63|128,t[e++]=s>>6&63|128,t[e++]=s&63|128):(t[e++]=s>>12|224,t[e++]=s>>6&63|128,t[e++]=s&63|128);return e-n}function Y(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Pe(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Pr=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Y(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Y(this,4);return Pe(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Y(this,4);return Pe(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Y(this,4);let t=Kn(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Y(this,4);let t=Zn(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Y(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return es(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Y(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Y(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new G(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Y(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Y(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Y(this,8);let t=Pe(this.buf,this.pos+=4),e=Pe(this.buf,this.pos+=4);return new G(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=kr(this.buf,this.pos);return this.pos+=P(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function _r(r){return new Pr(r instanceof Uint8Array?r:r.subarray())}function wt(r,t,e){let n=_r(r);return t.decode(n,void 0,e)}var Nr={};q(Nr,{base10:()=>jo});var Sl=new Uint8Array(0);function ns(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function it(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function ss(r){return new TextEncoder().encode(r)}function os(r){return new TextDecoder().decode(r)}function qo(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var s=0;s<r.length;s++){var o=r.charAt(s),i=o.charCodeAt(0);if(e[i]!==255)throw new TypeError(o+" is ambiguous");e[i]=s}var c=r.length,l=r.charAt(0),u=Math.log(c)/Math.log(256),d=Math.log(256)/Math.log(c);function f(h){if(h instanceof Uint8Array||(ArrayBuffer.isView(h)?h=new Uint8Array(h.buffer,h.byteOffset,h.byteLength):Array.isArray(h)&&(h=Uint8Array.from(h))),!(h instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(h.length===0)return"";for(var p=0,E=0,m=0,g=h.length;m!==g&&h[m]===0;)m++,p++;for(var w=(g-m)*d+1>>>0,x=new Uint8Array(w);m!==g;){for(var v=h[m],S=0,b=w-1;(v!==0||S<E)&&b!==-1;b--,S++)v+=256*x[b]>>>0,x[b]=v%c>>>0,v=v/c>>>0;if(v!==0)throw new Error("Non-zero carry");E=S,m++}for(var D=w-E;D!==w&&x[D]===0;)D++;for(var nt=l.repeat(p);D<w;++D)nt+=r.charAt(x[D]);return nt}function y(h){if(typeof h!="string")throw new TypeError("Expected String");if(h.length===0)return new Uint8Array;var p=0;if(h[p]!==" "){for(var E=0,m=0;h[p]===l;)E++,p++;for(var g=(h.length-p)*u+1>>>0,w=new Uint8Array(g);h[p];){var x=e[h.charCodeAt(p)];if(x===255)return;for(var v=0,S=g-1;(x!==0||v<m)&&S!==-1;S--,v++)x+=c*w[S]>>>0,w[S]=x%256>>>0,x=x/256>>>0;if(x!==0)throw new Error("Non-zero carry");m=v,p++}if(h[p]!==" "){for(var b=g-m;b!==g&&w[b]===0;)b++;for(var D=new Uint8Array(E+(g-b)),nt=E;b!==g;)D[nt++]=w[b++];return D}}}function a(h){var p=y(h);if(p)return p;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:y,decode:a}}var Wo=qo,Go=Wo,as=Go;var Ur=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Cr=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let s=e.codePointAt(0);if(s===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return cs(this,t)}},Mr=class{decoders;constructor(t){this.decoders=t}or(t){return cs(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function cs(r,t){return new Mr({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Fr=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,s){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=s,this.encoder=new Ur(t,e,n),this.decoder=new Cr(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Pt({name:r,prefix:t,encode:e,decode:n}){return new Fr(r,t,e,n)}function dt({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=as(e,r);return Pt({prefix:t,name:r,encode:n,decode:o=>it(s(o))})}function Xo(r,t,e,n){let s={};for(let d=0;d<t.length;++d)s[t[d]]=d;let o=r.length;for(;r[o-1]==="=";)--o;let i=new Uint8Array(o*e/8|0),c=0,l=0,u=0;for(let d=0;d<o;++d){let f=s[r[d]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);l=l<<e|f,c+=e,c>=8&&(c-=8,i[u++]=255&l>>c)}if(c>=e||255&l<<8-c)throw new SyntaxError("Unexpected end of data");return i}function Qo(r,t,e){let n=t[t.length-1]==="=",s=(1<<e)-1,o="",i=0,c=0;for(let l=0;l<r.length;++l)for(c=c<<8|r[l],i+=8;i>e;)i-=e,o+=t[s&c>>i];if(i!==0&&(o+=t[s&c<<e-i]),n)for(;o.length*e&7;)o+="=";return o}function M({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Pt({prefix:t,name:r,encode(s){return Qo(s,n,e)},decode(s){return Xo(s,n,e,r)}})}var jo=dt({prefix:"9",name:"base10",alphabet:"0123456789"});var Br={};q(Br,{base16:()=>Ko,base16upper:()=>Jo});var Ko=M({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Jo=M({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Rr={};q(Rr,{base2:()=>Zo});var Zo=M({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Or={};q(Or,{base256emoji:()=>ni});var ls=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),Yo=ls.reduce((r,t,e)=>(r[e]=t,r),[]),ti=ls.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function ei(r){return r.reduce((t,e)=>(t+=Yo[e],t),"")}function ri(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let s=ti[n];if(s==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(s)}return new Uint8Array(t)}var ni=Pt({prefix:"\u{1F680}",name:"base256emoji",encode:ei,decode:ri});var $r={};q($r,{base32:()=>at,base32hex:()=>ai,base32hexpad:()=>li,base32hexpadupper:()=>ui,base32hexupper:()=>ci,base32pad:()=>oi,base32padupper:()=>ii,base32upper:()=>si,base32z:()=>hi});var at=M({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),si=M({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),oi=M({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),ii=M({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),ai=M({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),ci=M({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),li=M({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ui=M({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),hi=M({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var zr={};q(zr,{base36:()=>Xt,base36upper:()=>fi});var Xt=dt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),fi=dt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Vr={};q(Vr,{base58btc:()=>B,base58flickr:()=>di});var B=dt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),di=dt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var qr={};q(qr,{base64:()=>ct,base64pad:()=>pi,base64url:()=>Hr,base64urlpad:()=>mi});var ct=M({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),pi=M({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Hr=M({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),mi=M({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Wr={};q(Wr,{base8:()=>gi});var gi=M({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Gr={};q(Gr,{identity:()=>wi});var wi=Pt({prefix:"\0",name:"identity",encode:r=>os(r),decode:r=>ss(r)});var $l=new TextEncoder,zl=new TextDecoder;var Qr={};q(Qr,{identity:()=>$i});var yi=fs,us=128,vi=127,Ei=~vi,ki=Math.pow(2,31);function fs(r,t,e){t=t||[],e=e||0;for(var n=e;r>=ki;)t[e++]=r&255|us,r/=128;for(;r&Ei;)t[e++]=r&255|us,r>>>=7;return t[e]=r|0,fs.bytes=e-n+1,t}var Si=Xr,Ai=128,hs=127;function Xr(r,n){var e=0,n=n||0,s=0,o=n,i,c=r.length;do{if(o>=c)throw Xr.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&hs)<<s:(i&hs)*Math.pow(2,s),s+=7}while(i>=Ai);return Xr.bytes=o-n,e}var Li=Math.pow(2,7),Ii=Math.pow(2,14),Ti=Math.pow(2,21),Di=Math.pow(2,28),Pi=Math.pow(2,35),_i=Math.pow(2,42),Ui=Math.pow(2,49),Ci=Math.pow(2,56),Mi=Math.pow(2,63),Fi=function(r){return r<Li?1:r<Ii?2:r<Ti?3:r<Di?4:r<Pi?5:r<_i?6:r<Ui?7:r<Ci?8:r<Mi?9:10},Ni={encode:yi,decode:Si,encodingLength:Fi},Bi=Ni,Qt=Bi;function jt(r,t=0){return[Qt.decode(r,t),Qt.decode.bytes]}function _t(r,t,e=0){return Qt.encode(r,t,e),t}function Ut(r){return Qt.encodingLength(r)}function bt(r,t){let e=t.byteLength,n=Ut(r),s=n+Ut(e),o=new Uint8Array(s+e);return _t(r,o,0),_t(e,o,n),o.set(t,s),new Ct(r,e,t,o)}function Kt(r){let t=it(r),[e,n]=jt(t),[s,o]=jt(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Ct(e,s,i,t)}function ds(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&ns(r.bytes,e.bytes)}}var Ct=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var ps=0,Ri="identity",ms=it;function Oi(r){return bt(ps,ms(r))}var $i={code:ps,name:Ri,encode:ms,digest:Oi};var Jr={};q(Jr,{sha256:()=>Ue,sha512:()=>zi});function Kr({name:r,code:t,encode:e}){return new jr(r,t,e)}var jr=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?bt(this.code,e):e.then(n=>bt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function ws(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Ue=Kr({name:"sha2-256",code:18,encode:ws("SHA-256")}),zi=Kr({name:"sha2-512",code:19,encode:ws("SHA-512")});function bs(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Hi(e,Zr(r),t??B.encoder);default:return qi(e,Zr(r),t??at.encoder)}}var xs=new WeakMap;function Zr(r){let t=xs.get(r);if(t==null){let e=new Map;return xs.set(r,e),e}return t}var X=class r{code;version;multihash;bytes;"/";constructor(t,e,n,s){this.code=e,this.version=t,this.multihash=n,this.bytes=s,this["/"]=s}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==Jt)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Wi)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=bt(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&ds(t.multihash,n.multihash)}toString(t){return bs(this,t)}toJSON(){return{"/":bs(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:s,multihash:o,bytes:i}=e;return new r(n,s,o,i??ys(n,s,o.bytes))}else if(e[Gi]===!0){let{version:n,multihash:s,code:o}=e,i=Kt(s);return r.create(n,o,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==Jt)throw new Error(`Version 0 CID must use dag-pb (code: ${Jt}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=ys(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Jt,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,s=it(t.subarray(n,n+e.multihashSize));if(s.byteLength!==e.multihashSize)throw new Error("Incorrect length");let o=s.subarray(e.multihashSize-e.digestSize),i=new Ct(e.multihashCode,e.digestSize,o,s);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[f,y]=jt(t.subarray(e));return e+=y,f},s=n(),o=Jt;if(s===18?(s=0,e=0):o=n(),s!==0&&s!==1)throw new RangeError(`Invalid CID version ${s}`);let i=e,c=n(),l=n(),u=e+l,d=u-i;return{version:s,codec:o,multihashCode:c,digestSize:l,multihashSize:d,size:u}}static parse(t,e){let[n,s]=Vi(t,e),o=r.decode(s);if(o.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Zr(o).set(n,t),o}};function Vi(r,t){switch(r[0]){case"Q":{let e=t??B;return[B.prefix,e.decode(`${B.prefix}${r}`)]}case B.prefix:{let e=t??B;return[B.prefix,e.decode(r)]}case at.prefix:{let e=t??at;return[at.prefix,e.decode(r)]}case Xt.prefix:{let e=t??Xt;return[Xt.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Hi(r,t,e){let{prefix:n}=e;if(n!==B.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let s=t.get(n);if(s==null){let o=e.encode(r).slice(1);return t.set(n,o),o}else return s}function qi(r,t,e){let{prefix:n}=e,s=t.get(n);if(s==null){let o=e.encode(r);return t.set(n,o),o}else return s}var Jt=112,Wi=18;function ys(r,t,e){let n=Ut(r),s=n+Ut(t),o=new Uint8Array(s+e.byteLength);return _t(r,o,0),_t(t,o,n),o.set(e,s),o}var Gi=Symbol.for("@ipld/js-cid/CID");var Zt={...Gr,...Rr,...Wr,...Nr,...Br,...$r,...zr,...Vr,...qr,...Or},lu={...Jr,...Qr};function Es(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var vs=Es("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Yr=Es("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=O(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Xi={utf8:vs,"utf-8":vs,hex:Zt.base16,latin1:Yr,ascii:Yr,binary:Yr,...Zt},Ce=Xi;function pt(r,t="utf8"){let e=Ce[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function tn(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return O(i);s+i>t&&(n=O(t),s=0);let c=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),c}}var yt=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function en(){}var nn=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Qi=tn();function ji(r){return globalThis.Buffer!=null?O(r):Qi(r)}var te=class{len;head;tail;states;constructor(){this.len=0,this.head=new yt(en,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new yt(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new sn((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(Me,10,G.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=G.fromBigInt(t);return this._push(Me,e.length(),e)}uint64Number(t){return this._push(Er,P(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=G.fromBigInt(t).zzEncode();return this._push(Me,e.length(),e)}sint64Number(t){let e=G.fromNumber(t).zzEncode();return this._push(Me,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(rn,1,t?1:0)}fixed32(t){return this._push(Yt,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=G.fromBigInt(t);return this._push(Yt,4,e.lo)._push(Yt,4,e.hi)}fixed64Number(t){let e=G.fromNumber(t);return this._push(Yt,4,e.lo)._push(Yt,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(jn,4,t)}double(t){return this._push(Jn,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(rn,1,0):this.uint32(e)._push(Ji,e,t)}string(t){let e=ts(t);return e!==0?this.uint32(e)._push(Dr,e,t):this._push(rn,1,0)}fork(){return this.states=new nn(this),this.head=this.tail=new yt(en,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new yt(en,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=ji(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function rn(r,t,e){t[e]=r&255}function Ki(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var sn=class extends yt{next;constructor(t,e){super(Ki,t,e),this.next=void 0}};function Me(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Yt(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Ji(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(te.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Zi,t,r),this},te.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Yi,t,r),this});function Zi(r,t,e){t.set(r,e)}function Yi(r,t,e){r.length<40?Dr(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(pt(r),e)}function on(){return new te}function vt(r,t){let e=on();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Mt;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(Mt||(Mt={}));function Fe(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ne(r){function t(s){if(r[s.toString()]==null)throw new Error("Invalid enum value");return r[s]}let e=function(o,i){let c=t(o);i.int32(c)},n=function(o){let i=o.int32();return t(i)};return Fe("enum",Mt.VARINT,e,n)}function Et(r,t){return Fe("message",Mt.LENGTH_DELIMITED,r,t)}var Ft=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var F;(function(r){r.WantBlock="WantBlock",r.WantHave="WantHave"})(F||(F={}));var an;(function(r){r[r.WantBlock=0]="WantBlock",r[r.WantHave=1]="WantHave"})(an||(an={}));(function(r){r.codec=()=>Ne(an)})(F||(F={}));var Nt;(function(r){let t;r.codec=()=>(t==null&&(t=Et((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.cid!=null&&e.cid.byteLength>0&&(n.uint32(10),n.bytes(e.cid)),e.priority!=null&&e.priority!==0&&(n.uint32(16),n.int32(e.priority)),e.cancel!=null&&(n.uint32(24),n.bool(e.cancel)),e.wantType!=null&&(n.uint32(32),F.codec().encode(e.wantType,n)),e.sendDontHave!=null&&(n.uint32(40),n.bool(e.sendDontHave)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={cid:R(0),priority:0},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let c=e.uint32();switch(c>>>3){case 1:{o.cid=e.bytes();break}case 2:{o.priority=e.int32();break}case 3:{o.cancel=e.bool();break}case 4:{o.wantType=F.codec().decode(e);break}case 5:{o.sendDontHave=e.bool();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>vt(e,r.codec()),r.decode=(e,n)=>wt(e,r.codec(),n)})(Nt||(Nt={}));var Be;(function(r){let t;r.codec=()=>(t==null&&(t=Et((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.entries!=null)for(let o of e.entries)n.uint32(10),Nt.codec().encode(o,n);e.full!=null&&(n.uint32(16),n.bool(e.full)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={entries:[]},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let c=e.uint32();switch(c>>>3){case 1:{if(s.limits?.entries!=null&&o.entries.length===s.limits.entries)throw new Ft('Decode error - map field "entries" had too many elements');o.entries.push(Nt.codec().decode(e,e.uint32(),{limits:s.limits?.entries$}));break}case 2:{o.full=e.bool();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>vt(e,r.codec()),r.decode=(e,n)=>wt(e,r.codec(),n)})(Be||(Be={}));var Bt;(function(r){let t;r.codec=()=>(t==null&&(t=Et((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.prefix!=null&&e.prefix.byteLength>0&&(n.uint32(10),n.bytes(e.prefix)),e.data!=null&&e.data.byteLength>0&&(n.uint32(18),n.bytes(e.data)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={prefix:R(0),data:R(0)},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let c=e.uint32();switch(c>>>3){case 1:{o.prefix=e.bytes();break}case 2:{o.data=e.bytes();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>vt(e,r.codec()),r.decode=(e,n)=>wt(e,r.codec(),n)})(Bt||(Bt={}));var j;(function(r){r.HaveBlock="HaveBlock",r.DontHaveBlock="DontHaveBlock"})(j||(j={}));var Re;(function(r){r[r.HaveBlock=0]="HaveBlock",r[r.DontHaveBlock=1]="DontHaveBlock"})(Re||(Re={}));(function(r){r.codec=()=>Ne(Re)})(j||(j={}));var Rt;(function(r){let t;r.codec=()=>(t==null&&(t=Et((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.cid!=null&&e.cid.byteLength>0&&(n.uint32(10),n.bytes(e.cid)),e.type!=null&&Re[e.type]!==0&&(n.uint32(16),j.codec().encode(e.type,n)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={cid:R(0),type:j.HaveBlock},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let c=e.uint32();switch(c>>>3){case 1:{o.cid=e.bytes();break}case 2:{o.type=j.codec().decode(e);break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>vt(e,r.codec()),r.decode=(e,n)=>wt(e,r.codec(),n)})(Rt||(Rt={}));var kt;(function(r){let t;r.codec=()=>(t==null&&(t=Et((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.wantlist!=null&&(n.uint32(10),Be.codec().encode(e.wantlist,n)),e.blocks!=null)for(let o of e.blocks)n.uint32(26),Bt.codec().encode(o,n);if(e.blockPresences!=null)for(let o of e.blockPresences)n.uint32(34),Rt.codec().encode(o,n);e.pendingBytes!=null&&e.pendingBytes!==0&&(n.uint32(40),n.int32(e.pendingBytes)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={blocks:[],blockPresences:[],pendingBytes:0},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let c=e.uint32();switch(c>>>3){case 1:{o.wantlist=Be.codec().decode(e,e.uint32(),{limits:s.limits?.wantlist});break}case 3:{if(s.limits?.blocks!=null&&o.blocks.length===s.limits.blocks)throw new Ft('Decode error - map field "blocks" had too many elements');o.blocks.push(Bt.codec().decode(e,e.uint32(),{limits:s.limits?.blocks$}));break}case 4:{if(s.limits?.blockPresences!=null&&o.blockPresences.length===s.limits.blockPresences)throw new Ft('Decode error - map field "blockPresences" had too many elements');o.blockPresences.push(Rt.codec().decode(e,e.uint32(),{limits:s.limits?.blockPresences$}));break}case 5:{o.pendingBytes=e.int32();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>vt(e,r.codec()),r.decode=(e,n)=>wt(e,r.codec(),n)})(kt||(kt={}));function ks(r,t){for(let[e,n]of t.wantlist.entries()){let s=r.wantlist.get(e);s!=null&&(s.priority>n.priority&&(n.priority=s.priority),n.cancel=n.cancel??s.cancel,n.wantType=n.wantType??s.wantType,n.sendDontHave=n.sendDontHave??s.sendDontHave),r.wantlist.set(e,n)}for(let[e,n]of t.blockPresences.entries())r.blockPresences.set(e,n);for(let[e,n]of t.blocks.entries())r.blocks.set(e,n);return t.full&&!r.full&&(r.full=!0),r}var Oe=class extends Error{static name="BlockTooLargeError";constructor(t="Block too large"){super(t),this.name="BlockTooLargeError"}};var ta=4193648,ea=ta+16;function*Ss(r,t){let e=[...r.wantlist.values()],n=[...r.blockPresences.values()],s=[...r.blocks.values()],o=0,i=0,c=0,l=!1;for(;;){let u={wantlist:{full:r.full??!1,entries:[]},blockPresences:[],blocks:[],pendingBytes:0},d=kt.encode(u).byteLength,{added:f,hasMore:y,newSize:a}=cn(s,u.blocks,c,t,d,ra);c+=f,d=a;let h=y;({added:f,hasMore:y,newSize:a}=cn(n,u.blockPresences,i,t,d,na)),i+=f,d=a;let p=y;if({added:f,hasMore:y,newSize:a}=cn(e,u.wantlist.entries,o,t,d,sa),o+=f,d=a,l=!h&&!p&&!y,l||(u.wantlist.full=!1),yield kt.encode(u),l)break}}function cn(r,t,e,n,s,o){let i=0,c=!1;for(let l=e;l<r.length;l++){let u=r[l],d=o(u);if(d>ea)throw new Oe("Cannot send block as after encoding it is over the max message size");let f=s+d;if(f>n){c=!0;break}t.push(u),i++,s=f}return{hasMore:c,added:i,newSize:s}}function ra(r){return ln(3,Bt.encode(r))}function na(r){return ln(4,Rt.encode(r))}function sa(r){return ln(1,Nt.encode(r))}function ln(r,t){let e=P(r),n=P(t.byteLength);return e+n+t.byteLength}var $e=class extends tt{log;libp2p;routing;protocols;running;maxInboundStreams;maxOutboundStreams;messageReceiveTimeout;registrarIds;metrics;sendQueue;runOnLimitedConnections;maxOutgoingMessageSize;maxIncomingMessageSize;constructor(t,e={}){super(),this.log=t.logger.forComponent("helia:bitswap:network"),this.libp2p=t.libp2p,this.routing=t.routing,this.protocols=e.protocols??[Gt],this.registrarIds=[],this.running=!1,this._onStream=this._onStream.bind(this),this.maxInboundStreams=e.maxInboundStreams??1024,this.maxOutboundStreams=e.maxOutboundStreams??1024,this.messageReceiveTimeout=e.messageReceiveTimeout??5e3,this.runOnLimitedConnections=e.runOnLimitedConnections??!1,this.maxIncomingMessageSize=e.maxIncomingMessageSize??4194304,this.maxOutgoingMessageSize=e.maxOutgoingMessageSize??e.maxIncomingMessageSize??4194304,this.metrics={blocksSent:t.metrics?.registerCounter("helia_bitswap_sent_blocks_total"),dataSent:t.metrics?.registerCounter("helia_bitswap_sent_data_bytes_total")},this.sendQueue=new ve({concurrency:e.messageSendConcurrency??50,metrics:t.metrics,metricName:"helia_bitswap_message_send_queue"}),this.sendQueue.addEventListener("error",n=>{this.log.error("error sending wantlist to peer",n.detail)})}async start(){if(this.running)return;this.running=!0,await this.libp2p.handle(this.protocols,this._onStream,{maxInboundStreams:this.maxInboundStreams,maxOutboundStreams:this.maxOutboundStreams,runOnLimitedConnection:this.runOnLimitedConnections});let t={onConnect:e=>{this.safeDispatchEvent("peer:connected",{detail:e})},onDisconnect:e=>{this.safeDispatchEvent("peer:disconnected",{detail:e})}};this.registrarIds=[];for(let e of this.protocols)this.registrarIds.push(await this.libp2p.register(e,t));this.libp2p.getConnections().forEach(e=>{this.safeDispatchEvent("peer:connected",{detail:e.remotePeer})})}async stop(){if(this.running=!1,await this.libp2p.unhandle(this.protocols),this.registrarIds!=null){for(let t of this.registrarIds)this.libp2p.unregister(t);this.registrarIds=[]}}_onStream(t){if(!this.running)return;let{stream:e,connection:n}=t;Promise.resolve().then(async()=>{this.log("incoming new bitswap %s stream from %p",e.protocol,n.remotePeer);let s=()=>{e.status==="open"?e.abort(new pe(`Incoming Bitswap stream timed out after ${this.messageReceiveTimeout}ms`)):this.log("stream aborted with status %s",e.status)},o=AbortSignal.timeout(this.messageReceiveTimeout);W(1/0,o),o.addEventListener("abort",s),await e.closeWrite(),await Lr(e,i=>Wt(i,{maxDataLength:this.maxIncomingMessageSize}),async i=>{for await(let c of i)try{let l=kt.decode(c);this.log("incoming new bitswap %s message from %p on stream",e.protocol,n.remotePeer,e.id),this.safeDispatchEvent("bitswap:message",{detail:{peer:n.remotePeer,message:l}}),o.removeEventListener("abort",s),o=AbortSignal.timeout(this.messageReceiveTimeout),W(1/0,o),o.addEventListener("abort",s)}catch(l){this.log.error("error reading incoming bitswap message from %p on stream",n.remotePeer,e.id,l),e.abort(l);break}})}).catch(s=>{this.log.error("error handling incoming stream from %p",n.remotePeer,s),e.abort(s)})}async*findProviders(t,e){e?.onProgress?.(new rt("bitswap:network:find-providers",t));for await(let n of this.routing.findProviders(t,e))await this.libp2p.isDialable(n.multiaddrs,{runOnLimitedConnection:this.runOnLimitedConnections})&&(yield n)}async findAndConnect(t,e){await wr(qn(Qn(this.findProviders(t,e),e?.maxProviders??3),async n=>this.connectTo(n.id,e))).catch(n=>{this.log.error(n)})}async sendMessage(t,e,n){if(!this.running)throw new Error("network isn't running");let s=this.sendQueue.queue.find(o=>t.equals(o.options.peerId)&&o.status==="queued");if(s!=null){s.options.message=ks(s.options.message,e),await s.join({signal:n?.signal});return}await this.sendQueue.add(async o=>{let i=o?.message;if(i==null)throw new Lt("No message to send");this.log("sendMessage to %p",t),o?.onProgress?.(new rt("bitswap:network:send-wantlist",t));let c=await this.libp2p.dialProtocol(t,Gt,o);await c.closeRead();try{await Lr(Ss(i,this.maxOutgoingMessageSize),l=>Le(l),c),await c.close(o)}catch(l){o?.onProgress?.(new rt("bitswap:network:send-wantlist:error",{peer:t,error:l})),this.log.error("error sending message to %p",t,l),c.abort(l)}this._updateSentStats(i.blocks)},{peerId:t,signal:n?.signal,message:e})}async connectTo(t,e){if(!this.running)throw new me("Network isn't running");e?.onProgress?.(new rt("bitswap:network:dial",t));let[n]=await Promise.all([this.libp2p.dial(t,e),J(this.libp2p,"peer:identify",e?.signal,{filter:s=>{if(!s.detail.peerId.equals(t))return!1;if(s.detail.protocols.includes(Gt))return!0;throw new de(`${t} did not support ${Gt}`)}})]);return n}_updateSentStats(t){let e=0;for(let n of t.values())e+=n.data.byteLength;this.metrics.dataSent?.increment(e),this.metrics.blocksSent?.increment(t.size)}};var St=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var lh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var uh={}.toString;function As(r=32){if(St&&typeof St.getRandomValues=="function")return St.getRandomValues(new Uint8Array(r));if(St&&typeof St.randomBytes=="function")return St.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function U(r,t="utf8"){let e=Ce[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function ze(r){if(isNaN(r)||r<=0)throw new Lt("random bytes length must be a Number bigger than 0");return As(r)}function Ve(r,t){let e={[Symbol.iterator]:()=>e,next:()=>{let n=r.next(),s=n.value;return n.done===!0||s==null?{done:!0,value:void 0}:{done:!1,value:t(s)}}};return e}var ee=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[e,n]of t.entries())this.map.set(e.toString(),{key:e,value:n})}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){return this.map.delete(t.toString())}entries(){return Ve(this.map.entries(),t=>[t[1].key,t[1].value])}forEach(t){this.map.forEach((e,n)=>{t(e.value,e.key,this)})}get(t){return this.map.get(t.toString())?.value}has(t){return this.map.has(t.toString())}set(t,e){this.map.set(t.toString(),{key:t,value:e})}keys(){return Ve(this.map.values(),t=>t.key)}values(){return Ve(this.map.values(),t=>t.value)}get size(){return this.map.size}};var un=class extends ee{metric;constructor(t){super();let{name:e,metrics:n}=t;this.metric=n.registerMetric(e),this.updateComponentMetric()}set(t,e){return super.set(t,e),this.updateComponentMetric(),this}delete(t){let e=super.delete(t);return this.updateComponentMetric(),e}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function ne(r){let{name:t,metrics:e}=r,n;return e!=null?n=new un({name:t,metrics:e}):n=new ee,n}var lt=class{full;pendingBytes;wantlist;blocks;blockPresences;constructor(t=!1,e=0){this.full=t,this.wantlist=new Map,this.blocks=new Map,this.blockPresences=new Map,this.pendingBytes=0}addWantlistEntry(t,e){let n=ct.encode(t.multihash.bytes);this.wantlist.set(n,e)}addBlockPresence(t,e){let n=ct.encode(t.multihash.bytes);this.blockPresences.set(n,e)}addBlock(t,e){let n=ct.encode(t.multihash.bytes);this.blocks.set(n,e)}};function da(r){let t=new Uint8Array(r.reduce((n,s)=>n+P(s),0)),e=0;for(let n of r)t=et(n,t,e),e+=P(n);return t}var Ds=da;function hn(r){return Ds([r.version,r.code,r.multihash.code,r.multihash.digest.byteLength])}var qe=class{peerId;blockstore;network;wants;exchangeCount;bytesSent;bytesReceived;lastExchange;maxSizeReplaceHasWithBlock;log;constructor(t,e){this.peerId=t.peerId,this.blockstore=t.blockstore,this.network=t.network,this.wants=new Map,this.log=t.logger.forComponent(`helia:bitswap:ledger:${t.peerId}`),this.exchangeCount=0,this.bytesSent=0,this.bytesReceived=0,this.maxSizeReplaceHasWithBlock=e.maxSizeReplaceHasWithBlock??1024}sentBytes(t){this.exchangeCount++,this.lastExchange=new Date().getTime(),this.bytesSent+=t}receivedBytes(t){this.exchangeCount++,this.lastExchange=new Date().getTime(),this.bytesReceived+=t}debtRatio(){return this.bytesSent/(this.bytesReceived+1)}async sendBlocksToPeer(t){let e=new lt,n=new Set;for(let[s,o]of this.wants.entries())try{let i=await this.blockstore.get(o.cid,t);o.wantType===F.WantHave?i.byteLength<this.maxSizeReplaceHasWithBlock?(this.log("sending have and block for %c",o.cid),n.add(s),e.addBlock(o.cid,{data:i,prefix:hn(o.cid)})):(this.log("sending have for %c",o.cid),e.addBlockPresence(o.cid,{cid:o.cid.bytes,type:j.HaveBlock})):(this.log("sending block for %c",o.cid),n.add(s),e.addBlock(o.cid,{data:i,prefix:hn(o.cid)}))}catch(i){if(i.name!=="NotFoundError")throw i;if(this.log("do not have block for %c",o.cid),!o.sendDontHave||o.sentDontHave===!0)continue;o.sentDontHave=!0,e.addBlockPresence(o.cid,{cid:o.cid.bytes,type:j.DontHaveBlock})}if(e.blocks.size>0||e.blockPresences.size>0){this.log("sending message"),await this.network.sendMessage(this.peerId,e,t),this.log("sent message"),this.sentBytes([...e.blocks.values()].reduce((s,o)=>s+o.data.byteLength,0));for(let s of n)this.wants.delete(s)}}};var We=class{blockstore;network;ledgerMap;maxSizeReplaceHasWithBlock;log;logger;constructor(t,e={}){this.blockstore=t.blockstore,this.network=t.network,this.maxSizeReplaceHasWithBlock=e.maxSizeReplaceHasWithBlock,this.log=t.logger.forComponent("helia:bitswap:peer-want-lists"),this.logger=t.logger,this.ledgerMap=ne({name:"helia_bitswap_ledger_map",metrics:t.metrics}),this.network.addEventListener("bitswap:message",n=>{this.receiveMessage(n.detail.peer,n.detail.message).catch(s=>{this.log.error("error receiving bitswap message from %p",n.detail.peer,s)})}),this.network.addEventListener("peer:disconnected",n=>{this.peerDisconnected(n.detail)})}ledgerForPeer(t){let e=this.ledgerMap.get(t);if(e!=null)return{peer:e.peerId,value:e.debtRatio(),sent:e.bytesSent,received:e.bytesReceived,exchanged:e.exchangeCount}}wantListForPeer(t){let e=this.ledgerMap.get(t);if(e!=null)return[...e.wants.values()]}peers(){return Array.from(this.ledgerMap.values()).map(t=>t.peerId)}async receiveMessage(t,e){let n=this.ledgerMap.get(t);if(n==null&&(n=new qe({peerId:t,blockstore:this.blockstore,network:this.network,logger:this.logger},{maxSizeReplaceHasWithBlock:this.maxSizeReplaceHasWithBlock}),this.ledgerMap.set(t,n)),n.receivedBytes(e.blocks?.reduce((s,o)=>s+o.data.byteLength,0)??0),e.wantlist!=null){e.wantlist.full===!0&&n.wants.clear();for(let s of e.wantlist.entries){let o=X.decode(s.cid),i=U(o.multihash.bytes,"base64");s.cancel===!0?(this.log("peer %p cancelled want of block for %c",t,o),n.wants.delete(i)):(s.wantType===F.WantHave?this.log("peer %p wanted block presence for %c",t,o):this.log("peer %p wanted block for %c",t,o),n.wants.set(i,{cid:o,priority:s.priority,wantType:s.wantType??F.WantBlock,sendDontHave:s.sendDontHave??!1}))}}this.log("send blocks to peer"),await n.sendBlocksToPeer()}async receivedBlock(t,e){let n=U(t.multihash.bytes,"base64"),s=[];for(let o of this.ledgerMap.values())o.wants.has(n)&&s.push(o);await Promise.all(s.map(async o=>o.sendBlocksToPeer(e)))}peerDisconnected(t){this.ledgerMap.delete(t)}};var ga=pr(_s(),1);var Ot;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(Ot||(Ot={}));var Ge=class extends Error{static name="InsufficientProvidersError";constructor(t="Insufficient providers found"){super(t),this.name="InsufficientProvidersError"}};var fn=pr(Ts(),1);var wa=Math.LN2*Math.LN2,Xe=class r{static create(t,e=.005){let n=ba(t,e);return new r(n)}seeds;bits;buffer;constructor(t={}){t.seeds!=null?this.seeds=t.seeds:this.seeds=xa(t.hashes??8),this.bits=t.bits??1024,this.buffer=R(Math.ceil(this.bits/8))}add(t){typeof t=="string"&&(t=pt(t));for(let e=0;e<this.seeds.length;e++){let s=fn.default.x86.hash32(t,this.seeds[e])%this.bits;this.setbit(s)}}has(t){typeof t=="string"&&(t=pt(t));for(let e=0;e<this.seeds.length;e++){let s=fn.default.x86.hash32(t,this.seeds[e])%this.bits;if(!this.getbit(s))return!1}return!0}clear(){this.buffer.fill(0)}setbit(t){let e=0,n=t;for(;n>7;)e++,n-=8;let s=this.buffer[e];s|=1<<n,this.buffer[e]=s}getbit(t){let e=0,n=t;for(;n>7;)e++,n-=8;return(this.buffer[e]&1<<n)!==0}};function ba(r,t=.005){let e=Math.round(-1*r*Math.log(t)/wa),n=Math.round(e/r*Math.LN2);return{bits:e,hashes:n}}function xa(r){let t,e,n=[];for(let s=0;s<r;s++)for(t=new ht(ze(4)),n[s]=t.getUint32(0,!0),e=0;e<s;e++)if(n[s]===n[e]){s--;break}return n}var At=class extends tt{intialPeerSearchComplete;requests;name;log;logger;minProviders;maxProviders;providers;evictionFilter;constructor(t,e){super(),W(1/0,this),this.name=e.name,this.logger=t.logger,this.log=t.logger.forComponent(this.name),this.requests=new Map,this.minProviders=e.minProviders??1,this.maxProviders=e.maxProviders??5,this.providers=[],this.evictionFilter=Xe.create(this.maxProviders)}async retrieve(t,e={}){let n=ct.encode(t.multihash.bytes),s=this.requests.get(n);if(s!=null)return this.log("join existing request for %c",t),s;let o=K();if(this.requests.set(n,o.promise),this.providers.length===0){let u=!1;this.intialPeerSearchComplete==null&&(u=!0,this.log=this.logger.forComponent(`${this.name}:${t}`),this.intialPeerSearchComplete=this.findProviders(t,this.minProviders,e)),await this.intialPeerSearchComplete,u&&this.log("found initial session peers for %c",t)}let i=!1,c=new Dt({concurrency:this.maxProviders});c.addEventListener("error",()=>{}),c.addEventListener("failure",u=>{this.log.error("error querying provider %o, evicting from session",u.detail.job.options.provider,u.detail.error),this.evict(u.detail.job.options.provider)}),c.addEventListener("success",u=>{i=!0,o.resolve(u.detail.result)}),c.addEventListener("idle",()=>{i||e.signal?.aborted===!0||Promise.resolve().then(async()=>{this.log("no session peers had block for for %c, finding new providers",t);for(let u=0;u<this.minProviders&&this.providers.length!==0;u++){let d=this.providers[Math.floor(Math.random()*this.providers.length)];this.evict(d)}await this.findProviders(t,this.minProviders,e),this.log("found new providers re-retrieving %c",t),this.requests.delete(n),o.resolve(await this.retrieve(t,e))}).catch(u=>{this.log.error("could not find new providers for %c",t,u),o.reject(u)})});let l=u=>{c.add(async()=>this.queryProvider(t,u.detail,e),{provider:u.detail}).catch(d=>{e.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c",t,d)})};this.addEventListener("provider",l),Promise.all([...this.providers].map(async u=>c.add(async()=>this.queryProvider(t,u,e),{provider:u}))).catch(u=>{e.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c",t,u)});try{return await o.promise}finally{this.removeEventListener("provider",l),c.clear(),this.requests.delete(n)}}evict(t){this.evictionFilter.add(this.toEvictionKey(t));let e=this.providers.findIndex(n=>this.equals(n,t));e!==-1&&this.providers.splice(e,1)}isEvicted(t){return this.evictionFilter.has(this.toEvictionKey(t))}hasProvider(t){return!!(this.providers.find(e=>this.equals(e,t))!=null||this.isEvicted(t))}async findProviders(t,e,n){let s=K(),o=0;return Promise.resolve().then(async()=>{this.log("finding %d-%d new provider(s) for %c",e,this.maxProviders,t);for await(let i of this.findNewProviders(t,n)){if(o===this.maxProviders||n.signal?.aborted===!0)break;if(!this.hasProvider(i)&&(this.log("found %d/%d new providers",o,this.maxProviders),this.providers.push(i),this.safeDispatchEvent("provider",{detail:i}),o++,o===e&&(this.log("session is ready"),s.resolve()),this.providers.length===this.maxProviders)){this.log("found max session peers",o);break}}if(this.log("found %d/%d new session peers",o,this.maxProviders),o<e)throw new Ge(`Found ${o} of ${e} ${this.name} providers for ${t}`)}).catch(i=>{this.log.error("error searching routing for potential session peers for %c",t,i.errors??i),s.reject(i)}),s.promise}};var dn=class extends At{wantList;network;constructor(t,e){super(t,{...e,name:"helia:bitswap:session"}),this.wantList=t.wantList,this.network=t.network}async queryProvider(t,e,n){this.log("sending WANT-BLOCK for %c to %p",t,e);let s=await this.wantList.wantSessionBlock(t,e,n);if(this.log("%p %s %c",e,s.has?"has":"does not have",t),s.has&&s.block!=null)return s.block;throw new Error("Provider did not have block")}async*findNewProviders(t,e={}){for await(let n of this.network.findProviders(t,e))yield n.id}toEvictionKey(t){return t.toMultihash().bytes}equals(t,e){return t.equals(e)}};function Us(r,t){return new dn(r,t)}var Qe=class{blocksReceived;duplicateBlocksReceived;dataReceived;duplicateDataReceived;constructor(t){this.blocksReceived=t.metrics?.registerMetricGroup("helia_bitswap_received_blocks"),this.duplicateBlocksReceived=t.metrics?.registerMetricGroup("helia_bitswap_duplicate_received_blocks"),this.dataReceived=t.metrics?.registerMetricGroup("helia_bitswap_data_received_bytes"),this.duplicateDataReceived=t.metrics?.registerMetricGroup("helia_bitswap_duplicate_data_received_bytes")}updateBlocksReceived(t=1,e){let n={global:t};e!=null&&(n[e.toString()]=t),this.blocksReceived?.increment(n)}updateDuplicateBlocksReceived(t=1,e){let n={global:t};e!=null&&(n[e.toString()]=t),this.duplicateBlocksReceived?.increment(n)}updateDataReceived(t,e){let n={global:t};e!=null&&(n[e.toString()]=t),this.dataReceived?.increment(n)}updateDuplicateDataReceived(t,e){let n={global:t};e!=null&&(n[e.toString()]=t),this.duplicateDataReceived?.increment(n)}};var pn=class extends Map{metric;constructor(t){super();let{name:e,metrics:n}=t;this.metric=n.registerMetric(e),this.updateComponentMetric()}set(t,e){return super.set(t,e),this.updateComponentMetric(),this}delete(t){let e=super.delete(t);return this.updateComponentMetric(),e}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function Cs(r){let{name:t,metrics:e}=r,n;return e!=null?n=new pn({name:t,metrics:e}):n=new Map,n}function Ea(r){if(!(r instanceof Uint8Array))throw new Error("arg needs to be a Uint8Array");let t=[];for(;r.length>0;){let e=Z(r);t.push(e),r=r.slice(P(e))}return t}var Ms=Ea;var je=class extends tt{peers;wants;network;log;sendMessagesDelay;sendMessagesTimeout;hashLoader;sendingMessages;constructor(t,e={}){super(),W(1/0,this),this.peers=ne({name:"helia_bitswap_peers",metrics:t.metrics}),this.wants=Cs({name:"helia_bitswap_wantlist",metrics:t.metrics}),this.network=t.network,this.sendMessagesDelay=e.sendMessagesDelay??10,this.log=t.logger.forComponent("helia:bitswap:wantlist"),this.hashLoader=e.hashLoader,this.network.addEventListener("bitswap:message",n=>{this.receiveMessage(n.detail.peer,n.detail.message).catch(s=>{this.log.error("error receiving bitswap message from %p",n.detail.peer,s)})}),this.network.addEventListener("peer:connected",n=>{this.peerConnected(n.detail).catch(s=>{this.log.error("error processing newly connected bitswap peer %p",n.detail,s)})}),this.network.addEventListener("peer:disconnected",n=>{this.peerDisconnected(n.detail)})}async addEntry(t,e){let n=U(t.multihash.bytes,"base64"),s=this.wants.get(n);s==null&&(s={cid:t,priority:e.priority??1,wantType:e.wantType??F.WantBlock,cancel:!1,sendDontHave:!0},this.wants.set(n,s)),s.wantType===F.WantHave&&e.wantType===F.WantBlock&&(s.wantType=F.WantBlock),await this.sendMessagesDebounced();try{return e.wantType===F.WantBlock?(await J(this,"block",e?.signal,{filter:c=>ot(t.multihash.digest,c.detail.cid.multihash.digest),errorMessage:"Want was aborted"})).detail:(await J(this,"presence",e?.signal,{filter:i=>ot(t.multihash.digest,i.detail.cid.multihash.digest),errorMessage:"Want was aborted"})).detail}finally{e.signal?.aborted===!0&&(this.log("want for %c was aborted, cancelling want",t),s.cancel=!0,await this.sendMessagesDebounced())}}async sendMessagesDebounced(){await this.sendingMessages?.promise,clearTimeout(this.sendMessagesTimeout),this.sendMessagesTimeout=setTimeout(()=>{this.sendMessages().catch(t=>{this.log("error sending messages to peers",t)})},this.sendMessagesDelay)}async sendMessages(){this.sendingMessages=K(),await Promise.all([...this.peers.entries()].map(async([t,e])=>{let n=new Set,s=new lt;for(let[o,i]of this.wants.entries())e.has(o)||i.cancel||(n.add(o),s.addWantlistEntry(i.cid,{cid:i.cid.bytes,priority:i.priority,wantType:i.wantType,cancel:i.cancel,sendDontHave:i.sendDontHave}));if(s.wantlist.size!==0)try{await this.network.sendMessage(t,s);for(let o of n)e.add(o)}catch(o){this.log.error("error sending full wantlist to new peer",o)}})).catch(t=>{this.log.error("error sending messages",t)});for(let[t,e]of this.wants)if(e.cancel){this.wants.delete(t);for(let n of this.peers.values())n.delete(t)}this.sendingMessages.resolve()}has(t){let e=U(t.multihash.bytes,"base64");return this.wants.has(e)}async wantSessionPresence(t,e,n={}){let s=new lt;return s.addWantlistEntry(t,{cid:t.bytes,sendDontHave:!0,wantType:F.WantHave,priority:1}),await this.network.sendMessage(e,s),(await J(this,"presence",n.signal,{filter:i=>e.equals(i.detail.sender)&&ot(t.multihash.digest,i.detail.cid.multihash.digest)})).detail}async wantBlock(t,e={}){return this.addEntry(t,{...e,wantType:F.WantBlock})}async wantSessionBlock(t,e,n={}){let s=new lt;return s.addWantlistEntry(t,{cid:t.bytes,sendDontHave:!0,wantType:F.WantBlock,priority:1}),await this.network.sendMessage(e,s),(await J(this,"presence",n.signal,{filter:i=>e.equals(i.detail.sender)&&ot(t.multihash.digest,i.detail.cid.multihash.digest)})).detail}async receivedBlock(t,e){let n=U(t.multihash.bytes,"base64"),s=this.wants.get(n);s!=null&&(s.cancel=!0,await this.sendMessagesDebounced())}async receiveMessage(t,e){this.log("received message from %p with %d blocks",t,e.blocks.length);let n=!1;for(let s of e.blocks){if(s.prefix==null||s.data==null)continue;let o=Ms(s.prefix),i=o[0],c=o[1],l=o[2],u=l===Ue.code?Ue:await this.hashLoader?.getHasher(l);if(u==null){this.log.error("unknown hash algorithm",l);continue}let d=u.digest(s.data);d.then!=null&&(d=await d);let f=X.create(i===0?0:1,c,d);this.log("received block from %p for %c",t,f),this.safeDispatchEvent("block",{detail:{sender:t,cid:f,block:s.data}}),this.safeDispatchEvent("presence",{detail:{sender:t,cid:f,has:!0,block:s.data}});let y=U(f.multihash.bytes,"base64"),a=this.wants.get(y);a!=null&&(a.cancel=!0,n=!0)}for(let{cid:s,type:o}of e.blockPresences){let i=X.decode(s);this.log("received %s from %p for %c",o,t,i),this.safeDispatchEvent("presence",{detail:{sender:t,cid:i,has:o===j.HaveBlock}})}n&&await this.sendMessagesDebounced()}async peerConnected(t){let e=new Set,n=new lt(!0);for(let[s,o]of this.wants.entries())o.cancel||(e.add(s),n.addWantlistEntry(o.cid,{cid:o.cid.bytes,priority:1,wantType:F.WantBlock,cancel:!1,sendDontHave:!1}));if(n.wantlist.size===0){this.peers.set(t,e);return}try{await this.network.sendMessage(t,n),this.peers.set(t,e)}catch(s){this.log.error("error sending full wantlist to new peer %p",t,s)}}peerDisconnected(t){this.peers.delete(t)}start(){}stop(){this.peers.clear(),clearTimeout(this.sendMessagesTimeout)}};var Ke=class{log;logger;stats;network;blockstore;peerWantLists;wantList;constructor(t,e={}){this.logger=t.logger,this.log=t.logger.forComponent("helia:bitswap"),this.blockstore=t.blockstore,this.stats=new Qe(t),this.network=new $e(t,e),this.peerWantLists=new We({...t,network:this.network},e),this.wantList=new je({...t,network:this.network},e)}createSession(t={}){return Us({wantList:this.wantList,network:this.network,logger:this.logger},t)}async want(t,e={}){let n=new AbortController,s=On([n.signal,e.signal]);W(1/0,n.signal,s),this.network.findAndConnect(t,{...e,signal:s}).catch(o=>{n.signal.aborted||this.log.error("error during finding and connect for cid %c",t,o)});try{return(await this.wantList.wantBlock(t,{...e,signal:s})).block}finally{n.abort(),s.clear()}}async notify(t,e,n={}){await Promise.all([this.peerWantLists.receivedBlock(t,n),this.wantList.receivedBlock(t,n)])}getWantlist(){return[...this.wantList.wants.values()].filter(t=>!t.cancel).map(t=>({cid:t.cid,priority:t.priority,wantType:t.wantType}))}getPeerWantlist(t){return this.peerWantLists.wantListForPeer(t)}async start(){this.wantList.start(),await this.network.start()}async stop(){this.wantList.stop(),await this.network.stop()}};var Fs=(r,t={})=>new Ke(r,t);var mn=class{bitswap;started;constructor(t,e={}){let{getHasher:n}=t;this.bitswap=Fs(t,{hashLoader:{getHasher:async s=>n(s)},...e}),this.started=!1}isStarted(){return this.started}async start(){await this.bitswap.start(),this.started=!0}async stop(){await this.bitswap.stop(),this.started=!1}async announce(t,e,n){await this.bitswap.notify(t,e,n)}async retrieve(t,e={}){return this.bitswap.want(t,e)}createSession(t){let e=this.bitswap.createSession(t);return{announce:async(n,s,o)=>{await this.bitswap.notify(n,s,o)},retrieve:async(n,s)=>e.retrieve(n,s)}}};function Ns(r={}){return t=>new mn(t,r)}var Je=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,s){return this.readAtomically(()=>{let o=0,i=0,c=this.peekChar();if(c===void 0)return;let l=c==="0",u=2**(8*s)-1;for(;;){let d=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let y=Number.parseInt(f,t);if(!Number.isNaN(y))return y});if(d===void 0)break;if(o*=t,o+=d,o>u||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&l&&i>1?void 0:o})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let s=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[s]=i[0],e[s+1]=i[1],e[s+2]=i[2],e[s+3]=i[3],[s+4,!0]}let o=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(o===void 0)return[s,!1];e[s]=o>>8,e[s+1]=o&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,s]=t(e);if(n===16)return e;if(s||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let o=new Uint8Array(14),i=16-(n+2),[c]=t(o.subarray(0,i));return e.set(o.subarray(0,c),16-c),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Bs=45,ka=15,$t=new Je;function gn(r){if(!(r.length>ka))return $t.new(r).parseWith(()=>$t.readIPv4Addr())}function wn(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Bs))return $t.new(r).parseWith(()=>$t.readIPv6Addr())}function Ze(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Bs))return $t.new(r).parseWith(()=>$t.readIPAddr())}function zt(r){return!!gn(r)}function Vt(r){return!!wn(r)}function Ye(r){return!!Ze(r)}var Os=pr(Rs(),1),Sa=["0.0.0.0/8","10.0.0.0/8","100.64.0.0/10","127.0.0.0/8","169.254.0.0/16","172.16.0.0/12","192.0.0.0/24","192.0.0.0/29","192.0.0.8/32","192.0.0.9/32","192.0.0.10/32","192.0.0.170/32","192.0.0.171/32","192.0.2.0/24","192.31.196.0/24","192.52.193.0/24","192.88.99.0/24","192.168.0.0/16","192.175.48.0/24","198.18.0.0/15","198.51.100.0/24","203.0.113.0/24","240.0.0.0/4","255.255.255.255/32"],Aa=Sa.map(r=>new Os.Netmask(r));function bn(r){for(let t of Aa)if(t.contains(r))return!0;return!1}function La(r){return/^::ffff:([0-9a-fA-F]{1,4}):([0-9a-fA-F]{1,4})$/.test(r)}function Ia(r){let t=r.split(":");if(t.length<2)return!1;let e=t[t.length-1].padStart(4,"0"),n=t[t.length-2].padStart(4,"0"),s=`${parseInt(n.substring(0,2),16)}.${parseInt(n.substring(2),16)}.${parseInt(e.substring(0,2),16)}.${parseInt(e.substring(2),16)}`;return bn(s)}function Ta(r){return/^::ffff:([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)}function Da(r){let t=r.split(":"),e=t[t.length-1];return bn(e)}function Pa(r){return/^::$/.test(r)||/^::1$/.test(r)||/^64:ff9b::([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)||/^100::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001:2[0-9a-fA-F]:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001:db8:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2002:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^f[c-d]([0-9a-fA-F]{2,2}):/i.test(r)||/^fe[8-9a-bA-B][0-9a-fA-F]:/i.test(r)||/^ff([0-9a-fA-F]{2,2}):/i.test(r)}function $s(r){return zt(r)?bn(r):La(r)?Ia(r):Ta(r)?Da(r):Vt(r)?Pa(r):void 0}var _d=parseInt("0xFFFF",16),Ud=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Hs=zt,Fa=Vt,xn=function(r){let t=0;if(r=r.toString().trim(),Hs(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(Fa(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let o=Hs(e[n]),i;o&&(i=xn(e[n]),e[n]=U(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,U(i.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let o=[n,1];for(n=9-e.length;n>0;n--)o.push("0");e.splice.apply(e,o)}let s=new Uint8Array(t+16);for(n=0;n<e.length;n++){let o=parseInt(e[n],16);s[t++]=o>>8&255,s[t++]=o&255}return s}throw new Error("invalid ip address")},qs=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let s=[];for(let o=0;o<e;o++)s.push(r[t+o]);return s.join(".")}if(e===16){let s=[];for(let o=0;o<e;o+=2)s.push(n.getUint16(t+o).toString(16));return s.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var Ht={},yn={},Ba=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[481,-1,"http-path"],[777,-1,"memory"]];Ba.forEach(r=>{let t=Ra(...r);yn[t.code]=t,Ht[t.name]=t});function Ra(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function k(r){if(typeof r=="number"){if(yn[r]!=null)return yn[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(Ht[r]!=null)return Ht[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var dp=k("ip4"),pp=k("ip6"),mp=k("ipcidr");function Sn(r,t){switch(k(r).code){case 4:case 41:return $a(t);case 42:return kn(t);case 6:case 273:case 33:case 132:return Xs(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return kn(t);case 421:return qa(t);case 444:return Gs(t);case 445:return Gs(t);case 466:return Ha(t);case 481:return globalThis.encodeURIComponent(kn(t));default:return U(t,"base16")}}function An(r,t){switch(k(r).code){case 4:return Ws(t);case 41:return Ws(t);case 42:return En(t);case 6:case 273:case 33:case 132:return Ln(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return En(t);case 421:return za(t);case 444:return Wa(t);case 445:return Ga(t);case 466:return Va(t);case 481:return En(globalThis.decodeURIComponent(t));default:return pt(t,"base16")}}var vn=Object.values(Zt).map(r=>r.decoder),Oa=function(){let r=vn[0].or(vn[1]);return vn.slice(2).forEach(t=>r=r.or(t)),r}();function Ws(r){if(!Ye(r))throw new Error("invalid ip address");return xn(r)}function $a(r){let t=qs(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!Ye(t))throw new Error("invalid ip address");return t}function Ln(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Xs(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function En(r){let t=pt(r),e=Uint8Array.from(et(t.length));return Q([e,t],e.length+t.length)}function kn(r){let t=Z(r);if(r=r.slice(P(t)),r.length!==t)throw new Error("inconsistent lengths");return U(r)}function za(r){let t;r[0]==="Q"||r[0]==="1"?t=Kt(B.decode(`z${r}`)).bytes:t=X.parse(r).multihash.bytes;let e=Uint8Array.from(et(t.length));return Q([e,t],e.length+t.length)}function Va(r){let t=Oa.decode(r),e=Uint8Array.from(et(t.length));return Q([e,t],e.length+t.length)}function Ha(r){let t=Z(r),e=r.slice(P(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+U(e,"base64url")}function qa(r){let t=Z(r),e=r.slice(P(t));if(e.length!==t)throw new Error("inconsistent lengths");return U(e,"base58btc")}function Wa(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let e=at.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=Ln(n);return Q([e,s],e.length+s.length)}function Ga(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let e=at.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=Ln(n);return Q([e,s],e.length+s.length)}function Gs(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=U(t,"base32"),s=Xs(e);return`${n}:${s}`}function Qs(r){r=In(r);let t=[],e=[],n=null,s=r.split("/").slice(1);if(s.length===1&&s[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let o=0;o<s.length;o++){let i=s[o],c=k(i);if(c.size===0){t.push([c.code]),e.push([c.code]);continue}if(o++,o>=s.length)throw Ks("invalid address: "+r);if(c.path===!0){n=In(s.slice(o).join("/")),t.push([c.code,An(c.code,n)]),e.push([c.code,n]);break}let l=An(c.code,s[o]);t.push([c.code,l]),e.push([c.code,Sn(c.code,l)])}return{string:js(e),bytes:Dn(t),tuples:t,stringTuples:e,path:n}}function Tn(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let o=Z(r,s),i=P(o),c=k(o),l=Xa(c,r.slice(s+i));if(l===0){t.push([o]),e.push([o]),s+=i;continue}let u=r.slice(s+i,s+i+l);if(s+=l+i,s>r.length)throw Ks("Invalid address Uint8Array: "+U(r,"base16"));t.push([o,u]);let d=Sn(o,u);if(e.push([o,d]),c.path===!0){n=d;break}}return{bytes:Uint8Array.from(r),string:js(e),tuples:t,stringTuples:e,path:n}}function js(r){let t=[];return r.map(e=>{let n=k(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),In(t.join("/"))}function Dn(r){return Q(r.map(t=>{let e=k(t[0]),n=Uint8Array.from(et(e.code));return t.length>1&&t[1]!=null&&(n=Q([n,t[1]])),n}))}function Xa(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Z(t instanceof Uint8Array?t:Uint8Array.from(t));return e+P(e)}}function In(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function Ks(r){return new Error("Error parsing address: "+r)}var Qa=Symbol.for("nodejs.util.inspect.custom"),_n=Symbol.for("@multiformats/js-multiaddr/multiaddr"),ja=[k("dns").code,k("dns4").code,k("dns6").code,k("dnsaddr").code],Pn=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},tr=class r{bytes;#t;#e;#r;#n;[_n]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Tn(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Qs(t)}else if(Zs(t))e=Tn(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#t=e.string,this.#e=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#t}toJSON(){return this.toString()}toOptions(){let t,e,n,s,o="",i=k("tcp"),c=k("udp"),l=k("ip4"),u=k("ip6"),d=k("dns6"),f=k("ip6zone");for(let[a,h]of this.stringTuples())a===f.code&&(o=`%${h??""}`),ja.includes(a)&&(e=i.name,s=443,n=`${h??""}${o}`,t=a===d.code?6:4),(a===i.code||a===c.code)&&(e=k(a).name,s=parseInt(h??"")),(a===l.code||a===u.code)&&(e=k(a).name,n=`${h??""}${o}`,t=a===u.code?6:4);if(t==null||e==null||n==null||s==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:s}}protos(){return this.#e.map(([t])=>Object.assign({},k(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>k(t).name)}tuples(){return this.#e}stringTuples(){return this.#r}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),s=n.lastIndexOf(e);if(s<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,s))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(Dn(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,s])=>{n===Ht.p2p.code&&t.push([n,s]),n===Ht["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?U(B.decode(`z${n}`),"base58btc"):U(X.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return ot(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(o=>o.resolvable);if(e==null)return[this];let n=Js.get(e.name);if(n==null)throw new Pn(`no available resolver for ${e.name}`);return(await n(this,t)).map(o=>oe(o))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[Qa](){return`Multiaddr(${this.#t})`}};var Js=new Map;function Zs(r){return!!r?.[_n]}function oe(r){return new tr(r)}var Ka=r=>r.toString().split("/").slice(1),ie=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),L=r=>({match:t=>ie(e=>e===r).match(t),pattern:r}),nr=()=>({match:r=>ie(t=>typeof t=="string").match(r),pattern:"{string}"}),sr=()=>({match:r=>ie(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),C=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{B.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),er=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Hr.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),_=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),V=(...r)=>({match:t=>{let e;for(let n of r){let s=n.match(t);s!==!1&&(e==null||s.length<e.length)&&(e=s)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),T=(...r)=>({match:t=>{for(let e of r){let n=e.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${r.map(t=>t.pattern).join(", ")})`});function N(...r){function t(s){let o=Ka(s);for(let i of r){let c=i.match(o);if(c===!1)return!1;o=c}return o}function e(s){return t(s)!==!1}function n(s){let o=t(s);return o===!1?!1:o.length===0}return{matches:e,exactMatch:n}}var or=T(L("dns4"),nr()),ir=T(L("dns6"),nr()),ar=T(L("dnsaddr"),nr()),Cn=T(L("dns"),nr()),Hp=N(or,_(C())),qp=N(ir,_(C())),Wp=N(ar,_(C())),Ys=N(V(Cn,ar,or,ir),_(C())),to=T(L("ip4"),ie(zt)),eo=T(L("ip6"),ie(Vt)),Mn=V(to,eo),ut=V(Mn,Cn,or,ir,ar),Gp=N(V(Mn,T(V(Cn,ar,or,ir),_(C())))),Xp=N(to),Qp=N(eo),jp=N(Mn),Fn=T(ut,L("tcp"),sr()),ae=T(ut,L("udp"),sr()),Kp=N(T(Fn,_(C()))),Jp=N(ae),Nn=T(ae,L("quic")),cr=T(ae,L("quic-v1")),Ja=V(Nn,cr),Zp=N(Nn),Yp=N(cr),Un=V(ut,Fn,ae,Nn,cr),ro=V(T(Un,L("ws"),_(C()))),tm=N(ro),no=V(T(Un,L("wss"),_(C())),T(Un,L("tls"),L("ws"),_(C()))),em=N(no),so=T(ae,L("webrtc-direct"),_(er()),_(er()),_(C())),rm=N(so),oo=T(cr,L("webtransport"),_(er()),_(er()),_(C())),nm=N(oo),rr=V(ro,no,T(Fn,_(C())),T(Ja,_(C())),T(ut,_(C())),so,oo,C()),sm=N(rr),Za=T(rr,L("p2p-circuit"),C()),om=N(Za),Ya=V(T(rr,L("p2p-circuit"),L("webrtc"),_(C())),T(rr,L("webrtc"),_(C())),L("webrtc")),im=N(Ya),tc=V(T(ut,L("tcp"),sr(),L("http"),_(C())),T(ut,L("http"),_(C()))),io=N(tc),ec=V(T(ut,L("tcp"),V(T(L("443"),L("http")),T(sr(),L("https"))),_(C())),T(ut,L("tls"),L("http"),_(C())),T(ut,L("https"),_(C()))),ao=N(ec);var rc=[k("tcp").code,k("dns").code,k("dnsaddr").code,k("dns4").code,k("dns6").code];function co(r){let t;try{t=k("sni").code}catch{return null}for(let[e,n]of r)if(e===t&&n!==void 0)return n;return null}function lo(r){return r.some(([t,e])=>t===k("tls").code)}function H(r,t,e){let n=uo[k(r).name];if(n===void 0)throw new Error(`Can't interpret protocol ${k(r).name}`);let s=n(t,e);return r===k("ip6").code?`[${s}]`:s}var uo={ip4:(r,t)=>r,ip6:(r,t)=>t.length===0?r:`[${r}]`,tcp:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`tcp://${H(e[0],e[1]??"",t)}:${r}`},udp:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`udp://${H(e[0],e[1]??"",t)}:${r}`},dnsaddr:(r,t)=>r,dns4:(r,t)=>r,dns6:(r,t)=>r,dns:(r,t)=>r,ipfs:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${H(e[0],e[1]??"",t)}/ipfs/${r}`},p2p:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${H(e[0],e[1]??"",t)}/p2p/${r}`},http:(r,t)=>{let e=lo(t),n=co(t);if(e&&n!==null)return`https://${n}`;let s=e?"https://":"http://",o=t.pop();if(o===void 0)throw new Error("Unexpected end of multiaddr");let i=H(o[0],o[1]??"",t);return i=i.replace("tcp://",""),`${s}${i}`},"http-path":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");let n=H(e[0],e[1]??"",t),s=decodeURIComponent(r);return`${n}/${s}`},tls:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return H(e[0],e[1]??"",t)},sni:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return H(e[0],e[1]??"",t)},https:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");let n=H(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`https://${n}`},ws:(r,t)=>{let e=lo(t),n=co(t);if(e&&n!==null)return`wss://${n}`;let s=e?"wss://":"ws://",o=t.pop();if(o===void 0)throw new Error("Unexpected end of multiaddr");let i=H(o[0],o[1]??"",t);return i=i.replace("tcp://",""),`${s}${i}`},wss:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");let n=H(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`wss://${n}`},"p2p-websocket-star":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${H(e[0],e[1]??"",t)}/p2p-websocket-star`},"p2p-webrtc-star":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${H(e[0],e[1]??"",t)}/p2p-webrtc-star`},"p2p-webrtc-direct":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${H(e[0],e[1]??"",t)}/p2p-webrtc-direct`}};function ho(r,t){let n=oe(r).stringTuples(),s=n.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let o=k(s[0]),i=uo[o.name];if(i==null)throw new Error(`No interpreter found for ${o.name}`);let c=i(s[1]??"",n);return t?.assumeHttp!==!1&&rc.includes(s[0])&&(c=c.replace(/^.*:\/\//,""),s[1]==="443"?c=`https://${c}`:c=`http://${c}`),(c.startsWith("http://")||c.startsWith("https://"))&&(c=new URL(c).toString(),c.endsWith("/")&&(c=c.substring(0,c.length-1))),c}var lr=class{url;#t=0;#e=0;#r=0;#n=0;#s=new Map;log;constructor(t,e){this.url=t instanceof URL?t:new URL(t),this.log=e.forComponent(`helia:trustless-gateway-block-broker:${this.url.hostname}`)}#o(t){let e=t.multihash.bytes;return ct.encode(e)}async getRawBlock(t,e){let n=new URL(this.url.toString());if(n.pathname=`/ipfs/${t.toString()}`,n.search="?format=raw",e?.aborted===!0)throw new Error(`Signal to fetch raw block for CID ${t} from gateway ${this.url} was aborted prior to fetch`);let s=this.#o(t),o=new AbortController,i=()=>{o.abort()};e?.addEventListener("abort",i);try{let c=this.#s.get(s);return c==null&&(this.#t++,c=fetch(n.toString(),{signal:o.signal,headers:{Accept:"application/vnd.ipld.raw"},cache:"force-cache"}).then(async l=>{if(this.log("GET %s %d",n,l.status),!l.ok)throw this.#e++,new Error(`unable to fetch raw block for CID ${t} from gateway ${this.url}`);return this.#n++,new Uint8Array(await l.arrayBuffer())}),this.#s.set(s,c)),await c}catch{throw e?.aborted===!0?new Error(`fetching raw block for CID ${t} from gateway ${this.url} was aborted`):(this.#e++,new Error(`unable to fetch raw block for CID ${t}`))}finally{e?.removeEventListener("abort",i),this.#s.delete(s)}}reliability(){return this.#t===0?1:this.#r>0?-1/0:this.#n/(this.#t+this.#e*3)}incrementInvalidBlocks(){this.#r++}getStats(){return{attempts:this.#t,errors:this.#e,invalidBlocks:this.#r,successes:this.#n,pendingResponses:this.#s.size}}};function nc(r,t,e){return r.filter(n=>{if(ao.matches(n)||t&&io.matches(n))return e||Ys.matches(n)?!0:$s(n.toOptions().host)===!1;if(!t&&e){let{host:s}=n.toOptions();if(s==="127.0.0.1"||s==="localhost"||s.endsWith(".localhost"))return!0}return!1})}async function*ur(r,t,e,n,s,o){for await(let i of t.findProviders(r,o)){let c=nc(i.multiaddrs,n,s);if(c.length===0)continue;let l=ho(c[0]);yield new lr(l,e)}}var Bn=class extends At{routing;allowInsecure;allowLocal;constructor(t,e){super(t,{...e,name:"helia:trustless-gateway:session"}),this.routing=t.routing,this.allowInsecure=e.allowInsecure??hr,this.allowLocal=e.allowLocal??fr}async queryProvider(t,e,n){this.log("fetching BLOCK for %c from %s",t,e.url);let s=await e.getRawBlock(t,n.signal);return this.log.trace("got block for %c from %s",t,e.url),await n.validateFn?.(s),s}async*findNewProviders(t,e={}){yield*ur(t,this.routing,this.logger,this.allowInsecure,this.allowLocal,e)}toEvictionKey(t){return t.url.toString()}equals(t,e){return t.url.toString()===e.url.toString()}};function fo(r,t){return new Bn(r,t)}var dr=class{allowInsecure;allowLocal;routing;log;logger;constructor(t,e={}){this.log=t.logger.forComponent("helia:trustless-gateway-block-broker"),this.logger=t.logger,this.routing=t.routing,this.allowInsecure=e.allowInsecure??hr,this.allowLocal=e.allowLocal??fr}async retrieve(t,e={}){let n=[];for await(let s of ur(t,this.routing,this.logger,this.allowInsecure,this.allowLocal,e)){this.log("getting block for %c from %s",t,s.url);try{let o=await s.getRawBlock(t,e.signal);this.log.trace("got block for %c from %s",t,s.url);try{await e.validateFn?.(o)}catch(i){this.log.error("failed to validate block for %c from %s",t,s.url,i);continue}return o}catch(o){if(this.log.error("failed to get block for %c from %s",t,s.url,o),o instanceof Error?n.push(o):n.push(new Error(`Unable to fetch raw block for CID ${t} from gateway ${s.url}`)),e.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",t,s.url);break}}}throw n.length>0?new AggregateError(n,`Unable to fetch raw block for CID ${t} from any gateway`):new Error(`Unable to fetch raw block for CID ${t} from any gateway`)}createSession(t={}){return fo({logger:this.logger,routing:this.routing},{...t,allowLocal:this.allowLocal,allowInsecure:this.allowInsecure})}};var hr=!1,fr=!1;function po(r={}){return t=>new dr(t,r)}return yo(sc);})();
3
3
  /*! Bundled license information:
4
4
 
5
5
  @noble/hashes/esm/utils.js:
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@helia/block-brokers",
3
- "version": "3.0.4-c04dbf5",
3
+ "version": "3.0.4-efdefc1",
4
4
  "description": "Block brokers for Helia",
5
5
  "license": "Apache-2.0 OR MIT",
6
6
  "homepage": "https://github.com/ipfs/helia/tree/main/packages/block-brokers#readme",
@@ -54,9 +54,9 @@
54
54
  "test:electron-main": "aegir test -t electron-main"
55
55
  },
56
56
  "dependencies": {
57
- "@helia/bitswap": "1.1.4-c04dbf5",
58
- "@helia/interface": "4.3.1-c04dbf5",
59
- "@helia/utils": "0.3.3-c04dbf5",
57
+ "@helia/bitswap": "1.1.4-efdefc1",
58
+ "@helia/interface": "4.3.1-efdefc1",
59
+ "@helia/utils": "0.3.3-efdefc1",
60
60
  "@libp2p/interface": "^2.0.0",
61
61
  "@libp2p/utils": "^6.0.0",
62
62
  "@multiformats/multiaddr": "^12.2.1",