@helia/block-brokers 3.0.4 → 4.0.0-0238ed4

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 So=Object.create;var be=Object.defineProperty;var Ao=Object.getOwnPropertyDescriptor;var ko=Object.getOwnPropertyNames;var Lo=Object.getPrototypeOf,Io=Object.prototype.hasOwnProperty;var ye=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),q=(r,t)=>{for(var e in t)be(r,e,{get:t[e],enumerable:!0})},On=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of ko(t))!Io.call(r,s)&&s!==e&&be(r,s,{get:()=>t[s],enumerable:!(n=Ao(t,s))||n.enumerable});return r};var ur=(r,t,e)=>(e=r!=null?So(Lo(r)):{},On(t||!r||!r.__esModule?be(e,"default",{value:r,enumerable:!0}):e,r)),To=r=>On(be({},"__esModule",{value:!0}),r);var Rs=ye((le,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 x(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,v=a.length-p,m=h,g=0,w=3432918353,y=461845907,E=0;E<v;E=E+4)g=a[E]|a[E+1]<<8|a[E+2]<<16|a[E+3]<<24,g=s(g,w),g=o(g,15),g=s(g,y),m^=g,m=o(m,13),m=s(m,5)+3864292196;switch(g=0,p){case 3:g^=a[E+2]<<16;case 2:g^=a[E+1]<<8;case 1:g^=a[E],g=s(g,w),g=o(g,15),g=s(g,y),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,v=a.length-p,m=h,g=h,w=h,y=h,E=0,A=0,b=0,T=0,at=597399067,me=2869860233,ge=951274213,we=2716044179,k=0;k<v;k=k+16)E=a[k]|a[k+1]<<8|a[k+2]<<16|a[k+3]<<24,A=a[k+4]|a[k+5]<<8|a[k+6]<<16|a[k+7]<<24,b=a[k+8]|a[k+9]<<8|a[k+10]<<16|a[k+11]<<24,T=a[k+12]|a[k+13]<<8|a[k+14]<<16|a[k+15]<<24,E=s(E,at),E=o(E,15),E=s(E,me),m^=E,m=o(m,19),m+=g,m=s(m,5)+1444728091,A=s(A,me),A=o(A,16),A=s(A,ge),g^=A,g=o(g,17),g+=w,g=s(g,5)+197830471,b=s(b,ge),b=o(b,17),b=s(b,we),w^=b,w=o(w,15),w+=y,w=s(w,5)+2530024501,T=s(T,we),T=o(T,18),T=s(T,at),y^=T,y=o(y,13),y+=m,y=s(y,5)+850148119;switch(E=0,A=0,b=0,T=0,p){case 15:T^=a[k+14]<<16;case 14:T^=a[k+13]<<8;case 13:T^=a[k+12],T=s(T,we),T=o(T,18),T=s(T,at),y^=T;case 12:b^=a[k+11]<<24;case 11:b^=a[k+10]<<16;case 10:b^=a[k+9]<<8;case 9:b^=a[k+8],b=s(b,ge),b=o(b,17),b=s(b,we),w^=b;case 8:A^=a[k+7]<<24;case 7:A^=a[k+6]<<16;case 6:A^=a[k+5]<<8;case 5:A^=a[k+4],A=s(A,me),A=o(A,16),A=s(A,ge),g^=A;case 4:E^=a[k+3]<<24;case 3:E^=a[k+2]<<16;case 2:E^=a[k+1]<<8;case 1:E^=a[k],E=s(E,at),E=o(E,15),E=s(E,me),m^=E}return m^=a.length,g^=a.length,w^=a.length,y^=a.length,m+=g,m+=w,m+=y,g+=m,w+=m,y+=m,m=i(m),g=i(g),w=i(w),y=i(y),m+=g,m+=w,m+=y,g+=m,w+=m,y+=m,("00000000"+(m>>>0).toString(16)).slice(-8)+("00000000"+(g>>>0).toString(16)).slice(-8)+("00000000"+(w>>>0).toString(16)).slice(-8)+("00000000"+(y>>>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,v=a.length-p,m=[0,h],g=[0,h],w=[0,0],y=[0,0],E=[2277735313,289559509],A=[1291169091,658871167],b=0;b<v;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],y=[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,E),w=u(w,31),w=l(w,A),m=f(m,w),m=u(m,27),m=c(m,g),m=c(l(m,[0,5]),[0,1390208809]),y=l(y,A),y=u(y,33),y=l(y,E),g=f(g,y),g=u(g,31),g=c(g,m),g=c(l(g,[0,5]),[0,944331445]);switch(w=[0,0],y=[0,0],p){case 15:y=f(y,d([0,a[b+14]],48));case 14:y=f(y,d([0,a[b+13]],40));case 13:y=f(y,d([0,a[b+12]],32));case 12:y=f(y,d([0,a[b+11]],24));case 11:y=f(y,d([0,a[b+10]],16));case 10:y=f(y,d([0,a[b+9]],8));case 9:y=f(y,[0,a[b+8]]),y=l(y,A),y=u(y,33),y=l(y,E),g=f(g,y);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,E),w=u(w,31),w=l(w,A),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=x(m),g=x(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 le<"u"?(typeof He<"u"&&He.exports&&(le=He.exports=e),le.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)})(le)});var Us=ye((Oh,Cs)=>{Cs.exports=Rs()});var Fs=ye((Ef,Ms)=>{Ms.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 Ws=ye(he=>{(function(){var r,t,e,n,s,o,i,c;c=function(l){var u,d,f,x;return u=(l&255<<24)>>>24,d=(l&255<<16)>>>16,f=(l&65280)>>>8,x=l&255,[u,d,f,x].join(".")},i=function(l){var u,d,f,x,a,h;for(u=[],f=x=0;x<=3&&l.length!==0;f=++x){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,x,a;for(x=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)x=x*u+(e(l[f])-n)>>>0;else if(u===16)if("a"<=l[f]&&l[f]<="f")x=x*u+(10+e(l[f])-o)>>>0;else if("A"<=l[f]&&l[f]<="F")x=x*u+(10+e(l[f])-s)>>>0;else break;else break;if(x>4294967295)throw new Error("too large");f++}if(f===a)throw new Error("empty octet");return[x,f]},r=function(){function l(u,d){var f,x,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(x=a=32;a>=0;x=--a)if(this.maskLong===4294967295<<32-x>>>0){this.bitmask=x;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,x;for(x=i(this.first),f=i(this.last),d=0;x<=f;)u(c(x),x,d),d++,x++},l.prototype.toString=function(){return this.base+"/"+this.bitmask},l}(),he.ip2long=i,he.long2ip=c,he.Netmask=r}).call(he)});var fc={};q(fc,{bitswap:()=>Vs,trustlessGateway:()=>vo});var hr=Symbol.for("@libp2p/peer-id");var ft=class r extends Error{code;type;constructor(t="The operation was aborted"){super(t),this.name="AbortError",this.code=r.code,this.type=r.type}static code="ABORT_ERR";static type="aborted"},H=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var G=(r,...t)=>{try{[...t]}catch{}};var rt=class extends EventTarget{#t=new Map;constructor(){super(),G(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 _o(t,e))}},_o=globalThis.CustomEvent;function $n(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 Z(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var xe=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}},Dt=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new xe(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 xe(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 fr=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Pt(r={}){return Do(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 Do(r,t){t=t??{};let e=t.onEnd,n=new Dt,s,o,i,c=Z(),l=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((v,m)=>{o=g=>{o=null,n.push(g);try{v(r(n))}catch(w){m(w)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{c.resolve(),c=Z()})}},u=v=>o!=null?o(v):(n.push(v),s),d=v=>(n=new Dt,o!=null?o({error:v}):(n.push({error:v}),s)),f=v=>{if(i)return s;if(t?.objectMode!==!0&&v?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return u({done:!1,value:v})},x=v=>i?s:(i=!0,v!=null?d(v):u({done:!0})),a=()=>(n=new Dt,x(),{done:!0}),h=v=>(x(v),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:l,return:a,throw:h,push:f,end:x,get readableLength(){return n.size},onEmpty:async v=>{let m=v?.signal;if(m?.throwIfAborted(),n.isEmpty())return;let g,w;m!=null&&(g=new Promise((y,E)=>{w=()=>{E(new fr)},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(v){return p.throw(v),e!=null&&(e(v),e=void 0),{done:!0}},return(){return p.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(v){return p.end(v),e!=null&&(e(v),e=void 0),s},get readableLength(){return p.readableLength},onEmpty:v=>p.onEmpty(v)},s}var dr=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 Y(r,t,e,n){let s=new dr(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(x){c(),i(x);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 Ee=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 zn(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new Ee(e?.errorMessage,e?.errorCode,e?.errorName));let n,s=new Ee(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 ve=class{deferred;signal;constructor(t){this.signal=t,this.deferred=Z(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new ft)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function Po(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var Se=class{id;fn;options;recipients;status;timeline;controller;constructor(t,e){this.id=Po(),this.status="queued",this.fn=t,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,G(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 ft),this.cleanup())}async join(t={}){let e=new ve(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 zn(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 Rt=class extends rt{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 Se(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 ft)}),this.clear()}async onEmpty(t){this.size!==0&&await Y(this,"empty",t?.signal)}async onSizeLessThan(t,e){this.size<t||await Y(this,"next",e?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await Y(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=Pt({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 H("Queue aborted","ERR_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 Ae=class extends Rt{has(t){return this.find(t)!=null}find(t){return this.queue.find(e=>t.equals(e.options.peerId))}};function Ro(r){return r[Symbol.asyncIterator]!=null}function Co(r){if(Ro(r))return(async()=>{for await(let t of r);})();for(let t of r);}var pr=Co;function O(r=0){return new Uint8Array(r)}function $(r=0){return new Uint8Array(r)}var Uo=Math.pow(2,7),No=Math.pow(2,14),Mo=Math.pow(2,21),mr=Math.pow(2,28),gr=Math.pow(2,35),wr=Math.pow(2,42),br=Math.pow(2,49),I=128,z=127;function D(r){if(r<Uo)return 1;if(r<No)return 2;if(r<Mo)return 3;if(r<mr)return 4;if(r<gr)return 5;if(r<wr)return 6;if(r<br)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function yr(r,t,e=0){switch(D(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 Fo(r,t,e=0){switch(D(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 xr(r,t){let e=r[t],n=0;if(n+=e&z,e<I||(e=r[t+1],n+=(e&z)<<7,e<I)||(e=r[t+2],n+=(e&z)<<14,e<I)||(e=r[t+3],n+=(e&z)<<21,e<I)||(e=r[t+4],n+=(e&z)*mr,e<I)||(e=r[t+5],n+=(e&z)*gr,e<I)||(e=r[t+6],n+=(e&z)*wr,e<I)||(e=r[t+7],n+=(e&z)*br,e<I))return n;throw new RangeError("Could not decode varint")}function Bo(r,t){let e=r.get(t),n=0;if(n+=e&z,e<I||(e=r.get(t+1),n+=(e&z)<<7,e<I)||(e=r.get(t+2),n+=(e&z)<<14,e<I)||(e=r.get(t+3),n+=(e&z)<<21,e<I)||(e=r.get(t+4),n+=(e&z)*mr,e<I)||(e=r.get(t+5),n+=(e&z)*gr,e<I)||(e=r.get(t+6),n+=(e&z)*wr,e<I)||(e=r.get(t+7),n+=(e&z)*br,e<I))return n;throw new RangeError("Could not decode varint")}function nt(r,t,e=0){return t==null&&(t=$(D(r))),t instanceof Uint8Array?yr(r,t,e):Fo(r,t,e)}function tt(r,t=0){return r instanceof Uint8Array?xr(r,t):Bo(r,t)}function Q(r,t){t==null&&(t=r.reduce((s,o)=>s+o.length,0));let e=$(t),n=0;for(let s of r)e.set(s,n),n+=s.length;return e}function j(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 Hn=Symbol.for("@achingbrain/uint8arraylist");function Vn(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 Le(r){return!!r?.[Hn]}var dt=class r{bufs;length;[Hn]=!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(Le(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(Le(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=Vn(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Vn(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(Le(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(!Le(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 x=u;x>=0;x--){let a=this.get(f+x);if(n[x]!==a){d=Math.max(1,x-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=$(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=O(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=O(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=O(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=$(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=O(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=O(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=O(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=O(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=O(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(!j(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 Ie(r){return r[Symbol.asyncIterator]!=null}var Te=r=>{let t=D(r),e=$(t);return nt(r,e),Te.bytes=t,e};Te.bytes=0;function _e(r,t){t=t??{};let e=t.lengthEncoder??Te;function*n(s){let o=e(s.byteLength);o instanceof Uint8Array?yield o:yield*o,s instanceof Uint8Array?yield s:yield*s}return Ie(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}_e.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Te;return new dt(e(r.byteLength),r)};var De=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Pe=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Re=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},Xt=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Oo=8,$o=1024*1024*4,bt;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(bt||(bt={}));var Er=r=>{let t=tt(r);return Er.bytes=D(t),t};Er.bytes=0;function Qt(r,t){let e=new dt,n=bt.LENGTH,s=-1,o=t?.lengthDecoder??Er,i=t?.maxLengthLength??Oo,c=t?.maxDataLength??$o;function*l(){for(;e.byteLength>0;){if(n===bt.LENGTH)try{if(s=o(e),s<0)throw new De("Invalid message length");if(s>c)throw new Pe("Message length too long");let u=o.bytes;e.consume(u),t?.onLength!=null&&t.onLength(s),n=bt.DATA}catch(u){if(u instanceof RangeError){if(e.byteLength>i)throw new Re("Message length length too long");break}throw u}if(n===bt.DATA){if(e.byteLength<s)break;let u=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(u),yield u,n=bt.LENGTH}}}return Ie(r)?async function*(){for await(let u of r)e.append(u),yield*l();if(e.byteLength>0)throw new Xt("Unexpected end of input")}():function*(){for(let u of r)e.append(u),yield*l();if(e.byteLength>0)throw new Xt("Unexpected end of input")}()}Qt.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 Qt(n,{...t??{},onLength:o=>{e=o}})};function Vo(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 Wn=Vo;function Ho(r){return r[Symbol.asyncIterator]!=null}function Wo(r,t){let e=0;if(Ho(r))return async function*(){for await(let l of r)yield t(l,e++)}();let n=Wn(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=Wo;function qo(r){return r[Symbol.asyncIterator]!=null}function Go(...r){let t=[];for(let e of r)qo(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Pt({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 Gn=Go;function Sr(r,...t){if(r==null)throw new Error("Empty pipeline");if(vr(r)){let n=r;r=()=>n.source}else if(Qn(r)||Xn(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&vr(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++)vr(e[n])&&(e[n]=Qo(e[n]));return Xo(...e)}var Xo=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},Xn=r=>r?.[Symbol.asyncIterator]!=null,Qn=r=>r?.[Symbol.iterator]!=null,vr=r=>r==null?!1:r.sink!=null&&r.source!=null,Qo=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Pt({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(Xn(o))s=async function*(){yield*o,n.end()};else if(Qn(o))s=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Gn(n,s())}return r.source};function jo(r){return r[Symbol.asyncIterator]!=null}function Ko(r,t){return jo(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 jn=Ko;var st=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};var jt="/ipfs/bitswap/1.2.0";var Ar=new Float32Array([-0]),pt=new Uint8Array(Ar.buffer);function Kn(r,t,e){Ar[0]=r,t[e]=pt[0],t[e+1]=pt[1],t[e+2]=pt[2],t[e+3]=pt[3]}function Jn(r,t){return pt[0]=r[t],pt[1]=r[t+1],pt[2]=r[t+2],pt[3]=r[t+3],Ar[0]}var kr=new Float64Array([-0]),V=new Uint8Array(kr.buffer);function Zn(r,t,e){kr[0]=r,t[e]=V[0],t[e+1]=V[1],t[e+2]=V[2],t[e+3]=V[3],t[e+4]=V[4],t[e+5]=V[5],t[e+6]=V[6],t[e+7]=V[7]}function Yn(r,t){return V[0]=r[t],V[1]=r[t+1],V[2]=r[t+2],V[3]=r[t+3],V[4]=r[t+4],V[5]=r[t+5],V[6]=r[t+6],V[7]=r[t+7],kr[0]}var Jo=BigInt(Number.MAX_SAFE_INTEGER),Zo=BigInt(Number.MIN_SAFE_INTEGER),X=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 yt;if(t<Jo&&t>Zo)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>ts&&(s=0n,++n>ts&&(n=0n))),new r(Number(s),Number(n))}static fromNumber(t){if(t===0)return yt;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):yt}},yt=new X(0,0);yt.toBigInt=function(){return 0n};yt.zzEncode=yt.zzDecode=function(){return this};yt.length=function(){return 1};var ts=4294967296n;function es(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 rs(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 Lr(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 et(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function Ce(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Ir=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,et(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 et(this,4);return Ce(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw et(this,4);return Ce(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw et(this,4);let t=Jn(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw et(this,4);let t=Yn(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 et(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return rs(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw et(this,t);this.pos+=t}else do if(this.pos>=this.len)throw et(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 X(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 et(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 et(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 et(this,8);let t=Ce(this.buf,this.pos+=4),e=Ce(this.buf,this.pos+=4);return new X(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=xr(this.buf,this.pos);return this.pos+=D(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 Tr(r){return new Ir(r instanceof Uint8Array?r:r.subarray())}function xt(r,t,e){let n=Tr(r);return t.decode(n,void 0,e)}var Cr={};q(Cr,{base10:()=>si});var Pl=new Uint8Array(0);function ss(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 ct(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 os(r){return new TextEncoder().encode(r)}function is(r){return new TextDecoder().decode(r)}function Yo(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,v=0,m=0,g=h.length;m!==g&&h[m]===0;)m++,p++;for(var w=(g-m)*d+1>>>0,y=new Uint8Array(w);m!==g;){for(var E=h[m],A=0,b=w-1;(E!==0||A<v)&&b!==-1;b--,A++)E+=256*y[b]>>>0,y[b]=E%c>>>0,E=E/c>>>0;if(E!==0)throw new Error("Non-zero carry");v=A,m++}for(var T=w-v;T!==w&&y[T]===0;)T++;for(var at=l.repeat(p);T<w;++T)at+=r.charAt(y[T]);return at}function x(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 v=0,m=0;h[p]===l;)v++,p++;for(var g=(h.length-p)*u+1>>>0,w=new Uint8Array(g);h[p];){var y=e[h.charCodeAt(p)];if(y===255)return;for(var E=0,A=g-1;(y!==0||E<m)&&A!==-1;A--,E++)y+=c*w[A]>>>0,w[A]=y%256>>>0,y=y/256>>>0;if(y!==0)throw new Error("Non-zero carry");m=E,p++}if(h[p]!==" "){for(var b=g-m;b!==g&&w[b]===0;)b++;for(var T=new Uint8Array(v+(g-b)),at=v;b!==g;)T[at++]=w[b++];return T}}}function a(h){var p=x(h);if(p)return p;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:x,decode:a}}var ti=Yo,ei=ti,cs=ei;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")}},Dr=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),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 ls(this,t)}},Pr=class{decoders;constructor(t){this.decoders=t}or(t){return ls(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 ls(r,t){return new Pr({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Rr=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 Dr(t,e,s)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ct({name:r,prefix:t,encode:e,decode:n}){return new Rr(r,t,e,n)}function mt({name:r,prefix:t,alphabet:e}){let{encode:n,decode:s}=cs(e,r);return Ct({prefix:t,name:r,encode:n,decode:o=>ct(s(o))})}function ri(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 ni(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 R({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Ct({prefix:t,name:r,encode(s){return ni(s,n,e)},decode(s){return ri(s,n,e,r)}})}var si=mt({prefix:"9",name:"base10",alphabet:"0123456789"});var Ur={};q(Ur,{base16:()=>oi,base16upper:()=>ii});var oi=R({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),ii=R({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Nr={};q(Nr,{base2:()=>ai});var ai=R({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Mr={};q(Mr,{base256emoji:()=>fi});var us=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}"),ci=us.reduce((r,t,e)=>(r[e]=t,r),[]),li=us.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function ui(r){return r.reduce((t,e)=>(t+=ci[e],t),"")}function hi(r){let t=[];for(let e of r){let n=li[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var fi=Ct({prefix:"\u{1F680}",name:"base256emoji",encode:ui,decode:hi});var Fr={};q(Fr,{base32:()=>lt,base32hex:()=>gi,base32hexpad:()=>bi,base32hexpadupper:()=>yi,base32hexupper:()=>wi,base32pad:()=>pi,base32padupper:()=>mi,base32upper:()=>di,base32z:()=>xi});var lt=R({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),di=R({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),pi=R({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),mi=R({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),gi=R({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),wi=R({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),bi=R({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),yi=R({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),xi=R({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Br={};q(Br,{base36:()=>Kt,base36upper:()=>Ei});var Kt=mt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Ei=mt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Or={};q(Or,{base58btc:()=>N,base58flickr:()=>vi});var N=mt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),vi=mt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var zr={};q(zr,{base64:()=>ut,base64pad:()=>Si,base64url:()=>$r,base64urlpad:()=>Ai});var ut=R({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Si=R({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),$r=R({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Ai=R({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Vr={};q(Vr,{base8:()=>ki});var ki=R({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Hr={};q(Hr,{identity:()=>Li});var Li=Ct({prefix:"\0",name:"identity",encode:r=>is(r),decode:r=>os(r)});var Xl=new TextEncoder,Ql=new TextDecoder;var qr={};q(qr,{identity:()=>Yt});var _i=ds,hs=128,Di=127,Pi=~Di,Ri=Math.pow(2,31);function ds(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Ri;)t[e++]=r&255|hs,r/=128;for(;r&Pi;)t[e++]=r&255|hs,r>>>=7;return t[e]=r|0,ds.bytes=e-n+1,t}var Ci=Wr,Ui=128,fs=127;function Wr(r,n){var e=0,n=n||0,s=0,o=n,i,c=r.length;do{if(o>=c)throw Wr.bytes=0,new RangeError("Could not decode varint");i=r[o++],e+=s<28?(i&fs)<<s:(i&fs)*Math.pow(2,s),s+=7}while(i>=Ui);return Wr.bytes=o-n,e}var Ni=Math.pow(2,7),Mi=Math.pow(2,14),Fi=Math.pow(2,21),Bi=Math.pow(2,28),Oi=Math.pow(2,35),$i=Math.pow(2,42),zi=Math.pow(2,49),Vi=Math.pow(2,56),Hi=Math.pow(2,63),Wi=function(r){return r<Ni?1:r<Mi?2:r<Fi?3:r<Bi?4:r<Oi?5:r<$i?6:r<zi?7:r<Vi?8:r<Hi?9:10},qi={encode:_i,decode:Ci,encodingLength:Wi},Gi=qi,Jt=Gi;function Zt(r,t=0){return[Jt.decode(r,t),Jt.decode.bytes]}function Ut(r,t,e=0){return Jt.encode(r,t,e),t}function Nt(r){return Jt.encodingLength(r)}function gt(r,t){let e=t.byteLength,n=Nt(r),s=n+Nt(e),o=new Uint8Array(s+e);return Ut(r,o,0),Ut(e,o,n),o.set(t,s),new Mt(r,e,t,o)}function Et(r){let t=ct(r),[e,n]=Zt(t),[s,o]=Zt(t.subarray(n)),i=t.subarray(n+o);if(i.byteLength!==s)throw new Error("Incorrect length");return new Mt(e,s,i,t)}function ps(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&ss(r.bytes,e.bytes)}}var Mt=class{code;size;digest;bytes;constructor(t,e,n,s){this.code=t,this.size=e,this.digest=n,this.bytes=s}};var ms=0,Xi="identity",gs=ct;function Qi(r){return gt(ms,gs(r))}var Yt={code:ms,name:Xi,encode:gs,digest:Qi};var Qr={};q(Qr,{sha256:()=>St,sha512:()=>ji});function Xr({name:r,code:t,encode:e}){return new Gr(r,t,e)}var Gr=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?gt(this.code,e):e.then(n=>gt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function bs(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var St=Xr({name:"sha2-256",code:18,encode:bs("SHA-256")}),ji=Xr({name:"sha2-512",code:19,encode:bs("SHA-512")});function ys(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Ji(e,jr(r),t??N.encoder);default:return Zi(e,jr(r),t??lt.encoder)}}var xs=new WeakMap;function jr(r){let t=xs.get(r);if(t==null){let e=new Map;return xs.set(r,e),e}return t}var F=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!==te)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Yi)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=gt(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&&ps(t.multihash,n.multihash)}toString(t){return ys(this,t)}toJSON(){return{"/":ys(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??Es(n,s,o.bytes))}else if(e[ta]===!0){let{version:n,multihash:s,code:o}=e,i=Et(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!==te)throw new Error(`Version 0 CID must use dag-pb (code: ${te}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let s=Es(t,e,n.bytes);return new r(t,e,n,s)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,te,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=ct(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 Mt(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,x]=Zt(t.subarray(e));return e+=x,f},s=n(),o=te;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]=Ki(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 Ki(r,t){switch(r[0]){case"Q":{let e=t??N;return[N.prefix,e.decode(`${N.prefix}${r}`)]}case N.prefix:{let e=t??N;return[N.prefix,e.decode(r)]}case lt.prefix:{let e=t??lt;return[lt.prefix,e.decode(r)]}case Kt.prefix:{let e=t??Kt;return[Kt.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 Ji(r,t,e){let{prefix:n}=e;if(n!==N.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 Zi(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 te=112,Yi=18;function Es(r,t,e){let n=Nt(r),s=n+Nt(t),o=new Uint8Array(s+e.byteLength);return Ut(r,o,0),Ut(t,o,n),o.set(e,s),o}var ta=Symbol.for("@ipld/js-cid/CID");var wt={...Hr,...Nr,...Vr,...Cr,...Ur,...Fr,...Br,...Or,...zr,...Mr},gu={...Qr,...qr};function Ss(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var vs=Ss("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Kr=Ss("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=$(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),ea={utf8:vs,"utf-8":vs,hex:wt.base16,latin1:Kr,ascii:Kr,binary:Kr,...wt},Ne=ea;function ot(r,t="utf8"){let e=Ne[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Jr(r){let t=r??8192,e=t>>>1,n,s=t;return function(i){if(i<1||i>e)return $(i);s+i>t&&(n=$(t),s=0);let c=n.subarray(s,s+=i);return s&7&&(s=(s|7)+1),c}}var At=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Zr(){}var tn=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},ra=Jr();function na(r){return globalThis.Buffer!=null?$(r):ra(r)}var re=class{len;head;tail;states;constructor(){this.len=0,this.head=new At(Zr,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new At(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new en((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,X.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=X.fromBigInt(t);return this._push(Me,e.length(),e)}uint64Number(t){return this._push(yr,D(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=X.fromBigInt(t).zzEncode();return this._push(Me,e.length(),e)}sint64Number(t){let e=X.fromNumber(t).zzEncode();return this._push(Me,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Yr,1,t?1:0)}fixed32(t){return this._push(ee,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=X.fromBigInt(t);return this._push(ee,4,e.lo)._push(ee,4,e.hi)}fixed64Number(t){let e=X.fromNumber(t);return this._push(ee,4,e.lo)._push(ee,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(Kn,4,t)}double(t){return this._push(Zn,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Yr,1,0):this.uint32(e)._push(oa,e,t)}string(t){let e=es(t);return e!==0?this.uint32(e)._push(Lr,e,t):this._push(Yr,1,0)}fork(){return this.states=new tn(this),this.head=this.tail=new At(Zr,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 At(Zr,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=na(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Yr(r,t,e){t[e]=r&255}function sa(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var en=class extends At{next;constructor(t,e){super(sa,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 ee(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 oa(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(re.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(ia,t,r),this},re.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(aa,t,r),this});function ia(r,t,e){t.set(r,e)}function aa(r,t,e){r.length<40?Lr(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(ot(r),e)}function rn(){return new re}function kt(r,t){let e=rn();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Ft;(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"})(Ft||(Ft={}));function Fe(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Be(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",Ft.VARINT,e,n)}function Lt(r,t){return Fe("message",Ft.LENGTH_DELIMITED,r,t)}var Bt=class extends Error{code;constructor(t,e){super(t),this.code=e}};var C;(function(r){r.WantBlock="WantBlock",r.WantHave="WantHave"})(C||(C={}));var nn;(function(r){r[r.WantBlock=0]="WantBlock",r[r.WantHave=1]="WantHave"})(nn||(nn={}));(function(r){r.codec=()=>Be(nn)})(C||(C={}));var Ot;(function(r){let t;r.codec=()=>(t==null&&(t=Lt((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),C.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:O(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=C.codec().decode(e);break}case 5:{o.sendDontHave=e.bool();break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>kt(e,r.codec()),r.decode=(e,n)=>xt(e,r.codec(),n)})(Ot||(Ot={}));var Oe;(function(r){let t;r.codec=()=>(t==null&&(t=Lt((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.entries!=null)for(let o of e.entries)n.uint32(10),Ot.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 Bt('decode error - map field "entries" had too many elements',"ERR_MAX_LENGTH");o.entries.push(Ot.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=>kt(e,r.codec()),r.decode=(e,n)=>xt(e,r.codec(),n)})(Oe||(Oe={}));var $t;(function(r){let t;r.codec=()=>(t==null&&(t=Lt((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:O(0),data:O(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=>kt(e,r.codec()),r.decode=(e,n)=>xt(e,r.codec(),n)})($t||($t={}));var K;(function(r){r.HaveBlock="HaveBlock",r.DontHaveBlock="DontHaveBlock"})(K||(K={}));var $e;(function(r){r[r.HaveBlock=0]="HaveBlock",r[r.DontHaveBlock=1]="DontHaveBlock"})($e||($e={}));(function(r){r.codec=()=>Be($e)})(K||(K={}));var zt;(function(r){let t;r.codec=()=>(t==null&&(t=Lt((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&&$e[e.type]!==0&&(n.uint32(16),K.codec().encode(e.type,n)),s.lengthDelimited!==!1&&n.ldelim()},(e,n,s={})=>{let o={cid:O(0),type:K.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=K.codec().decode(e);break}default:{e.skipType(c&7);break}}}return o})),t),r.encode=e=>kt(e,r.codec()),r.decode=(e,n)=>xt(e,r.codec(),n)})(zt||(zt={}));var It;(function(r){let t;r.codec=()=>(t==null&&(t=Lt((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.wantlist!=null&&(n.uint32(10),Oe.codec().encode(e.wantlist,n)),e.blocks!=null)for(let o of e.blocks)n.uint32(26),$t.codec().encode(o,n);if(e.blockPresences!=null)for(let o of e.blockPresences)n.uint32(34),zt.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=Oe.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 Bt('decode error - map field "blocks" had too many elements',"ERR_MAX_LENGTH");o.blocks.push($t.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 Bt('decode error - map field "blockPresences" had too many elements',"ERR_MAX_LENGTH");o.blockPresences.push(zt.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=>kt(e,r.codec()),r.decode=(e,n)=>xt(e,r.codec(),n)})(It||(It={}));function As(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 ca=4193648,la=ca+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=It.encode(u).byteLength,{added:f,hasMore:x,newSize:a}=sn(s,u.blocks,c,t,d,ua);c+=f,d=a;let h=x;({added:f,hasMore:x,newSize:a}=sn(n,u.blockPresences,i,t,d,ha)),i+=f,d=a;let p=x;if({added:f,hasMore:x,newSize:a}=sn(e,u.wantlist.entries,o,t,d,fa),o+=f,d=a,l=!h&&!p&&!x,l||(u.wantlist.full=!1),yield It.encode(u),l)break}}function sn(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>la)throw new H("Cannot send block as after encoding it is over the max message size","ERR_BLOCK_TOO_LARGE");let f=s+d;if(f>n){c=!0;break}t.push(u),i++,s=f}return{hasMore:c,added:i,newSize:s}}function ua(r){return on(3,$t.encode(r))}function ha(r){return on(4,zt.encode(r))}function fa(r){return on(1,Ot.encode(r))}function on(r,t){let e=D(r),n=D(t.byteLength);return e+n+t.byteLength}var ze=class extends rt{log;libp2p;routing;protocols;running;maxInboundStreams;maxOutboundStreams;messageReceiveTimeout;registrarIds;metrics;sendQueue;runOnTransientConnections;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??[jt],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.runOnTransientConnections=e.runOnTransientConnections??!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 Ae({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,runOnTransientConnection:this.runOnTransientConnections});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 H(`Incoming Bitswap stream timed out after ${this.messageReceiveTimeout}ms`,"ERR_TIMEOUT")):this.log("stream aborted with status %s",e.status)},o=AbortSignal.timeout(this.messageReceiveTimeout);G(1/0,o),o.addEventListener("abort",s),await e.closeWrite(),await Sr(e,i=>Qt(i,{maxDataLength:this.maxIncomingMessageSize}),async i=>{for await(let c of i)try{let l=It.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),G(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 st("bitswap:network:find-providers",t));for await(let n of this.routing.findProviders(t,e))await this.libp2p.isDialable(n.multiaddrs,{runOnTransientConnection:this.runOnTransientConnections})&&(yield n)}async findAndConnect(t,e){await pr(qn(jn(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=As(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 H("No message to send","ERR_NO_MESSAGE");this.log("sendMessage to %p",t),o?.onProgress?.(new st("bitswap:network:send-wantlist",t));let c=await this.libp2p.dialProtocol(t,jt,o);await c.closeRead();try{await Sr(ks(i,this.maxOutgoingMessageSize),l=>_e(l),c),await c.close(o)}catch(l){o?.onProgress?.(new st("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 H("Network isn't running","ERR_NOT_STARTED");e?.onProgress?.(new st("bitswap:network:dial",t));let[n]=await Promise.all([this.libp2p.dial(t,e),Y(this.libp2p,"peer:identify",e?.signal,{filter:s=>{if(!s.detail.peerId.equals(t))return!1;if(s.detail.protocols.includes(jt))return!0;throw new H(`${t} did not support ${jt}`,"ERR_BITSWAP_UNSUPPORTED_BY_PEER")}})]);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)}};function P(r,t="utf8"){let e=Ne[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Is=Symbol.for("nodejs.util.inspect.custom"),Ls=Object.values(wt).map(r=>r.decoder).reduce((r,t)=>r.or(t),wt.identity.decoder),Ts=114,_s=36,Ds=37,ne=class{type;multihash;privateKey;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,this.privateKey=t.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[hr]=!0;toString(){return this.string==null&&(this.string=N.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return F.createV1(Ts,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return j(this.multihash.bytes,t);if(typeof t=="string")return ae(t).equals(this);if(t?.multihash?.bytes!=null)return j(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[Is](){return`PeerId(${this.toString()})`}},se=class extends ne{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},oe=class extends ne{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},ie=class extends ne{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}},an=2336,cn=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Yt.digest(ot(this.url))}[Is](){return`PeerId(${this.url})`}[hr]=!0;toString(){return this.toCID().toString()}toCID(){return F.createV1(an,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=P(t)),t.toString()===this.toString())}};function ae(r,t){if(t=t??Ls,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Et(N.decode(`z${r}`));return r.startsWith("12D")?new oe({multihash:e}):r.startsWith("16U")?new ie({multihash:e}):new se({multihash:e})}return Ea(Ls.decode(r))}function Ea(r){try{let t=Et(r);if(t.code===Yt.code){if(t.digest.length===_s)return new oe({multihash:t});if(t.digest.length===Ds)return new ie({multihash:t})}if(t.code===St.code)return new se({multihash:t})}catch{return va(F.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function va(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==Ts&&r.code!==an)throw new Error("Supplied PeerID CID is invalid");if(r.code===an){let e=P(r.multihash.digest);return new cn(new URL(e))}let t=r.multihash;if(t.code===St.code)return new se({multihash:r.multihash});if(t.code===Yt.code){if(t.digest.length===_s)return new oe({multihash:r.multihash});if(t.digest.length===Ds)return new ie({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}function ln(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 ce=class{map;constructor(t){if(this.map=new Map,t!=null)for(let[e,n]of t.entries())this.map.set(e.toString(),n)}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(t){return this.map.delete(t.toString())}entries(){return ln(this.map.entries(),t=>[ae(t[0]),t[1]])}forEach(t){this.map.forEach((e,n)=>{t(e,ae(n),this)})}get(t){return this.map.get(t.toString())}has(t){return this.map.has(t.toString())}set(t,e){this.map.set(t.toString(),e)}keys(){return ln(this.map.keys(),t=>ae(t))}values(){return this.map.values()}get size(){return this.map.size}};var Tt=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Ph=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Rh={}.toString;function Ps(r=32){if(Tt&&typeof Tt.getRandomValues=="function")return Tt.getRandomValues(new Uint8Array(r));if(Tt&&typeof Tt.randomBytes=="function")return Tt.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function Ve(r){if(isNaN(r)||r<=0)throw new H("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return Ps(r)}var un=class extends ce{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 ue(r){let{name:t,metrics:e}=r,n;return e!=null?n=new un({name:t,metrics:e}):n=new ce,n}var ht=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=ut.encode(t.multihash.bytes);this.wantlist.set(n,e)}addBlockPresence(t,e){let n=ut.encode(t.multihash.bytes);this.blockPresences.set(n,e)}addBlock(t,e){let n=ut.encode(t.multihash.bytes);this.blocks.set(n,e)}};function Sa(r){let t=new Uint8Array(r.reduce((n,s)=>n+D(s),0)),e=0;for(let n of r)t=nt(n,t,e),e+=D(n);return t}var Ns=Sa;function hn(r){return Ns([r.version,r.code,r.multihash.code,r.multihash.digest.byteLength])}var We=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 ht,n=new Set;for(let[s,o]of this.wants.entries())try{let i=await this.blockstore.get(o.cid,t);o.wantType===C.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:K.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.code!=="ERR_NOT_FOUND")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:K.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=ue({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 We({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=F.decode(s.cid),i=P(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===C.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??C.WantBlock,sendDontHave:s.sendDontHave??!1}))}}this.log("send blocks to peer"),await n.sendBlocksToPeer()}async receivedBlock(t,e){let n=P(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 La=ur(Fs(),1);var Vt;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(Vt||(Vt={}));var fn=ur(Us(),1);var Ia=Math.LN2*Math.LN2,Ge=class r{static create(t,e=.005){let n=Ta(t,e);return new r(n)}seeds;bits;buffer;constructor(t={}){t.seeds!=null?this.seeds=t.seeds:this.seeds=_a(t.hashes??8),this.bits=t.bits??1024,this.buffer=O(Math.ceil(this.bits/8))}add(t){typeof t=="string"&&(t=ot(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=ot(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 Ta(r,t=.005){let e=Math.round(-1*r*Math.log(t)/Ia),n=Math.round(e/r*Math.LN2);return{bits:e,hashes:n}}function _a(r){let t,e,n=[];for(let s=0;s<r;s++)for(t=new dt(Ve(4)),n[s]=t.getUint32(0,!0),e=0;e<s;e++)if(n[s]===n[e]){s--;break}return n}var _t=class extends rt{intialPeerSearchComplete;requests;name;log;logger;minProviders;maxProviders;providers;evictionFilter;constructor(t,e){super(),G(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=ut.encode(t.multihash.bytes),s=this.requests.get(n);if(s!=null)return this.log("join existing request for %c",t),s;let o=Z();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 Rt({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=Z(),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 H(`Found ${o} of ${e} ${this.name} providers for ${t}`,"ERR_INSUFFICIENT_PROVIDERS_FOUND")}).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 _t{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.toBytes()}equals(t,e){return t.equals(e)}};function Bs(r,t){return new dn(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 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 Os(r){let{name:t,metrics:e}=r,n;return e!=null?n=new pn({name:t,metrics:e}):n=new Map,n}function Da(r){if(!(r instanceof Uint8Array))throw new Error("arg needs to be a Uint8Array");let t=[];for(;r.length>0;){let e=tt(r);t.push(e),r=r.slice(D(e))}return t}var $s=Da;var Qe=class extends rt{peers;wants;network;log;sendMessagesDelay;sendMessagesTimeout;hashLoader;sendingMessages;constructor(t,e={}){super(),G(1/0,this),this.peers=ue({name:"helia_bitswap_peers",metrics:t.metrics}),this.wants=Os({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=P(t.multihash.bytes,"base64"),s=this.wants.get(n);s==null&&(s={cid:t,priority:e.priority??1,wantType:e.wantType??C.WantBlock,cancel:!1,sendDontHave:!0},this.wants.set(n,s)),s.wantType===C.WantHave&&e.wantType===C.WantBlock&&(s.wantType=C.WantBlock),await this.sendMessagesDebounced();try{return e.wantType===C.WantBlock?(await Y(this,"block",e?.signal,{filter:c=>j(t.multihash.digest,c.detail.cid.multihash.digest),errorMessage:"Want was aborted"})).detail:(await Y(this,"presence",e?.signal,{filter:i=>j(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=Z(),await Promise.all([...this.peers.entries()].map(async([t,e])=>{let n=new Set,s=new ht;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=P(t.multihash.bytes,"base64");return this.wants.has(e)}async wantSessionPresence(t,e,n={}){let s=new ht;return s.addWantlistEntry(t,{cid:t.bytes,sendDontHave:!0,wantType:C.WantHave,priority:1}),await this.network.sendMessage(e,s),(await Y(this,"presence",n.signal,{filter:i=>e.equals(i.detail.sender)&&j(t.multihash.digest,i.detail.cid.multihash.digest)})).detail}async wantBlock(t,e={}){return this.addEntry(t,{...e,wantType:C.WantBlock})}async wantSessionBlock(t,e,n={}){let s=new ht;return s.addWantlistEntry(t,{cid:t.bytes,sendDontHave:!0,wantType:C.WantBlock,priority:1}),await this.network.sendMessage(e,s),(await Y(this,"presence",n.signal,{filter:i=>e.equals(i.detail.sender)&&j(t.multihash.digest,i.detail.cid.multihash.digest)})).detail}async receivedBlock(t,e){let n=P(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=$s(s.prefix),i=o[0],c=o[1],l=o[2],u=l===St.code?St: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=F.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 x=P(f.multihash.bytes,"base64"),a=this.wants.get(x);a!=null&&(a.cancel=!0,n=!0)}for(let{cid:s,type:o}of e.blockPresences){let i=F.decode(s);this.log("received %s from %p for %c",o,t,i),this.safeDispatchEvent("presence",{detail:{sender:t,cid:i,has:o===K.HaveBlock}})}n&&await this.sendMessagesDebounced()}async peerConnected(t){let e=new Set,n=new ht(!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:C.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 ze(t,e),this.peerWantLists=new qe({...t,network:this.network},e),this.wantList=new Qe({...t,network:this.network},e)}createSession(t={}){return Bs({wantList:this.wantList,network:this.network,logger:this.logger},t)}async want(t,e={}){let n=new AbortController,s=$n([n.signal,e.signal]);G(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 zs=(r,t={})=>new je(r,t);var mn=class{bitswap;started;constructor(t,e={}){let{hashers:n}=t;this.bitswap=zs(t,{hashLoader:{getHasher:async s=>{let o;if(typeof s=="string"?o=Object.values(n).find(i=>i.name===s):o=n[s],o!=null)return o;throw new Error(`Could not load hasher for code/name "${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 Vs(r={}){return t=>new mn(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 x=Number.parseInt(f,t);if(!Number.isNaN(x))return x});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 Hs=45,Pa=15,Ht=new Ke;function gn(r){if(!(r.length>Pa))return Ht.new(r).parseWith(()=>Ht.readIPv4Addr())}function wn(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Hs))return Ht.new(r).parseWith(()=>Ht.readIPv6Addr())}function Je(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Hs))return Ht.new(r).parseWith(()=>Ht.readIPAddr())}function Wt(r){return!!gn(r)}function qt(r){return!!wn(r)}function Ze(r){return!!Je(r)}var qs=ur(Ws(),1),Ra=["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"],Ca=Ra.map(r=>new qs.Netmask(r));function bn(r){for(let t of Ca)if(t.contains(r))return!0;return!1}function Ua(r){return/^::ffff:([0-9a-fA-F]{1,4}):([0-9a-fA-F]{1,4})$/.test(r)}function Na(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 Ma(r){return/^::ffff:([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)}function Fa(r){let t=r.split(":"),e=t[t.length-1];return bn(e)}function Ba(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 Gs(r){return Wt(r)?bn(r):Ua(r)?Na(r):Ma(r)?Fa(r):qt(r)?Ba(r):void 0}var Xd=parseInt("0xFFFF",16),Qd=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var js=Wt,Ha=qt,yn=function(r){let t=0;if(r=r.toString().trim(),js(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(Ha(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let o=js(e[n]),i;o&&(i=yn(e[n]),e[n]=P(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,P(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")},Ks=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 Gt={},xn={},qa=[[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"]];qa.forEach(r=>{let t=Ga(...r);xn[t.code]=t,Gt[t.name]=t});function Ga(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function S(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(Gt[r]!=null)return Gt[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var _p=S("ip4"),Dp=S("ip6"),Pp=S("ipcidr");function An(r,t){switch(S(r).code){case 4:case 41:return Qa(t);case 42:return Sn(t);case 6:case 273:case 33:case 132:return Ys(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Sn(t);case 421:return Za(t);case 444:return Zs(t);case 445:return Zs(t);case 466:return Ja(t);case 481:return globalThis.encodeURIComponent(Sn(t));default:return P(t,"base16")}}function kn(r,t){switch(S(r).code){case 4:return Js(t);case 41:return Js(t);case 42:return vn(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 vn(t);case 421:return ja(t);case 444:return Ya(t);case 445:return tc(t);case 466:return Ka(t);case 481:return vn(globalThis.decodeURIComponent(t));default:return ot(t,"base16")}}var En=Object.values(wt).map(r=>r.decoder),Xa=function(){let r=En[0].or(En[1]);return En.slice(2).forEach(t=>r=r.or(t)),r}();function Js(r){if(!Ze(r))throw new Error("invalid ip address");return yn(r)}function Qa(r){let t=Ks(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 Ln(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Ys(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function vn(r){let t=ot(r),e=Uint8Array.from(nt(t.length));return Q([e,t],e.length+t.length)}function Sn(r){let t=tt(r);if(r=r.slice(D(t)),r.length!==t)throw new Error("inconsistent lengths");return P(r)}function ja(r){let t;r[0]==="Q"||r[0]==="1"?t=Et(N.decode(`z${r}`)).bytes:t=F.parse(r).multihash.bytes;let e=Uint8Array.from(nt(t.length));return Q([e,t],e.length+t.length)}function Ka(r){let t=Xa.decode(r),e=Uint8Array.from(nt(t.length));return Q([e,t],e.length+t.length)}function Ja(r){let t=tt(r),e=r.slice(D(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+P(e,"base64url")}function Za(r){let t=tt(r),e=r.slice(D(t));if(e.length!==t)throw new Error("inconsistent lengths");return P(e,"base58btc")}function Ya(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=lt.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 tc(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=lt.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 Zs(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=P(t,"base32"),s=Ys(e);return`${n}:${s}`}function to(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=S(i);if(c.size===0){t.push([c.code]),e.push([c.code]);continue}if(o++,o>=s.length)throw ro("invalid address: "+r);if(c.path===!0){n=In(s.slice(o).join("/")),t.push([c.code,kn(c.code,n)]),e.push([c.code,n]);break}let l=kn(c.code,s[o]);t.push([c.code,l]),e.push([c.code,An(c.code,l)])}return{string:eo(e),bytes:_n(t),tuples:t,stringTuples:e,path:n}}function Tn(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let o=tt(r,s),i=D(o),c=S(o),l=ec(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 ro("Invalid address Uint8Array: "+P(r,"base16"));t.push([o,u]);let d=An(o,u);if(e.push([o,d]),c.path===!0){n=d;break}}return{bytes:Uint8Array.from(r),string:eo(e),tuples:t,stringTuples:e,path:n}}function eo(r){let t=[];return r.map(e=>{let n=S(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),In(t.join("/"))}function _n(r){return Q(r.map(t=>{let e=S(t[0]),n=Uint8Array.from(nt(e.code));return t.length>1&&t[1]!=null&&(n=Q([n,t[1]])),n}))}function ec(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=tt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+D(e)}}function In(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function ro(r){return new Error("Error parsing address: "+r)}var rc=Symbol.for("nodejs.util.inspect.custom"),Pn=Symbol.for("@multiformats/js-multiaddr/multiaddr"),nc=[S("dns").code,S("dns4").code,S("dns6").code,S("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=Tn(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=to(t)}else if(so(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=S("tcp"),c=S("udp"),l=S("ip4"),u=S("ip6"),d=S("dns6"),f=S("ip6zone");for(let[a,h]of this.stringTuples())a===f.code&&(o=`%${h??""}`),nc.includes(a)&&(e=i.name,s=443,n=`${h??""}${o}`,t=a===d.code?6:4),(a===i.code||a===c.code)&&(e=S(a).name,s=parseInt(h??"")),(a===l.code||a===u.code)&&(e=S(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({},S(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>S(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(_n(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,s])=>{n===Gt.p2p.code&&t.push([n,s]),n===Gt["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?P(N.decode(`z${n}`),"base58btc"):P(F.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return j(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(o=>o.resolvable);if(e==null)return[this];let n=no.get(e.name);if(n==null)throw new Dn(`no available resolver for ${e.name}`);return(await n(this,t)).map(o=>fe(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)}[rc](){return`Multiaddr(${this.#t})`}};var no=new Map;function so(r){return!!r?.[Pn]}function fe(r){return new Ye(r)}var sc=r=>r.toString().split("/").slice(1),de=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),L=r=>({match:t=>de(e=>e===r).match(t),pattern:r}),rr=()=>({match:r=>de(t=>typeof t=="string").match(r),pattern:"{string}"}),nr=()=>({match:r=>de(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),B=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{N.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{$r.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),M=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),J=(...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(", ")})`}),_=(...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 U(...r){function t(s){let o=sc(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 Cn=_(L("dns4"),rr()),Un=_(L("dns6"),rr()),Nn=_(L("dnsaddr"),rr()),oo=_(L("dns"),rr()),om=U(Cn),im=U(Un),am=U(Nn),io=U(J(oo,Nn,Cn,Un)),ao=_(L("ip4"),de(Wt)),co=_(L("ip6"),de(qt)),lo=J(ao,co),it=J(lo,oo,Cn,Un,Nn),cm=U(it),lm=U(ao),um=U(co),hm=U(lo),Mn=_(it,L("tcp"),nr()),pe=_(it,L("udp"),nr()),fm=U(Mn),dm=U(pe),Fn=_(pe,L("quic")),sr=_(pe,L("quic-v1")),oc=J(Fn,sr),pm=U(Fn),mm=U(sr),Rn=J(it,Mn,pe,Fn,sr),uo=J(_(Rn,L("ws"),M(B()))),gm=U(uo),ho=J(_(Rn,L("wss"),M(B())),_(Rn,L("tls"),L("ws"),M(B()))),wm=U(ho),fo=_(pe,L("webrtc-direct"),M(tr()),M(tr()),M(B())),bm=U(fo),po=_(sr,L("webtransport"),M(tr()),M(tr()),M(B())),ym=U(po),er=J(uo,ho,_(Mn,M(B())),_(oc,M(B())),_(it,M(B())),fo,po,B()),xm=U(er),ic=_(er,L("p2p-circuit"),B()),Em=U(ic),ac=J(_(er,L("p2p-circuit"),L("webrtc"),M(B())),_(er,L("webrtc"),M(B())),L("webrtc")),vm=U(ac),cc=J(_(it,L("tcp"),nr(),L("http"),M(B())),_(it,L("http"),M(B()))),mo=U(cc),lc=J(_(it,L("tcp"),J(_(L("443"),L("http")),_(nr(),L("https"))),M(B())),_(it,L("tls"),L("http"),M(B())),_(it,L("https"),M(B()))),go=U(lc);var uc=[S("tcp").code,S("dns").code,S("dnsaddr").code,S("dns4").code,S("dns6").code];function wo(r){let t;try{t=S("sni").code}catch{return null}for(let[e,n]of r)if(e===t&&n!==void 0)return n;return null}function bo(r){return r.some(([t,e])=>t===S("tls").code)}function W(r,t,e){let n=yo[S(r).name];if(n===void 0)throw new Error(`Can't interpret protocol ${S(r).name}`);let s=n(t,e);return r===S("ip6").code?`[${s}]`:s}var yo={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://${W(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://${W(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`${W(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`${W(e[0],e[1]??"",t)}/p2p/${r}`},http:(r,t)=>{let e=bo(t),n=wo(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=W(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=W(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 W(e[0],e[1]??"",t)},sni:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return W(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=W(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`https://${n}`},ws:(r,t)=>{let e=bo(t),n=wo(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=W(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=W(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`${W(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`${W(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`${W(e[0],e[1]??"",t)}/p2p-webrtc-direct`}};function xo(r,t){let n=fe(r).stringTuples(),s=n.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let o=S(s[0]),i=yo[o.name];if(i==null)throw new Error(`No interpreter found for ${o.name}`);let c=i(s[1]??"",n);return t?.assumeHttp!==!1&&uc.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 or=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 ut.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 hc(r,t,e){return r.filter(n=>{if(go.matches(n)||t&&mo.matches(n))return e||io.matches(n)?!0:Gs(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*ir(r,t,e,n,s,o){for await(let i of t.findProviders(r,o)){let c=hc(i.multiaddrs,n,s);if(c.length===0)continue;let l=xo(c[0]);yield new or(l,e)}}var Bn=class extends _t{routing;allowInsecure;allowLocal;constructor(t,e){super(t,{...e,name:"helia:trustless-gateway:session"}),this.routing=t.routing,this.allowInsecure=e.allowInsecure??ar,this.allowLocal=e.allowLocal??cr}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*ir(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 Eo(r,t){return new Bn(r,t)}var lr=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??ar,this.allowLocal=e.allowLocal??cr}async retrieve(t,e={}){let n=[];for await(let s of ir(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 Eo({logger:this.logger,routing:this.routing},{...t,allowLocal:this.allowLocal,allowInsecure:this.allowInsecure})}};var ar=!1,cr=!1;function vo(r={}){return t=>new lr(t,r)}return To(fc);})();
2
+ "use strict";var HeliaBlockBrokers=(()=>{var mo=Object.create;var pe=Object.defineProperty;var go=Object.getOwnPropertyDescriptor;var wo=Object.getOwnPropertyNames;var bo=Object.getPrototypeOf,xo=Object.prototype.hasOwnProperty;var me=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),q=(r,t)=>{for(var e in t)pe(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&&pe(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?pe(e,"default",{value:r,enumerable:!0}):e,r)),yo=r=>Rn(pe({},"__esModule",{value:!0}),r);var Ls=me((ne,Ge)=>{(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,he=2869860233,fe=951274213,de=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,he),m^=v,m=o(m,19),m+=g,m=s(m,5)+1444728091,S=s(S,he),S=o(S,16),S=s(S,fe),g^=S,g=o(g,17),g+=w,g=s(g,5)+197830471,b=s(b,fe),b=o(b,17),b=s(b,de),w^=b,w=o(w,15),w+=x,w=s(w,5)+2530024501,D=s(D,de),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,de),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,fe),b=o(b,17),b=s(b,de),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,he),S=o(S,16),S=s(S,fe),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,he),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 ne<"u"?(typeof Ge<"u"&&Ge.exports&&(ne=Ge.exports=e),ne.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)})(ne)});var Ts=me((kh,Is)=>{Is.exports=Ls()});var _s=me((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=me(oe=>{(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}(),oe.ip2long=i,oe.long2ip=c,oe.Netmask=r}).call(oe)});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 ge=class extends Error{static name="UnsupportedProtocolError";constructor(t="Unsupported protocol error"){super(t),this.name="UnsupportedProtocolError"}};var we=class extends Error{static name="TimeoutError";constructor(t="Timed out"){super(t),this.name="TimeoutError"}},be=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 xe=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 xe(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 xe(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 ye=class extends Error{static name="QueueFullError";constructor(t="The queue was full"){super(t),this.name="QueueFullError"}};var ve=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 ve(e?.errorMessage,e?.errorCode,e?.errorName));let n,s=new ve(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 Ee=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 ke=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 Ee(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 ye;let n=new ke(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 Se=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),T=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|T,r/=128;case 7:t[e++]=r&255|T,r/=128;case 6:t[e++]=r&255|T,r/=128;case 5:t[e++]=r&255|T,r/=128;case 4:t[e++]=r&255|T,r>>>=7;case 3:t[e++]=r&255|T,r>>>=7;case 2:t[e++]=r&255|T,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|T),r/=128;case 7:t.set(e++,r&255|T),r/=128;case 6:t.set(e++,r&255|T),r/=128;case 5:t.set(e++,r&255|T),r/=128;case 4:t.set(e++,r&255|T),r>>>=7;case 3:t.set(e++,r&255|T),r>>>=7;case 2:t.set(e++,r&255|T),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<T||(e=r[t+1],n+=(e&$)<<7,e<T)||(e=r[t+2],n+=(e&$)<<14,e<T)||(e=r[t+3],n+=(e&$)<<21,e<T)||(e=r[t+4],n+=(e&$)*br,e<T)||(e=r[t+5],n+=(e&$)*xr,e<T)||(e=r[t+6],n+=(e&$)*yr,e<T)||(e=r[t+7],n+=(e&$)*vr,e<T))return n;throw new RangeError("Could not decode varint")}function Do(r,t){let e=r.get(t),n=0;if(n+=e&$,e<T||(e=r.get(t+1),n+=(e&$)<<7,e<T)||(e=r.get(t+2),n+=(e&$)<<14,e<T)||(e=r.get(t+3),n+=(e&$)<<21,e<T)||(e=r.get(t+4),n+=(e&$)*br,e<T)||(e=r.get(t+5),n+=(e&$)*xr,e<T)||(e=r.get(t+6),n+=(e&$)*yr,e<T)||(e=r.get(t+7),n+=(e&$)*vr,e<T))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 Le(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(Le(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(Le(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(Le(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(!Le(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 Ie(r){return r[Symbol.asyncIterator]!=null}var Te=r=>{let t=P(r),e=O(t);return et(r,e),Te.bytes=t,e};Te.bytes=0;function De(r,t){t=t??{};let e=t.lengthEncoder??Te;function*n(s){let o=e(s.byteLength);o instanceof Uint8Array?yield o:yield*o,s instanceof Uint8Array?yield s:yield*s}return Ie(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}De.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Te;return new ht(e(r.byteLength),r)};var Pe=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},_e=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Ue=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},Wt=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 Gt(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 Pe("Invalid message length");if(s>c)throw new _e("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 Ue("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 Ie(r)?async function*(){for await(let u of r)e.append(u),yield*l();if(e.byteLength>0)throw new Wt("Unexpected end of input")}():function*(){for(let u of r)e.append(u),yield*l();if(e.byteLength>0)throw new Wt("Unexpected end of input")}()}Gt.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 Gt(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 Xt="/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 Ce(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 Ce(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Y(this,4);return Ce(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=Ce(this.buf,this.pos+=4),e=Ce(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:()=>Qt,base36upper:()=>fi});var Qt=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,jt=Bi;function Kt(r,t=0){return[jt.decode(r,t),jt.decode.bytes]}function _t(r,t,e=0){return jt.encode(r,t,e),t}function Ut(r){return jt.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 Jt(r){let t=it(r),[e,n]=Kt(t),[s,o]=Kt(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:()=>Fe,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 Fe=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!==Zt)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=Jt(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!==Zt)throw new Error(`Version 0 CID must use dag-pb (code: ${Zt}) 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,Zt,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]=Kt(t.subarray(e));return e+=y,f},s=n(),o=Zt;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 Qt.prefix:{let e=t??Qt;return[Qt.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 Zt=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 Yt={...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:Yt.base16,latin1:Yr,ascii:Yr,binary:Yr,...Yt},Ne=Xi;function pt(r,t="utf8"){let e=Ne[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 ee=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(Be,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(Be,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(Be,e.length(),e)}sint64Number(t){let e=G.fromNumber(t).zzEncode();return this._push(Be,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(te,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=G.fromBigInt(t);return this._push(te,4,e.lo)._push(te,4,e.hi)}fixed64Number(t){let e=G.fromNumber(t);return this._push(te,4,e.lo)._push(te,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 Be(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 te(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&&(ee.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Zi,t,r),this},ee.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 ee}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 Re(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Oe(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 Re("enum",Mt.VARINT,e,n)}function Et(r,t){return Re("message",Mt.LENGTH_DELIMITED,r,t)}var Ft=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var N;(function(r){r.WantBlock="WantBlock",r.WantHave="WantHave"})(N||(N={}));var an;(function(r){r[r.WantBlock=0]="WantBlock",r[r.WantHave=1]="WantHave"})(an||(an={}));(function(r){r.codec=()=>Oe(an)})(N||(N={}));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),N.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=N.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 $e;(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)})($e||($e={}));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 ze;(function(r){r[r.HaveBlock=0]="HaveBlock",r[r.DontHaveBlock=1]="DontHaveBlock"})(ze||(ze={}));(function(r){r.codec=()=>Oe(ze)})(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&&ze[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),$e.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=$e.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 Ve=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 Ve("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 He=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??[Xt],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 Se({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 we(`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=>Gt(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,Xt,o);await c.closeRead();try{await Lr(Ss(i,this.maxOutgoingMessageSize),l=>De(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 be("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(Xt))return!0;throw new ge(`${t} did not support ${Xt}`)}})]);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 C(r,t="utf8"){let e=Ne[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function qe(r){if(isNaN(r)||r<=0)throw new Lt("random bytes length must be a Number bigger than 0");return As(r)}function We(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 re=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 We(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 We(this.map.values(),t=>t.key)}values(){return We(this.map.values(),t=>t.value)}get size(){return this.map.size}};var un=class extends re{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 se(r){let{name:t,metrics:e}=r,n;return e!=null?n=new un({name:t,metrics:e}):n=new re,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 Xe=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===N.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 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=se({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 Xe({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=C(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===N.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??N.WantBlock,sendDontHave:s.sendDontHave??!1}))}}this.log("send blocks to peer"),await n.sendBlocksToPeer()}async receivedBlock(t,e){let n=C(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 je=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,Ke=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(qe(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=Ke.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 je(`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 Je=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 Ze=class extends tt{peers;wants;network;log;sendMessagesDelay;sendMessagesTimeout;hashLoader;sendingMessages;constructor(t,e={}){super(),W(1/0,this),this.peers=se({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=C(t.multihash.bytes,"base64"),s=this.wants.get(n);s==null&&(s={cid:t,priority:e.priority??1,wantType:e.wantType??N.WantBlock,cancel:!1,sendDontHave:!0},this.wants.set(n,s)),s.wantType===N.WantHave&&e.wantType===N.WantBlock&&(s.wantType=N.WantBlock),await this.sendMessagesDebounced();try{return e.wantType===N.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=C(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:N.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:N.WantBlock})}async wantSessionBlock(t,e,n={}){let s=new lt;return s.addWantlistEntry(t,{cid:t.bytes,sendDontHave:!0,wantType:N.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=C(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===Fe.code?Fe: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=C(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:N.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 Ye=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 Je(t),this.network=new He(t,e),this.peerWantLists=new Qe({...t,network:this.network},e),this.wantList=new Ze({...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 Ye(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 tr=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 tr;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 er(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 rr(r){return!!er(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 _a=r=>r.toString().split("/").slice(1),Ht=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),L=r=>({match:t=>Ht(e=>e===r).match(t),pattern:r}),ie=()=>({match:r=>Ht(t=>typeof t=="string").match(r),pattern:"{string}"}),ae=()=>({match:r=>Ht(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),U=()=>({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}"}),ce=()=>({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(", ")})`}),I=(...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 F(...r){function t(s){let o=_a(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{matchers:r,matches:e,exactMatch:n}}var sr=I(L("dns4"),ie()),or=I(L("dns6"),ie()),ir=I(L("dnsaddr"),ie()),yn=I(L("dns"),ie()),Pd=F(sr,_(U())),_d=F(or,_(U())),Ud=F(ir,_(U())),zs=F(V(yn,ir,sr,or),_(U())),Vs=I(L("ip4"),Ht(zt)),Hs=I(L("ip6"),Ht(Vt)),vn=V(Vs,Hs),ut=V(vn,yn,sr,or,ir),Cd=F(V(vn,I(V(yn,ir,sr,or),_(U())))),Md=F(Vs),Fd=F(Hs),Nd=F(vn),En=I(ut,L("tcp"),ae()),le=I(ut,L("udp"),ae()),Bd=F(I(En,_(U()))),Rd=F(le),kn=I(le,L("quic")),ar=I(le,L("quic-v1")),Ua=V(kn,ar),Od=F(kn),$d=F(ar),xn=V(ut,En,le,kn,ar),qs=V(I(xn,L("ws"),_(U()))),zd=F(qs),Ws=V(I(xn,L("wss"),_(U())),I(xn,L("tls"),L("ws"),_(U()))),Vd=F(Ws),Gs=I(le,L("webrtc-direct"),_(ce()),_(ce()),_(U())),Hd=F(Gs),Xs=I(ar,L("webtransport"),_(ce()),_(ce()),_(U())),qd=F(Xs),nr=V(qs,Ws,I(En,_(U())),I(Ua,_(U())),I(ut,_(U())),Gs,Xs,U()),Wd=F(nr),Ca=I(nr,L("p2p-circuit"),U()),Gd=F(Ca),Ma=V(I(nr,L("p2p-circuit"),L("webrtc"),_(U())),I(nr,L("webrtc"),_(U())),L("webrtc")),Xd=F(Ma),Fa=V(I(ut,L("tcp"),ae(),L("http"),_(U())),I(ut,L("http"),_(U()))),Qs=F(Fa),Na=V(I(ut,L("tcp"),V(I(L("443"),L("http")),I(ae(),L("https"))),_(U())),I(ut,L("tls"),L("http"),_(U())),I(ut,L("https"),_(U()))),js=F(Na);var ep=parseInt("0xFFFF",16),rp=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Zs=zt,za=Vt,Sn=function(r){let t=0;if(r=r.toString().trim(),Zs(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(za(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let o=Zs(e[n]),i;o&&(i=Sn(e[n]),e[n]=C(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,C(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")},Ys=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 qt={},An={},Ha=[[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"]];Ha.forEach(r=>{let t=qa(...r);An[t.code]=t,qt[t.name]=t});function qa(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function k(r){if(typeof r=="number"){if(An[r]!=null)return An[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(qt[r]!=null)return qt[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var Bp=k("ip4"),Rp=k("ip6"),Op=k("ipcidr");function Dn(r,t){switch(k(r).code){case 4:case 41:return Ga(t);case 42:return Tn(t);case 6:case 273:case 33:case 132:return ro(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Tn(t);case 421:return Ka(t);case 444:return eo(t);case 445:return eo(t);case 466:return ja(t);case 481:return globalThis.encodeURIComponent(Tn(t));default:return C(t,"base16")}}function Pn(r,t){switch(k(r).code){case 4:return to(t);case 41:return to(t);case 42:return In(t);case 6:case 273:case 33:case 132:return _n(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return In(t);case 421:return Xa(t);case 444:return Ja(t);case 445:return Za(t);case 466:return Qa(t);case 481:return In(globalThis.decodeURIComponent(t));default:return pt(t,"base16")}}var Ln=Object.values(Yt).map(r=>r.decoder),Wa=function(){let r=Ln[0].or(Ln[1]);return Ln.slice(2).forEach(t=>r=r.or(t)),r}();function to(r){if(!rr(r))throw new Error("invalid ip address");return Sn(r)}function Ga(r){let t=Ys(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!rr(t))throw new Error("invalid ip address");return t}function _n(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function ro(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function In(r){let t=pt(r),e=Uint8Array.from(et(t.length));return Q([e,t],e.length+t.length)}function Tn(r){let t=Z(r);if(r=r.slice(P(t)),r.length!==t)throw new Error("inconsistent lengths");return C(r)}function Xa(r){let t;r[0]==="Q"||r[0]==="1"?t=Jt(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 Qa(r){let t=Wa.decode(r),e=Uint8Array.from(et(t.length));return Q([e,t],e.length+t.length)}function ja(r){let t=Z(r),e=r.slice(P(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+C(e,"base64url")}function Ka(r){let t=Z(r),e=r.slice(P(t));if(e.length!==t)throw new Error("inconsistent lengths");return C(e,"base58btc")}function Ja(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=_n(n);return Q([e,s],e.length+s.length)}function Za(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=_n(n);return Q([e,s],e.length+s.length)}function eo(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=C(t,"base32"),s=ro(e);return`${n}:${s}`}function no(r){r=Un(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 oo("invalid address: "+r);if(c.path===!0){n=Un(s.slice(o).join("/")),t.push([c.code,Pn(c.code,n)]),e.push([c.code,n]);break}let l=Pn(c.code,s[o]);t.push([c.code,l]),e.push([c.code,Dn(c.code,l)])}return{string:so(e),bytes:Mn(t),tuples:t,stringTuples:e,path:n}}function Cn(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let o=Z(r,s),i=P(o),c=k(o),l=Ya(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 oo("Invalid address Uint8Array: "+C(r,"base16"));t.push([o,u]);let d=Dn(o,u);if(e.push([o,d]),c.path===!0){n=d;break}}return{bytes:Uint8Array.from(r),string:so(e),tuples:t,stringTuples:e,path:n}}function so(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}),Un(t.join("/"))}function Mn(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 Ya(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 Un(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function oo(r){return new Error("Error parsing address: "+r)}var tc=Symbol.for("nodejs.util.inspect.custom"),Nn=Symbol.for("@multiformats/js-multiaddr/multiaddr"),ec=[k("dns").code,k("dns4").code,k("dns6").code,k("dnsaddr").code],Fn=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},cr=class r{bytes;#t;#e;#r;#n;[Nn]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Cn(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=no(t)}else if(ao(t))e=Cn(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??""}`),ec.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(Mn(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,s])=>{n===qt.p2p.code&&t.push([n,s]),n===qt["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?C(B.decode(`z${n}`),"base58btc"):C(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=io.get(e.name);if(n==null)throw new Fn(`no available resolver for ${e.name}`);return(await n(this,t)).map(o=>ue(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)}[tc](){return`Multiaddr(${this.#t})`}};var io=new Map;function ao(r){return!!r?.[Nn]}function ue(r){return new cr(r)}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=ue(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(js.matches(n)||t&&Qs.matches(n))return e||zs.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:
@@ -1,21 +1,19 @@
1
1
  import type { BitswapOptions } from '@helia/bitswap';
2
- import type { BlockBroker, Routing } from '@helia/interface';
2
+ import type { BlockBroker, Routing, HasherLoader } from '@helia/interface';
3
3
  import type { Libp2p, ComponentLogger } from '@libp2p/interface';
4
4
  import type { Blockstore } from 'interface-blockstore';
5
- import type { MultihashHasher } from 'multiformats/hashes/interface';
6
- interface BitswapComponents {
5
+ export interface BitswapBlockBrokerComponents {
7
6
  libp2p: Libp2p;
8
7
  blockstore: Blockstore;
9
- hashers: Record<string, MultihashHasher>;
10
8
  routing: Routing;
11
9
  logger: ComponentLogger;
10
+ getHasher: HasherLoader;
12
11
  }
13
- export interface BitswapInit extends BitswapOptions {
12
+ export interface BitswapBlockBrokerInit extends BitswapOptions {
14
13
  }
15
14
  /**
16
15
  * A helper factory for users who want to override Helia `blockBrokers` but
17
16
  * still want to use the default `BitswapBlockBroker`.
18
17
  */
19
- export declare function bitswap(init?: BitswapInit): (components: BitswapComponents) => BlockBroker;
20
- export {};
18
+ export declare function bitswap(init?: BitswapBlockBrokerInit): (components: BitswapBlockBrokerComponents) => BlockBroker;
21
19
  //# sourceMappingURL=bitswap.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"bitswap.d.ts","sourceRoot":"","sources":["../../src/bitswap.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAwE,MAAM,gBAAgB,CAAA;AAC1H,OAAO,KAAK,EAAwB,WAAW,EAA+C,OAAO,EAAE,MAAM,kBAAkB,CAAA;AAC/H,OAAO,KAAK,EAAE,MAAM,EAAa,eAAe,EAAE,MAAM,mBAAmB,CAAA;AAC3E,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AAEtD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAA;AAEpE,UAAU,iBAAiB;IACzB,MAAM,EAAE,MAAM,CAAA;IACd,UAAU,EAAE,UAAU,CAAA;IACtB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IACxC,OAAO,EAAE,OAAO,CAAA;IAChB,MAAM,EAAE,eAAe,CAAA;CACxB;AAED,MAAM,WAAW,WAAY,SAAQ,cAAc;CAElD;AAuED;;;GAGG;AACH,wBAAgB,OAAO,CAAE,IAAI,GAAE,WAAgB,GAAG,CAAC,UAAU,EAAE,iBAAiB,KAAK,WAAW,CAE/F"}
1
+ {"version":3,"file":"bitswap.d.ts","sourceRoot":"","sources":["../../src/bitswap.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAwE,MAAM,gBAAgB,CAAA;AAC1H,OAAO,KAAK,EAAwB,WAAW,EAA+C,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAA;AAC7I,OAAO,KAAK,EAAE,MAAM,EAAa,eAAe,EAAE,MAAM,mBAAmB,CAAA;AAC3E,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AAItD,MAAM,WAAW,4BAA4B;IAC3C,MAAM,EAAE,MAAM,CAAA;IACd,UAAU,EAAE,UAAU,CAAA;IACtB,OAAO,EAAE,OAAO,CAAA;IAChB,MAAM,EAAE,eAAe,CAAA;IACvB,SAAS,EAAE,YAAY,CAAA;CACxB;AAED,MAAM,WAAW,sBAAuB,SAAQ,cAAc;CAE7D;AAyDD;;;GAGG;AACH,wBAAgB,OAAO,CAAE,IAAI,GAAE,sBAA2B,GAAG,CAAC,UAAU,EAAE,4BAA4B,KAAK,WAAW,CAErH"}
@@ -3,23 +3,11 @@ class BitswapBlockBroker {
3
3
  bitswap;
4
4
  started;
5
5
  constructor(components, init = {}) {
6
- const { hashers } = components;
6
+ const { getHasher } = components;
7
7
  this.bitswap = createBitswap(components, {
8
8
  hashLoader: {
9
9
  getHasher: async (codecOrName) => {
10
- let hasher;
11
- if (typeof codecOrName === 'string') {
12
- hasher = Object.values(hashers).find(hasher => {
13
- return hasher.name === codecOrName;
14
- });
15
- }
16
- else {
17
- hasher = hashers[codecOrName];
18
- }
19
- if (hasher != null) {
20
- return hasher;
21
- }
22
- throw new Error(`Could not load hasher for code/name "${codecOrName}"`);
10
+ return getHasher(codecOrName);
23
11
  }
24
12
  },
25
13
  ...init
@@ -1 +1 @@
1
- {"version":3,"file":"bitswap.js","sourceRoot":"","sources":["../../src/bitswap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAA;AAoB9C,MAAM,kBAAkB;IACL,OAAO,CAAS;IACzB,OAAO,CAAS;IAExB,YAAa,UAA6B,EAAE,OAAoB,EAAE;QAChE,MAAM,EAAE,OAAO,EAAE,GAAG,UAAU,CAAA;QAE9B,IAAI,CAAC,OAAO,GAAG,aAAa,CAAC,UAAU,EAAE;YACvC,UAAU,EAAE;gBACV,SAAS,EAAE,KAAK,EAAE,WAA4B,EAAoC,EAAE;oBAClF,IAAI,MAAmC,CAAA;oBAEvC,IAAI,OAAO,WAAW,KAAK,QAAQ,EAAE,CAAC;wBACpC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;4BAC5C,OAAO,MAAM,CAAC,IAAI,KAAK,WAAW,CAAA;wBACpC,CAAC,CAAC,CAAA;oBACJ,CAAC;yBAAM,CAAC;wBACN,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC,CAAA;oBAC/B,CAAC;oBAED,IAAI,MAAM,IAAI,IAAI,EAAE,CAAC;wBACnB,OAAO,MAAM,CAAA;oBACf,CAAC;oBAED,MAAM,IAAI,KAAK,CAAC,wCAAwC,WAAW,GAAG,CAAC,CAAA;gBACzE,CAAC;aACF;YACD,GAAG,IAAI;SACR,CAAC,CAAA;QACF,IAAI,CAAC,OAAO,GAAG,KAAK,CAAA;IACtB,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,CAAA;IACrB,CAAC;IAED,KAAK,CAAC,KAAK;QACT,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAA;QAC1B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAA;IACrB,CAAC;IAED,KAAK,CAAC,IAAI;QACR,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAA;QACzB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAA;IACtB,CAAC;IAED,KAAK,CAAC,QAAQ,CAAE,GAAQ,EAAE,KAAiB,EAAE,OAA2D;QACtG,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,EAAE,KAAK,EAAE,OAAO,CAAC,CAAA;IAChD,CAAC;IAED,KAAK,CAAC,QAAQ,CAAE,GAAQ,EAAE,UAAiE,EAAE;QAC3F,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,EAAE,OAAO,CAAC,CAAA;IACxC,CAAC;IAED,aAAa,CAAE,OAA8D;QAC3E,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,CAAA;QAEnD,OAAO;YACL,QAAQ,EAAE,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;gBACtC,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,EAAE,KAAK,EAAE,OAAO,CAAC,CAAA;YAChD,CAAC;YAED,QAAQ,EAAE,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,EAAE;gBAC/B,OAAO,OAAO,CAAC,QAAQ,CAAC,GAAG,EAAE,OAAO,CAAC,CAAA;YACvC,CAAC;SACF,CAAA;IACH,CAAC;CACF;AAED;;;GAGG;AACH,MAAM,UAAU,OAAO,CAAE,OAAoB,EAAE;IAC7C,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,IAAI,kBAAkB,CAAC,UAAU,EAAE,IAAI,CAAC,CAAA;AACjE,CAAC"}
1
+ {"version":3,"file":"bitswap.js","sourceRoot":"","sources":["../../src/bitswap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAA;AAoB9C,MAAM,kBAAkB;IACL,OAAO,CAAS;IACzB,OAAO,CAAS;IAExB,YAAa,UAAwC,EAAE,OAA+B,EAAE;QACtF,MAAM,EAAE,SAAS,EAAE,GAAG,UAAU,CAAA;QAEhC,IAAI,CAAC,OAAO,GAAG,aAAa,CAAC,UAAU,EAAE;YACvC,UAAU,EAAE;gBACV,SAAS,EAAE,KAAK,EAAE,WAAmB,EAAoC,EAAE;oBACzE,OAAO,SAAS,CAAC,WAAW,CAAC,CAAA;gBAC/B,CAAC;aACF;YACD,GAAG,IAAI;SACR,CAAC,CAAA;QACF,IAAI,CAAC,OAAO,GAAG,KAAK,CAAA;IACtB,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,CAAA;IACrB,CAAC;IAED,KAAK,CAAC,KAAK;QACT,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAA;QAC1B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAA;IACrB,CAAC;IAED,KAAK,CAAC,IAAI;QACR,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAA;QACzB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAA;IACtB,CAAC;IAED,KAAK,CAAC,QAAQ,CAAE,GAAQ,EAAE,KAAiB,EAAE,OAA2D;QACtG,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,EAAE,KAAK,EAAE,OAAO,CAAC,CAAA;IAChD,CAAC;IAED,KAAK,CAAC,QAAQ,CAAE,GAAQ,EAAE,UAAiE,EAAE;QAC3F,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,EAAE,OAAO,CAAC,CAAA;IACxC,CAAC;IAED,aAAa,CAAE,OAA8D;QAC3E,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,CAAA;QAEnD,OAAO;YACL,QAAQ,EAAE,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;gBACtC,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,EAAE,KAAK,EAAE,OAAO,CAAC,CAAA;YAChD,CAAC;YAED,QAAQ,EAAE,KAAK,EAAE,GAAG,EAAE,OAAO,EAAE,EAAE;gBAC/B,OAAO,OAAO,CAAC,QAAQ,CAAC,GAAG,EAAE,OAAO,CAAC,CAAA;YACvC,CAAC;SACF,CAAA;IACH,CAAC;CACF;AAED;;;GAGG;AACH,MAAM,UAAU,OAAO,CAAE,OAA+B,EAAE;IACxD,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,IAAI,kBAAkB,CAAC,UAAU,EAAE,IAAI,CAAC,CAAA;AACjE,CAAC"}
@@ -1,3 +1,5 @@
1
1
  export { bitswap } from './bitswap.js';
2
+ export type { BitswapBlockBrokerInit, BitswapBlockBrokerComponents } from './bitswap.js';
2
3
  export { trustlessGateway } from './trustless-gateway/index.js';
4
+ export type { TrustlessGatewayBlockBrokerInit, TrustlessGatewayBlockBrokerComponents, TrustlessGatewayGetBlockProgressEvents } from './trustless-gateway/index.js';
3
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AACtC,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AACtC,YAAY,EAAE,sBAAsB,EAAE,4BAA4B,EAAE,MAAM,cAAc,CAAA;AACxF,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAA;AAC/D,YAAY,EAAE,+BAA+B,EAAE,qCAAqC,EAAE,sCAAsC,EAAE,MAAM,8BAA8B,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AACtC,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAEtC,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAA"}
@@ -1,4 +1,4 @@
1
- import type { TrustlessGatewayBlockBrokerInit, TrustlessGatewayComponents, TrustlessGatewayGetBlockProgressEvents } from './index.js';
1
+ import type { TrustlessGatewayBlockBrokerInit, TrustlessGatewayBlockBrokerComponents, TrustlessGatewayGetBlockProgressEvents } from './index.js';
2
2
  import type { BlockRetrievalOptions, BlockBroker, CreateSessionOptions } from '@helia/interface';
3
3
  import type { CID } from 'multiformats/cid';
4
4
  export interface CreateTrustlessGatewaySessionOptions extends CreateSessionOptions<TrustlessGatewayGetBlockProgressEvents> {
@@ -27,7 +27,7 @@ export declare class TrustlessGatewayBlockBroker implements BlockBroker<Trustles
27
27
  private readonly routing;
28
28
  private readonly log;
29
29
  private readonly logger;
30
- constructor(components: TrustlessGatewayComponents, init?: TrustlessGatewayBlockBrokerInit);
30
+ constructor(components: TrustlessGatewayBlockBrokerComponents, init?: TrustlessGatewayBlockBrokerInit);
31
31
  retrieve(cid: CID, options?: BlockRetrievalOptions<TrustlessGatewayGetBlockProgressEvents>): Promise<Uint8Array>;
32
32
  createSession(options?: CreateTrustlessGatewaySessionOptions): BlockBroker<TrustlessGatewayGetBlockProgressEvents>;
33
33
  }
@@ -1 +1 @@
1
- {"version":3,"file":"broker.d.ts","sourceRoot":"","sources":["../../../src/trustless-gateway/broker.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,+BAA+B,EAAE,0BAA0B,EAAE,sCAAsC,EAAE,MAAM,YAAY,CAAA;AACrI,OAAO,KAAK,EAAW,qBAAqB,EAAE,WAAW,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAA;AAEzG,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAA;AAE3C,MAAM,WAAW,oCAAqC,SAAQ,oBAAoB,CAAC,sCAAsC,CAAC;IACxH;;;;;OAKG;IACH,aAAa,CAAC,EAAE,OAAO,CAAA;IAEvB;;;;;OAKG;IACH,UAAU,CAAC,EAAE,OAAO,CAAA;CACrB;AAED;;;GAGG;AACH,qBAAa,2BAA4B,YAAW,WAAW,CAAC,sCAAsC,CAAC;IACrG,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;IACvC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAQ;IAC5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAiB;gBAE3B,UAAU,EAAE,0BAA0B,EAAE,IAAI,GAAE,+BAAoC;IAQzF,QAAQ,CAAE,GAAG,EAAE,GAAG,EAAE,OAAO,GAAE,qBAAqB,CAAC,sCAAsC,CAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IA2C3H,aAAa,CAAE,OAAO,GAAE,oCAAyC,GAAG,WAAW,CAAC,sCAAsC,CAAC;CAUxH"}
1
+ {"version":3,"file":"broker.d.ts","sourceRoot":"","sources":["../../../src/trustless-gateway/broker.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,+BAA+B,EAAE,qCAAqC,EAAE,sCAAsC,EAAE,MAAM,YAAY,CAAA;AAChJ,OAAO,KAAK,EAAW,qBAAqB,EAAE,WAAW,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAA;AAEzG,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAA;AAE3C,MAAM,WAAW,oCAAqC,SAAQ,oBAAoB,CAAC,sCAAsC,CAAC;IACxH;;;;;OAKG;IACH,aAAa,CAAC,EAAE,OAAO,CAAA;IAEvB;;;;;OAKG;IACH,UAAU,CAAC,EAAE,OAAO,CAAA;CACrB;AAED;;;GAGG;AACH,qBAAa,2BAA4B,YAAW,WAAW,CAAC,sCAAsC,CAAC;IACrG,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAS;IACvC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAS;IACjC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAQ;IAC5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAiB;gBAE3B,UAAU,EAAE,qCAAqC,EAAE,IAAI,GAAE,+BAAoC;IAQpG,QAAQ,CAAE,GAAG,EAAE,GAAG,EAAE,OAAO,GAAE,qBAAqB,CAAC,sCAAsC,CAAM,GAAG,OAAO,CAAC,UAAU,CAAC;IA2C3H,aAAa,CAAE,OAAO,GAAE,oCAAyC,GAAG,WAAW,CAAC,sCAAsC,CAAC;CAUxH"}
@@ -1 +1 @@
1
- {"version":3,"file":"broker.js","sourceRoot":"","sources":["../../../src/trustless-gateway/broker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,6BAA6B,EAAE,MAAM,cAAc,CAAA;AAC5D,OAAO,EAAE,wBAAwB,EAAE,MAAM,YAAY,CAAA;AACrD,OAAO,EAAE,sBAAsB,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAA;AAwBxE;;;GAGG;AACH,MAAM,OAAO,2BAA2B;IACrB,aAAa,CAAS;IACtB,UAAU,CAAS;IACnB,OAAO,CAAS;IAChB,GAAG,CAAQ;IACX,MAAM,CAAiB;IAExC,YAAa,UAAsC,EAAE,OAAwC,EAAE;QAC7F,IAAI,CAAC,GAAG,GAAG,UAAU,CAAC,MAAM,CAAC,YAAY,CAAC,sCAAsC,CAAC,CAAA;QACjF,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,CAAA;QAC/B,IAAI,CAAC,OAAO,GAAG,UAAU,CAAC,OAAO,CAAA;QACjC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,IAAI,sBAAsB,CAAA;QACjE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,IAAI,mBAAmB,CAAA;IAC1D,CAAC;IAED,KAAK,CAAC,QAAQ,CAAE,GAAQ,EAAE,UAAyE,EAAE;QACnG,MAAM,eAAe,GAAY,EAAE,CAAA;QAEnC,IAAI,KAAK,EAAE,MAAM,OAAO,IAAI,wBAAwB,CAAC,GAAG,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,EAAE,CAAC;YACnI,IAAI,CAAC,GAAG,CAAC,8BAA8B,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,CAAA;YAE1D,IAAI,CAAC;gBACH,MAAM,KAAK,GAAG,MAAM,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,OAAO,CAAC,MAAM,CAAC,CAAA;gBAC5D,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,0BAA0B,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,CAAA;gBAE5D,IAAI,CAAC;oBACH,MAAM,OAAO,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,CAAA;gBACnC,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,yCAAyC,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;oBAChF,sBAAsB;oBACtB,SAAQ;gBACV,CAAC;gBAED,OAAO,KAAK,CAAA;YACd,CAAC;YAAC,OAAO,GAAY,EAAE,CAAC;gBACtB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,oCAAoC,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;gBAE3E,IAAI,GAAG,YAAY,KAAK,EAAE,CAAC;oBACzB,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;gBAC3B,CAAC;qBAAM,CAAC;oBACN,eAAe,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,qCAAqC,GAAG,iBAAiB,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,CAAA;gBACzG,CAAC;gBAED,uCAAuC;gBACvC,IAAI,OAAO,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,EAAE,CAAC;oBACrC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,qEAAqE,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,CAAA;oBACvG,MAAK;gBACP,CAAC;YACH,CAAC;QACH,CAAC;QAED,IAAI,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC/B,MAAM,IAAI,cAAc,CAAC,eAAe,EAAE,qCAAqC,GAAG,mBAAmB,CAAC,CAAA;QACxG,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,qCAAqC,GAAG,mBAAmB,CAAC,CAAA;QAC9E,CAAC;IACH,CAAC;IAED,aAAa,CAAE,UAAgD,EAAE;QAC/D,OAAO,6BAA6B,CAAC;YACnC,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,EAAE;YACD,GAAG,OAAO;YACV,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,aAAa,EAAE,IAAI,CAAC,aAAa;SAClC,CAAC,CAAA;IACJ,CAAC;CACF"}
1
+ {"version":3,"file":"broker.js","sourceRoot":"","sources":["../../../src/trustless-gateway/broker.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,6BAA6B,EAAE,MAAM,cAAc,CAAA;AAC5D,OAAO,EAAE,wBAAwB,EAAE,MAAM,YAAY,CAAA;AACrD,OAAO,EAAE,sBAAsB,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAA;AAwBxE;;;GAGG;AACH,MAAM,OAAO,2BAA2B;IACrB,aAAa,CAAS;IACtB,UAAU,CAAS;IACnB,OAAO,CAAS;IAChB,GAAG,CAAQ;IACX,MAAM,CAAiB;IAExC,YAAa,UAAiD,EAAE,OAAwC,EAAE;QACxG,IAAI,CAAC,GAAG,GAAG,UAAU,CAAC,MAAM,CAAC,YAAY,CAAC,sCAAsC,CAAC,CAAA;QACjF,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,CAAA;QAC/B,IAAI,CAAC,OAAO,GAAG,UAAU,CAAC,OAAO,CAAA;QACjC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,IAAI,sBAAsB,CAAA;QACjE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,IAAI,mBAAmB,CAAA;IAC1D,CAAC;IAED,KAAK,CAAC,QAAQ,CAAE,GAAQ,EAAE,UAAyE,EAAE;QACnG,MAAM,eAAe,GAAY,EAAE,CAAA;QAEnC,IAAI,KAAK,EAAE,MAAM,OAAO,IAAI,wBAAwB,CAAC,GAAG,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,EAAE,CAAC;YACnI,IAAI,CAAC,GAAG,CAAC,8BAA8B,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,CAAA;YAE1D,IAAI,CAAC;gBACH,MAAM,KAAK,GAAG,MAAM,OAAO,CAAC,WAAW,CAAC,GAAG,EAAE,OAAO,CAAC,MAAM,CAAC,CAAA;gBAC5D,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,0BAA0B,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,CAAA;gBAE5D,IAAI,CAAC;oBACH,MAAM,OAAO,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,CAAA;gBACnC,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,yCAAyC,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;oBAChF,sBAAsB;oBACtB,SAAQ;gBACV,CAAC;gBAED,OAAO,KAAK,CAAA;YACd,CAAC;YAAC,OAAO,GAAY,EAAE,CAAC;gBACtB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,oCAAoC,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,EAAE,GAAG,CAAC,CAAA;gBAE3E,IAAI,GAAG,YAAY,KAAK,EAAE,CAAC;oBACzB,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;gBAC3B,CAAC;qBAAM,CAAC;oBACN,eAAe,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,qCAAqC,GAAG,iBAAiB,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC,CAAA;gBACzG,CAAC;gBAED,uCAAuC;gBACvC,IAAI,OAAO,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,EAAE,CAAC;oBACrC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,qEAAqE,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,CAAA;oBACvG,MAAK;gBACP,CAAC;YACH,CAAC;QACH,CAAC;QAED,IAAI,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC/B,MAAM,IAAI,cAAc,CAAC,eAAe,EAAE,qCAAqC,GAAG,mBAAmB,CAAC,CAAA;QACxG,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,KAAK,CAAC,qCAAqC,GAAG,mBAAmB,CAAC,CAAA;QAC9E,CAAC;IACH,CAAC;IAED,aAAa,CAAE,UAAgD,EAAE;QAC/D,OAAO,6BAA6B,CAAC;YACnC,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,OAAO,EAAE,IAAI,CAAC,OAAO;SACtB,EAAE;YACD,GAAG,OAAO;YACV,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,aAAa,EAAE,IAAI,CAAC,aAAa;SAClC,CAAC,CAAA;IACJ,CAAC;CACF"}
@@ -20,9 +20,9 @@ export interface TrustlessGatewayBlockBrokerInit {
20
20
  */
21
21
  allowLocal?: boolean;
22
22
  }
23
- export interface TrustlessGatewayComponents {
23
+ export interface TrustlessGatewayBlockBrokerComponents {
24
24
  routing: Routing;
25
25
  logger: ComponentLogger;
26
26
  }
27
- export declare function trustlessGateway(init?: TrustlessGatewayBlockBrokerInit): (components: TrustlessGatewayComponents) => BlockBroker<TrustlessGatewayGetBlockProgressEvents>;
27
+ export declare function trustlessGateway(init?: TrustlessGatewayBlockBrokerInit): (components: TrustlessGatewayBlockBrokerComponents) => BlockBroker<TrustlessGatewayGetBlockProgressEvents>;
28
28
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/trustless-gateway/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAC5D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACxD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAEpD,eAAO,MAAM,sBAAsB,QAAQ,CAAA;AAC3C,eAAO,MAAM,mBAAmB,QAAQ,CAAA;AAExC,MAAM,MAAM,sCAAsC,GAChD,aAAa,CAAC,mCAAmC,EAAE,GAAG,CAAC,CAAA;AAEzD,MAAM,WAAW,+BAA+B;IAC9C;;;;;OAKG;IACH,aAAa,CAAC,EAAE,OAAO,CAAA;IAEvB;;;;;OAKG;IACH,UAAU,CAAC,EAAE,OAAO,CAAA;CACrB;AAED,MAAM,WAAW,0BAA0B;IACzC,OAAO,EAAE,OAAO,CAAA;IAChB,MAAM,EAAE,eAAe,CAAA;CACxB;AAED,wBAAgB,gBAAgB,CAAE,IAAI,GAAE,+BAAoC,GAAG,CAAC,UAAU,EAAE,0BAA0B,KAAK,WAAW,CAAC,sCAAsC,CAAC,CAE7K"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/trustless-gateway/index.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAC5D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACxD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAEpD,eAAO,MAAM,sBAAsB,QAAQ,CAAA;AAC3C,eAAO,MAAM,mBAAmB,QAAQ,CAAA;AAExC,MAAM,MAAM,sCAAsC,GAChD,aAAa,CAAC,mCAAmC,EAAE,GAAG,CAAC,CAAA;AAEzD,MAAM,WAAW,+BAA+B;IAC9C;;;;;OAKG;IACH,aAAa,CAAC,EAAE,OAAO,CAAA;IAEvB;;;;;OAKG;IACH,UAAU,CAAC,EAAE,OAAO,CAAA;CACrB;AAED,MAAM,WAAW,qCAAqC;IACpD,OAAO,EAAE,OAAO,CAAA;IAChB,MAAM,EAAE,eAAe,CAAA;CACxB;AAED,wBAAgB,gBAAgB,CAAE,IAAI,GAAE,+BAAoC,GAAG,CAAC,UAAU,EAAE,qCAAqC,KAAK,WAAW,CAAC,sCAAsC,CAAC,CAExL"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@helia/block-brokers",
3
- "version": "3.0.4",
3
+ "version": "4.0.0-0238ed4",
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",
@@ -43,6 +43,7 @@
43
43
  "clean": "aegir clean",
44
44
  "lint": "aegir lint",
45
45
  "dep-check": "aegir dep-check",
46
+ "doc-check": "aegir doc-check",
46
47
  "build": "aegir build",
47
48
  "test": "aegir test",
48
49
  "test:chrome": "aegir test -t browser --cov",
@@ -53,29 +54,30 @@
53
54
  "test:electron-main": "aegir test -t electron-main"
54
55
  },
55
56
  "dependencies": {
56
- "@helia/bitswap": "^1.1.4",
57
- "@helia/interface": "^4.3.1",
58
- "@helia/utils": "^0.3.3",
59
- "@libp2p/interface": "^1.1.4",
60
- "@libp2p/utils": "^5.2.6",
57
+ "@helia/bitswap": "2.0.0-0238ed4",
58
+ "@helia/interface": "5.0.0-0238ed4",
59
+ "@helia/utils": "1.0.0-0238ed4",
60
+ "@libp2p/interface": "^2.0.0",
61
+ "@libp2p/utils": "^6.0.0",
61
62
  "@multiformats/multiaddr": "^12.2.1",
62
63
  "@multiformats/multiaddr-matcher": "^1.2.0",
63
64
  "@multiformats/multiaddr-to-uri": "^10.0.1",
64
65
  "interface-blockstore": "^5.2.10",
65
- "interface-store": "^5.1.8",
66
+ "interface-store": "^6.0.0",
66
67
  "multiformats": "^13.1.0",
67
68
  "progress-events": "^1.0.0"
68
69
  },
69
70
  "devDependencies": {
70
- "@libp2p/logger": "^4.0.7",
71
- "@libp2p/peer-id-factory": "^4.0.7",
71
+ "@libp2p/crypto": "^5.0.0",
72
+ "@libp2p/logger": "^5.0.0",
73
+ "@libp2p/peer-id": "^5.0.0",
72
74
  "@multiformats/uri-to-multiaddr": "^8.0.0",
73
75
  "@types/polka": "^0.5.7",
74
76
  "@types/sinon": "^17.0.3",
75
77
  "aegir": "^44.0.1",
76
78
  "cors": "^2.8.5",
77
79
  "polka": "^0.5.2",
78
- "sinon": "^18.0.0",
80
+ "sinon": "^19.0.2",
79
81
  "sinon-ts": "^2.0.0",
80
82
  "uint8arrays": "^5.0.3"
81
83
  }
package/src/bitswap.ts CHANGED
@@ -1,20 +1,20 @@
1
1
  import { createBitswap } from '@helia/bitswap'
2
2
  import type { BitswapOptions, Bitswap, BitswapWantBlockProgressEvents, BitswapNotifyProgressEvents } from '@helia/bitswap'
3
- import type { BlockAnnounceOptions, BlockBroker, BlockRetrievalOptions, CreateSessionOptions, Routing } from '@helia/interface'
3
+ import type { BlockAnnounceOptions, BlockBroker, BlockRetrievalOptions, CreateSessionOptions, Routing, HasherLoader } from '@helia/interface'
4
4
  import type { Libp2p, Startable, ComponentLogger } from '@libp2p/interface'
5
5
  import type { Blockstore } from 'interface-blockstore'
6
6
  import type { CID } from 'multiformats/cid'
7
7
  import type { MultihashHasher } from 'multiformats/hashes/interface'
8
8
 
9
- interface BitswapComponents {
9
+ export interface BitswapBlockBrokerComponents {
10
10
  libp2p: Libp2p
11
11
  blockstore: Blockstore
12
- hashers: Record<string, MultihashHasher>
13
12
  routing: Routing
14
13
  logger: ComponentLogger
14
+ getHasher: HasherLoader
15
15
  }
16
16
 
17
- export interface BitswapInit extends BitswapOptions {
17
+ export interface BitswapBlockBrokerInit extends BitswapOptions {
18
18
 
19
19
  }
20
20
 
@@ -22,27 +22,13 @@ class BitswapBlockBroker implements BlockBroker<BitswapWantBlockProgressEvents,
22
22
  private readonly bitswap: Bitswap
23
23
  private started: boolean
24
24
 
25
- constructor (components: BitswapComponents, init: BitswapInit = {}) {
26
- const { hashers } = components
25
+ constructor (components: BitswapBlockBrokerComponents, init: BitswapBlockBrokerInit = {}) {
26
+ const { getHasher } = components
27
27
 
28
28
  this.bitswap = createBitswap(components, {
29
29
  hashLoader: {
30
- getHasher: async (codecOrName: string | number): Promise<MultihashHasher<number>> => {
31
- let hasher: MultihashHasher | undefined
32
-
33
- if (typeof codecOrName === 'string') {
34
- hasher = Object.values(hashers).find(hasher => {
35
- return hasher.name === codecOrName
36
- })
37
- } else {
38
- hasher = hashers[codecOrName]
39
- }
40
-
41
- if (hasher != null) {
42
- return hasher
43
- }
44
-
45
- throw new Error(`Could not load hasher for code/name "${codecOrName}"`)
30
+ getHasher: async (codecOrName: number): Promise<MultihashHasher<number>> => {
31
+ return getHasher(codecOrName)
46
32
  }
47
33
  },
48
34
  ...init
@@ -91,6 +77,6 @@ class BitswapBlockBroker implements BlockBroker<BitswapWantBlockProgressEvents,
91
77
  * A helper factory for users who want to override Helia `blockBrokers` but
92
78
  * still want to use the default `BitswapBlockBroker`.
93
79
  */
94
- export function bitswap (init: BitswapInit = {}): (components: BitswapComponents) => BlockBroker {
80
+ export function bitswap (init: BitswapBlockBrokerInit = {}): (components: BitswapBlockBrokerComponents) => BlockBroker {
95
81
  return (components) => new BitswapBlockBroker(components, init)
96
82
  }
package/src/index.ts CHANGED
@@ -1,2 +1,4 @@
1
1
  export { bitswap } from './bitswap.js'
2
+ export type { BitswapBlockBrokerInit, BitswapBlockBrokerComponents } from './bitswap.js'
2
3
  export { trustlessGateway } from './trustless-gateway/index.js'
4
+ export type { TrustlessGatewayBlockBrokerInit, TrustlessGatewayBlockBrokerComponents, TrustlessGatewayGetBlockProgressEvents } from './trustless-gateway/index.js'
@@ -1,7 +1,7 @@
1
1
  import { createTrustlessGatewaySession } from './session.js'
2
2
  import { findHttpGatewayProviders } from './utils.js'
3
3
  import { DEFAULT_ALLOW_INSECURE, DEFAULT_ALLOW_LOCAL } from './index.js'
4
- import type { TrustlessGatewayBlockBrokerInit, TrustlessGatewayComponents, TrustlessGatewayGetBlockProgressEvents } from './index.js'
4
+ import type { TrustlessGatewayBlockBrokerInit, TrustlessGatewayBlockBrokerComponents, TrustlessGatewayGetBlockProgressEvents } from './index.js'
5
5
  import type { Routing, BlockRetrievalOptions, BlockBroker, CreateSessionOptions } from '@helia/interface'
6
6
  import type { ComponentLogger, Logger } from '@libp2p/interface'
7
7
  import type { CID } from 'multiformats/cid'
@@ -35,7 +35,7 @@ export class TrustlessGatewayBlockBroker implements BlockBroker<TrustlessGateway
35
35
  private readonly log: Logger
36
36
  private readonly logger: ComponentLogger
37
37
 
38
- constructor (components: TrustlessGatewayComponents, init: TrustlessGatewayBlockBrokerInit = {}) {
38
+ constructor (components: TrustlessGatewayBlockBrokerComponents, init: TrustlessGatewayBlockBrokerInit = {}) {
39
39
  this.log = components.logger.forComponent('helia:trustless-gateway-block-broker')
40
40
  this.logger = components.logger
41
41
  this.routing = components.routing
@@ -27,11 +27,11 @@ export interface TrustlessGatewayBlockBrokerInit {
27
27
  allowLocal?: boolean
28
28
  }
29
29
 
30
- export interface TrustlessGatewayComponents {
30
+ export interface TrustlessGatewayBlockBrokerComponents {
31
31
  routing: Routing
32
32
  logger: ComponentLogger
33
33
  }
34
34
 
35
- export function trustlessGateway (init: TrustlessGatewayBlockBrokerInit = {}): (components: TrustlessGatewayComponents) => BlockBroker<TrustlessGatewayGetBlockProgressEvents> {
35
+ export function trustlessGateway (init: TrustlessGatewayBlockBrokerInit = {}): (components: TrustlessGatewayBlockBrokerComponents) => BlockBroker<TrustlessGatewayGetBlockProgressEvents> {
36
36
  return (components) => new TrustlessGatewayBlockBroker(components, init)
37
37
  }
@@ -1,4 +0,0 @@
1
- {
2
- "bitswap": "https://ipfs.github.io/helia/functions/_helia_block_brokers.bitswap.html",
3
- "trustlessGateway": "https://ipfs.github.io/helia/functions/_helia_block_brokers.trustlessGateway.html"
4
- }