@helia/unixfs 6.0.3 → 6.0.4-362f0b25

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,10 +1,14 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.HeliaUnixfs = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var HeliaUnixfs=(()=>{var Ec=Object.create;var gr=Object.defineProperty;var vc=Object.getOwnPropertyDescriptor;var Bc=Object.getOwnPropertyNames;var Ic=Object.getPrototypeOf,Ac=Object.prototype.hasOwnProperty;var wr=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),W=(r,e)=>{for(var t in e)gr(r,t,{get:e[t],enumerable:!0})},qi=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Bc(e))!Ac.call(r,i)&&i!==t&&gr(r,i,{get:()=>e[i],enumerable:!(n=vc(e,i))||n.enumerable});return r};var Ft=(r,e,t)=>(t=r!=null?Ec(Ic(r)):{},qi(e||!r||!r.__esModule?gr(t,"default",{value:r,enumerable:!0}):t,r)),Cc=r=>qi(gr({},"__esModule",{value:!0}),r);var Qo=wr((er,Dr)=>{(function(r,e){"use strict";var t={version:"3.0.0",x86:{},x64:{},inputValidation:!0};function n(u){if(!Array.isArray(u)&&!ArrayBuffer.isView(u))return!1;for(var d=0;d<u.length;d++)if(!Number.isInteger(u[d])||u[d]<0||u[d]>255)return!1;return!0}function i(u,d){return(u&65535)*d+(((u>>>16)*d&65535)<<16)}function o(u,d){return u<<d|u>>>32-d}function s(u){return u^=u>>>16,u=i(u,2246822507),u^=u>>>13,u=i(u,3266489909),u^=u>>>16,u}function a(u,d){u=[u[0]>>>16,u[0]&65535,u[1]>>>16,u[1]&65535],d=[d[0]>>>16,d[0]&65535,d[1]>>>16,d[1]&65535];var m=[0,0,0,0];return m[3]+=u[3]+d[3],m[2]+=m[3]>>>16,m[3]&=65535,m[2]+=u[2]+d[2],m[1]+=m[2]>>>16,m[2]&=65535,m[1]+=u[1]+d[1],m[0]+=m[1]>>>16,m[1]&=65535,m[0]+=u[0]+d[0],m[0]&=65535,[m[0]<<16|m[1],m[2]<<16|m[3]]}function c(u,d){u=[u[0]>>>16,u[0]&65535,u[1]>>>16,u[1]&65535],d=[d[0]>>>16,d[0]&65535,d[1]>>>16,d[1]&65535];var m=[0,0,0,0];return m[3]+=u[3]*d[3],m[2]+=m[3]>>>16,m[3]&=65535,m[2]+=u[2]*d[3],m[1]+=m[2]>>>16,m[2]&=65535,m[2]+=u[3]*d[2],m[1]+=m[2]>>>16,m[2]&=65535,m[1]+=u[1]*d[3],m[0]+=m[1]>>>16,m[1]&=65535,m[1]+=u[2]*d[2],m[0]+=m[1]>>>16,m[1]&=65535,m[1]+=u[3]*d[1],m[0]+=m[1]>>>16,m[1]&=65535,m[0]+=u[0]*d[3]+u[1]*d[2]+u[2]*d[1]+u[3]*d[0],m[0]&=65535,[m[0]<<16|m[1],m[2]<<16|m[3]]}function h(u,d){return d%=64,d===32?[u[1],u[0]]:d<32?[u[0]<<d|u[1]>>>32-d,u[1]<<d|u[0]>>>32-d]:(d-=32,[u[1]<<d|u[0]>>>32-d,u[0]<<d|u[1]>>>32-d])}function f(u,d){return d%=64,d===0?u:d<32?[u[0]<<d|u[1]>>>32-d,u[1]<<d]:[u[1]<<d-32,0]}function l(u,d){return[u[0]^d[0],u[1]^d[1]]}function y(u){return u=l(u,[0,u[0]>>>1]),u=c(u,[4283543511,3981806797]),u=l(u,[0,u[0]>>>1]),u=c(u,[3301882366,444984403]),u=l(u,[0,u[0]>>>1]),u}t.x86.hash32=function(u,d){if(t.inputValidation&&!n(u))return e;d=d||0;for(var m=u.length%4,x=u.length-m,g=d,w=0,b=3432918353,S=461845907,B=0;B<x;B=B+4)w=u[B]|u[B+1]<<8|u[B+2]<<16|u[B+3]<<24,w=i(w,b),w=o(w,15),w=i(w,S),g^=w,g=o(g,13),g=i(g,5)+3864292196;switch(w=0,m){case 3:w^=u[B+2]<<16;case 2:w^=u[B+1]<<8;case 1:w^=u[B],w=i(w,b),w=o(w,15),w=i(w,S),g^=w}return g^=u.length,g=s(g),g>>>0},t.x86.hash128=function(u,d){if(t.inputValidation&&!n(u))return e;d=d||0;for(var m=u.length%16,x=u.length-m,g=d,w=d,b=d,S=d,B=0,C=0,E=0,L=0,le=597399067,ot=2869860233,mr=951274213,yr=2716044179,N=0;N<x;N=N+16)B=u[N]|u[N+1]<<8|u[N+2]<<16|u[N+3]<<24,C=u[N+4]|u[N+5]<<8|u[N+6]<<16|u[N+7]<<24,E=u[N+8]|u[N+9]<<8|u[N+10]<<16|u[N+11]<<24,L=u[N+12]|u[N+13]<<8|u[N+14]<<16|u[N+15]<<24,B=i(B,le),B=o(B,15),B=i(B,ot),g^=B,g=o(g,19),g+=w,g=i(g,5)+1444728091,C=i(C,ot),C=o(C,16),C=i(C,mr),w^=C,w=o(w,17),w+=b,w=i(w,5)+197830471,E=i(E,mr),E=o(E,17),E=i(E,yr),b^=E,b=o(b,15),b+=S,b=i(b,5)+2530024501,L=i(L,yr),L=o(L,18),L=i(L,le),S^=L,S=o(S,13),S+=g,S=i(S,5)+850148119;switch(B=0,C=0,E=0,L=0,m){case 15:L^=u[N+14]<<16;case 14:L^=u[N+13]<<8;case 13:L^=u[N+12],L=i(L,yr),L=o(L,18),L=i(L,le),S^=L;case 12:E^=u[N+11]<<24;case 11:E^=u[N+10]<<16;case 10:E^=u[N+9]<<8;case 9:E^=u[N+8],E=i(E,mr),E=o(E,17),E=i(E,yr),b^=E;case 8:C^=u[N+7]<<24;case 7:C^=u[N+6]<<16;case 6:C^=u[N+5]<<8;case 5:C^=u[N+4],C=i(C,ot),C=o(C,16),C=i(C,mr),w^=C;case 4:B^=u[N+3]<<24;case 3:B^=u[N+2]<<16;case 2:B^=u[N+1]<<8;case 1:B^=u[N],B=i(B,le),B=o(B,15),B=i(B,ot),g^=B}return g^=u.length,w^=u.length,b^=u.length,S^=u.length,g+=w,g+=b,g+=S,w+=g,b+=g,S+=g,g=s(g),w=s(w),b=s(b),S=s(S),g+=w,g+=b,g+=S,w+=g,b+=g,S+=g,("00000000"+(g>>>0).toString(16)).slice(-8)+("00000000"+(w>>>0).toString(16)).slice(-8)+("00000000"+(b>>>0).toString(16)).slice(-8)+("00000000"+(S>>>0).toString(16)).slice(-8)},t.x64.hash128=function(u,d){if(t.inputValidation&&!n(u))return e;d=d||0;for(var m=u.length%16,x=u.length-m,g=[0,d],w=[0,d],b=[0,0],S=[0,0],B=[2277735313,289559509],C=[1291169091,658871167],E=0;E<x;E=E+16)b=[u[E+4]|u[E+5]<<8|u[E+6]<<16|u[E+7]<<24,u[E]|u[E+1]<<8|u[E+2]<<16|u[E+3]<<24],S=[u[E+12]|u[E+13]<<8|u[E+14]<<16|u[E+15]<<24,u[E+8]|u[E+9]<<8|u[E+10]<<16|u[E+11]<<24],b=c(b,B),b=h(b,31),b=c(b,C),g=l(g,b),g=h(g,27),g=a(g,w),g=a(c(g,[0,5]),[0,1390208809]),S=c(S,C),S=h(S,33),S=c(S,B),w=l(w,S),w=h(w,31),w=a(w,g),w=a(c(w,[0,5]),[0,944331445]);switch(b=[0,0],S=[0,0],m){case 15:S=l(S,f([0,u[E+14]],48));case 14:S=l(S,f([0,u[E+13]],40));case 13:S=l(S,f([0,u[E+12]],32));case 12:S=l(S,f([0,u[E+11]],24));case 11:S=l(S,f([0,u[E+10]],16));case 10:S=l(S,f([0,u[E+9]],8));case 9:S=l(S,[0,u[E+8]]),S=c(S,C),S=h(S,33),S=c(S,B),w=l(w,S);case 8:b=l(b,f([0,u[E+7]],56));case 7:b=l(b,f([0,u[E+6]],48));case 6:b=l(b,f([0,u[E+5]],40));case 5:b=l(b,f([0,u[E+4]],32));case 4:b=l(b,f([0,u[E+3]],24));case 3:b=l(b,f([0,u[E+2]],16));case 2:b=l(b,f([0,u[E+1]],8));case 1:b=l(b,[0,u[E]]),b=c(b,B),b=h(b,31),b=c(b,C),g=l(g,b)}return g=l(g,[0,u.length]),w=l(w,[0,u.length]),g=a(g,w),w=a(w,g),g=y(g),w=y(w),g=a(g,w),w=a(w,g),("00000000"+(g[0]>>>0).toString(16)).slice(-8)+("00000000"+(g[1]>>>0).toString(16)).slice(-8)+("00000000"+(w[0]>>>0).toString(16)).slice(-8)+("00000000"+(w[1]>>>0).toString(16)).slice(-8)},typeof er<"u"?(typeof Dr<"u"&&Dr.exports&&(er=Dr.exports=t),er.murmurHash3=t):typeof define=="function"&&define.amd?define([],function(){return t}):(t._murmurHash3=r.murmurHash3,t.noConflict=function(){return r.murmurHash3=t._murmurHash3,t._murmurHash3=e,t.noConflict=e,t},r.murmurHash3=t)})(er)});var ts=wr((jm,es)=>{es.exports=Qo()});var zr=wr((Zm,ns)=>{"use strict";ns.exports=class{constructor(){this._bitArrays=[],this._data=[],this._length=0,this._changedLength=!1,this._changedData=!1}set(e,t){let n=this._internalPositionFor(e,!1);if(t===void 0)n!==-1&&(this._unsetInternalPos(n),this._unsetBit(e),this._changedLength=!0,this._changedData=!0);else{let i=!1;n===-1?(n=this._data.length,this._setBit(e),this._changedData=!0):i=!0,this._setInternalPos(n,e,t,i),this._changedLength=!0}}unset(e){this.set(e,void 0)}get(e){this._sortData();let t=this._internalPositionFor(e,!0);if(t!==-1)return this._data[t][1]}push(e){return this.set(this.length,e),this.length}get length(){if(this._sortData(),this._changedLength){let e=this._data[this._data.length-1];this._length=e?e[0]+1:0,this._changedLength=!1}return this._length}forEach(e){let t=0;for(;t<this.length;)e(this.get(t),t,this),t++}map(e){let t=0,n=new Array(this.length);for(;t<this.length;)n[t]=e(this.get(t),t,this),t++;return n}reduce(e,t){let n=0,i=t;for(;n<this.length;){let o=this.get(n);i=e(i,o,n),n++}return i}find(e){let t=0,n,i;for(;t<this.length&&!n;)i=this.get(t),n=e(i),t++;return n?i:void 0}_internalPositionFor(e,t){let n=this._bytePosFor(e,t);if(n>=this._bitArrays.length)return-1;let i=this._bitArrays[n],o=e-n*7;if(!((i&1<<o)>0))return-1;let a=this._bitArrays.slice(0,n).reduce(Bf,0),c=~(4294967295<<o+1),h=rs(i&c);return a+h-1}_bytePosFor(e,t){let n=Math.floor(e/7),i=n+1;for(;!t&&this._bitArrays.length<i;)this._bitArrays.push(0);return n}_setBit(e){let t=this._bytePosFor(e,!1);this._bitArrays[t]|=1<<e-t*7}_unsetBit(e){let t=this._bytePosFor(e,!1);this._bitArrays[t]&=~(1<<e-t*7)}_setInternalPos(e,t,n,i){let o=this._data,s=[t,n];if(i)this._sortData(),o[e]=s;else{if(o.length)if(o[o.length-1][0]>=t)o.push(s);else if(o[0][0]<=t)o.unshift(s);else{let a=Math.round(o.length/2);this._data=o.slice(0,a).concat(s).concat(o.slice(a))}else this._data.push(s);this._changedData=!0,this._changedLength=!0}}_unsetInternalPos(e){this._data.splice(e,1)}_sortData(){this._changedData&&this._data.sort(If),this._changedData=!1}bitField(){let e=[],t=8,n=0,i=0,o,s=this._bitArrays.slice();for(;s.length||n;){n===0&&(o=s.shift(),n=7);let c=Math.min(n,t),h=~(255<<c),f=o&h;i|=f<<8-t,o=o>>>c,n-=c,t-=c,(!t||!n&&!s.length)&&(e.push(i),i=0,t=8)}for(var a=e.length-1;a>0&&e[a]===0;a--)e.pop();return e}compactArray(){return this._sortData(),this._data.map(Af)}};function Bf(r,e){return r+rs(e)}function rs(r){let e=r;return e=e-(e>>1&1431655765),e=(e&858993459)+(e>>2&858993459),(e+(e>>4)&252645135)*16843009>>24}function If(r,e){return r[0]-e[0]}function Af(r){return r[1]}});var Ga=wr((vw,Ni)=>{"use strict";var Ql=Object.prototype.hasOwnProperty,Z="~";function cr(){}Object.create&&(cr.prototype=Object.create(null),new cr().__proto__||(Z=!1));function eh(r,e,t){this.fn=r,this.context=e,this.once=t||!1}function qa(r,e,t,n,i){if(typeof t!="function")throw new TypeError("The listener must be a function");var o=new eh(t,n||r,i),s=Z?Z+e:e;return r._events[s]?r._events[s].fn?r._events[s]=[r._events[s],o]:r._events[s].push(o):(r._events[s]=o,r._eventsCount++),r}function hn(r,e){--r._eventsCount===0?r._events=new cr:delete r._events[e]}function X(){this._events=new cr,this._eventsCount=0}X.prototype.eventNames=function(){var e=[],t,n;if(this._eventsCount===0)return e;for(n in t=this._events)Ql.call(t,n)&&e.push(Z?n.slice(1):n);return Object.getOwnPropertySymbols?e.concat(Object.getOwnPropertySymbols(t)):e};X.prototype.listeners=function(e){var t=Z?Z+e:e,n=this._events[t];if(!n)return[];if(n.fn)return[n.fn];for(var i=0,o=n.length,s=new Array(o);i<o;i++)s[i]=n[i].fn;return s};X.prototype.listenerCount=function(e){var t=Z?Z+e:e,n=this._events[t];return n?n.fn?1:n.length:0};X.prototype.emit=function(e,t,n,i,o,s){var a=Z?Z+e:e;if(!this._events[a])return!1;var c=this._events[a],h=arguments.length,f,l;if(c.fn){switch(c.once&&this.removeListener(e,c.fn,void 0,!0),h){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,t),!0;case 3:return c.fn.call(c.context,t,n),!0;case 4:return c.fn.call(c.context,t,n,i),!0;case 5:return c.fn.call(c.context,t,n,i,o),!0;case 6:return c.fn.call(c.context,t,n,i,o,s),!0}for(l=1,f=new Array(h-1);l<h;l++)f[l-1]=arguments[l];c.fn.apply(c.context,f)}else{var y=c.length,u;for(l=0;l<y;l++)switch(c[l].once&&this.removeListener(e,c[l].fn,void 0,!0),h){case 1:c[l].fn.call(c[l].context);break;case 2:c[l].fn.call(c[l].context,t);break;case 3:c[l].fn.call(c[l].context,t,n);break;case 4:c[l].fn.call(c[l].context,t,n,i);break;default:if(!f)for(u=1,f=new Array(h-1);u<h;u++)f[u-1]=arguments[u];c[l].fn.apply(c[l].context,f)}}return!0};X.prototype.on=function(e,t,n){return qa(this,e,t,n,!1)};X.prototype.once=function(e,t,n){return qa(this,e,t,n,!0)};X.prototype.removeListener=function(e,t,n,i){var o=Z?Z+e:e;if(!this._events[o])return this;if(!t)return hn(this,o),this;var s=this._events[o];if(s.fn)s.fn===t&&(!i||s.once)&&(!n||s.context===n)&&hn(this,o);else{for(var a=0,c=[],h=s.length;a<h;a++)(s[a].fn!==t||i&&!s[a].once||n&&s[a].context!==n)&&c.push(s[a]);c.length?this._events[o]=c.length===1?c[0]:c:hn(this,o)}return this};X.prototype.removeAllListeners=function(e){var t;return e?(t=Z?Z+e:e,this._events[t]&&hn(this,t)):(this._events=new cr,this._eventsCount=0),this};X.prototype.off=X.prototype.removeListener;X.prototype.addListener=X.prototype.on;X.prefixed=Z;X.EventEmitter=X;typeof Ni<"u"&&(Ni.exports=X)});var rd={};W(rd,{globSource:()=>kc,unixfs:()=>td,urlSource:()=>Sc});function Nc(r){return r[Symbol.asyncIterator]!=null}function Tc(r){if(Nc(r))return(async()=>{for await(let e of r)return e})();for(let e of r)return e}var xr=Tc;function Dc(r){return r[Symbol.asyncIterator]!=null}function Lc(r,e=1){return e=Number(e),Dc(r)?(async function*(){let t=[];if(e<1&&(e=1),e!==Math.round(e))throw new Error("Batch size must be an integer");for await(let n of r)for(t.push(n);t.length>=e;)yield t.slice(0,e),t=t.slice(e);for(;t.length>0;)yield t.slice(0,e),t=t.slice(e)})():(function*(){let t=[];if(e<1&&(e=1),e!==Math.round(e))throw new Error("Batch size must be an integer");for(let n of r)for(t.push(n);t.length>=e;)yield t.slice(0,e),t=t.slice(e);for(;t.length>0;)yield t.slice(0,e),t=t.slice(e)})()}var br=Lc;async function*Pt(r,e=1){for await(let t of br(r,e)){let n=t.map(async i=>i().then(o=>({ok:!0,value:o}),o=>({ok:!1,err:o})));for(let i=0;i<n.length;i++){let o=await n[i];if(o.ok)yield o.value;else throw o.err}}}function ge(r=0){return new Uint8Array(r)}function ne(r=0){return new Uint8Array(r)}function Ie(r,e){e==null&&(e=r.reduce((i,o)=>i+o.length,0));let t=ne(e),n=0;for(let i of r)t.set(i,n),n+=i.length;return t}function _r(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}var Wi=Symbol.for("@achingbrain/uint8arraylist");function Gi(r,e){if(e==null||e<0)throw new RangeError("index is out of bounds");let t=0;for(let n of r){let i=t+n.byteLength;if(e<i)return{buf:n,index:e-t};t=i}throw new RangeError("index is out of bounds")}function kr(r){return!!r?.[Wi]}var st=class r{bufs;length;[Wi]=!0;constructor(...e){this.bufs=[],this.length=0,e.length>0&&this.appendAll(e)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...e){this.appendAll(e)}appendAll(e){let t=0;for(let n of e)if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.push(n);else if(kr(n))t+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}prepend(...e){this.prependAll(e)}prependAll(e){let t=0;for(let n of e.reverse())if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.unshift(n);else if(kr(n))t+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}get(e){let t=Gi(this.bufs,e);return t.buf[t.index]}set(e,t){let n=Gi(this.bufs,e);n.buf[n.index]=t}write(e,t=0){if(e instanceof Uint8Array)for(let n=0;n<e.length;n++)this.set(t+n,e[n]);else if(kr(e))for(let n=0;n<e.length;n++)this.set(t+n,e.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(e){if(e=Math.trunc(e),!(Number.isNaN(e)||e<=0)){if(e===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(e>=this.bufs[0].byteLength)e-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(e),this.length-=e;break}}}slice(e,t){let{bufs:n,length:i}=this._subList(e,t);return Ie(n,i)}subarray(e,t){let{bufs:n,length:i}=this._subList(e,t);return n.length===1?n[0]:Ie(n,i)}sublist(e,t){let{bufs:n,length:i}=this._subList(e,t),o=new r;return o.length=i,o.bufs=[...n],o}_subList(e,t){if(e=e??0,t=t??this.length,e<0&&(e=this.length+e),t<0&&(t=this.length+t),e<0||t>this.length)throw new RangeError("index is out of bounds");if(e===t)return{bufs:[],length:0};if(e===0&&t===this.length)return{bufs:this.bufs,length:this.length};let n=[],i=0;for(let o=0;o<this.bufs.length;o++){let s=this.bufs[o],a=i,c=a+s.byteLength;if(i=c,e>=c)continue;let h=e>=a&&e<c,f=t>a&&t<=c;if(h&&f){if(e===a&&t===c){n.push(s);break}let l=e-a;n.push(s.subarray(l,l+(t-e)));break}if(h){if(e===0){n.push(s);continue}n.push(s.subarray(e-a));continue}if(f){if(t===c){n.push(s);break}n.push(s.subarray(0,t-a));break}n.push(s)}return{bufs:n,length:t-e}}indexOf(e,t=0){if(!kr(e)&&!(e instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=e instanceof Uint8Array?e:e.subarray();if(t=Number(t??0),isNaN(t)&&(t=0),t<0&&(t=this.length+t),t<0&&(t=0),e.length===0)return t>this.length?this.length:t;let i=n.byteLength;if(i===0)throw new TypeError("search must be at least 1 byte long");let o=256,s=new Int32Array(o);for(let l=0;l<o;l++)s[l]=-1;for(let l=0;l<i;l++)s[n[l]]=l;let a=s,c=this.byteLength-n.byteLength,h=n.byteLength-1,f;for(let l=t;l<=c;l+=f){f=0;for(let y=h;y>=0;y--){let u=this.get(l+y);if(n[y]!==u){f=Math.max(1,y-a[u]);break}}if(f===0)return l}return-1}getInt8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getInt8(0)}setInt8(e,t){let n=ne(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,t),this.write(n,e)}getInt16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,t)}setInt16(e,t,n){let i=ge(2);new DataView(i.buffer,i.byteOffset,i.byteLength).setInt16(0,t,n),this.write(i,e)}getInt32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,t)}setInt32(e,t,n){let i=ge(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setInt32(0,t,n),this.write(i,e)}getBigInt64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,t)}setBigInt64(e,t,n){let i=ge(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setBigInt64(0,t,n),this.write(i,e)}getUint8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getUint8(0)}setUint8(e,t){let n=ne(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,t),this.write(n,e)}getUint16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,t)}setUint16(e,t,n){let i=ge(2);new DataView(i.buffer,i.byteOffset,i.byteLength).setUint16(0,t,n),this.write(i,e)}getUint32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,t)}setUint32(e,t,n){let i=ge(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setUint32(0,t,n),this.write(i,e)}getBigUint64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,t)}setBigUint64(e,t,n){let i=ge(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setBigUint64(0,t,n),this.write(i,e)}getFloat32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,t)}setFloat32(e,t,n){let i=ge(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setFloat32(0,t,n),this.write(i,e)}getFloat64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,t)}setFloat64(e,t,n){let i=ge(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setFloat64(0,t,n),this.write(i,e)}equals(e){if(e==null||!(e instanceof r)||e.bufs.length!==this.bufs.length)return!1;for(let t=0;t<this.bufs.length;t++)if(!_r(this.bufs[t],e.bufs[t]))return!1;return!0}static fromUint8Arrays(e,t){let n=new r;return n.bufs=e,t==null&&(t=e.reduce((i,o)=>i+o.byteLength,0)),n.length=t,n}};var zc=262144,Ut=(r={})=>{let e=r.chunkSize??zc;return async function*(n){let i=new st,o=0,s=!1;for await(let a of n)for(i.append(a),o+=a.length;o>=e;)if(yield i.slice(0,e),s=!0,e===i.length)i=new st,o=0;else{let c=new st;c.append(i.sublist(e)),i=c,o-=e}(!s||o>0)&&(yield i.subarray(0,o))}};var O={};W(O,{code:()=>q,createLink:()=>po,createNode:()=>ho,decode:()=>$,encode:()=>T,name:()=>Lu,prepare:()=>P,validate:()=>Vn});var Fn={};W(Fn,{base32:()=>Ue,base32hex:()=>Wc,base32hexpad:()=>Xc,base32hexpadupper:()=>Jc,base32hexupper:()=>Kc,base32pad:()=>qc,base32padupper:()=>Gc,base32upper:()=>jc,base32z:()=>Zc});var at={};W(at,{coerce:()=>he,empty:()=>Ki,equals:()=>An,fromHex:()=>Pc,fromString:()=>Cn,isBinary:()=>Uc,toHex:()=>Fc,toString:()=>Nn});var Ki=new Uint8Array(0);function Fc(r){return r.reduce((e,t)=>e+t.toString(16).padStart(2,"0"),"")}function Pc(r){let e=r.match(/../g);return e!=null?new Uint8Array(e.map(t=>parseInt(t,16))):Ki}function An(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function he(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 Uc(r){return r instanceof ArrayBuffer||ArrayBuffer.isView(r)}function Cn(r){return new TextEncoder().encode(r)}function Nn(r){return new TextDecoder().decode(r)}function $c(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var i=0;i<r.length;i++){var o=r.charAt(i),s=o.charCodeAt(0);if(t[s]!==255)throw new TypeError(o+" is ambiguous");t[s]=i}var a=r.length,c=r.charAt(0),h=Math.log(a)/Math.log(256),f=Math.log(256)/Math.log(a);function l(d){if(d instanceof Uint8Array||(ArrayBuffer.isView(d)?d=new Uint8Array(d.buffer,d.byteOffset,d.byteLength):Array.isArray(d)&&(d=Uint8Array.from(d))),!(d instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(d.length===0)return"";for(var m=0,x=0,g=0,w=d.length;g!==w&&d[g]===0;)g++,m++;for(var b=(w-g)*f+1>>>0,S=new Uint8Array(b);g!==w;){for(var B=d[g],C=0,E=b-1;(B!==0||C<x)&&E!==-1;E--,C++)B+=256*S[E]>>>0,S[E]=B%a>>>0,B=B/a>>>0;if(B!==0)throw new Error("Non-zero carry");x=C,g++}for(var L=b-x;L!==b&&S[L]===0;)L++;for(var le=c.repeat(m);L<b;++L)le+=r.charAt(S[L]);return le}function y(d){if(typeof d!="string")throw new TypeError("Expected String");if(d.length===0)return new Uint8Array;var m=0;if(d[m]!==" "){for(var x=0,g=0;d[m]===c;)x++,m++;for(var w=(d.length-m)*h+1>>>0,b=new Uint8Array(w);d[m];){var S=t[d.charCodeAt(m)];if(S===255)return;for(var B=0,C=w-1;(S!==0||B<g)&&C!==-1;C--,B++)S+=a*b[C]>>>0,b[C]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");g=B,m++}if(d[m]!==" "){for(var E=w-g;E!==w&&b[E]===0;)E++;for(var L=new Uint8Array(x+(w-E)),le=x;E!==w;)L[le++]=b[E++];return L}}}function u(d){var m=y(d);if(m)return m;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:y,decode:u}}var Rc=$c,Mc=Rc,Xi=Mc;var Tn=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},Dn=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){this.name=e,this.prefix=t;let i=t.codePointAt(0);if(i===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=i,this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return Ji(this,e)}},Ln=class{decoders;constructor(e){this.decoders=e}or(e){return Ji(this,e)}decode(e){let t=e[0],n=this.decoders[t];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Ji(r,e){return new Ln({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var zn=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,i){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=i,this.encoder=new Tn(e,t,n),this.decoder=new Dn(e,t,i)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function ct({name:r,prefix:e,encode:t,decode:n}){return new zn(r,e,t,n)}function Pe({name:r,prefix:e,alphabet:t}){let{encode:n,decode:i}=Xi(t,r);return ct({prefix:e,name:r,encode:n,decode:o=>he(i(o))})}function Oc(r,e,t,n){let i=r.length;for(;r[i-1]==="=";)--i;let o=new Uint8Array(i*t/8|0),s=0,a=0,c=0;for(let h=0;h<i;++h){let f=e[r[h]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<t|f,s+=t,s>=8&&(s-=8,o[c++]=255&a>>s)}if(s>=t||(255&a<<8-s)!==0)throw new SyntaxError("Unexpected end of data");return o}function Vc(r,e,t){let n=e[e.length-1]==="=",i=(1<<t)-1,o="",s=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],s+=8;s>t;)s-=t,o+=e[i&a>>s];if(s!==0&&(o+=e[i&a<<t-s]),n)for(;(o.length*t&7)!==0;)o+="=";return o}function Hc(r){let e={};for(let t=0;t<r.length;++t)e[r[t]]=t;return e}function F({name:r,prefix:e,bitsPerChar:t,alphabet:n}){let i=Hc(n);return ct({prefix:e,name:r,encode(o){return Vc(o,n,t)},decode(o){return Oc(o,i,t,r)}})}var Ue=F({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),jc=F({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),qc=F({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Gc=F({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Wc=F({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Kc=F({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Xc=F({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Jc=F({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Zc=F({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Pn={};W(Pn,{base36:()=>$t,base36upper:()=>Yc});var $t=Pe({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Yc=Pe({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Un={};W(Un,{base58btc:()=>de,base58flickr:()=>Qc});var de=Pe({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Qc=Pe({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var eu=Qi,Zi=128,tu=127,ru=~tu,nu=Math.pow(2,31);function Qi(r,e,t){e=e||[],t=t||0;for(var n=t;r>=nu;)e[t++]=r&255|Zi,r/=128;for(;r&ru;)e[t++]=r&255|Zi,r>>>=7;return e[t]=r|0,Qi.bytes=t-n+1,e}var iu=$n,ou=128,Yi=127;function $n(r,n){var t=0,n=n||0,i=0,o=n,s,a=r.length;do{if(o>=a)throw $n.bytes=0,new RangeError("Could not decode varint");s=r[o++],t+=i<28?(s&Yi)<<i:(s&Yi)*Math.pow(2,i),i+=7}while(s>=ou);return $n.bytes=o-n,t}var su=Math.pow(2,7),au=Math.pow(2,14),cu=Math.pow(2,21),uu=Math.pow(2,28),fu=Math.pow(2,35),lu=Math.pow(2,42),hu=Math.pow(2,49),du=Math.pow(2,56),pu=Math.pow(2,63),mu=function(r){return r<su?1:r<au?2:r<cu?3:r<uu?4:r<fu?5:r<lu?6:r<hu?7:r<du?8:r<pu?9:10},yu={encode:eu,decode:iu,encodingLength:mu},gu=yu,Rt=gu;function Mt(r,e=0){return[Rt.decode(r,e),Rt.decode.bytes]}function ut(r,e,t=0){return Rt.encode(r,e,t),e}function ft(r){return Rt.encodingLength(r)}function ht(r,e){let t=e.byteLength,n=ft(r),i=n+ft(t),o=new Uint8Array(i+t);return ut(r,o,0),ut(t,o,n),o.set(e,i),new lt(r,t,e,o)}function Er(r){let e=he(r),[t,n]=Mt(e),[i,o]=Mt(e.subarray(n)),s=e.subarray(n+o);if(s.byteLength!==i)throw new Error("Incorrect length");return new lt(t,i,s,e)}function eo(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&An(r.bytes,t.bytes)}}var lt=class{code;size;digest;bytes;constructor(e,t,n,i){this.code=e,this.size=t,this.digest=n,this.bytes=i}};function to(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return xu(t,Rn(r),e??de.encoder);default:return bu(t,Rn(r),e??Ue.encoder)}}var ro=new WeakMap;function Rn(r){let e=ro.get(r);if(e==null){let t=new Map;return ro.set(r,t),t}return e}var A=class r{code;version;multihash;bytes;"/";constructor(e,t,n,i){this.code=t,this.version=e,this.multihash=n,this.bytes=i,this["/"]=i}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:e,multihash:t}=this;if(e!==Ot)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==_u)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:e,digest:t}=this.multihash,n=ht(e,t);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&eo(e.multihash,n.multihash)}toString(e){return to(this,e)}toJSON(){return{"/":to(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:i,multihash:o,bytes:s}=t;return new r(n,i,o,s??no(n,i,o.bytes))}else if(t[ku]===!0){let{version:n,multihash:i,code:o}=t,s=Er(i);return r.create(n,o,s)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==Ot)throw new Error(`Version 0 CID must use dag-pb (code: ${Ot}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let i=no(e,t,n.bytes);return new r(e,t,n,i)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Ot,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,i=he(e.subarray(n,n+t.multihashSize));if(i.byteLength!==t.multihashSize)throw new Error("Incorrect length");let o=i.subarray(t.multihashSize-t.digestSize),s=new lt(t.multihashCode,t.digestSize,o,i);return[t.version===0?r.createV0(s):r.createV1(t.codec,s),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[l,y]=Mt(e.subarray(t));return t+=y,l},i=n(),o=Ot;if(i===18?(i=0,t=0):o=n(),i!==0&&i!==1)throw new RangeError(`Invalid CID version ${i}`);let s=t,a=n(),c=n(),h=t+c,f=h-s;return{version:i,codec:o,multihashCode:a,digestSize:c,multihashSize:f,size:h}}static parse(e,t){let[n,i]=wu(e,t),o=r.decode(i);if(o.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Rn(o).set(n,e),o}};function wu(r,e){switch(r[0]){case"Q":{let t=e??de;return[de.prefix,t.decode(`${de.prefix}${r}`)]}case de.prefix:{let t=e??de;return[de.prefix,t.decode(r)]}case Ue.prefix:{let t=e??Ue;return[Ue.prefix,t.decode(r)]}case $t.prefix:{let t=e??$t;return[$t.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function xu(r,e,t){let{prefix:n}=t;if(n!==de.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let i=e.get(n);if(i==null){let o=t.encode(r).slice(1);return e.set(n,o),o}else return i}function bu(r,e,t){let{prefix:n}=t,i=e.get(n);if(i==null){let o=t.encode(r);return e.set(n,o),o}else return i}var Ot=112,_u=18;function no(r,e,t){let n=ft(r),i=n+ft(e),o=new Uint8Array(i+t.byteLength);return ut(r,o,0),ut(e,o,n),o.set(t,i),o}var ku=Symbol.for("@ipld/js-cid/CID");var Su=new TextDecoder;function Mn(r,e){let t=0;for(let n=0;;n+=7){if(n>=64)throw new Error("protobuf: varint overflow");if(e>=r.length)throw new Error("protobuf: unexpected end of data");let i=r[e++];if(t+=n<28?(i&127)<<n:(i&127)*2**n,i<128)break}return[t,e]}function vr(r,e){let t;[t,e]=Mn(r,e);let n=e+t;if(t<0||n<0)throw new Error("protobuf: invalid length");if(n>r.length)throw new Error("protobuf: unexpected end of data");return[r.subarray(e,n),n]}function io(r,e){let t;return[t,e]=Mn(r,e),[t&7,t>>3,e]}function Eu(r){let e={},t=r.length,n=0;for(;n<t;){let i,o;if([i,o,n]=io(r,n),o===1){if(e.Hash)throw new Error("protobuf: (PBLink) duplicate Hash section");if(i!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${i}) for Hash`);if(e.Name!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Name before Hash");if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Hash");[e.Hash,n]=vr(r,n)}else if(o===2){if(e.Name!==void 0)throw new Error("protobuf: (PBLink) duplicate Name section");if(i!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${i}) for Name`);if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Name");let s;[s,n]=vr(r,n),e.Name=Su.decode(s)}else if(o===3){if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) duplicate Tsize section");if(i!==0)throw new Error(`protobuf: (PBLink) wrong wireType (${i}) for Tsize`);[e.Tsize,n]=Mn(r,n)}else throw new Error(`protobuf: (PBLink) invalid fieldNumber, expected 1, 2 or 3, got ${o}`)}if(n>t)throw new Error("protobuf: (PBLink) unexpected end of data");return e}function oo(r){let e=r.length,t=0,n,i=!1,o;for(;t<e;){let a,c;if([a,c,t]=io(r,t),a!==2)throw new Error(`protobuf: (PBNode) invalid wireType, expected 2, got ${a}`);if(c===1){if(o)throw new Error("protobuf: (PBNode) duplicate Data section");[o,t]=vr(r,t),n&&(i=!0)}else if(c===2){if(i)throw new Error("protobuf: (PBNode) duplicate Links section");n||(n=[]);let h;[h,t]=vr(r,t),n.push(Eu(h))}else throw new Error(`protobuf: (PBNode) invalid fieldNumber, expected 1 or 2, got ${c}`)}if(t>e)throw new Error("protobuf: (PBNode) unexpected end of data");let s={};return o&&(s.Data=o),s.Links=n||[],s}var ao=new TextEncoder,so=2**32,vu=2**31;function Bu(r,e){let t=e.length;if(typeof r.Tsize=="number"){if(r.Tsize<0)throw new Error("Tsize cannot be negative");if(!Number.isSafeInteger(r.Tsize))throw new Error("Tsize too large for encoding");t=Vt(e,t,r.Tsize)-1,e[t]=24}if(typeof r.Name=="string"){let n=ao.encode(r.Name);t-=n.length,e.set(n,t),t=Vt(e,t,n.length)-1,e[t]=18}return r.Hash&&(t-=r.Hash.length,e.set(r.Hash,t),t=Vt(e,t,r.Hash.length)-1,e[t]=10),e.length-t}function co(r){let e=Au(r),t=new Uint8Array(e),n=e;if(r.Data&&(n-=r.Data.length,t.set(r.Data,n),n=Vt(t,n,r.Data.length)-1,t[n]=10),r.Links)for(let i=r.Links.length-1;i>=0;i--){let o=Bu(r.Links[i],t.subarray(0,n));n-=o,n=Vt(t,n,o)-1,t[n]=18}return t}function Iu(r){let e=0;if(r.Hash){let t=r.Hash.length;e+=1+t+pt(t)}if(typeof r.Name=="string"){let t=ao.encode(r.Name).length;e+=1+t+pt(t)}return typeof r.Tsize=="number"&&(e+=1+pt(r.Tsize)),e}function Au(r){let e=0;if(r.Data){let t=r.Data.length;e+=1+t+pt(t)}if(r.Links)for(let t of r.Links){let n=Iu(t);e+=1+n+pt(n)}return e}function Vt(r,e,t){e-=pt(t);let n=e;for(;t>=vu;)r[e++]=t&127|128,t/=128;for(;t>=128;)r[e++]=t&127|128,t>>>=7;return r[e]=t,n}function pt(r){return r%2===0&&r++,Math.floor((Cu(r)+6)/7)}function Cu(r){let e=0;return r>=so&&(r=Math.floor(r/so),e=32),r>=65536&&(r>>>=16,e+=16),r>=256&&(r>>>=8,e+=8),e+Nu[r]}var Nu=[0,1,2,2,3,3,3,3,4,4,4,4,4,4,4,4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8];var Tu=["Data","Links"],Du=["Hash","Name","Tsize"],On=new TextEncoder;function fo(r,e){if(r===e)return 0;let t=r.Name?On.encode(r.Name):[],n=e.Name?On.encode(e.Name):[],i=t.length,o=n.length;for(let s=0,a=Math.min(i,o);s<a;++s)if(t[s]!==n[s]){i=t[s],o=n[s];break}return i<o?-1:o<i?1:0}function uo(r,e){return!Object.keys(r).some(t=>!e.includes(t))}function lo(r){if(typeof r.asCID=="object"){let t=A.asCID(r);if(!t)throw new TypeError("Invalid DAG-PB form");return{Hash:t}}if(typeof r!="object"||Array.isArray(r))throw new TypeError("Invalid DAG-PB form");let e={};if(r.Hash){let t=A.asCID(r.Hash);try{t||(typeof r.Hash=="string"?t=A.parse(r.Hash):r.Hash instanceof Uint8Array&&(t=A.decode(r.Hash)))}catch(n){throw new TypeError(`Invalid DAG-PB form: ${n.message}`)}t&&(e.Hash=t)}if(!e.Hash)throw new TypeError("Invalid DAG-PB form");return typeof r.Name=="string"&&(e.Name=r.Name),typeof r.Tsize=="number"&&(e.Tsize=r.Tsize),e}function P(r){if((r instanceof Uint8Array||typeof r=="string")&&(r={Data:r}),typeof r!="object"||Array.isArray(r))throw new TypeError("Invalid DAG-PB form");let e={};if(r.Data!==void 0)if(typeof r.Data=="string")e.Data=On.encode(r.Data);else if(r.Data instanceof Uint8Array)e.Data=r.Data;else throw new TypeError("Invalid DAG-PB form");if(r.Links!==void 0)if(Array.isArray(r.Links))e.Links=r.Links.map(lo),e.Links.sort(fo);else throw new TypeError("Invalid DAG-PB form");else e.Links=[];return e}function Vn(r){if(!r||typeof r!="object"||Array.isArray(r)||r instanceof Uint8Array||r["/"]&&r["/"]===r.bytes)throw new TypeError("Invalid DAG-PB form");if(!uo(r,Tu))throw new TypeError("Invalid DAG-PB form (extraneous properties)");if(r.Data!==void 0&&!(r.Data instanceof Uint8Array))throw new TypeError("Invalid DAG-PB form (Data must be bytes)");if(!Array.isArray(r.Links))throw new TypeError("Invalid DAG-PB form (Links must be a list)");for(let e=0;e<r.Links.length;e++){let t=r.Links[e];if(!t||typeof t!="object"||Array.isArray(t)||t instanceof Uint8Array||t["/"]&&t["/"]===t.bytes)throw new TypeError("Invalid DAG-PB form (bad link)");if(!uo(t,Du))throw new TypeError("Invalid DAG-PB form (extraneous properties on link)");if(t.Hash===void 0)throw new TypeError("Invalid DAG-PB form (link must have a Hash)");if(t.Hash==null||!t.Hash["/"]||t.Hash["/"]!==t.Hash.bytes)throw new TypeError("Invalid DAG-PB form (link Hash must be a CID)");if(t.Name!==void 0&&typeof t.Name!="string")throw new TypeError("Invalid DAG-PB form (link Name must be a string)");if(t.Tsize!==void 0){if(typeof t.Tsize!="number"||t.Tsize%1!==0)throw new TypeError("Invalid DAG-PB form (link Tsize must be an integer)");if(t.Tsize<0)throw new TypeError("Invalid DAG-PB form (link Tsize cannot be negative)")}if(e>0&&fo(t,r.Links[e-1])===-1)throw new TypeError("Invalid DAG-PB form (links must be sorted by Name bytes)")}}function ho(r,e=[]){return P({Data:r,Links:e})}function po(r,e,t){return lo({Hash:t,Name:r,Tsize:e})}function mo(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var Lu="dag-pb",q=112;function T(r){Vn(r);let e={};return r.Links&&(e.Links=r.Links.map(t=>{let n={};return t.Hash&&(n.Hash=t.Hash.bytes),t.Name!==void 0&&(n.Name=t.Name),t.Tsize!==void 0&&(n.Tsize=t.Tsize),n})),r.Data&&(e.Data=r.Data),co(e)}function $(r){let e=mo(r),t=oo(e),n={};return t.Data&&(n.Data=t.Data),t.Links&&(n.Links=t.Links.map(i=>{let o={};try{o.Hash=A.decode(i.Hash)}catch{}if(!o.Hash)throw new Error("Invalid Hash field found in link, expected CID");return i.Name!==void 0&&(o.Name=i.Name),i.Tsize!==void 0&&(o.Tsize=i.Tsize),o})),n}var Ht=class r extends Error{static name="InvalidTypeError";static code="ERR_INVALID_TYPE";name=r.name;code=r.code;constructor(e="Invalid type"){super(e)}},Br=class r extends Error{static name="InvalidUnixFSMessageError";static code="ERR_INVALID_MESSAGE";name=r.name;code=r.code;constructor(e="Invalid message"){super(e)}};var zu=Math.pow(2,7),Fu=Math.pow(2,14),Pu=Math.pow(2,21),yo=Math.pow(2,28),go=Math.pow(2,35),wo=Math.pow(2,42),xo=Math.pow(2,49),J=128,$e=127;function jt(r){if(r<zu)return 1;if(r<Fu)return 2;if(r<Pu)return 3;if(r<yo)return 4;if(r<go)return 5;if(r<wo)return 6;if(r<xo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function bo(r,e,t=0){switch(jt(r)){case 8:e[t++]=r&255|J,r/=128;case 7:e[t++]=r&255|J,r/=128;case 6:e[t++]=r&255|J,r/=128;case 5:e[t++]=r&255|J,r/=128;case 4:e[t++]=r&255|J,r>>>=7;case 3:e[t++]=r&255|J,r>>>=7;case 2:e[t++]=r&255|J,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function _o(r,e){let t=r[e],n=0;if(n+=t&$e,t<J||(t=r[e+1],n+=(t&$e)<<7,t<J)||(t=r[e+2],n+=(t&$e)<<14,t<J)||(t=r[e+3],n+=(t&$e)<<21,t<J)||(t=r[e+4],n+=(t&$e)*yo,t<J)||(t=r[e+5],n+=(t&$e)*go,t<J)||(t=r[e+6],n+=(t&$e)*wo,t<J)||(t=r[e+7],n+=(t&$e)*xo,t<J))return n;throw new RangeError("Could not decode varint")}var Hn=new Float32Array([-0]),Re=new Uint8Array(Hn.buffer);function ko(r,e,t){Hn[0]=r,e[t]=Re[0],e[t+1]=Re[1],e[t+2]=Re[2],e[t+3]=Re[3]}function So(r,e){return Re[0]=r[e],Re[1]=r[e+1],Re[2]=r[e+2],Re[3]=r[e+3],Hn[0]}var jn=new Float64Array([-0]),K=new Uint8Array(jn.buffer);function Eo(r,e,t){jn[0]=r,e[t]=K[0],e[t+1]=K[1],e[t+2]=K[2],e[t+3]=K[3],e[t+4]=K[4],e[t+5]=K[5],e[t+6]=K[6],e[t+7]=K[7]}function vo(r,e){return K[0]=r[e],K[1]=r[e+1],K[2]=r[e+2],K[3]=r[e+3],K[4]=r[e+4],K[5]=r[e+5],K[6]=r[e+6],K[7]=r[e+7],jn[0]}var Uu=BigInt(Number.MAX_SAFE_INTEGER),$u=BigInt(Number.MIN_SAFE_INTEGER),ie=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return qe;if(e<Uu&&e>$u)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,i=e-(n<<32n);return t&&(n=~n|0n,i=~i|0n,++i>Bo&&(i=0n,++n>Bo&&(n=0n))),new r(Number(i),Number(n))}static fromNumber(e){if(e===0)return qe;let t=e<0;t&&(e=-e);let n=e>>>0,i=(e-n)/4294967296>>>0;return t&&(i=~i>>>0,n=~n>>>0,++n>4294967295&&(n=0,++i>4294967295&&(i=0))),new r(n,i)}static from(e){return typeof e=="number"?r.fromNumber(e):typeof e=="bigint"?r.fromBigInt(e):typeof e=="string"?r.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new r(e.low>>>0,e.high>>>0):qe}},qe=new ie(0,0);qe.toBigInt=function(){return 0n};qe.zzEncode=qe.zzDecode=function(){return this};qe.length=function(){return 1};var Bo=4294967296n;function Io(r){let e=0,t=0;for(let n=0;n<r.length;++n)t=r.charCodeAt(n),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,e+=4):e+=3;return e}function Ao(r,e,t){if(t-e<1)return"";let i,o=[],s=0,a;for(;e<t;)a=r[e++],a<128?o[s++]=a:a>191&&a<224?o[s++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,o[s++]=55296+(a>>10),o[s++]=56320+(a&1023)):o[s++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&63,s>8191&&((i??(i=[])).push(String.fromCharCode.apply(String,o)),s=0);return i!=null?(s>0&&i.push(String.fromCharCode.apply(String,o.slice(0,s))),i.join("")):String.fromCharCode.apply(String,o.slice(0,s))}function qn(r,e,t){let n=t,i,o;for(let s=0;s<r.length;++s)i=r.charCodeAt(s),i<128?e[t++]=i:i<2048?(e[t++]=i>>6|192,e[t++]=i&63|128):(i&64512)===55296&&((o=r.charCodeAt(s+1))&64512)===56320?(i=65536+((i&1023)<<10)+(o&1023),++s,e[t++]=i>>18|240,e[t++]=i>>12&63|128,e[t++]=i>>6&63|128,e[t++]=i&63|128):(e[t++]=i>>12|224,e[t++]=i>>6&63|128,e[t++]=i&63|128);return t-n}function we(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function Ir(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var Gn=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,we(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw we(this,4);return Ir(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw we(this,4);return Ir(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw we(this,4);let e=So(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw we(this,4);let e=vo(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,n=this.pos+e;if(n>this.len)throw we(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return Ao(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw we(this,e);this.pos+=e}else do if(this.pos>=this.len)throw we(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new ie(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw we(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw we(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw we(this,8);let e=Ir(this.buf,this.pos+=4),t=Ir(this.buf,this.pos+=4);return new ie(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=_o(this.buf,this.pos);return this.pos+=jt(e),e}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Wn(r){return new Gn(r instanceof Uint8Array?r:r.subarray())}function qt(r,e,t){let n=Wn(r);return e.decode(n,void 0,t)}var Kn={};W(Kn,{base10:()=>Ru});var Ru=Pe({prefix:"9",name:"base10",alphabet:"0123456789"});var Xn={};W(Xn,{base16:()=>Mu,base16upper:()=>Ou});var Mu=F({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Ou=F({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Jn={};W(Jn,{base2:()=>Vu});var Vu=F({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Zn={};W(Zn,{base256emoji:()=>Wu});var No=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}"),Hu=No.reduce((r,e,t)=>(r[t]=e,r),[]),ju=No.reduce((r,e,t)=>{let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);return r[n]=t,r},[]);function qu(r){return r.reduce((e,t)=>(e+=Hu[t],e),"")}function Gu(r){let e=[];for(let t of r){let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);let i=ju[n];if(i==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(i)}return new Uint8Array(e)}var Wu=ct({prefix:"\u{1F680}",name:"base256emoji",encode:qu,decode:Gu});var Yn={};W(Yn,{base64:()=>Gt,base64pad:()=>Ku,base64url:()=>Xu,base64urlpad:()=>Ju});var Gt=F({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Ku=F({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Xu=F({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Ju=F({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Qn={};W(Qn,{base8:()=>Zu});var Zu=F({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ei={};W(ei,{identity:()=>Yu});var Yu=ct({prefix:"\0",name:"identity",encode:r=>Nn(r),decode:r=>Cn(r)});var fp=new TextEncoder,Qu=new TextDecoder;var To=512;function Do(r){return JSON.parse(Qu.decode(r))}var Ae={};W(Ae,{code:()=>Q,decode:()=>rf,encode:()=>tf,name:()=>ef});var ef="raw",Q=85;function tf(r){return he(r)}function rf(r){return he(r)}var ni={};W(ni,{identity:()=>ri});var Lo=0,nf="identity",zo=he;function of(r,e){if(e?.truncate!=null&&e.truncate!==r.byteLength){if(e.truncate<0||e.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e.truncate)}return ht(Lo,zo(r))}var ri={code:Lo,name:nf,encode:zo,digest:of};var oi={};W(oi,{sha256:()=>oe,sha512:()=>af});var sf=20;function Ge({name:r,code:e,encode:t,minDigestLength:n,maxDigestLength:i}){return new ii(r,e,t,n,i)}var ii=class{name;code;encode;minDigestLength;maxDigestLength;constructor(e,t,n,i,o){this.name=e,this.code=t,this.encode=n,this.minDigestLength=i??sf,this.maxDigestLength=o}digest(e,t){if(t?.truncate!=null){if(t.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&t.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(e instanceof Uint8Array){let n=this.encode(e);return n instanceof Uint8Array?Fo(n,this.code,t?.truncate):n.then(i=>Fo(i,this.code,t?.truncate))}else throw Error("Unknown type, must be binary type")}};function Fo(r,e,t){if(t!=null&&t!==r.byteLength){if(t>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t)}return ht(e,r)}function Uo(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var oe=Ge({name:"sha2-256",code:18,encode:Uo("SHA-256")}),af=Ge({name:"sha2-512",code:19,encode:Uo("SHA-512")});var si={...ei,...Jn,...Qn,...Kn,...Xn,...Fn,...Pn,...Un,...Yn,...Zn},Sp={...oi,...ni};function Ro(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var $o=Ro("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),ai=Ro("ascii","a",r=>{let e="a";for(let t=0;t<r.length;t++)e+=String.fromCharCode(r[t]);return e},r=>{r=r.substring(1);let e=ne(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),cf={utf8:$o,"utf-8":$o,hex:si.base16,latin1:ai,ascii:ai,binary:ai,...si},Mo=cf;function M(r,e="utf8"){let t=Mo[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function ci(r){let e=r??8192,t=e>>>1,n,i=e;return function(s){if(s<1||s>t)return ne(s);i+s>e&&(n=ne(e),i=0);let a=n.subarray(i,i+=s);return(i&7)!==0&&(i=(i|7)+1),a}}var We=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function ui(){}var li=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},uf=ci();function ff(r){return globalThis.Buffer!=null?ne(r):uf(r)}var Kt=class{len;head;tail;states;constructor(){this.len=0,this.head=new We(ui,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new We(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new hi((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(Ar,10,ie.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=ie.fromBigInt(e);return this._push(Ar,t.length(),t)}uint64Number(e){return this._push(bo,jt(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=ie.fromBigInt(e).zzEncode();return this._push(Ar,t.length(),t)}sint64Number(e){let t=ie.fromNumber(e).zzEncode();return this._push(Ar,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(fi,1,e?1:0)}fixed32(e){return this._push(Wt,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=ie.fromBigInt(e);return this._push(Wt,4,t.lo)._push(Wt,4,t.hi)}fixed64Number(e){let t=ie.fromNumber(e);return this._push(Wt,4,t.lo)._push(Wt,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push(ko,4,e)}double(e){return this._push(Eo,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(fi,1,0):this.uint32(t)._push(hf,t,e)}string(e){let t=Io(e);return t!==0?this.uint32(t)._push(qn,t,e):this._push(fi,1,0)}fork(){return this.states=new li(this),this.head=this.tail=new We(ui,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 We(ui,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=e.next,this.tail=t,this.len+=n),this}finish(){let e=this.head.next,t=ff(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function fi(r,e,t){e[t]=r&255}function lf(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var hi=class extends We{next;constructor(e,t){super(lf,e,t),this.next=void 0}};function Ar(r,e,t){for(;r.hi!==0;)e[t++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)e[t++]=r.lo&127|128,r.lo=r.lo>>>7;e[t++]=r.lo}function Wt(r,e,t){e[t]=r&255,e[t+1]=r>>>8&255,e[t+2]=r>>>16&255,e[t+3]=r>>>24}function hf(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(Kt.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(df,e,r),this},Kt.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(pf,e,r),this});function df(r,e,t){e.set(r,t)}function pf(r,e,t){r.length<40?qn(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(M(r),t)}function di(){return new Kt}function Xt(r,e){let t=di();return e.encode(r,t,{lengthDelimited:!1}),t.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 Cr(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function pi(r){function e(i){if(r[i.toString()]==null)throw new Error("Invalid enum value");return r[i]}let t=function(o,s){let a=e(o);s.int32(a)},n=function(o){let s=o.int32();return e(s)};return Cr("enum",mt.VARINT,t,n)}function Jt(r,e){return Cr("message",mt.LENGTH_DELIMITED,r,e)}var xe;(function(r){let e;(function(i){i.Raw="Raw",i.Directory="Directory",i.File="File",i.Metadata="Metadata",i.Symlink="Symlink",i.HAMTShard="HAMTShard"})(e=r.DataType||(r.DataType={}));let t;(function(i){i[i.Raw=0]="Raw",i[i.Directory=1]="Directory",i[i.File=2]="File",i[i.Metadata=3]="Metadata",i[i.Symlink=4]="Symlink",i[i.HAMTShard=5]="HAMTShard"})(t||(t={})),(function(i){i.codec=()=>pi(t)})(e=r.DataType||(r.DataType={}));let n;r.codec=()=>(n==null&&(n=Jt((i,o,s={})=>{if(s.lengthDelimited!==!1&&o.fork(),i.Type!=null&&(o.uint32(8),r.DataType.codec().encode(i.Type,o)),i.Data!=null&&(o.uint32(18),o.bytes(i.Data)),i.filesize!=null&&(o.uint32(24),o.uint64(i.filesize)),i.blocksizes!=null)for(let a of i.blocksizes)o.uint32(32),o.uint64(a);i.hashType!=null&&(o.uint32(40),o.uint64(i.hashType)),i.fanout!=null&&(o.uint32(48),o.uint64(i.fanout)),i.mode!=null&&(o.uint32(56),o.uint32(i.mode)),i.mtime!=null&&(o.uint32(66),Nr.codec().encode(i.mtime,o)),s.lengthDelimited!==!1&&o.ldelim()},(i,o)=>{let s={blocksizes:[]},a=o==null?i.len:i.pos+o;for(;i.pos<a;){let c=i.uint32();switch(c>>>3){case 1:s.Type=r.DataType.codec().decode(i);break;case 2:s.Data=i.bytes();break;case 3:s.filesize=i.uint64();break;case 4:s.blocksizes.push(i.uint64());break;case 5:s.hashType=i.uint64();break;case 6:s.fanout=i.uint64();break;case 7:s.mode=i.uint32();break;case 8:s.mtime=Nr.codec().decode(i,i.uint32());break;default:i.skipType(c&7);break}}return s})),n),r.encode=i=>Xt(i,r.codec()),r.decode=i=>qt(i,r.codec())})(xe||(xe={}));var Nr;(function(r){let e;r.codec=()=>(e==null&&(e=Jt((t,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),t.Seconds!=null&&(n.uint32(8),n.int64(t.Seconds)),t.FractionalNanoseconds!=null&&(n.uint32(21),n.fixed32(t.FractionalNanoseconds)),i.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let i={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let s=t.uint32();switch(s>>>3){case 1:i.Seconds=t.int64();break;case 2:i.FractionalNanoseconds=t.fixed32();break;default:t.skipType(s&7);break}}return i})),e),r.encode=t=>Xt(t,r.codec()),r.decode=t=>qt(t,r.codec())})(Nr||(Nr={}));var Oo;(function(r){let e;r.codec=()=>(e==null&&(e=Jt((t,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),t.MimeType!=null&&(n.uint32(10),n.string(t.MimeType)),i.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let i={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let s=t.uint32();switch(s>>>3){case 1:i.MimeType=t.string();break;default:t.skipType(s&7);break}}return i})),e),r.encode=t=>Xt(t,r.codec()),r.decode=t=>qt(t,r.codec())})(Oo||(Oo={}));var Vo={Raw:"raw",Directory:"directory",File:"file",Metadata:"metadata",Symlink:"symlink",HAMTShard:"hamt-sharded-directory"},mf=["directory","hamt-sharded-directory"],Ho=parseInt("0644",8),jo=parseInt("0755",8),qo=BigInt(1024),I=class r{static unmarshal(e){let t=xe.decode(e);if(t.fanout!=null&&t.fanout>qo)throw new Br(`Fanout size was too large - ${t.fanout} > ${qo}`);let n=new r({type:Vo[t.Type!=null?t.Type.toString():"File"],data:t.Data,blockSizes:t.blocksizes,mode:t.mode,mtime:t.mtime!=null?{secs:t.mtime.Seconds??0n,nsecs:t.mtime.FractionalNanoseconds}:void 0,fanout:t.fanout});return n._originalMode=t.mode??0,n}type;data;blockSizes;hashType;fanout;mtime;_mode;_originalMode;constructor(e={type:"file"}){let{type:t,data:n,blockSizes:i,hashType:o,fanout:s,mtime:a,mode:c}=e;if(t!=null&&!Object.values(Vo).includes(t))throw new Ht("Type: "+t+" is not valid");this.type=t??"file",this.data=n,this.hashType=o,this.fanout=s,this.blockSizes=i??[],this._originalMode=0,this.mode=c,this.mtime=a}set mode(e){e==null?this._mode=this.isDirectory()?jo:Ho:this._mode=e&4095}get mode(){return this._mode}isDirectory(){return mf.includes(this.type)}addBlockSize(e){this.blockSizes.push(e)}removeBlockSize(e){this.blockSizes.splice(e,1)}fileSize(){if(this.isDirectory())return 0n;let e=0n;return this.blockSizes.forEach(t=>{e+=t}),this.data!=null&&(e+=BigInt(this.data.length)),e}marshal(){let e;switch(this.type){case"raw":e=xe.DataType.Raw;break;case"directory":e=xe.DataType.Directory;break;case"file":e=xe.DataType.File;break;case"metadata":e=xe.DataType.Metadata;break;case"symlink":e=xe.DataType.Symlink;break;case"hamt-sharded-directory":e=xe.DataType.HAMTShard;break;default:throw new Ht(`Type: ${e} is not valid`)}let t=this.data;(this.data==null||this.data.length===0)&&(t=void 0);let n;this.mode!=null&&(n=this._originalMode&4294963200|(this.mode??0),n===Ho&&!this.isDirectory()&&(n=void 0),n===jo&&this.isDirectory()&&(n=void 0));let i;return this.mtime!=null&&(i={Seconds:this.mtime.secs,FractionalNanoseconds:this.mtime.nsecs}),xe.encode({Type:e,Data:t,filesize:this.isDirectory()?void 0:this.fileSize(),blocksizes:this.blockSizes,hashType:this.hashType,fanout:this.fanout,mode:n,mtime:i})}};var U=class extends Event{type;detail;constructor(e,t){super(e),this.type=e,this.detail=t}};var be=async(r,e,t)=>{t.codec==null&&(t.codec=O);let n=await oe.digest(r),i=A.create(t.cidVersion,t.codec.code,n);return await e.put(i,r,t),i};function Go(r){return async function*(t,n){let i=0n;for await(let o of t.content)yield async()=>{let s,a={codec:O,cidVersion:r.cidVersion,onProgress:r.onProgress};r.rawLeaves?(a.codec=Ae,a.cidVersion=1):(s=new I({type:r.leafType,data:o}),o=T({Data:s.marshal(),Links:[]}));let c=await be(o,n,a);return i+=BigInt(o.byteLength),r.onProgress?.(new U("unixfs:importer:progress:file:write",{bytesWritten:i,cid:c,path:t.path})),{cid:c,unixfs:s,size:BigInt(o.length),block:o}}}}var Tr=class r extends Error{static name="InvalidParametersError";static code="ERR_INVALID_PARAMS";name=r.name;code=r.code;constructor(e="Invalid parameters"){super(e)}};var Me=class r extends Error{static name="InvalidContentError";static code="ERR_INVALID_CONTENT";name=r.name;code=r.code;constructor(e="Invalid content"){super(e)}};var Wo=async(r,e,t)=>{let n=new I({type:"directory",mtime:r.mtime,mode:r.mode}),i=T(P({Data:n.marshal()})),o=await be(i,e,t),s=r.path;return{cid:o,path:s,unixfs:n,size:BigInt(i.length),originalPath:r.originalPath,block:i}};async function*yf(r,e,t){let n=-1,i;for await(let o of Pt(t.bufferImporter(r,e),t.blockWriteConcurrency)){if(n++,n===0){i={...o,single:!0};continue}else n===1&&i!=null&&(yield{...i,block:void 0,single:void 0},i=void 0);yield{...o,block:void 0}}i!=null&&(yield i)}function Ko(r){return r.single===!0}var gf=(r,e,t)=>async function(i){if(i.length===1&&Ko(i[0])&&t.reduceSingleLeafToSelf){let f=i[0],l=f.block;return Ko(f)&&(r.mtime!==void 0||r.mode!==void 0)&&(f.unixfs=new I({type:"file",mtime:r.mtime,mode:r.mode,data:f.block}),l={Data:f.unixfs.marshal(),Links:[]},f.block=T(P(l)),f.cid=await be(f.block,e,{...t,cidVersion:t.cidVersion}),f.size=BigInt(f.block.length)),t.onProgress?.(new U("unixfs:importer:progress:file:layout",{cid:f.cid,path:f.originalPath})),{cid:f.cid,path:r.path,unixfs:f.unixfs,size:f.size,originalPath:f.originalPath}}let o=new I({type:"file",mtime:r.mtime,mode:r.mode}),s=i.filter(f=>f.cid.code===Q&&f.size>0||f.unixfs!=null&&f.unixfs.data==null&&f.unixfs.fileSize()>0n?!0:!!f.unixfs?.data?.length).map(f=>f.cid.code===Q?(o.addBlockSize(f.size),{Name:"",Tsize:Number(f.size),Hash:f.cid}):(f.unixfs?.data==null?o.addBlockSize(f.unixfs?.fileSize()??0n):o.addBlockSize(BigInt(f.unixfs.data.length)),{Name:"",Tsize:Number(f.size),Hash:f.cid})),a={Data:o.marshal(),Links:s},c=T(P(a)),h=await be(c,e,t);return t.onProgress?.(new U("unixfs:importer:progress:file:layout",{cid:h,path:r.originalPath})),{cid:h,path:r.path,unixfs:o,size:BigInt(c.length+a.Links.reduce((f,l)=>f+(l.Tsize??0),0)),originalPath:r.originalPath,block:c}},Xo=async(r,e,t)=>t.layout(yf(r,e,t),gf(r,e,t));function wf(r){return Symbol.iterator in r}function xf(r){return Symbol.asyncIterator in r}function bf(r){try{if(r instanceof Uint8Array)return(async function*(){yield r})();if(wf(r))return(async function*(){yield*r})();if(xf(r))return r}catch{throw new Me("Content was invalid")}throw new Me("Content was invalid")}function Jo(r){return async function*(t,n){for await(let i of t){let o;if(i.path!=null&&(o=i.path,i.path=i.path.split("/").filter(s=>s!=null&&s!==".").join("/")),_f(i)){let s={path:i.path,mtime:i.mtime,mode:i.mode,content:(async function*(){let c=0n;for await(let h of r.chunker(r.chunkValidator(bf(i.content)))){let f=BigInt(h.byteLength);c+=f,r.onProgress?.(new U("unixfs:importer:progress:file:read",{bytesRead:c,chunkSize:f,path:i.path})),yield h}})(),originalPath:o},a=r.fileBuilder??Xo;yield async()=>a(s,n,r)}else if(i.path!=null){let s={path:i.path,mtime:i.mtime,mode:i.mode,originalPath:o},a=r.dirBuilder??Wo;yield async()=>a(s,n,r)}else throw new Error("Import candidate must have content or path or both")}}}function _f(r){return r.content!=null}var Zo=()=>async function*(e){for await(let t of e){if(t.length===void 0)throw new Me("Content was invalid");if(typeof t=="string"||t instanceof String)yield M(t.toString());else if(Array.isArray(t))yield Uint8Array.from(t);else if(t instanceof Uint8Array)yield t;else throw new Me("Content was invalid")}};var kf=174;function Zt(r){let e=r?.maxChildrenPerNode??kf;return async function t(n,i){let o=[];for await(let s of br(n,e))o.push(await i(s));return o.length>1?t(o,i):o[0]}}function Sf(r){return r[Symbol.asyncIterator]!=null}function Ef(r){if(Sf(r))return(async()=>{let t=[];for await(let n of r)t.push(n);return t})();let e=[];for(let t of r)e.push(t);return e}var Yo=Ef;var Ce=class{options;root;dir;path;dirty;flat;parent;parentKey;unixfs;mode;mtime;cid;size;nodeSize;constructor(e,t){this.options=t??{},this.root=e.root,this.dir=e.dir,this.path=e.path,this.dirty=e.dirty,this.flat=e.flat,this.parent=e.parent,this.parentKey=e.parentKey,this.unixfs=e.unixfs,this.mode=e.mode,this.mtime=e.mtime}},Yt=A.parse("QmUNLLsPACCz1vLxQVkXqqLX5R1X345qqfHbsf67hvA3Nn"),Qt=A.parse("zdj7WbTaiJT1fgatdet9Ei9iDB5hdCxkbVyhyh8YTUnXMiwYi");var Ke=class extends Ce{_children;constructor(e,t){super(e,t),this._children=new Map}async put(e,t){this.cid=void 0,this.size=void 0,this.nodeSize=void 0,this._children.set(e,t)}async get(e){return Promise.resolve(this._children.get(e))}childCount(){return this._children.size}directChildrenCount(){return this.childCount()}onlyChild(){return this._children.values().next().value}*eachChildSeries(){for(let[e,t]of this._children.entries())yield{key:e,child:t}}estimateNodeSize(){if(this.nodeSize!==void 0)return this.nodeSize;this.nodeSize=0;for(let[e,t]of this._children.entries())t.size!=null&&t.cid!=null&&(this.nodeSize+=e.length+(this.options.cidVersion===1?Qt.bytes.byteLength:Yt.bytes.byteLength));return this.nodeSize}async*flush(e){let t=[];for(let[c,h]of this._children.entries()){let f=h;if(h instanceof Ce)for await(let l of h.flush(e))f=l,yield l;f.size!=null&&f.cid!=null&&t.push({Name:c,Tsize:Number(f.size),Hash:f.cid})}let n=new I({type:"directory",mtime:this.mtime,mode:this.mode}),i={Data:n.marshal(),Links:t},o=T(P(i)),s=await be(o,e,this.options),a=o.length+i.Links.reduce((c,h)=>c+(h.Tsize??0),0);this.cid=s,this.size=a,yield{cid:s,unixfs:n,path:this.path,size:BigInt(a)}}};var Lr=Ft(ts(),1);function vf(r){let e=new Array(4);for(let t=0;t<4;t++)e[t]=r&255,r=r>>8;return new Uint8Array(e)}var Wm=Ge({name:"murmur3-32",code:35,encode:r=>vf(Lr.default.x86.hash32(r))}),Xe=Ge({name:"murmur3-128",code:34,encode:r=>at.fromHex(Lr.default.x64.hash128(r))}),Km=Ge({name:"murmur3-x64-64",code:34,encode:r=>at.fromHex(Lr.default.x64.hash128(r)).subarray(0,8)});var is=Ft(zr(),1);var se=class r{_options;_popCount;_parent;_posAtParent;_children;key;constructor(e,t,n=0){this._options=e,this._popCount=0,this._parent=t,this._posAtParent=n,this._children=new is.default,this.key=null}async put(e,t){let n=await this._findNewBucketAndPos(e);n.bucket._putAt(n,e,t)}async get(e){let t=await this._findChild(e);if(t!=null)return t.value}async del(e){let t=await this._findPlace(e),n=t.bucket._at(t.pos);n!=null&&n.key===e&&t.bucket._delAt(t.pos)}leafCount(){return this._children.compactArray().reduce((t,n)=>n instanceof r?t+n.leafCount():t+1,0)}childrenCount(){return this._children.length}onlyChild(){return this._children.get(0)}*eachLeafSeries(){let e=this._children.compactArray();for(let t of e)t instanceof r?yield*t.eachLeafSeries():yield t}serialize(e,t){let n=[];return t(this._children.reduce((i,o,s)=>(o!=null&&(o instanceof r?i.push(o.serialize(e,t)):i.push(e(o,s))),i),n))}async asyncTransform(e,t){return os(this,e,t)}toJSON(){return this.serialize(Nf,Tf)}prettyPrint(){return JSON.stringify(this.toJSON(),null," ")}tableSize(){return Math.pow(2,this._options.bits)}async _findChild(e){let t=await this._findPlace(e),n=t.bucket._at(t.pos);if(!(n instanceof r)&&n!=null&&n.key===e)return n}async _findPlace(e){let t=this._options.hash(typeof e=="string"?M(e):e),n=await t.take(this._options.bits),i=this._children.get(n);return i instanceof r?i._findPlace(t):{bucket:this,pos:n,hash:t,existingChild:i}}async _findNewBucketAndPos(e){let t=await this._findPlace(e);if(t.existingChild!=null&&t.existingChild.key!==e){let n=new r(this._options,t.bucket,t.pos);t.bucket._putObjectAt(t.pos,n);let i=await n._findPlace(t.existingChild.hash);return i.bucket._putAt(i,t.existingChild.key,t.existingChild.value),n._findNewBucketAndPos(t.hash)}return t}_putAt(e,t,n){this._putObjectAt(e.pos,{key:t,value:n,hash:e.hash})}_putObjectAt(e,t){this._children.get(e)==null&&this._popCount++,this._children.set(e,t)}_delAt(e){if(e===-1)throw new Error("Invalid position");this._children.get(e)!=null&&this._popCount--,this._children.unset(e),this._level()}_level(){if(this._parent!=null&&this._popCount<=1)if(this._popCount===1){let e=this._children.find(Cf);if(e!=null&&!(e instanceof r)){let t=e.hash;t.untake(this._options.bits);let n={pos:this._posAtParent,hash:t,bucket:this._parent};this._parent._putAt(n,e.key,e.value)}}else this._parent._delAt(this._posAtParent)}_at(e){return this._children.get(e)}};function Cf(r){return!!r}function Nf(r,e){return r.key}function Tf(r){return r}async function os(r,e,t){let n=[];for(let i of r._children.compactArray())if(i instanceof se)await os(i,e,t);else{let o=await e(i);n.push({bitField:r._children.bitField(),children:o})}return t(n)}var Df=[255,254,252,248,240,224,192,128],Lf=[1,3,7,15,31,63,127,255],Fr=class{_value;_currentBytePos;_currentBitPos;constructor(e){this._value=e,this._currentBytePos=e.length-1,this._currentBitPos=7}availableBits(){return this._currentBitPos+1+this._currentBytePos*8}totalBits(){return this._value.length*8}take(e){let t=e,n=0;for(;t>0&&this._haveBits();){let i=this._value[this._currentBytePos],o=this._currentBitPos+1,s=Math.min(o,t),a=zf(i,o-s,s);n=(n<<s)+a,t-=s,this._currentBitPos-=s,this._currentBitPos<0&&(this._currentBitPos=7,this._currentBytePos--)}return n}untake(e){for(this._currentBitPos+=e;this._currentBitPos>7;)this._currentBitPos-=8,this._currentBytePos+=1}_haveBits(){return this._currentBytePos>=0}};function zf(r,e,t){let n=Ff(e,t);return(r&n)>>>e}function Ff(r,e){return Df[r]&Lf[Math.min(e+r-1,7)]}function ss(r){function e(t){return t instanceof Pr?t:new Pr(t,r)}return e}var Pr=class{_value;_hashFn;_depth;_availableBits;_currentBufferIndex;_buffers;constructor(e,t){if(!(e instanceof Uint8Array))throw new Error("can only hash Uint8Arrays");this._value=e,this._hashFn=t,this._depth=-1,this._availableBits=0,this._currentBufferIndex=0,this._buffers=[]}async take(e){let t=e;for(;this._availableBits<t;)await this._produceMoreBits();let n=0;for(;t>0;){let i=this._buffers[this._currentBufferIndex],o=Math.min(i.availableBits(),t),s=i.take(o);n=(n<<o)+s,t-=o,this._availableBits-=o,i.availableBits()===0&&this._currentBufferIndex++}return n}untake(e){let t=e;for(;t>0;){let n=this._buffers[this._currentBufferIndex],i=Math.min(n.totalBits()-n.availableBits(),t);n.untake(i),t-=i,this._availableBits+=i,this._currentBufferIndex>0&&n.totalBits()===n.availableBits()&&(this._depth--,this._currentBufferIndex--)}}async _produceMoreBits(){this._depth++;let e=this._depth>0?Ie([this._value,Uint8Array.from([this._depth])]):this._value,t=await this._hashFn(e),n=new Fr(t);this._buffers.push(n),this._availableBits+=n.availableBits()}};function yt(r){if(r==null||r.hashFn==null)throw new Error("please define an options.hashFn");let e={bits:r.bits??8,hash:ss(r.hashFn)};return new se(e)}async function Pf(r){return(await Xe.encode(r)).slice(0,8).reverse()}var as=BigInt(34),Uf=8,mi=class extends Ce{_bucket;constructor(e,t){super(e,t),this._bucket=yt({hashFn:Pf,bits:t.shardFanoutBits??Uf})}async put(e,t){this.cid=void 0,this.size=void 0,this.nodeSize=void 0,await this._bucket.put(e,t)}async get(e){return this._bucket.get(e)}childCount(){return this._bucket.leafCount()}directChildrenCount(){return this._bucket.childrenCount()}onlyChild(){return this._bucket.onlyChild()}*eachChildSeries(){for(let{key:e,value:t}of this._bucket.eachLeafSeries())yield{key:e,child:t}}estimateNodeSize(){return this.nodeSize!==void 0?this.nodeSize:(this.nodeSize=fs(this._bucket,this,this.options),this.nodeSize)}async*flush(e){for await(let t of us(this._bucket,e,this,this.options))yield{...t,path:this.path}}},cs=mi;async function*us(r,e,t,n){let i=r._children,o=(r.tableSize()-1).toString(16).length,s=[],a=0n;for(let d=0;d<i.length;d++){let m=i.get(d);if(m==null)continue;let x=d.toString(16).toUpperCase().padStart(o,"0");if(m instanceof se){let g;for await(let w of us(m,e,null,n))g=w;if(g==null)throw new Error("Could not flush sharded directory, no subshard found");s.push({Name:x,Tsize:Number(g.size),Hash:g.cid}),a+=g.size}else if($f(m.value)){let g=m.value,w;for await(let S of g.flush(e))w=S,yield w;if(w==null)throw new Error("Did not flush dir");let b=x+m.key;s.push({Name:b,Tsize:Number(w.size),Hash:w.cid}),a+=w.size}else{let g=m.value;if(g.cid==null)continue;let w=x+m.key,b=g.size;s.push({Name:w,Tsize:Number(b),Hash:g.cid}),a+=BigInt(b??0)}}let c=Uint8Array.from(i.bitField().reverse()),h=new I({type:"hamt-sharded-directory",data:c,fanout:BigInt(r.tableSize()),hashType:as,mtime:t?.mtime,mode:t?.mode}),f={Data:h.marshal(),Links:s},l=T(P(f)),y=await be(l,e,n),u=BigInt(l.byteLength)+a;yield{cid:y,unixfs:h,size:u}}function $f(r){return typeof r.flush=="function"}function fs(r,e,t){let n=r._children,i=(r.tableSize()-1).toString(16).length,o=[];for(let h=0;h<n.length;h++){let f=n.get(h);if(f==null)continue;let l=h.toString(16).toUpperCase().padStart(i,"0");if(f instanceof se){let y=fs(f,null,t);o.push({Name:l,Tsize:Number(y),Hash:t.cidVersion===0?Yt:Qt})}else if(typeof f.value.flush=="function"){let u=f.value.nodeSize();o.push({Name:l+f.key,Tsize:Number(u),Hash:t.cidVersion===0?Yt:Qt})}else{let y=f.value;if(y.cid==null)continue;let u=l+f.key,d=y.size;o.push({Name:u,Tsize:Number(d),Hash:y.cid})}}let s=Uint8Array.from(n.bitField().reverse()),a=new I({type:"hamt-sharded-directory",data:s,fanout:BigInt(r.tableSize()),hashType:as,mtime:e?.mtime,mode:e?.mode});return T(P({Data:a.marshal(),Links:o})).length}async function yi(r,e,t,n){let i=e;e instanceof Ke&&e.estimateNodeSize()>t&&(i=await Rf(e,n));let o=i.parent;if(o!=null){if(i!==e){if(r!=null&&(r.parent=i),i.parentKey==null)throw new Error("No parent key found");await o.put(i.parentKey,i)}return yi(i,o,t,n)}return i}async function Rf(r,e){let t=new cs({root:r.root,dir:!0,parent:r.parent,parentKey:r.parentKey,path:r.path,dirty:r.dirty,flat:!1,mtime:r.mtime,mode:r.mode},e);for(let{key:n,child:i}of r.eachChildSeries())await t.put(n,i);return t}var ls=(r="")=>r.split(/(?<!\\)\//).filter(Boolean);async function Mf(r,e,t){let n=ls(r.path??""),i=n.length-1,o=e,s="";for(let a=0;a<n.length;a++){let c=n[a];s+=`${s!==""?"/":""}${c}`;let h=a===i;if(o.dirty=!0,o.cid=void 0,o.size=void 0,h)await o.put(c,r),e=await yi(null,o,t.shardSplitThresholdBytes,t);else{let f=await o.get(c);(f==null||!(f instanceof Ce))&&(f=new Ke({root:!1,dir:!0,parent:o,parentKey:c,path:s,dirty:!0,flat:!0,mtime:f?.unixfs?.mtime,mode:f?.unixfs?.mode},t)),await o.put(c,f),o=f}}return e}async function*hs(r,e){if(!(r instanceof Ce)){r.unixfs?.isDirectory()===!0&&(yield r);return}yield*r.flush(e)}function ds(r){return async function*(t,n){let i=new Ke({root:!0,dir:!0,path:"",dirty:!0,flat:!0},r),o,s=!1;for await(let a of t){if(a==null)continue;let c=`${a.originalPath??""}`.split("/")[0];c!=null&&c!==""&&(o==null?(o=c,s=!0):o!==c&&(s=!1)),i=await Mf(a,i,r),a.unixfs?.isDirectory()!==!0&&(yield a)}if(r.wrapWithDirectory||s&&i.childCount()>1)yield*hs(i,n);else for(let a of i.eachChildSeries())a!=null&&(yield*hs(a.child,n))}}async function*Je(r,e,t={}){let n;Symbol.asyncIterator in r||Symbol.iterator in r?n=r:n=[r];let i=t.wrapWithDirectory??!1,o=t.shardSplitThresholdBytes??262144,s=t.shardFanoutBits??8,a=t.cidVersion??1,c=t.rawLeaves??!0,h=t.leafType??"file",f=t.fileImportConcurrency??50,l=t.blockWriteConcurrency??10,y=t.reduceSingleLeafToSelf??!0,u=t.chunker??Ut(),d=t.chunkValidator??Zo(),m=t.dagBuilder??Jo({chunker:u,chunkValidator:d,wrapWithDirectory:i,layout:t.layout??Zt(),bufferImporter:t.bufferImporter??Go({cidVersion:a,rawLeaves:c,leafType:h,onProgress:t.onProgress}),blockWriteConcurrency:l,reduceSingleLeafToSelf:y,cidVersion:a,onProgress:t.onProgress,dirBuilder:t.dirBuilder,fileBuilder:t.fileBuilder}),x=t.treeBuilder??ds({wrapWithDirectory:i,shardSplitThresholdBytes:o,shardFanoutBits:s,cidVersion:a,onProgress:t.onProgress});for await(let g of x(Pt(m(n,e),f),e))yield{cid:g.cid,path:g.path,unixfs:g.unixfs,size:g.size}}async function ps(r,e,t={}){let n=await xr(Je([r],e,t));if(n==null)throw new Tr("Nothing imported");return n}async function ms(r,e,t={}){return ps({content:r},e,t)}async function ys(r,e,t={}){return ps({content:r},e,t)}function Of(r){return r[Symbol.asyncIterator]!=null}function Vf(r){if(Of(r))return(async()=>{let t;for await(let n of r)t=n;return t})();let e;for(let t of r)e=t;return e}var _e=Vf;var ke=class extends Error{name;code;constructor(e,t,n){super(e),this.name=t,this.code=n}},Ne=class extends ke{constructor(e="not a Unixfs node"){super(e,"NotUnixFSError","ERR_NOT_UNIXFS")}},ee=class extends ke{constructor(e="invalid PBNode"){super(e,"InvalidPBNodeError","ERR_INVALID_PB_NODE")}},Te=class extends ke{constructor(e="unknown error"){super(e,"InvalidPBNodeError","ERR_UNKNOWN_ERROR")}},tr=class extends ke{constructor(e="path already exists"){super(e,"AlreadyExistsError","ERR_ALREADY_EXISTS")}},Ur=class extends ke{constructor(e="path does not exist"){super(e,"DoesNotExistError","ERR_DOES_NOT_EXIST")}},gt=class extends ke{constructor(e="no content"){super(e,"NoContentError","ERR_NO_CONTENT")}},$r=class extends ke{constructor(e="not a file"){super(e,"NotAFileError","ERR_NOT_A_FILE")}},Oe=class extends ke{constructor(e="not a directory"){super(e,"NotADirectoryError","ERR_NOT_A_DIRECTORY")}},V=class extends ke{constructor(e="invalid parameters"){super(e,"InvalidParametersError","ERR_INVALID_PARAMETERS")}};var rr={cidVersion:1,rawLeaves:!0,layout:Zt({maxChildrenPerNode:1024}),chunker:Ut({chunkSize:1048576})};async function*Rr(r,e,t={}){yield*Je(r,e,{...rr,...t})}async function gs(r,e,t={}){let{cid:n}=await ms(r,e,{...rr,...t});return n}async function ws(r,e,t={}){let{cid:n}=await ys(r,e,{...rr,...t});return n}async function xs(r,e,t={}){if(r.path==null)throw new V("path is required");if(r.content==null)throw new V("content is required");let n=await _e(Rr([r],e,{...rr,...t,wrapWithDirectory:!0}));if(n==null)throw new V("Nothing imported");return n.cid}async function bs(r,e,t={}){if(r.content!=null)throw new V("Directories cannot have content, use addFile instead");let i=await(r.path==null?xr:_e)(Rr([{...r,path:r.path??"-"}],e,{...rr,...t,wrapWithDirectory:r.path!=null}));if(i==null)throw new V("Nothing imported");return i.cid}var Mr=class r extends Error{static name="BadPathError";static code="ERR_BAD_PATH";name=r.name;code=r.code;constructor(e="Bad path"){super(e)}},pe=class r extends Error{static name="NotFoundError";static code="ERR_NOT_FOUND";name=r.name;code=r.code;constructor(e="Not found"){super(e)}},Or=class r extends Error{static name="NoResolverError";static code="ERR_NO_RESOLVER";name=r.name;code=r.code;constructor(e="No resolver"){super(e)}},H=class r extends Error{static name="NotUnixFSError";static code="ERR_NOT_UNIXFS";name=r.name;code=r.code;constructor(e="Not UnixFS"){super(e)}},Vr=class r extends Error{static name="OverReadError";static code="ERR_OVER_READ";name=r.name;code=r.code;constructor(e="Over read"){super(e)}},Hr=class r extends Error{static name="UnderReadError";static code="ERR_UNDER_READ";name=r.name;code=r.code;constructor(e="Under read"){super(e)}},jr=class r extends Error{static name="NoPropError";static code="ERR_NO_PROP";name=r.name;code=r.code;constructor(e="No Property found"){super(e)}},Ze=class r extends Error{static name="InvalidParametersError";static code="ERR_INVALID_PARAMS";name=r.name;code=r.code;constructor(e="Invalid parameters"){super(e)}};var Hf=["string","number","bigint","symbol"],jf=["Function","Generator","AsyncGenerator","GeneratorFunction","AsyncGeneratorFunction","AsyncFunction","Observable","Array","Buffer","Object","RegExp","Date","Error","Map","Set","WeakMap","WeakSet","ArrayBuffer","SharedArrayBuffer","DataView","Promise","URL","HTMLElement","Int8Array","Uint8Array","Uint8ClampedArray","Int16Array","Uint16Array","Int32Array","Uint32Array","Float32Array","Float64Array","BigInt64Array","BigUint64Array"];function _s(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let e=typeof r;if(Hf.includes(e))return e;if(e==="function")return"Function";if(Array.isArray(r))return"Array";if(qf(r))return"Buffer";let t=Gf(r);return t||"Object"}function qf(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function Gf(r){let e=Object.prototype.toString.call(r).slice(8,-1);if(jf.includes(e))return e}var p=class{constructor(e,t,n){this.major=e,this.majorEncoded=e<<5,this.name=t,this.terminal=n}toString(){return`Type[${this.major}].${this.name}`}compare(e){return this.major<e.major?-1:this.major>e.major?1:0}};p.uint=new p(0,"uint",!0);p.negint=new p(1,"negint",!0);p.bytes=new p(2,"bytes",!0);p.string=new p(3,"string",!0);p.array=new p(4,"array",!1);p.map=new p(5,"map",!1);p.tag=new p(6,"tag",!1);p.float=new p(7,"float",!0);p.false=new p(7,"false",!0);p.true=new p(7,"true",!0);p.null=new p(7,"null",!0);p.undefined=new p(7,"undefined",!0);p.break=new p(7,"break",!0);var _=class{constructor(e,t,n){this.type=e,this.value=t,this.encodedLength=n,this.encodedBytes=void 0,this.byteValue=void 0}toString(){return`Token[${this.type}].${this.value}`}};var wt=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",Wf=new TextDecoder,Kf=new TextEncoder;function qr(r){return wt&&globalThis.Buffer.isBuffer(r)}function Gr(r){return r instanceof Uint8Array?qr(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var vs=wt?(r,e,t)=>t-e>64?globalThis.Buffer.from(r.subarray(e,t)).toString("utf8"):Ss(r,e,t):(r,e,t)=>t-e>64?Wf.decode(r.subarray(e,t)):Ss(r,e,t),Wr=wt?r=>r.length>64?globalThis.Buffer.from(r):ks(r):r=>r.length>64?Kf.encode(r):ks(r);var xt=wt?(r,e,t)=>qr(r)?new Uint8Array(r.subarray(e,t)):r.slice(e,t):(r,e,t)=>r.slice(e,t),Bs=wt?(r,e)=>(r=r.map(t=>t instanceof Uint8Array?t:globalThis.Buffer.from(t)),Gr(globalThis.Buffer.concat(r,e))):(r,e)=>{let t=new Uint8Array(e),n=0;for(let i of r)n+i.length>t.length&&(i=i.subarray(0,t.length-n)),t.set(i,n),n+=i.length;return t},Is=wt?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function As(r,e){if(qr(r)&&qr(e))return r.compare(e);for(let t=0;t<r.length;t++)if(r[t]!==e[t])return r[t]<e[t]?-1:1;return 0}function ks(r){let e=[],t=0;for(let n=0;n<r.length;n++){let i=r.charCodeAt(n);i<128?e[t++]=i:i<2048?(e[t++]=i>>6|192,e[t++]=i&63|128):(i&64512)===55296&&n+1<r.length&&(r.charCodeAt(n+1)&64512)===56320?(i=65536+((i&1023)<<10)+(r.charCodeAt(++n)&1023),e[t++]=i>>18|240,e[t++]=i>>12&63|128,e[t++]=i>>6&63|128,e[t++]=i&63|128):(e[t++]=i>>12|224,e[t++]=i>>6&63|128,e[t++]=i&63|128)}return e}function Ss(r,e,t){let n=[];for(;e<t;){let i=r[e],o=null,s=i>239?4:i>223?3:i>191?2:1;if(e+s<=t){let a,c,h,f;switch(s){case 1:i<128&&(o=i);break;case 2:a=r[e+1],(a&192)===128&&(f=(i&31)<<6|a&63,f>127&&(o=f));break;case 3:a=r[e+1],c=r[e+2],(a&192)===128&&(c&192)===128&&(f=(i&15)<<12|(a&63)<<6|c&63,f>2047&&(f<55296||f>57343)&&(o=f));break;case 4:a=r[e+1],c=r[e+2],h=r[e+3],(a&192)===128&&(c&192)===128&&(h&192)===128&&(f=(i&15)<<18|(a&63)<<12|(c&63)<<6|h&63,f>65535&&f<1114112&&(o=f))}}o===null?(o=65533,s=1):o>65535&&(o-=65536,n.push(o>>>10&1023|55296),o=56320|o&1023),n.push(o),e+=s}return gi(n)}var Es=4096;function gi(r){let e=r.length;if(e<=Es)return String.fromCharCode.apply(String,r);let t="",n=0;for(;n<e;)t+=String.fromCharCode.apply(String,r.slice(n,n+=Es));return t}var Xf=256,Kr=class{constructor(e=Xf){this.chunkSize=e,this.cursor=0,this.maxCursor=-1,this.chunks=[],this._initReuseChunk=null}reset(){this.cursor=0,this.maxCursor=-1,this.chunks.length&&(this.chunks=[]),this._initReuseChunk!==null&&(this.chunks.push(this._initReuseChunk),this.maxCursor=this._initReuseChunk.length-1)}push(e){let t=this.chunks[this.chunks.length-1];if(this.cursor+e.length<=this.maxCursor+1){let i=t.length-(this.maxCursor-this.cursor)-1;t.set(e,i)}else{if(t){let i=t.length-(this.maxCursor-this.cursor)-1;i<t.length&&(this.chunks[this.chunks.length-1]=t.subarray(0,i),this.maxCursor=this.cursor-1)}e.length<64&&e.length<this.chunkSize?(t=Is(this.chunkSize),this.chunks.push(t),this.maxCursor+=t.length,this._initReuseChunk===null&&(this._initReuseChunk=t),t.set(e,0)):(this.chunks.push(e),this.maxCursor+=e.length)}this.cursor+=e.length}toBytes(e=!1){let t;if(this.chunks.length===1){let n=this.chunks[0];e&&this.cursor>n.length/2?(t=this.cursor===n.length?n:n.subarray(0,this.cursor),this._initReuseChunk=null,this.chunks=[]):t=xt(n,0,this.cursor)}else t=Bs(this.chunks,this.cursor);return e&&this.reset(),t}};var v="CBOR decode error:",bt="CBOR encode error:",nr=[];nr[23]=1;nr[24]=2;nr[25]=3;nr[26]=5;nr[27]=9;function Fe(r,e,t){if(r.length-e<t)throw new Error(`${v} not enough data for type`)}var j=[24,256,65536,4294967296,BigInt("18446744073709551616")];function ae(r,e,t){Fe(r,e,1);let n=r[e];if(t.strict===!0&&n<j[0])throw new Error(`${v} integer encoded in more bytes than necessary (strict decode)`);return n}function ce(r,e,t){Fe(r,e,2);let n=r[e]<<8|r[e+1];if(t.strict===!0&&n<j[1])throw new Error(`${v} integer encoded in more bytes than necessary (strict decode)`);return n}function ue(r,e,t){Fe(r,e,4);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3];if(t.strict===!0&&n<j[2])throw new Error(`${v} integer encoded in more bytes than necessary (strict decode)`);return n}function fe(r,e,t){Fe(r,e,8);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3],i=r[e+4]*16777216+(r[e+5]<<16)+(r[e+6]<<8)+r[e+7],o=(BigInt(n)<<BigInt(32))+BigInt(i);if(t.strict===!0&&o<j[3])throw new Error(`${v} integer encoded in more bytes than necessary (strict decode)`);if(o<=Number.MAX_SAFE_INTEGER)return Number(o);if(t.allowBigInt===!0)return o;throw new Error(`${v} integers outside of the safe integer range are not supported`)}function Cs(r,e,t,n){return new _(p.uint,ae(r,e+1,n),2)}function Ns(r,e,t,n){return new _(p.uint,ce(r,e+1,n),3)}function Ts(r,e,t,n){return new _(p.uint,ue(r,e+1,n),5)}function Ds(r,e,t,n){return new _(p.uint,fe(r,e+1,n),9)}function me(r,e){return G(r,0,e.value)}function G(r,e,t){if(t<j[0]){let n=Number(t);r.push([e|n])}else if(t<j[1]){let n=Number(t);r.push([e|24,n])}else if(t<j[2]){let n=Number(t);r.push([e|25,n>>>8,n&255])}else if(t<j[3]){let n=Number(t);r.push([e|26,n>>>24&255,n>>>16&255,n>>>8&255,n&255])}else{let n=BigInt(t);if(n<j[4]){let i=[e|27,0,0,0,0,0,0,0],o=Number(n&BigInt(4294967295)),s=Number(n>>BigInt(32)&BigInt(4294967295));i[8]=o&255,o=o>>8,i[7]=o&255,o=o>>8,i[6]=o&255,o=o>>8,i[5]=o&255,i[4]=s&255,s=s>>8,i[3]=s&255,s=s>>8,i[2]=s&255,s=s>>8,i[1]=s&255,r.push(i)}else throw new Error(`${v} encountered BigInt larger than allowable range`)}}me.encodedSize=function(e){return G.encodedSize(e.value)};G.encodedSize=function(e){return e<j[0]?1:e<j[1]?2:e<j[2]?3:e<j[3]?5:9};me.compareTokens=function(e,t){return e.value<t.value?-1:e.value>t.value?1:0};function Ls(r,e,t,n){return new _(p.negint,-1-ae(r,e+1,n),2)}function zs(r,e,t,n){return new _(p.negint,-1-ce(r,e+1,n),3)}function Fs(r,e,t,n){return new _(p.negint,-1-ue(r,e+1,n),5)}var wi=BigInt(-1),Ps=BigInt(1);function Us(r,e,t,n){let i=fe(r,e+1,n);if(typeof i!="bigint"){let o=-1-i;if(o>=Number.MIN_SAFE_INTEGER)return new _(p.negint,o,9)}if(n.allowBigInt!==!0)throw new Error(`${v} integers outside of the safe integer range are not supported`);return new _(p.negint,wi-BigInt(i),9)}function Xr(r,e){let t=e.value,n=typeof t=="bigint"?t*wi-Ps:t*-1-1;G(r,e.type.majorEncoded,n)}Xr.encodedSize=function(e){let t=e.value,n=typeof t=="bigint"?t*wi-Ps:t*-1-1;return n<j[0]?1:n<j[1]?2:n<j[2]?3:n<j[3]?5:9};Xr.compareTokens=function(e,t){return e.value<t.value?1:e.value>t.value?-1:0};function ir(r,e,t,n){Fe(r,e,t+n);let i=xt(r,e+t,e+t+n);return new _(p.bytes,i,t+n)}function $s(r,e,t,n){return ir(r,e,1,t)}function Rs(r,e,t,n){return ir(r,e,2,ae(r,e+1,n))}function Ms(r,e,t,n){return ir(r,e,3,ce(r,e+1,n))}function Os(r,e,t,n){return ir(r,e,5,ue(r,e+1,n))}function Vs(r,e,t,n){let i=fe(r,e+1,n);if(typeof i=="bigint")throw new Error(`${v} 64-bit integer bytes lengths not supported`);return ir(r,e,9,i)}function Jr(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===p.string?Wr(r.value):r.value),r.encodedBytes}function _t(r,e){let t=Jr(e);G(r,e.type.majorEncoded,t.length),r.push(t)}_t.encodedSize=function(e){let t=Jr(e);return G.encodedSize(t.length)+t.length};_t.compareTokens=function(e,t){return Zf(Jr(e),Jr(t))};function Zf(r,e){return r.length<e.length?-1:r.length>e.length?1:As(r,e)}function or(r,e,t,n,i){let o=t+n;Fe(r,e,o);let s=new _(p.string,vs(r,e+t,e+o),o);return i.retainStringBytes===!0&&(s.byteValue=xt(r,e+t,e+o)),s}function Hs(r,e,t,n){return or(r,e,1,t,n)}function js(r,e,t,n){return or(r,e,2,ae(r,e+1,n),n)}function qs(r,e,t,n){return or(r,e,3,ce(r,e+1,n),n)}function Gs(r,e,t,n){return or(r,e,5,ue(r,e+1,n),n)}function Ws(r,e,t,n){let i=fe(r,e+1,n);if(typeof i=="bigint")throw new Error(`${v} 64-bit integer string lengths not supported`);return or(r,e,9,i,n)}var Ks=_t;function kt(r,e,t,n){return new _(p.array,n,t)}function Xs(r,e,t,n){return kt(r,e,1,t)}function Js(r,e,t,n){return kt(r,e,2,ae(r,e+1,n))}function Zs(r,e,t,n){return kt(r,e,3,ce(r,e+1,n))}function Ys(r,e,t,n){return kt(r,e,5,ue(r,e+1,n))}function Qs(r,e,t,n){let i=fe(r,e+1,n);if(typeof i=="bigint")throw new Error(`${v} 64-bit integer array lengths not supported`);return kt(r,e,9,i)}function ea(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${v} indefinite length items not allowed`);return kt(r,e,1,1/0)}function Zr(r,e){G(r,p.array.majorEncoded,e.value)}Zr.compareTokens=me.compareTokens;Zr.encodedSize=function(e){return G.encodedSize(e.value)};function St(r,e,t,n){return new _(p.map,n,t)}function ta(r,e,t,n){return St(r,e,1,t)}function ra(r,e,t,n){return St(r,e,2,ae(r,e+1,n))}function na(r,e,t,n){return St(r,e,3,ce(r,e+1,n))}function ia(r,e,t,n){return St(r,e,5,ue(r,e+1,n))}function oa(r,e,t,n){let i=fe(r,e+1,n);if(typeof i=="bigint")throw new Error(`${v} 64-bit integer map lengths not supported`);return St(r,e,9,i)}function sa(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${v} indefinite length items not allowed`);return St(r,e,1,1/0)}function Yr(r,e){G(r,p.map.majorEncoded,e.value)}Yr.compareTokens=me.compareTokens;Yr.encodedSize=function(e){return G.encodedSize(e.value)};function aa(r,e,t,n){return new _(p.tag,t,1)}function ca(r,e,t,n){return new _(p.tag,ae(r,e+1,n),2)}function ua(r,e,t,n){return new _(p.tag,ce(r,e+1,n),3)}function fa(r,e,t,n){return new _(p.tag,ue(r,e+1,n),5)}function la(r,e,t,n){return new _(p.tag,fe(r,e+1,n),9)}function Qr(r,e){G(r,p.tag.majorEncoded,e.value)}Qr.compareTokens=me.compareTokens;Qr.encodedSize=function(e){return G.encodedSize(e.value)};var nl=20,il=21,ol=22,sl=23;function ha(r,e,t,n){if(n.allowUndefined===!1)throw new Error(`${v} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new _(p.null,null,1):new _(p.undefined,void 0,1)}function da(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${v} indefinite length items not allowed`);return new _(p.break,void 0,1)}function xi(r,e,t){if(t){if(t.allowNaN===!1&&Number.isNaN(r))throw new Error(`${v} NaN values are not supported`);if(t.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${v} Infinity values are not supported`)}return new _(p.float,r,e)}function pa(r,e,t,n){return xi(bi(r,e+1),3,n)}function ma(r,e,t,n){return xi(_i(r,e+1),5,n)}function ya(r,e,t,n){return xi(ba(r,e+1),9,n)}function en(r,e,t){let n=e.value;if(n===!1)r.push([p.float.majorEncoded|nl]);else if(n===!0)r.push([p.float.majorEncoded|il]);else if(n===null)r.push([p.float.majorEncoded|ol]);else if(n===void 0)r.push([p.float.majorEncoded|sl]);else{let i,o=!1;(!t||t.float64!==!0)&&(wa(n),i=bi(Se,1),n===i||Number.isNaN(n)?(Se[0]=249,r.push(Se.slice(0,3)),o=!0):(xa(n),i=_i(Se,1),n===i&&(Se[0]=250,r.push(Se.slice(0,5)),o=!0))),o||(al(n),i=ba(Se,1),Se[0]=251,r.push(Se.slice(0,9)))}}en.encodedSize=function(e,t){let n=e.value;if(n===!1||n===!0||n===null||n===void 0)return 1;if(!t||t.float64!==!0){wa(n);let i=bi(Se,1);if(n===i||Number.isNaN(n))return 3;if(xa(n),i=_i(Se,1),n===i)return 5}return 9};var ga=new ArrayBuffer(9),ye=new DataView(ga,1),Se=new Uint8Array(ga,0);function wa(r){if(r===1/0)ye.setUint16(0,31744,!1);else if(r===-1/0)ye.setUint16(0,64512,!1);else if(Number.isNaN(r))ye.setUint16(0,32256,!1);else{ye.setFloat32(0,r);let e=ye.getUint32(0),t=(e&2139095040)>>23,n=e&8388607;if(t===255)ye.setUint16(0,31744,!1);else if(t===0)ye.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let i=t-127;i<-24?ye.setUint16(0,0):i<-14?ye.setUint16(0,(e&2147483648)>>16|1<<24+i,!1):ye.setUint16(0,(e&2147483648)>>16|i+15<<10|n>>13,!1)}}}function bi(r,e){if(r.length-e<2)throw new Error(`${v} not enough data for float16`);let t=(r[e]<<8)+r[e+1];if(t===31744)return 1/0;if(t===64512)return-1/0;if(t===32256)return NaN;let n=t>>10&31,i=t&1023,o;return n===0?o=i*2**-24:n!==31?o=(i+1024)*2**(n-25):o=i===0?1/0:NaN,t&32768?-o:o}function xa(r){ye.setFloat32(0,r,!1)}function _i(r,e){if(r.length-e<4)throw new Error(`${v} not enough data for float32`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,4).getFloat32(0,!1)}function al(r){ye.setFloat64(0,r,!1)}function ba(r,e){if(r.length-e<8)throw new Error(`${v} not enough data for float64`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,8).getFloat64(0,!1)}en.compareTokens=me.compareTokens;function D(r,e,t){throw new Error(`${v} encountered invalid minor (${t}) for major ${r[e]>>>5}`)}function tn(r){return()=>{throw new Error(`${v} ${r}`)}}var k=[];for(let r=0;r<=23;r++)k[r]=D;k[24]=Cs;k[25]=Ns;k[26]=Ts;k[27]=Ds;k[28]=D;k[29]=D;k[30]=D;k[31]=D;for(let r=32;r<=55;r++)k[r]=D;k[56]=Ls;k[57]=zs;k[58]=Fs;k[59]=Us;k[60]=D;k[61]=D;k[62]=D;k[63]=D;for(let r=64;r<=87;r++)k[r]=$s;k[88]=Rs;k[89]=Ms;k[90]=Os;k[91]=Vs;k[92]=D;k[93]=D;k[94]=D;k[95]=tn("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)k[r]=Hs;k[120]=js;k[121]=qs;k[122]=Gs;k[123]=Ws;k[124]=D;k[125]=D;k[126]=D;k[127]=tn("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)k[r]=Xs;k[152]=Js;k[153]=Zs;k[154]=Ys;k[155]=Qs;k[156]=D;k[157]=D;k[158]=D;k[159]=ea;for(let r=160;r<=183;r++)k[r]=ta;k[184]=ra;k[185]=na;k[186]=ia;k[187]=oa;k[188]=D;k[189]=D;k[190]=D;k[191]=sa;for(let r=192;r<=215;r++)k[r]=aa;k[216]=ca;k[217]=ua;k[218]=fa;k[219]=la;k[220]=D;k[221]=D;k[222]=D;k[223]=D;for(let r=224;r<=243;r++)k[r]=tn("simple values are not supported");k[244]=D;k[245]=D;k[246]=D;k[247]=ha;k[248]=tn("simple values are not supported");k[249]=pa;k[250]=ma;k[251]=ya;k[252]=D;k[253]=D;k[254]=D;k[255]=da;var Ee=[];for(let r=0;r<24;r++)Ee[r]=new _(p.uint,r,1);for(let r=-1;r>=-24;r--)Ee[31-r]=new _(p.negint,r,1);Ee[64]=new _(p.bytes,new Uint8Array(0),1);Ee[96]=new _(p.string,"",1);Ee[128]=new _(p.array,0,1);Ee[160]=new _(p.map,0,1);Ee[244]=new _(p.false,!1,1);Ee[245]=new _(p.true,!0,1);Ee[246]=new _(p.null,null,1);function ul(){let r=[];return r[p.uint.major]=me,r[p.negint.major]=Xr,r[p.bytes.major]=_t,r[p.string.major]=Ks,r[p.array.major]=Zr,r[p.map.major]=Yr,r[p.tag.major]=Qr,r[p.float.major]=en,r}var Uy=ul(),$y=new Kr,rn=class r{constructor(e,t){this.obj=e,this.parent=t}includes(e){let t=this;do if(t.obj===e)return!0;while(t=t.parent);return!1}static createCheck(e,t){if(e&&e.includes(t))throw new Error(`${bt} object contains circular references`);return new r(t,e)}},Ve={null:new _(p.null,null),undefined:new _(p.undefined,void 0),true:new _(p.true,!0),false:new _(p.false,!1),emptyArray:new _(p.array,0),emptyMap:new _(p.map,0)},He={number(r,e,t,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new _(p.float,r):r>=0?new _(p.uint,r):new _(p.negint,r)},bigint(r,e,t,n){return r>=BigInt(0)?new _(p.uint,r):new _(p.negint,r)},Uint8Array(r,e,t,n){return new _(p.bytes,r)},string(r,e,t,n){return new _(p.string,r)},boolean(r,e,t,n){return r?Ve.true:Ve.false},null(r,e,t,n){return Ve.null},undefined(r,e,t,n){return Ve.undefined},ArrayBuffer(r,e,t,n){return new _(p.bytes,new Uint8Array(r))},DataView(r,e,t,n){return new _(p.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,e,t,n){if(!r.length)return t.addBreakTokens===!0?[Ve.emptyArray,new _(p.break)]:Ve.emptyArray;n=rn.createCheck(n,r);let i=[],o=0;for(let s of r)i[o++]=ki(s,t,n);return t.addBreakTokens?[new _(p.array,r.length),i,new _(p.break)]:[new _(p.array,r.length),i]},Object(r,e,t,n){let i=e!=="Object",o=i?r.keys():Object.keys(r),s=i?r.size:o.length;if(!s)return t.addBreakTokens===!0?[Ve.emptyMap,new _(p.break)]:Ve.emptyMap;n=rn.createCheck(n,r);let a=[],c=0;for(let h of o)a[c++]=[ki(h,t,n),ki(i?r.get(h):r[h],t,n)];return fl(a,t),t.addBreakTokens?[new _(p.map,s),a,new _(p.break)]:[new _(p.map,s),a]}};He.Map=He.Object;He.Buffer=He.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))He[`${r}Array`]=He.DataView;function ki(r,e={},t){let n=_s(r),i=e&&e.typeEncoders&&e.typeEncoders[n]||He[n];if(typeof i=="function"){let s=i(r,n,e,t);if(s!=null)return s}let o=He[n];if(!o)throw new Error(`${bt} unsupported type: ${n}`);return o(r,n,e,t)}function fl(r,e){e.mapSorter&&r.sort(e.mapSorter)}var ll={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},nn=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t}pos(){return this._pos}done(){return this._pos>=this.data.length}next(){let e=this.data[this._pos],t=Ee[e];if(t===void 0){let n=k[e];if(!n)throw new Error(`${v} no decoder for major type ${e>>>5} (byte 0x${e.toString(16).padStart(2,"0")})`);let i=e&31;t=n(this.data,this._pos,i,this.options)}return this._pos+=t.encodedLength,t}},sr=Symbol.for("DONE"),on=Symbol.for("BREAK");function hl(r,e,t){let n=[];for(let i=0;i<r.value;i++){let o=Et(e,t);if(o===on){if(r.value===1/0)break;throw new Error(`${v} got unexpected break to lengthed array`)}if(o===sr)throw new Error(`${v} found array but not enough entries (got ${i}, expected ${r.value})`);n[i]=o}return n}function dl(r,e,t){let n=t.useMaps===!0,i=n?void 0:{},o=n?new Map:void 0;for(let s=0;s<r.value;s++){let a=Et(e,t);if(a===on){if(r.value===1/0)break;throw new Error(`${v} got unexpected break to lengthed map`)}if(a===sr)throw new Error(`${v} found map but not enough entries (got ${s} [no key], expected ${r.value})`);if(n!==!0&&typeof a!="string")throw new Error(`${v} non-string keys not supported (got ${typeof a})`);if(t.rejectDuplicateMapKeys===!0&&(n&&o.has(a)||!n&&a in i))throw new Error(`${v} found repeat map key "${a}"`);let c=Et(e,t);if(c===sr)throw new Error(`${v} found map but not enough entries (got ${s} [no value], expected ${r.value})`);n?o.set(a,c):i[a]=c}return n?o:i}function Et(r,e){if(r.done())return sr;let t=r.next();if(t.type===p.break)return on;if(t.type.terminal)return t.value;if(t.type===p.array)return hl(t,r,e);if(t.type===p.map)return dl(t,r,e);if(t.type===p.tag){if(e.tags&&typeof e.tags[t.value]=="function"){let n=Et(r,e);return e.tags[t.value](n)}throw new Error(`${v} tag not supported (${t.value})`)}throw new Error("unsupported")}function Si(r,e){if(!(r instanceof Uint8Array))throw new Error(`${v} data to decode must be a Uint8Array`);e=Object.assign({},ll,e);let t=e.tokenizer||new nn(r,e),n=Et(t,e);if(n===sr)throw new Error(`${v} did not find any content to decode`);if(n===on)throw new Error(`${v} got unexpected break`);return[n,r.subarray(t.pos())]}function ar(r,e){let[t,n]=Si(r,e);if(n.length>0)throw new Error(`${v} too many terminals, data makes no sense`);return t}var ka=42;function yl(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}function gl(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let e=A.asCID(r);if(!e)return null;let t=new Uint8Array(e.bytes.byteLength+1);return t.set(e.bytes,1),[new _(p.tag,ka),new _(p.bytes,t)]}function wl(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function xl(r){if(Number.isNaN(r))throw new Error("`NaN` is not supported by the IPLD Data Model and cannot be encoded");if(r===1/0||r===-1/0)throw new Error("`Infinity` and `-Infinity` is not supported by the IPLD Data Model and cannot be encoded");return null}function bl(r){for(let e of r.keys())if(typeof e!="string"||e.length===0)throw new Error("Non-string Map keys are not supported by the IPLD Data Model and cannot be encoded");return null}var _a={float64:!0,typeEncoders:{Map:bl,Object:gl,undefined:wl,number:xl}},Ky={..._a,typeEncoders:{..._a.typeEncoders}};function _l(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return A.decode(r.subarray(1))}var sn={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};sn.tags[ka]=_l;var Xy={...sn,tags:sn.tags.slice()};var Sa=113;var Ea=r=>ar(yl(r),sn);var Ba=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(e){let t=this.inRecursive[this.inRecursive.length-1];t&&(t.type===p.array&&(t.elements++,t.elements!==1&&e.push([44])),t.type===p.map&&(t.elements++,t.elements!==1&&(t.elements%2===1?e.push([44]):e.push([58]))))}[p.uint.major](e,t){this.prefix(e);let n=String(t.value),i=[];for(let o=0;o<n.length;o++)i[o]=n.charCodeAt(o);e.push(i)}[p.negint.major](e,t){this[p.uint.major](e,t)}[p.bytes.major](e,t){throw new Error(`${bt} unsupported type: Uint8Array`)}[p.string.major](e,t){this.prefix(e);let n=Wr(JSON.stringify(t.value));e.push(n.length>32?Gr(n):n)}[p.array.major](e,t){this.prefix(e),this.inRecursive.push({type:p.array,elements:0}),e.push([91])}[p.map.major](e,t){this.prefix(e),this.inRecursive.push({type:p.map,elements:0}),e.push([123])}[p.tag.major](e,t){}[p.float.major](e,t){if(t.type.name==="break"){let s=this.inRecursive.pop();if(s){if(s.type===p.array)e.push([93]);else if(s.type===p.map)e.push([125]);else throw new Error("Unexpected recursive type; this should not happen!");return}throw new Error("Unexpected break; this should not happen!")}if(t.value===void 0)throw new Error(`${bt} unsupported type: undefined`);if(this.prefix(e),t.type.name==="true"){e.push([116,114,117,101]);return}else if(t.type.name==="false"){e.push([102,97,108,115,101]);return}else if(t.type.name==="null"){e.push([110,117,108,108]);return}let n=String(t.value),i=[],o=!1;for(let s=0;s<n.length;s++)i[s]=n.charCodeAt(s),!o&&(i[s]===46||i[s]===101||i[s]===69)&&(o=!0);o||(i.push(46),i.push(48)),e.push(i)}};var vt=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t,this.modeStack=["value"],this.lastToken=""}pos(){return this._pos}done(){return this._pos>=this.data.length}ch(){return this.data[this._pos]}currentMode(){return this.modeStack[this.modeStack.length-1]}skipWhitespace(){let e=this.ch();for(;e===32||e===9||e===13||e===10;)e=this.data[++this._pos]}expect(e){if(this.data.length-this._pos<e.length)throw new Error(`${v} unexpected end of input at position ${this._pos}`);for(let t=0;t<e.length;t++)if(this.data[this._pos++]!==e[t])throw new Error(`${v} unexpected token at position ${this._pos}, expected to find '${String.fromCharCode(...e)}'`)}parseNumber(){let e=this._pos,t=!1,n=!1,i=a=>{for(;!this.done();){let c=this.ch();if(a.includes(c))this._pos++;else break}};if(this.ch()===45&&(t=!0,this._pos++),this.ch()===48)if(this._pos++,this.ch()===46)this._pos++,n=!0;else return new _(p.uint,0,this._pos-e);if(i([48,49,50,51,52,53,54,55,56,57]),t&&this._pos===e+1)throw new Error(`${v} unexpected token at position ${this._pos}`);if(!this.done()&&this.ch()===46){if(n)throw new Error(`${v} unexpected token at position ${this._pos}`);n=!0,this._pos++,i([48,49,50,51,52,53,54,55,56,57])}!this.done()&&(this.ch()===101||this.ch()===69)&&(n=!0,this._pos++,!this.done()&&(this.ch()===43||this.ch()===45)&&this._pos++,i([48,49,50,51,52,53,54,55,56,57]));let o=String.fromCharCode.apply(null,this.data.subarray(e,this._pos)),s=parseFloat(o);return n?new _(p.float,s,this._pos-e):this.options.allowBigInt!==!0||Number.isSafeInteger(s)?new _(s>=0?p.uint:p.negint,s,this._pos-e):new _(s>=0?p.uint:p.negint,BigInt(o),this._pos-e)}parseString(){if(this.ch()!==34)throw new Error(`${v} unexpected character at position ${this._pos}; this shouldn't happen`);this._pos++;for(let o=this._pos,s=0;o<this.data.length&&s<65536;o++,s++){let a=this.data[o];if(a===92||a<32||a>=128)break;if(a===34){let c=String.fromCharCode.apply(null,this.data.subarray(this._pos,o));return this._pos=o+1,new _(p.string,c,s)}}let e=this._pos,t=[],n=()=>{if(this._pos+4>=this.data.length)throw new Error(`${v} unexpected end of unicode escape sequence at position ${this._pos}`);let o=0;for(let s=0;s<4;s++){let a=this.ch();if(a>=48&&a<=57)a-=48;else if(a>=97&&a<=102)a=a-97+10;else if(a>=65&&a<=70)a=a-65+10;else throw new Error(`${v} unexpected unicode escape character at position ${this._pos}`);o=o*16+a,this._pos++}return o},i=()=>{let o=this.ch(),s=null,a=o>239?4:o>223?3:o>191?2:1;if(this._pos+a>this.data.length)throw new Error(`${v} unexpected unicode sequence at position ${this._pos}`);let c,h,f,l;switch(a){case 1:o<128&&(s=o);break;case 2:c=this.data[this._pos+1],(c&192)===128&&(l=(o&31)<<6|c&63,l>127&&(s=l));break;case 3:c=this.data[this._pos+1],h=this.data[this._pos+2],(c&192)===128&&(h&192)===128&&(l=(o&15)<<12|(c&63)<<6|h&63,l>2047&&(l<55296||l>57343)&&(s=l));break;case 4:c=this.data[this._pos+1],h=this.data[this._pos+2],f=this.data[this._pos+3],(c&192)===128&&(h&192)===128&&(f&192)===128&&(l=(o&15)<<18|(c&63)<<12|(h&63)<<6|f&63,l>65535&&l<1114112&&(s=l))}s===null?(s=65533,a=1):s>65535&&(s-=65536,t.push(s>>>10&1023|55296),s=56320|s&1023),t.push(s),this._pos+=a};for(;!this.done();){let o=this.ch(),s;switch(o){case 92:if(this._pos++,this.done())throw new Error(`${v} unexpected string termination at position ${this._pos}`);switch(s=this.ch(),this._pos++,s){case 34:case 39:case 92:case 47:t.push(s);break;case 98:t.push(8);break;case 116:t.push(9);break;case 110:t.push(10);break;case 102:t.push(12);break;case 114:t.push(13);break;case 117:t.push(n());break;default:throw new Error(`${v} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new _(p.string,gi(t),this._pos-e);default:if(o<32)throw new Error(`${v} invalid control character at position ${this._pos}`);o<128?(t.push(o),this._pos++):i()}}throw new Error(`${v} unexpected end of string at position ${this._pos}`)}parseValue(){switch(this.ch()){case 123:return this.modeStack.push("obj-start"),this._pos++,new _(p.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new _(p.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new _(p.null,null,4);case 102:return this.expect([102,97,108,115,101]),new _(p.false,!1,5);case 116:return this.expect([116,114,117,101]),new _(p.true,!0,4);case 45:case 48:case 49:case 50:case 51:case 52:case 53:case 54:case 55:case 56:case 57:return this.parseNumber();default:throw new Error(`${v} unexpected character at position ${this._pos}`)}}next(){switch(this.skipWhitespace(),this.currentMode()){case"value":return this.modeStack.pop(),this.parseValue();case"array-value":{if(this.modeStack.pop(),this.ch()===93)return this._pos++,this.skipWhitespace(),new _(p.break,void 0,1);if(this.ch()!==44)throw new Error(`${v} unexpected character at position ${this._pos}, was expecting array delimiter but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue()}case"array-start":return this.modeStack.pop(),this.ch()===93?(this._pos++,this.skipWhitespace(),new _(p.break,void 0,1)):(this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue());case"obj-key":if(this.ch()===125)return this.modeStack.pop(),this._pos++,this.skipWhitespace(),new _(p.break,void 0,1);if(this.ch()!==44)throw new Error(`${v} unexpected character at position ${this._pos}, was expecting object delimiter but found '${String.fromCharCode(this.ch())}'`);this._pos++,this.skipWhitespace();case"obj-start":{if(this.modeStack.pop(),this.ch()===125)return this._pos++,this.skipWhitespace(),new _(p.break,void 0,1);let e=this.parseString();if(this.skipWhitespace(),this.ch()!==58)throw new Error(`${v} unexpected character at position ${this._pos}, was expecting key/value delimiter ':' but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("obj-value"),e}case"obj-value":return this.modeStack.pop(),this.modeStack.push("obj-key"),this.skipWhitespace(),this.parseValue();default:throw new Error(`${v} unexpected parse state at position ${this._pos}; this shouldn't happen`)}}};function Ei(r,e){return e=Object.assign({tokenizer:new vt(r,e)},e),ar(r,e)}function El(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var vi=class extends vt{constructor(e,t){super(e,t),this.tokenBuffer=[]}done(){return this.tokenBuffer.length===0&&super.done()}_next(){return this.tokenBuffer.length>0?this.tokenBuffer.pop():super.next()}next(){let e=this._next();if(e.type===p.map){let t=this._next();if(t.type===p.string&&t.value==="/"){let n=this._next();if(n.type===p.string){if(this._next().type!==p.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new _(p.tag,42,0)}if(n.type===p.map){let i=this._next();if(i.type===p.string&&i.value==="bytes"){let o=this._next();if(o.type===p.string){for(let a=0;a<2;a++)if(this._next().type!==p.break)throw new Error("Invalid encoded Bytes form");let s=Gt.decode(`m${o.value}`);return new _(p.bytes,s,o.value.length)}this.tokenBuffer.push(o)}this.tokenBuffer.push(i)}this.tokenBuffer.push(n)}this.tokenBuffer.push(t)}return e}},Bi={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Bi.tags[42]=A.parse;var Ia=297;var Aa=r=>{let e=El(r),t=Object.assign(Bi,{tokenizer:new vi(e,Bi)});return Ei(e,t)};var dg=new TextDecoder;var pg=new TextEncoder;function vl(r){return r[Symbol.asyncIterator]!=null}function Bl(r){if(vl(r))return(async()=>{let n=new Uint8Array(0);for await(let i of r)n=Ie([n,i],n.length+i.length);return n})();let e=[],t=0;for(let n of r)e.push(n),t+=n.byteLength;return Ie(e,t)}var z=Bl;function Bt(r,e,t,n,i,o,s){let a=r,c=i;for(;o.length>0;){let h=o[0];if(h in a){o.shift(),c=`${c}/${h}`;let f=A.asCID(a[h]);if(f!=null)return{entry:{type:"object",name:n,path:i,cid:t,node:e,depth:s,size:BigInt(e.length),content:async function*(){yield r}},next:{cid:f,name:h,path:c,toResolve:o}};a=a[h]}else throw new jr(`No property named ${h} found in node ${t}`)}return{entry:{type:"object",name:n,path:i,cid:t,node:e,depth:s,size:BigInt(e.length),content:async function*(){yield r}}}}var Il=async(r,e,t,n,i,o,s,a)=>{let c=await z(s.get(r,a)),h=Ea(c);return Bt(h,c,r,e,t,n,o)},Na=Il;var Al=async(r,e,t,n,i,o,s,a)=>{let c=await z(s.get(r,a)),h=Aa(c);return Bt(h,c,r,e,t,n,o)},Ta=Al;function Cl(r,e,t,n){let i=BigInt(r.length),o=BigInt(e+i);return t>=o||n<e?new Uint8Array(0):(n>=e&&n<o&&(r=r.subarray(0,Number(n-e))),t>=e&&t<o&&(r=r.subarray(Number(t-e))),r)}var Qe=Cl;var Nl=(r,e=0,t=r)=>{let n=BigInt(r),i=BigInt(e??0),o=BigInt(t);if(o!==n&&(o=i+o),o>n&&(o=n),i<0n)throw new Ze("Offset must be greater than or equal to 0");if(i>n)throw new Ze("Offset must be less than the file size");if(o<0n)throw new Ze("Length must be greater than or equal to 0");if(o>n)throw new Ze("Length must be less than the file size");return{start:i,end:o}},It=Nl;var Tl=r=>{async function*e(t={}){let{start:n,end:i}=It(r.length,t.offset,t.length),o=Qe(r,0n,n,i);t.onProgress?.(new U("unixfs:exporter:progress:identity",{bytesRead:BigInt(o.byteLength),totalBytes:i-n,fileSize:BigInt(r.byteLength)})),yield o}return e},Dl=async(r,e,t,n,i,o,s,a)=>{if(n.length>0)throw new pe(`No link named ${t} found in raw node ${r}`);let c=Er(r.multihash.bytes);return{entry:{type:"identity",name:e,path:t,cid:r,content:Tl(c.digest),depth:o,size:BigInt(c.digest.length),node:c.digest}}},Da=Dl;var Ll=async(r,e,t,n,i,o,s,a)=>{let c=await z(s.get(r,a)),h=Do(c);return Bt(h,c,r,e,t,n,o)},La=Ll;var zl=r=>{async function*e(t={}){let{start:n,end:i}=It(r.length,t.offset,t.length),o=Qe(r,0n,n,i);t.onProgress?.(new U("unixfs:exporter:progress:raw",{bytesRead:BigInt(o.byteLength),totalBytes:i-n,fileSize:BigInt(r.byteLength)})),yield o}return e},Fl=async(r,e,t,n,i,o,s,a)=>{if(n.length>0)throw new pe(`No link named ${t} found in raw node ${r}`);let c=await z(s.get(r,a));return{entry:{type:"raw",name:e,path:t,cid:r,content:zl(c),depth:o,size:BigInt(c.length),node:c}}},za=Fl;var Pl=async function(r){return(await Xe.encode(r)).slice(0,8).reverse()},Ul=async(r,e,t)=>{let n=(e.tableSize()-1).toString(16).length;await Promise.all(r.map(async i=>{if(i.Name==null)throw new Error("Unexpected Link without a Name");if(i.Name.length===n){let o=parseInt(i.Name,16);e._putObjectAt(o,new se({hash:t._options.hash,bits:t._options.bits},e,o));return}await t.put(i.Name.substring(2),!0)}))},Fa=(r,e)=>r.toString(16).toUpperCase().padStart(e,"0").substring(0,e),$l=r=>{let e=r.bucket,t=[];for(;e._parent!=null;)t.push(e),e=e._parent;return t.push(e),t.reverse()},Pa=async(r,e,t,n,i)=>{if(n==null){if(r.Data==null)throw new H("no data in PBNode");let l;try{l=I.unmarshal(r.Data)}catch(u){throw new H(u.message)}if(l.type!=="hamt-sharded-directory")throw new H("not a HAMT");if(l.fanout==null)throw new H("missing fanout");let y=yt({hashFn:Pl,bits:Math.log2(Number(l.fanout))});n={rootBucket:y,hamtDepth:1,lastBucket:y}}let o=(n.lastBucket.tableSize()-1).toString(16).length;await Ul(r.Links,n.lastBucket,n.rootBucket);let s=await n.rootBucket._findNewBucketAndPos(e),a=Fa(s.pos,o),c=$l(s);c.length>n.hamtDepth&&(n.lastBucket=c[n.hamtDepth],a=Fa(n.lastBucket._posAtParent,o));let h=r.Links.find(l=>{if(l.Name==null)return!1;let y=l.Name.substring(0,o),u=l.Name.substring(o);return!(y!==a||u!==""&&u!==e)});if(h==null)return;if(h.Name!=null&&h.Name.substring(o)===e)return h.Hash;n.hamtDepth++;let f=await z(t.get(h.Hash,i));return r=$(f),Pa(r,e,t,n,i)},Ua=Pa;function At(r){return r?.extended===!1}function Rl(r){let[e,t]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>e.next(),push:i=>{n.push(i)},next:()=>n.length>0?{done:!1,value:n.shift()}:e.next(),[t](){return this}}}var an=Rl;function Ml(r){return r[Symbol.asyncIterator]!=null}function Ol(r,e){let t=0;if(Ml(r))return(async function*(){for await(let c of r)await e(c,t++)&&(yield c)})();let n=an(r),{value:i,done:o}=n.next();if(o===!0)return(function*(){})();let s=e(i,t++);if(typeof s.then=="function")return(async function*(){await s&&(yield i);for(let c of n)await e(c,t++)&&(yield c)})();let a=e;return(function*(){s===!0&&(yield i);for(let c of n)a(c,t++)&&(yield c)})()}var $a=Ol;function Vl(r){return r[Symbol.asyncIterator]!=null}function Hl(r,e){let t=0;if(Vl(r))return(async function*(){for await(let c of r)yield e(c,t++)})();let n=an(r),{value:i,done:o}=n.next();if(o===!0)return(function*(){})();let s=e(i,t++);if(typeof s.then=="function")return(async function*(){yield await s;for(let c of n)yield e(c,t++)})();let a=e;return(function*(){yield s;for(let c of n)yield a(c,t++)})()}var Ct=Hl;function te(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var cn=globalThis.CustomEvent??Event;async function*et(r,e={}){let t=e.concurrency??1/0;t<1&&(t=1/0);let n=e.ordered??!1,i=new EventTarget,o=[],s=te(),a=te(),c=!1,h,f=!1;i.addEventListener("task-complete",()=>{a.resolve()}),Promise.resolve().then(async()=>{try{for await(let d of r){if(o.length===t&&(s=te(),await s.promise),f)break;let m={done:!1};o.push(m),d().then(x=>{m.done=!0,m.ok=!0,m.value=x,i.dispatchEvent(new cn("task-complete"))},x=>{m.done=!0,m.err=x,i.dispatchEvent(new cn("task-complete"))})}c=!0,i.dispatchEvent(new cn("task-complete"))}catch(d){h=d,i.dispatchEvent(new cn("task-complete"))}});function l(){return n?o[0]?.done:!!o.find(d=>d.done)}function*y(){for(;o.length>0&&o[0].done;){let d=o[0];if(o.shift(),d.ok)yield d.value;else throw f=!0,s.resolve(),d.err;s.resolve()}}function*u(){for(;l();)for(let d=0;d<o.length;d++)if(o[d].done){let m=o[d];if(o.splice(d,1),d--,m.ok)yield m.value;else throw f=!0,s.resolve(),m.err;s.resolve()}}for(;;){if(l()||(a=te(),await a.promise),h!=null||(n?yield*y():yield*u(),h!=null))throw h;if(c&&o.length===0)break}}var un=class{buffer;mask;top;btm;next;constructor(e){if(!(e>0)||(e-1&e)!==0)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},Nt=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new un(this.hwm),this.tail=this.head,this.size=0}calculateSize(e){return e?.byteLength!=null?e.byteLength:1}push(e){if(e?.value!=null&&(this.size+=this.calculateSize(e.value)),!this.head.push(e)){let t=this.head;this.head=t.next=new un(2*this.head.buffer.length),this.head.push(e)}}shift(){let e=this.tail.shift();if(e===void 0&&this.tail.next!=null){let t=this.tail.next;this.tail.next=null,this.tail=t,e=this.tail.shift()}return e?.value!=null&&(this.size-=this.calculateSize(e.value)),e}isEmpty(){return this.head.isEmpty()}};var Ii=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function fn(r={}){return jl(t=>{let n=t.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function jl(r,e){e=e??{};let t=e.onEnd,n=new Nt,i,o,s,a=te(),c=async()=>{try{return n.isEmpty()?s?{done:!0}:await new Promise((x,g)=>{o=w=>{o=null,n.push(w);try{x(r(n))}catch(b){g(b)}return i}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=te()})}},h=x=>o!=null?o(x):(n.push(x),i),f=x=>(n=new Nt,o!=null?o({error:x}):(n.push({error:x}),i)),l=x=>{if(s)return i;if(e?.objectMode!==!0&&x?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return h({done:!1,value:x})},y=x=>s?i:(s=!0,x!=null?f(x):h({done:!0})),u=()=>(n=new Nt,y(),{done:!0}),d=x=>(y(x),{done:!0});if(i={[Symbol.asyncIterator](){return this},next:c,return:u,throw:d,push:l,end:y,get readableLength(){return n.size},onEmpty:async x=>{let g=x?.signal;if(g?.throwIfAborted(),n.isEmpty())return;let w,b;g!=null&&(w=new Promise((S,B)=>{b=()=>{B(new Ii)},g.addEventListener("abort",b)}));try{await Promise.race([a.promise,w])}finally{b!=null&&g!=null&&g?.removeEventListener("abort",b)}}},t==null)return i;let m=i;return i={[Symbol.asyncIterator](){return this},next(){return m.next()},throw(x){return m.throw(x),t!=null&&(t(x),t=void 0),{done:!0}},return(){return m.return(),t!=null&&(t(),t=void 0),{done:!0}},push:l,end(x){return m.end(x),t!=null&&(t(x),t=void 0),i},get readableLength(){return m.readableLength},onEmpty:x=>m.onEmpty(x)},i}var ln=class extends Error{type;code;constructor(e,t,n){super(e??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=t??"ABORT_ERR"}};async function Ra(r,e,t){if(e==null)return r;if(e.aborted)return r.catch(()=>{}),Promise.reject(new ln(t?.errorMessage,t?.errorCode,t?.errorName));let n,i=new ln(t?.errorMessage,t?.errorCode,t?.errorName);try{return await Promise.race([r,new Promise((o,s)=>{n=()=>{s(i)},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var Ai=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=te(),this.haveNext=te()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let e=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=te(),e}async throw(e){return this.ended=!0,this.error=e,e!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(e)),{done:!0,value:void 0}}async return(){let e={done:!0,value:void 0};return this.ended=!0,this.nextResult=e,this.haveNext.resolve(),e}async push(e,t){await this._push(e,t)}async end(e,t){e!=null?await this.throw(e):await this._push(void 0,t)}async _push(e,t){if(e!=null&&this.ended)throw this.error??new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;e!=null?this.nextResult={done:!1,value:e}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=te(),await Ra(this.readNext.promise,t?.signal,t)}};function Ma(){return new Ai}function ql(r){return r[Symbol.asyncIterator]!=null}async function Gl(r,e,t){try{await Promise.all(r.map(async n=>{for await(let i of n)await e.push(i,{signal:t}),t.throwIfAborted()})),await e.end(void 0,{signal:t})}catch(n){await e.end(n,{signal:t}).catch(()=>{})}}async function*Wl(r){let e=new AbortController,t=Ma();Gl(r,t,e.signal).catch(()=>{});try{yield*t}finally{e.abort()}}function*Kl(r){for(let e of r)yield*e}function Xl(...r){let e=[];for(let t of r)ql(t)||e.push(t);return e.length===r.length?Kl(e):Wl(r)}var Oa=Xl;function De(r,...e){if(r==null)throw new Error("Empty pipeline");if(Ci(r)){let n=r;r=()=>n.source}else if(Ha(r)||Va(r)){let n=r;r=()=>n}let t=[r,...e];if(t.length>1&&Ci(t[t.length-1])&&(t[t.length-1]=t[t.length-1].sink),t.length>2)for(let n=1;n<t.length-1;n++)Ci(t[n])&&(t[n]=Zl(t[n]));return Jl(...t)}var Jl=(...r)=>{let e;for(;r.length>0;)e=r.shift()(e);return e},Va=r=>r?.[Symbol.asyncIterator]!=null,Ha=r=>r?.[Symbol.iterator]!=null,Ci=r=>r==null?!1:r.sink!=null&&r.source!=null,Zl=r=>e=>{let t=r.sink(e);if(t?.then!=null){let n=fn({objectMode:!0});t.then(()=>{n.end()},s=>{n.end(s)});let i,o=r.source;if(Va(o))i=async function*(){yield*o,n.end()};else if(Ha(o))i=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Oa(n,i())}return r.source};var Yl=(r,e,t,n,i,o,s)=>{async function*a(c={}){let h=c.offset??0,f=c.length??e.Links.length,l=e.Links.slice(h,f);c.onProgress?.(new U("unixfs:exporter:walk:directory",{cid:r})),yield*De(l,y=>Ct(y,u=>async()=>{let d=u.Name??"",m=`${n}/${d}`;return At(c)?{cid:u.Hash,name:d,path:m}:(await i(u.Hash,d,m,[],o+1,s,c)).entry}),y=>et(y,{ordered:!0,concurrency:c.blockReadConcurrency}),y=>$a(y,u=>u!=null))}return a},ja=Yl;var Ti=Ft(Ga(),1);var Di=class r extends Error{name="TimeoutError";constructor(e,t){super(e,t),Error.captureStackTrace?.(this,r)}},Wa=r=>r.reason??new DOMException("This operation was aborted.","AbortError");function Li(r,e){let{milliseconds:t,fallback:n,message:i,customTimers:o={setTimeout,clearTimeout},signal:s}=e,a,c,f=new Promise((l,y)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(s?.aborted){y(Wa(s));return}if(s&&(c=()=>{y(Wa(s))},s.addEventListener("abort",c,{once:!0})),r.then(l,y),t===Number.POSITIVE_INFINITY)return;let u=new Di;a=o.setTimeout.call(void 0,()=>{if(n){try{l(n())}catch(d){y(d)}return}typeof r.cancel=="function"&&r.cancel(),i===!1?l():i instanceof Error?y(i):(u.message=i??`Promise timed out after ${t} milliseconds`,y(u))},t)}).finally(()=>{f.clear(),c&&s&&s.removeEventListener("abort",c)});return f.clear=()=>{o.clearTimeout.call(void 0,a),a=void 0},f}function zi(r,e,t){let n=0,i=r.length;for(;i>0;){let o=Math.trunc(i/2),s=n+o;t(r[s],e)<=0?(n=++s,i-=o+1):i=o}return n}var ur=class{#t=[];enqueue(e,t){let{priority:n=0,id:i}=t??{},o={priority:n,id:i,run:e};if(this.size===0||this.#t[this.size-1].priority>=n){this.#t.push(o);return}let s=zi(this.#t,o,(a,c)=>c.priority-a.priority);this.#t.splice(s,0,o)}setPriority(e,t){let n=this.#t.findIndex(o=>o.id===e);if(n===-1)throw new ReferenceError(`No promise function with the id "${e}" exists in the queue.`);let[i]=this.#t.splice(n,1);this.enqueue(i.run,{priority:t,id:e})}dequeue(){return this.#t.shift()?.run}filter(e){return this.#t.filter(t=>t.priority===e.priority).map(t=>t.run)}get size(){return this.#t.length}};var fr=class extends Ti.default{#t;#n;#i=0;#d;#p=!1;#m=!1;#u;#x=0;#y=0;#o;#s;#e;#b;#r=0;#f;#a;#B=1n;#l=new Map;timeout;constructor(e){if(super(),e={carryoverIntervalCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:ur,...e},!(typeof e.intervalCap=="number"&&e.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${e.intervalCap?.toString()??""}\` (${typeof e.intervalCap})`);if(e.interval===void 0||!(Number.isFinite(e.interval)&&e.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${e.interval?.toString()??""}\` (${typeof e.interval})`);if(this.#t=e.carryoverIntervalCount??e.carryoverConcurrencyCount??!1,this.#n=e.intervalCap===Number.POSITIVE_INFINITY||e.interval===0,this.#d=e.intervalCap,this.#u=e.interval,this.#e=new e.queueClass,this.#b=e.queueClass,this.concurrency=e.concurrency,e.timeout!==void 0&&!(Number.isFinite(e.timeout)&&e.timeout>0))throw new TypeError(`Expected \`timeout\` to be a positive finite number, got \`${e.timeout}\` (${typeof e.timeout})`);this.timeout=e.timeout,this.#a=e.autoStart===!1,this.#z()}get#I(){return this.#n||this.#i<this.#d}get#A(){return this.#r<this.#f}#C(){this.#r--,this.#r===0&&this.emit("pendingZero"),this.#g(),this.emit("next")}#N(){this.#E(),this.#S(),this.#s=void 0}get#T(){let e=Date.now();if(this.#o===void 0){let t=this.#x-e;if(t<0){if(this.#y>0){let n=e-this.#y;if(n<this.#u)return this.#_(this.#u-n),!0}this.#i=this.#t?this.#r:0}else return this.#_(t),!0}return!1}#_(e){this.#s===void 0&&(this.#s=setTimeout(()=>{this.#N()},e))}#k(){this.#o&&(clearInterval(this.#o),this.#o=void 0)}#D(){this.#s&&(clearTimeout(this.#s),this.#s=void 0)}#g(){if(this.#e.size===0)return this.#k(),this.emit("empty"),this.#r===0&&(this.#D(),this.emit("idle")),!1;let e=!1;if(!this.#a){let t=!this.#T;if(this.#I&&this.#A){let n=this.#e.dequeue();this.#n||(this.#i++,this.#h()),this.emit("active"),this.#y=Date.now(),n(),t&&this.#S(),e=!0}}return e}#S(){this.#n||this.#o!==void 0||(this.#o=setInterval(()=>{this.#E()},this.#u),this.#x=Date.now()+this.#u)}#E(){this.#i===0&&this.#r===0&&this.#o&&this.#k(),this.#i=this.#t?this.#r:0,this.#w(),this.#h()}#w(){for(;this.#g(););}get concurrency(){return this.#f}set concurrency(e){if(!(typeof e=="number"&&e>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${e}\` (${typeof e})`);this.#f=e,this.#w()}async#L(e){return new Promise((t,n)=>{e.addEventListener("abort",()=>{n(e.reason)},{once:!0})})}setPriority(e,t){if(typeof t!="number"||!Number.isFinite(t))throw new TypeError(`Expected \`priority\` to be a finite number, got \`${t}\` (${typeof t})`);this.#e.setPriority(e,t)}async add(e,t={}){return t.id??=(this.#B++).toString(),t={timeout:this.timeout,...t},new Promise((n,i)=>{let o=Symbol(`task-${t.id}`);this.#e.enqueue(async()=>{this.#r++,this.#l.set(o,{id:t.id,priority:t.priority??0,startTime:Date.now(),timeout:t.timeout});try{try{t.signal?.throwIfAborted()}catch(c){throw this.#n||this.#i--,this.#l.delete(o),c}let s=e({signal:t.signal});t.timeout&&(s=Li(Promise.resolve(s),{milliseconds:t.timeout,message:`Task timed out after ${t.timeout}ms (queue has ${this.#r} running, ${this.#e.size} waiting)`})),t.signal&&(s=Promise.race([s,this.#L(t.signal)]));let a=await s;n(a),this.emit("completed",a)}catch(s){i(s),this.emit("error",s)}finally{this.#l.delete(o),queueMicrotask(()=>{this.#C()})}},t),this.emit("add"),this.#g()})}async addAll(e,t){return Promise.all(e.map(async n=>this.add(n,t)))}start(){return this.#a?(this.#a=!1,this.#w(),this):this}pause(){this.#a=!0}clear(){this.#e=new this.#b,this.#v()}async onEmpty(){this.#e.size!==0&&await this.#c("empty")}async onSizeLessThan(e){this.#e.size<e||await this.#c("next",()=>this.#e.size<e)}async onIdle(){this.#r===0&&this.#e.size===0||await this.#c("idle")}async onPendingZero(){this.#r!==0&&await this.#c("pendingZero")}async onRateLimit(){this.isRateLimited||await this.#c("rateLimit")}async onRateLimitCleared(){this.isRateLimited&&await this.#c("rateLimitCleared")}async onError(){return new Promise((e,t)=>{let n=i=>{this.off("error",n),t(i)};this.on("error",n)})}async#c(e,t){return new Promise(n=>{let i=()=>{t&&!t()||(this.off(e,i),n())};this.on(e,i)})}get size(){return this.#e.size}sizeBy(e){return this.#e.filter(e).length}get pending(){return this.#r}get isPaused(){return this.#a}#z(){this.#n||(this.on("add",()=>{this.#e.size>0&&this.#h()}),this.on("next",()=>{this.#h()}))}#h(){this.#n||this.#m||(this.#m=!0,queueMicrotask(()=>{this.#m=!1,this.#v()}))}#v(){let e=this.#p,t=!this.#n&&this.#i>=this.#d&&this.#e.size>0;t!==e&&(this.#p=t,this.emit(t?"rateLimit":"rateLimitCleared"))}get isRateLimited(){return this.#p}get isSaturated(){return this.#r===this.#f&&this.#e.size>0||this.isRateLimited&&this.#e.size>0}get runningTasks(){return[...this.#l.values()].map(e=>({...e}))}};async function Ka(r,e,t,n,i,o,s){if(e instanceof Uint8Array){let h=Qe(e,n,i,o);t.push(h);return}if(e.Data==null)throw new H("no data in PBNode");let a;try{a=I.unmarshal(e.Data)}catch(h){throw new H(h.message)}if(a.data!=null){let h=a.data,f=Qe(h,n,i,o);t.push(f),n+=BigInt(f.byteLength)}let c=[];if(e.Links.length!==a.blockSizes.length)throw new H("Inconsistent block sizes and dag links");for(let h=0;h<e.Links.length;h++){let f=e.Links[h],l=n,y=l+a.blockSizes[h];if((i>=l&&i<y||o>=l&&o<=y||i<l&&o>y)&&c.push({link:f,blockStart:n}),n=y,n>o)break}await De(c,h=>Ct(h,f=>async()=>{let l=await z(r.get(f.link.Hash,s));return{...f,block:l}}),h=>et(h,{ordered:!0,concurrency:s.blockReadConcurrency}),async h=>{for await(let{link:f,block:l,blockStart:y}of h){let u;switch(f.Hash.code){case q:u=$(l);break;case Q:u=l;break;default:t.end(new H(`Unsupported codec: ${f.Hash.code}`));return}let d=new fr({concurrency:1});d.on("error",m=>{t.end(m)}),d.add(async()=>{s.onProgress?.(new U("unixfs:exporter:walk:file",{cid:f.Hash})),await Ka(r,u,t,y,i,o,s)}),await d.onIdle()}}),n>=o&&t.end()}var th=(r,e,t,n,i,o,s)=>{async function*a(c={}){let h=t.fileSize();if(h===void 0)throw new Error("File was a directory");let{start:f,end:l}=It(h,c.offset,c.length);if(l===0n)return;let y=0n,u=l-f,d=fn();c.onProgress?.(new U("unixfs:exporter:walk:file",{cid:r})),Ka(s,e,d,0n,f,l,c).catch(m=>{d.end(m)});for await(let m of d)if(m!=null){if(y+=BigInt(m.byteLength),y>u)throw d.end(),new Vr("Read too many bytes - the file size reported by the UnixFS data in the root node may be incorrect");y===u&&d.end(),c.onProgress?.(new U("unixfs:exporter:progress:unixfs:file",{bytesRead:y,totalBytes:u,fileSize:h})),yield m}if(y<u)throw new Hr("Traversed entire DAG but did not read enough bytes")}return a},Fi=th;var rh=(r,e,t,n,i,o,s)=>{function a(c={}){return c.onProgress?.(new U("unixfs:exporter:walk:hamt-sharded-directory",{cid:r})),Xa(e,n,i,o,s,c)}return a};async function*Xa(r,e,t,n,i,o){let s=r.Links;if(r.Data==null)throw new H("no data in PBNode");let a;try{a=I.unmarshal(r.Data)}catch(f){throw new H(f.message)}if(a.fanout==null)throw new H("missing fanout");let c=(a.fanout-1n).toString(16).length,h=De(s,f=>Ct(f,l=>async()=>{let y=l.Name!=null?l.Name.substring(c):null;if(y!=null&&y!==""){let u=`${e}/${y}`;return At(o)?{entries:[{cid:l.Hash,name:y,path:u}]}:{entries:[(await t(l.Hash,y,u,[],n+1,i,o)).entry].filter(Boolean)}}else{let u=await z(i.get(l.Hash,o));return r=$(u),o.onProgress?.(new U("unixfs:exporter:walk:hamt-sharded-directory",{cid:l.Hash})),{entries:Xa(r,e,t,n,i,o)}}}),f=>et(f,{ordered:!0,concurrency:o.blockReadConcurrency}));for await(let{entries:f}of h)yield*f}var Ja=rh;var nh=(r,e)=>r.Links.find(n=>n.Name===e)?.Hash,ih={raw:Fi,file:Fi,directory:ja,"hamt-sharded-directory":Ja,metadata:(r,e,t,n,i,o,s)=>()=>[],symlink:(r,e,t,n,i,o,s)=>()=>[]},oh=async(r,e,t,n,i,o,s,a)=>{if(At(a)&&n.length===0)return{entry:{cid:r,name:e,path:t}};let c=await z(s.get(r,a)),h=$(c),f,l;if(e==null&&(e=r.toString()),h.Data==null)throw new H("no data in PBNode");try{f=I.unmarshal(h.Data)}catch(u){throw new H(u.message)}if(t==null&&(t=e),n.length>0){let u;if(f?.type==="hamt-sharded-directory"?u=await Ua(h,n[0],s):u=nh(h,n[0]),u==null)throw new pe("file does not exist");let d=n.shift(),m=`${t}/${d}`;l={cid:u,toResolve:n,name:d??"",path:m}}let y=ih[f.type](r,h,f,t,i,o,s);if(y==null)throw new pe("could not find content exporter");return f.isDirectory()?{entry:{type:"directory",name:e,path:t,cid:r,content:y,unixfs:f,depth:o,node:h,size:f.fileSize()},next:l}:{entry:{type:"file",name:e,path:t,cid:r,content:y,unixfs:f,depth:o,node:h,size:f.fileSize()},next:l}},Za=oh;var sh={[q]:Za,[Q]:za,[Sa]:Na,[Ia]:Ta,[ri.code]:Da,[To]:La},Ya=async(r,e,t,n,i,o,s)=>{let a=sh[r.code];if(a==null)throw new Or(`No resolver for code ${r.code}`);return a(r,e,t,n,Ya,i,o,s)},Qa=Ya;var ah=(r="")=>(r.trim().match(/([^\\^/]|\\\/)+/g)??[]).filter(Boolean),ch=r=>{if(r instanceof Uint8Array)return{cid:A.decode(r),toResolve:[]};let e=A.asCID(r);if(e!=null)return{cid:e,toResolve:[]};if(typeof r=="string"){r.indexOf("/ipfs/")===0&&(r=r.substring(6));let t=ah(r);return{cid:A.parse(t[0]),toResolve:t.slice(1)}}throw new Mr(`Unknown path type ${r}`)};async function*Pi(r,e,t={}){let{cid:n,toResolve:i}=ch(r),o=n.toString(),s=o,a=i.length;for(;;){let c=await Qa(n,o,s,i,a,e,t);if(c.entry==null&&c.next==null)throw new pe(`Could not resolve ${r}`);if(c.entry!=null&&(yield c.entry),c.next==null)return;i=c.next.toResolve,n=c.next.cid,o=c.next.name,s=c.next.path}}async function Y(r,e,t={}){let n=await _e(Pi(r,e,t));if(n==null)throw new pe(`Could not resolve ${r}`);return n}async function*dn(r,e,t={}){let n=await Y(r,e,t);if(n==null)return;if(yield n,n.type==="directory")for await(let o of i(n,t))yield o;async function*i(o,s){for await(let a of o.content(s))yield a,!(a instanceof Uint8Array)&&a.type==="directory"&&(yield*i(a,s))}}function uh(r,e){if(typeof r=="string")return fh(r);if(typeof r=="number")return dh(r,e);throw Error(`Value provided to ms() must be a string or number. value=${JSON.stringify(r)}`)}var pn=uh;function fh(r){if(typeof r!="string"||r.length===0||r.length>100)throw Error(`Value provided to ms.parse() must be a string with length between 1 and 99. value=${JSON.stringify(r)}`);let e=/^(?<value>-?\d*\.?\d+) *(?<unit>milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|months?|mo|years?|yrs?|y)?$/i.exec(r);if(!e?.groups)return NaN;let{value:t,unit:n="ms"}=e.groups,i=parseFloat(t),o=n.toLowerCase();switch(o){case"years":case"year":case"yrs":case"yr":case"y":return i*315576e5;case"months":case"month":case"mo":return i*26298e5;case"weeks":case"week":case"w":return i*6048e5;case"days":case"day":case"d":return i*864e5;case"hours":case"hour":case"hrs":case"hr":case"h":return i*36e5;case"minutes":case"minute":case"mins":case"min":case"m":return i*6e4;case"seconds":case"second":case"secs":case"sec":case"s":return i*1e3;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return i;default:throw Error(`Unknown unit "${o}" provided to ms.parse(). value=${JSON.stringify(r)}`)}}function lh(r){let e=Math.abs(r);return e>=315576e5?`${Math.round(r/315576e5)}y`:e>=26298e5?`${Math.round(r/26298e5)}mo`:e>=6048e5?`${Math.round(r/6048e5)}w`:e>=864e5?`${Math.round(r/864e5)}d`:e>=36e5?`${Math.round(r/36e5)}h`:e>=6e4?`${Math.round(r/6e4)}m`:e>=1e3?`${Math.round(r/1e3)}s`:`${r}ms`}function hh(r){let e=Math.abs(r);return e>=315576e5?tt(r,e,315576e5,"year"):e>=26298e5?tt(r,e,26298e5,"month"):e>=6048e5?tt(r,e,6048e5,"week"):e>=864e5?tt(r,e,864e5,"day"):e>=36e5?tt(r,e,36e5,"hour"):e>=6e4?tt(r,e,6e4,"minute"):e>=1e3?tt(r,e,1e3,"second"):`${r} ms`}function dh(r,e){if(typeof r!="number"||!Number.isFinite(r))throw Error("Value provided to ms.format() must be of type number.");return e?.long?hh(r):lh(r)}function tt(r,e,t,n){let i=e>=t*1.5;return`${Math.round(r/t)} ${n}${i?"s":""}`}function Ui(r){t.debug=t,t.default=t,t.coerce=c,t.disable=o,t.enable=i,t.enabled=s,t.humanize=pn,t.destroy=h,Object.keys(r).forEach(f=>{t[f]=r[f]}),t.names=[],t.skips=[],t.formatters={};function e(f){let l=0;for(let y=0;y<f.length;y++)l=(l<<5)-l+f.charCodeAt(y),l|=0;return t.colors[Math.abs(l)%t.colors.length]}t.selectColor=e;function t(f,l){let y,u=null,d,m;function x(...g){if(!x.enabled)return;let w=x,b=Number(new Date),S=b-(y||b);w.diff=S,w.prev=y,w.curr=b,y=b,g[0]=t.coerce(g[0]),typeof g[0]!="string"&&g.unshift("%O");let B=0;g[0]=g[0].replace(/%([a-zA-Z%])/g,(E,L)=>{if(E==="%%")return"%";B++;let le=t.formatters[L];if(typeof le=="function"){let ot=g[B];E=le.call(w,ot),g.splice(B,1),B--}return E}),t.formatArgs.call(w,g),l?.onLog!=null&&l.onLog(...g),(w.log||t.log).apply(w,g)}return x.namespace=f,x.useColors=t.useColors(),x.color=t.selectColor(f),x.extend=n,x.destroy=t.destroy,Object.defineProperty(x,"enabled",{enumerable:!0,configurable:!1,get:()=>u!==null?u:(d!==t.namespaces&&(d=t.namespaces,m=t.enabled(f)),m),set:g=>{u=g}}),typeof t.init=="function"&&t.init(x),x}function n(f,l){let y=t(this.namespace+(typeof l>"u"?":":l)+f);return y.log=this.log,y}function i(f){t.save(f),t.namespaces=f,t.names=[],t.skips=[];let l,y=(typeof f=="string"?f:"").split(/[\s,]+/),u=y.length;for(l=0;l<u;l++)y[l]&&(f=y[l].replace(/\*/g,".*?"),f[0]==="-"?t.skips.push(new RegExp("^"+f.substr(1)+"$")):t.names.push(new RegExp("^"+f+"$")))}function o(){let f=[...t.names.map(a),...t.skips.map(a).map(l=>"-"+l)].join(",");return t.enable(""),f}function s(f){if(f[f.length-1]==="*")return!0;let l,y;for(l=0,y=t.skips.length;l<y;l++)if(t.skips[l].test(f))return!1;for(l=0,y=t.names.length;l<y;l++)if(t.names[l].test(f))return!0;return!1}function a(f){return f.toString().substring(2,f.toString().length-2).replace(/\.\*\?$/,"*")}function c(f){return f instanceof Error?f.stack??f.message:f}function h(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return t.setupFormatters(t.formatters),t.enable(t.load()),t}var mn=bh(),ph=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function mh(){return typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs)?!0:typeof navigator<"u"&&navigator.userAgent?.toLowerCase().match(/(edge|trident)\/(\d+)/)!=null?!1:typeof document<"u"&&document.documentElement?.style?.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent?.toLowerCase().match(/firefox\/(\d+)/)!=null&&parseInt(RegExp.$1,10)>=31||typeof navigator<"u"&&navigator.userAgent?.toLowerCase().match(/applewebkit\/(\d+)/)}function yh(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+pn(this.diff),!this.useColors)return;let e="color: "+this.color;r.splice(1,0,e,"color: inherit");let t=0,n=0;r[0].replace(/%[a-zA-Z%]/g,i=>{i!=="%%"&&(t++,i==="%c"&&(n=t))}),r.splice(n,0,e)}var gh=console.debug??console.log??(()=>{});function wh(r){try{r?mn?.setItem("debug",r):mn?.removeItem("debug")}catch{}}function xh(){let r;try{r=mn?.getItem("debug")}catch{}return!r&&typeof globalThis.process<"u"&&"env"in globalThis.process&&(r=globalThis.process.env.DEBUG),r}function bh(){try{return localStorage}catch{}}function _h(r){r.j=function(e){try{return JSON.stringify(e)}catch(t){return"[UnexpectedJSONParseError]: "+t.message}}}var ec=Ui({formatArgs:yh,save:wh,load:xh,useColors:mh,setupFormatters:_h,colors:ph,storage:mn,log:gh});var re=ec;re.formatters.b=r=>r==null?"undefined":de.baseEncode(r);re.formatters.t=r=>r==null?"undefined":Ue.baseEncode(r);re.formatters.m=r=>r==null?"undefined":Gt.baseEncode(r);re.formatters.p=r=>r==null?"undefined":r.toString();re.formatters.c=r=>r==null?"undefined":r.toString();re.formatters.k=r=>r==null?"undefined":r.toString();re.formatters.a=r=>r==null?"undefined":r.toString();function $i(r){let e=tc(r.message),t=tc(r.stack);return e!=null&&t!=null?t.includes(e)?t:`${e}
3
- ${t}`:t??e??r.toString()}function kh(r){return r instanceof AggregateError||r?.name==="AggregateError"&&Array.isArray(r.errors)}re.formatters.e=r=>{if(r==null)return"undefined";if(kh(r)){let e=" ",t=$i(r);return r.errors.length>0?t+=`
4
- ${e}${r.errors.map(n=>` ${$i(n).split(`
2
+ "use strict";var HeliaUnixfs=(()=>{var Tc=Object.create;var br=Object.defineProperty;var Dc=Object.getOwnPropertyDescriptor;var Lc=Object.getOwnPropertyNames;var zc=Object.getPrototypeOf,Fc=Object.prototype.hasOwnProperty;var _r=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),W=(r,e)=>{for(var t in e)br(r,t,{get:e[t],enumerable:!0})},Gi=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Lc(e))!Fc.call(r,i)&&i!==t&&br(r,i,{get:()=>e[i],enumerable:!(n=Dc(e,i))||n.enumerable});return r};var Pt=(r,e,t)=>(t=r!=null?Tc(zc(r)):{},Gi(e||!r||!r.__esModule?br(t,"default",{value:r,enumerable:!0}):t,r)),Pc=r=>Gi(br({},"__esModule",{value:!0}),r);var es=_r((tr,Fr)=>{(function(r,e){"use strict";var t={version:"3.0.0",x86:{},x64:{},inputValidation:!0};function n(u){if(!Array.isArray(u)&&!ArrayBuffer.isView(u))return!1;for(var d=0;d<u.length;d++)if(!Number.isInteger(u[d])||u[d]<0||u[d]>255)return!1;return!0}function i(u,d){return(u&65535)*d+(((u>>>16)*d&65535)<<16)}function o(u,d){return u<<d|u>>>32-d}function s(u){return u^=u>>>16,u=i(u,2246822507),u^=u>>>13,u=i(u,3266489909),u^=u>>>16,u}function a(u,d){u=[u[0]>>>16,u[0]&65535,u[1]>>>16,u[1]&65535],d=[d[0]>>>16,d[0]&65535,d[1]>>>16,d[1]&65535];var m=[0,0,0,0];return m[3]+=u[3]+d[3],m[2]+=m[3]>>>16,m[3]&=65535,m[2]+=u[2]+d[2],m[1]+=m[2]>>>16,m[2]&=65535,m[1]+=u[1]+d[1],m[0]+=m[1]>>>16,m[1]&=65535,m[0]+=u[0]+d[0],m[0]&=65535,[m[0]<<16|m[1],m[2]<<16|m[3]]}function c(u,d){u=[u[0]>>>16,u[0]&65535,u[1]>>>16,u[1]&65535],d=[d[0]>>>16,d[0]&65535,d[1]>>>16,d[1]&65535];var m=[0,0,0,0];return m[3]+=u[3]*d[3],m[2]+=m[3]>>>16,m[3]&=65535,m[2]+=u[2]*d[3],m[1]+=m[2]>>>16,m[2]&=65535,m[2]+=u[3]*d[2],m[1]+=m[2]>>>16,m[2]&=65535,m[1]+=u[1]*d[3],m[0]+=m[1]>>>16,m[1]&=65535,m[1]+=u[2]*d[2],m[0]+=m[1]>>>16,m[1]&=65535,m[1]+=u[3]*d[1],m[0]+=m[1]>>>16,m[1]&=65535,m[0]+=u[0]*d[3]+u[1]*d[2]+u[2]*d[1]+u[3]*d[0],m[0]&=65535,[m[0]<<16|m[1],m[2]<<16|m[3]]}function h(u,d){return d%=64,d===32?[u[1],u[0]]:d<32?[u[0]<<d|u[1]>>>32-d,u[1]<<d|u[0]>>>32-d]:(d-=32,[u[1]<<d|u[0]>>>32-d,u[0]<<d|u[1]>>>32-d])}function f(u,d){return d%=64,d===0?u:d<32?[u[0]<<d|u[1]>>>32-d,u[1]<<d]:[u[1]<<d-32,0]}function l(u,d){return[u[0]^d[0],u[1]^d[1]]}function y(u){return u=l(u,[0,u[0]>>>1]),u=c(u,[4283543511,3981806797]),u=l(u,[0,u[0]>>>1]),u=c(u,[3301882366,444984403]),u=l(u,[0,u[0]>>>1]),u}t.x86.hash32=function(u,d){if(t.inputValidation&&!n(u))return e;d=d||0;for(var m=u.length%4,x=u.length-m,g=d,w=0,_=3432918353,S=461845907,B=0;B<x;B=B+4)w=u[B]|u[B+1]<<8|u[B+2]<<16|u[B+3]<<24,w=i(w,_),w=o(w,15),w=i(w,S),g^=w,g=o(g,13),g=i(g,5)+3864292196;switch(w=0,m){case 3:w^=u[B+2]<<16;case 2:w^=u[B+1]<<8;case 1:w^=u[B],w=i(w,_),w=o(w,15),w=i(w,S),g^=w}return g^=u.length,g=s(g),g>>>0},t.x86.hash128=function(u,d){if(t.inputValidation&&!n(u))return e;d=d||0;for(var m=u.length%16,x=u.length-m,g=d,w=d,_=d,S=d,B=0,C=0,E=0,L=0,le=597399067,st=2869860233,wr=951274213,xr=2716044179,N=0;N<x;N=N+16)B=u[N]|u[N+1]<<8|u[N+2]<<16|u[N+3]<<24,C=u[N+4]|u[N+5]<<8|u[N+6]<<16|u[N+7]<<24,E=u[N+8]|u[N+9]<<8|u[N+10]<<16|u[N+11]<<24,L=u[N+12]|u[N+13]<<8|u[N+14]<<16|u[N+15]<<24,B=i(B,le),B=o(B,15),B=i(B,st),g^=B,g=o(g,19),g+=w,g=i(g,5)+1444728091,C=i(C,st),C=o(C,16),C=i(C,wr),w^=C,w=o(w,17),w+=_,w=i(w,5)+197830471,E=i(E,wr),E=o(E,17),E=i(E,xr),_^=E,_=o(_,15),_+=S,_=i(_,5)+2530024501,L=i(L,xr),L=o(L,18),L=i(L,le),S^=L,S=o(S,13),S+=g,S=i(S,5)+850148119;switch(B=0,C=0,E=0,L=0,m){case 15:L^=u[N+14]<<16;case 14:L^=u[N+13]<<8;case 13:L^=u[N+12],L=i(L,xr),L=o(L,18),L=i(L,le),S^=L;case 12:E^=u[N+11]<<24;case 11:E^=u[N+10]<<16;case 10:E^=u[N+9]<<8;case 9:E^=u[N+8],E=i(E,wr),E=o(E,17),E=i(E,xr),_^=E;case 8:C^=u[N+7]<<24;case 7:C^=u[N+6]<<16;case 6:C^=u[N+5]<<8;case 5:C^=u[N+4],C=i(C,st),C=o(C,16),C=i(C,wr),w^=C;case 4:B^=u[N+3]<<24;case 3:B^=u[N+2]<<16;case 2:B^=u[N+1]<<8;case 1:B^=u[N],B=i(B,le),B=o(B,15),B=i(B,st),g^=B}return g^=u.length,w^=u.length,_^=u.length,S^=u.length,g+=w,g+=_,g+=S,w+=g,_+=g,S+=g,g=s(g),w=s(w),_=s(_),S=s(S),g+=w,g+=_,g+=S,w+=g,_+=g,S+=g,("00000000"+(g>>>0).toString(16)).slice(-8)+("00000000"+(w>>>0).toString(16)).slice(-8)+("00000000"+(_>>>0).toString(16)).slice(-8)+("00000000"+(S>>>0).toString(16)).slice(-8)},t.x64.hash128=function(u,d){if(t.inputValidation&&!n(u))return e;d=d||0;for(var m=u.length%16,x=u.length-m,g=[0,d],w=[0,d],_=[0,0],S=[0,0],B=[2277735313,289559509],C=[1291169091,658871167],E=0;E<x;E=E+16)_=[u[E+4]|u[E+5]<<8|u[E+6]<<16|u[E+7]<<24,u[E]|u[E+1]<<8|u[E+2]<<16|u[E+3]<<24],S=[u[E+12]|u[E+13]<<8|u[E+14]<<16|u[E+15]<<24,u[E+8]|u[E+9]<<8|u[E+10]<<16|u[E+11]<<24],_=c(_,B),_=h(_,31),_=c(_,C),g=l(g,_),g=h(g,27),g=a(g,w),g=a(c(g,[0,5]),[0,1390208809]),S=c(S,C),S=h(S,33),S=c(S,B),w=l(w,S),w=h(w,31),w=a(w,g),w=a(c(w,[0,5]),[0,944331445]);switch(_=[0,0],S=[0,0],m){case 15:S=l(S,f([0,u[E+14]],48));case 14:S=l(S,f([0,u[E+13]],40));case 13:S=l(S,f([0,u[E+12]],32));case 12:S=l(S,f([0,u[E+11]],24));case 11:S=l(S,f([0,u[E+10]],16));case 10:S=l(S,f([0,u[E+9]],8));case 9:S=l(S,[0,u[E+8]]),S=c(S,C),S=h(S,33),S=c(S,B),w=l(w,S);case 8:_=l(_,f([0,u[E+7]],56));case 7:_=l(_,f([0,u[E+6]],48));case 6:_=l(_,f([0,u[E+5]],40));case 5:_=l(_,f([0,u[E+4]],32));case 4:_=l(_,f([0,u[E+3]],24));case 3:_=l(_,f([0,u[E+2]],16));case 2:_=l(_,f([0,u[E+1]],8));case 1:_=l(_,[0,u[E]]),_=c(_,B),_=h(_,31),_=c(_,C),g=l(g,_)}return g=l(g,[0,u.length]),w=l(w,[0,u.length]),g=a(g,w),w=a(w,g),g=y(g),w=y(w),g=a(g,w),w=a(w,g),("00000000"+(g[0]>>>0).toString(16)).slice(-8)+("00000000"+(g[1]>>>0).toString(16)).slice(-8)+("00000000"+(w[0]>>>0).toString(16)).slice(-8)+("00000000"+(w[1]>>>0).toString(16)).slice(-8)},typeof tr<"u"?(typeof Fr<"u"&&Fr.exports&&(tr=Fr.exports=t),tr.murmurHash3=t):typeof define=="function"&&define.amd?define([],function(){return t}):(t._murmurHash3=r.murmurHash3,t.noConflict=function(){return r.murmurHash3=t._murmurHash3,t._murmurHash3=e,t.noConflict=e,t},r.murmurHash3=t)})(tr)});var rs=_r((e0,ts)=>{ts.exports=es()});var Ur=_r((a0,is)=>{"use strict";is.exports=class{constructor(){this._bitArrays=[],this._data=[],this._length=0,this._changedLength=!1,this._changedData=!1}set(e,t){let n=this._internalPositionFor(e,!1);if(t===void 0)n!==-1&&(this._unsetInternalPos(n),this._unsetBit(e),this._changedLength=!0,this._changedData=!0);else{let i=!1;n===-1?(n=this._data.length,this._setBit(e),this._changedData=!0):i=!0,this._setInternalPos(n,e,t,i),this._changedLength=!0}}unset(e){this.set(e,void 0)}get(e){this._sortData();let t=this._internalPositionFor(e,!0);if(t!==-1)return this._data[t][1]}push(e){return this.set(this.length,e),this.length}get length(){if(this._sortData(),this._changedLength){let e=this._data[this._data.length-1];this._length=e?e[0]+1:0,this._changedLength=!1}return this._length}forEach(e){let t=0;for(;t<this.length;)e(this.get(t),t,this),t++}map(e){let t=0,n=new Array(this.length);for(;t<this.length;)n[t]=e(this.get(t),t,this),t++;return n}reduce(e,t){let n=0,i=t;for(;n<this.length;){let o=this.get(n);i=e(i,o,n),n++}return i}find(e){let t=0,n,i;for(;t<this.length&&!n;)i=this.get(t),n=e(i),t++;return n?i:void 0}_internalPositionFor(e,t){let n=this._bytePosFor(e,t);if(n>=this._bitArrays.length)return-1;let i=this._bitArrays[n],o=e-n*7;if(!((i&1<<o)>0))return-1;let a=this._bitArrays.slice(0,n).reduce(Lf,0),c=~(4294967295<<o+1),h=ns(i&c);return a+h-1}_bytePosFor(e,t){let n=Math.floor(e/7),i=n+1;for(;!t&&this._bitArrays.length<i;)this._bitArrays.push(0);return n}_setBit(e){let t=this._bytePosFor(e,!1);this._bitArrays[t]|=1<<e-t*7}_unsetBit(e){let t=this._bytePosFor(e,!1);this._bitArrays[t]&=~(1<<e-t*7)}_setInternalPos(e,t,n,i){let o=this._data,s=[t,n];if(i)this._sortData(),o[e]=s;else{if(o.length)if(o[o.length-1][0]>=t)o.push(s);else if(o[0][0]<=t)o.unshift(s);else{let a=Math.round(o.length/2);this._data=o.slice(0,a).concat(s).concat(o.slice(a))}else this._data.push(s);this._changedData=!0,this._changedLength=!0}}_unsetInternalPos(e){this._data.splice(e,1)}_sortData(){this._changedData&&this._data.sort(zf),this._changedData=!1}bitField(){let e=[],t=8,n=0,i=0,o,s=this._bitArrays.slice();for(;s.length||n;){n===0&&(o=s.shift(),n=7);let c=Math.min(n,t),h=~(255<<c),f=o&h;i|=f<<8-t,o=o>>>c,n-=c,t-=c,(!t||!n&&!s.length)&&(e.push(i),i=0,t=8)}for(var a=e.length-1;a>0&&e[a]===0;a--)e.pop();return e}compactArray(){return this._sortData(),this._data.map(Ff)}};function Lf(r,e){return r+ns(e)}function ns(r){let e=r;return e=e-(e>>1&1431655765),e=(e&858993459)+(e>>2&858993459),(e+(e>>4)&252645135)*16843009>>24}function zf(r,e){return r[0]-e[0]}function Ff(r){return r[1]}});var Za=_r((Nw,Di)=>{"use strict";var uh=Object.prototype.hasOwnProperty,Z="~";function lr(){}Object.create&&(lr.prototype=Object.create(null),new lr().__proto__||(Z=!1));function fh(r,e,t){this.fn=r,this.context=e,this.once=t||!1}function Ja(r,e,t,n,i){if(typeof t!="function")throw new TypeError("The listener must be a function");var o=new fh(t,n||r,i),s=Z?Z+e:e;return r._events[s]?r._events[s].fn?r._events[s]=[r._events[s],o]:r._events[s].push(o):(r._events[s]=o,r._eventsCount++),r}function pn(r,e){--r._eventsCount===0?r._events=new lr:delete r._events[e]}function X(){this._events=new lr,this._eventsCount=0}X.prototype.eventNames=function(){var e=[],t,n;if(this._eventsCount===0)return e;for(n in t=this._events)uh.call(t,n)&&e.push(Z?n.slice(1):n);return Object.getOwnPropertySymbols?e.concat(Object.getOwnPropertySymbols(t)):e};X.prototype.listeners=function(e){var t=Z?Z+e:e,n=this._events[t];if(!n)return[];if(n.fn)return[n.fn];for(var i=0,o=n.length,s=new Array(o);i<o;i++)s[i]=n[i].fn;return s};X.prototype.listenerCount=function(e){var t=Z?Z+e:e,n=this._events[t];return n?n.fn?1:n.length:0};X.prototype.emit=function(e,t,n,i,o,s){var a=Z?Z+e:e;if(!this._events[a])return!1;var c=this._events[a],h=arguments.length,f,l;if(c.fn){switch(c.once&&this.removeListener(e,c.fn,void 0,!0),h){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,t),!0;case 3:return c.fn.call(c.context,t,n),!0;case 4:return c.fn.call(c.context,t,n,i),!0;case 5:return c.fn.call(c.context,t,n,i,o),!0;case 6:return c.fn.call(c.context,t,n,i,o,s),!0}for(l=1,f=new Array(h-1);l<h;l++)f[l-1]=arguments[l];c.fn.apply(c.context,f)}else{var y=c.length,u;for(l=0;l<y;l++)switch(c[l].once&&this.removeListener(e,c[l].fn,void 0,!0),h){case 1:c[l].fn.call(c[l].context);break;case 2:c[l].fn.call(c[l].context,t);break;case 3:c[l].fn.call(c[l].context,t,n);break;case 4:c[l].fn.call(c[l].context,t,n,i);break;default:if(!f)for(u=1,f=new Array(h-1);u<h;u++)f[u-1]=arguments[u];c[l].fn.apply(c[l].context,f)}}return!0};X.prototype.on=function(e,t,n){return Ja(this,e,t,n,!1)};X.prototype.once=function(e,t,n){return Ja(this,e,t,n,!0)};X.prototype.removeListener=function(e,t,n,i){var o=Z?Z+e:e;if(!this._events[o])return this;if(!t)return pn(this,o),this;var s=this._events[o];if(s.fn)s.fn===t&&(!i||s.once)&&(!n||s.context===n)&&pn(this,o);else{for(var a=0,c=[],h=s.length;a<h;a++)(s[a].fn!==t||i&&!s[a].once||n&&s[a].context!==n)&&c.push(s[a]);c.length?this._events[o]=c.length===1?c[0]:c:pn(this,o)}return this};X.prototype.removeAllListeners=function(e){var t;return e?(t=Z?Z+e:e,this._events[t]&&pn(this,t)):(this._events=new lr,this._eventsCount=0),this};X.prototype.off=X.prototype.removeListener;X.prototype.addListener=X.prototype.on;X.prefixed=Z;X.EventEmitter=X;typeof Di<"u"&&(Di.exports=X)});var hd={};W(hd,{globSource:()=>Cc,unixfs:()=>ld,urlSource:()=>Nc});function Uc(r){return r[Symbol.asyncIterator]!=null}function $c(r){if(Uc(r))return(async()=>{for await(let e of r)return e})();for(let e of r)return e}var kr=$c;function Rc(r){return r[Symbol.asyncIterator]!=null}function Mc(r,e=1){return e=Number(e),Rc(r)?(async function*(){let t=[];if(e<1&&(e=1),e!==Math.round(e))throw new Error("Batch size must be an integer");for await(let n of r)for(t.push(n);t.length>=e;)yield t.slice(0,e),t=t.slice(e);for(;t.length>0;)yield t.slice(0,e),t=t.slice(e)})():(function*(){let t=[];if(e<1&&(e=1),e!==Math.round(e))throw new Error("Batch size must be an integer");for(let n of r)for(t.push(n);t.length>=e;)yield t.slice(0,e),t=t.slice(e);for(;t.length>0;)yield t.slice(0,e),t=t.slice(e)})()}var Sr=Mc;async function*Ut(r,e=1){for await(let t of Sr(r,e)){let n=t.map(async i=>i().then(o=>({ok:!0,value:o}),o=>({ok:!1,err:o})));for(let i=0;i<n.length;i++){let o=await n[i];if(o.ok)yield o.value;else throw o.err}}}function ge(r=0){return new Uint8Array(r)}function ne(r=0){return new Uint8Array(r)}function Ie(r,e){e==null&&(e=r.reduce((i,o)=>i+o.length,0));let t=ne(e),n=0;for(let i of r)t.set(i,n),n+=i.length;return t}function Er(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}var Ki=Symbol.for("@achingbrain/uint8arraylist");function Wi(r,e){if(e==null||e<0)throw new RangeError("index is out of bounds");let t=0;for(let n of r){let i=t+n.byteLength;if(e<i)return{buf:n,index:e-t};t=i}throw new RangeError("index is out of bounds")}function vr(r){return!!r?.[Ki]}var at=class r{bufs;length;[Ki]=!0;constructor(...e){this.bufs=[],this.length=0,e.length>0&&this.appendAll(e)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...e){this.appendAll(e)}appendAll(e){let t=0;for(let n of e)if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.push(n);else if(vr(n))t+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}prepend(...e){this.prependAll(e)}prependAll(e){let t=0;for(let n of e.reverse())if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.unshift(n);else if(vr(n))t+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}get(e){let t=Wi(this.bufs,e);return t.buf[t.index]}set(e,t){let n=Wi(this.bufs,e);n.buf[n.index]=t}write(e,t=0){if(e instanceof Uint8Array)for(let n=0;n<e.length;n++)this.set(t+n,e[n]);else if(vr(e))for(let n=0;n<e.length;n++)this.set(t+n,e.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(e){if(e=Math.trunc(e),!(Number.isNaN(e)||e<=0)){if(e===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(e>=this.bufs[0].byteLength)e-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(e),this.length-=e;break}}}slice(e,t){let{bufs:n,length:i}=this._subList(e,t);return Ie(n,i)}subarray(e,t){let{bufs:n,length:i}=this._subList(e,t);return n.length===1?n[0]:Ie(n,i)}sublist(e,t){let{bufs:n,length:i}=this._subList(e,t),o=new r;return o.length=i,o.bufs=[...n],o}_subList(e,t){if(e=e??0,t=t??this.length,e<0&&(e=this.length+e),t<0&&(t=this.length+t),e<0||t>this.length)throw new RangeError("index is out of bounds");if(e===t)return{bufs:[],length:0};if(e===0&&t===this.length)return{bufs:this.bufs,length:this.length};let n=[],i=0;for(let o=0;o<this.bufs.length;o++){let s=this.bufs[o],a=i,c=a+s.byteLength;if(i=c,e>=c)continue;let h=e>=a&&e<c,f=t>a&&t<=c;if(h&&f){if(e===a&&t===c){n.push(s);break}let l=e-a;n.push(s.subarray(l,l+(t-e)));break}if(h){if(e===0){n.push(s);continue}n.push(s.subarray(e-a));continue}if(f){if(t===c){n.push(s);break}n.push(s.subarray(0,t-a));break}n.push(s)}return{bufs:n,length:t-e}}indexOf(e,t=0){if(!vr(e)&&!(e instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=e instanceof Uint8Array?e:e.subarray();if(t=Number(t??0),isNaN(t)&&(t=0),t<0&&(t=this.length+t),t<0&&(t=0),e.length===0)return t>this.length?this.length:t;let i=n.byteLength;if(i===0)throw new TypeError("search must be at least 1 byte long");let o=256,s=new Int32Array(o);for(let l=0;l<o;l++)s[l]=-1;for(let l=0;l<i;l++)s[n[l]]=l;let a=s,c=this.byteLength-n.byteLength,h=n.byteLength-1,f;for(let l=t;l<=c;l+=f){f=0;for(let y=h;y>=0;y--){let u=this.get(l+y);if(n[y]!==u){f=Math.max(1,y-a[u]);break}}if(f===0)return l}return-1}getInt8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getInt8(0)}setInt8(e,t){let n=ne(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,t),this.write(n,e)}getInt16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,t)}setInt16(e,t,n){let i=ge(2);new DataView(i.buffer,i.byteOffset,i.byteLength).setInt16(0,t,n),this.write(i,e)}getInt32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,t)}setInt32(e,t,n){let i=ge(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setInt32(0,t,n),this.write(i,e)}getBigInt64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,t)}setBigInt64(e,t,n){let i=ge(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setBigInt64(0,t,n),this.write(i,e)}getUint8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getUint8(0)}setUint8(e,t){let n=ne(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,t),this.write(n,e)}getUint16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,t)}setUint16(e,t,n){let i=ge(2);new DataView(i.buffer,i.byteOffset,i.byteLength).setUint16(0,t,n),this.write(i,e)}getUint32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,t)}setUint32(e,t,n){let i=ge(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setUint32(0,t,n),this.write(i,e)}getBigUint64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,t)}setBigUint64(e,t,n){let i=ge(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setBigUint64(0,t,n),this.write(i,e)}getFloat32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,t)}setFloat32(e,t,n){let i=ge(4);new DataView(i.buffer,i.byteOffset,i.byteLength).setFloat32(0,t,n),this.write(i,e)}getFloat64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,t)}setFloat64(e,t,n){let i=ge(8);new DataView(i.buffer,i.byteOffset,i.byteLength).setFloat64(0,t,n),this.write(i,e)}equals(e){if(e==null||!(e instanceof r)||e.bufs.length!==this.bufs.length)return!1;for(let t=0;t<this.bufs.length;t++)if(!Er(this.bufs[t],e.bufs[t]))return!1;return!0}static fromUint8Arrays(e,t){let n=new r;return n.bufs=e,t==null&&(t=e.reduce((i,o)=>i+o.byteLength,0)),n.length=t,n}};var Oc=262144,$t=(r={})=>{let e=r.chunkSize??Oc;return async function*(n){let i=new at,o=0,s=!1;for await(let a of n)for(i.append(a),o+=a.length;o>=e;)if(yield i.slice(0,e),s=!0,e===i.length)i=new at,o=0;else{let c=new at;c.append(i.sublist(e)),i=c,o-=e}(!s||o>0)&&(yield i.subarray(0,o))}};var V={};W(V,{code:()=>q,createLink:()=>mo,createNode:()=>po,decode:()=>$,encode:()=>T,name:()=>Mu,prepare:()=>P,validate:()=>jn});var Un={};W(Un,{base32:()=>$e,base32hex:()=>eu,base32hexpad:()=>ru,base32hexpadupper:()=>nu,base32hexupper:()=>tu,base32pad:()=>Yc,base32padupper:()=>Qc,base32upper:()=>Zc,base32z:()=>iu});var ct={};W(ct,{coerce:()=>he,empty:()=>Xi,equals:()=>Nn,fromHex:()=>Hc,fromString:()=>Tn,isBinary:()=>jc,toHex:()=>Vc,toString:()=>Dn});var Xi=new Uint8Array(0);function Vc(r){return r.reduce((e,t)=>e+t.toString(16).padStart(2,"0"),"")}function Hc(r){let e=r.match(/../g);return e!=null?new Uint8Array(e.map(t=>parseInt(t,16))):Xi}function Nn(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function he(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 jc(r){return r instanceof ArrayBuffer||ArrayBuffer.isView(r)}function Tn(r){return new TextEncoder().encode(r)}function Dn(r){return new TextDecoder().decode(r)}function qc(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var i=0;i<r.length;i++){var o=r.charAt(i),s=o.charCodeAt(0);if(t[s]!==255)throw new TypeError(o+" is ambiguous");t[s]=i}var a=r.length,c=r.charAt(0),h=Math.log(a)/Math.log(256),f=Math.log(256)/Math.log(a);function l(d){if(d instanceof Uint8Array||(ArrayBuffer.isView(d)?d=new Uint8Array(d.buffer,d.byteOffset,d.byteLength):Array.isArray(d)&&(d=Uint8Array.from(d))),!(d instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(d.length===0)return"";for(var m=0,x=0,g=0,w=d.length;g!==w&&d[g]===0;)g++,m++;for(var _=(w-g)*f+1>>>0,S=new Uint8Array(_);g!==w;){for(var B=d[g],C=0,E=_-1;(B!==0||C<x)&&E!==-1;E--,C++)B+=256*S[E]>>>0,S[E]=B%a>>>0,B=B/a>>>0;if(B!==0)throw new Error("Non-zero carry");x=C,g++}for(var L=_-x;L!==_&&S[L]===0;)L++;for(var le=c.repeat(m);L<_;++L)le+=r.charAt(S[L]);return le}function y(d){if(typeof d!="string")throw new TypeError("Expected String");if(d.length===0)return new Uint8Array;var m=0;if(d[m]!==" "){for(var x=0,g=0;d[m]===c;)x++,m++;for(var w=(d.length-m)*h+1>>>0,_=new Uint8Array(w);d[m];){var S=t[d.charCodeAt(m)];if(S===255)return;for(var B=0,C=w-1;(S!==0||B<g)&&C!==-1;C--,B++)S+=a*_[C]>>>0,_[C]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");g=B,m++}if(d[m]!==" "){for(var E=w-g;E!==w&&_[E]===0;)E++;for(var L=new Uint8Array(x+(w-E)),le=x;E!==w;)L[le++]=_[E++];return L}}}function u(d){var m=y(d);if(m)return m;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:y,decode:u}}var Gc=qc,Wc=Gc,Ji=Wc;var Ln=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},zn=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){this.name=e,this.prefix=t;let i=t.codePointAt(0);if(i===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=i,this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return Zi(this,e)}},Fn=class{decoders;constructor(e){this.decoders=e}or(e){return Zi(this,e)}decode(e){let t=e[0],n=this.decoders[t];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Zi(r,e){return new Fn({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var Pn=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,i){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=i,this.encoder=new Ln(e,t,n),this.decoder=new zn(e,t,i)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function ut({name:r,prefix:e,encode:t,decode:n}){return new Pn(r,e,t,n)}function Ue({name:r,prefix:e,alphabet:t}){let{encode:n,decode:i}=Ji(t,r);return ut({prefix:e,name:r,encode:n,decode:o=>he(i(o))})}function Kc(r,e,t,n){let i=r.length;for(;r[i-1]==="=";)--i;let o=new Uint8Array(i*t/8|0),s=0,a=0,c=0;for(let h=0;h<i;++h){let f=e[r[h]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<t|f,s+=t,s>=8&&(s-=8,o[c++]=255&a>>s)}if(s>=t||(255&a<<8-s)!==0)throw new SyntaxError("Unexpected end of data");return o}function Xc(r,e,t){let n=e[e.length-1]==="=",i=(1<<t)-1,o="",s=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],s+=8;s>t;)s-=t,o+=e[i&a>>s];if(s!==0&&(o+=e[i&a<<t-s]),n)for(;(o.length*t&7)!==0;)o+="=";return o}function Jc(r){let e={};for(let t=0;t<r.length;++t)e[r[t]]=t;return e}function F({name:r,prefix:e,bitsPerChar:t,alphabet:n}){let i=Jc(n);return ut({prefix:e,name:r,encode(o){return Xc(o,n,t)},decode(o){return Kc(o,i,t,r)}})}var $e=F({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Zc=F({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Yc=F({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Qc=F({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),eu=F({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),tu=F({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),ru=F({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),nu=F({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),iu=F({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var $n={};W($n,{base36:()=>Rt,base36upper:()=>ou});var Rt=Ue({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),ou=Ue({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Rn={};W(Rn,{base58btc:()=>de,base58flickr:()=>su});var de=Ue({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),su=Ue({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var au=eo,Yi=128,cu=127,uu=~cu,fu=Math.pow(2,31);function eo(r,e,t){e=e||[],t=t||0;for(var n=t;r>=fu;)e[t++]=r&255|Yi,r/=128;for(;r&uu;)e[t++]=r&255|Yi,r>>>=7;return e[t]=r|0,eo.bytes=t-n+1,e}var lu=Mn,hu=128,Qi=127;function Mn(r,n){var t=0,n=n||0,i=0,o=n,s,a=r.length;do{if(o>=a)throw Mn.bytes=0,new RangeError("Could not decode varint");s=r[o++],t+=i<28?(s&Qi)<<i:(s&Qi)*Math.pow(2,i),i+=7}while(s>=hu);return Mn.bytes=o-n,t}var du=Math.pow(2,7),pu=Math.pow(2,14),mu=Math.pow(2,21),yu=Math.pow(2,28),gu=Math.pow(2,35),wu=Math.pow(2,42),xu=Math.pow(2,49),bu=Math.pow(2,56),_u=Math.pow(2,63),ku=function(r){return r<du?1:r<pu?2:r<mu?3:r<yu?4:r<gu?5:r<wu?6:r<xu?7:r<bu?8:r<_u?9:10},Su={encode:au,decode:lu,encodingLength:ku},Eu=Su,Mt=Eu;function Ot(r,e=0){return[Mt.decode(r,e),Mt.decode.bytes]}function ft(r,e,t=0){return Mt.encode(r,e,t),e}function lt(r){return Mt.encodingLength(r)}function dt(r,e){let t=e.byteLength,n=lt(r),i=n+lt(t),o=new Uint8Array(i+t);return ft(r,o,0),ft(t,o,n),o.set(e,i),new ht(r,t,e,o)}function Ir(r){let e=he(r),[t,n]=Ot(e),[i,o]=Ot(e.subarray(n)),s=e.subarray(n+o);if(s.byteLength!==i)throw new Error("Incorrect length");return new ht(t,i,s,e)}function to(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&Nn(r.bytes,t.bytes)}}var ht=class{code;size;digest;bytes;constructor(e,t,n,i){this.code=e,this.size=t,this.digest=n,this.bytes=i}};function ro(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return Bu(t,On(r),e??de.encoder);default:return Iu(t,On(r),e??$e.encoder)}}var no=new WeakMap;function On(r){let e=no.get(r);if(e==null){let t=new Map;return no.set(r,t),t}return e}var A=class r{code;version;multihash;bytes;"/";constructor(e,t,n,i){this.code=t,this.version=e,this.multihash=n,this.bytes=i,this["/"]=i}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:e,multihash:t}=this;if(e!==Vt)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==Au)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:e,digest:t}=this.multihash,n=dt(e,t);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&to(e.multihash,n.multihash)}toString(e){return ro(this,e)}toJSON(){return{"/":ro(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:i,multihash:o,bytes:s}=t;return new r(n,i,o,s??io(n,i,o.bytes))}else if(t[Cu]===!0){let{version:n,multihash:i,code:o}=t,s=Ir(i);return r.create(n,o,s)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==Vt)throw new Error(`Version 0 CID must use dag-pb (code: ${Vt}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let i=io(e,t,n.bytes);return new r(e,t,n,i)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Vt,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,i=he(e.subarray(n,n+t.multihashSize));if(i.byteLength!==t.multihashSize)throw new Error("Incorrect length");let o=i.subarray(t.multihashSize-t.digestSize),s=new ht(t.multihashCode,t.digestSize,o,i);return[t.version===0?r.createV0(s):r.createV1(t.codec,s),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[l,y]=Ot(e.subarray(t));return t+=y,l},i=n(),o=Vt;if(i===18?(i=0,t=0):o=n(),i!==0&&i!==1)throw new RangeError(`Invalid CID version ${i}`);let s=t,a=n(),c=n(),h=t+c,f=h-s;return{version:i,codec:o,multihashCode:a,digestSize:c,multihashSize:f,size:h}}static parse(e,t){let[n,i]=vu(e,t),o=r.decode(i);if(o.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return On(o).set(n,e),o}};function vu(r,e){switch(r[0]){case"Q":{let t=e??de;return[de.prefix,t.decode(`${de.prefix}${r}`)]}case de.prefix:{let t=e??de;return[de.prefix,t.decode(r)]}case $e.prefix:{let t=e??$e;return[$e.prefix,t.decode(r)]}case Rt.prefix:{let t=e??Rt;return[Rt.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function Bu(r,e,t){let{prefix:n}=t;if(n!==de.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let i=e.get(n);if(i==null){let o=t.encode(r).slice(1);return e.set(n,o),o}else return i}function Iu(r,e,t){let{prefix:n}=t,i=e.get(n);if(i==null){let o=t.encode(r);return e.set(n,o),o}else return i}var Vt=112,Au=18;function io(r,e,t){let n=lt(r),i=n+lt(e),o=new Uint8Array(i+t.byteLength);return ft(r,o,0),ft(e,o,n),o.set(t,i),o}var Cu=Symbol.for("@ipld/js-cid/CID");var Nu=new TextDecoder;function Vn(r,e){let t=0;for(let n=0;;n+=7){if(n>=64)throw new Error("protobuf: varint overflow");if(e>=r.length)throw new Error("protobuf: unexpected end of data");let i=r[e++];if(t+=n<28?(i&127)<<n:(i&127)*2**n,i<128)break}return[t,e]}function Ar(r,e){let t;[t,e]=Vn(r,e);let n=e+t;if(t<0||n<0)throw new Error("protobuf: invalid length");if(n>r.length)throw new Error("protobuf: unexpected end of data");return[r.subarray(e,n),n]}function oo(r,e){let t;return[t,e]=Vn(r,e),[t&7,t>>3,e]}function Tu(r){let e={},t=r.length,n=0;for(;n<t;){let i,o;if([i,o,n]=oo(r,n),o===1){if(e.Hash)throw new Error("protobuf: (PBLink) duplicate Hash section");if(i!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${i}) for Hash`);if(e.Name!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Name before Hash");if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Hash");[e.Hash,n]=Ar(r,n)}else if(o===2){if(e.Name!==void 0)throw new Error("protobuf: (PBLink) duplicate Name section");if(i!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${i}) for Name`);if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Name");let s;[s,n]=Ar(r,n),e.Name=Nu.decode(s)}else if(o===3){if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) duplicate Tsize section");if(i!==0)throw new Error(`protobuf: (PBLink) wrong wireType (${i}) for Tsize`);[e.Tsize,n]=Vn(r,n)}else throw new Error(`protobuf: (PBLink) invalid fieldNumber, expected 1, 2 or 3, got ${o}`)}if(n>t)throw new Error("protobuf: (PBLink) unexpected end of data");return e}function so(r){let e=r.length,t=0,n,i=!1,o;for(;t<e;){let a,c;if([a,c,t]=oo(r,t),a!==2)throw new Error(`protobuf: (PBNode) invalid wireType, expected 2, got ${a}`);if(c===1){if(o)throw new Error("protobuf: (PBNode) duplicate Data section");[o,t]=Ar(r,t),n&&(i=!0)}else if(c===2){if(i)throw new Error("protobuf: (PBNode) duplicate Links section");n||(n=[]);let h;[h,t]=Ar(r,t),n.push(Tu(h))}else throw new Error(`protobuf: (PBNode) invalid fieldNumber, expected 1 or 2, got ${c}`)}if(t>e)throw new Error("protobuf: (PBNode) unexpected end of data");let s={};return o&&(s.Data=o),s.Links=n||[],s}var co=new TextEncoder,ao=2**32,Du=2**31;function Lu(r,e){let t=e.length;if(typeof r.Tsize=="number"){if(r.Tsize<0)throw new Error("Tsize cannot be negative");if(!Number.isSafeInteger(r.Tsize))throw new Error("Tsize too large for encoding");t=Ht(e,t,r.Tsize)-1,e[t]=24}if(typeof r.Name=="string"){let n=co.encode(r.Name);t-=n.length,e.set(n,t),t=Ht(e,t,n.length)-1,e[t]=18}return r.Hash&&(t-=r.Hash.length,e.set(r.Hash,t),t=Ht(e,t,r.Hash.length)-1,e[t]=10),e.length-t}function uo(r){let e=Fu(r),t=new Uint8Array(e),n=e;if(r.Data&&(n-=r.Data.length,t.set(r.Data,n),n=Ht(t,n,r.Data.length)-1,t[n]=10),r.Links)for(let i=r.Links.length-1;i>=0;i--){let o=Lu(r.Links[i],t.subarray(0,n));n-=o,n=Ht(t,n,o)-1,t[n]=18}return t}function zu(r){let e=0;if(r.Hash){let t=r.Hash.length;e+=1+t+mt(t)}if(typeof r.Name=="string"){let t=co.encode(r.Name).length;e+=1+t+mt(t)}return typeof r.Tsize=="number"&&(e+=1+mt(r.Tsize)),e}function Fu(r){let e=0;if(r.Data){let t=r.Data.length;e+=1+t+mt(t)}if(r.Links)for(let t of r.Links){let n=zu(t);e+=1+n+mt(n)}return e}function Ht(r,e,t){e-=mt(t);let n=e;for(;t>=Du;)r[e++]=t&127|128,t/=128;for(;t>=128;)r[e++]=t&127|128,t>>>=7;return r[e]=t,n}function mt(r){return r%2===0&&r++,Math.floor((Pu(r)+6)/7)}function Pu(r){let e=0;return r>=ao&&(r=Math.floor(r/ao),e=32),r>=65536&&(r>>>=16,e+=16),r>=256&&(r>>>=8,e+=8),e+Uu[r]}var Uu=[0,1,2,2,3,3,3,3,4,4,4,4,4,4,4,4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8];var $u=["Data","Links"],Ru=["Hash","Name","Tsize"],Hn=new TextEncoder;function lo(r,e){if(r===e)return 0;let t=r.Name?Hn.encode(r.Name):[],n=e.Name?Hn.encode(e.Name):[],i=t.length,o=n.length;for(let s=0,a=Math.min(i,o);s<a;++s)if(t[s]!==n[s]){i=t[s],o=n[s];break}return i<o?-1:o<i?1:0}function fo(r,e){return!Object.keys(r).some(t=>!e.includes(t))}function ho(r){if(typeof r.asCID=="object"){let t=A.asCID(r);if(!t)throw new TypeError("Invalid DAG-PB form");return{Hash:t}}if(typeof r!="object"||Array.isArray(r))throw new TypeError("Invalid DAG-PB form");let e={};if(r.Hash){let t=A.asCID(r.Hash);try{t||(typeof r.Hash=="string"?t=A.parse(r.Hash):r.Hash instanceof Uint8Array&&(t=A.decode(r.Hash)))}catch(n){throw new TypeError(`Invalid DAG-PB form: ${n.message}`)}t&&(e.Hash=t)}if(!e.Hash)throw new TypeError("Invalid DAG-PB form");return typeof r.Name=="string"&&(e.Name=r.Name),typeof r.Tsize=="number"&&(e.Tsize=r.Tsize),e}function P(r){if((r instanceof Uint8Array||typeof r=="string")&&(r={Data:r}),typeof r!="object"||Array.isArray(r))throw new TypeError("Invalid DAG-PB form");let e={};if(r.Data!==void 0)if(typeof r.Data=="string")e.Data=Hn.encode(r.Data);else if(r.Data instanceof Uint8Array)e.Data=r.Data;else throw new TypeError("Invalid DAG-PB form");if(r.Links!==void 0)if(Array.isArray(r.Links))e.Links=r.Links.map(ho),e.Links.sort(lo);else throw new TypeError("Invalid DAG-PB form");else e.Links=[];return e}function jn(r){if(!r||typeof r!="object"||Array.isArray(r)||r instanceof Uint8Array||r["/"]&&r["/"]===r.bytes)throw new TypeError("Invalid DAG-PB form");if(!fo(r,$u))throw new TypeError("Invalid DAG-PB form (extraneous properties)");if(r.Data!==void 0&&!(r.Data instanceof Uint8Array))throw new TypeError("Invalid DAG-PB form (Data must be bytes)");if(!Array.isArray(r.Links))throw new TypeError("Invalid DAG-PB form (Links must be a list)");for(let e=0;e<r.Links.length;e++){let t=r.Links[e];if(!t||typeof t!="object"||Array.isArray(t)||t instanceof Uint8Array||t["/"]&&t["/"]===t.bytes)throw new TypeError("Invalid DAG-PB form (bad link)");if(!fo(t,Ru))throw new TypeError("Invalid DAG-PB form (extraneous properties on link)");if(t.Hash===void 0)throw new TypeError("Invalid DAG-PB form (link must have a Hash)");if(t.Hash==null||!t.Hash["/"]||t.Hash["/"]!==t.Hash.bytes)throw new TypeError("Invalid DAG-PB form (link Hash must be a CID)");if(t.Name!==void 0&&typeof t.Name!="string")throw new TypeError("Invalid DAG-PB form (link Name must be a string)");if(t.Tsize!==void 0){if(typeof t.Tsize!="number"||t.Tsize%1!==0)throw new TypeError("Invalid DAG-PB form (link Tsize must be an integer)");if(t.Tsize<0)throw new TypeError("Invalid DAG-PB form (link Tsize cannot be negative)")}if(e>0&&lo(t,r.Links[e-1])===-1)throw new TypeError("Invalid DAG-PB form (links must be sorted by Name bytes)")}}function po(r,e=[]){return P({Data:r,Links:e})}function mo(r,e,t){return ho({Hash:t,Name:r,Tsize:e})}function yo(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var Mu="dag-pb",q=112;function T(r){jn(r);let e={};return r.Links&&(e.Links=r.Links.map(t=>{let n={};return t.Hash&&(n.Hash=t.Hash.bytes),t.Name!==void 0&&(n.Name=t.Name),t.Tsize!==void 0&&(n.Tsize=t.Tsize),n})),r.Data&&(e.Data=r.Data),uo(e)}function $(r){let e=yo(r),t=so(e),n={};return t.Data&&(n.Data=t.Data),t.Links&&(n.Links=t.Links.map(i=>{let o={};try{o.Hash=A.decode(i.Hash)}catch{}if(!o.Hash)throw new Error("Invalid Hash field found in link, expected CID");return i.Name!==void 0&&(o.Name=i.Name),i.Tsize!==void 0&&(o.Tsize=i.Tsize),o})),n}var jt=class r extends Error{static name="InvalidTypeError";static code="ERR_INVALID_TYPE";name=r.name;code=r.code;constructor(e="Invalid type"){super(e)}},Cr=class r extends Error{static name="InvalidUnixFSMessageError";static code="ERR_INVALID_MESSAGE";name=r.name;code=r.code;constructor(e="Invalid message"){super(e)}};var Ou=Math.pow(2,7),Vu=Math.pow(2,14),Hu=Math.pow(2,21),go=Math.pow(2,28),wo=Math.pow(2,35),xo=Math.pow(2,42),bo=Math.pow(2,49),J=128,Re=127;function qt(r){if(r<Ou)return 1;if(r<Vu)return 2;if(r<Hu)return 3;if(r<go)return 4;if(r<wo)return 5;if(r<xo)return 6;if(r<bo)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function _o(r,e,t=0){switch(qt(r)){case 8:e[t++]=r&255|J,r/=128;case 7:e[t++]=r&255|J,r/=128;case 6:e[t++]=r&255|J,r/=128;case 5:e[t++]=r&255|J,r/=128;case 4:e[t++]=r&255|J,r>>>=7;case 3:e[t++]=r&255|J,r>>>=7;case 2:e[t++]=r&255|J,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function ko(r,e){let t=r[e],n=0;if(n+=t&Re,t<J||(t=r[e+1],n+=(t&Re)<<7,t<J)||(t=r[e+2],n+=(t&Re)<<14,t<J)||(t=r[e+3],n+=(t&Re)<<21,t<J)||(t=r[e+4],n+=(t&Re)*go,t<J)||(t=r[e+5],n+=(t&Re)*wo,t<J)||(t=r[e+6],n+=(t&Re)*xo,t<J)||(t=r[e+7],n+=(t&Re)*bo,t<J))return n;throw new RangeError("Could not decode varint")}var qn=new Float32Array([-0]),Me=new Uint8Array(qn.buffer);function So(r,e,t){qn[0]=r,e[t]=Me[0],e[t+1]=Me[1],e[t+2]=Me[2],e[t+3]=Me[3]}function Eo(r,e){return Me[0]=r[e],Me[1]=r[e+1],Me[2]=r[e+2],Me[3]=r[e+3],qn[0]}var Gn=new Float64Array([-0]),K=new Uint8Array(Gn.buffer);function vo(r,e,t){Gn[0]=r,e[t]=K[0],e[t+1]=K[1],e[t+2]=K[2],e[t+3]=K[3],e[t+4]=K[4],e[t+5]=K[5],e[t+6]=K[6],e[t+7]=K[7]}function Bo(r,e){return K[0]=r[e],K[1]=r[e+1],K[2]=r[e+2],K[3]=r[e+3],K[4]=r[e+4],K[5]=r[e+5],K[6]=r[e+6],K[7]=r[e+7],Gn[0]}var ju=BigInt(Number.MAX_SAFE_INTEGER),qu=BigInt(Number.MIN_SAFE_INTEGER),ie=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return Ge;if(e<ju&&e>qu)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,i=e-(n<<32n);return t&&(n=~n|0n,i=~i|0n,++i>Io&&(i=0n,++n>Io&&(n=0n))),new r(Number(i),Number(n))}static fromNumber(e){if(e===0)return Ge;let t=e<0;t&&(e=-e);let n=e>>>0,i=(e-n)/4294967296>>>0;return t&&(i=~i>>>0,n=~n>>>0,++n>4294967295&&(n=0,++i>4294967295&&(i=0))),new r(n,i)}static from(e){return typeof e=="number"?r.fromNumber(e):typeof e=="bigint"?r.fromBigInt(e):typeof e=="string"?r.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new r(e.low>>>0,e.high>>>0):Ge}},Ge=new ie(0,0);Ge.toBigInt=function(){return 0n};Ge.zzEncode=Ge.zzDecode=function(){return this};Ge.length=function(){return 1};var Io=4294967296n;function Ao(r){let e=0,t=0;for(let n=0;n<r.length;++n)t=r.charCodeAt(n),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,e+=4):e+=3;return e}function Co(r,e,t){if(t-e<1)return"";let i,o=[],s=0,a;for(;e<t;)a=r[e++],a<128?o[s++]=a:a>191&&a<224?o[s++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,o[s++]=55296+(a>>10),o[s++]=56320+(a&1023)):o[s++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&63,s>8191&&((i??(i=[])).push(String.fromCharCode.apply(String,o)),s=0);return i!=null?(s>0&&i.push(String.fromCharCode.apply(String,o.slice(0,s))),i.join("")):String.fromCharCode.apply(String,o.slice(0,s))}function Wn(r,e,t){let n=t,i,o;for(let s=0;s<r.length;++s)i=r.charCodeAt(s),i<128?e[t++]=i:i<2048?(e[t++]=i>>6|192,e[t++]=i&63|128):(i&64512)===55296&&((o=r.charCodeAt(s+1))&64512)===56320?(i=65536+((i&1023)<<10)+(o&1023),++s,e[t++]=i>>18|240,e[t++]=i>>12&63|128,e[t++]=i>>6&63|128,e[t++]=i&63|128):(e[t++]=i>>12|224,e[t++]=i>>6&63|128,e[t++]=i&63|128);return t-n}function we(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function Nr(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var Kn=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,we(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw we(this,4);return Nr(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw we(this,4);return Nr(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw we(this,4);let e=Eo(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw we(this,4);let e=Bo(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,n=this.pos+e;if(n>this.len)throw we(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return Co(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw we(this,e);this.pos+=e}else do if(this.pos>=this.len)throw we(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new ie(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw we(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw we(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw we(this,8);let e=Nr(this.buf,this.pos+=4),t=Nr(this.buf,this.pos+=4);return new ie(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=ko(this.buf,this.pos);return this.pos+=qt(e),e}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Xn(r){return new Kn(r instanceof Uint8Array?r:r.subarray())}function Gt(r,e,t){let n=Xn(r);return e.decode(n,void 0,t)}var Jn={};W(Jn,{base10:()=>Gu});var Gu=Ue({prefix:"9",name:"base10",alphabet:"0123456789"});var Zn={};W(Zn,{base16:()=>Wu,base16upper:()=>Ku});var Wu=F({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Ku=F({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Yn={};W(Yn,{base2:()=>Xu});var Xu=F({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Qn={};W(Qn,{base256emoji:()=>ef});var To=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}"),Ju=To.reduce((r,e,t)=>(r[t]=e,r),[]),Zu=To.reduce((r,e,t)=>{let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);return r[n]=t,r},[]);function Yu(r){return r.reduce((e,t)=>(e+=Ju[t],e),"")}function Qu(r){let e=[];for(let t of r){let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);let i=Zu[n];if(i==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(i)}return new Uint8Array(e)}var ef=ut({prefix:"\u{1F680}",name:"base256emoji",encode:Yu,decode:Qu});var ei={};W(ei,{base64:()=>Wt,base64pad:()=>tf,base64url:()=>rf,base64urlpad:()=>nf});var Wt=F({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),tf=F({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),rf=F({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),nf=F({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var ti={};W(ti,{base8:()=>of});var of=F({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ri={};W(ri,{identity:()=>sf});var sf=ut({prefix:"\0",name:"identity",encode:r=>Dn(r),decode:r=>Tn(r)});var bp=new TextEncoder,af=new TextDecoder;var Do=512;function Lo(r){return JSON.parse(af.decode(r))}var Ae={};W(Ae,{code:()=>Q,decode:()=>ff,encode:()=>uf,name:()=>cf});var cf="raw",Q=85;function uf(r){return he(r)}function ff(r){return he(r)}var oi={};W(oi,{identity:()=>ii});var zo=0,lf="identity",Fo=he;function hf(r,e){if(e?.truncate!=null&&e.truncate!==r.byteLength){if(e.truncate<0||e.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e.truncate)}return dt(zo,Fo(r))}var ii={code:zo,name:lf,encode:Fo,digest:hf};var ai={};W(ai,{sha256:()=>oe,sha512:()=>pf});var df=20;function We({name:r,code:e,encode:t,minDigestLength:n,maxDigestLength:i}){return new si(r,e,t,n,i)}var si=class{name;code;encode;minDigestLength;maxDigestLength;constructor(e,t,n,i,o){this.name=e,this.code=t,this.encode=n,this.minDigestLength=i??df,this.maxDigestLength=o}digest(e,t){if(t?.truncate!=null){if(t.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&t.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(e instanceof Uint8Array){let n=this.encode(e);return n instanceof Uint8Array?Po(n,this.code,t?.truncate):n.then(i=>Po(i,this.code,t?.truncate))}else throw Error("Unknown type, must be binary type")}};function Po(r,e,t){if(t!=null&&t!==r.byteLength){if(t>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t)}return dt(e,r)}function $o(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var oe=We({name:"sha2-256",code:18,encode:$o("SHA-256")}),pf=We({name:"sha2-512",code:19,encode:$o("SHA-512")});var ci={...ri,...Yn,...ti,...Jn,...Zn,...Un,...$n,...Rn,...ei,...Qn},Lp={...ai,...oi};function Mo(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var Ro=Mo("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),ui=Mo("ascii","a",r=>{let e="a";for(let t=0;t<r.length;t++)e+=String.fromCharCode(r[t]);return e},r=>{r=r.substring(1);let e=ne(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),mf={utf8:Ro,"utf-8":Ro,hex:ci.base16,latin1:ui,ascii:ui,binary:ui,...ci},Oo=mf;function M(r,e="utf8"){let t=Oo[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function fi(r){let e=r??8192,t=e>>>1,n,i=e;return function(s){if(s<1||s>t)return ne(s);i+s>e&&(n=ne(e),i=0);let a=n.subarray(i,i+=s);return(i&7)!==0&&(i=(i|7)+1),a}}var Ke=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function li(){}var di=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},yf=fi();function gf(r){return globalThis.Buffer!=null?ne(r):yf(r)}var Xt=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ke(li,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new Ke(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new pi((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(Tr,10,ie.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=ie.fromBigInt(e);return this._push(Tr,t.length(),t)}uint64Number(e){return this._push(_o,qt(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=ie.fromBigInt(e).zzEncode();return this._push(Tr,t.length(),t)}sint64Number(e){let t=ie.fromNumber(e).zzEncode();return this._push(Tr,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(hi,1,e?1:0)}fixed32(e){return this._push(Kt,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=ie.fromBigInt(e);return this._push(Kt,4,t.lo)._push(Kt,4,t.hi)}fixed64Number(e){let t=ie.fromNumber(e);return this._push(Kt,4,t.lo)._push(Kt,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push(So,4,e)}double(e){return this._push(vo,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(hi,1,0):this.uint32(t)._push(xf,t,e)}string(e){let t=Ao(e);return t!==0?this.uint32(t)._push(Wn,t,e):this._push(hi,1,0)}fork(){return this.states=new di(this),this.head=this.tail=new Ke(li,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 Ke(li,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=e.next,this.tail=t,this.len+=n),this}finish(){let e=this.head.next,t=gf(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function hi(r,e,t){e[t]=r&255}function wf(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var pi=class extends Ke{next;constructor(e,t){super(wf,e,t),this.next=void 0}};function Tr(r,e,t){for(;r.hi!==0;)e[t++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)e[t++]=r.lo&127|128,r.lo=r.lo>>>7;e[t++]=r.lo}function Kt(r,e,t){e[t]=r&255,e[t+1]=r>>>8&255,e[t+2]=r>>>16&255,e[t+3]=r>>>24}function xf(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(Xt.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(bf,e,r),this},Xt.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(_f,e,r),this});function bf(r,e,t){e.set(r,t)}function _f(r,e,t){r.length<40?Wn(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(M(r),t)}function mi(){return new Xt}function Jt(r,e){let t=mi();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var yt;(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"})(yt||(yt={}));function Dr(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function yi(r){function e(i){if(r[i.toString()]==null)throw new Error("Invalid enum value");return r[i]}let t=function(o,s){let a=e(o);s.int32(a)},n=function(o){let s=o.int32();return e(s)};return Dr("enum",yt.VARINT,t,n)}function Zt(r,e){return Dr("message",yt.LENGTH_DELIMITED,r,e)}var xe;(function(r){let e;(function(i){i.Raw="Raw",i.Directory="Directory",i.File="File",i.Metadata="Metadata",i.Symlink="Symlink",i.HAMTShard="HAMTShard"})(e=r.DataType||(r.DataType={}));let t;(function(i){i[i.Raw=0]="Raw",i[i.Directory=1]="Directory",i[i.File=2]="File",i[i.Metadata=3]="Metadata",i[i.Symlink=4]="Symlink",i[i.HAMTShard=5]="HAMTShard"})(t||(t={})),(function(i){i.codec=()=>yi(t)})(e=r.DataType||(r.DataType={}));let n;r.codec=()=>(n==null&&(n=Zt((i,o,s={})=>{if(s.lengthDelimited!==!1&&o.fork(),i.Type!=null&&(o.uint32(8),r.DataType.codec().encode(i.Type,o)),i.Data!=null&&(o.uint32(18),o.bytes(i.Data)),i.filesize!=null&&(o.uint32(24),o.uint64(i.filesize)),i.blocksizes!=null)for(let a of i.blocksizes)o.uint32(32),o.uint64(a);i.hashType!=null&&(o.uint32(40),o.uint64(i.hashType)),i.fanout!=null&&(o.uint32(48),o.uint64(i.fanout)),i.mode!=null&&(o.uint32(56),o.uint32(i.mode)),i.mtime!=null&&(o.uint32(66),Lr.codec().encode(i.mtime,o)),s.lengthDelimited!==!1&&o.ldelim()},(i,o)=>{let s={blocksizes:[]},a=o==null?i.len:i.pos+o;for(;i.pos<a;){let c=i.uint32();switch(c>>>3){case 1:s.Type=r.DataType.codec().decode(i);break;case 2:s.Data=i.bytes();break;case 3:s.filesize=i.uint64();break;case 4:s.blocksizes.push(i.uint64());break;case 5:s.hashType=i.uint64();break;case 6:s.fanout=i.uint64();break;case 7:s.mode=i.uint32();break;case 8:s.mtime=Lr.codec().decode(i,i.uint32());break;default:i.skipType(c&7);break}}return s})),n),r.encode=i=>Jt(i,r.codec()),r.decode=i=>Gt(i,r.codec())})(xe||(xe={}));var Lr;(function(r){let e;r.codec=()=>(e==null&&(e=Zt((t,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),t.Seconds!=null&&(n.uint32(8),n.int64(t.Seconds)),t.FractionalNanoseconds!=null&&(n.uint32(21),n.fixed32(t.FractionalNanoseconds)),i.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let i={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let s=t.uint32();switch(s>>>3){case 1:i.Seconds=t.int64();break;case 2:i.FractionalNanoseconds=t.fixed32();break;default:t.skipType(s&7);break}}return i})),e),r.encode=t=>Jt(t,r.codec()),r.decode=t=>Gt(t,r.codec())})(Lr||(Lr={}));var Vo;(function(r){let e;r.codec=()=>(e==null&&(e=Zt((t,n,i={})=>{i.lengthDelimited!==!1&&n.fork(),t.MimeType!=null&&(n.uint32(10),n.string(t.MimeType)),i.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let i={},o=n==null?t.len:t.pos+n;for(;t.pos<o;){let s=t.uint32();switch(s>>>3){case 1:i.MimeType=t.string();break;default:t.skipType(s&7);break}}return i})),e),r.encode=t=>Jt(t,r.codec()),r.decode=t=>Gt(t,r.codec())})(Vo||(Vo={}));var Ho={Raw:"raw",Directory:"directory",File:"file",Metadata:"metadata",Symlink:"symlink",HAMTShard:"hamt-sharded-directory"},kf=["directory","hamt-sharded-directory"],jo=parseInt("0644",8),qo=parseInt("0755",8),Go=BigInt(1024),I=class r{static unmarshal(e){let t=xe.decode(e);if(t.fanout!=null&&t.fanout>Go)throw new Cr(`Fanout size was too large - ${t.fanout} > ${Go}`);let n=new r({type:Ho[t.Type!=null?t.Type.toString():"File"],data:t.Data,blockSizes:t.blocksizes,mode:t.mode,mtime:t.mtime!=null?{secs:t.mtime.Seconds??0n,nsecs:t.mtime.FractionalNanoseconds}:void 0,fanout:t.fanout});return n._originalMode=t.mode??0,n}type;data;blockSizes;hashType;fanout;mtime;_mode;_originalMode;constructor(e={type:"file"}){let{type:t,data:n,blockSizes:i,hashType:o,fanout:s,mtime:a,mode:c}=e;if(t!=null&&!Object.values(Ho).includes(t))throw new jt("Type: "+t+" is not valid");this.type=t??"file",this.data=n,this.hashType=o,this.fanout=s,this.blockSizes=i??[],this._originalMode=0,this.mode=c,this.mtime=a}set mode(e){e==null?this._mode=this.isDirectory()?qo:jo:this._mode=e&4095}get mode(){return this._mode}isDirectory(){return kf.includes(this.type)}addBlockSize(e){this.blockSizes.push(e)}removeBlockSize(e){this.blockSizes.splice(e,1)}fileSize(){if(this.isDirectory())return 0n;let e=0n;return this.blockSizes.forEach(t=>{e+=t}),this.data!=null&&(e+=BigInt(this.data.length)),e}marshal(){let e;switch(this.type){case"raw":e=xe.DataType.Raw;break;case"directory":e=xe.DataType.Directory;break;case"file":e=xe.DataType.File;break;case"metadata":e=xe.DataType.Metadata;break;case"symlink":e=xe.DataType.Symlink;break;case"hamt-sharded-directory":e=xe.DataType.HAMTShard;break;default:throw new jt(`Type: ${e} is not valid`)}let t=this.data;(this.data==null||this.data.length===0)&&(t=void 0);let n;this.mode!=null&&(n=this._originalMode&4294963200|(this.mode??0),n===jo&&!this.isDirectory()&&(n=void 0),n===qo&&this.isDirectory()&&(n=void 0));let i;return this.mtime!=null&&(i={Seconds:this.mtime.secs,FractionalNanoseconds:this.mtime.nsecs}),xe.encode({Type:e,Data:t,filesize:this.isDirectory()?void 0:this.fileSize(),blocksizes:this.blockSizes,hashType:this.hashType,fanout:this.fanout,mode:n,mtime:i})}};var U=class extends Event{type;detail;constructor(e,t){super(e),this.type=e,this.detail=t}};var be=async(r,e,t)=>{t.codec==null&&(t.codec=V);let n=await oe.digest(r),i=A.create(t.cidVersion,t.codec.code,n);return await e.put(i,r,t),i};function Wo(r){return async function*(t,n){let i=0n;for await(let o of t.content)yield async()=>{let s,a={codec:V,cidVersion:r.cidVersion,onProgress:r.onProgress};r.rawLeaves?(a.codec=Ae,a.cidVersion=1):(s=new I({type:r.leafType,data:o}),o=T({Data:s.marshal(),Links:[]}));let c=await be(o,n,a);return i+=BigInt(o.byteLength),r.onProgress?.(new U("unixfs:importer:progress:file:write",{bytesWritten:i,cid:c,path:t.path})),{cid:c,unixfs:s,size:BigInt(o.length),block:o}}}}var zr=class r extends Error{static name="InvalidParametersError";static code="ERR_INVALID_PARAMS";name=r.name;code=r.code;constructor(e="Invalid parameters"){super(e)}};var Oe=class r extends Error{static name="InvalidContentError";static code="ERR_INVALID_CONTENT";name=r.name;code=r.code;constructor(e="Invalid content"){super(e)}};var Ko=async(r,e,t)=>{let n=new I({type:"directory",mtime:r.mtime,mode:r.mode}),i=T(P({Data:n.marshal()})),o=await be(i,e,t),s=r.path;return{cid:o,path:s,unixfs:n,size:BigInt(i.length),originalPath:r.originalPath,block:i}};async function*Sf(r,e,t){let n=-1,i;for await(let o of Ut(t.bufferImporter(r,e),t.blockWriteConcurrency)){if(n++,n===0){i={...o,single:!0};continue}else n===1&&i!=null&&(yield{...i,block:void 0,single:void 0},i=void 0);yield{...o,block:void 0}}i!=null&&(yield i)}function Xo(r){return r.single===!0}var Ef=(r,e,t)=>async function(i){if(i.length===1&&Xo(i[0])&&t.reduceSingleLeafToSelf){let f=i[0],l=f.block;return Xo(f)&&(r.mtime!==void 0||r.mode!==void 0)&&(f.unixfs=new I({type:"file",mtime:r.mtime,mode:r.mode,data:f.block}),l={Data:f.unixfs.marshal(),Links:[]},f.block=T(P(l)),f.cid=await be(f.block,e,{...t,cidVersion:t.cidVersion}),f.size=BigInt(f.block.length)),t.onProgress?.(new U("unixfs:importer:progress:file:layout",{cid:f.cid,path:f.originalPath})),{cid:f.cid,path:r.path,unixfs:f.unixfs,size:f.size,originalPath:f.originalPath}}let o=new I({type:"file",mtime:r.mtime,mode:r.mode}),s=i.filter(f=>f.cid.code===Q&&f.size>0||f.unixfs!=null&&f.unixfs.data==null&&f.unixfs.fileSize()>0n?!0:!!f.unixfs?.data?.length).map(f=>f.cid.code===Q?(o.addBlockSize(f.size),{Name:"",Tsize:Number(f.size),Hash:f.cid}):(f.unixfs?.data==null?o.addBlockSize(f.unixfs?.fileSize()??0n):o.addBlockSize(BigInt(f.unixfs.data.length)),{Name:"",Tsize:Number(f.size),Hash:f.cid})),a={Data:o.marshal(),Links:s},c=T(P(a)),h=await be(c,e,t);return t.onProgress?.(new U("unixfs:importer:progress:file:layout",{cid:h,path:r.originalPath})),{cid:h,path:r.path,unixfs:o,size:BigInt(c.length+a.Links.reduce((f,l)=>f+(l.Tsize??0),0)),originalPath:r.originalPath,block:c}},Jo=async(r,e,t)=>t.layout(Sf(r,e,t),Ef(r,e,t));function vf(r){return Symbol.iterator in r}function Bf(r){return Symbol.asyncIterator in r}function If(r){try{if(r instanceof Uint8Array)return(async function*(){yield r})();if(vf(r))return(async function*(){yield*r})();if(Bf(r))return r}catch{throw new Oe("Content was invalid")}throw new Oe("Content was invalid")}function Zo(r){return async function*(t,n){for await(let i of t){let o;if(i.path!=null&&(o=i.path,i.path=i.path.split("/").filter(s=>s!=null&&s!==".").join("/")),Af(i)){let s={path:i.path,mtime:i.mtime,mode:i.mode,content:(async function*(){let c=0n;for await(let h of r.chunker(r.chunkValidator(If(i.content)))){let f=BigInt(h.byteLength);c+=f,r.onProgress?.(new U("unixfs:importer:progress:file:read",{bytesRead:c,chunkSize:f,path:i.path})),yield h}})(),originalPath:o},a=r.fileBuilder??Jo;yield async()=>a(s,n,r)}else if(i.path!=null){let s={path:i.path,mtime:i.mtime,mode:i.mode,originalPath:o},a=r.dirBuilder??Ko;yield async()=>a(s,n,r)}else throw new Error("Import candidate must have content or path or both")}}}function Af(r){return r.content!=null}var Yo=()=>async function*(e){for await(let t of e){if(t.length===void 0)throw new Oe("Content was invalid");if(typeof t=="string"||t instanceof String)yield M(t.toString());else if(Array.isArray(t))yield Uint8Array.from(t);else if(t instanceof Uint8Array)yield t;else throw new Oe("Content was invalid")}};var Cf=174;function Yt(r){let e=r?.maxChildrenPerNode??Cf;return async function t(n,i){let o=[];for await(let s of Sr(n,e))o.push(await i(s));return o.length>1?t(o,i):o[0]}}function Nf(r){return r[Symbol.asyncIterator]!=null}function Tf(r){if(Nf(r))return(async()=>{let t=[];for await(let n of r)t.push(n);return t})();let e=[];for(let t of r)e.push(t);return e}var Qo=Tf;var Ce=class{options;root;dir;path;dirty;flat;parent;parentKey;unixfs;mode;mtime;cid;size;nodeSize;constructor(e,t){this.options=t??{},this.root=e.root,this.dir=e.dir,this.path=e.path,this.dirty=e.dirty,this.flat=e.flat,this.parent=e.parent,this.parentKey=e.parentKey,this.unixfs=e.unixfs,this.mode=e.mode,this.mtime=e.mtime}},Qt=A.parse("QmUNLLsPACCz1vLxQVkXqqLX5R1X345qqfHbsf67hvA3Nn"),er=A.parse("zdj7WbTaiJT1fgatdet9Ei9iDB5hdCxkbVyhyh8YTUnXMiwYi");var Xe=class extends Ce{_children;constructor(e,t){super(e,t),this._children=new Map}async put(e,t){this.cid=void 0,this.size=void 0,this.nodeSize=void 0,this._children.set(e,t)}async get(e){return Promise.resolve(this._children.get(e))}childCount(){return this._children.size}directChildrenCount(){return this.childCount()}onlyChild(){return this._children.values().next().value}*eachChildSeries(){for(let[e,t]of this._children.entries())yield{key:e,child:t}}estimateNodeSize(){if(this.nodeSize!==void 0)return this.nodeSize;this.nodeSize=0;for(let[e,t]of this._children.entries())t.size!=null&&t.cid!=null&&(this.nodeSize+=e.length+(this.options.cidVersion===1?er.bytes.byteLength:Qt.bytes.byteLength));return this.nodeSize}async*flush(e){let t=[];for(let[c,h]of this._children.entries()){let f=h;if(h instanceof Ce)for await(let l of h.flush(e))f=l,yield l;f.size!=null&&f.cid!=null&&t.push({Name:c,Tsize:Number(f.size),Hash:f.cid})}let n=new I({type:"directory",mtime:this.mtime,mode:this.mode}),i={Data:n.marshal(),Links:t},o=T(P(i)),s=await be(o,e,this.options),a=o.length+i.Links.reduce((c,h)=>c+(h.Tsize??0),0);this.cid=s,this.size=a,yield{cid:s,unixfs:n,path:this.path,size:BigInt(a)}}};var Pr=Pt(rs(),1);function Df(r){let e=new Array(4);for(let t=0;t<4;t++)e[t]=r&255,r=r>>8;return new Uint8Array(e)}var n0=We({name:"murmur3-32",code:35,encode:r=>Df(Pr.default.x86.hash32(r))}),Je=We({name:"murmur3-128",code:34,encode:r=>ct.fromHex(Pr.default.x64.hash128(r))}),i0=We({name:"murmur3-x64-64",code:34,encode:r=>ct.fromHex(Pr.default.x64.hash128(r)).subarray(0,8)});var os=Pt(Ur(),1);var se=class r{_options;_popCount;_parent;_posAtParent;_children;key;constructor(e,t,n=0){this._options=e,this._popCount=0,this._parent=t,this._posAtParent=n,this._children=new os.default,this.key=null}async put(e,t){let n=await this._findNewBucketAndPos(e);n.bucket._putAt(n,e,t)}async get(e){let t=await this._findChild(e);if(t!=null)return t.value}async del(e){let t=await this._findPlace(e),n=t.bucket._at(t.pos);n!=null&&n.key===e&&t.bucket._delAt(t.pos)}leafCount(){return this._children.compactArray().reduce((t,n)=>n instanceof r?t+n.leafCount():t+1,0)}childrenCount(){return this._children.length}onlyChild(){return this._children.get(0)}*eachLeafSeries(){let e=this._children.compactArray();for(let t of e)t instanceof r?yield*t.eachLeafSeries():yield t}serialize(e,t){let n=[];return t(this._children.reduce((i,o,s)=>(o!=null&&(o instanceof r?i.push(o.serialize(e,t)):i.push(e(o,s))),i),n))}async asyncTransform(e,t){return ss(this,e,t)}toJSON(){return this.serialize(Uf,$f)}prettyPrint(){return JSON.stringify(this.toJSON(),null," ")}tableSize(){return Math.pow(2,this._options.bits)}async _findChild(e){let t=await this._findPlace(e),n=t.bucket._at(t.pos);if(!(n instanceof r)&&n!=null&&n.key===e)return n}async _findPlace(e){let t=this._options.hash(typeof e=="string"?M(e):e),n=await t.take(this._options.bits),i=this._children.get(n);return i instanceof r?i._findPlace(t):{bucket:this,pos:n,hash:t,existingChild:i}}async _findNewBucketAndPos(e){let t=await this._findPlace(e);if(t.existingChild!=null&&t.existingChild.key!==e){let n=new r(this._options,t.bucket,t.pos);t.bucket._putObjectAt(t.pos,n);let i=await n._findPlace(t.existingChild.hash);return i.bucket._putAt(i,t.existingChild.key,t.existingChild.value),n._findNewBucketAndPos(t.hash)}return t}_putAt(e,t,n){this._putObjectAt(e.pos,{key:t,value:n,hash:e.hash})}_putObjectAt(e,t){this._children.get(e)==null&&this._popCount++,this._children.set(e,t)}_delAt(e){if(e===-1)throw new Error("Invalid position");this._children.get(e)!=null&&this._popCount--,this._children.unset(e),this._level()}_level(){if(this._parent!=null&&this._popCount<=1)if(this._popCount===1){let e=this._children.find(Pf);if(e!=null&&!(e instanceof r)){let t=e.hash;t.untake(this._options.bits);let n={pos:this._posAtParent,hash:t,bucket:this._parent};this._parent._putAt(n,e.key,e.value)}}else this._parent._delAt(this._posAtParent)}_at(e){return this._children.get(e)}};function Pf(r){return!!r}function Uf(r,e){return r.key}function $f(r){return r}async function ss(r,e,t){let n=[];for(let i of r._children.compactArray())if(i instanceof se)await ss(i,e,t);else{let o=await e(i);n.push({bitField:r._children.bitField(),children:o})}return t(n)}var Rf=[255,254,252,248,240,224,192,128],Mf=[1,3,7,15,31,63,127,255],$r=class{_value;_currentBytePos;_currentBitPos;constructor(e){this._value=e,this._currentBytePos=e.length-1,this._currentBitPos=7}availableBits(){return this._currentBitPos+1+this._currentBytePos*8}totalBits(){return this._value.length*8}take(e){let t=e,n=0;for(;t>0&&this._haveBits();){let i=this._value[this._currentBytePos],o=this._currentBitPos+1,s=Math.min(o,t),a=Of(i,o-s,s);n=(n<<s)+a,t-=s,this._currentBitPos-=s,this._currentBitPos<0&&(this._currentBitPos=7,this._currentBytePos--)}return n}untake(e){for(this._currentBitPos+=e;this._currentBitPos>7;)this._currentBitPos-=8,this._currentBytePos+=1}_haveBits(){return this._currentBytePos>=0}};function Of(r,e,t){let n=Vf(e,t);return(r&n)>>>e}function Vf(r,e){return Rf[r]&Mf[Math.min(e+r-1,7)]}function as(r){function e(t){return t instanceof Rr?t:new Rr(t,r)}return e}var Rr=class{_value;_hashFn;_depth;_availableBits;_currentBufferIndex;_buffers;constructor(e,t){if(!(e instanceof Uint8Array))throw new Error("can only hash Uint8Arrays");this._value=e,this._hashFn=t,this._depth=-1,this._availableBits=0,this._currentBufferIndex=0,this._buffers=[]}async take(e){let t=e;for(;this._availableBits<t;)await this._produceMoreBits();let n=0;for(;t>0;){let i=this._buffers[this._currentBufferIndex],o=Math.min(i.availableBits(),t),s=i.take(o);n=(n<<o)+s,t-=o,this._availableBits-=o,i.availableBits()===0&&this._currentBufferIndex++}return n}untake(e){let t=e;for(;t>0;){let n=this._buffers[this._currentBufferIndex],i=Math.min(n.totalBits()-n.availableBits(),t);n.untake(i),t-=i,this._availableBits+=i,this._currentBufferIndex>0&&n.totalBits()===n.availableBits()&&(this._depth--,this._currentBufferIndex--)}}async _produceMoreBits(){this._depth++;let e=this._depth>0?Ie([this._value,Uint8Array.from([this._depth])]):this._value,t=await this._hashFn(e),n=new $r(t);this._buffers.push(n),this._availableBits+=n.availableBits()}};function gt(r){if(r==null||r.hashFn==null)throw new Error("please define an options.hashFn");let e={bits:r.bits??8,hash:as(r.hashFn)};return new se(e)}async function Hf(r){return(await Je.encode(r)).slice(0,8).reverse()}var cs=BigInt(34),jf=8,gi=class extends Ce{_bucket;constructor(e,t){super(e,t),this._bucket=gt({hashFn:Hf,bits:t.shardFanoutBits??jf})}async put(e,t){this.cid=void 0,this.size=void 0,this.nodeSize=void 0,await this._bucket.put(e,t)}async get(e){return this._bucket.get(e)}childCount(){return this._bucket.leafCount()}directChildrenCount(){return this._bucket.childrenCount()}onlyChild(){return this._bucket.onlyChild()}*eachChildSeries(){for(let{key:e,value:t}of this._bucket.eachLeafSeries())yield{key:e,child:t}}estimateNodeSize(){return this.nodeSize!==void 0?this.nodeSize:(this.nodeSize=ls(this._bucket,this,this.options),this.nodeSize)}async*flush(e){for await(let t of fs(this._bucket,e,this,this.options))yield{...t,path:this.path}}},us=gi;async function*fs(r,e,t,n){let i=r._children,o=(r.tableSize()-1).toString(16).length,s=[],a=0n;for(let d=0;d<i.length;d++){let m=i.get(d);if(m==null)continue;let x=d.toString(16).toUpperCase().padStart(o,"0");if(m instanceof se){let g;for await(let w of fs(m,e,null,n))g=w;if(g==null)throw new Error("Could not flush sharded directory, no subshard found");s.push({Name:x,Tsize:Number(g.size),Hash:g.cid}),a+=g.size}else if(qf(m.value)){let g=m.value,w;for await(let S of g.flush(e))w=S,yield w;if(w==null)throw new Error("Did not flush dir");let _=x+m.key;s.push({Name:_,Tsize:Number(w.size),Hash:w.cid}),a+=w.size}else{let g=m.value;if(g.cid==null)continue;let w=x+m.key,_=g.size;s.push({Name:w,Tsize:Number(_),Hash:g.cid}),a+=BigInt(_??0)}}let c=Uint8Array.from(i.bitField().reverse()),h=new I({type:"hamt-sharded-directory",data:c,fanout:BigInt(r.tableSize()),hashType:cs,mtime:t?.mtime,mode:t?.mode}),f={Data:h.marshal(),Links:s},l=T(P(f)),y=await be(l,e,n),u=BigInt(l.byteLength)+a;yield{cid:y,unixfs:h,size:u}}function qf(r){return typeof r.flush=="function"}function ls(r,e,t){let n=r._children,i=(r.tableSize()-1).toString(16).length,o=[];for(let h=0;h<n.length;h++){let f=n.get(h);if(f==null)continue;let l=h.toString(16).toUpperCase().padStart(i,"0");if(f instanceof se){let y=ls(f,null,t);o.push({Name:l,Tsize:Number(y),Hash:t.cidVersion===0?Qt:er})}else if(typeof f.value.flush=="function"){let u=f.value.nodeSize();o.push({Name:l+f.key,Tsize:Number(u),Hash:t.cidVersion===0?Qt:er})}else{let y=f.value;if(y.cid==null)continue;let u=l+f.key,d=y.size;o.push({Name:u,Tsize:Number(d),Hash:y.cid})}}let s=Uint8Array.from(n.bitField().reverse()),a=new I({type:"hamt-sharded-directory",data:s,fanout:BigInt(r.tableSize()),hashType:cs,mtime:e?.mtime,mode:e?.mode});return T(P({Data:a.marshal(),Links:o})).length}async function wi(r,e,t,n){let i=e;e instanceof Xe&&e.estimateNodeSize()>t&&(i=await Gf(e,n));let o=i.parent;if(o!=null){if(i!==e){if(r!=null&&(r.parent=i),i.parentKey==null)throw new Error("No parent key found");await o.put(i.parentKey,i)}return wi(i,o,t,n)}return i}async function Gf(r,e){let t=new us({root:r.root,dir:!0,parent:r.parent,parentKey:r.parentKey,path:r.path,dirty:r.dirty,flat:!1,mtime:r.mtime,mode:r.mode},e);for(let{key:n,child:i}of r.eachChildSeries())await t.put(n,i);return t}var hs=(r="")=>r.split(/(?<!\\)\//).filter(Boolean);async function Wf(r,e,t){let n=hs(r.path??""),i=n.length-1,o=e,s="";for(let a=0;a<n.length;a++){let c=n[a];s+=`${s!==""?"/":""}${c}`;let h=a===i;if(o.dirty=!0,o.cid=void 0,o.size=void 0,h)await o.put(c,r),e=await wi(null,o,t.shardSplitThresholdBytes,t);else{let f=await o.get(c);(f==null||!(f instanceof Ce))&&(f=new Xe({root:!1,dir:!0,parent:o,parentKey:c,path:s,dirty:!0,flat:!0,mtime:f?.unixfs?.mtime,mode:f?.unixfs?.mode},t)),await o.put(c,f),o=f}}return e}async function*ds(r,e){if(!(r instanceof Ce)){r.unixfs?.isDirectory()===!0&&(yield r);return}yield*r.flush(e)}function ps(r){return async function*(t,n){let i=new Xe({root:!0,dir:!0,path:"",dirty:!0,flat:!0},r),o,s=!1;for await(let a of t){if(a==null)continue;let c=`${a.originalPath??""}`.split("/")[0];c!=null&&c!==""&&(o==null?(o=c,s=!0):o!==c&&(s=!1)),i=await Wf(a,i,r),a.unixfs?.isDirectory()!==!0&&(yield a)}if(r.wrapWithDirectory||s&&i.childCount()>1)yield*ds(i,n);else for(let a of i.eachChildSeries())a!=null&&(yield*ds(a.child,n))}}async function*Ze(r,e,t={}){let n;Symbol.asyncIterator in r||Symbol.iterator in r?n=r:n=[r];let i=t.wrapWithDirectory??!1,o=t.shardSplitThresholdBytes??262144,s=t.shardFanoutBits??8,a=t.cidVersion??1,c=t.rawLeaves??!0,h=t.leafType??"file",f=t.fileImportConcurrency??50,l=t.blockWriteConcurrency??10,y=t.reduceSingleLeafToSelf??!0,u=t.chunker??$t(),d=t.chunkValidator??Yo(),m=t.dagBuilder??Zo({chunker:u,chunkValidator:d,wrapWithDirectory:i,layout:t.layout??Yt(),bufferImporter:t.bufferImporter??Wo({cidVersion:a,rawLeaves:c,leafType:h,onProgress:t.onProgress}),blockWriteConcurrency:l,reduceSingleLeafToSelf:y,cidVersion:a,onProgress:t.onProgress,dirBuilder:t.dirBuilder,fileBuilder:t.fileBuilder}),x=t.treeBuilder??ps({wrapWithDirectory:i,shardSplitThresholdBytes:o,shardFanoutBits:s,cidVersion:a,onProgress:t.onProgress});for await(let g of x(Ut(m(n,e),f),e))yield{cid:g.cid,path:g.path,unixfs:g.unixfs,size:g.size}}async function ms(r,e,t={}){let n=await kr(Ze([r],e,t));if(n==null)throw new zr("Nothing imported");return n}async function ys(r,e,t={}){return ms({content:r},e,t)}async function gs(r,e,t={}){return ms({content:r},e,t)}function Kf(r){return r[Symbol.asyncIterator]!=null}function Xf(r){if(Kf(r))return(async()=>{let t;for await(let n of r)t=n;return t})();let e;for(let t of r)e=t;return e}var _e=Xf;var ke=class extends Error{name;code;constructor(e,t,n){super(e),this.name=t,this.code=n}},Ne=class extends ke{constructor(e="not a Unixfs node"){super(e,"NotUnixFSError","ERR_NOT_UNIXFS")}},ee=class extends ke{constructor(e="invalid PBNode"){super(e,"InvalidPBNodeError","ERR_INVALID_PB_NODE")}},Te=class extends ke{constructor(e="unknown error"){super(e,"InvalidPBNodeError","ERR_UNKNOWN_ERROR")}},rr=class extends ke{constructor(e="path already exists"){super(e,"AlreadyExistsError","ERR_ALREADY_EXISTS")}},Mr=class extends ke{constructor(e="path does not exist"){super(e,"DoesNotExistError","ERR_DOES_NOT_EXIST")}},wt=class extends ke{constructor(e="no content"){super(e,"NoContentError","ERR_NO_CONTENT")}},Or=class extends ke{constructor(e="not a file"){super(e,"NotAFileError","ERR_NOT_A_FILE")}},Ve=class extends ke{constructor(e="not a directory"){super(e,"NotADirectoryError","ERR_NOT_A_DIRECTORY")}},H=class extends ke{constructor(e="invalid parameters"){super(e,"InvalidParametersError","ERR_INVALID_PARAMETERS")}};var nr={cidVersion:1,rawLeaves:!0,layout:Yt({maxChildrenPerNode:1024}),chunker:$t({chunkSize:1048576})};async function*Vr(r,e,t={}){yield*Ze(r,e,{...nr,...t})}async function ws(r,e,t={}){let{cid:n}=await ys(r,e,{...nr,...t});return n}async function xs(r,e,t={}){let{cid:n}=await gs(r,e,{...nr,...t});return n}async function bs(r,e,t={}){if(r.path==null)throw new H("path is required");if(r.content==null)throw new H("content is required");let n=await _e(Vr([r],e,{...nr,...t,wrapWithDirectory:!0}));if(n==null)throw new H("Nothing imported");return n.cid}async function _s(r,e,t={}){if(r.content!=null)throw new H("Directories cannot have content, use addFile instead");let i=await(r.path==null?kr:_e)(Vr([{...r,path:r.path??"-"}],e,{...nr,...t,wrapWithDirectory:r.path!=null}));if(i==null)throw new H("Nothing imported");return i.cid}var Hr=class r extends Error{static name="BadPathError";static code="ERR_BAD_PATH";name=r.name;code=r.code;constructor(e="Bad path"){super(e)}},pe=class r extends Error{static name="NotFoundError";static code="ERR_NOT_FOUND";name=r.name;code=r.code;constructor(e="Not found"){super(e)}},jr=class r extends Error{static name="NoResolverError";static code="ERR_NO_RESOLVER";name=r.name;code=r.code;constructor(e="No resolver"){super(e)}},O=class r extends Error{static name="NotUnixFSError";static code="ERR_NOT_UNIXFS";name=r.name;code=r.code;constructor(e="Not UnixFS"){super(e)}},qr=class r extends Error{static name="OverReadError";static code="ERR_OVER_READ";name=r.name;code=r.code;constructor(e="Over read"){super(e)}},Gr=class r extends Error{static name="UnderReadError";static code="ERR_UNDER_READ";name=r.name;code=r.code;constructor(e="Under read"){super(e)}},Wr=class r extends Error{static name="NoPropError";static code="ERR_NO_PROP";name=r.name;code=r.code;constructor(e="No Property found"){super(e)}},Ye=class r extends Error{static name="InvalidParametersError";static code="ERR_INVALID_PARAMS";name=r.name;code=r.code;constructor(e="Invalid parameters"){super(e)}};var Jf=["string","number","bigint","symbol"],Zf=["Function","Generator","AsyncGenerator","GeneratorFunction","AsyncGeneratorFunction","AsyncFunction","Observable","Array","Buffer","Object","RegExp","Date","Error","Map","Set","WeakMap","WeakSet","ArrayBuffer","SharedArrayBuffer","DataView","Promise","URL","HTMLElement","Int8Array","Uint8Array","Uint8ClampedArray","Int16Array","Uint16Array","Int32Array","Uint32Array","Float32Array","Float64Array","BigInt64Array","BigUint64Array"];function ks(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let e=typeof r;if(Jf.includes(e))return e;if(e==="function")return"Function";if(Array.isArray(r))return"Array";if(Yf(r))return"Buffer";let t=Qf(r);return t||"Object"}function Yf(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function Qf(r){let e=Object.prototype.toString.call(r).slice(8,-1);if(Zf.includes(e))return e}var p=class{constructor(e,t,n){this.major=e,this.majorEncoded=e<<5,this.name=t,this.terminal=n}toString(){return`Type[${this.major}].${this.name}`}compare(e){return this.major<e.major?-1:this.major>e.major?1:0}};p.uint=new p(0,"uint",!0);p.negint=new p(1,"negint",!0);p.bytes=new p(2,"bytes",!0);p.string=new p(3,"string",!0);p.array=new p(4,"array",!1);p.map=new p(5,"map",!1);p.tag=new p(6,"tag",!1);p.float=new p(7,"float",!0);p.false=new p(7,"false",!0);p.true=new p(7,"true",!0);p.null=new p(7,"null",!0);p.undefined=new p(7,"undefined",!0);p.break=new p(7,"break",!0);var b=class{constructor(e,t,n){this.type=e,this.value=t,this.encodedLength=n,this.encodedBytes=void 0,this.byteValue=void 0}toString(){return`Token[${this.type}].${this.value}`}};var xt=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",el=new TextDecoder,tl=new TextEncoder;function Kr(r){return xt&&globalThis.Buffer.isBuffer(r)}function ir(r){return r instanceof Uint8Array?Kr(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var Bs=xt?(r,e,t)=>t-e>64?globalThis.Buffer.from(r.subarray(e,t)).toString("utf8"):Es(r,e,t):(r,e,t)=>t-e>64?el.decode(r.subarray(e,t)):Es(r,e,t),Xr=xt?r=>r.length>64?globalThis.Buffer.from(r):Ss(r):r=>r.length>64?tl.encode(r):Ss(r),De=r=>Uint8Array.from(r),bt=xt?(r,e,t)=>Kr(r)?new Uint8Array(r.subarray(e,t)):r.slice(e,t):(r,e,t)=>r.slice(e,t),Is=xt?(r,e)=>(r=r.map(t=>t instanceof Uint8Array?t:globalThis.Buffer.from(t)),ir(globalThis.Buffer.concat(r,e))):(r,e)=>{let t=new Uint8Array(e),n=0;for(let i of r)n+i.length>t.length&&(i=i.subarray(0,t.length-n)),t.set(i,n),n+=i.length;return t},As=xt?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function Jr(r,e){if(Kr(r)&&Kr(e))return r.compare(e);for(let t=0;t<r.length;t++)if(r[t]!==e[t])return r[t]<e[t]?-1:1;return 0}function Ss(r){let e=[],t=0;for(let n=0;n<r.length;n++){let i=r.charCodeAt(n);i<128?e[t++]=i:i<2048?(e[t++]=i>>6|192,e[t++]=i&63|128):(i&64512)===55296&&n+1<r.length&&(r.charCodeAt(n+1)&64512)===56320?(i=65536+((i&1023)<<10)+(r.charCodeAt(++n)&1023),e[t++]=i>>18|240,e[t++]=i>>12&63|128,e[t++]=i>>6&63|128,e[t++]=i&63|128):(e[t++]=i>>12|224,e[t++]=i>>6&63|128,e[t++]=i&63|128)}return e}function Es(r,e,t){let n=[];for(;e<t;){let i=r[e],o=null,s=i>239?4:i>223?3:i>191?2:1;if(e+s<=t){let a,c,h,f;switch(s){case 1:i<128&&(o=i);break;case 2:a=r[e+1],(a&192)===128&&(f=(i&31)<<6|a&63,f>127&&(o=f));break;case 3:a=r[e+1],c=r[e+2],(a&192)===128&&(c&192)===128&&(f=(i&15)<<12|(a&63)<<6|c&63,f>2047&&(f<55296||f>57343)&&(o=f));break;case 4:a=r[e+1],c=r[e+2],h=r[e+3],(a&192)===128&&(c&192)===128&&(h&192)===128&&(f=(i&15)<<18|(a&63)<<12|(c&63)<<6|h&63,f>65535&&f<1114112&&(o=f))}}o===null?(o=65533,s=1):o>65535&&(o-=65536,n.push(o>>>10&1023|55296),o=56320|o&1023),n.push(o),e+=s}return xi(n)}var vs=4096;function xi(r){let e=r.length;if(e<=vs)return String.fromCharCode.apply(String,r);let t="",n=0;for(;n<e;)t+=String.fromCharCode.apply(String,r.slice(n,n+=vs));return t}var rl=256,or=class{constructor(e=rl){this.chunkSize=e,this.cursor=0,this.maxCursor=-1,this.chunks=[],this._initReuseChunk=null}reset(){this.cursor=0,this.maxCursor=-1,this.chunks.length&&(this.chunks=[]),this._initReuseChunk!==null&&(this.chunks.push(this._initReuseChunk),this.maxCursor=this._initReuseChunk.length-1)}push(e){let t=this.chunks[this.chunks.length-1];if(this.cursor+e.length<=this.maxCursor+1){let i=t.length-(this.maxCursor-this.cursor)-1;t.set(e,i)}else{if(t){let i=t.length-(this.maxCursor-this.cursor)-1;i<t.length&&(this.chunks[this.chunks.length-1]=t.subarray(0,i),this.maxCursor=this.cursor-1)}e.length<64&&e.length<this.chunkSize?(t=As(this.chunkSize),this.chunks.push(t),this.maxCursor+=t.length,this._initReuseChunk===null&&(this._initReuseChunk=t),t.set(e,0)):(this.chunks.push(e),this.maxCursor+=e.length)}this.cursor+=e.length}toBytes(e=!1){let t;if(this.chunks.length===1){let n=this.chunks[0];e&&this.cursor>n.length/2?(t=this.cursor===n.length?n:n.subarray(0,this.cursor),this._initReuseChunk=null,this.chunks=[]):t=bt(n,0,this.cursor)}else t=Is(this.chunks,this.cursor);return e&&this.reset(),t}};var v="CBOR decode error:",_t="CBOR encode error:",sr=[];sr[23]=1;sr[24]=2;sr[25]=3;sr[26]=5;sr[27]=9;function Pe(r,e,t){if(r.length-e<t)throw new Error(`${v} not enough data for type`)}var j=[24,256,65536,4294967296,BigInt("18446744073709551616")];function ae(r,e,t){Pe(r,e,1);let n=r[e];if(t.strict===!0&&n<j[0])throw new Error(`${v} integer encoded in more bytes than necessary (strict decode)`);return n}function ce(r,e,t){Pe(r,e,2);let n=r[e]<<8|r[e+1];if(t.strict===!0&&n<j[1])throw new Error(`${v} integer encoded in more bytes than necessary (strict decode)`);return n}function ue(r,e,t){Pe(r,e,4);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3];if(t.strict===!0&&n<j[2])throw new Error(`${v} integer encoded in more bytes than necessary (strict decode)`);return n}function fe(r,e,t){Pe(r,e,8);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3],i=r[e+4]*16777216+(r[e+5]<<16)+(r[e+6]<<8)+r[e+7],o=(BigInt(n)<<BigInt(32))+BigInt(i);if(t.strict===!0&&o<j[3])throw new Error(`${v} integer encoded in more bytes than necessary (strict decode)`);if(o<=Number.MAX_SAFE_INTEGER)return Number(o);if(t.allowBigInt===!0)return o;throw new Error(`${v} integers outside of the safe integer range are not supported`)}function Cs(r,e,t,n){return new b(p.uint,ae(r,e+1,n),2)}function Ns(r,e,t,n){return new b(p.uint,ce(r,e+1,n),3)}function Ts(r,e,t,n){return new b(p.uint,ue(r,e+1,n),5)}function Ds(r,e,t,n){return new b(p.uint,fe(r,e+1,n),9)}function me(r,e){return G(r,0,e.value)}function G(r,e,t){if(t<j[0]){let n=Number(t);r.push([e|n])}else if(t<j[1]){let n=Number(t);r.push([e|24,n])}else if(t<j[2]){let n=Number(t);r.push([e|25,n>>>8,n&255])}else if(t<j[3]){let n=Number(t);r.push([e|26,n>>>24&255,n>>>16&255,n>>>8&255,n&255])}else{let n=BigInt(t);if(n<j[4]){let i=[e|27,0,0,0,0,0,0,0],o=Number(n&BigInt(4294967295)),s=Number(n>>BigInt(32)&BigInt(4294967295));i[8]=o&255,o=o>>8,i[7]=o&255,o=o>>8,i[6]=o&255,o=o>>8,i[5]=o&255,i[4]=s&255,s=s>>8,i[3]=s&255,s=s>>8,i[2]=s&255,s=s>>8,i[1]=s&255,r.push(i)}else throw new Error(`${v} encountered BigInt larger than allowable range`)}}me.encodedSize=function(e){return G.encodedSize(e.value)};G.encodedSize=function(e){return e<j[0]?1:e<j[1]?2:e<j[2]?3:e<j[3]?5:9};me.compareTokens=function(e,t){return e.value<t.value?-1:e.value>t.value?1:0};function Ls(r,e,t,n){return new b(p.negint,-1-ae(r,e+1,n),2)}function zs(r,e,t,n){return new b(p.negint,-1-ce(r,e+1,n),3)}function Fs(r,e,t,n){return new b(p.negint,-1-ue(r,e+1,n),5)}var bi=BigInt(-1),Ps=BigInt(1);function Us(r,e,t,n){let i=fe(r,e+1,n);if(typeof i!="bigint"){let o=-1-i;if(o>=Number.MIN_SAFE_INTEGER)return new b(p.negint,o,9)}if(n.allowBigInt!==!0)throw new Error(`${v} integers outside of the safe integer range are not supported`);return new b(p.negint,bi-BigInt(i),9)}function Zr(r,e){let t=e.value,n=typeof t=="bigint"?t*bi-Ps:t*-1-1;G(r,e.type.majorEncoded,n)}Zr.encodedSize=function(e){let t=e.value,n=typeof t=="bigint"?t*bi-Ps:t*-1-1;return n<j[0]?1:n<j[1]?2:n<j[2]?3:n<j[3]?5:9};Zr.compareTokens=function(e,t){return e.value<t.value?1:e.value>t.value?-1:0};function ar(r,e,t,n){Pe(r,e,t+n);let i=bt(r,e+t,e+t+n);return new b(p.bytes,i,t+n)}function $s(r,e,t,n){return ar(r,e,1,t)}function Rs(r,e,t,n){return ar(r,e,2,ae(r,e+1,n))}function Ms(r,e,t,n){return ar(r,e,3,ce(r,e+1,n))}function Os(r,e,t,n){return ar(r,e,5,ue(r,e+1,n))}function Vs(r,e,t,n){let i=fe(r,e+1,n);if(typeof i=="bigint")throw new Error(`${v} 64-bit integer bytes lengths not supported`);return ar(r,e,9,i)}function Yr(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===p.string?Xr(r.value):r.value),r.encodedBytes}function kt(r,e){let t=Yr(e);G(r,e.type.majorEncoded,t.length),r.push(t)}kt.encodedSize=function(e){let t=Yr(e);return G.encodedSize(t.length)+t.length};kt.compareTokens=function(e,t){return il(Yr(e),Yr(t))};function il(r,e){return r.length<e.length?-1:r.length>e.length?1:Jr(r,e)}function cr(r,e,t,n,i){let o=t+n;Pe(r,e,o);let s=new b(p.string,Bs(r,e+t,e+o),o);return i.retainStringBytes===!0&&(s.byteValue=bt(r,e+t,e+o)),s}function Hs(r,e,t,n){return cr(r,e,1,t,n)}function js(r,e,t,n){return cr(r,e,2,ae(r,e+1,n),n)}function qs(r,e,t,n){return cr(r,e,3,ce(r,e+1,n),n)}function Gs(r,e,t,n){return cr(r,e,5,ue(r,e+1,n),n)}function Ws(r,e,t,n){let i=fe(r,e+1,n);if(typeof i=="bigint")throw new Error(`${v} 64-bit integer string lengths not supported`);return cr(r,e,9,i,n)}var Ks=kt;function St(r,e,t,n){return new b(p.array,n,t)}function Xs(r,e,t,n){return St(r,e,1,t)}function Js(r,e,t,n){return St(r,e,2,ae(r,e+1,n))}function Zs(r,e,t,n){return St(r,e,3,ce(r,e+1,n))}function Ys(r,e,t,n){return St(r,e,5,ue(r,e+1,n))}function Qs(r,e,t,n){let i=fe(r,e+1,n);if(typeof i=="bigint")throw new Error(`${v} 64-bit integer array lengths not supported`);return St(r,e,9,i)}function ea(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${v} indefinite length items not allowed`);return St(r,e,1,1/0)}function Qr(r,e){G(r,p.array.majorEncoded,e.value)}Qr.compareTokens=me.compareTokens;Qr.encodedSize=function(e){return G.encodedSize(e.value)};function Et(r,e,t,n){return new b(p.map,n,t)}function ta(r,e,t,n){return Et(r,e,1,t)}function ra(r,e,t,n){return Et(r,e,2,ae(r,e+1,n))}function na(r,e,t,n){return Et(r,e,3,ce(r,e+1,n))}function ia(r,e,t,n){return Et(r,e,5,ue(r,e+1,n))}function oa(r,e,t,n){let i=fe(r,e+1,n);if(typeof i=="bigint")throw new Error(`${v} 64-bit integer map lengths not supported`);return Et(r,e,9,i)}function sa(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${v} indefinite length items not allowed`);return Et(r,e,1,1/0)}function en(r,e){G(r,p.map.majorEncoded,e.value)}en.compareTokens=me.compareTokens;en.encodedSize=function(e){return G.encodedSize(e.value)};function aa(r,e,t,n){return new b(p.tag,t,1)}function ca(r,e,t,n){return new b(p.tag,ae(r,e+1,n),2)}function ua(r,e,t,n){return new b(p.tag,ce(r,e+1,n),3)}function fa(r,e,t,n){return new b(p.tag,ue(r,e+1,n),5)}function la(r,e,t,n){return new b(p.tag,fe(r,e+1,n),9)}function tn(r,e){G(r,p.tag.majorEncoded,e.value)}tn.compareTokens=me.compareTokens;tn.encodedSize=function(e){return G.encodedSize(e.value)};var fl=20,ll=21,hl=22,dl=23;function ha(r,e,t,n){if(n.allowUndefined===!1)throw new Error(`${v} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new b(p.null,null,1):new b(p.undefined,void 0,1)}function da(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${v} indefinite length items not allowed`);return new b(p.break,void 0,1)}function _i(r,e,t){if(t){if(t.allowNaN===!1&&Number.isNaN(r))throw new Error(`${v} NaN values are not supported`);if(t.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${v} Infinity values are not supported`)}return new b(p.float,r,e)}function pa(r,e,t,n){return _i(ki(r,e+1),3,n)}function ma(r,e,t,n){return _i(Si(r,e+1),5,n)}function ya(r,e,t,n){return _i(ba(r,e+1),9,n)}function rn(r,e,t){let n=e.value;if(n===!1)r.push([p.float.majorEncoded|fl]);else if(n===!0)r.push([p.float.majorEncoded|ll]);else if(n===null)r.push([p.float.majorEncoded|hl]);else if(n===void 0)r.push([p.float.majorEncoded|dl]);else{let i,o=!1;(!t||t.float64!==!0)&&(wa(n),i=ki(Se,1),n===i||Number.isNaN(n)?(Se[0]=249,r.push(Se.slice(0,3)),o=!0):(xa(n),i=Si(Se,1),n===i&&(Se[0]=250,r.push(Se.slice(0,5)),o=!0))),o||(pl(n),i=ba(Se,1),Se[0]=251,r.push(Se.slice(0,9)))}}rn.encodedSize=function(e,t){let n=e.value;if(n===!1||n===!0||n===null||n===void 0)return 1;if(!t||t.float64!==!0){wa(n);let i=ki(Se,1);if(n===i||Number.isNaN(n))return 3;if(xa(n),i=Si(Se,1),n===i)return 5}return 9};var ga=new ArrayBuffer(9),ye=new DataView(ga,1),Se=new Uint8Array(ga,0);function wa(r){if(r===1/0)ye.setUint16(0,31744,!1);else if(r===-1/0)ye.setUint16(0,64512,!1);else if(Number.isNaN(r))ye.setUint16(0,32256,!1);else{ye.setFloat32(0,r);let e=ye.getUint32(0),t=(e&2139095040)>>23,n=e&8388607;if(t===255)ye.setUint16(0,31744,!1);else if(t===0)ye.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let i=t-127;i<-24?ye.setUint16(0,0):i<-14?ye.setUint16(0,(e&2147483648)>>16|1<<24+i,!1):ye.setUint16(0,(e&2147483648)>>16|i+15<<10|n>>13,!1)}}}function ki(r,e){if(r.length-e<2)throw new Error(`${v} not enough data for float16`);let t=(r[e]<<8)+r[e+1];if(t===31744)return 1/0;if(t===64512)return-1/0;if(t===32256)return NaN;let n=t>>10&31,i=t&1023,o;return n===0?o=i*2**-24:n!==31?o=(i+1024)*2**(n-25):o=i===0?1/0:NaN,t&32768?-o:o}function xa(r){ye.setFloat32(0,r,!1)}function Si(r,e){if(r.length-e<4)throw new Error(`${v} not enough data for float32`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,4).getFloat32(0,!1)}function pl(r){ye.setFloat64(0,r,!1)}function ba(r,e){if(r.length-e<8)throw new Error(`${v} not enough data for float64`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,8).getFloat64(0,!1)}rn.compareTokens=me.compareTokens;function D(r,e,t){throw new Error(`${v} encountered invalid minor (${t}) for major ${r[e]>>>5}`)}function nn(r){return()=>{throw new Error(`${v} ${r}`)}}var k=[];for(let r=0;r<=23;r++)k[r]=D;k[24]=Cs;k[25]=Ns;k[26]=Ts;k[27]=Ds;k[28]=D;k[29]=D;k[30]=D;k[31]=D;for(let r=32;r<=55;r++)k[r]=D;k[56]=Ls;k[57]=zs;k[58]=Fs;k[59]=Us;k[60]=D;k[61]=D;k[62]=D;k[63]=D;for(let r=64;r<=87;r++)k[r]=$s;k[88]=Rs;k[89]=Ms;k[90]=Os;k[91]=Vs;k[92]=D;k[93]=D;k[94]=D;k[95]=nn("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)k[r]=Hs;k[120]=js;k[121]=qs;k[122]=Gs;k[123]=Ws;k[124]=D;k[125]=D;k[126]=D;k[127]=nn("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)k[r]=Xs;k[152]=Js;k[153]=Zs;k[154]=Ys;k[155]=Qs;k[156]=D;k[157]=D;k[158]=D;k[159]=ea;for(let r=160;r<=183;r++)k[r]=ta;k[184]=ra;k[185]=na;k[186]=ia;k[187]=oa;k[188]=D;k[189]=D;k[190]=D;k[191]=sa;for(let r=192;r<=215;r++)k[r]=aa;k[216]=ca;k[217]=ua;k[218]=fa;k[219]=la;k[220]=D;k[221]=D;k[222]=D;k[223]=D;for(let r=224;r<=243;r++)k[r]=nn("simple values are not supported");k[244]=D;k[245]=D;k[246]=D;k[247]=ha;k[248]=nn("simple values are not supported");k[249]=pa;k[250]=ma;k[251]=ya;k[252]=D;k[253]=D;k[254]=D;k[255]=da;var Ee=[];for(let r=0;r<24;r++)Ee[r]=new b(p.uint,r,1);for(let r=-1;r>=-24;r--)Ee[31-r]=new b(p.negint,r,1);Ee[64]=new b(p.bytes,new Uint8Array(0),1);Ee[96]=new b(p.string,"",1);Ee[128]=new b(p.array,0,1);Ee[160]=new b(p.map,0,1);Ee[244]=new b(p.false,!1,1);Ee[245]=new b(p.true,!0,1);Ee[246]=new b(p.null,null,1);function _a(r){switch(r.type){case p.false:return De([244]);case p.true:return De([245]);case p.null:return De([246]);case p.bytes:return r.value.length?void 0:De([64]);case p.string:return r.value===""?De([96]):void 0;case p.array:return r.value===0?De([128]):void 0;case p.map:return r.value===0?De([160]):void 0;case p.uint:return r.value<24?De([Number(r.value)]):void 0;case p.negint:if(r.value>=-24)return De([31-Number(r.value)])}}var Sa=Object.freeze({float64:!0,mapSorter:xl,quickEncodeToken:_a});function yl(){let r=[];return r[p.uint.major]=me,r[p.negint.major]=Zr,r[p.bytes.major]=kt,r[p.string.major]=Ks,r[p.array.major]=Qr,r[p.map.major]=en,r[p.tag.major]=tn,r[p.float.major]=rn,r}var gl=yl(),Ei=new or,sn=class r{constructor(e,t){this.obj=e,this.parent=t}includes(e){let t=this;do if(t.obj===e)return!0;while(t=t.parent);return!1}static createCheck(e,t){if(e&&e.includes(t))throw new Error(`${_t} object contains circular references`);return new r(t,e)}},He={null:new b(p.null,null),undefined:new b(p.undefined,void 0),true:new b(p.true,!0),false:new b(p.false,!1),emptyArray:new b(p.array,0),emptyMap:new b(p.map,0)},je={number(r,e,t,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new b(p.float,r):r>=0?new b(p.uint,r):new b(p.negint,r)},bigint(r,e,t,n){return r>=BigInt(0)?new b(p.uint,r):new b(p.negint,r)},Uint8Array(r,e,t,n){return new b(p.bytes,r)},string(r,e,t,n){return new b(p.string,r)},boolean(r,e,t,n){return r?He.true:He.false},null(r,e,t,n){return He.null},undefined(r,e,t,n){return He.undefined},ArrayBuffer(r,e,t,n){return new b(p.bytes,new Uint8Array(r))},DataView(r,e,t,n){return new b(p.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,e,t,n){if(!r.length)return t.addBreakTokens===!0?[He.emptyArray,new b(p.break)]:He.emptyArray;n=sn.createCheck(n,r);let i=[],o=0;for(let s of r)i[o++]=on(s,t,n);return t.addBreakTokens?[new b(p.array,r.length),i,new b(p.break)]:[new b(p.array,r.length),i]},Object(r,e,t,n){let i=e!=="Object",o=i?r.keys():Object.keys(r),s=i?r.size:o.length;if(!s)return t.addBreakTokens===!0?[He.emptyMap,new b(p.break)]:He.emptyMap;n=sn.createCheck(n,r);let a=[],c=0;for(let h of o)a[c++]=[on(h,t,n),on(i?r.get(h):r[h],t,n)];return wl(a,t),t.addBreakTokens?[new b(p.map,s),a,new b(p.break)]:[new b(p.map,s),a]}};je.Map=je.Object;je.Buffer=je.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))je[`${r}Array`]=je.DataView;function on(r,e={},t){let n=ks(r),i=e&&e.typeEncoders&&e.typeEncoders[n]||je[n];if(typeof i=="function"){let s=i(r,n,e,t);if(s!=null)return s}let o=je[n];if(!o)throw new Error(`${_t} unsupported type: ${n}`);return o(r,n,e,t)}function wl(r,e){e.mapSorter&&r.sort(e.mapSorter)}function xl(r,e){if(r[0]instanceof b&&e[0]instanceof b){let t=r[0],n=e[0];return t._keyBytes||(t._keyBytes=ka(t.value)),n._keyBytes||(n._keyBytes=ka(n.value)),Jr(t._keyBytes,n._keyBytes)}throw new Error("rfc8949MapSorter: complex key types are not supported yet")}function ka(r){return va(r,gl,Sa)}function Ea(r,e,t,n){if(Array.isArray(e))for(let i of e)Ea(r,i,t,n);else t[e.type.major](r,e,n)}function va(r,e,t){let n=on(r,t);if(!Array.isArray(n)&&t.quickEncodeToken){let i=t.quickEncodeToken(n);if(i)return i;let o=e[n.type.major];if(o.encodedSize){let s=o.encodedSize(n,t),a=new or(s);if(o(a,n,t),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return ir(a.chunks[0])}}return Ei.reset(),Ea(Ei,n,e,t),Ei.toBytes(!0)}var bl={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},an=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t}pos(){return this._pos}done(){return this._pos>=this.data.length}next(){let e=this.data[this._pos],t=Ee[e];if(t===void 0){let n=k[e];if(!n)throw new Error(`${v} no decoder for major type ${e>>>5} (byte 0x${e.toString(16).padStart(2,"0")})`);let i=e&31;t=n(this.data,this._pos,i,this.options)}return this._pos+=t.encodedLength,t}},ur=Symbol.for("DONE"),cn=Symbol.for("BREAK");function _l(r,e,t){let n=[];for(let i=0;i<r.value;i++){let o=vt(e,t);if(o===cn){if(r.value===1/0)break;throw new Error(`${v} got unexpected break to lengthed array`)}if(o===ur)throw new Error(`${v} found array but not enough entries (got ${i}, expected ${r.value})`);n[i]=o}return n}function kl(r,e,t){let n=t.useMaps===!0,i=n?void 0:{},o=n?new Map:void 0;for(let s=0;s<r.value;s++){let a=vt(e,t);if(a===cn){if(r.value===1/0)break;throw new Error(`${v} got unexpected break to lengthed map`)}if(a===ur)throw new Error(`${v} found map but not enough entries (got ${s} [no key], expected ${r.value})`);if(n!==!0&&typeof a!="string")throw new Error(`${v} non-string keys not supported (got ${typeof a})`);if(t.rejectDuplicateMapKeys===!0&&(n&&o.has(a)||!n&&a in i))throw new Error(`${v} found repeat map key "${a}"`);let c=vt(e,t);if(c===ur)throw new Error(`${v} found map but not enough entries (got ${s} [no value], expected ${r.value})`);n?o.set(a,c):i[a]=c}return n?o:i}function vt(r,e){if(r.done())return ur;let t=r.next();if(t.type===p.break)return cn;if(t.type.terminal)return t.value;if(t.type===p.array)return _l(t,r,e);if(t.type===p.map)return kl(t,r,e);if(t.type===p.tag){if(e.tags&&typeof e.tags[t.value]=="function"){let n=vt(r,e);return e.tags[t.value](n)}throw new Error(`${v} tag not supported (${t.value})`)}throw new Error("unsupported")}function vi(r,e){if(!(r instanceof Uint8Array))throw new Error(`${v} data to decode must be a Uint8Array`);e=Object.assign({},bl,e);let t=e.tokenizer||new an(r,e),n=vt(t,e);if(n===ur)throw new Error(`${v} did not find any content to decode`);if(n===cn)throw new Error(`${v} got unexpected break`);return[n,r.subarray(t.pos())]}function fr(r,e){let[t,n]=vi(r,e);if(n.length>0)throw new Error(`${v} too many terminals, data makes no sense`);return t}var Ia=42;function vl(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}function Bl(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let e=A.asCID(r);if(!e)return null;let t=new Uint8Array(e.bytes.byteLength+1);return t.set(e.bytes,1),[new b(p.tag,Ia),new b(p.bytes,t)]}function Il(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function Al(r){if(Number.isNaN(r))throw new Error("`NaN` is not supported by the IPLD Data Model and cannot be encoded");if(r===1/0||r===-1/0)throw new Error("`Infinity` and `-Infinity` is not supported by the IPLD Data Model and cannot be encoded");return null}function Cl(r){for(let e of r.keys())if(typeof e!="string"||e.length===0)throw new Error("Non-string Map keys are not supported by the IPLD Data Model and cannot be encoded");return null}var Ba={float64:!0,typeEncoders:{Map:Cl,Object:Bl,undefined:Il,number:Al}},eg={...Ba,typeEncoders:{...Ba.typeEncoders}};function Nl(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return A.decode(r.subarray(1))}var un={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};un.tags[Ia]=Nl;var tg={...un,tags:un.tags.slice()};var Aa=113;var Ca=r=>fr(vl(r),un);var Ta=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(e){let t=this.inRecursive[this.inRecursive.length-1];t&&(t.type===p.array&&(t.elements++,t.elements!==1&&e.push([44])),t.type===p.map&&(t.elements++,t.elements!==1&&(t.elements%2===1?e.push([44]):e.push([58]))))}[p.uint.major](e,t){this.prefix(e);let n=String(t.value),i=[];for(let o=0;o<n.length;o++)i[o]=n.charCodeAt(o);e.push(i)}[p.negint.major](e,t){this[p.uint.major](e,t)}[p.bytes.major](e,t){throw new Error(`${_t} unsupported type: Uint8Array`)}[p.string.major](e,t){this.prefix(e);let n=Xr(JSON.stringify(t.value));e.push(n.length>32?ir(n):n)}[p.array.major](e,t){this.prefix(e),this.inRecursive.push({type:p.array,elements:0}),e.push([91])}[p.map.major](e,t){this.prefix(e),this.inRecursive.push({type:p.map,elements:0}),e.push([123])}[p.tag.major](e,t){}[p.float.major](e,t){if(t.type.name==="break"){let s=this.inRecursive.pop();if(s){if(s.type===p.array)e.push([93]);else if(s.type===p.map)e.push([125]);else throw new Error("Unexpected recursive type; this should not happen!");return}throw new Error("Unexpected break; this should not happen!")}if(t.value===void 0)throw new Error(`${_t} unsupported type: undefined`);if(this.prefix(e),t.type.name==="true"){e.push([116,114,117,101]);return}else if(t.type.name==="false"){e.push([102,97,108,115,101]);return}else if(t.type.name==="null"){e.push([110,117,108,108]);return}let n=String(t.value),i=[],o=!1;for(let s=0;s<n.length;s++)i[s]=n.charCodeAt(s),!o&&(i[s]===46||i[s]===101||i[s]===69)&&(o=!0);o||(i.push(46),i.push(48)),e.push(i)}};var Bt=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t,this.modeStack=["value"],this.lastToken=""}pos(){return this._pos}done(){return this._pos>=this.data.length}ch(){return this.data[this._pos]}currentMode(){return this.modeStack[this.modeStack.length-1]}skipWhitespace(){let e=this.ch();for(;e===32||e===9||e===13||e===10;)e=this.data[++this._pos]}expect(e){if(this.data.length-this._pos<e.length)throw new Error(`${v} unexpected end of input at position ${this._pos}`);for(let t=0;t<e.length;t++)if(this.data[this._pos++]!==e[t])throw new Error(`${v} unexpected token at position ${this._pos}, expected to find '${String.fromCharCode(...e)}'`)}parseNumber(){let e=this._pos,t=!1,n=!1,i=a=>{for(;!this.done();){let c=this.ch();if(a.includes(c))this._pos++;else break}};if(this.ch()===45&&(t=!0,this._pos++),this.ch()===48)if(this._pos++,this.ch()===46)this._pos++,n=!0;else return new b(p.uint,0,this._pos-e);if(i([48,49,50,51,52,53,54,55,56,57]),t&&this._pos===e+1)throw new Error(`${v} unexpected token at position ${this._pos}`);if(!this.done()&&this.ch()===46){if(n)throw new Error(`${v} unexpected token at position ${this._pos}`);n=!0,this._pos++,i([48,49,50,51,52,53,54,55,56,57])}!this.done()&&(this.ch()===101||this.ch()===69)&&(n=!0,this._pos++,!this.done()&&(this.ch()===43||this.ch()===45)&&this._pos++,i([48,49,50,51,52,53,54,55,56,57]));let o=String.fromCharCode.apply(null,this.data.subarray(e,this._pos)),s=parseFloat(o);return n?new b(p.float,s,this._pos-e):this.options.allowBigInt!==!0||Number.isSafeInteger(s)?new b(s>=0?p.uint:p.negint,s,this._pos-e):new b(s>=0?p.uint:p.negint,BigInt(o),this._pos-e)}parseString(){if(this.ch()!==34)throw new Error(`${v} unexpected character at position ${this._pos}; this shouldn't happen`);this._pos++;for(let o=this._pos,s=0;o<this.data.length&&s<65536;o++,s++){let a=this.data[o];if(a===92||a<32||a>=128)break;if(a===34){let c=String.fromCharCode.apply(null,this.data.subarray(this._pos,o));return this._pos=o+1,new b(p.string,c,s)}}let e=this._pos,t=[],n=()=>{if(this._pos+4>=this.data.length)throw new Error(`${v} unexpected end of unicode escape sequence at position ${this._pos}`);let o=0;for(let s=0;s<4;s++){let a=this.ch();if(a>=48&&a<=57)a-=48;else if(a>=97&&a<=102)a=a-97+10;else if(a>=65&&a<=70)a=a-65+10;else throw new Error(`${v} unexpected unicode escape character at position ${this._pos}`);o=o*16+a,this._pos++}return o},i=()=>{let o=this.ch(),s=null,a=o>239?4:o>223?3:o>191?2:1;if(this._pos+a>this.data.length)throw new Error(`${v} unexpected unicode sequence at position ${this._pos}`);let c,h,f,l;switch(a){case 1:o<128&&(s=o);break;case 2:c=this.data[this._pos+1],(c&192)===128&&(l=(o&31)<<6|c&63,l>127&&(s=l));break;case 3:c=this.data[this._pos+1],h=this.data[this._pos+2],(c&192)===128&&(h&192)===128&&(l=(o&15)<<12|(c&63)<<6|h&63,l>2047&&(l<55296||l>57343)&&(s=l));break;case 4:c=this.data[this._pos+1],h=this.data[this._pos+2],f=this.data[this._pos+3],(c&192)===128&&(h&192)===128&&(f&192)===128&&(l=(o&15)<<18|(c&63)<<12|(h&63)<<6|f&63,l>65535&&l<1114112&&(s=l))}s===null?(s=65533,a=1):s>65535&&(s-=65536,t.push(s>>>10&1023|55296),s=56320|s&1023),t.push(s),this._pos+=a};for(;!this.done();){let o=this.ch(),s;switch(o){case 92:if(this._pos++,this.done())throw new Error(`${v} unexpected string termination at position ${this._pos}`);switch(s=this.ch(),this._pos++,s){case 34:case 39:case 92:case 47:t.push(s);break;case 98:t.push(8);break;case 116:t.push(9);break;case 110:t.push(10);break;case 102:t.push(12);break;case 114:t.push(13);break;case 117:t.push(n());break;default:throw new Error(`${v} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new b(p.string,xi(t),this._pos-e);default:if(o<32)throw new Error(`${v} invalid control character at position ${this._pos}`);o<128?(t.push(o),this._pos++):i()}}throw new Error(`${v} unexpected end of string at position ${this._pos}`)}parseValue(){switch(this.ch()){case 123:return this.modeStack.push("obj-start"),this._pos++,new b(p.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new b(p.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new b(p.null,null,4);case 102:return this.expect([102,97,108,115,101]),new b(p.false,!1,5);case 116:return this.expect([116,114,117,101]),new b(p.true,!0,4);case 45:case 48:case 49:case 50:case 51:case 52:case 53:case 54:case 55:case 56:case 57:return this.parseNumber();default:throw new Error(`${v} unexpected character at position ${this._pos}`)}}next(){switch(this.skipWhitespace(),this.currentMode()){case"value":return this.modeStack.pop(),this.parseValue();case"array-value":{if(this.modeStack.pop(),this.ch()===93)return this._pos++,this.skipWhitespace(),new b(p.break,void 0,1);if(this.ch()!==44)throw new Error(`${v} unexpected character at position ${this._pos}, was expecting array delimiter but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue()}case"array-start":return this.modeStack.pop(),this.ch()===93?(this._pos++,this.skipWhitespace(),new b(p.break,void 0,1)):(this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue());case"obj-key":if(this.ch()===125)return this.modeStack.pop(),this._pos++,this.skipWhitespace(),new b(p.break,void 0,1);if(this.ch()!==44)throw new Error(`${v} unexpected character at position ${this._pos}, was expecting object delimiter but found '${String.fromCharCode(this.ch())}'`);this._pos++,this.skipWhitespace();case"obj-start":{if(this.modeStack.pop(),this.ch()===125)return this._pos++,this.skipWhitespace(),new b(p.break,void 0,1);let e=this.parseString();if(this.skipWhitespace(),this.ch()!==58)throw new Error(`${v} unexpected character at position ${this._pos}, was expecting key/value delimiter ':' but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("obj-value"),e}case"obj-value":return this.modeStack.pop(),this.modeStack.push("obj-key"),this.skipWhitespace(),this.parseValue();default:throw new Error(`${v} unexpected parse state at position ${this._pos}; this shouldn't happen`)}}};function Bi(r,e){return e=Object.assign({tokenizer:new Bt(r,e)},e),fr(r,e)}function Ll(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var Ii=class extends Bt{constructor(e,t){super(e,t),this.tokenBuffer=[]}done(){return this.tokenBuffer.length===0&&super.done()}_next(){return this.tokenBuffer.length>0?this.tokenBuffer.pop():super.next()}next(){let e=this._next();if(e.type===p.map){let t=this._next();if(t.type===p.string&&t.value==="/"){let n=this._next();if(n.type===p.string){if(this._next().type!==p.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new b(p.tag,42,0)}if(n.type===p.map){let i=this._next();if(i.type===p.string&&i.value==="bytes"){let o=this._next();if(o.type===p.string){for(let a=0;a<2;a++)if(this._next().type!==p.break)throw new Error("Invalid encoded Bytes form");let s=Wt.decode(`m${o.value}`);return new b(p.bytes,s,o.value.length)}this.tokenBuffer.push(o)}this.tokenBuffer.push(i)}this.tokenBuffer.push(n)}this.tokenBuffer.push(t)}return e}},Ai={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Ai.tags[42]=A.parse;var Da=297;var La=r=>{let e=Ll(r),t=Object.assign(Ai,{tokenizer:new Ii(e,Ai)});return Bi(e,t)};var wg=new TextDecoder;var xg=new TextEncoder;function zl(r){return r[Symbol.asyncIterator]!=null}function Fl(r){if(zl(r))return(async()=>{let n=new Uint8Array(0);for await(let i of r)n=Ie([n,i],n.length+i.length);return n})();let e=[],t=0;for(let n of r)e.push(n),t+=n.byteLength;return Ie(e,t)}var z=Fl;function It(r,e,t,n,i,o,s){let a=r,c=i;for(;o.length>0;){let h=o[0];if(h in a){o.shift(),c=`${c}/${h}`;let f=A.asCID(a[h]);if(f!=null)return{entry:{type:"object",name:n,path:i,cid:t,node:e,depth:s,size:BigInt(e.length),content:async function*(){yield r}},next:{cid:f,name:h,path:c,toResolve:o}};a=a[h]}else throw new Wr(`No property named ${h} found in node ${t}`)}return{entry:{type:"object",name:n,path:i,cid:t,node:e,depth:s,size:BigInt(e.length),content:async function*(){yield r}}}}var Pl=async(r,e,t,n,i,o,s,a)=>{let c=await z(s.get(r,a)),h=Ca(c);return It(h,c,r,e,t,n,o)},Fa=Pl;var Ul=async(r,e,t,n,i,o,s,a)=>{let c=await z(s.get(r,a)),h=La(c);return It(h,c,r,e,t,n,o)},Pa=Ul;function $l(r,e,t,n){let i=BigInt(r.length),o=BigInt(e+i);return t>=o||n<e?new Uint8Array(0):(n>=e&&n<o&&(r=r.subarray(0,Number(n-e))),t>=e&&t<o&&(r=r.subarray(Number(t-e))),r)}var et=$l;var Rl=(r,e=0,t=r)=>{let n=BigInt(r),i=BigInt(e??0),o=BigInt(t);if(o!==n&&(o=i+o),o>n&&(o=n),i<0n)throw new Ye("Offset must be greater than or equal to 0");if(i>n)throw new Ye("Offset must be less than the file size");if(o<0n)throw new Ye("Length must be greater than or equal to 0");if(o>n)throw new Ye("Length must be less than the file size");return{start:i,end:o}},At=Rl;var Ml=r=>{async function*e(t={}){let{start:n,end:i}=At(r.length,t.offset,t.length),o=et(r,0n,n,i);t.onProgress?.(new U("unixfs:exporter:progress:identity",{bytesRead:BigInt(o.byteLength),totalBytes:i-n,fileSize:BigInt(r.byteLength)})),yield o}return e},Ol=async(r,e,t,n,i,o,s,a)=>{if(n.length>0)throw new pe(`No link named ${t} found in raw node ${r}`);let c=Ir(r.multihash.bytes);return{entry:{type:"identity",name:e,path:t,cid:r,content:Ml(c.digest),depth:o,size:BigInt(c.digest.length),node:c.digest}}},Ua=Ol;var Vl=async(r,e,t,n,i,o,s,a)=>{let c=await z(s.get(r,a)),h=Lo(c);return It(h,c,r,e,t,n,o)},$a=Vl;var Hl=r=>{async function*e(t={}){let{start:n,end:i}=At(r.length,t.offset,t.length),o=et(r,0n,n,i);t.onProgress?.(new U("unixfs:exporter:progress:raw",{bytesRead:BigInt(o.byteLength),totalBytes:i-n,fileSize:BigInt(r.byteLength)})),yield o}return e},jl=async(r,e,t,n,i,o,s,a)=>{if(n.length>0)throw new pe(`No link named ${t} found in raw node ${r}`);let c=await z(s.get(r,a));return{entry:{type:"raw",name:e,path:t,cid:r,content:Hl(c),depth:o,size:BigInt(c.length),node:c}}},Ra=jl;var ql=async function(r){return(await Je.encode(r)).slice(0,8).reverse()},Gl=async(r,e,t)=>{let n=(e.tableSize()-1).toString(16).length;await Promise.all(r.map(async i=>{if(i.Name==null)throw new Error("Unexpected Link without a Name");if(i.Name.length===n){let o=parseInt(i.Name,16);e._putObjectAt(o,new se({hash:t._options.hash,bits:t._options.bits},e,o));return}await t.put(i.Name.substring(2),!0)}))},Ma=(r,e)=>r.toString(16).toUpperCase().padStart(e,"0").substring(0,e),Wl=r=>{let e=r.bucket,t=[];for(;e._parent!=null;)t.push(e),e=e._parent;return t.push(e),t.reverse()},Oa=async(r,e,t,n,i)=>{if(n==null){if(r.Data==null)throw new O("no data in PBNode");let l;try{l=I.unmarshal(r.Data)}catch(u){throw new O(u.message)}if(l.type!=="hamt-sharded-directory")throw new O("not a HAMT");if(l.fanout==null)throw new O("missing fanout");let y=gt({hashFn:ql,bits:Math.log2(Number(l.fanout))});n={rootBucket:y,hamtDepth:1,lastBucket:y}}let o=(n.lastBucket.tableSize()-1).toString(16).length;await Gl(r.Links,n.lastBucket,n.rootBucket);let s=await n.rootBucket._findNewBucketAndPos(e),a=Ma(s.pos,o),c=Wl(s);c.length>n.hamtDepth&&(n.lastBucket=c[n.hamtDepth],a=Ma(n.lastBucket._posAtParent,o));let h=r.Links.find(l=>{if(l.Name==null)return!1;let y=l.Name.substring(0,o),u=l.Name.substring(o);return!(y!==a||u!==""&&u!==e)});if(h==null)return;if(h.Name!=null&&h.Name.substring(o)===e)return h.Hash;n.hamtDepth++;let f=await z(t.get(h.Hash,i));return r=$(f),Oa(r,e,t,n,i)},Va=Oa;function Ct(r){return r?.extended===!1}function Kl(r){let[e,t]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>e.next(),push:i=>{n.push(i)},next:()=>n.length>0?{done:!1,value:n.shift()}:e.next(),[t](){return this}}}var fn=Kl;function Xl(r){return r[Symbol.asyncIterator]!=null}function Jl(r,e){let t=0;if(Xl(r))return(async function*(){for await(let c of r)await e(c,t++)&&(yield c)})();let n=fn(r),{value:i,done:o}=n.next();if(o===!0)return(function*(){})();let s=e(i,t++);if(typeof s.then=="function")return(async function*(){await s&&(yield i);for(let c of n)await e(c,t++)&&(yield c)})();let a=e;return(function*(){s===!0&&(yield i);for(let c of n)a(c,t++)&&(yield c)})()}var Ha=Jl;function Zl(r){return r[Symbol.asyncIterator]!=null}function Yl(r,e){let t=0;if(Zl(r))return(async function*(){for await(let c of r)yield e(c,t++)})();let n=fn(r),{value:i,done:o}=n.next();if(o===!0)return(function*(){})();let s=e(i,t++);if(typeof s.then=="function")return(async function*(){yield await s;for(let c of n)yield e(c,t++)})();let a=e;return(function*(){yield s;for(let c of n)yield a(c,t++)})()}var Nt=Yl;function te(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var ln=globalThis.CustomEvent??Event;async function*tt(r,e={}){let t=e.concurrency??1/0;t<1&&(t=1/0);let n=e.ordered??!1,i=new EventTarget,o=[],s=te(),a=te(),c=!1,h,f=!1;i.addEventListener("task-complete",()=>{a.resolve()}),Promise.resolve().then(async()=>{try{for await(let d of r){if(o.length===t&&(s=te(),await s.promise),f)break;let m={done:!1};o.push(m),d().then(x=>{m.done=!0,m.ok=!0,m.value=x,i.dispatchEvent(new ln("task-complete"))},x=>{m.done=!0,m.err=x,i.dispatchEvent(new ln("task-complete"))})}c=!0,i.dispatchEvent(new ln("task-complete"))}catch(d){h=d,i.dispatchEvent(new ln("task-complete"))}});function l(){return n?o[0]?.done:!!o.find(d=>d.done)}function*y(){for(;o.length>0&&o[0].done;){let d=o[0];if(o.shift(),d.ok)yield d.value;else throw f=!0,s.resolve(),d.err;s.resolve()}}function*u(){for(;l();)for(let d=0;d<o.length;d++)if(o[d].done){let m=o[d];if(o.splice(d,1),d--,m.ok)yield m.value;else throw f=!0,s.resolve(),m.err;s.resolve()}}for(;;){if(l()||(a=te(),await a.promise),h!=null||(n?yield*y():yield*u(),h!=null))throw h;if(c&&o.length===0)break}}var hn=class{buffer;mask;top;btm;next;constructor(e){if(!(e>0)||(e-1&e)!==0)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},Tt=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new hn(this.hwm),this.tail=this.head,this.size=0}calculateSize(e){return e?.byteLength!=null?e.byteLength:1}push(e){if(e?.value!=null&&(this.size+=this.calculateSize(e.value)),!this.head.push(e)){let t=this.head;this.head=t.next=new hn(2*this.head.buffer.length),this.head.push(e)}}shift(){let e=this.tail.shift();if(e===void 0&&this.tail.next!=null){let t=this.tail.next;this.tail.next=null,this.tail=t,e=this.tail.shift()}return e?.value!=null&&(this.size-=this.calculateSize(e.value)),e}isEmpty(){return this.head.isEmpty()}};var Ci=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function dn(r={}){return Ql(t=>{let n=t.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function Ql(r,e){e=e??{};let t=e.onEnd,n=new Tt,i,o,s,a=te(),c=async()=>{try{return n.isEmpty()?s?{done:!0}:await new Promise((x,g)=>{o=w=>{o=null,n.push(w);try{x(r(n))}catch(_){g(_)}return i}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=te()})}},h=x=>o!=null?o(x):(n.push(x),i),f=x=>(n=new Tt,o!=null?o({error:x}):(n.push({error:x}),i)),l=x=>{if(s)return i;if(e?.objectMode!==!0&&x?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return h({done:!1,value:x})},y=x=>s?i:(s=!0,x!=null?f(x):h({done:!0})),u=()=>(n=new Tt,y(),{done:!0}),d=x=>(y(x),{done:!0});if(i={[Symbol.asyncIterator](){return this},next:c,return:u,throw:d,push:l,end:y,get readableLength(){return n.size},onEmpty:async x=>{let g=x?.signal;if(g?.throwIfAborted(),n.isEmpty())return;let w,_;g!=null&&(w=new Promise((S,B)=>{_=()=>{B(new Ci)},g.addEventListener("abort",_)}));try{await Promise.race([a.promise,w])}finally{_!=null&&g!=null&&g?.removeEventListener("abort",_)}}},t==null)return i;let m=i;return i={[Symbol.asyncIterator](){return this},next(){return m.next()},throw(x){return m.throw(x),t!=null&&(t(x),t=void 0),{done:!0}},return(){return m.return(),t!=null&&(t(),t=void 0),{done:!0}},push:l,end(x){return m.end(x),t!=null&&(t(x),t=void 0),i},get readableLength(){return m.readableLength},onEmpty:x=>m.onEmpty(x)},i}function eh(r){return r.reason}async function ja(r,e,t){if(e==null)return r;let n=t?.translateError??eh;if(e.aborted)return r.catch(()=>{}),Promise.reject(n(e));let i;try{return await Promise.race([r,new Promise((o,s)=>{i=()=>{s(n(e))},e.addEventListener("abort",i)})])}finally{i!=null&&e.removeEventListener("abort",i)}}var Ni=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=te(),this.haveNext=te()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let e=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=te(),e}async throw(e){return this.ended=!0,this.error=e,e!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(e)),{done:!0,value:void 0}}async return(){let e={done:!0,value:void 0};return this.ended=!0,this.nextResult=e,this.haveNext.resolve(),e}async push(e,t){await this._push(e,t)}async end(e,t){e!=null?await this.throw(e):await this._push(void 0,t)}async _push(e,t){if(e!=null&&this.ended)throw this.error??new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;e!=null?this.nextResult={done:!1,value:e}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=te(),await ja(this.readNext.promise,t?.signal,t)}};function qa(){return new Ni}function th(r){return r[Symbol.asyncIterator]!=null}async function rh(r,e,t){try{await Promise.all(r.map(async n=>{for await(let i of n)await e.push(i,{signal:t}),t.throwIfAborted()})),await e.end(void 0,{signal:t})}catch(n){await e.end(n,{signal:t}).catch(()=>{})}}async function*nh(r){let e=new AbortController,t=qa();rh(r,t,e.signal).catch(()=>{});try{yield*t}finally{e.abort()}}function*ih(r){for(let e of r)yield*e}function oh(...r){let e=[];for(let t of r)th(t)||e.push(t);return e.length===r.length?ih(e):nh(r)}var Ga=oh;function Le(r,...e){if(r==null)throw new Error("Empty pipeline");if(Ti(r)){let n=r;r=()=>n.source}else if(Ka(r)||Wa(r)){let n=r;r=()=>n}let t=[r,...e];if(t.length>1&&Ti(t[t.length-1])&&(t[t.length-1]=t[t.length-1].sink),t.length>2)for(let n=1;n<t.length-1;n++)Ti(t[n])&&(t[n]=ah(t[n]));return sh(...t)}var sh=(...r)=>{let e;for(;r.length>0;)e=r.shift()(e);return e},Wa=r=>r?.[Symbol.asyncIterator]!=null,Ka=r=>r?.[Symbol.iterator]!=null,Ti=r=>r==null?!1:r.sink!=null&&r.source!=null,ah=r=>e=>{let t=r.sink(e);if(t?.then!=null){let n=dn({objectMode:!0});t.then(()=>{n.end()},s=>{n.end(s)});let i,o=r.source;if(Wa(o))i=async function*(){yield*o,n.end()};else if(Ka(o))i=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Ga(n,i())}return r.source};var ch=(r,e,t,n,i,o,s)=>{async function*a(c={}){let h=c.offset??0,f=c.length??e.Links.length,l=e.Links.slice(h,f);c.onProgress?.(new U("unixfs:exporter:walk:directory",{cid:r})),yield*Le(l,y=>Nt(y,u=>async()=>{let d=u.Name??"",m=`${n}/${d}`;return Ct(c)?{cid:u.Hash,name:d,path:m}:(await i(u.Hash,d,m,[],o+1,s,c)).entry}),y=>tt(y,{ordered:!0,concurrency:c.blockReadConcurrency}),y=>Ha(y,u=>u!=null))}return a},Xa=ch;var Li=Pt(Za(),1);var zi=class r extends Error{name="TimeoutError";constructor(e,t){super(e,t),Error.captureStackTrace?.(this,r)}},Ya=r=>r.reason??new DOMException("This operation was aborted.","AbortError");function Fi(r,e){let{milliseconds:t,fallback:n,message:i,customTimers:o={setTimeout,clearTimeout},signal:s}=e,a,c,f=new Promise((l,y)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(s?.aborted){y(Ya(s));return}if(s&&(c=()=>{y(Ya(s))},s.addEventListener("abort",c,{once:!0})),r.then(l,y),t===Number.POSITIVE_INFINITY)return;let u=new zi;a=o.setTimeout.call(void 0,()=>{if(n){try{l(n())}catch(d){y(d)}return}typeof r.cancel=="function"&&r.cancel(),i===!1?l():i instanceof Error?y(i):(u.message=i??`Promise timed out after ${t} milliseconds`,y(u))},t)}).finally(()=>{f.clear(),c&&s&&s.removeEventListener("abort",c)});return f.clear=()=>{o.clearTimeout.call(void 0,a),a=void 0},f}function Pi(r,e,t){let n=0,i=r.length;for(;i>0;){let o=Math.trunc(i/2),s=n+o;t(r[s],e)<=0?(n=++s,i-=o+1):i=o}return n}var hr=class{#r=[];enqueue(e,t){let{priority:n=0,id:i}=t??{},o={priority:n,id:i,run:e};if(this.size===0||this.#r[this.size-1].priority>=n){this.#r.push(o);return}let s=Pi(this.#r,o,(a,c)=>c.priority-a.priority);this.#r.splice(s,0,o)}setPriority(e,t){let n=this.#r.findIndex(o=>o.id===e);if(n===-1)throw new ReferenceError(`No promise function with the id "${e}" exists in the queue.`);let[i]=this.#r.splice(n,1);this.enqueue(i.run,{priority:t,id:e})}dequeue(){return this.#r.shift()?.run}filter(e){return this.#r.filter(t=>t.priority===e.priority).map(t=>t.run)}get size(){return this.#r.length}};var dr=class extends Li.default{#r;#s;#a=0;#d;#m=!1;#w=!1;#c;#B=0;#x=0;#u;#f;#o;#i=[];#n=0;#e;#I;#t=0;#y;#l;#D=1n;#g=new Map;timeout;constructor(e){if(super(),e={carryoverIntervalCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:hr,strict:!1,...e},!(typeof e.intervalCap=="number"&&e.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${e.intervalCap?.toString()??""}\` (${typeof e.intervalCap})`);if(e.interval===void 0||!(Number.isFinite(e.interval)&&e.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${e.interval?.toString()??""}\` (${typeof e.interval})`);if(e.strict&&e.interval===0)throw new TypeError("The `strict` option requires a non-zero `interval`");if(e.strict&&e.intervalCap===Number.POSITIVE_INFINITY)throw new TypeError("The `strict` option requires a finite `intervalCap`");if(this.#r=e.carryoverIntervalCount??e.carryoverConcurrencyCount??!1,this.#s=e.intervalCap===Number.POSITIVE_INFINITY||e.interval===0,this.#d=e.intervalCap,this.#c=e.interval,this.#o=e.strict,this.#e=new e.queueClass,this.#I=e.queueClass,this.concurrency=e.concurrency,e.timeout!==void 0&&!(Number.isFinite(e.timeout)&&e.timeout>0))throw new TypeError(`Expected \`timeout\` to be a positive finite number, got \`${e.timeout}\` (${typeof e.timeout})`);this.timeout=e.timeout,this.#l=e.autoStart===!1,this.#M()}#b(e){for(;this.#n<this.#i.length;){let n=this.#i[this.#n];if(n!==void 0&&e-n>=this.#c)this.#n++;else break}(this.#n>100&&this.#n>this.#i.length/2||this.#n===this.#i.length)&&(this.#i=this.#i.slice(this.#n),this.#n=0)}#L(e){this.#o?this.#i.push(e):this.#a++}#z(){this.#o?this.#i.length>this.#n&&this.#i.pop():this.#a>0&&this.#a--}#_(){return this.#i.length-this.#n}get#F(){return this.#s?!0:this.#o?this.#_()<this.#d:this.#a<this.#d}get#P(){return this.#t<this.#y}#U(){this.#t--,this.#t===0&&this.emit("pendingZero"),this.#E(),this.emit("next")}#$(){this.#f=void 0,this.#N(),this.#C()}#R(e){if(this.#o){if(this.#b(e),this.#_()>=this.#d){let n=this.#i[this.#n],i=this.#c-(e-n);return this.#k(i),!0}return!1}if(this.#u===void 0){let t=this.#B-e;if(t<0){if(this.#x>0){let n=e-this.#x;if(n<this.#c)return this.#k(this.#c-n),!0}this.#a=this.#r?this.#t:0}else return this.#k(t),!0}return!1}#k(e){this.#f===void 0&&(this.#f=setTimeout(()=>{this.#$()},e))}#S(){this.#u&&(clearInterval(this.#u),this.#u=void 0)}#A(){this.#f&&(clearTimeout(this.#f),this.#f=void 0)}#E(){if(this.#e.size===0){if(this.#S(),this.emit("empty"),this.#t===0){if(this.#A(),this.#o&&this.#n>0){let t=Date.now();this.#b(t)}this.emit("idle")}return!1}let e=!1;if(!this.#l){let t=Date.now(),n=!this.#R(t);if(this.#F&&this.#P){let i=this.#e.dequeue();this.#s||(this.#L(t),this.#p()),this.emit("active"),i(),n&&this.#C(),e=!0}}return e}#C(){this.#s||this.#u!==void 0||this.#o||(this.#u=setInterval(()=>{this.#N()},this.#c),this.#B=Date.now()+this.#c)}#N(){this.#o||(this.#a===0&&this.#t===0&&this.#u&&this.#S(),this.#a=this.#r?this.#t:0),this.#v(),this.#p()}#v(){for(;this.#E(););}get concurrency(){return this.#y}set concurrency(e){if(!(typeof e=="number"&&e>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${e}\` (${typeof e})`);this.#y=e,this.#v()}setPriority(e,t){if(typeof t!="number"||!Number.isFinite(t))throw new TypeError(`Expected \`priority\` to be a finite number, got \`${t}\` (${typeof t})`);this.#e.setPriority(e,t)}async add(e,t={}){return t={timeout:this.timeout,...t,id:t.id??(this.#D++).toString()},new Promise((n,i)=>{let o=Symbol(`task-${t.id}`);this.#e.enqueue(async()=>{this.#t++,this.#g.set(o,{id:t.id,priority:t.priority??0,startTime:Date.now(),timeout:t.timeout});let s;try{try{t.signal?.throwIfAborted()}catch(h){throw this.#O(),this.#g.delete(o),h}this.#x=Date.now();let a=e({signal:t.signal});if(t.timeout&&(a=Fi(Promise.resolve(a),{milliseconds:t.timeout,message:`Task timed out after ${t.timeout}ms (queue has ${this.#t} running, ${this.#e.size} waiting)`})),t.signal){let{signal:h}=t;a=Promise.race([a,new Promise((f,l)=>{s=()=>{l(h.reason)},h.addEventListener("abort",s,{once:!0})})])}let c=await a;n(c),this.emit("completed",c)}catch(a){i(a),this.emit("error",a)}finally{s&&t.signal?.removeEventListener("abort",s),this.#g.delete(o),queueMicrotask(()=>{this.#U()})}},t),this.emit("add"),this.#E()})}async addAll(e,t){return Promise.all(e.map(async n=>this.add(n,t)))}start(){return this.#l?(this.#l=!1,this.#v(),this):this}pause(){this.#l=!0}clear(){this.#e=new this.#I,this.#S(),this.#T(),this.emit("empty"),this.#t===0&&(this.#A(),this.emit("idle")),this.emit("next")}async onEmpty(){this.#e.size!==0&&await this.#h("empty")}async onSizeLessThan(e){this.#e.size<e||await this.#h("next",()=>this.#e.size<e)}async onIdle(){this.#t===0&&this.#e.size===0||await this.#h("idle")}async onPendingZero(){this.#t!==0&&await this.#h("pendingZero")}async onRateLimit(){this.isRateLimited||await this.#h("rateLimit")}async onRateLimitCleared(){this.isRateLimited&&await this.#h("rateLimitCleared")}onError(){return new Promise((e,t)=>{let n=i=>{this.off("error",n),t(i)};this.on("error",n)})}async#h(e,t){return new Promise(n=>{let i=()=>{t&&!t()||(this.off(e,i),n())};this.on(e,i)})}get size(){return this.#e.size}sizeBy(e){return this.#e.filter(e).length}get pending(){return this.#t}get isPaused(){return this.#l}#M(){this.#s||(this.on("add",()=>{this.#e.size>0&&this.#p()}),this.on("next",()=>{this.#p()}))}#p(){this.#s||this.#w||(this.#w=!0,queueMicrotask(()=>{this.#w=!1,this.#T()}))}#O(){this.#s||(this.#z(),this.#p())}#T(){let e=this.#m;if(this.#s||this.#e.size===0){e&&(this.#m=!1,this.emit("rateLimitCleared"));return}let t;if(this.#o){let i=Date.now();this.#b(i),t=this.#_()}else t=this.#a;let n=t>=this.#d;n!==e&&(this.#m=n,this.emit(n?"rateLimit":"rateLimitCleared"))}get isRateLimited(){return this.#m}get isSaturated(){return this.#t===this.#y&&this.#e.size>0||this.isRateLimited&&this.#e.size>0}get runningTasks(){return[...this.#g.values()].map(e=>({...e}))}};async function Qa(r,e,t,n,i,o,s){if(e instanceof Uint8Array){let h=et(e,n,i,o);t.push(h);return}if(e.Data==null)throw new O("no data in PBNode");let a;try{a=I.unmarshal(e.Data)}catch(h){throw new O(h.message)}if(a.data!=null){let h=a.data,f=et(h,n,i,o);t.push(f),n+=BigInt(f.byteLength)}let c=[];if(e.Links.length!==a.blockSizes.length)throw new O("Inconsistent block sizes and dag links");for(let h=0;h<e.Links.length;h++){let f=e.Links[h],l=n,y=l+a.blockSizes[h];if((i>=l&&i<y||o>=l&&o<=y||i<l&&o>y)&&c.push({link:f,blockStart:n}),n=y,n>o)break}await Le(c,h=>Nt(h,f=>async()=>{let l=await z(r.get(f.link.Hash,s));return{...f,block:l}}),h=>tt(h,{ordered:!0,concurrency:s.blockReadConcurrency}),async h=>{for await(let{link:f,block:l,blockStart:y}of h){let u;switch(f.Hash.code){case q:u=$(l);break;case Q:u=l;break;default:t.end(new O(`Unsupported codec: ${f.Hash.code}`));return}let d=new dr({concurrency:1});d.on("error",m=>{t.end(m)}),d.add(async()=>{s.onProgress?.(new U("unixfs:exporter:walk:file",{cid:f.Hash})),await Qa(r,u,t,y,i,o,s)}),await d.onIdle()}}),n>=o&&t.end()}var lh=(r,e,t,n,i,o,s)=>{async function*a(c={}){let h=t.fileSize();if(h===void 0)throw new Error("File was a directory");let{start:f,end:l}=At(h,c.offset,c.length);if(l===0n)return;let y=0n,u=l-f,d=dn();c.onProgress?.(new U("unixfs:exporter:walk:file",{cid:r})),Qa(s,e,d,0n,f,l,c).catch(m=>{d.end(m)});for await(let m of d)if(m!=null){if(y+=BigInt(m.byteLength),y>u)throw d.end(),new qr("Read too many bytes - the file size reported by the UnixFS data in the root node may be incorrect");y===u&&d.end(),c.onProgress?.(new U("unixfs:exporter:progress:unixfs:file",{bytesRead:y,totalBytes:u,fileSize:h})),yield m}if(y<u)throw new Gr("Traversed entire DAG but did not read enough bytes")}return a},Ui=lh;var hh=(r,e,t,n,i,o,s)=>{function a(c={}){return c.onProgress?.(new U("unixfs:exporter:walk:hamt-sharded-directory",{cid:r})),ec(e,n,i,o,s,c)}return a};async function*ec(r,e,t,n,i,o){let s=r.Links;if(r.Data==null)throw new O("no data in PBNode");let a;try{a=I.unmarshal(r.Data)}catch(f){throw new O(f.message)}if(a.fanout==null)throw new O("missing fanout");let c=(a.fanout-1n).toString(16).length,h=Le(s,f=>Nt(f,l=>async()=>{let y=l.Name!=null?l.Name.substring(c):null;if(y!=null&&y!==""){let u=`${e}/${y}`;return Ct(o)?{entries:[{cid:l.Hash,name:y,path:u}]}:{entries:[(await t(l.Hash,y,u,[],n+1,i,o)).entry].filter(Boolean)}}else{let u=await z(i.get(l.Hash,o));return r=$(u),o.onProgress?.(new U("unixfs:exporter:walk:hamt-sharded-directory",{cid:l.Hash})),{entries:ec(r,e,t,n,i,o)}}}),f=>tt(f,{ordered:!0,concurrency:o.blockReadConcurrency}));for await(let{entries:f}of h)yield*f}var tc=hh;var dh=(r,e)=>r.Links.find(n=>n.Name===e)?.Hash,ph={raw:Ui,file:Ui,directory:Xa,"hamt-sharded-directory":tc,metadata:(r,e,t,n,i,o,s)=>()=>[],symlink:(r,e,t,n,i,o,s)=>()=>[]},mh=async(r,e,t,n,i,o,s,a)=>{if(Ct(a)&&n.length===0)return{entry:{cid:r,name:e,path:t}};let c=await z(s.get(r,a)),h;try{h=$(c)}catch(u){throw new O(u.message)}let f,l;if(e==null&&(e=r.toString()),h.Data==null)throw new O("no data in PBNode");try{f=I.unmarshal(h.Data)}catch(u){throw new O(u.message)}if(t==null&&(t=e),n.length>0){let u;if(f?.type==="hamt-sharded-directory"?u=await Va(h,n[0],s):u=dh(h,n[0]),u==null)throw new pe("file does not exist");let d=n.shift(),m=`${t}/${d}`;l={cid:u,toResolve:n,name:d??"",path:m}}let y=ph[f.type](r,h,f,t,i,o,s);if(y==null)throw new pe("could not find content exporter");return f.isDirectory()?{entry:{type:"directory",name:e,path:t,cid:r,content:y,unixfs:f,depth:o,node:h,size:f.fileSize()},next:l}:{entry:{type:"file",name:e,path:t,cid:r,content:y,unixfs:f,depth:o,node:h,size:f.fileSize()},next:l}},rc=mh;var yh={[q]:rc,[Q]:Ra,[Aa]:Fa,[Da]:Pa,[ii.code]:Ua,[Do]:$a},nc=async(r,e,t,n,i,o,s)=>{let a=yh[r.code];if(a==null)throw new jr(`No resolver for code ${r.code}`);return a(r,e,t,n,nc,i,o,s)},ic=nc;var gh=(r="")=>(r.trim().match(/([^\\^/]|\\\/)+/g)??[]).filter(Boolean),wh=r=>{if(r instanceof Uint8Array)return{cid:A.decode(r),toResolve:[]};let e=A.asCID(r);if(e!=null)return{cid:e,toResolve:[]};if(typeof r=="string"){r.indexOf("/ipfs/")===0&&(r=r.substring(6));let t=gh(r);return{cid:A.parse(t[0]),toResolve:t.slice(1)}}throw new Hr(`Unknown path type ${r}`)};async function*$i(r,e,t={}){let{cid:n,toResolve:i}=wh(r),o=n.toString(),s=o,a=i.length;for(;;){let c=await ic(n,o,s,i,a,e,t);if(c.entry==null&&c.next==null)throw new pe(`Could not resolve ${r}`);if(c.entry!=null&&(yield c.entry),c.next==null)return;i=c.next.toResolve,n=c.next.cid,o=c.next.name,s=c.next.path}}async function Y(r,e,t={}){let n=await _e($i(r,e,t));if(n==null)throw new pe(`Could not resolve ${r}`);return n}async function*mn(r,e,t={}){let n=await Y(r,e,t);if(n==null)return;if(yield n,n.type==="directory")for await(let o of i(n,t))yield o;async function*i(o,s){for await(let a of o.content(s))yield a,!(a instanceof Uint8Array)&&a.type==="directory"&&(yield*i(a,s))}}function xh(r,e){if(typeof r=="string")return bh(r);if(typeof r=="number")return Sh(r,e);throw Error(`Value provided to ms() must be a string or number. value=${JSON.stringify(r)}`)}var yn=xh;function bh(r){if(typeof r!="string"||r.length===0||r.length>100)throw Error(`Value provided to ms.parse() must be a string with length between 1 and 99. value=${JSON.stringify(r)}`);let e=/^(?<value>-?\d*\.?\d+) *(?<unit>milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|months?|mo|years?|yrs?|y)?$/i.exec(r);if(!e?.groups)return NaN;let{value:t,unit:n="ms"}=e.groups,i=parseFloat(t),o=n.toLowerCase();switch(o){case"years":case"year":case"yrs":case"yr":case"y":return i*315576e5;case"months":case"month":case"mo":return i*26298e5;case"weeks":case"week":case"w":return i*6048e5;case"days":case"day":case"d":return i*864e5;case"hours":case"hour":case"hrs":case"hr":case"h":return i*36e5;case"minutes":case"minute":case"mins":case"min":case"m":return i*6e4;case"seconds":case"second":case"secs":case"sec":case"s":return i*1e3;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return i;default:throw Error(`Unknown unit "${o}" provided to ms.parse(). value=${JSON.stringify(r)}`)}}function _h(r){let e=Math.abs(r);return e>=315576e5?`${Math.round(r/315576e5)}y`:e>=26298e5?`${Math.round(r/26298e5)}mo`:e>=6048e5?`${Math.round(r/6048e5)}w`:e>=864e5?`${Math.round(r/864e5)}d`:e>=36e5?`${Math.round(r/36e5)}h`:e>=6e4?`${Math.round(r/6e4)}m`:e>=1e3?`${Math.round(r/1e3)}s`:`${r}ms`}function kh(r){let e=Math.abs(r);return e>=315576e5?rt(r,e,315576e5,"year"):e>=26298e5?rt(r,e,26298e5,"month"):e>=6048e5?rt(r,e,6048e5,"week"):e>=864e5?rt(r,e,864e5,"day"):e>=36e5?rt(r,e,36e5,"hour"):e>=6e4?rt(r,e,6e4,"minute"):e>=1e3?rt(r,e,1e3,"second"):`${r} ms`}function Sh(r,e){if(typeof r!="number"||!Number.isFinite(r))throw Error("Value provided to ms.format() must be of type number.");return e?.long?kh(r):_h(r)}function rt(r,e,t,n){let i=e>=t*1.5;return`${Math.round(r/t)} ${n}${i?"s":""}`}function Ri(r){t.debug=t,t.default=t,t.coerce=c,t.disable=o,t.enable=i,t.enabled=s,t.humanize=yn,t.destroy=h,Object.keys(r).forEach(f=>{t[f]=r[f]}),t.names=[],t.skips=[],t.formatters={};function e(f){let l=0;for(let y=0;y<f.length;y++)l=(l<<5)-l+f.charCodeAt(y),l|=0;return t.colors[Math.abs(l)%t.colors.length]}t.selectColor=e;function t(f,l){let y,u=null,d,m;function x(...g){if(!x.enabled)return;let w=x,_=Number(new Date),S=_-(y||_);w.diff=S,w.prev=y,w.curr=_,y=_,g[0]=t.coerce(g[0]),typeof g[0]!="string"&&g.unshift("%O");let B=0;g[0]=g[0].replace(/%([a-zA-Z%])/g,(E,L)=>{if(E==="%%")return"%";B++;let le=t.formatters[L];if(typeof le=="function"){let st=g[B];E=le.call(w,st),g.splice(B,1),B--}return E}),t.formatArgs.call(w,g),l?.onLog!=null&&l.onLog(...g),(w.log||t.log).apply(w,g)}return x.namespace=f,x.useColors=t.useColors(),x.color=t.selectColor(f),x.extend=n,x.destroy=t.destroy,Object.defineProperty(x,"enabled",{enumerable:!0,configurable:!1,get:()=>u!==null?u:(d!==t.namespaces&&(d=t.namespaces,m=t.enabled(f)),m),set:g=>{u=g}}),typeof t.init=="function"&&t.init(x),x}function n(f,l){let y=t(this.namespace+(typeof l>"u"?":":l)+f);return y.log=this.log,y}function i(f){t.save(f),t.namespaces=f,t.names=[],t.skips=[];let l,y=(typeof f=="string"?f:"").split(/[\s,]+/),u=y.length;for(l=0;l<u;l++)y[l]&&(f=y[l].replace(/\*/g,".*?"),f[0]==="-"?t.skips.push(new RegExp("^"+f.substr(1)+"$")):t.names.push(new RegExp("^"+f+"$")))}function o(){let f=[...t.names.map(a),...t.skips.map(a).map(l=>"-"+l)].join(",");return t.enable(""),f}function s(f){if(f[f.length-1]==="*")return!0;let l,y;for(l=0,y=t.skips.length;l<y;l++)if(t.skips[l].test(f))return!1;for(l=0,y=t.names.length;l<y;l++)if(t.names[l].test(f))return!0;return!1}function a(f){return f.toString().substring(2,f.toString().length-2).replace(/\.\*\?$/,"*")}function c(f){return f instanceof Error?f.stack??f.message:f}function h(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return t.setupFormatters(t.formatters),t.enable(t.load()),t}var gn=Nh(),Eh=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function vh(){return typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs)?!0:typeof navigator<"u"&&navigator.userAgent?.toLowerCase().match(/(edge|trident)\/(\d+)/)!=null?!1:typeof document<"u"&&document.documentElement?.style?.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent?.toLowerCase().match(/firefox\/(\d+)/)!=null&&parseInt(RegExp.$1,10)>=31||typeof navigator<"u"&&navigator.userAgent?.toLowerCase().match(/applewebkit\/(\d+)/)}function Bh(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+yn(this.diff),!this.useColors)return;let e="color: "+this.color;r.splice(1,0,e,"color: inherit");let t=0,n=0;r[0].replace(/%[a-zA-Z%]/g,i=>{i!=="%%"&&(t++,i==="%c"&&(n=t))}),r.splice(n,0,e)}var Ih=console.debug??console.log??(()=>{});function Ah(r){try{r?gn?.setItem("debug",r):gn?.removeItem("debug")}catch{}}function Ch(){let r;try{r=gn?.getItem("debug")}catch{}return!r&&typeof globalThis.process<"u"&&"env"in globalThis.process&&(r=globalThis.process.env.DEBUG),r}function Nh(){try{return localStorage}catch{}}function Th(r){r.j=function(e){try{return JSON.stringify(e)}catch(t){return"[UnexpectedJSONParseError]: "+t.message}}}var oc=Ri({formatArgs:Bh,save:Ah,load:Ch,useColors:vh,setupFormatters:Th,colors:Eh,storage:gn,log:Ih});var re=oc;re.formatters.b=r=>r==null?"undefined":de.baseEncode(r);re.formatters.t=r=>r==null?"undefined":$e.baseEncode(r);re.formatters.m=r=>r==null?"undefined":Wt.baseEncode(r);re.formatters.p=r=>r==null?"undefined":r.toString();re.formatters.c=r=>r==null?"undefined":r.toString();re.formatters.k=r=>r==null?"undefined":r.toString();re.formatters.a=r=>r==null?"undefined":r.toString();function sc(r,e=""){let t=ac(r.message),n=ac(r.stack);return t!=null&&n!=null?n.includes(t)?`${n.split(`
5
3
  `).join(`
6
- ${e}`)}`).join(`
7
- ${e}`)}`:t+=`
8
- ${e}[Error list was empty]`,t.trim()}return $i(r)};function Sh(r){let e=()=>{};return e.enabled=!1,e.color="",e.diff=0,e.log=()=>{},e.namespace=r,e.destroy=()=>!0,e.extend=()=>e,e}function R(r,e){let t=Sh(`${r}:trace`);return re.enabled(`${r}:trace`)&&re.names.map(n=>n.toString()).find(n=>n.includes(":trace"))!=null&&(t=re(`${r}:trace`,e)),Object.assign(re(r,e),{error:re(`${r}:error`,e),trace:t,newScope:n=>R(`${r}:${n}`,e)})}function tc(r){if(r!=null&&(r=r.trim(),r.length!==0))return r}var Vi=Ft(zr(),1);function gn(r){function e(t){return t instanceof yn?t:new yn(t,r)}return e}var yn=class{_value;_hashFn;_depth;_availableBits;_currentBufferIndex;_buffers;constructor(e,t){if(!(e instanceof Uint8Array))throw new Error("can only hash Uint8Arrays");this._value=e,this._hashFn=t,this._depth=-1,this._availableBits=0,this._currentBufferIndex=0,this._buffers=[]}async take(e){let t=e;for(;this._availableBits<t;)await this._produceMoreBits();let n=0;for(;t>0;){let i=this._buffers[this._currentBufferIndex],o=Math.min(i.availableBits(),t),s=i.take(o);n=(n<<o)+s,t-=o,this._availableBits-=o,i.availableBits()===0&&this._currentBufferIndex++}return n}untake(e){let t=e;for(;t>0;){let n=this._buffers[this._currentBufferIndex],i=Math.min(n.totalBits()-n.availableBits(),t);n.untake(i),t-=i,this._availableBits+=i,this._currentBufferIndex>0&&n.totalBits()===n.availableBits()&&(this._depth--,this._currentBufferIndex--)}}async _produceMoreBits(){this._depth++;let e=this._depth>0?Ie([this._value,Uint8Array.from([this._depth])]):this._value,t=await this._hashFn(e),n=new Ri(t);this._buffers.push(n),this._availableBits+=n.availableBits()}},Eh=[255,254,252,248,240,224,192,128],vh=[1,3,7,15,31,63,127,255],Ri=class{_value;_currentBytePos;_currentBitPos;constructor(e){this._value=e,this._currentBytePos=e.length-1,this._currentBitPos=7}availableBits(){return this._currentBitPos+1+this._currentBytePos*8}totalBits(){return this._value.length*8}take(e){let t=e,n=0;for(;t>0&&this._haveBits();){let i=this._value[this._currentBytePos],o=this._currentBitPos+1,s=Math.min(o,t),a=Bh(i,o-s,s);n=(n<<s)+a,t-=s,this._currentBitPos-=s,this._currentBitPos<0&&(this._currentBitPos=7,this._currentBytePos--)}return n}untake(e){for(this._currentBitPos+=e;this._currentBitPos>7;)this._currentBitPos-=8,this._currentBytePos+=1}_haveBits(){return this._currentBytePos>=0}};function Bh(r,e,t){let n=Ih(e,t);return(r&n)>>>e}function Ih(r,e){return Eh[r]&vh[Math.min(e+r-1,7)]}var lr=BigInt(Xe.code),rt=8;async function Tt(r){return(await Xe.encode(r)).subarray(0,8).reverse()}var ic=Ft(zr(),1);var ve=async(r,e,t)=>{t.codec==null&&(t.codec=O);let n=await oe.digest(r),i=A.create(t.cidVersion??1,t.codec.code,n);return await e.put(i,r,{...t,signal:t.signal}),i};var Mi=class{options;root;dir;path;dirty;flat;parent;parentKey;unixfs;mode;mtime;cid;size;nodeSize;constructor(e,t){this.options=t??{},this.root=e.root,this.dir=e.dir,this.path=e.path,this.dirty=e.dirty,this.flat=e.flat,this.parent=e.parent,this.parentKey=e.parentKey,this.unixfs=e.unixfs,this.mode=e.mode,this.mtime=e.mtime}},wn=class extends Mi{_bucket;constructor(e,t){super(e,t),this._bucket=yt({hashFn:Tt,bits:8})}async put(e,t){this.cid=void 0,this.size=void 0,this.nodeSize=void 0,await this._bucket.put(e,t)}async get(e){return this._bucket.get(e)}childCount(){return this._bucket.leafCount()}directChildrenCount(){return this._bucket.childrenCount()}onlyChild(){return this._bucket.onlyChild()}async*eachChildSeries(){for(let{key:e,value:t}of this._bucket.eachLeafSeries())yield{key:e,child:t}}estimateNodeSize(){return this.nodeSize!==void 0?this.nodeSize:(this.nodeSize=nc(this._bucket,this,this.options),this.nodeSize)}async*flush(e){for await(let t of rc(this._bucket,e,this,this.options))yield{...t,path:this.path}}};async function*rc(r,e,t,n){let i=r._children,o=[],s=0n;for(let u=0;u<i.length;u++){let d=i.get(u);if(d==null)continue;let m=u.toString(16).toUpperCase().padStart(2,"0");if(d instanceof se){let x;for await(let g of rc(d,e,null,n))x=g;if(x==null)throw new Error("Could not flush sharded directory, no sub-shard found");o.push({Name:m,Tsize:Number(x.size),Hash:x.cid}),s+=x.size}else if(Ch(d.value)){let x=d.value,g;for await(let b of x.flush(e))g=b,yield g;if(g==null)throw new Error("Did not flush dir");let w=m+d.key;o.push({Name:w,Tsize:Number(g.size),Hash:g.cid}),s+=g.size}else{let x=d.value;if(x.cid==null)continue;let g=m+d.key,w=x.size;o.push({Name:g,Tsize:Number(w),Hash:x.cid}),s+=BigInt(w??0)}}let a=Uint8Array.from(i.bitField().reverse()),c=new I({type:"hamt-sharded-directory",data:a,fanout:BigInt(r.tableSize()),hashType:lr,mtime:t?.mtime,mode:t?.mode}),h={Data:c.marshal(),Links:o},f=T(P(h)),l=await ve(f,e,n),y=BigInt(f.byteLength)+s;yield{cid:l,unixfs:c,size:y}}function Ch(r){return typeof r.flush=="function"}function nc(r,e,t){let n=r._children,i=[];for(let c=0;c<n.length;c++){let h=n.get(c);if(h==null)continue;let f=c.toString(16).toUpperCase().padStart(2,"0");if(h instanceof se){let l=nc(h,null,t);i.push({Name:f,Tsize:Number(l),Hash:t.cidVersion===0?xn:bn})}else if(typeof h.value.flush=="function"){let y=h.value.nodeSize();i.push({Name:f+h.key,Tsize:Number(y),Hash:t.cidVersion===0?xn:bn})}else{let l=h.value;if(l.cid==null)continue;let y=f+h.key,u=l.size;i.push({Name:y,Tsize:Number(u),Hash:l.cid})}}let o=Uint8Array.from(n.bitField().reverse()),s=new I({type:"hamt-sharded-directory",data:o,fanout:BigInt(r.tableSize()),hashType:lr,mtime:e?.mtime,mode:e?.mode});return T(P({Data:s.marshal(),Links:i})).length}var xn=A.parse("QmUNLLsPACCz1vLxQVkXqqLX5R1X345qqfHbsf67hvA3Nn"),bn=A.parse("zdj7WbTaiJT1fgatdet9Ei9iDB5hdCxkbVyhyh8YTUnXMiwYi");var Oi=R("helia:unixfs:commands:utils:hamt-utils"),_n=r=>r.toString(16).toUpperCase().padStart(2,"0").substring(0,2),oc=async(r,e,t)=>{let n=new wn({root:!0,dir:!0,parent:void 0,parentKey:void 0,path:"",dirty:!0,flat:!1,mtime:t.mtime,mode:t.mode},t);for(let o=0;o<e.length;o++)await n._bucket.put(e[o].name,{size:e[o].size,cid:e[o].cid});let i=await _e(n.flush(r));if(i==null)throw new Error("Flushing shard yielded no result");return i},kn=async(r,e,t)=>{let n=I.unmarshal(r[0].node.Data??new Uint8Array(0)),i=BigInt(Math.pow(2,rt));r.reverse();let o,s;for(let a=0;a<r.length;a++){let c=a===r.length-1,h=r[a],f=Uint8Array.from(h.children.bitField().reverse()),l=new I({type:"hamt-sharded-directory",data:f,fanout:i,hashType:lr});c&&(l.mtime=n.mtime,l.mode=n.mode),s={Data:l.marshal(),Links:h.node.Links};let y=T(P(s));if(o=await ve(y,e,t),!c){let u=r[a+1];if(u==null)throw new Error("Was not operating on shard root but also had no parent?");Oi("updating link in parent sub-shard with prefix %s",u.prefix),u.node.Links=u.node.Links.filter(d=>d.Name!==u.prefix),u.node.Links.push({Name:u.prefix,Hash:o,Tsize:h.node.Links.reduce((d,m)=>d+(m.Tsize??0),y.byteLength)})}}if(o==null||s==null)throw new Error("Noting persisted");return{cid:o,node:s}},Sn=async(r,e,t,n)=>{let o=gn(Tt)(M(e)),s=[];for(;;){let a=await z(t.get(r,n)),c=$(a),h=new ic.default,f=await o.take(rt),l=_n(f);s.push({prefix:l,children:h,node:c});let y;for(let d of c.Links){let m=d.Name??"";if(m.length<2)throw new Error("Invalid HAMT - link name was too short");let x=parseInt(m.substring(0,2),16);h.set(x,!0),m.startsWith(l)&&(y=d)}if(y==null){Oi("no link found with prefix %s for %s",l,e);break}let u=y.Name??"";if(u.length<2)throw new Error("Invalid HAMT - link name was too short");if(u.length===2){r=y.Hash,Oi("descend into sub-shard with prefix %s",u);continue}break}return{path:s,hash:o}};async function En(r,e,t,n){if(r.Data==null)throw new Error("DagPB node had no data");let i=I.unmarshal(r.Data),o;if(i.type==="directory")o=Nh(r);else if(i.type==="hamt-sharded-directory")o=await sc(r,0,t,e,n);else throw new Error("Can only estimate the size of directories or shards");return o>t}function Nh(r){let e=0;for(let t of r.Links)e+=(t.Name??"").length,e+=t.Hash.version===1?bn.bytes.byteLength:xn.bytes.byteLength;return e}async function sc(r,e,t,n,i){if(e>t)return t;if(r.Data==null||!I.unmarshal(r.Data).isDirectory())return e;for(let s of r.Links){let a=s.Name??"";if(a=a.substring(2),e+=a.length,e+=s.Hash.bytes.byteLength,s.Hash.code===q){let c=await z(n.get(s.Hash,i)),h=$(c);e+=await sc(h,e,t,n,i)}}return e}var Le=R("helia:unixfs:components:utils:add-link");async function Dt(r,e,t,n){if(r.node.Data==null)throw new V("Invalid parent passed to addLink");if(I.unmarshal(r.node.Data).type==="hamt-sharded-directory")return Le("adding link to sharded directory"),zh(r,e,t,n);Le(`adding ${e.Name} (${e.Hash}) to regular directory`);let o=await Lh(r,e,t,n);if(await En(o.node,t,n.shardSplitThresholdBytes??262144,n)){Le("converting directory to sharded directory");let s=await Dh(o,t);o.cid=s.cid,o.node=$(await z(t.get(s.cid,n)))}return o}var Dh=async(r,e)=>{if(r.node.Data==null)throw new V("Invalid parent passed to convertToShardedDirectory");let t=I.unmarshal(r.node.Data),n=await oc(e,r.node.Links.map(i=>({name:i.Name??"",size:BigInt(i.Tsize??0),cid:i.Hash})),{mode:t.mode,mtime:t.mtime,cidVersion:r.cid.version});return Le(`converted directory to sharded directory ${n.cid}`),n},Lh=async(r,e,t,n)=>{let i=r.node.Links.filter(f=>{let l=f.Name===e.Name;if(l&&!n.allowOverwriting)throw new tr;return!l});if(i.push(e),r.node.Data==null)throw new ee("Parent node with no data passed to addToDirectory");let o=I.unmarshal(r.node.Data),s;if(o.mtime!=null){let f=Date.now(),l=Math.floor(f/1e3);o.mtime={secs:BigInt(l),nsecs:(f-l*1e3)*1e3},s=o.marshal()}else s=r.node.Data;r.node=P({Data:s,Links:i});let a=T(r.node),c=await oe.digest(a),h=A.create(r.cid.version,q,c);return await t.put(h,a),{node:r.node,cid:h}},zh=async(r,e,t,n)=>{let{path:i,hash:o}=await Sn(r.cid,e.Name,t,n),s=i[i.length-1];if(s==null)throw new Error("Invalid HAMT, could not generate path");let a=s.prefix,c=parseInt(a,16);Le("next prefix for %s is %s",e.Name,a);let h=`${a}${e.Name}`,f=s.node.Links.find(l=>(l.Name??"").startsWith(a));if(f!=null)if(Le("link %s was present in shard",h),f.Name===h){if(!n.allowOverwriting)throw new tr;Le("overwriting %s in sub-shard",e.Name),s.node.Links=s.node.Links.filter(l=>l.Name!==h),s.node.Links.push({Name:h,Hash:e.Hash,Tsize:e.Tsize})}else{if(f.Name?.length===2)throw new Error("Existing link was sub-shard?!");{Le("prefix %s already exists, creating new sub-shard",a);let l=s.node.Links.findIndex(x=>x.Name?.startsWith(a)),y=s.node.Links.splice(l,1)[0],u=(y.Name??"").substring(2),m=gn(Tt)(M(u));for(let x=0;x<i.length;x++)await m.take(rt);for(;;){let x=await m.take(rt),g=_n(x);y.Name=`${g}${u}`;let w=await o.take(rt),b=_n(w);if(g===b){let B=new Vi.default;B.set(w,!0),i.push({prefix:b,children:B,node:{Links:[]}});continue}let S=new Vi.default;S.set(w,!0),S.set(x,!0),i.push({prefix:a,children:S,node:{Links:[y,{Name:`${b}${e.Name}`,Hash:e.Hash,Tsize:e.Tsize}]}});break}}}else Le("link %s was not present in sub-shard",h),e.Name=h,s.node.Links.push(e),s.children.set(c,!0),Le("adding %s to existing sub-shard",h);return kn(i,t,n)};async function je(r,e,t={}){let n=await Y(r,e,t);if(n.type!=="directory")throw new Oe(`${r.toString()} was not a UnixFS directory`);return{cid:r,node:n.node}}async function Lt(r,e,t,n){let i=await Y(r,t,n);if(i.type!=="directory"&&i.type!=="file"&&i.type!=="raw")throw new Ne(`${r.toString()} was not a UnixFS node`);return{Name:e,Tsize:i.node instanceof Uint8Array?i.node.byteLength:Fh(i.node),Hash:r}}function Fh(r){let e=r.Links.reduce((t,n)=>t+(n.Tsize??0),0);return T(r).byteLength+e}var Ph=R("helia:unixfs:components:utils:resolve");async function ze(r,e,t,n){if(e==null||e==="")return{cid:r};let i=`/ipfs/${r}${e==null?"":`/${e}`}`,o=await Yo(Pi(i,t,n));if(o.length===0)throw new Ur("Could not find path in directory");return Ph("resolved %s to %c",e,r),{cid:o[o.length-1].cid,path:e,segments:o}}async function zt(r,e,t,n){if(e.segments==null||e.segments.length===0)return r;let i=e.segments.pop();if(i==null)throw new Error("Insufficient segments");i.cid=r,e.segments.reverse();for(let o of e.segments){let[s,a]=await Promise.all([je(o.cid,t,n),Lt(i.cid,i.name,t,n)]);r=(await Dt(s,a,t,{...n,allowOverwriting:!0,cidVersion:r.version})).cid,o.cid=r,i=o}return r}async function*ac(r,e,t={}){let n=await ze(r,t.path,e,t),i=await Y(n.cid,e,t);if(i.type!=="file"&&i.type!=="raw")throw new $r;if(i.content==null)throw new gt;yield*i.content(t)}var Uh=R("helia:unixfs:chmod");async function cc(r,e,t,n={}){let i=await ze(r,n.path,t,n);if(Uh("chmod %c %d",i.cid,e),n.recursive===!0){let l=await De(async function*(){for await(let y of dn(i.cid,t,n)){let u,d=[];if(y.type==="raw")u=new I({type:"file",data:y.node});else if(y.type==="file"||y.type==="directory")u=y.unixfs,d=y.node.Links;else throw new Ne;u.mode=e;let m={Data:u.marshal(),Links:d};yield{path:y.path,content:m}}},y=>Je(y,t,{...n,dagBuilder:async function*(u,d){for await(let m of u)yield async function(){let x=m.content,g=T(x),w=await ve(g,d,{...n,cidVersion:r.version});if(x.Data==null)throw new ee(`${w} had no data`);let b=I.unmarshal(x.Data);return{cid:w,size:BigInt(g.length),path:m.path,unixfs:b}}}}),async y=>_e(y));if(l==null)throw new Te(`Could not chmod ${i.cid.toString()}`);return zt(l.cid,i,t,n)}let o=await z(t.get(i.cid,n)),s,a=[];if(i.cid.code===Q)s=new I({type:"file",data:o});else{let l=$(o);if(l.Data==null)throw new ee(`${i.cid.toString()} had no data`);a=l.Links,s=I.unmarshal(l.Data)}s.mode=e;let c=T({Data:s.marshal(),Links:a}),h=await oe.digest(c),f=A.create(i.cid.version,q,h);return await t.put(f,c),zt(f,i,t,n)}var $h=R("helia:unixfs:cp");async function uc(r,e,t,n,i={}){if(t.includes("/"))throw new V("Name must not have slashes");let[o,s]=await Promise.all([je(e,n,i),Lt(r,t,n,i)]);return $h('Adding %c as "%s" to %c',r,t,e),(await Dt(o,s,n,{allowOverwriting:i.force,cidVersion:e.version,...i})).cid}async function*fc(r,e,t={}){let n=await ze(r,t.path,e,t),i=await Y(n.cid,e,{...t,extended:!0});if(i.type==="file"||i.type==="raw"){t.extended===!1?yield{name:i.name,path:i.path,cid:i.cid}:yield i;return}if(i.content==null)throw new gt;if(i.type!=="directory")throw new Oe;yield*i.content(t)}var lc=R("helia:unixfs:mkdir");async function hc(r,e,t,n={}){if(e.includes("/"))throw new V("Path must not have slashes");if((await Y(r,t,n)).type!=="directory")throw new Oe(`${r.toString()} was not a UnixFS directory`);lc("creating %s",e);let s={Data:new I({type:"directory",mode:n.mode,mtime:n.mtime}).marshal(),Links:[]},a=T(s),c=await oe.digest(a),h=A.create(n.cidVersion??1,q,c);await t.put(h,a);let[f,l]=await Promise.all([je(r,t,n),Lt(h,e,t,n)]);return lc("adding empty dir called %s to %c",e,r),(await Dt(f,l,t,{...n,allowOverwriting:n.force})).cid}var vn=R("helia:unixfs:utils:remove-link");async function dc(r,e,t,n){if(r.node.Data==null)throw new ee("Parent node had no data");if(I.unmarshal(r.node.Data).type==="hamt-sharded-directory"){vn(`removing ${e} from sharded directory`);let o=await Mh(r,e,t,n);return await En(o.node,t,n.shardSplitThresholdBytes??262144,n)?o:(vn("converting shard to flat directory %c",r.cid),Oh(o,t,n))}return vn(`removing link ${e} regular directory`),Rh(r,e,t,n)}var Rh=async(r,e,t,n)=>{r.node.Links=r.node.Links.filter(s=>s.Name!==e);let i=T(r.node),o=await ve(i,t,{...n,cidVersion:r.cid.version});return vn(`Updated regular directory ${o}`),{node:r.node,cid:o}},Mh=async(r,e,t,n)=>{let{path:i}=await Sn(r.cid,e,t,n),o=i[i.length-1];if(o==null)throw new Error("Invalid HAMT, could not generate path");let s=o.node.Links.filter(h=>(h.Name??"").substring(2)===e).map(h=>h.Name).pop();if(s==null)throw new Error("File not found");let a=s.substring(0,2),c=parseInt(a,16);if(o.node.Links=o.node.Links.filter(h=>h.Name!==s),o.children.unset(c),o.node.Links.length===1)for(;i.length!==1;){let h=i[i.length-1];if(h==null||h.node.Links.length>1)break;i.pop();let f=i[i.length-1];if(f==null)break;let l=h.node.Links[0];f.node.Links=f.node.Links.filter(y=>!(y.Name??"").startsWith(f.prefix)),f.node.Links.push({Hash:l.Hash,Name:`${f.prefix}${(l.Name??"").substring(2)}`,Tsize:l.Tsize})}return kn(i,t,n)},Oh=async(r,e,t)=>{if(r.node.Data==null)throw new V("Invalid parent passed to convertToFlatDirectory");let n={Links:[]},i=await Y(r.cid,e);if(i.type!=="directory")throw new Error("Unexpected node type");for await(let c of i.content()){let h=0;c.node instanceof Uint8Array?h=c.node.byteLength:h=T(c.node).length,n.Links.push({Hash:c.cid,Name:c.name,Tsize:h})}let o=I.unmarshal(r.node.Data);n.Data=new I({type:"directory",mode:o.mode,mtime:o.mtime}).marshal();let s=T(P(n));return{cid:await ve(s,e,{codec:O,cidVersion:r.cid.version,signal:t.signal}),node:n}};var Vh=R("helia:unixfs:rm");async function pc(r,e,t,n={}){if(e.includes("/"))throw new V("Name must not have slashes");let i=await je(r,t,n);return Vh("Removing %s from %c",e,r),(await dc(i,e,t,{...n,cidVersion:r.version})).cid}var Hi={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},mc={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},yc=new globalThis.TextEncoder;function Hh(r,e){let t=Hi[e],n=mc[e];for(let i=0;i<r.length;i++)n^=BigInt(r[i]),n=BigInt.asUintN(e,n*t);return n}function jh(r,e,t){if(t.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=Hi[e],i=mc[e],o=r;for(;o.length>0;){let s=yc.encodeInto(o,t);o=o.slice(s.read);for(let a=0;a<s.written;a++)i^=BigInt(t[a]),i=BigInt.asUintN(e,i*n)}return i}function ji(r,{size:e=32,utf8Buffer:t}={}){if(!Hi[e])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof r=="string"){if(t)return jh(r,e,t);r=yc.encode(r)}return Hh(r,e)}var hr={hash:r=>Number(ji(r,{size:32})),hashV:(r,e)=>qh(hr.hash(r,e))};function qh(r){let e=r.toString(16);return e.length%2===1&&(e=`0${e}`),M(e,"base16")}var gc=64,Be=class{fp;h;seed;constructor(e,t,n,i=2){if(i>gc)throw new TypeError("Invalid Fingerprint Size");let o=t.hashV(e,n),s=ge(i);for(let a=0;a<s.length;a++)s[a]=o[a];s.length===0&&(s[0]=7),this.fp=s,this.h=t,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(e){return e?.fp instanceof Uint8Array?_r(this.fp,e.fp):!1}};function nt(r,e){return Math.floor(Math.random()*(e-r))+r}var it=class{contents;constructor(e){this.contents=new Array(e).fill(null)}has(e){if(!(e instanceof Be))throw new TypeError("Invalid Fingerprint");return this.contents.some(t=>e.equals(t))}add(e){if(!(e instanceof Be))throw new TypeError("Invalid Fingerprint");for(let t=0;t<this.contents.length;t++)if(this.contents[t]==null)return this.contents[t]=e,!0;return!0}swap(e){if(!(e instanceof Be))throw new TypeError("Invalid Fingerprint");let t=nt(0,this.contents.length-1),n=this.contents[t];return this.contents[t]=e,n}remove(e){if(!(e instanceof Be))throw new TypeError("Invalid Fingerprint");let t=this.contents.findIndex(n=>e.equals(n));return t>-1?(this.contents[t]=null,!0):!1}};var Gh=500,dr=class{bucketSize;filterSize;fingerprintSize;buckets;count;hash;seed;constructor(e){this.filterSize=e.filterSize,this.bucketSize=e.bucketSize??4,this.fingerprintSize=e.fingerprintSize??2,this.count=0,this.buckets=[],this.hash=e.hash??hr,this.seed=e.seed??nt(0,Math.pow(2,10))}add(e){typeof e=="string"&&(e=M(e));let t=new Be(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,i=(n^t.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new it(this.bucketSize)),this.buckets[i]==null&&(this.buckets[i]=new it(this.bucketSize)),this.buckets[n].add(t)||this.buckets[i].add(t))return this.count++,!0;let o=[n,i],s=o[nt(0,o.length-1)];this.buckets[s]==null&&(this.buckets[s]=new it(this.bucketSize));for(let a=0;a<Gh;a++){let c=this.buckets[s].swap(t);if(c!=null&&(s=(s^c.hash())%this.filterSize,this.buckets[s]==null&&(this.buckets[s]=new it(this.bucketSize)),this.buckets[s].add(c)))return this.count++,!0}return!1}has(e){typeof e=="string"&&(e=M(e));let t=new Be(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,i=this.buckets[n]?.has(t)??!1;if(i)return i;let o=(n^t.hash())%this.filterSize;return this.buckets[o]?.has(t)??!1}remove(e){typeof e=="string"&&(e=M(e));let t=new Be(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,i=this.buckets[n]?.remove(t)??!1;if(i)return this.count--,i;let o=(n^t.hash())%this.filterSize,s=this.buckets[o]?.remove(t)??!1;return s&&this.count--,s}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}};var pr=class{filterSize;bucketSize;fingerprintSize;scale;filterSeries;hash;seed;constructor(e){this.bucketSize=e.bucketSize??4,this.filterSize=e.filterSize??(1<<18)/this.bucketSize,this.fingerprintSize=e.fingerprintSize??2,this.scale=e.scale??2,this.hash=e.hash??hr,this.seed=e.seed??nt(0,Math.pow(2,10)),this.filterSeries=[new dr({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(e){if(typeof e=="string"&&(e=M(e)),this.has(e))return!0;let t=this.filterSeries.find(n=>n.reliable);if(t==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);t=new dr({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(t)}return t.add(e)}has(e){typeof e=="string"&&(e=M(e));for(let t=0;t<this.filterSeries.length;t++)if(this.filterSeries[t].has(e))return!0;return!1}remove(e){typeof e=="string"&&(e=M(e));for(let t=0;t<this.filterSeries.length;t++)if(this.filterSeries[t].remove(e))return!0;return!1}get count(){return this.filterSeries.reduce((e,t)=>e+t.count,0)}};var wc=1877,Bn=1604,Wh=R("helia:unixfs:stat");async function xc(r,e,t={}){let n=await ze(r,t.path,e,t);Wh("stat %c",n.cid);let i=await Y(n.cid,e,t);if(i.type==="raw")return t.extended===!0?Zh(i):Jh(i);if(i.type==="file"||i.type==="directory")return t.extended===!0?Xh(i,e,t.filter??new pr({filterSize:1024}),t):Kh(i);throw new Ne}function Kh(r){return{type:r.type,cid:r.cid,unixfs:r.unixfs,mode:r.unixfs.mode??(r.unixfs.isDirectory()?wc:Bn),mtime:r.unixfs.mtime,size:r.unixfs.fileSize()}}async function Xh(r,e,t,n){let i=await bc(r.cid,e,!1,t,n);return{type:r.type,cid:r.cid,unixfs:r.unixfs,size:r.unixfs.isDirectory()?i.dirSize:r.unixfs.fileSize(),mode:r.unixfs.mode??(r.unixfs.isDirectory()?wc:Bn),mtime:r.unixfs.mtime,localSize:i.localSize,dagSize:i.dagSize,deduplicatedDagSize:i.deduplicatedDagSize,blocks:i.blocks,uniqueBlocks:i.uniqueBlocks}}function Jh(r){return{type:r.type,cid:r.cid,unixfs:void 0,mode:Bn,mtime:void 0,size:BigInt(r.node.byteLength)}}function Zh(r){return{type:r.type,cid:r.cid,unixfs:void 0,mode:Bn,mtime:void 0,size:BigInt(r.node.byteLength),localSize:BigInt(r.node.byteLength),dagSize:BigInt(r.node.byteLength),deduplicatedDagSize:BigInt(r.node.byteLength),blocks:1n,uniqueBlocks:1n}}async function bc(r,e,t,n,i){let o={dirSize:0n,localSize:0n,dagSize:0n,deduplicatedDagSize:0n,blocks:0n,uniqueBlocks:0n};try{let s=n.has(r.bytes);n.add(r.bytes);let a=await z(e.get(r,i));if(o.blocks++,o.dagSize+=BigInt(a.byteLength),s||(o.uniqueBlocks++,o.deduplicatedDagSize+=BigInt(a.byteLength)),r.code===Q)o.localSize+=BigInt(a.byteLength),t&&(o.dirSize+=BigInt(a.byteLength));else if(r.code===q){let c=$(a),h;if(c.Data!=null&&(h=I.unmarshal(c.Data)),c.Links.length>0){for(let f of c.Links){let l=await bc(f.Hash,e,Yh(f,h),n,i);o.localSize+=l.localSize,o.dagSize+=l.dagSize,o.deduplicatedDagSize+=l.deduplicatedDagSize,o.blocks+=l.blocks,o.uniqueBlocks+=l.uniqueBlocks,o.dirSize+=l.dirSize}t&&h!=null&&(o.dirSize+=h.fileSize())}else{if(h==null)throw new ee(`PBNode ${r.toString()} had no data`);h.data!=null&&(o.localSize+=BigInt(h.data.byteLength??0)),t&&(o.dirSize+=h.fileSize())}}else throw new Te(`${r.toString()} was neither DAG_PB nor RAW`)}catch(s){if(s.name!=="NotFoundError"||i.offline!==!0)throw s}return o}function Yh(r,e){if(e==null)return!1;let t=r.Name;return t==null?!1:e.type==="directory"?!0:e.type==="hamt-sharded-directory"&&t.length>2}var Qh=R("helia:unixfs:touch");async function _c(r,e,t={}){let n=await ze(r,t.path,e,t),i=t.mtime??{secs:BigInt(Math.round(Date.now()/1e3)),nsecs:0};if(Qh("touch %c %o",n.cid,i),t.recursive){let l=await De(async function*(){for await(let y of dn(n.cid,e)){let u,d;if(y.type==="raw")u=new I({data:y.node}),d=[];else if(y.type==="file"||y.type==="directory")u=y.unixfs,d=y.node.Links;else throw new Ne;u.mtime=i;let m={Data:u.marshal(),Links:d};yield{path:y.path,content:m}}},y=>Je(y,e,{...t,dagBuilder:async function*(u,d){for await(let m of u)yield async function(){let x=m.content,g=T(x),w=await ve(g,d,{...t,cidVersion:r.version});if(x.Data==null)throw new ee(`${w} had no data`);let b=I.unmarshal(x.Data);return{cid:w,size:BigInt(g.length),path:m.path,unixfs:b}}}}),async y=>_e(y));if(l==null)throw new Te(`Could not chmod ${n.cid.toString()}`);return zt(l.cid,n,e,t)}let o=await z(e.get(n.cid,t)),s,a=[];if(n.cid.code===Q)s=new I({data:o});else{let l=$(o);if(a=l.Links,l.Data==null)throw new ee(`${n.cid.toString()} had no data`);s=I.unmarshal(l.Data)}s.mtime=i;let c=T({Data:s.marshal(),Links:a}),h=await oe.digest(c),f=A.create(n.cid.version,q,h);return await e.put(f,c),zt(f,n,e,t)}var In=class{components;constructor(e){this.components=e}async*addAll(e,t={}){yield*Rr(e,this.components.blockstore,t)}async addBytes(e,t={}){return gs(e,this.components.blockstore,t)}async addByteStream(e,t={}){return ws(e,this.components.blockstore,t)}async addFile(e,t={}){return xs(e,this.components.blockstore,t)}async addDirectory(e={},t={}){return bs(e,this.components.blockstore,t)}async*cat(e,t={}){yield*ac(e,this.components.blockstore,t)}async chmod(e,t,n={}){return cc(e,t,this.components.blockstore,n)}async cp(e,t,n,i={}){return uc(e,t,n,this.components.blockstore,i)}async*ls(e,t={}){yield*fc(e,this.components.blockstore,t)}async mkdir(e,t,n={}){return hc(e,t,this.components.blockstore,n)}async rm(e,t,n={}){return pc(e,t,this.components.blockstore,n)}async stat(e,t={}){return xc(e,this.components.blockstore,t)}async touch(e,t={}){return _c(e,this.components.blockstore,t)}};async function*kc(){throw new Error("Not supported in browsers")}function Sc(r,e){return r=new URL(r),{path:decodeURIComponent(new URL(r).pathname.split("/").pop()??""),content:ed(r,e)}}async function*ed(r,e){let t=await globalThis.fetch(r,e);if(t.body==null)throw new Te("HTTP response did not have a body");let n=t.body.getReader();try{for(;;){let{done:i,value:o}=await n.read();if(i)return;o!=null&&(yield o)}}finally{n.releaseLock()}}function td(r){return new In(r)}return Cc(rd);})();
4
+ ${e}`)}`:`${t}
5
+ ${e}${n.split(`
6
+ `).join(`
7
+ ${e}`)}`:n!=null?`${n.split(`
8
+ `).join(`
9
+ ${e}`)}`:t!=null?`${t}`:`${r.toString()}`}function Dh(r){return r instanceof AggregateError||r?.name==="AggregateError"&&Array.isArray(r.errors)}function cc(r,e=""){if(Dh(r)){let t=sc(r,e);return r.errors.length>0?(e=`${e} `,t+=`
10
+ ${e}${r.errors.map(n=>`${cc(n,`${e}`)}`).join(`
11
+ ${e}`)}`):t+=`
12
+ ${e}[Error list was empty]`,t.trim()}return sc(r,e)}re.formatters.e=r=>r==null?"undefined":cc(r);function Lh(r){let e=()=>{};return e.enabled=!1,e.color="",e.diff=0,e.log=()=>{},e.namespace=r,e.destroy=()=>!0,e.extend=()=>e,e}function R(r,e){let t=Lh(`${r}:trace`);return re.enabled(`${r}:trace`)&&re.names.map(n=>n.toString()).find(n=>n.includes(":trace"))!=null&&(t=re(`${r}:trace`,e)),Object.assign(re(r,e),{error:re(`${r}:error`,e),trace:t,newScope:n=>R(`${r}:${n}`,e)})}function ac(r){if(r!=null&&(r=r.trim(),r.length!==0))return r}var Hi=Pt(Ur(),1);function xn(r){function e(t){return t instanceof wn?t:new wn(t,r)}return e}var wn=class{_value;_hashFn;_depth;_availableBits;_currentBufferIndex;_buffers;constructor(e,t){if(!(e instanceof Uint8Array))throw new Error("can only hash Uint8Arrays");this._value=e,this._hashFn=t,this._depth=-1,this._availableBits=0,this._currentBufferIndex=0,this._buffers=[]}async take(e){let t=e;for(;this._availableBits<t;)await this._produceMoreBits();let n=0;for(;t>0;){let i=this._buffers[this._currentBufferIndex],o=Math.min(i.availableBits(),t),s=i.take(o);n=(n<<o)+s,t-=o,this._availableBits-=o,i.availableBits()===0&&this._currentBufferIndex++}return n}untake(e){let t=e;for(;t>0;){let n=this._buffers[this._currentBufferIndex],i=Math.min(n.totalBits()-n.availableBits(),t);n.untake(i),t-=i,this._availableBits+=i,this._currentBufferIndex>0&&n.totalBits()===n.availableBits()&&(this._depth--,this._currentBufferIndex--)}}async _produceMoreBits(){this._depth++;let e=this._depth>0?Ie([this._value,Uint8Array.from([this._depth])]):this._value,t=await this._hashFn(e),n=new Mi(t);this._buffers.push(n),this._availableBits+=n.availableBits()}},zh=[255,254,252,248,240,224,192,128],Fh=[1,3,7,15,31,63,127,255],Mi=class{_value;_currentBytePos;_currentBitPos;constructor(e){this._value=e,this._currentBytePos=e.length-1,this._currentBitPos=7}availableBits(){return this._currentBitPos+1+this._currentBytePos*8}totalBits(){return this._value.length*8}take(e){let t=e,n=0;for(;t>0&&this._haveBits();){let i=this._value[this._currentBytePos],o=this._currentBitPos+1,s=Math.min(o,t),a=Ph(i,o-s,s);n=(n<<s)+a,t-=s,this._currentBitPos-=s,this._currentBitPos<0&&(this._currentBitPos=7,this._currentBytePos--)}return n}untake(e){for(this._currentBitPos+=e;this._currentBitPos>7;)this._currentBitPos-=8,this._currentBytePos+=1}_haveBits(){return this._currentBytePos>=0}};function Ph(r,e,t){let n=Uh(e,t);return(r&n)>>>e}function Uh(r,e){return zh[r]&Fh[Math.min(e+r-1,7)]}var pr=BigInt(Je.code),nt=8;async function Dt(r){return(await Je.encode(r)).subarray(0,8).reverse()}var lc=Pt(Ur(),1);var ve=async(r,e,t)=>{t.codec==null&&(t.codec=V);let n=await oe.digest(r),i=A.create(t.cidVersion??1,t.codec.code,n);return await e.put(i,r,{...t,signal:t.signal}),i};var Oi=class{options;root;dir;path;dirty;flat;parent;parentKey;unixfs;mode;mtime;cid;size;nodeSize;constructor(e,t){this.options=t??{},this.root=e.root,this.dir=e.dir,this.path=e.path,this.dirty=e.dirty,this.flat=e.flat,this.parent=e.parent,this.parentKey=e.parentKey,this.unixfs=e.unixfs,this.mode=e.mode,this.mtime=e.mtime}},bn=class extends Oi{_bucket;constructor(e,t){super(e,t),this._bucket=gt({hashFn:Dt,bits:8})}async put(e,t){this.cid=void 0,this.size=void 0,this.nodeSize=void 0,await this._bucket.put(e,t)}async get(e){return this._bucket.get(e)}childCount(){return this._bucket.leafCount()}directChildrenCount(){return this._bucket.childrenCount()}onlyChild(){return this._bucket.onlyChild()}async*eachChildSeries(){for(let{key:e,value:t}of this._bucket.eachLeafSeries())yield{key:e,child:t}}estimateNodeSize(){return this.nodeSize!==void 0?this.nodeSize:(this.nodeSize=fc(this._bucket,this,this.options),this.nodeSize)}async*flush(e){for await(let t of uc(this._bucket,e,this,this.options))yield{...t,path:this.path}}};async function*uc(r,e,t,n){let i=r._children,o=[],s=0n;for(let u=0;u<i.length;u++){let d=i.get(u);if(d==null)continue;let m=u.toString(16).toUpperCase().padStart(2,"0");if(d instanceof se){let x;for await(let g of uc(d,e,null,n))x=g;if(x==null)throw new Error("Could not flush sharded directory, no sub-shard found");o.push({Name:m,Tsize:Number(x.size),Hash:x.cid}),s+=x.size}else if(Rh(d.value)){let x=d.value,g;for await(let _ of x.flush(e))g=_,yield g;if(g==null)throw new Error("Did not flush dir");let w=m+d.key;o.push({Name:w,Tsize:Number(g.size),Hash:g.cid}),s+=g.size}else{let x=d.value;if(x.cid==null)continue;let g=m+d.key,w=x.size;o.push({Name:g,Tsize:Number(w),Hash:x.cid}),s+=BigInt(w??0)}}let a=Uint8Array.from(i.bitField().reverse()),c=new I({type:"hamt-sharded-directory",data:a,fanout:BigInt(r.tableSize()),hashType:pr,mtime:t?.mtime,mode:t?.mode}),h={Data:c.marshal(),Links:o},f=T(P(h)),l=await ve(f,e,n),y=BigInt(f.byteLength)+s;yield{cid:l,unixfs:c,size:y}}function Rh(r){return typeof r.flush=="function"}function fc(r,e,t){let n=r._children,i=[];for(let c=0;c<n.length;c++){let h=n.get(c);if(h==null)continue;let f=c.toString(16).toUpperCase().padStart(2,"0");if(h instanceof se){let l=fc(h,null,t);i.push({Name:f,Tsize:Number(l),Hash:t.cidVersion===0?_n:kn})}else if(typeof h.value.flush=="function"){let y=h.value.nodeSize();i.push({Name:f+h.key,Tsize:Number(y),Hash:t.cidVersion===0?_n:kn})}else{let l=h.value;if(l.cid==null)continue;let y=f+h.key,u=l.size;i.push({Name:y,Tsize:Number(u),Hash:l.cid})}}let o=Uint8Array.from(n.bitField().reverse()),s=new I({type:"hamt-sharded-directory",data:o,fanout:BigInt(r.tableSize()),hashType:pr,mtime:e?.mtime,mode:e?.mode});return T(P({Data:s.marshal(),Links:i})).length}var _n=A.parse("QmUNLLsPACCz1vLxQVkXqqLX5R1X345qqfHbsf67hvA3Nn"),kn=A.parse("zdj7WbTaiJT1fgatdet9Ei9iDB5hdCxkbVyhyh8YTUnXMiwYi");var Vi=R("helia:unixfs:commands:utils:hamt-utils"),Sn=r=>r.toString(16).toUpperCase().padStart(2,"0").substring(0,2),hc=async(r,e,t)=>{let n=new bn({root:!0,dir:!0,parent:void 0,parentKey:void 0,path:"",dirty:!0,flat:!1,mtime:t.mtime,mode:t.mode},t);for(let o=0;o<e.length;o++)await n._bucket.put(e[o].name,{size:e[o].size,cid:e[o].cid});let i=await _e(n.flush(r));if(i==null)throw new Error("Flushing shard yielded no result");return i},En=async(r,e,t)=>{let n=I.unmarshal(r[0].node.Data??new Uint8Array(0)),i=BigInt(Math.pow(2,nt));r.reverse();let o,s;for(let a=0;a<r.length;a++){let c=a===r.length-1,h=r[a],f=Uint8Array.from(h.children.bitField().reverse()),l=new I({type:"hamt-sharded-directory",data:f,fanout:i,hashType:pr});c&&(l.mtime=n.mtime,l.mode=n.mode),s={Data:l.marshal(),Links:h.node.Links};let y=T(P(s));if(o=await ve(y,e,t),!c){let u=r[a+1];if(u==null)throw new Error("Was not operating on shard root but also had no parent?");Vi("updating link in parent sub-shard with prefix %s",u.prefix),u.node.Links=u.node.Links.filter(d=>d.Name!==u.prefix),u.node.Links.push({Name:u.prefix,Hash:o,Tsize:h.node.Links.reduce((d,m)=>d+(m.Tsize??0),y.byteLength)})}}if(o==null||s==null)throw new Error("Noting persisted");return{cid:o,node:s}},vn=async(r,e,t,n)=>{let o=xn(Dt)(M(e)),s=[];for(;;){let a=await z(t.get(r,n)),c=$(a),h=new lc.default,f=await o.take(nt),l=Sn(f);s.push({prefix:l,children:h,node:c});let y;for(let d of c.Links){let m=d.Name??"";if(m.length<2)throw new Error("Invalid HAMT - link name was too short");let x=parseInt(m.substring(0,2),16);h.set(x,!0),m.startsWith(l)&&(y=d)}if(y==null){Vi("no link found with prefix %s for %s",l,e);break}let u=y.Name??"";if(u.length<2)throw new Error("Invalid HAMT - link name was too short");if(u.length===2){r=y.Hash,Vi("descend into sub-shard with prefix %s",u);continue}break}return{path:s,hash:o}};async function Bn(r,e,t,n){if(r.Data==null)throw new Error("DagPB node had no data");let i=I.unmarshal(r.Data),o;if(i.type==="directory")o=Mh(r);else if(i.type==="hamt-sharded-directory")o=await dc(r,0,t,e,n);else throw new Error("Can only estimate the size of directories or shards");return o>t}function Mh(r){let e=0;for(let t of r.Links)e+=(t.Name??"").length,e+=t.Hash.version===1?kn.bytes.byteLength:_n.bytes.byteLength;return e}async function dc(r,e,t,n,i){if(e>t)return t;if(r.Data==null||!I.unmarshal(r.Data).isDirectory())return e;for(let s of r.Links){let a=s.Name??"";if(a=a.substring(2),e+=a.length,e+=s.Hash.bytes.byteLength,s.Hash.code===q){let c=await z(n.get(s.Hash,i)),h=$(c);e+=await dc(h,e,t,n,i)}}return e}var ze=R("helia:unixfs:components:utils:add-link");async function Lt(r,e,t,n){if(r.node.Data==null)throw new H("Invalid parent passed to addLink");if(I.unmarshal(r.node.Data).type==="hamt-sharded-directory")return ze("adding link to sharded directory"),jh(r,e,t,n);ze(`adding ${e.Name} (${e.Hash}) to regular directory`);let o=await Hh(r,e,t,n);if(await Bn(o.node,t,n.shardSplitThresholdBytes??262144,n)){ze("converting directory to sharded directory");let s=await Vh(o,t);o.cid=s.cid,o.node=$(await z(t.get(s.cid,n)))}return o}var Vh=async(r,e)=>{if(r.node.Data==null)throw new H("Invalid parent passed to convertToShardedDirectory");let t=I.unmarshal(r.node.Data),n=await hc(e,r.node.Links.map(i=>({name:i.Name??"",size:BigInt(i.Tsize??0),cid:i.Hash})),{mode:t.mode,mtime:t.mtime,cidVersion:r.cid.version});return ze(`converted directory to sharded directory ${n.cid}`),n},Hh=async(r,e,t,n)=>{let i=r.node.Links.filter(f=>{let l=f.Name===e.Name;if(l&&!n.allowOverwriting)throw new rr;return!l});if(i.push(e),r.node.Data==null)throw new ee("Parent node with no data passed to addToDirectory");let o=I.unmarshal(r.node.Data),s;if(o.mtime!=null){let f=Date.now(),l=Math.floor(f/1e3);o.mtime={secs:BigInt(l),nsecs:(f-l*1e3)*1e3},s=o.marshal()}else s=r.node.Data;r.node=P({Data:s,Links:i});let a=T(r.node),c=await oe.digest(a),h=A.create(r.cid.version,q,c);return await t.put(h,a),{node:r.node,cid:h}},jh=async(r,e,t,n)=>{let{path:i,hash:o}=await vn(r.cid,e.Name,t,n),s=i[i.length-1];if(s==null)throw new Error("Invalid HAMT, could not generate path");let a=s.prefix,c=parseInt(a,16);ze("next prefix for %s is %s",e.Name,a);let h=`${a}${e.Name}`,f=s.node.Links.find(l=>(l.Name??"").startsWith(a));if(f!=null)if(ze("link %s was present in shard",h),f.Name===h){if(!n.allowOverwriting)throw new rr;ze("overwriting %s in sub-shard",e.Name),s.node.Links=s.node.Links.filter(l=>l.Name!==h),s.node.Links.push({Name:h,Hash:e.Hash,Tsize:e.Tsize})}else{if(f.Name?.length===2)throw new Error("Existing link was sub-shard?!");{ze("prefix %s already exists, creating new sub-shard",a);let l=s.node.Links.findIndex(x=>x.Name?.startsWith(a)),y=s.node.Links.splice(l,1)[0],u=(y.Name??"").substring(2),m=xn(Dt)(M(u));for(let x=0;x<i.length;x++)await m.take(nt);for(;;){let x=await m.take(nt),g=Sn(x);y.Name=`${g}${u}`;let w=await o.take(nt),_=Sn(w);if(g===_){let B=new Hi.default;B.set(w,!0),i.push({prefix:_,children:B,node:{Links:[]}});continue}let S=new Hi.default;S.set(w,!0),S.set(x,!0),i.push({prefix:a,children:S,node:{Links:[y,{Name:`${_}${e.Name}`,Hash:e.Hash,Tsize:e.Tsize}]}});break}}}else ze("link %s was not present in sub-shard",h),e.Name=h,s.node.Links.push(e),s.children.set(c,!0),ze("adding %s to existing sub-shard",h);return En(i,t,n)};async function qe(r,e,t={}){let n=await Y(r,e,t);if(n.type!=="directory")throw new Ve(`${r.toString()} was not a UnixFS directory`);return{cid:r,node:n.node}}async function zt(r,e,t,n){let i=await Y(r,t,n);if(i.type!=="directory"&&i.type!=="file"&&i.type!=="raw")throw new Ne(`${r.toString()} was not a UnixFS node`);return{Name:e,Tsize:i.node instanceof Uint8Array?i.node.byteLength:qh(i.node),Hash:r}}function qh(r){let e=r.Links.reduce((t,n)=>t+(n.Tsize??0),0);return T(r).byteLength+e}var Gh=R("helia:unixfs:components:utils:resolve");async function Fe(r,e,t,n){if(e==null||e==="")return{cid:r};let i=`/ipfs/${r}${e==null?"":`/${e}`}`,o=await Qo($i(i,t,n));if(o.length===0)throw new Mr("Could not find path in directory");return Gh("resolved %s to %c",e,r),{cid:o[o.length-1].cid,path:e,segments:o}}async function Ft(r,e,t,n){if(e.segments==null||e.segments.length===0)return r;let i=e.segments.pop();if(i==null)throw new Error("Insufficient segments");i.cid=r,e.segments.reverse();for(let o of e.segments){let[s,a]=await Promise.all([qe(o.cid,t,n),zt(i.cid,i.name,t,n)]);r=(await Lt(s,a,t,{...n,allowOverwriting:!0,cidVersion:r.version})).cid,o.cid=r,i=o}return r}async function*pc(r,e,t={}){let n=await Fe(r,t.path,e,t),i=await Y(n.cid,e,t);if(i.type!=="file"&&i.type!=="raw")throw new Or;if(i.content==null)throw new wt;yield*i.content(t)}var Wh=R("helia:unixfs:chmod");async function mc(r,e,t,n={}){let i=await Fe(r,n.path,t,n);if(Wh("chmod %c %d",i.cid,e),n.recursive===!0){let l=await Le(async function*(){for await(let y of mn(i.cid,t,n)){let u,d=[];if(y.type==="raw")u=new I({type:"file",data:y.node});else if(y.type==="file"||y.type==="directory")u=y.unixfs,d=y.node.Links;else throw new Ne;u.mode=e;let m={Data:u.marshal(),Links:d};yield{path:y.path,content:m}}},y=>Ze(y,t,{...n,dagBuilder:async function*(u,d){for await(let m of u)yield async function(){let x=m.content,g=T(x),w=await ve(g,d,{...n,cidVersion:r.version});if(x.Data==null)throw new ee(`${w} had no data`);let _=I.unmarshal(x.Data);return{cid:w,size:BigInt(g.length),path:m.path,unixfs:_}}}}),async y=>_e(y));if(l==null)throw new Te(`Could not chmod ${i.cid.toString()}`);return Ft(l.cid,i,t,n)}let o=await z(t.get(i.cid,n)),s,a=[];if(i.cid.code===Q)s=new I({type:"file",data:o});else{let l=$(o);if(l.Data==null)throw new ee(`${i.cid.toString()} had no data`);a=l.Links,s=I.unmarshal(l.Data)}s.mode=e;let c=T({Data:s.marshal(),Links:a}),h=await oe.digest(c),f=A.create(i.cid.version,q,h);return await t.put(f,c),Ft(f,i,t,n)}var Kh=R("helia:unixfs:cp");async function yc(r,e,t,n,i={}){if(t.includes("/"))throw new H("Name must not have slashes");let[o,s]=await Promise.all([qe(e,n,i),zt(r,t,n,i)]);return Kh('Adding %c as "%s" to %c',r,t,e),(await Lt(o,s,n,{allowOverwriting:i.force,cidVersion:e.version,...i})).cid}async function*gc(r,e,t={}){let n=await Fe(r,t.path,e,t),i=await Y(n.cid,e,{...t,extended:!0});if(i.type==="file"||i.type==="raw"){t.extended===!1?yield{name:i.name,path:i.path,cid:i.cid}:yield i;return}if(i.content==null)throw new wt;if(i.type!=="directory")throw new Ve;yield*i.content(t)}var wc=R("helia:unixfs:mkdir");async function xc(r,e,t,n={}){if(e.includes("/"))throw new H("Path must not have slashes");if((await Y(r,t,n)).type!=="directory")throw new Ve(`${r.toString()} was not a UnixFS directory`);wc("creating %s",e);let s={Data:new I({type:"directory",mode:n.mode,mtime:n.mtime}).marshal(),Links:[]},a=T(s),c=await oe.digest(a),h=A.create(n.cidVersion??1,q,c);await t.put(h,a);let[f,l]=await Promise.all([qe(r,t,n),zt(h,e,t,n)]);return wc("adding empty dir called %s to %c",e,r),(await Lt(f,l,t,{...n,allowOverwriting:n.force})).cid}var In=R("helia:unixfs:utils:remove-link");async function bc(r,e,t,n){if(r.node.Data==null)throw new ee("Parent node had no data");if(I.unmarshal(r.node.Data).type==="hamt-sharded-directory"){In(`removing ${e} from sharded directory`);let o=await Jh(r,e,t,n);return await Bn(o.node,t,n.shardSplitThresholdBytes??262144,n)?o:(In("converting shard to flat directory %c",r.cid),Zh(o,t,n))}return In(`removing link ${e} regular directory`),Xh(r,e,t,n)}var Xh=async(r,e,t,n)=>{r.node.Links=r.node.Links.filter(s=>s.Name!==e);let i=T(r.node),o=await ve(i,t,{...n,cidVersion:r.cid.version});return In(`Updated regular directory ${o}`),{node:r.node,cid:o}},Jh=async(r,e,t,n)=>{let{path:i}=await vn(r.cid,e,t,n),o=i[i.length-1];if(o==null)throw new Error("Invalid HAMT, could not generate path");let s=o.node.Links.filter(h=>(h.Name??"").substring(2)===e).map(h=>h.Name).pop();if(s==null)throw new Error("File not found");let a=s.substring(0,2),c=parseInt(a,16);if(o.node.Links=o.node.Links.filter(h=>h.Name!==s),o.children.unset(c),o.node.Links.length===1)for(;i.length!==1;){let h=i[i.length-1];if(h==null||h.node.Links.length>1)break;i.pop();let f=i[i.length-1];if(f==null)break;let l=h.node.Links[0];f.node.Links=f.node.Links.filter(y=>!(y.Name??"").startsWith(f.prefix)),f.node.Links.push({Hash:l.Hash,Name:`${f.prefix}${(l.Name??"").substring(2)}`,Tsize:l.Tsize})}return En(i,t,n)},Zh=async(r,e,t)=>{if(r.node.Data==null)throw new H("Invalid parent passed to convertToFlatDirectory");let n={Links:[]},i=await Y(r.cid,e);if(i.type!=="directory")throw new Error("Unexpected node type");for await(let c of i.content()){let h=0;c.node instanceof Uint8Array?h=c.node.byteLength:h=T(c.node).length,n.Links.push({Hash:c.cid,Name:c.name,Tsize:h})}let o=I.unmarshal(r.node.Data);n.Data=new I({type:"directory",mode:o.mode,mtime:o.mtime}).marshal();let s=T(P(n));return{cid:await ve(s,e,{codec:V,cidVersion:r.cid.version,signal:t.signal}),node:n}};var Yh=R("helia:unixfs:rm");async function _c(r,e,t,n={}){if(e.includes("/"))throw new H("Name must not have slashes");let i=await qe(r,t,n);return Yh("Removing %s from %c",e,r),(await bc(i,e,t,{...n,cidVersion:r.version})).cid}var ji={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},kc={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},Sc=new globalThis.TextEncoder;function Qh(r,e){let t=ji[e],n=kc[e];for(let i=0;i<r.length;i++)n^=BigInt(r[i]),n=BigInt.asUintN(e,n*t);return n}function ed(r,e,t){if(t.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=ji[e],i=kc[e],o=r;for(;o.length>0;){let s=Sc.encodeInto(o,t);o=o.slice(s.read);for(let a=0;a<s.written;a++)i^=BigInt(t[a]),i=BigInt.asUintN(e,i*n)}return i}function qi(r,{size:e=32,utf8Buffer:t}={}){if(!ji[e])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof r=="string"){if(t)return ed(r,e,t);r=Sc.encode(r)}return Qh(r,e)}var mr={hash:r=>Number(qi(r,{size:32})),hashV:(r,e)=>td(mr.hash(r,e))};function td(r){let e=r.toString(16);return e.length%2===1&&(e=`0${e}`),M(e,"base16")}var Ec=64,Be=class{fp;h;seed;constructor(e,t,n,i=2){if(i>Ec)throw new TypeError("Invalid Fingerprint Size");let o=t.hashV(e,n),s=ge(i);for(let a=0;a<s.length;a++)s[a]=o[a];s.length===0&&(s[0]=7),this.fp=s,this.h=t,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(e){return e?.fp instanceof Uint8Array?Er(this.fp,e.fp):!1}};function it(r,e){return Math.floor(Math.random()*(e-r))+r}var ot=class{contents;constructor(e){this.contents=new Array(e).fill(null)}has(e){if(!(e instanceof Be))throw new TypeError("Invalid Fingerprint");return this.contents.some(t=>e.equals(t))}add(e){if(!(e instanceof Be))throw new TypeError("Invalid Fingerprint");for(let t=0;t<this.contents.length;t++)if(this.contents[t]==null)return this.contents[t]=e,!0;return!0}swap(e){if(!(e instanceof Be))throw new TypeError("Invalid Fingerprint");let t=it(0,this.contents.length-1),n=this.contents[t];return this.contents[t]=e,n}remove(e){if(!(e instanceof Be))throw new TypeError("Invalid Fingerprint");let t=this.contents.findIndex(n=>e.equals(n));return t>-1?(this.contents[t]=null,!0):!1}};var rd=500,yr=class{bucketSize;filterSize;fingerprintSize;buckets;count;hash;seed;constructor(e){this.filterSize=e.filterSize,this.bucketSize=e.bucketSize??4,this.fingerprintSize=e.fingerprintSize??2,this.count=0,this.buckets=[],this.hash=e.hash??mr,this.seed=e.seed??it(0,Math.pow(2,10))}add(e){typeof e=="string"&&(e=M(e));let t=new Be(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,i=(n^t.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new ot(this.bucketSize)),this.buckets[i]==null&&(this.buckets[i]=new ot(this.bucketSize)),this.buckets[n].add(t)||this.buckets[i].add(t))return this.count++,!0;let o=[n,i],s=o[it(0,o.length-1)];this.buckets[s]==null&&(this.buckets[s]=new ot(this.bucketSize));for(let a=0;a<rd;a++){let c=this.buckets[s].swap(t);if(c!=null&&(s=(s^c.hash())%this.filterSize,this.buckets[s]==null&&(this.buckets[s]=new ot(this.bucketSize)),this.buckets[s].add(c)))return this.count++,!0}return!1}has(e){typeof e=="string"&&(e=M(e));let t=new Be(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,i=this.buckets[n]?.has(t)??!1;if(i)return i;let o=(n^t.hash())%this.filterSize;return this.buckets[o]?.has(t)??!1}remove(e){typeof e=="string"&&(e=M(e));let t=new Be(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,i=this.buckets[n]?.remove(t)??!1;if(i)return this.count--,i;let o=(n^t.hash())%this.filterSize,s=this.buckets[o]?.remove(t)??!1;return s&&this.count--,s}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}};var gr=class{filterSize;bucketSize;fingerprintSize;scale;filterSeries;hash;seed;constructor(e){this.bucketSize=e.bucketSize??4,this.filterSize=e.filterSize??(1<<18)/this.bucketSize,this.fingerprintSize=e.fingerprintSize??2,this.scale=e.scale??2,this.hash=e.hash??mr,this.seed=e.seed??it(0,Math.pow(2,10)),this.filterSeries=[new yr({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(e){if(typeof e=="string"&&(e=M(e)),this.has(e))return!0;let t=this.filterSeries.find(n=>n.reliable);if(t==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);t=new yr({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(t)}return t.add(e)}has(e){typeof e=="string"&&(e=M(e));for(let t=0;t<this.filterSeries.length;t++)if(this.filterSeries[t].has(e))return!0;return!1}remove(e){typeof e=="string"&&(e=M(e));for(let t=0;t<this.filterSeries.length;t++)if(this.filterSeries[t].remove(e))return!0;return!1}get count(){return this.filterSeries.reduce((e,t)=>e+t.count,0)}};var vc=1877,An=1604,nd=R("helia:unixfs:stat");async function Bc(r,e,t={}){let n=await Fe(r,t.path,e,t);nd("stat %c",n.cid);let i=await Y(n.cid,e,t);if(i.type==="raw")return t.extended===!0?ad(i):sd(i);if(i.type==="file"||i.type==="directory")return t.extended===!0?od(i,e,t.filter??new gr({filterSize:1024}),t):id(i);throw new Ne}function id(r){return{type:r.type,cid:r.cid,unixfs:r.unixfs,mode:r.unixfs.mode??(r.unixfs.isDirectory()?vc:An),mtime:r.unixfs.mtime,size:r.unixfs.fileSize()}}async function od(r,e,t,n){let i=await Ic(r.cid,e,!1,t,n);return{type:r.type,cid:r.cid,unixfs:r.unixfs,size:r.unixfs.isDirectory()?i.dirSize:r.unixfs.fileSize(),mode:r.unixfs.mode??(r.unixfs.isDirectory()?vc:An),mtime:r.unixfs.mtime,localSize:i.localSize,dagSize:i.dagSize,deduplicatedDagSize:i.deduplicatedDagSize,blocks:i.blocks,uniqueBlocks:i.uniqueBlocks}}function sd(r){return{type:r.type,cid:r.cid,unixfs:void 0,mode:An,mtime:void 0,size:BigInt(r.node.byteLength)}}function ad(r){return{type:r.type,cid:r.cid,unixfs:void 0,mode:An,mtime:void 0,size:BigInt(r.node.byteLength),localSize:BigInt(r.node.byteLength),dagSize:BigInt(r.node.byteLength),deduplicatedDagSize:BigInt(r.node.byteLength),blocks:1n,uniqueBlocks:1n}}async function Ic(r,e,t,n,i){let o={dirSize:0n,localSize:0n,dagSize:0n,deduplicatedDagSize:0n,blocks:0n,uniqueBlocks:0n};try{let s=n.has(r.bytes);n.add(r.bytes);let a=await z(e.get(r,i));if(o.blocks++,o.dagSize+=BigInt(a.byteLength),s||(o.uniqueBlocks++,o.deduplicatedDagSize+=BigInt(a.byteLength)),r.code===Q)o.localSize+=BigInt(a.byteLength),t&&(o.dirSize+=BigInt(a.byteLength));else if(r.code===q){let c=$(a),h;if(c.Data!=null&&(h=I.unmarshal(c.Data)),c.Links.length>0){for(let f of c.Links){let l=await Ic(f.Hash,e,cd(f,h),n,i);o.localSize+=l.localSize,o.dagSize+=l.dagSize,o.deduplicatedDagSize+=l.deduplicatedDagSize,o.blocks+=l.blocks,o.uniqueBlocks+=l.uniqueBlocks,o.dirSize+=l.dirSize}t&&h!=null&&(o.dirSize+=h.fileSize())}else{if(h==null)throw new ee(`PBNode ${r.toString()} had no data`);h.data!=null&&(o.localSize+=BigInt(h.data.byteLength??0)),t&&(o.dirSize+=h.fileSize())}}else throw new Te(`${r.toString()} was neither DAG_PB nor RAW`)}catch(s){if(s.name!=="NotFoundError"&&s.name!=="BlockNotFoundWhileOfflineError"||i.offline!==!0)throw s}return o}function cd(r,e){if(e==null)return!1;let t=r.Name;return t==null?!1:e.type==="directory"?!0:e.type==="hamt-sharded-directory"&&t.length>2}var ud=R("helia:unixfs:touch");async function Ac(r,e,t={}){let n=await Fe(r,t.path,e,t),i=t.mtime??{secs:BigInt(Math.round(Date.now()/1e3)),nsecs:0};if(ud("touch %c %o",n.cid,i),t.recursive){let l=await Le(async function*(){for await(let y of mn(n.cid,e)){let u,d;if(y.type==="raw")u=new I({data:y.node}),d=[];else if(y.type==="file"||y.type==="directory")u=y.unixfs,d=y.node.Links;else throw new Ne;u.mtime=i;let m={Data:u.marshal(),Links:d};yield{path:y.path,content:m}}},y=>Ze(y,e,{...t,dagBuilder:async function*(u,d){for await(let m of u)yield async function(){let x=m.content,g=T(x),w=await ve(g,d,{...t,cidVersion:r.version});if(x.Data==null)throw new ee(`${w} had no data`);let _=I.unmarshal(x.Data);return{cid:w,size:BigInt(g.length),path:m.path,unixfs:_}}}}),async y=>_e(y));if(l==null)throw new Te(`Could not chmod ${n.cid.toString()}`);return Ft(l.cid,n,e,t)}let o=await z(e.get(n.cid,t)),s,a=[];if(n.cid.code===Q)s=new I({data:o});else{let l=$(o);if(a=l.Links,l.Data==null)throw new ee(`${n.cid.toString()} had no data`);s=I.unmarshal(l.Data)}s.mtime=i;let c=T({Data:s.marshal(),Links:a}),h=await oe.digest(c),f=A.create(n.cid.version,q,h);return await e.put(f,c),Ft(f,n,e,t)}var Cn=class{components;constructor(e){this.components=e}async*addAll(e,t={}){yield*Vr(e,this.components.blockstore,t)}async addBytes(e,t={}){return ws(e,this.components.blockstore,t)}async addByteStream(e,t={}){return xs(e,this.components.blockstore,t)}async addFile(e,t={}){return bs(e,this.components.blockstore,t)}async addDirectory(e={},t={}){return _s(e,this.components.blockstore,t)}async*cat(e,t={}){yield*pc(e,this.components.blockstore,t)}async chmod(e,t,n={}){return mc(e,t,this.components.blockstore,n)}async cp(e,t,n,i={}){return yc(e,t,n,this.components.blockstore,i)}async*ls(e,t={}){yield*gc(e,this.components.blockstore,t)}async mkdir(e,t,n={}){return xc(e,t,this.components.blockstore,n)}async rm(e,t,n={}){return _c(e,t,this.components.blockstore,n)}async stat(e,t={}){return Bc(e,this.components.blockstore,t)}async touch(e,t={}){return Ac(e,this.components.blockstore,t)}};async function*Cc(){throw new Error("Not supported in browsers")}function Nc(r,e){return r=new URL(r),{path:decodeURIComponent(new URL(r).pathname.split("/").pop()??""),content:fd(r,e)}}async function*fd(r,e){let t=await globalThis.fetch(r,e);if(t.body==null)throw new Te("HTTP response did not have a body");let n=t.body.getReader();try{for(;;){let{done:i,value:o}=await n.read();if(i)return;o!=null&&(yield o)}}finally{n.releaseLock()}}function ld(r){return new Cn(r)}return Pc(hd);})();
9
13
  return HeliaUnixfs}));
10
14
  //# sourceMappingURL=index.min.js.map