@helia/http 2.0.2-73121c2 → 2.0.2-a7aebd5

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.
Files changed (2) hide show
  1. package/dist/index.min.js +11 -14
  2. package/package.json +5 -5
package/dist/index.min.js CHANGED
@@ -1,21 +1,21 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.HeliaHttp = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var HeliaHttp=(()=>{var Vm=Object.create;var Qo=Object.defineProperty;var Om=Object.getOwnPropertyDescriptor;var $m=Object.getOwnPropertyNames;var Hm=Object.getPrototypeOf,zm=Object.prototype.hasOwnProperty;var Dr=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),gt=(r,t)=>{for(var e in t)Qo(r,e,{get:t[e],enumerable:!0})},lf=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of $m(t))!zm.call(r,o)&&o!==e&&Qo(r,o,{get:()=>t[o],enumerable:!(n=Om(t,o))||n.enumerable});return r};var Fr=(r,t,e)=>(e=r!=null?Vm(Hm(r)):{},lf(t||!r||!r.__esModule?Qo(e,"default",{value:r,enumerable:!0}):e,r)),Km=r=>lf(Qo({},"__esModule",{value:!0}),r);var yh=Dr(In=>{"use strict";var Lw="[object ArrayBuffer]",We=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Lw}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),o=r.toUint8Array(e);if(n.length!==o.byteLength)return!1;for(let s=0;s<n.length;s++)if(n[s]!==o[s])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let o=new Uint8Array(n),s=0;for(let i of e){let a=this.toUint8Array(i);o.set(a,s),s+=a.length}return t[t.length-1]instanceof Function?this.toView(o,t[t.length-1]):o.buffer}},ou="string",Uw=/^[0-9a-f\s]+$/i,Pw=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Rw=/^[a-zA-Z0-9-_]+$/,Rs=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let o=0;o<e.length;o++)n[o]=e.charCodeAt(o);return n.buffer}static toString(t){let e=We.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return decodeURIComponent(escape(n))}},se=class{static toString(t,e=!1){let n=We.toArrayBuffer(t),o=new DataView(n),s="";for(let i=0;i<n.byteLength;i+=2){let a=o.getUint16(i,e);s+=String.fromCharCode(a)}return s}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),o=new DataView(n);for(let s=0;s<t.length;s++)o.setUint16(s*2,t.charCodeAt(s),e);return n}},Ds=class r{static isHex(t){return typeof t===ou&&Uw.test(t)}static isBase64(t){return typeof t===ou&&Pw.test(t)}static isBase64Url(t){return typeof t===ou&&Rw.test(t)}static ToString(t,e="utf8"){let n=We.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return se.toString(n,!0);case"utf16":case"utf16be":return se.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return se.fromString(t,!0);case"utf16":case"utf16be":return se.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=We.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return Rs.fromString(t);case"utf16":case"utf16be":return se.fromString(t);case"utf16le":case"usc2":return se.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return Rs.toString(t);case"utf16":case"utf16be":return se.toString(t);case"utf16le":case"usc2":return se.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let o=0;o<e;o++)n[o]=t.charCodeAt(o);return n.buffer}static ToBinary(t){let e=We.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return n}static ToHex(t){let e=We.toUint8Array(t),n="",o=e.length;for(let s=0;s<o;s++){let i=e[s];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let o=0;o<e.length;o=o+2){let s=e.slice(o,o+2);n[o/2]=parseInt(s,16)}return n.buffer}static ToUtf16String(t,e=!1){return se.toString(t,e)}static FromUtf16String(t,e=!1){return se.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};Ds.DEFAULT_UTF8_ENCODING="utf8";function Dw(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let o=arguments[n];for(let s in o)e[s]=o[s]}return e}function Fw(...r){let t=r.map(o=>o.byteLength).reduce((o,s)=>o+s),e=new Uint8Array(t),n=0;return r.map(o=>new Uint8Array(o)).forEach(o=>{for(let s of o)e[n++]=s}),e.buffer}function Mw(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let o=0;o<r.byteLength;o++)if(e[o]!==n[o])return!1;return!0}In.BufferSourceConverter=We;In.Convert=Ds;In.assign=Dw;In.combine=Fw;In.isEqual=Mw});var Ld=Dr((ko,Li)=>{(function(r,t){"use strict";var e={version:"3.0.0",x86:{},x64:{},inputValidation:!0};function n(h){if(!Array.isArray(h)&&!ArrayBuffer.isView(h))return!1;for(var g=0;g<h.length;g++)if(!Number.isInteger(h[g])||h[g]<0||h[g]>255)return!1;return!0}function o(h,g){return(h&65535)*g+(((h>>>16)*g&65535)<<16)}function s(h,g){return h<<g|h>>>32-g}function i(h){return h^=h>>>16,h=o(h,2246822507),h^=h>>>13,h=o(h,3266489909),h^=h>>>16,h}function a(h,g){h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535],g=[g[0]>>>16,g[0]&65535,g[1]>>>16,g[1]&65535];var p=[0,0,0,0];return p[3]+=h[3]+g[3],p[2]+=p[3]>>>16,p[3]&=65535,p[2]+=h[2]+g[2],p[1]+=p[2]>>>16,p[2]&=65535,p[1]+=h[1]+g[1],p[0]+=p[1]>>>16,p[1]&=65535,p[0]+=h[0]+g[0],p[0]&=65535,[p[0]<<16|p[1],p[2]<<16|p[3]]}function c(h,g){h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535],g=[g[0]>>>16,g[0]&65535,g[1]>>>16,g[1]&65535];var p=[0,0,0,0];return p[3]+=h[3]*g[3],p[2]+=p[3]>>>16,p[3]&=65535,p[2]+=h[2]*g[3],p[1]+=p[2]>>>16,p[2]&=65535,p[2]+=h[3]*g[2],p[1]+=p[2]>>>16,p[2]&=65535,p[1]+=h[1]*g[3],p[0]+=p[1]>>>16,p[1]&=65535,p[1]+=h[2]*g[2],p[0]+=p[1]>>>16,p[1]&=65535,p[1]+=h[3]*g[1],p[0]+=p[1]>>>16,p[1]&=65535,p[0]+=h[0]*g[3]+h[1]*g[2]+h[2]*g[1]+h[3]*g[0],p[0]&=65535,[p[0]<<16|p[1],p[2]<<16|p[3]]}function u(h,g){return g%=64,g===32?[h[1],h[0]]:g<32?[h[0]<<g|h[1]>>>32-g,h[1]<<g|h[0]>>>32-g]:(g-=32,[h[1]<<g|h[0]>>>32-g,h[0]<<g|h[1]>>>32-g])}function f(h,g){return g%=64,g===0?h:g<32?[h[0]<<g|h[1]>>>32-g,h[1]<<g]:[h[1]<<g-32,0]}function l(h,g){return[h[0]^g[0],h[1]^g[1]]}function d(h){return h=l(h,[0,h[0]>>>1]),h=c(h,[4283543511,3981806797]),h=l(h,[0,h[0]>>>1]),h=c(h,[3301882366,444984403]),h=l(h,[0,h[0]>>>1]),h}e.x86.hash32=function(h,g){if(e.inputValidation&&!n(h))return t;g=g||0;for(var p=h.length%4,w=h.length-p,x=g,b=0,y=3432918353,S=461845907,_=0;_<w;_=_+4)b=h[_]|h[_+1]<<8|h[_+2]<<16|h[_+3]<<24,b=o(b,y),b=s(b,15),b=o(b,S),x^=b,x=s(x,13),x=o(x,5)+3864292196;switch(b=0,p){case 3:b^=h[_+2]<<16;case 2:b^=h[_+1]<<8;case 1:b^=h[_],b=o(b,y),b=s(b,15),b=o(b,S),x^=b}return x^=h.length,x=i(x),x>>>0},e.x86.hash128=function(h,g){if(e.inputValidation&&!n(h))return t;g=g||0;for(var p=h.length%16,w=h.length-p,x=g,b=g,y=g,S=g,_=0,N=0,E=0,v=0,k=597399067,O=2869860233,D=951274213,R=2716044179,U=0;U<w;U=U+16)_=h[U]|h[U+1]<<8|h[U+2]<<16|h[U+3]<<24,N=h[U+4]|h[U+5]<<8|h[U+6]<<16|h[U+7]<<24,E=h[U+8]|h[U+9]<<8|h[U+10]<<16|h[U+11]<<24,v=h[U+12]|h[U+13]<<8|h[U+14]<<16|h[U+15]<<24,_=o(_,k),_=s(_,15),_=o(_,O),x^=_,x=s(x,19),x+=b,x=o(x,5)+1444728091,N=o(N,O),N=s(N,16),N=o(N,D),b^=N,b=s(b,17),b+=y,b=o(b,5)+197830471,E=o(E,D),E=s(E,17),E=o(E,R),y^=E,y=s(y,15),y+=S,y=o(y,5)+2530024501,v=o(v,R),v=s(v,18),v=o(v,k),S^=v,S=s(S,13),S+=x,S=o(S,5)+850148119;switch(_=0,N=0,E=0,v=0,p){case 15:v^=h[U+14]<<16;case 14:v^=h[U+13]<<8;case 13:v^=h[U+12],v=o(v,R),v=s(v,18),v=o(v,k),S^=v;case 12:E^=h[U+11]<<24;case 11:E^=h[U+10]<<16;case 10:E^=h[U+9]<<8;case 9:E^=h[U+8],E=o(E,D),E=s(E,17),E=o(E,R),y^=E;case 8:N^=h[U+7]<<24;case 7:N^=h[U+6]<<16;case 6:N^=h[U+5]<<8;case 5:N^=h[U+4],N=o(N,O),N=s(N,16),N=o(N,D),b^=N;case 4:_^=h[U+3]<<24;case 3:_^=h[U+2]<<16;case 2:_^=h[U+1]<<8;case 1:_^=h[U],_=o(_,k),_=s(_,15),_=o(_,O),x^=_}return x^=h.length,b^=h.length,y^=h.length,S^=h.length,x+=b,x+=y,x+=S,b+=x,y+=x,S+=x,x=i(x),b=i(b),y=i(y),S=i(S),x+=b,x+=y,x+=S,b+=x,y+=x,S+=x,("00000000"+(x>>>0).toString(16)).slice(-8)+("00000000"+(b>>>0).toString(16)).slice(-8)+("00000000"+(y>>>0).toString(16)).slice(-8)+("00000000"+(S>>>0).toString(16)).slice(-8)},e.x64.hash128=function(h,g){if(e.inputValidation&&!n(h))return t;g=g||0;for(var p=h.length%16,w=h.length-p,x=[0,g],b=[0,g],y=[0,0],S=[0,0],_=[2277735313,289559509],N=[1291169091,658871167],E=0;E<w;E=E+16)y=[h[E+4]|h[E+5]<<8|h[E+6]<<16|h[E+7]<<24,h[E]|h[E+1]<<8|h[E+2]<<16|h[E+3]<<24],S=[h[E+12]|h[E+13]<<8|h[E+14]<<16|h[E+15]<<24,h[E+8]|h[E+9]<<8|h[E+10]<<16|h[E+11]<<24],y=c(y,_),y=u(y,31),y=c(y,N),x=l(x,y),x=u(x,27),x=a(x,b),x=a(c(x,[0,5]),[0,1390208809]),S=c(S,N),S=u(S,33),S=c(S,_),b=l(b,S),b=u(b,31),b=a(b,x),b=a(c(b,[0,5]),[0,944331445]);switch(y=[0,0],S=[0,0],p){case 15:S=l(S,f([0,h[E+14]],48));case 14:S=l(S,f([0,h[E+13]],40));case 13:S=l(S,f([0,h[E+12]],32));case 12:S=l(S,f([0,h[E+11]],24));case 11:S=l(S,f([0,h[E+10]],16));case 10:S=l(S,f([0,h[E+9]],8));case 9:S=l(S,[0,h[E+8]]),S=c(S,N),S=u(S,33),S=c(S,_),b=l(b,S);case 8:y=l(y,f([0,h[E+7]],56));case 7:y=l(y,f([0,h[E+6]],48));case 6:y=l(y,f([0,h[E+5]],40));case 5:y=l(y,f([0,h[E+4]],32));case 4:y=l(y,f([0,h[E+3]],24));case 3:y=l(y,f([0,h[E+2]],16));case 2:y=l(y,f([0,h[E+1]],8));case 1:y=l(y,[0,h[E]]),y=c(y,_),y=u(y,31),y=c(y,N),x=l(x,y)}return x=l(x,[0,h.length]),b=l(b,[0,h.length]),x=a(x,b),b=a(b,x),x=d(x),b=d(b),x=a(x,b),b=a(b,x),("00000000"+(x[0]>>>0).toString(16)).slice(-8)+("00000000"+(x[1]>>>0).toString(16)).slice(-8)+("00000000"+(b[0]>>>0).toString(16)).slice(-8)+("00000000"+(b[1]>>>0).toString(16)).slice(-8)},typeof ko<"u"?(typeof Li<"u"&&Li.exports&&(ko=Li.exports=e),ko.murmurHash3=e):typeof define=="function"&&define.amd?define([],function(){return e}):(e._murmurHash3=r.murmurHash3,e.noConflict=function(){return r.murmurHash3=e._murmurHash3,e._murmurHash3=t,e.noConflict=t,e},r.murmurHash3=e)})(ko)});var Pd=Dr((LA,Ud)=>{Ud.exports=Ld()});var Hd=Dr((g4,Au)=>{"use strict";var _x=Object.prototype.hasOwnProperty,zt="~";function To(){}Object.create&&(To.prototype=Object.create(null),new To().__proto__||(zt=!1));function Tx(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function $d(r,t,e,n,o){if(typeof e!="function")throw new TypeError("The listener must be a function");var s=new Tx(e,n||r,o),i=zt?zt+t:t;return r._events[i]?r._events[i].fn?r._events[i]=[r._events[i],s]:r._events[i].push(s):(r._events[i]=s,r._eventsCount++),r}function Fi(r,t){--r._eventsCount===0?r._events=new To:delete r._events[t]}function Ft(){this._events=new To,this._eventsCount=0}Ft.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)_x.call(e,n)&&t.push(zt?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};Ft.prototype.listeners=function(t){var e=zt?zt+t:t,n=this._events[e];if(!n)return[];if(n.fn)return[n.fn];for(var o=0,s=n.length,i=new Array(s);o<s;o++)i[o]=n[o].fn;return i};Ft.prototype.listenerCount=function(t){var e=zt?zt+t:t,n=this._events[e];return n?n.fn?1:n.length:0};Ft.prototype.emit=function(t,e,n,o,s,i){var a=zt?zt+t:t;if(!this._events[a])return!1;var c=this._events[a],u=arguments.length,f,l;if(c.fn){switch(c.once&&this.removeListener(t,c.fn,void 0,!0),u){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,e),!0;case 3:return c.fn.call(c.context,e,n),!0;case 4:return c.fn.call(c.context,e,n,o),!0;case 5:return c.fn.call(c.context,e,n,o,s),!0;case 6:return c.fn.call(c.context,e,n,o,s,i),!0}for(l=1,f=new Array(u-1);l<u;l++)f[l-1]=arguments[l];c.fn.apply(c.context,f)}else{var d=c.length,h;for(l=0;l<d;l++)switch(c[l].once&&this.removeListener(t,c[l].fn,void 0,!0),u){case 1:c[l].fn.call(c[l].context);break;case 2:c[l].fn.call(c[l].context,e);break;case 3:c[l].fn.call(c[l].context,e,n);break;case 4:c[l].fn.call(c[l].context,e,n,o);break;default:if(!f)for(h=1,f=new Array(u-1);h<u;h++)f[h-1]=arguments[h];c[l].fn.apply(c[l].context,f)}}return!0};Ft.prototype.on=function(t,e,n){return $d(this,t,e,n,!1)};Ft.prototype.once=function(t,e,n){return $d(this,t,e,n,!0)};Ft.prototype.removeListener=function(t,e,n,o){var s=zt?zt+t:t;if(!this._events[s])return this;if(!e)return Fi(this,s),this;var i=this._events[s];if(i.fn)i.fn===e&&(!o||i.once)&&(!n||i.context===n)&&Fi(this,s);else{for(var a=0,c=[],u=i.length;a<u;a++)(i[a].fn!==e||o&&!i[a].once||n&&i[a].context!==n)&&c.push(i[a]);c.length?this._events[s]=c.length===1?c[0]:c:Fi(this,s)}return this};Ft.prototype.removeAllListeners=function(t){var e;return t?(e=zt?zt+t:t,this._events[e]&&Fi(this,e)):(this._events=new To,this._eventsCount=0),this};Ft.prototype.off=Ft.prototype.removeListener;Ft.prototype.addListener=Ft.prototype.on;Ft.prefixed=zt;Ft.EventEmitter=Ft;typeof Au<"u"&&(Au.exports=Ft)});var Gd=Dr((V4,jd)=>{jd.exports=function(r){if(!r)throw Error("hashlru must have a max value, of type number, greater than 0");var t=0,e=Object.create(null),n=Object.create(null);function o(s,i){e[s]=i,t++,t>=r&&(t=0,n=e,e=Object.create(null))}return{has:function(s){return e[s]!==void 0||n[s]!==void 0},remove:function(s){e[s]!==void 0&&(e[s]=void 0),n[s]!==void 0&&(n[s]=void 0)},get:function(s){var i=e[s];if(i!==void 0)return i;if((i=n[s])!==void 0)return o(s,i),i},set:function(s,i){e[s]!==void 0?e[s]=i:o(s,i)},clear:function(){e=Object.create(null),n=Object.create(null)}}}});var N0=Dr(Ko=>{(function(){var r,t,e,n,o,s,i,a;a=function(c){var u,f,l,d;return u=(c&255<<24)>>>24,f=(c&255<<16)>>>16,l=(c&65280)>>>8,d=c&255,[u,f,l,d].join(".")},i=function(c){var u,f,l,d,h,g;for(u=[],l=d=0;d<=3&&c.length!==0;l=++d){if(l>0){if(c[0]!==".")throw new Error("Invalid IP");c=c.substring(1)}g=t(c),h=g[0],f=g[1],c=c.substring(f),u.push(h)}if(c.length!==0)throw new Error("Invalid IP");switch(u.length){case 1:if(u[0]>4294967295)throw new Error("Invalid IP");return u[0]>>>0;case 2:if(u[0]>255||u[1]>16777215)throw new Error("Invalid IP");return(u[0]<<24|u[1])>>>0;case 3:if(u[0]>255||u[1]>255||u[2]>65535)throw new Error("Invalid IP");return(u[0]<<24|u[1]<<16|u[2])>>>0;case 4:if(u[0]>255||u[1]>255||u[2]>255||u[3]>255)throw new Error("Invalid IP");return(u[0]<<24|u[1]<<16|u[2]<<8|u[3])>>>0;default:throw new Error("Invalid IP")}},e=function(c){return c.charCodeAt(0)},n=e("0"),s=e("a"),o=e("A"),t=function(c){var u,f,l,d,h;for(d=0,u=10,f="9",l=0,c.length>1&&c[l]==="0"&&(c[l+1]==="x"||c[l+1]==="X"?(l+=2,u=16):"0"<=c[l+1]&&c[l+1]<="9"&&(l++,u=8,f="7")),h=l;l<c.length;){if("0"<=c[l]&&c[l]<=f)d=d*u+(e(c[l])-n)>>>0;else if(u===16)if("a"<=c[l]&&c[l]<="f")d=d*u+(10+e(c[l])-s)>>>0;else if("A"<=c[l]&&c[l]<="F")d=d*u+(10+e(c[l])-o)>>>0;else break;else break;if(d>4294967295)throw new Error("too large");l++}if(l===h)throw new Error("empty octet");return[d,l]},r=function(){function c(u,f){var l,d,h,g;if(typeof u!="string")throw new Error("Missing `net' parameter");if(f||(g=u.split("/",2),u=g[0],f=g[1]),f||(f=32),typeof f=="string"&&f.indexOf(".")>-1){try{this.maskLong=i(f)}catch(p){throw l=p,new Error("Invalid mask: "+f)}for(d=h=32;h>=0;d=--h)if(this.maskLong===4294967295<<32-d>>>0){this.bitmask=d;break}}else if(f||f===0)this.bitmask=parseInt(f,10),this.maskLong=0,this.bitmask>0&&(this.maskLong=4294967295<<32-this.bitmask>>>0);else throw new Error("Invalid mask: empty");try{this.netLong=(i(u)&this.maskLong)>>>0}catch(p){throw l=p,new Error("Invalid net address: "+u)}if(!(this.bitmask<=32))throw new Error("Invalid mask for ip4: "+f);this.size=Math.pow(2,32-this.bitmask),this.base=a(this.netLong),this.mask=a(this.maskLong),this.hostmask=a(~this.maskLong),this.first=this.bitmask<=30?a(this.netLong+1):this.base,this.last=this.bitmask<=30?a(this.netLong+this.size-2):a(this.netLong+this.size-1),this.broadcast=this.bitmask<=30?a(this.netLong+this.size-1):void 0}return c.prototype.contains=function(u){return typeof u=="string"&&(u.indexOf("/")>0||u.split(".").length!==4)&&(u=new c(u)),u instanceof c?this.contains(u.base)&&this.contains(u.broadcast||u.last):(i(u)&this.maskLong)>>>0===(this.netLong&this.maskLong)>>>0},c.prototype.next=function(u){return u==null&&(u=1),new c(a(this.netLong+this.size*u),this.mask)},c.prototype.forEach=function(u){var f,l,d;for(d=i(this.first),l=i(this.last),f=0;d<=l;)u(a(d),d,f),f++,d++},c.prototype.toString=function(){return this.base+"/"+this.bitmask},c}(),Ko.ip2long=i,Ko.long2ip=a,Ko.Netmask=r}).call(Ko)});var zl=Dr((x5,Hl)=>{var w5=function(){typeof Hl<"u"&&(Hl.exports=p);var r=86400,t=3200,e=146097*t/400,n=r*e,o=1e3*n,s=864e13,i=4294967296,a=1e6,c="000000000",u=Math.trunc||function(v){var k=v-v%1;return k==0&&(v<0||v===0&&1/v!=1/0)?-0:k},f=p.prototype,l=(p.fromDate=function(v){return new p(+v)},p.fromInt64BE=S(0,1,2,3,0,4),p.fromInt64LE=S(3,2,1,0,4,0),p.fromString=function(D){var k,O=new p,D=(D+="").replace(/^\s*[+\-]?\d+/,function(U){var U=+U,C=1970+(U-1970)%400;return O.year=U-C,C}).replace(/(?:Z|([+\-]\d{2}):?(\d{2}))$/,function(R,U,C){return U<0&&(C*=-1),k=6e4*(60*+U+ +C),""}).replace(/\.\d+$/,function(R){return O.nano=+(R+c).substr(1,9),""}).split(/\D+/);if(1<D.length?D[1]--:D[1]=0,O.time=k=Date.UTC.apply(Date,D)-(k||0),isNaN(k))throw new TypeError("Invalid Date");return w(O)},p.fromTimeT=function(v){return b(v,0)},f.year=0,f.time=0,f.nano=0,f.addNano=function(v){return this.nano+=+v||0,this},f.getNano=function(){var v=w(this);return(v.time%1e3*a+ +v.nano+1e9)%1e9},f.getTimeT=function(){var k=w(this),v=Math.floor(k.time/1e3),k=k.year;return k&&(v+=k*e*r/t),v},f.getYear=function(){return this.toDate().getUTCFullYear()+this.year},f.toDate=function(){return x(w(this).time)},f.toJSON=function(){return this.toString().replace(/0{1,6}Z$/,"Z")},f.toString=function(v){var k=this,O=k.toDate(),D={H:function(){return N(O.getUTCHours())},L:function(){return E(O.getUTCMilliseconds(),3)},M:function(){return N(O.getUTCMinutes())},N:function(){return E(k.getNano(),9)},S:function(){return N(O.getUTCSeconds())},Y:function(){var R=k.getYear();return 999999<R?"+"+R:9999<R?"+"+E(R,6):0<=R?E(R,4):-999999<=R?"-"+E(-R,6):R},a:function(){return h[O.getUTCDay()]},b:function(){return d[O.getUTCMonth()]},d:function(){return N(O.getUTCDate())},e:function(){return function(R){return(9<R?"":" ")+(0|R)}(O.getUTCDate())},m:function(){return N(O.getUTCMonth()+1)}};return function R(U){return U.replace(/%./g,function(C){var B=C[1],L=g[B],B=D[B];return L?R(L):B?B():C})}(v||l)},f.writeInt64BE=y(0,1,2,3,0,4),f.writeInt64LE=y(3,2,1,0,4,0),"%Y-%m-%dT%H:%M:%S.%NZ"),d=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],h=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],g={"%":"%",F:"%Y-%m-%d",n:`
3
- `,R:"%H:%M",T:"%H:%M:%S",t:" ",X:"%T",Z:"GMT",z:"+0000"};return p;function p(v,k,O){var D=this;if(!(D instanceof p))return new p(v,k,O);D.time=+v||0,D.nano=+k||0,D.year=+O||0,w(D)}function w(v){var k,O,D,R=v.year,U=v.time,C=v.nano,L=((C<0||a<=C)&&(C-=(O=Math.floor(C/a))*a,U+=O,O=1),R%t);return(U<-s||s<U||L)&&((k=u(U/o))&&(R+=k*t,U-=k*o),(D=x(U)).setUTCFullYear(L+D.getUTCFullYear()),D=(U=+D)+(k=u((R-=L)/t))*o,k&&-s<=D&&D<=s&&(R-=k*t,U=D),O=1),O&&(v.year=R,v.time=U,v.nano=C),v}function x(v){var k=new Date(0);return k.setTime(v),k}function b(R,D){R=+R||0;var O=u((D=(D|0)*i)/n)+u(R/n),D=D%n+R%n,R=u(D/n);return R&&(O+=R,D-=R*n),new p(1e3*D,0,O*t)}function y(v,k,O,D,R,U){return function(L,B){var T=w(this);L=L||new Array(8),_(L,B|=0);var F=Math.floor(T.time/1e3),T=T.year*(e*r/t),A=u(T/i)+u(F/i),T=T%i+F%i,F=Math.floor(T/i);return F&&(A+=F,T-=F*i),C(L,B+R,A),C(L,B+U,T),L};function C(L,B,A){L[B+v]=A>>24&255,L[B+k]=A>>16&255,L[B+O]=A>>8&255,L[B+D]=255&A}}function S(v,k,O,D,R,U){return function(L,B){_(L,B|=0);var A=C(L,B+R);return b(C(L,B+U),A)};function C(L,B){return 16777216*L[B+v]+(L[B+k]<<16|L[B+O]<<8|L[B+D])}}function _(v,k){if(v=v&&v.length,v==null)throw new TypeError("Invalid Buffer");if(v<k+8)throw new RangeError("Out of range")}function N(v){return(9<v?"":"0")+(0|v)}function E(v,k){return(c+(0|v)).substr(-k)}}()});var y2={};gt(y2,{DEFAULT_SESSION_MAX_PROVIDERS:()=>Ku,DEFAULT_SESSION_MIN_PROVIDERS:()=>zu,InsufficientProvidersError:()=>Vo,NoRoutersAvailableError:()=>Lr,UnknownCodecError:()=>$o,UnknownHashAlgorithmError:()=>Oo,createHeliaHTTP:()=>g2});var Jn=Symbol.for("@libp2p/content-routing");var za=Symbol.for("@libp2p/peer-id");var Xn=Symbol.for("@libp2p/peer-routing");var $e=class extends Error{static name="AbortError";constructor(t="The operation was aborted"){super(t),this.name="AbortError"}};var Et=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},an=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var Ut=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var ts=class extends Error{static name="InvalidCIDError";constructor(t="Invalid CID"){super(t),this.name="InvalidCIDError"}},lr=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var cn=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var ht=(r,...t)=>{try{[...t]}catch{}};var un=class extends EventTarget{#t=new Map;constructor(){super(),ht(1/0,this)}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let o=this.#t.get(t);o==null&&(o=[],this.#t.set(t,o)),o.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let o=this.#t.get(t);o!=null&&(o=o.filter(({callback:s})=>s!==e),this.#t.set(t,o))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:o})=>!o),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new CustomEvent(t,e))}};function ff(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function fr(...r){let t=[];for(let e of r)ff(e)&&t.push(e);await Promise.all(t.map(async e=>{e.beforeStart!=null&&await e.beforeStart()})),await Promise.all(t.map(async e=>{await e.start()})),await Promise.all(t.map(async e=>{e.afterStart!=null&&await e.afterStart()}))}async function hr(...r){let t=[];for(let e of r)ff(e)&&t.push(e);await Promise.all(t.map(async e=>{e.beforeStop!=null&&await e.beforeStop()})),await Promise.all(t.map(async e=>{await e.stop()})),await Promise.all(t.map(async e=>{e.afterStop!=null&&await e.afterStop()}))}function $t(r){let t=new globalThis.AbortController;function e(){t.abort();for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",e)}for(let s of r){if(s?.aborted===!0){e();break}s?.addEventListener!=null&&s.addEventListener("abort",e)}function n(){for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",e)}let o=t.signal;return o.clear=n,o}function At(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var es=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},ln=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new es(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new es(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var Ka=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Mr(r={}){return qm(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function qm(r,t){t=t??{};let e=t.onEnd,n=new ln,o,s,i,a=At(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((w,x)=>{s=b=>{s=null,n.push(b);try{w(r(n))}catch(y){x(y)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=At()})}},u=w=>s!=null?s(w):(n.push(w),o),f=w=>(n=new ln,s!=null?s({error:w}):(n.push({error:w}),o)),l=w=>{if(i)return o;if(t?.objectMode!==!0&&w?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return u({done:!1,value:w})},d=w=>i?o:(i=!0,w!=null?f(w):u({done:!0})),h=()=>(n=new ln,d(),{done:!0}),g=w=>(d(w),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:h,throw:g,push:l,end:d,get readableLength(){return n.size},onEmpty:async w=>{let x=w?.signal;if(x?.throwIfAborted(),n.isEmpty())return;let b,y;x!=null&&(b=new Promise((S,_)=>{y=()=>{_(new Ka)},x.addEventListener("abort",y)}));try{await Promise.race([a.promise,b])}finally{y!=null&&x!=null&&x?.removeEventListener("abort",y)}}},e==null)return o;let p=o;return o={[Symbol.asyncIterator](){return this},next(){return p.next()},throw(w){return p.throw(w),e!=null&&(e(w),e=void 0),{done:!0}},return(){return p.return(),e!=null&&(e(),e=void 0),{done:!0}},push:l,end(w){return p.end(w),e!=null&&(e(w),e=void 0),o},get readableLength(){return p.readableLength},onEmpty:w=>p.onEmpty(w)},o}var qa=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=e??"ABORT_ERR"}};async function rs(r,t,e,n){let o=new qa(n?.errorMessage,n?.errorCode);return e?.aborted===!0?Promise.reject(o):new Promise((s,i)=>{function a(){e?.removeEventListener("abort",f),r.removeEventListener(t,c),n?.errorEvent!=null&&r.removeEventListener(n.errorEvent,u)}let c=l=>{try{if(n?.filter?.(l)===!1)return}catch(d){a(),i(d);return}a(),s(l)},u=l=>{a(),i(l.detail)},f=()=>{a(),i(o)};e?.addEventListener("abort",f),r.addEventListener(t,c),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,u)})}var ns=class extends Error{static name="QueueFullError";constructor(t="The queue was full"){super(t),this.name="QueueFullError"}};var os=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};async function hf(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new os(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new os(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var ss=class{deferred;signal;constructor(t){this.signal=t,this.deferred=At(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new $e)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function jm(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var is=class{id;fn;options;recipients;status;timeline;controller;constructor(t,e){this.id=jm(),this.status="queued",this.fn=t,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,ht(1/0,this.controller.signal),this.onAbort=this.onAbort.bind(this)}abort(t){this.controller.abort(t)}onAbort(){this.recipients.reduce((e,n)=>e&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new $e),this.cleanup())}async join(t={}){let e=new ss(t.signal);return this.recipients.push(e),t.signal?.addEventListener("abort",this.onAbort),e.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let t=await hf(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(e=>{e.deferred.resolve(t)}),this.status="complete"}catch(t){this.recipients.forEach(e=>{e.deferred.reject(t)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(t=>{t.cleanup(),t.signal?.removeEventListener("abort",this.onAbort)})}};var He=class extends un{concurrency;maxSize;queue;pending;sort;constructor(t={}){super(),this.concurrency=t.concurrency??Number.POSITIVE_INFINITY,this.maxSize=t.maxSize??Number.POSITIVE_INFINITY,this.pending=0,t.metricName!=null&&t.metrics?.registerMetricGroup(t.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.sort=t.sort,this.queue=[]}tryToStartAnother(){if(this.size===0)return queueMicrotask(()=>{this.safeDispatchEvent("empty")}),this.running===0&&queueMicrotask(()=>{this.safeDispatchEvent("idle")}),!1;if(this.pending<this.concurrency){let t;for(let e of this.queue)if(e.status==="queued"){t=e;break}return t==null?!1:(this.safeDispatchEvent("active"),this.pending++,t.run().finally(()=>{for(let e=0;e<this.queue.length;e++)if(this.queue[e]===t){this.queue.splice(e,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(t){this.queue.push(t),this.sort!=null&&this.queue.sort(this.sort)}async add(t,e){if(e?.signal?.throwIfAborted(),this.size===this.maxSize)throw new ns;let n=new is(t,e);return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),n.join(e).then(o=>(this.safeDispatchEvent("completed",{detail:o}),this.safeDispatchEvent("success",{detail:{job:n,result:o}}),o)).catch(o=>{if(n.status==="queued"){for(let s=0;s<this.queue.length;s++)if(this.queue[s]===n){this.queue.splice(s,1);break}}throw this.safeDispatchEvent("error",{detail:o}),this.safeDispatchEvent("failure",{detail:{job:n,error:o}}),o})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(t=>{t.abort(new $e)}),this.clear()}async onEmpty(t){this.size!==0&&await rs(this,"empty",t?.signal)}async onSizeLessThan(t,e){this.size<t||await rs(this,"next",e?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await rs(this,"idle",t?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(t){t?.signal?.throwIfAborted();let e=Mr({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),e.end(c)},o=c=>{c.detail!=null&&e.push(c.detail)},s=c=>{n(c.detail)},i=()=>{n()},a=()=>{n(new $e("Queue aborted"))};this.addEventListener("completed",o),this.addEventListener("error",s),this.addEventListener("idle",i),t?.signal?.addEventListener("abort",a);try{yield*e}finally{this.removeEventListener("completed",o),this.removeEventListener("error",s),this.removeEventListener("idle",i),t?.signal?.removeEventListener("abort",a),n()}}};var as=class extends He{has(t){return this.find(t)!=null}find(t){return this.queue.find(e=>t.equals(e.options.peerId))}};function Gm(r){return r[Symbol.asyncIterator]!=null}function Wm(r){if(Gm(r))return(async()=>{for await(let t of r);})();for(let t of r);}var Vr=Wm;function df(r=0){return new Uint8Array(r)}function ue(r=0){return new Uint8Array(r)}var Zm=Math.pow(2,7),Ym=Math.pow(2,14),Jm=Math.pow(2,21),ja=Math.pow(2,28),Ga=Math.pow(2,35),Wa=Math.pow(2,42),Za=Math.pow(2,49),rt=128,Pt=127;function qt(r){if(r<Zm)return 1;if(r<Ym)return 2;if(r<Jm)return 3;if(r<ja)return 4;if(r<Ga)return 5;if(r<Wa)return 6;if(r<Za)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ya(r,t,e=0){switch(qt(r)){case 8:t[e++]=r&255|rt,r/=128;case 7:t[e++]=r&255|rt,r/=128;case 6:t[e++]=r&255|rt,r/=128;case 5:t[e++]=r&255|rt,r/=128;case 4:t[e++]=r&255|rt,r>>>=7;case 3:t[e++]=r&255|rt,r>>>=7;case 2:t[e++]=r&255|rt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Xm(r,t,e=0){switch(qt(r)){case 8:t.set(e++,r&255|rt),r/=128;case 7:t.set(e++,r&255|rt),r/=128;case 6:t.set(e++,r&255|rt),r/=128;case 5:t.set(e++,r&255|rt),r/=128;case 4:t.set(e++,r&255|rt),r>>>=7;case 3:t.set(e++,r&255|rt),r>>>=7;case 2:t.set(e++,r&255|rt),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Ja(r,t){let e=r[t],n=0;if(n+=e&Pt,e<rt||(e=r[t+1],n+=(e&Pt)<<7,e<rt)||(e=r[t+2],n+=(e&Pt)<<14,e<rt)||(e=r[t+3],n+=(e&Pt)<<21,e<rt)||(e=r[t+4],n+=(e&Pt)*ja,e<rt)||(e=r[t+5],n+=(e&Pt)*Ga,e<rt)||(e=r[t+6],n+=(e&Pt)*Wa,e<rt)||(e=r[t+7],n+=(e&Pt)*Za,e<rt))return n;throw new RangeError("Could not decode varint")}function Qm(r,t){let e=r.get(t),n=0;if(n+=e&Pt,e<rt||(e=r.get(t+1),n+=(e&Pt)<<7,e<rt)||(e=r.get(t+2),n+=(e&Pt)<<14,e<rt)||(e=r.get(t+3),n+=(e&Pt)<<21,e<rt)||(e=r.get(t+4),n+=(e&Pt)*ja,e<rt)||(e=r.get(t+5),n+=(e&Pt)*Ga,e<rt)||(e=r.get(t+6),n+=(e&Pt)*Wa,e<rt)||(e=r.get(t+7),n+=(e&Pt)*Za,e<rt))return n;throw new RangeError("Could not decode varint")}function fn(r,t,e=0){return t==null&&(t=ue(qt(r))),t instanceof Uint8Array?Ya(r,t,e):Xm(r,t,e)}function Or(r,t=0){return r instanceof Uint8Array?Ja(r,t):Qm(r,t)}function Jt(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=ue(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}function st(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function tg(r){let[t,e]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>t.next(),push:o=>{n.push(o)},next:()=>n.length>0?{done:!1,value:n.shift()}:t.next(),[e](){return this}}}var hn=tg;function eg(r){return r[Symbol.asyncIterator]!=null}function rg(r,t){let e=0;if(eg(r))return async function*(){for await(let c of r)yield t(c,e++)}();let n=hn(r),{value:o,done:s}=n.next();if(s===!0)return function*(){}();let i=t(o,e++);if(typeof i.then=="function")return async function*(){yield await i;for await(let c of n)yield t(c,e++)}();let a=t;return function*(){yield i;for(let c of n)yield a(c,e++)}()}var dn=rg;function ng(r){return r[Symbol.asyncIterator]!=null}function og(...r){let t=[];for(let e of r)ng(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Mr({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let o of n)e.push(o)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var $r=og;function sg(r){return r[Symbol.asyncIterator]!=null}function ig(r,t){return sg(r)?async function*(){let e=0;if(!(t<1)){for await(let n of r)if(yield n,e++,e===t)return}}():function*(){let e=0;if(!(t<1)){for(let n of r)if(yield n,e++,e===t)return}}()}var cs=ig;var tt=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};var Xa=new Float32Array([-0]),dr=new Uint8Array(Xa.buffer);function mf(r,t,e){Xa[0]=r,t[e]=dr[0],t[e+1]=dr[1],t[e+2]=dr[2],t[e+3]=dr[3]}function gf(r,t){return dr[0]=r[t],dr[1]=r[t+1],dr[2]=r[t+2],dr[3]=r[t+3],Xa[0]}var Qa=new Float64Array([-0]),Rt=new Uint8Array(Qa.buffer);function yf(r,t,e){Qa[0]=r,t[e]=Rt[0],t[e+1]=Rt[1],t[e+2]=Rt[2],t[e+3]=Rt[3],t[e+4]=Rt[4],t[e+5]=Rt[5],t[e+6]=Rt[6],t[e+7]=Rt[7]}function wf(r,t){return Rt[0]=r[t],Rt[1]=r[t+1],Rt[2]=r[t+2],Rt[3]=r[t+3],Rt[4]=r[t+4],Rt[5]=r[t+5],Rt[6]=r[t+6],Rt[7]=r[t+7],Qa[0]}var ag=BigInt(Number.MAX_SAFE_INTEGER),cg=BigInt(Number.MIN_SAFE_INTEGER),Xt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Hr;if(t<ag&&t>cg)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,o=t-(n<<32n);return e&&(n=~n|0n,o=~o|0n,++o>xf&&(o=0n,++n>xf&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Hr;let e=t<0;e&&(t=-t);let n=t>>>0,o=(t-n)/4294967296>>>0;return e&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new r(n,o)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Hr}},Hr=new Xt(0,0);Hr.toBigInt=function(){return 0n};Hr.zzEncode=Hr.zzDecode=function(){return this};Hr.length=function(){return 1};var xf=4294967296n;function bf(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function vf(r,t,e){if(e-t<1)return"";let o,s=[],i=0,a;for(;t<e;)a=r[t++],a<128?s[i++]=a:a>191&&a<224?s[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,s)),i=0);return o!=null?(i>0&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))}function tc(r,t,e){let n=e,o,s;for(let i=0;i<r.length;++i)o=r.charCodeAt(i),o<128?t[e++]=o:o<2048?(t[e++]=o>>6|192,t[e++]=o&63|128):(o&64512)===55296&&((s=r.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,t[e++]=o>>18|240,t[e++]=o>>12&63|128,t[e++]=o>>6&63|128,t[e++]=o&63|128):(t[e++]=o>>12|224,t[e++]=o>>6&63|128,t[e++]=o&63|128);return e-n}function le(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function us(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var ec=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,le(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw le(this,4);return us(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw le(this,4);return us(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw le(this,4);let t=gf(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw le(this,4);let t=wf(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw le(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return vf(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw le(this,t);this.pos+=t}else do if(this.pos>=this.len)throw le(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new Xt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw le(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw le(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw le(this,8);let t=us(this.buf,this.pos+=4),e=us(this.buf,this.pos+=4);return new Xt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Ja(this.buf,this.pos);return this.pos+=qt(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function rc(r){return new ec(r instanceof Uint8Array?r:r.subarray())}function pn(r,t,e){let n=rc(r);return t.decode(n,void 0,e)}var cc={};gt(cc,{base10:()=>pg});var Sv=new Uint8Array(0);function Af(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function fe(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 Sf(r){return new TextEncoder().encode(r)}function Bf(r){return new TextDecoder().decode(r)}function ug(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(e[i]!==255)throw new TypeError(s+" is ambiguous");e[i]=o}var a=r.length,c=r.charAt(0),u=Math.log(a)/Math.log(256),f=Math.log(256)/Math.log(a);function l(g){if(g instanceof Uint8Array||(ArrayBuffer.isView(g)?g=new Uint8Array(g.buffer,g.byteOffset,g.byteLength):Array.isArray(g)&&(g=Uint8Array.from(g))),!(g instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(g.length===0)return"";for(var p=0,w=0,x=0,b=g.length;x!==b&&g[x]===0;)x++,p++;for(var y=(b-x)*f+1>>>0,S=new Uint8Array(y);x!==b;){for(var _=g[x],N=0,E=y-1;(_!==0||N<w)&&E!==-1;E--,N++)_+=256*S[E]>>>0,S[E]=_%a>>>0,_=_/a>>>0;if(_!==0)throw new Error("Non-zero carry");w=N,x++}for(var v=y-w;v!==y&&S[v]===0;)v++;for(var k=c.repeat(p);v<y;++v)k+=r.charAt(S[v]);return k}function d(g){if(typeof g!="string")throw new TypeError("Expected String");if(g.length===0)return new Uint8Array;var p=0;if(g[p]!==" "){for(var w=0,x=0;g[p]===c;)w++,p++;for(var b=(g.length-p)*u+1>>>0,y=new Uint8Array(b);g[p];){var S=e[g.charCodeAt(p)];if(S===255)return;for(var _=0,N=b-1;(S!==0||_<x)&&N!==-1;N--,_++)S+=a*y[N]>>>0,y[N]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");x=_,p++}if(g[p]!==" "){for(var E=b-x;E!==b&&y[E]===0;)E++;for(var v=new Uint8Array(w+(b-E)),k=w;E!==b;)v[k++]=y[E++];return v}}}function h(g){var p=d(g);if(p)return p;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:d,decode:h}}var lg=ug,fg=lg,kf=fg;var oc=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},sc=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let o=e.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return If(this,t)}},ic=class{decoders;constructor(t){this.decoders=t}or(t){return If(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function If(r,t){return new ic({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var ac=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,o){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=o,this.encoder=new oc(t,e,n),this.decoder=new sc(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function mn({name:r,prefix:t,encode:e,decode:n}){return new ac(r,t,e,n)}function pr({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=kf(e,r);return mn({prefix:t,name:r,encode:n,decode:s=>fe(o(s))})}function hg(r,t,e,n){let o={};for(let f=0;f<t.length;++f)o[t[f]]=f;let s=r.length;for(;r[s-1]==="=";)--s;let i=new Uint8Array(s*e/8|0),a=0,c=0,u=0;for(let f=0;f<s;++f){let l=o[r[f]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|l,a+=e,a>=8&&(a-=8,i[u++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function dg(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,s+=t[o&a>>i];if(i!==0&&(s+=t[o&a<<e-i]),n)for(;s.length*e&7;)s+="=";return s}function mt({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return mn({prefix:t,name:r,encode(o){return dg(o,n,e)},decode(o){return hg(o,n,e,r)}})}var pg=pr({prefix:"9",name:"base10",alphabet:"0123456789"});var uc={};gt(uc,{base16:()=>mg,base16upper:()=>gg});var mg=mt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),gg=mt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var lc={};gt(lc,{base2:()=>yg});var yg=mt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var fc={};gt(fc,{base256emoji:()=>Eg});var _f=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}"),wg=_f.reduce((r,t,e)=>(r[e]=t,r),[]),xg=_f.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function bg(r){return r.reduce((t,e)=>(t+=wg[e],t),"")}function vg(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=xg[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var Eg=mn({prefix:"\u{1F680}",name:"base256emoji",encode:bg,decode:vg});var hc={};gt(hc,{base32:()=>_t,base32hex:()=>kg,base32hexpad:()=>_g,base32hexpadupper:()=>Tg,base32hexupper:()=>Ig,base32pad:()=>Sg,base32padupper:()=>Bg,base32upper:()=>Ag,base32z:()=>Cg});var _t=mt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Ag=mt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Sg=mt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Bg=mt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),kg=mt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Ig=mt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),_g=mt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Tg=mt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Cg=mt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var dc={};gt(dc,{base36:()=>Ce,base36upper:()=>Ng});var Ce=pr({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Ng=pr({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var pc={};gt(pc,{base58btc:()=>it,base58flickr:()=>Lg});var it=pr({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Lg=pr({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var gc={};gt(gc,{base64:()=>Ne,base64pad:()=>Ug,base64url:()=>mc,base64urlpad:()=>Pg});var Ne=mt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Ug=mt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),mc=mt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Pg=mt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var yc={};gt(yc,{base8:()=>Rg});var Rg=mt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var wc={};gt(wc,{identity:()=>Dg});var Dg=mn({prefix:"\0",name:"identity",encode:r=>Bf(r),decode:r=>Sf(r)});var ls={};gt(ls,{code:()=>xc,decode:()=>$g,encode:()=>Og,name:()=>Vg});var Fg=new TextEncoder,Mg=new TextDecoder,Vg="json",xc=512;function Og(r){return Fg.encode(JSON.stringify(r))}function $g(r){return JSON.parse(Mg.decode(r))}var to={};gt(to,{code:()=>Qn,decode:()=>Kg,encode:()=>zg,name:()=>Hg});var Hg="raw",Qn=85;function zg(r){return fe(r)}function Kg(r){return fe(r)}var vc={};gt(vc,{identity:()=>jt});var qg=Nf,Tf=128,jg=127,Gg=~jg,Wg=Math.pow(2,31);function Nf(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Wg;)t[e++]=r&255|Tf,r/=128;for(;r&Gg;)t[e++]=r&255|Tf,r>>>=7;return t[e]=r|0,Nf.bytes=e-n+1,t}var Zg=bc,Yg=128,Cf=127;function bc(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw bc.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&Cf)<<o:(i&Cf)*Math.pow(2,o),o+=7}while(i>=Yg);return bc.bytes=s-n,e}var Jg=Math.pow(2,7),Xg=Math.pow(2,14),Qg=Math.pow(2,21),ty=Math.pow(2,28),ey=Math.pow(2,35),ry=Math.pow(2,42),ny=Math.pow(2,49),oy=Math.pow(2,56),sy=Math.pow(2,63),iy=function(r){return r<Jg?1:r<Xg?2:r<Qg?3:r<ty?4:r<ey?5:r<ry?6:r<ny?7:r<oy?8:r<sy?9:10},ay={encode:qg,decode:Zg,encodingLength:iy},cy=ay,eo=cy;function ro(r,t=0){return[eo.decode(r,t),eo.decode.bytes]}function gn(r,t,e=0){return eo.encode(r,t,e),t}function yn(r){return eo.encodingLength(r)}function he(r,t){let e=t.byteLength,n=yn(r),o=n+yn(e),s=new Uint8Array(o+e);return gn(r,s,0),gn(e,s,n),s.set(t,o),new wn(r,e,t,s)}function de(r){let t=fe(r),[e,n]=ro(t),[o,s]=ro(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new wn(e,o,i,t)}function Lf(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Af(r.bytes,e.bytes)}}var wn=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};var Uf=0,uy="identity",Pf=fe;function ly(r){return he(Uf,Pf(r))}var jt={code:Uf,name:uy,encode:Pf,digest:ly};var Sc={};gt(Sc,{sha256:()=>mr,sha512:()=>hs});function Ac({name:r,code:t,encode:e}){return new Ec(r,t,e)}var Ec=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?he(this.code,e):e.then(n=>he(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Df(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var mr=Ac({name:"sha2-256",code:18,encode:Df("SHA-256")}),hs=Ac({name:"sha2-512",code:19,encode:Df("SHA-512")});function Ff(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return hy(e,Bc(r),t??it.encoder);default:return dy(e,Bc(r),t??_t.encoder)}}var Mf=new WeakMap;function Bc(r){let t=Mf.get(r);if(t==null){let e=new Map;return Mf.set(r,e),e}return t}var $=class r{code;version;multihash;bytes;"/";constructor(t,e,n,o){this.code=e,this.version=t,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==no)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==py)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=he(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Lf(t.multihash,n.multihash)}toString(t){return Ff(this,t)}toJSON(){return{"/":Ff(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:o,multihash:s,bytes:i}=e;return new r(n,o,s,i??Vf(n,o,s.bytes))}else if(e[my]===!0){let{version:n,multihash:o,code:s}=e,i=de(o);return r.create(n,s,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==no)throw new Error(`Version 0 CID must use dag-pb (code: ${no}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=Vf(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,no,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,o=fe(t.subarray(n,n+e.multihashSize));if(o.byteLength!==e.multihashSize)throw new Error("Incorrect length");let s=o.subarray(e.multihashSize-e.digestSize),i=new wn(e.multihashCode,e.digestSize,s,o);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[l,d]=ro(t.subarray(e));return e+=d,l},o=n(),s=no;if(o===18?(o=0,e=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=e,a=n(),c=n(),u=e+c,f=u-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:f,size:u}}static parse(t,e){let[n,o]=fy(t,e),s=r.decode(o);if(s.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Bc(s).set(n,t),s}};function fy(r,t){switch(r[0]){case"Q":{let e=t??it;return[it.prefix,e.decode(`${it.prefix}${r}`)]}case it.prefix:{let e=t??it;return[it.prefix,e.decode(r)]}case _t.prefix:{let e=t??_t;return[_t.prefix,e.decode(r)]}case Ce.prefix:{let e=t??Ce;return[Ce.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function hy(r,t,e){let{prefix:n}=e;if(n!==it.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let o=t.get(n);if(o==null){let s=e.encode(r).slice(1);return t.set(n,s),s}else return o}function dy(r,t,e){let{prefix:n}=e,o=t.get(n);if(o==null){let s=e.encode(r);return t.set(n,s),s}else return o}var no=112,py=18;function Vf(r,t,e){let n=yn(r),o=n+yn(t),s=new Uint8Array(o+e.byteLength);return gn(r,s,0),gn(t,s,n),s.set(e,o),s}var my=Symbol.for("@ipld/js-cid/CID");var oo={...wc,...lc,...yc,...cc,...uc,...hc,...dc,...pc,...gc,...fc},aE={...Sc,...vc};function $f(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Of=$f("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),kc=$f("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=ue(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),gy={utf8:Of,"utf-8":Of,hex:oo.base16,latin1:kc,ascii:kc,binary:kc,...oo},ds=gy;function K(r,t="utf8"){let e=ds[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Ic(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return ue(i);o+i>t&&(n=ue(t),o=0);let a=n.subarray(o,o+=i);return o&7&&(o=(o|7)+1),a}}var zr=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function _c(){}var Cc=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},yy=Ic();function wy(r){return globalThis.Buffer!=null?ue(r):yy(r)}var io=class{len;head;tail;states;constructor(){this.len=0,this.head=new zr(_c,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new zr(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Nc((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(ps,10,Xt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Xt.fromBigInt(t);return this._push(ps,e.length(),e)}uint64Number(t){return this._push(Ya,qt(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Xt.fromBigInt(t).zzEncode();return this._push(ps,e.length(),e)}sint64Number(t){let e=Xt.fromNumber(t).zzEncode();return this._push(ps,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Tc,1,t?1:0)}fixed32(t){return this._push(so,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Xt.fromBigInt(t);return this._push(so,4,e.lo)._push(so,4,e.hi)}fixed64Number(t){let e=Xt.fromNumber(t);return this._push(so,4,e.lo)._push(so,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(mf,4,t)}double(t){return this._push(yf,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Tc,1,0):this.uint32(e)._push(by,e,t)}string(t){let e=bf(t);return e!==0?this.uint32(e)._push(tc,e,t):this._push(Tc,1,0)}fork(){return this.states=new Cc(this),this.head=this.tail=new zr(_c,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 zr(_c,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=wy(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Tc(r,t,e){t[e]=r&255}function xy(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Nc=class extends zr{next;constructor(t,e){super(xy,t,e),this.next=void 0}};function ps(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function so(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function by(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(io.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(vy,t,r),this},io.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Ey,t,r),this});function vy(r,t,e){t.set(r,e)}function Ey(r,t,e){r.length<40?tc(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(K(r),e)}function Lc(){return new io}function xn(r,t){let e=Lc();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var bn;(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"})(bn||(bn={}));function ms(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function ao(r){function t(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let e=function(s,i){let a=t(s);i.int32(a)},n=function(s){let i=s.int32();return t(i)};return ms("enum",bn.VARINT,e,n)}function vn(r,t){return ms("message",bn.LENGTH_DELIMITED,r,t)}function Hf(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Ay(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function En(r,...t){if(!Ay(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function zf(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Hf(r.outputLen),Hf(r.blockLen)}function An(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function Kf(r,t){En(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Kr=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var gs=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),pe=(r,t)=>r<<32-t|r>>>t;function qf(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function co(r){return typeof r=="string"&&(r=qf(r)),En(r),r}function Uc(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];En(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let s=r[n];e.set(s,o),o+=s.length}return e}var Sn=class{clone(){return this._cloneInto()}};function ys(r){let t=n=>r().update(co(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function ws(r=32){if(Kr&&typeof Kr.getRandomValues=="function")return Kr.getRandomValues(new Uint8Array(r));if(Kr&&typeof Kr.randomBytes=="function")return Kr.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function Sy(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(e>>o&s),a=Number(e&s),c=n?4:0,u=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+u,a,n)}var jf=(r,t,e)=>r&t^~r&e,Gf=(r,t,e)=>r&t^r&e^t&e,Bn=class extends Sn{constructor(t,e,n,o){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=o,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=gs(this.buffer)}update(t){An(this);let{view:e,buffer:n,blockLen:o}=this;t=co(t);let s=t.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=gs(t);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){An(this),Kf(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)e[l]=0;Sy(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=gs(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=c/4,f=this.get();if(u>f.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<u;l++)a.setUint32(4*l,f[l],s)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return t.length=o,t.pos=a,t.finished=s,t.destroyed=i,o%e&&t.buffer.set(n),t}};var xs=BigInt(4294967295),Pc=BigInt(32);function Wf(r,t=!1){return t?{h:Number(r&xs),l:Number(r>>Pc&xs)}:{h:Number(r>>Pc&xs)|0,l:Number(r&xs)|0}}function By(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let o=0;o<r.length;o++){let{h:s,l:i}=Wf(r[o],t);[e[o],n[o]]=[s,i]}return[e,n]}var ky=(r,t)=>BigInt(r>>>0)<<Pc|BigInt(t>>>0),Iy=(r,t,e)=>r>>>e,_y=(r,t,e)=>r<<32-e|t>>>e,Ty=(r,t,e)=>r>>>e|t<<32-e,Cy=(r,t,e)=>r<<32-e|t>>>e,Ny=(r,t,e)=>r<<64-e|t>>>e-32,Ly=(r,t,e)=>r>>>e-32|t<<64-e,Uy=(r,t)=>t,Py=(r,t)=>r,Ry=(r,t,e)=>r<<e|t>>>32-e,Dy=(r,t,e)=>t<<e|r>>>32-e,Fy=(r,t,e)=>t<<e-32|r>>>64-e,My=(r,t,e)=>r<<e-32|t>>>64-e;function Vy(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var Oy=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),$y=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Hy=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),zy=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,Ky=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),qy=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var jy={fromBig:Wf,split:By,toBig:ky,shrSH:Iy,shrSL:_y,rotrSH:Ty,rotrSL:Cy,rotrBH:Ny,rotrBL:Ly,rotr32H:Uy,rotr32L:Py,rotlSH:Ry,rotlSL:Dy,rotlBH:Fy,rotlBL:My,add:Vy,add3L:Oy,add3H:$y,add4L:Hy,add4H:zy,add5H:qy,add5L:Ky},j=jy;var[Gy,Wy]=j.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),gr=new Uint32Array(80),yr=new Uint32Array(80),Rc=class extends Bn{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:u,El:f,Fh:l,Fl:d,Gh:h,Gl:g,Hh:p,Hl:w}=this;return[t,e,n,o,s,i,a,c,u,f,l,d,h,g,p,w]}set(t,e,n,o,s,i,a,c,u,f,l,d,h,g,p,w){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=o|0,this.Ch=s|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=u|0,this.El=f|0,this.Fh=l|0,this.Fl=d|0,this.Gh=h|0,this.Gl=g|0,this.Hh=p|0,this.Hl=w|0}process(t,e){for(let y=0;y<16;y++,e+=4)gr[y]=t.getUint32(e),yr[y]=t.getUint32(e+=4);for(let y=16;y<80;y++){let S=gr[y-15]|0,_=yr[y-15]|0,N=j.rotrSH(S,_,1)^j.rotrSH(S,_,8)^j.shrSH(S,_,7),E=j.rotrSL(S,_,1)^j.rotrSL(S,_,8)^j.shrSL(S,_,7),v=gr[y-2]|0,k=yr[y-2]|0,O=j.rotrSH(v,k,19)^j.rotrBH(v,k,61)^j.shrSH(v,k,6),D=j.rotrSL(v,k,19)^j.rotrBL(v,k,61)^j.shrSL(v,k,6),R=j.add4L(E,D,yr[y-7],yr[y-16]),U=j.add4H(R,N,O,gr[y-7],gr[y-16]);gr[y]=U|0,yr[y]=R|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:u,Dl:f,Eh:l,El:d,Fh:h,Fl:g,Gh:p,Gl:w,Hh:x,Hl:b}=this;for(let y=0;y<80;y++){let S=j.rotrSH(l,d,14)^j.rotrSH(l,d,18)^j.rotrBH(l,d,41),_=j.rotrSL(l,d,14)^j.rotrSL(l,d,18)^j.rotrBL(l,d,41),N=l&h^~l&p,E=d&g^~d&w,v=j.add5L(b,_,E,Wy[y],yr[y]),k=j.add5H(v,x,S,N,Gy[y],gr[y]),O=v|0,D=j.rotrSH(n,o,28)^j.rotrBH(n,o,34)^j.rotrBH(n,o,39),R=j.rotrSL(n,o,28)^j.rotrBL(n,o,34)^j.rotrBL(n,o,39),U=n&s^n&a^s&a,C=o&i^o&c^i&c;x=p|0,b=w|0,p=h|0,w=g|0,h=l|0,g=d|0,{h:l,l:d}=j.add(u|0,f|0,k|0,O|0),u=a|0,f=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let L=j.add3L(O,R,C);n=j.add3H(L,k,D,U),o=L|0}({h:n,l:o}=j.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=j.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=j.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l:f}=j.add(this.Dh|0,this.Dl|0,u|0,f|0),{h:l,l:d}=j.add(this.Eh|0,this.El|0,l|0,d|0),{h,l:g}=j.add(this.Fh|0,this.Fl|0,h|0,g|0),{h:p,l:w}=j.add(this.Gh|0,this.Gl|0,p|0,w|0),{h:x,l:b}=j.add(this.Hh|0,this.Hl|0,x|0,b|0),this.set(n,o,s,i,a,c,u,f,l,d,h,g,p,w,x,b)}roundClean(){gr.fill(0),yr.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Zf=ys(()=>new Rc);var Es={};gt(Es,{aInRange:()=>Gt,abool:()=>me,abytes:()=>kn,bitGet:()=>tw,bitLen:()=>Vc,bitMask:()=>lo,bitSet:()=>ew,bytesToHex:()=>qe,bytesToNumberBE:()=>je,bytesToNumberLE:()=>xr,concatBytes:()=>Ge,createHmacDrbg:()=>Oc,ensureBytes:()=>dt,equalBytes:()=>Xy,hexToBytes:()=>jr,hexToNumber:()=>Mc,inRange:()=>uo,isBytes:()=>wr,memoized:()=>Wr,notImplemented:()=>nw,numberToBytesBE:()=>br,numberToBytesLE:()=>Gr,numberToHexUnpadded:()=>qr,numberToVarBytesBE:()=>Jy,utf8ToBytes:()=>Qy,validateObject:()=>Le});var bs=BigInt(0),vs=BigInt(1),Zy=BigInt(2);function wr(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function kn(r){if(!wr(r))throw new Error("Uint8Array expected")}function me(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var Yy=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function qe(r){kn(r);let t="";for(let e=0;e<r.length;e++)t+=Yy[r[e]];return t}function qr(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Mc(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?bs:BigInt("0x"+r)}var Ke={_0:48,_9:57,A:65,F:70,a:97,f:102};function Yf(r){if(r>=Ke._0&&r<=Ke._9)return r-Ke._0;if(r>=Ke.A&&r<=Ke.F)return r-(Ke.A-10);if(r>=Ke.a&&r<=Ke.f)return r-(Ke.a-10)}function jr(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let o=0,s=0;o<e;o++,s+=2){let i=Yf(r.charCodeAt(s)),a=Yf(r.charCodeAt(s+1));if(i===void 0||a===void 0){let c=r[s]+r[s+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+s)}n[o]=i*16+a}return n}function je(r){return Mc(qe(r))}function xr(r){return kn(r),Mc(qe(Uint8Array.from(r).reverse()))}function br(r,t){return jr(r.toString(16).padStart(t*2,"0"))}function Gr(r,t){return br(r,t).reverse()}function Jy(r){return jr(qr(r))}function dt(r,t,e){let n;if(typeof t=="string")try{n=jr(t)}catch(s){throw new Error(r+" must be hex string or Uint8Array, cause: "+s)}else if(wr(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let o=n.length;if(typeof e=="number"&&o!==e)throw new Error(r+" of length "+e+" expected, got "+o);return n}function Ge(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];kn(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let s=r[n];e.set(s,o),o+=s.length}return e}function Xy(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function Qy(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var Dc=r=>typeof r=="bigint"&&bs<=r;function uo(r,t,e){return Dc(r)&&Dc(t)&&Dc(e)&&t<=r&&r<e}function Gt(r,t,e,n){if(!uo(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Vc(r){let t;for(t=0;r>bs;r>>=vs,t+=1);return t}function tw(r,t){return r>>BigInt(t)&vs}function ew(r,t,e){return r|(e?vs:bs)<<BigInt(t)}var lo=r=>(Zy<<BigInt(r-1))-vs,Fc=r=>new Uint8Array(r),Jf=r=>Uint8Array.from(r);function Oc(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=Fc(r),o=Fc(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>e(o,n,...l),c=(l=Fc())=>{o=a(Jf([0]),l),n=a(),l.length!==0&&(o=a(Jf([1]),l),n=a())},u=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,d=[];for(;l<t;){n=a();let h=n.slice();d.push(h),l+=n.length}return Ge(...d)};return(l,d)=>{i(),c(l);let h;for(;!(h=d(u()));)c();return i(),h}}var rw={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||wr(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Le(r,t,e={}){let n=(o,s,i)=>{let a=rw[s];if(typeof a!="function")throw new Error("invalid validator function");let c=r[o];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(o)+" is invalid. Expected "+s+", got "+c)};for(let[o,s]of Object.entries(t))n(o,s,!1);for(let[o,s]of Object.entries(e))n(o,s,!0);return r}var nw=()=>{throw new Error("not implemented")};function Wr(r){let t=new WeakMap;return(e,...n)=>{let o=t.get(e);if(o!==void 0)return o;let s=r(e,...n);return t.set(e,s),s}}var wt=BigInt(0),lt=BigInt(1),Zr=BigInt(2),ow=BigInt(3),$c=BigInt(4),Xf=BigInt(5),Qf=BigInt(8),sw=BigInt(9),iw=BigInt(16);function at(r,t){let e=r%t;return e>=wt?e:t+e}function aw(r,t,e){if(t<wt)throw new Error("invalid exponent, negatives unsupported");if(e<=wt)throw new Error("invalid modulus");if(e===lt)return wt;let n=lt;for(;t>wt;)t&lt&&(n=n*r%e),r=r*r%e,t>>=lt;return n}function ft(r,t,e){let n=r;for(;t-- >wt;)n*=n,n%=e;return n}function As(r,t){if(r===wt)throw new Error("invert: expected non-zero number");if(t<=wt)throw new Error("invert: expected positive modulus, got "+t);let e=at(r,t),n=t,o=wt,s=lt,i=lt,a=wt;for(;e!==wt;){let u=n/e,f=n%e,l=o-i*u,d=s-a*u;n=e,e=f,o=i,s=a,i=l,a=d}if(n!==lt)throw new Error("invert: does not exist");return at(o,t)}function cw(r){let t=(r-lt)/Zr,e,n,o;for(e=r-lt,n=0;e%Zr===wt;e/=Zr,n++);for(o=Zr;o<r&&aw(o,t,r)!==r-lt;o++)if(o>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let i=(r+lt)/$c;return function(c,u){let f=c.pow(u,i);if(!c.eql(c.sqr(f),u))throw new Error("Cannot find square root");return f}}let s=(e+lt)/Zr;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let u=n,f=a.pow(a.mul(a.ONE,o),e),l=a.pow(c,s),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let h=1;for(let p=a.sqr(d);h<u&&!a.eql(p,a.ONE);h++)p=a.sqr(p);let g=a.pow(f,lt<<BigInt(u-h-1));f=a.sqr(g),l=a.mul(l,g),d=a.mul(d,f),u=h}return l}}function uw(r){if(r%$c===ow){let t=(r+lt)/$c;return function(n,o){let s=n.pow(o,t);if(!n.eql(n.sqr(s),o))throw new Error("Cannot find square root");return s}}if(r%Qf===Xf){let t=(r-Xf)/Qf;return function(n,o){let s=n.mul(o,Zr),i=n.pow(s,t),a=n.mul(o,i),c=n.mul(n.mul(a,Zr),i),u=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(u),o))throw new Error("Cannot find square root");return u}}return r%iw,cw(r)}var th=(r,t)=>(at(r,t)&lt)===lt,lw=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Hc(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=lw.reduce((n,o)=>(n[o]="function",n),t);return Le(r,e)}function fw(r,t,e){if(e<wt)throw new Error("invalid exponent, negatives unsupported");if(e===wt)return r.ONE;if(e===lt)return t;let n=r.ONE,o=t;for(;e>wt;)e&lt&&(n=r.mul(n,o)),o=r.sqr(o),e>>=lt;return n}function hw(r,t){let e=new Array(t.length),n=t.reduce((s,i,a)=>r.is0(i)?s:(e[a]=s,r.mul(s,i)),r.ONE),o=r.inv(n);return t.reduceRight((s,i,a)=>r.is0(i)?s:(e[a]=r.mul(s,e[a]),r.mul(s,i)),o),e}function zc(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function vr(r,t,e=!1,n={}){if(r<=wt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:o,nByteLength:s}=zc(r,t);if(s>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,BITS:o,BYTES:s,MASK:lo(o),ZERO:wt,ONE:lt,create:c=>at(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return wt<=c&&c<r},is0:c=>c===wt,isOdd:c=>(c&lt)===lt,neg:c=>at(-c,r),eql:(c,u)=>c===u,sqr:c=>at(c*c,r),add:(c,u)=>at(c+u,r),sub:(c,u)=>at(c-u,r),mul:(c,u)=>at(c*u,r),pow:(c,u)=>fw(a,c,u),div:(c,u)=>at(c*As(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>As(c,r),sqrt:n.sqrt||(c=>(i||(i=uw(r)),i(a,c))),invertBatch:c=>hw(a,c),cmov:(c,u,f)=>f?u:c,toBytes:c=>e?Gr(c,s):br(c,s),fromBytes:c=>{if(c.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+c.length);return e?xr(c):je(c)}});return Object.freeze(a)}function eh(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function Kc(r){let t=eh(r);return t+Math.ceil(t/2)}function rh(r,t,e=!1){let n=r.length,o=eh(t),s=Kc(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?je(r):xr(r),a=at(i,t-lt)+lt;return e?Gr(a,o):br(a,o)}var nh=BigInt(0),Ss=BigInt(1);function qc(r,t){let e=t.negate();return r?e:t}function oh(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function jc(r,t){oh(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function pw(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function mw(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var Gc=new WeakMap,sh=new WeakMap;function Wc(r){return sh.get(r)||1}function Bs(r,t){return{constTimeNegate:qc,hasPrecomputes(e){return Wc(e)!==1},unsafeLadder(e,n,o=r.ZERO){let s=e;for(;n>nh;)n&Ss&&(o=o.add(s)),s=s.double(),n>>=Ss;return o},precomputeWindow(e,n){let{windows:o,windowSize:s}=jc(n,t),i=[],a=e,c=a;for(let u=0;u<o;u++){c=a,i.push(c);for(let f=1;f<s;f++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,o){let{windows:s,windowSize:i}=jc(e,t),a=r.ZERO,c=r.BASE,u=BigInt(2**e-1),f=2**e,l=BigInt(e);for(let d=0;d<s;d++){let h=d*i,g=Number(o&u);o>>=l,g>i&&(g-=f,o+=Ss);let p=h,w=h+Math.abs(g)-1,x=d%2!==0,b=g<0;g===0?c=c.add(qc(x,n[p])):a=a.add(qc(b,n[w]))}return{p:a,f:c}},wNAFUnsafe(e,n,o,s=r.ZERO){let{windows:i,windowSize:a}=jc(e,t),c=BigInt(2**e-1),u=2**e,f=BigInt(e);for(let l=0;l<i;l++){let d=l*a;if(o===nh)break;let h=Number(o&c);if(o>>=f,h>a&&(h-=u,o+=Ss),h===0)continue;let g=n[d+Math.abs(h)-1];h<0&&(g=g.negate()),s=s.add(g)}return s},getPrecomputes(e,n,o){let s=Gc.get(n);return s||(s=this.precomputeWindow(n,e),e!==1&&Gc.set(n,o(s))),s},wNAFCached(e,n,o){let s=Wc(e);return this.wNAF(s,this.getPrecomputes(s,e,o),n)},wNAFCachedUnsafe(e,n,o,s){let i=Wc(e);return i===1?this.unsafeLadder(e,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,e,o),n,s)},setWindowSize(e,n){oh(n,t),sh.set(e,n),Gc.delete(e)}}}function ks(r,t,e,n){if(pw(e,r),mw(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let o=r.ZERO,s=Vc(BigInt(e.length)),i=s>12?s-3:s>4?s-2:s?2:1,a=(1<<i)-1,c=new Array(a+1).fill(o),u=Math.floor((t.BITS-1)/i)*i,f=o;for(let l=u;l>=0;l-=i){c.fill(o);for(let h=0;h<n.length;h++){let g=n[h],p=Number(g>>BigInt(l)&BigInt(a));c[p]=c[p].add(e[h])}let d=o;for(let h=c.length-1,g=o;h>0;h--)g=g.add(c[h]),d=d.add(g);if(f=f.add(d),l!==0)for(let h=0;h<i;h++)f=f.double()}return f}function fo(r){return Hc(r.Fp),Le(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...zc(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var ge=BigInt(0),Wt=BigInt(1),Is=BigInt(2),gw=BigInt(8),yw={zip215:!0};function ww(r){let t=fo(r);return Le(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function ih(r){let t=ww(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,u=Is<<BigInt(a*8)-Wt,f=e.create,l=vr(t.n,t.nBitLength),d=t.uvRatio||((B,A)=>{try{return{isValid:!0,value:e.sqrt(B*e.inv(A))}}catch{return{isValid:!1,value:ge}}}),h=t.adjustScalarBytes||(B=>B),g=t.domain||((B,A,T)=>{if(me("phflag",T),A.length||T)throw new Error("Contexts/pre-hash are not supported");return B});function p(B,A){Gt("coordinate "+B,A,ge,u)}function w(B){if(!(B instanceof y))throw new Error("ExtendedPoint expected")}let x=Wr((B,A)=>{let{ex:T,ey:F,ez:H}=B,z=B.is0();A==null&&(A=z?gw:e.inv(H));let W=f(T*A),Y=f(F*A),q=f(H*A);if(z)return{x:ge,y:Wt};if(q!==Wt)throw new Error("invZ was invalid");return{x:W,y:Y}}),b=Wr(B=>{let{a:A,d:T}=t;if(B.is0())throw new Error("bad point: ZERO");let{ex:F,ey:H,ez:z,et:W}=B,Y=f(F*F),q=f(H*H),ot=f(z*z),ut=f(ot*ot),bt=f(Y*A),vt=f(ot*f(bt+q)),It=f(ut+f(T*f(Y*q)));if(vt!==It)throw new Error("bad point: equation left != right (1)");let Lt=f(F*H),Kt=f(z*W);if(Lt!==Kt)throw new Error("bad point: equation left != right (2)");return!0});class y{constructor(A,T,F,H){this.ex=A,this.ey=T,this.ez=F,this.et=H,p("x",A),p("y",T),p("z",F),p("t",H),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(A){if(A instanceof y)throw new Error("extended point not allowed");let{x:T,y:F}=A||{};return p("x",T),p("y",F),new y(T,F,Wt,f(T*F))}static normalizeZ(A){let T=e.invertBatch(A.map(F=>F.ez));return A.map((F,H)=>F.toAffine(T[H])).map(y.fromAffine)}static msm(A,T){return ks(y,l,A,T)}_setWindowSize(A){N.setWindowSize(this,A)}assertValidity(){b(this)}equals(A){w(A);let{ex:T,ey:F,ez:H}=this,{ex:z,ey:W,ez:Y}=A,q=f(T*Y),ot=f(z*H),ut=f(F*Y),bt=f(W*H);return q===ot&&ut===bt}is0(){return this.equals(y.ZERO)}negate(){return new y(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:A}=t,{ex:T,ey:F,ez:H}=this,z=f(T*T),W=f(F*F),Y=f(Is*f(H*H)),q=f(A*z),ot=T+F,ut=f(f(ot*ot)-z-W),bt=q+W,vt=bt-Y,It=q-W,Lt=f(ut*vt),Kt=f(bt*It),Ot=f(ut*It),Te=f(vt*bt);return new y(Lt,Kt,Te,Ot)}add(A){w(A);let{a:T,d:F}=t,{ex:H,ey:z,ez:W,et:Y}=this,{ex:q,ey:ot,ez:ut,et:bt}=A;if(T===BigInt(-1)){let rf=f((z-H)*(ot+q)),nf=f((z+H)*(ot-q)),Ha=f(nf-rf);if(Ha===ge)return this.double();let of=f(W*Is*bt),sf=f(Y*Is*ut),af=sf+of,cf=nf+rf,uf=sf-of,Rm=f(af*Ha),Dm=f(cf*uf),Fm=f(af*uf),Mm=f(Ha*cf);return new y(Rm,Dm,Mm,Fm)}let vt=f(H*q),It=f(z*ot),Lt=f(Y*F*bt),Kt=f(W*ut),Ot=f((H+z)*(q+ot)-vt-It),Te=Kt-Lt,Oe=Kt+Lt,Yn=f(It-T*vt),Nm=f(Ot*Te),Lm=f(Oe*Yn),Um=f(Ot*Yn),Pm=f(Te*Oe);return new y(Nm,Lm,Pm,Um)}subtract(A){return this.add(A.negate())}wNAF(A){return N.wNAFCached(this,A,y.normalizeZ)}multiply(A){let T=A;Gt("scalar",T,Wt,n);let{p:F,f:H}=this.wNAF(T);return y.normalizeZ([F,H])[0]}multiplyUnsafe(A,T=y.ZERO){let F=A;return Gt("scalar",F,ge,n),F===ge?_:this.is0()||F===Wt?this:N.wNAFCachedUnsafe(this,F,y.normalizeZ,T)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return N.unsafeLadder(this,n).is0()}toAffine(A){return x(this,A)}clearCofactor(){let{h:A}=t;return A===Wt?this:this.multiplyUnsafe(A)}static fromHex(A,T=!1){let{d:F,a:H}=t,z=e.BYTES;A=dt("pointHex",A,z),me("zip215",T);let W=A.slice(),Y=A[z-1];W[z-1]=Y&-129;let q=xr(W),ot=T?u:e.ORDER;Gt("pointHex.y",q,ge,ot);let ut=f(q*q),bt=f(ut-Wt),vt=f(F*ut-H),{isValid:It,value:Lt}=d(bt,vt);if(!It)throw new Error("Point.fromHex: invalid y coordinate");let Kt=(Lt&Wt)===Wt,Ot=(Y&128)!==0;if(!T&&Lt===ge&&Ot)throw new Error("Point.fromHex: x=0 and x_0=1");return Ot!==Kt&&(Lt=f(-Lt)),y.fromAffine({x:Lt,y:q})}static fromPrivateKey(A){return k(A).point}toRawBytes(){let{x:A,y:T}=this.toAffine(),F=Gr(T,e.BYTES);return F[F.length-1]|=A&Wt?128:0,F}toHex(){return qe(this.toRawBytes())}}y.BASE=new y(t.Gx,t.Gy,Wt,f(t.Gx*t.Gy)),y.ZERO=new y(ge,Wt,Wt,ge);let{BASE:S,ZERO:_}=y,N=Bs(y,a*8);function E(B){return at(B,n)}function v(B){return E(xr(B))}function k(B){let A=e.BYTES;B=dt("private key",B,A);let T=dt("hashed private key",s(B),2*A),F=h(T.slice(0,A)),H=T.slice(A,2*A),z=v(F),W=S.multiply(z),Y=W.toRawBytes();return{head:F,prefix:H,scalar:z,point:W,pointBytes:Y}}function O(B){return k(B).pointBytes}function D(B=new Uint8Array,...A){let T=Ge(...A);return v(s(g(T,dt("context",B),!!o)))}function R(B,A,T={}){B=dt("message",B),o&&(B=o(B));let{prefix:F,scalar:H,pointBytes:z}=k(A),W=D(T.context,F,B),Y=S.multiply(W).toRawBytes(),q=D(T.context,Y,z,B),ot=E(W+q*H);Gt("signature.s",ot,ge,n);let ut=Ge(Y,Gr(ot,e.BYTES));return dt("result",ut,e.BYTES*2)}let U=yw;function C(B,A,T,F=U){let{context:H,zip215:z}=F,W=e.BYTES;B=dt("signature",B,2*W),A=dt("message",A),T=dt("publicKey",T,W),z!==void 0&&me("zip215",z),o&&(A=o(A));let Y=xr(B.slice(W,2*W)),q,ot,ut;try{q=y.fromHex(T,z),ot=y.fromHex(B.slice(0,W),z),ut=S.multiplyUnsafe(Y)}catch{return!1}if(!z&&q.isSmallOrder())return!1;let bt=D(H,ot.toRawBytes(),q.toRawBytes(),A);return ot.add(q.multiplyUnsafe(bt)).subtract(ut).clearCofactor().equals(y.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:O,sign:R,verify:C,ExtendedPoint:y,utils:{getExtendedPublicKey:k,randomPrivateKey:()=>i(e.BYTES),precompute(B=8,A=y.BASE){return A._setWindowSize(B),A.multiply(BigInt(3)),A}}}}var Zc=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ah=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),u8=BigInt(0),xw=BigInt(1),ch=BigInt(2),l8=BigInt(3),bw=BigInt(5),vw=BigInt(8);function Ew(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=Zc,a=r*r%s*r%s,c=ft(a,ch,s)*a%s,u=ft(c,xw,s)*r%s,f=ft(u,bw,s)*u%s,l=ft(f,t,s)*f%s,d=ft(l,e,s)*l%s,h=ft(d,n,s)*d%s,g=ft(h,o,s)*h%s,p=ft(g,o,s)*h%s,w=ft(p,t,s)*f%s;return{pow_p_5_8:ft(w,ch,s)*r%s,b2:a}}function Aw(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Sw(r,t){let e=Zc,n=at(t*t*t,e),o=at(n*n*t,e),s=Ew(r*o).pow_p_5_8,i=at(r*n*s,e),a=at(t*i*i,e),c=i,u=at(i*ah,e),f=a===r,l=a===at(-r,e),d=a===at(-r*ah,e);return f&&(i=c),(l||d)&&(i=u),th(i,e)&&(i=at(-i,e)),{isValid:f||l,value:i}}var Bw=vr(Zc,void 0,!0),kw={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Bw,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:vw,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Zf,randomBytes:ws,adjustScalarBytes:Aw,uvRatio:Sw},uh=ih(kw);var _s=32;function lh(r,t,e){return uh.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var Ts=class{type="Ed25519";raw;constructor(t){this.raw=Yc(t,_s)}toMultihash(){return jt.digest(Cs(this))}toCID(){return $.createV1(114,this.toMultihash())}toString(){return it.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:st(this.raw,t.raw)}verify(t,e){return lh(this.raw,e,t)}};function Jc(r){return r=Yc(r,_s),new Ts(r)}function Yc(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new Et(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var xt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(xt||(xt={}));var Xc;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(Xc||(Xc={}));(function(r){r.codec=()=>ao(Xc)})(xt||(xt={}));var Ue;(function(r){let t;r.codec=()=>(t==null&&(t=vn((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),xt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.Type=xt.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>xn(e,r.codec()),r.decode=(e,n)=>pn(e,r.codec(),n)})(Ue||(Ue={}));var Qc;(function(r){let t;r.codec=()=>(t==null&&(t=vn((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),xt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.Type=xt.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>xn(e,r.codec()),r.decode=(e,n)=>pn(e,r.codec(),n)})(Qc||(Qc={}));var Eo={};gt(Eo,{MAX_RSA_KEY_SIZE:()=>Bi,generateRSAKeyPair:()=>hd,jwkToJWKKeyPair:()=>dd,jwkToPkcs1:()=>jw,jwkToPkix:()=>fu,jwkToRSAPrivateKey:()=>fd,pkcs1ToJwk:()=>cd,pkcs1ToRSAPrivateKey:()=>ld,pkixToJwk:()=>ud,pkixToRSAPublicKey:()=>hu});function _w(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function tu(r,...t){if(!_w(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function eu(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function dh(r,t){tu(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Ls=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),ye=(r,t)=>r<<32-t|r>>>t;function Tw(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function ru(r){return typeof r=="string"&&(r=Tw(r)),tu(r),r}var Ns=class{clone(){return this._cloneInto()}};function ph(r){let t=n=>r().update(ru(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Cw(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(e>>o&s),a=Number(e&s),c=n?4:0,u=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+u,a,n)}var mh=(r,t,e)=>r&t^~r&e,gh=(r,t,e)=>r&t^r&e^t&e,Us=class extends Ns{constructor(t,e,n,o){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=o,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Ls(this.buffer)}update(t){eu(this);let{view:e,buffer:n,blockLen:o}=this;t=ru(t);let s=t.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=Ls(t);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){eu(this),dh(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)e[l]=0;Cw(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=Ls(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=c/4,f=this.get();if(u>f.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<u;l++)a.setUint32(4*l,f[l],s)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return t.length=o,t.pos=a,t.finished=s,t.destroyed=i,o%e&&t.buffer.set(n),t}};var Nw=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Er=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Ar=new Uint32Array(64),nu=class extends Us{constructor(){super(64,32,8,!1),this.A=Er[0]|0,this.B=Er[1]|0,this.C=Er[2]|0,this.D=Er[3]|0,this.E=Er[4]|0,this.F=Er[5]|0,this.G=Er[6]|0,this.H=Er[7]|0}get(){let{A:t,B:e,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[t,e,n,o,s,i,a,c]}set(t,e,n,o,s,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let l=0;l<16;l++,e+=4)Ar[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let d=Ar[l-15],h=Ar[l-2],g=ye(d,7)^ye(d,18)^d>>>3,p=ye(h,17)^ye(h,19)^h>>>10;Ar[l]=p+Ar[l-7]+g+Ar[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:u,H:f}=this;for(let l=0;l<64;l++){let d=ye(a,6)^ye(a,11)^ye(a,25),h=f+d+mh(a,c,u)+Nw[l]+Ar[l]|0,p=(ye(n,2)^ye(n,13)^ye(n,22))+gh(n,o,s)|0;f=u,u=c,c=a,a=i+h|0,i=s,s=o,o=n,n=h+p|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,f=f+this.H|0,this.set(n,o,s,i,a,c,u,f)}roundClean(){Ar.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Ps=ph(()=>new nu);var Z=Fr(yh());function Yr(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function Sr(r,t,e=-1){let n=e,o=r,s=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),s=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),s=n}let u=new Uint8Array(c);for(let f=a-1;f>=0;f--){let l=Math.pow(2,f*t);u[s-f-1]=Math.floor(o/l),o-=u[s-f-1]*l}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Fs(...r){let t=0,e=0;for(let s of r)t+=s.length;let n=new ArrayBuffer(t),o=new Uint8Array(n);for(let s of r)o.set(s,e),e+=s.length;return o}function su(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=Yr(e,8),o=new ArrayBuffer(this.valueHex.byteLength),s=new Uint8Array(o);for(let a=0;a<this.valueHex.byteLength;a++)s[a]=r[a];return s[0]&=127,Yr(s,8)-n}function wh(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=Sr(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=Sr(t,8,n),s=new Uint8Array(o);if(s[0]&128){let i=o.slice(0),a=new Uint8Array(i);o=new ArrayBuffer(o.byteLength+1),s=new Uint8Array(o);for(let c=0;c<i.byteLength;c++)s[c+1]=a[c];s[0]=0}return o}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function xh(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let o=0;o<e.length;o++)if(e[o]!==n[o])return!1;return!0}function Zt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,o=new Array(n);for(let i=0;i<n;i++)o[i]="0";return o.join("").concat(e)}var V8=Math.log(2);function Ms(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function iu(r){let t=0,e=0;for(let o=0;o<r.length;o++){let s=r[o];t+=s.byteLength}let n=new Uint8Array(t);for(let o=0;o<r.length;o++){let s=r[o];n.set(new Uint8Array(s),e),e+=s.byteLength}return n.buffer}function Xe(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var po=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return iu(this.items)}},ho=[new Uint8Array([1])],bh="0123456789";var Nn="",we=new ArrayBuffer(0),au=new Uint8Array(0),mo="EndOfContent",Eh="OCTET STRING",Ah="BIT STRING";function Qe(r){var t;return t=class extends r{constructor(...n){var o;super(...n);let s=n[0]||{};this.isHexOnly=(o=s.isHexOnly)!==null&&o!==void 0?o:!1,this.valueHexView=s.valueHex?Z.BufferSourceConverter.toUint8Array(s.valueHex):au}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,o,s){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Xe(this,i,o,s))return-1;let a=o+s;return this.valueHexView=i.subarray(o,a),this.valueHexView.length?(this.blockLength=s,a):(this.warnings.push("Zero buffer length"),o)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",we)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Z.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var Ze=class{constructor({blockLength:t=0,error:e=Nn,warnings:n=[],valueBeforeDecode:o=au}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=Z.BufferSourceConverter.toUint8Array(o)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:Z.Convert.ToHex(this.valueBeforeDecodeView)}}};Ze.NAME="baseBlock";var Dt=class extends Ze{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};Dt.NAME="valueBlock";var Vs=class extends Qe(Ze){constructor({idBlock:t={}}={}){var e,n,o,s;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?Z.BufferSourceConverter.toUint8Array(t.valueHex):au,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(o=t.tagNumber)!==null&&o!==void 0?o:-1,this.isConstructed=(s=t.isConstructed)!==null&&s!==void 0?s:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",we}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let o=new Uint8Array(1);if(!t){let s=this.tagNumber;s&=31,e|=s,o[0]=e}return o.buffer}if(!this.isHexOnly){let o=Sr(this.tagNumber,7),s=new Uint8Array(o),i=o.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=s[c]|128;a[i]=s[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let o=this.valueHexView;for(let s=0;s<o.length-1;s++)n[s+1]=o[s]|128;n[this.valueHexView.byteLength]=o[o.length-1]}return n.buffer}fromBER(t,e,n){let o=Z.BufferSourceConverter.toUint8Array(t);if(!Xe(this,o,e,n))return-1;let s=o.subarray(e,e+n);if(s.length===0)return this.error="Zero buffer length",-1;switch(s[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(s[0]&32)===32,this.isHexOnly=!1;let a=s[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,u=this.valueHexView=new Uint8Array(255),f=255;for(;s[c]&128;){if(u[c-1]=s[c]&127,c++,c>=s.length)return this.error="End of input reached before message was fully decoded",-1;if(c===f){f+=255;let d=new Uint8Array(f);for(let h=0;h<u.length;h++)d[h]=u[h];u=this.valueHexView=new Uint8Array(f)}}this.blockLength=c+1,u[c-1]=s[c]&127;let l=new Uint8Array(c);for(let d=0;d<c;d++)l[d]=u[d];u=this.valueHexView=new Uint8Array(c),u.set(l),this.blockLength<=9?this.tagNumber=Yr(u,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};Vs.NAME="identificationBlock";var Os=class extends Ze{constructor({lenBlock:t={}}={}){var e,n,o;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(o=t.length)!==null&&o!==void 0?o:0}fromBER(t,e,n){let o=Z.BufferSourceConverter.toUint8Array(t);if(!Xe(this,o,e,n))return-1;let s=o.subarray(e,e+n);if(s.length===0)return this.error="Zero buffer length",-1;if(s[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=s[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(s[0]&128),this.longFormUsed===!1)return this.length=s[0],this.blockLength=1,e+this.blockLength;let i=s[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>s.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=o.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Yr(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let o=Sr(this.length,8);if(o.byteLength>127)return this.error="Too big length",we;if(e=new ArrayBuffer(o.byteLength+1),t)return e;let s=new Uint8Array(o);n=new Uint8Array(e),n[0]=o.byteLength|128;for(let i=0;i<o.byteLength;i++)n[i+1]=s[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Os.NAME="lengthBlock";var M={},Tt=class extends Ze{constructor({name:t=Nn,optional:e=!1,primitiveSchema:n,...o}={},s){super(o),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Vs(o),this.lenBlock=new Os(o),this.valueBlock=s?new s(o):new Dt(o)}fromBER(t,e,n){let o=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return o===-1?(this.error=this.valueBlock.error,o):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),o)}toBER(t,e){let n=e||new po;e||Sh(this);let o=this.idBlock.toBER(t);if(n.write(o),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let s=this.valueBlock.toBER(t);this.lenBlock.length=s.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(s)}return e?we:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():Z.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${Z.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return xh(e,n)}};Tt.NAME="BaseBlock";function Sh(r){if(r instanceof M.Constructed)for(let t of r.valueBlock.value)Sh(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var $s=class extends Tt{constructor({value:t=Nn,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let o=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return o===-1?(this.error=this.valueBlock.error,o):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),o)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};$s.NAME="BaseStringBlock";var Hs=class extends Qe(Dt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Hs.NAME="PrimitiveValueBlock";var Bh,zs=class extends Tt{constructor(t={}){super(t,Hs),this.idBlock.isConstructed=!1}};Bh=zs;M.Primitive=Bh;zs.NAME="PRIMITIVE";function Ow(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function Ai(r,t=0,e=r.length){let n=t,o=new Tt({},Dt),s=new Ze;if(!Xe(s,r,t,e))return o.error=s.error,{offset:-1,result:o};if(!r.subarray(t,t+e).length)return o.error="Zero buffer length",{offset:-1,result:o};let a=o.idBlock.fromBER(r,t,e);if(o.idBlock.warnings.length&&o.warnings.concat(o.idBlock.warnings),a===-1)return o.error=o.idBlock.error,{offset:-1,result:o};if(t=a,e-=o.idBlock.blockLength,a=o.lenBlock.fromBER(r,t,e),o.lenBlock.warnings.length&&o.warnings.concat(o.lenBlock.warnings),a===-1)return o.error=o.lenBlock.error,{offset:-1,result:o};if(t=a,e-=o.lenBlock.blockLength,!o.idBlock.isConstructed&&o.lenBlock.isIndefiniteForm)return o.error="Indefinite length form used for primitive encoding form",{offset:-1,result:o};let c=Tt;switch(o.idBlock.tagClass){case 1:if(o.idBlock.tagNumber>=37&&o.idBlock.isHexOnly===!1)return o.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:o};switch(o.idBlock.tagNumber){case 0:if(o.idBlock.isConstructed&&o.lenBlock.length>0)return o.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:o};c=M.EndOfContent;break;case 1:c=M.Boolean;break;case 2:c=M.Integer;break;case 3:c=M.BitString;break;case 4:c=M.OctetString;break;case 5:c=M.Null;break;case 6:c=M.ObjectIdentifier;break;case 10:c=M.Enumerated;break;case 12:c=M.Utf8String;break;case 13:c=M.RelativeObjectIdentifier;break;case 14:c=M.TIME;break;case 15:return o.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:o};case 16:c=M.Sequence;break;case 17:c=M.Set;break;case 18:c=M.NumericString;break;case 19:c=M.PrintableString;break;case 20:c=M.TeletexString;break;case 21:c=M.VideotexString;break;case 22:c=M.IA5String;break;case 23:c=M.UTCTime;break;case 24:c=M.GeneralizedTime;break;case 25:c=M.GraphicString;break;case 26:c=M.VisibleString;break;case 27:c=M.GeneralString;break;case 28:c=M.UniversalString;break;case 29:c=M.CharacterString;break;case 30:c=M.BmpString;break;case 31:c=M.DATE;break;case 32:c=M.TimeOfDay;break;case 33:c=M.DateTime;break;case 34:c=M.Duration;break;default:{let u=o.idBlock.isConstructed?new M.Constructed:new M.Primitive;u.idBlock=o.idBlock,u.lenBlock=o.lenBlock,u.warnings=o.warnings,o=u}}break;case 2:case 3:case 4:default:c=o.idBlock.isConstructed?M.Constructed:M.Primitive}return o=Ow(o,c),a=o.fromBER(r,t,o.lenBlock.isIndefiniteForm?e:o.lenBlock.length),o.valueBeforeDecodeView=r.subarray(n,n+o.blockLength),{offset:a,result:o}}function cu(r){if(!r.byteLength){let t=new Tt({},Dt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Ai(Z.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function $w(r,t){return r?1:t}var Pe=class extends Dt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let o=Z.BufferSourceConverter.toUint8Array(t);if(!Xe(this,o,e,n))return-1;if(this.valueBeforeDecodeView=o.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let s=e;for(;$w(this.isIndefiniteForm,n)>0;){let i=Ai(o,s,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(s=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===mo)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===mo?this.value.pop():this.warnings.push("No EndOfContent block encoded")),s}toBER(t,e){let n=e||new po;for(let o=0;o<this.value.length;o++)this.value[o].toBER(t,n);return e?we:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Pe.NAME="ConstructedValueBlock";var kh,Br=class extends Tt{constructor(t={}){super(t,Pe),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let o=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return o===-1?(this.error=this.valueBlock.error,o):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),o)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
2
+ "use strict";var HeliaHttp=(()=>{var km=Object.create;var Jo=Object.defineProperty;var Im=Object.getOwnPropertyDescriptor;var _m=Object.getOwnPropertyNames;var Tm=Object.getPrototypeOf,Cm=Object.prototype.hasOwnProperty;var Pr=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),gt=(r,t)=>{for(var e in t)Jo(r,e,{get:t[e],enumerable:!0})},ef=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of _m(t))!Cm.call(r,o)&&o!==e&&Jo(r,o,{get:()=>t[o],enumerable:!(n=Im(t,o))||n.enumerable});return r};var Rr=(r,t,e)=>(e=r!=null?km(Tm(r)):{},ef(t||!r||!r.__esModule?Jo(e,"default",{value:r,enumerable:!0}):e,r)),Nm=r=>ef(Jo({},"__esModule",{value:!0}),r);var sh=Pr(Bn=>{"use strict";var gw="[object ArrayBuffer]",Ge=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===gw}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),o=r.toUint8Array(e);if(n.length!==o.byteLength)return!1;for(let s=0;s<n.length;s++)if(n[s]!==o[s])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let o=new Uint8Array(n),s=0;for(let i of e){let a=this.toUint8Array(i);o.set(a,s),s+=a.length}return t[t.length-1]instanceof Function?this.toView(o,t[t.length-1]):o.buffer}},Yc="string",yw=/^[0-9a-f\s]+$/i,ww=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,xw=/^[a-zA-Z0-9-_]+$/,Ts=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let o=0;o<e.length;o++)n[o]=e.charCodeAt(o);return n.buffer}static toString(t){let e=Ge.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return decodeURIComponent(escape(n))}},se=class{static toString(t,e=!1){let n=Ge.toArrayBuffer(t),o=new DataView(n),s="";for(let i=0;i<n.byteLength;i+=2){let a=o.getUint16(i,e);s+=String.fromCharCode(a)}return s}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),o=new DataView(n);for(let s=0;s<t.length;s++)o.setUint16(s*2,t.charCodeAt(s),e);return n}},Cs=class r{static isHex(t){return typeof t===Yc&&yw.test(t)}static isBase64(t){return typeof t===Yc&&ww.test(t)}static isBase64Url(t){return typeof t===Yc&&xw.test(t)}static ToString(t,e="utf8"){let n=Ge.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return se.toString(n,!0);case"utf16":case"utf16be":return se.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return se.fromString(t,!0);case"utf16":case"utf16be":return se.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Ge.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return Ts.fromString(t);case"utf16":case"utf16be":return se.fromString(t);case"utf16le":case"usc2":return se.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return Ts.toString(t);case"utf16":case"utf16be":return se.toString(t);case"utf16le":case"usc2":return se.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let o=0;o<e;o++)n[o]=t.charCodeAt(o);return n.buffer}static ToBinary(t){let e=Ge.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return n}static ToHex(t){let e=Ge.toUint8Array(t),n="",o=e.length;for(let s=0;s<o;s++){let i=e[s];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let o=0;o<e.length;o=o+2){let s=e.slice(o,o+2);n[o/2]=parseInt(s,16)}return n.buffer}static ToUtf16String(t,e=!1){return se.toString(t,e)}static FromUtf16String(t,e=!1){return se.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};Cs.DEFAULT_UTF8_ENCODING="utf8";function bw(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let o=arguments[n];for(let s in o)e[s]=o[s]}return e}function vw(...r){let t=r.map(o=>o.byteLength).reduce((o,s)=>o+s),e=new Uint8Array(t),n=0;return r.map(o=>new Uint8Array(o)).forEach(o=>{for(let s of o)e[n++]=s}),e.buffer}function Ew(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let o=0;o<r.byteLength;o++)if(e[o]!==n[o])return!1;return!0}Bn.BufferSourceConverter=Ge;Bn.Convert=Cs;Bn.assign=bw;Bn.combine=vw;Bn.isEqual=Ew});var xd=Pr((So,ki)=>{(function(r,t){"use strict";var e={version:"3.0.0",x86:{},x64:{},inputValidation:!0};function n(h){if(!Array.isArray(h)&&!ArrayBuffer.isView(h))return!1;for(var g=0;g<h.length;g++)if(!Number.isInteger(h[g])||h[g]<0||h[g]>255)return!1;return!0}function o(h,g){return(h&65535)*g+(((h>>>16)*g&65535)<<16)}function s(h,g){return h<<g|h>>>32-g}function i(h){return h^=h>>>16,h=o(h,2246822507),h^=h>>>13,h=o(h,3266489909),h^=h>>>16,h}function a(h,g){h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535],g=[g[0]>>>16,g[0]&65535,g[1]>>>16,g[1]&65535];var m=[0,0,0,0];return m[3]+=h[3]+g[3],m[2]+=m[3]>>>16,m[3]&=65535,m[2]+=h[2]+g[2],m[1]+=m[2]>>>16,m[2]&=65535,m[1]+=h[1]+g[1],m[0]+=m[1]>>>16,m[1]&=65535,m[0]+=h[0]+g[0],m[0]&=65535,[m[0]<<16|m[1],m[2]<<16|m[3]]}function c(h,g){h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535],g=[g[0]>>>16,g[0]&65535,g[1]>>>16,g[1]&65535];var m=[0,0,0,0];return m[3]+=h[3]*g[3],m[2]+=m[3]>>>16,m[3]&=65535,m[2]+=h[2]*g[3],m[1]+=m[2]>>>16,m[2]&=65535,m[2]+=h[3]*g[2],m[1]+=m[2]>>>16,m[2]&=65535,m[1]+=h[1]*g[3],m[0]+=m[1]>>>16,m[1]&=65535,m[1]+=h[2]*g[2],m[0]+=m[1]>>>16,m[1]&=65535,m[1]+=h[3]*g[1],m[0]+=m[1]>>>16,m[1]&=65535,m[0]+=h[0]*g[3]+h[1]*g[2]+h[2]*g[1]+h[3]*g[0],m[0]&=65535,[m[0]<<16|m[1],m[2]<<16|m[3]]}function u(h,g){return g%=64,g===32?[h[1],h[0]]:g<32?[h[0]<<g|h[1]>>>32-g,h[1]<<g|h[0]>>>32-g]:(g-=32,[h[1]<<g|h[0]>>>32-g,h[0]<<g|h[1]>>>32-g])}function l(h,g){return g%=64,g===0?h:g<32?[h[0]<<g|h[1]>>>32-g,h[1]<<g]:[h[1]<<g-32,0]}function f(h,g){return[h[0]^g[0],h[1]^g[1]]}function d(h){return h=f(h,[0,h[0]>>>1]),h=c(h,[4283543511,3981806797]),h=f(h,[0,h[0]>>>1]),h=c(h,[3301882366,444984403]),h=f(h,[0,h[0]>>>1]),h}e.x86.hash32=function(h,g){if(e.inputValidation&&!n(h))return t;g=g||0;for(var m=h.length%4,w=h.length-m,x=g,b=0,y=3432918353,S=461845907,_=0;_<w;_=_+4)b=h[_]|h[_+1]<<8|h[_+2]<<16|h[_+3]<<24,b=o(b,y),b=s(b,15),b=o(b,S),x^=b,x=s(x,13),x=o(x,5)+3864292196;switch(b=0,m){case 3:b^=h[_+2]<<16;case 2:b^=h[_+1]<<8;case 1:b^=h[_],b=o(b,y),b=s(b,15),b=o(b,S),x^=b}return x^=h.length,x=i(x),x>>>0},e.x86.hash128=function(h,g){if(e.inputValidation&&!n(h))return t;g=g||0;for(var m=h.length%16,w=h.length-m,x=g,b=g,y=g,S=g,_=0,N=0,E=0,v=0,k=597399067,O=2869860233,D=951274213,U=2716044179,P=0;P<w;P=P+16)_=h[P]|h[P+1]<<8|h[P+2]<<16|h[P+3]<<24,N=h[P+4]|h[P+5]<<8|h[P+6]<<16|h[P+7]<<24,E=h[P+8]|h[P+9]<<8|h[P+10]<<16|h[P+11]<<24,v=h[P+12]|h[P+13]<<8|h[P+14]<<16|h[P+15]<<24,_=o(_,k),_=s(_,15),_=o(_,O),x^=_,x=s(x,19),x+=b,x=o(x,5)+1444728091,N=o(N,O),N=s(N,16),N=o(N,D),b^=N,b=s(b,17),b+=y,b=o(b,5)+197830471,E=o(E,D),E=s(E,17),E=o(E,U),y^=E,y=s(y,15),y+=S,y=o(y,5)+2530024501,v=o(v,U),v=s(v,18),v=o(v,k),S^=v,S=s(S,13),S+=x,S=o(S,5)+850148119;switch(_=0,N=0,E=0,v=0,m){case 15:v^=h[P+14]<<16;case 14:v^=h[P+13]<<8;case 13:v^=h[P+12],v=o(v,U),v=s(v,18),v=o(v,k),S^=v;case 12:E^=h[P+11]<<24;case 11:E^=h[P+10]<<16;case 10:E^=h[P+9]<<8;case 9:E^=h[P+8],E=o(E,D),E=s(E,17),E=o(E,U),y^=E;case 8:N^=h[P+7]<<24;case 7:N^=h[P+6]<<16;case 6:N^=h[P+5]<<8;case 5:N^=h[P+4],N=o(N,O),N=s(N,16),N=o(N,D),b^=N;case 4:_^=h[P+3]<<24;case 3:_^=h[P+2]<<16;case 2:_^=h[P+1]<<8;case 1:_^=h[P],_=o(_,k),_=s(_,15),_=o(_,O),x^=_}return x^=h.length,b^=h.length,y^=h.length,S^=h.length,x+=b,x+=y,x+=S,b+=x,y+=x,S+=x,x=i(x),b=i(b),y=i(y),S=i(S),x+=b,x+=y,x+=S,b+=x,y+=x,S+=x,("00000000"+(x>>>0).toString(16)).slice(-8)+("00000000"+(b>>>0).toString(16)).slice(-8)+("00000000"+(y>>>0).toString(16)).slice(-8)+("00000000"+(S>>>0).toString(16)).slice(-8)},e.x64.hash128=function(h,g){if(e.inputValidation&&!n(h))return t;g=g||0;for(var m=h.length%16,w=h.length-m,x=[0,g],b=[0,g],y=[0,0],S=[0,0],_=[2277735313,289559509],N=[1291169091,658871167],E=0;E<w;E=E+16)y=[h[E+4]|h[E+5]<<8|h[E+6]<<16|h[E+7]<<24,h[E]|h[E+1]<<8|h[E+2]<<16|h[E+3]<<24],S=[h[E+12]|h[E+13]<<8|h[E+14]<<16|h[E+15]<<24,h[E+8]|h[E+9]<<8|h[E+10]<<16|h[E+11]<<24],y=c(y,_),y=u(y,31),y=c(y,N),x=f(x,y),x=u(x,27),x=a(x,b),x=a(c(x,[0,5]),[0,1390208809]),S=c(S,N),S=u(S,33),S=c(S,_),b=f(b,S),b=u(b,31),b=a(b,x),b=a(c(b,[0,5]),[0,944331445]);switch(y=[0,0],S=[0,0],m){case 15:S=f(S,l([0,h[E+14]],48));case 14:S=f(S,l([0,h[E+13]],40));case 13:S=f(S,l([0,h[E+12]],32));case 12:S=f(S,l([0,h[E+11]],24));case 11:S=f(S,l([0,h[E+10]],16));case 10:S=f(S,l([0,h[E+9]],8));case 9:S=f(S,[0,h[E+8]]),S=c(S,N),S=u(S,33),S=c(S,_),b=f(b,S);case 8:y=f(y,l([0,h[E+7]],56));case 7:y=f(y,l([0,h[E+6]],48));case 6:y=f(y,l([0,h[E+5]],40));case 5:y=f(y,l([0,h[E+4]],32));case 4:y=f(y,l([0,h[E+3]],24));case 3:y=f(y,l([0,h[E+2]],16));case 2:y=f(y,l([0,h[E+1]],8));case 1:y=f(y,[0,h[E]]),y=c(y,_),y=u(y,31),y=c(y,N),x=f(x,y)}return x=f(x,[0,h.length]),b=f(b,[0,h.length]),x=a(x,b),b=a(b,x),x=d(x),b=d(b),x=a(x,b),b=a(b,x),("00000000"+(x[0]>>>0).toString(16)).slice(-8)+("00000000"+(x[1]>>>0).toString(16)).slice(-8)+("00000000"+(b[0]>>>0).toString(16)).slice(-8)+("00000000"+(b[1]>>>0).toString(16)).slice(-8)},typeof So<"u"?(typeof ki<"u"&&ki.exports&&(So=ki.exports=e),So.murmurHash3=e):typeof define=="function"&&define.amd?define([],function(){return e}):(e._murmurHash3=r.murmurHash3,e.noConflict=function(){return r.murmurHash3=e._murmurHash3,e._murmurHash3=t,e.noConflict=t,e},r.murmurHash3=e)})(So)});var vd=Pr((sA,bd)=>{bd.exports=xd()});var Td=Pr((zA,mu)=>{"use strict";var fx=Object.prototype.hasOwnProperty,zt="~";function Io(){}Object.create&&(Io.prototype=Object.create(null),new Io().__proto__||(zt=!1));function hx(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function _d(r,t,e,n,o){if(typeof e!="function")throw new TypeError("The listener must be a function");var s=new hx(e,n||r,o),i=zt?zt+t:t;return r._events[i]?r._events[i].fn?r._events[i]=[r._events[i],s]:r._events[i].push(s):(r._events[i]=s,r._eventsCount++),r}function Ni(r,t){--r._eventsCount===0?r._events=new Io:delete r._events[t]}function Ft(){this._events=new Io,this._eventsCount=0}Ft.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)fx.call(e,n)&&t.push(zt?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};Ft.prototype.listeners=function(t){var e=zt?zt+t:t,n=this._events[e];if(!n)return[];if(n.fn)return[n.fn];for(var o=0,s=n.length,i=new Array(s);o<s;o++)i[o]=n[o].fn;return i};Ft.prototype.listenerCount=function(t){var e=zt?zt+t:t,n=this._events[e];return n?n.fn?1:n.length:0};Ft.prototype.emit=function(t,e,n,o,s,i){var a=zt?zt+t:t;if(!this._events[a])return!1;var c=this._events[a],u=arguments.length,l,f;if(c.fn){switch(c.once&&this.removeListener(t,c.fn,void 0,!0),u){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,e),!0;case 3:return c.fn.call(c.context,e,n),!0;case 4:return c.fn.call(c.context,e,n,o),!0;case 5:return c.fn.call(c.context,e,n,o,s),!0;case 6:return c.fn.call(c.context,e,n,o,s,i),!0}for(f=1,l=new Array(u-1);f<u;f++)l[f-1]=arguments[f];c.fn.apply(c.context,l)}else{var d=c.length,h;for(f=0;f<d;f++)switch(c[f].once&&this.removeListener(t,c[f].fn,void 0,!0),u){case 1:c[f].fn.call(c[f].context);break;case 2:c[f].fn.call(c[f].context,e);break;case 3:c[f].fn.call(c[f].context,e,n);break;case 4:c[f].fn.call(c[f].context,e,n,o);break;default:if(!l)for(h=1,l=new Array(u-1);h<u;h++)l[h-1]=arguments[h];c[f].fn.apply(c[f].context,l)}}return!0};Ft.prototype.on=function(t,e,n){return _d(this,t,e,n,!1)};Ft.prototype.once=function(t,e,n){return _d(this,t,e,n,!0)};Ft.prototype.removeListener=function(t,e,n,o){var s=zt?zt+t:t;if(!this._events[s])return this;if(!e)return Ni(this,s),this;var i=this._events[s];if(i.fn)i.fn===e&&(!o||i.once)&&(!n||i.context===n)&&Ni(this,s);else{for(var a=0,c=[],u=i.length;a<u;a++)(i[a].fn!==e||o&&!i[a].once||n&&i[a].context!==n)&&c.push(i[a]);c.length?this._events[s]=c.length===1?c[0]:c:Ni(this,s)}return this};Ft.prototype.removeAllListeners=function(t){var e;return t?(e=zt?zt+t:t,this._events[e]&&Ni(this,e)):(this._events=new Io,this._eventsCount=0),this};Ft.prototype.off=Ft.prototype.removeListener;Ft.prototype.addListener=Ft.prototype.on;Ft.prefixed=zt;Ft.EventEmitter=Ft;typeof mu<"u"&&(mu.exports=Ft)});var Rd=Pr((hS,Pd)=>{Pd.exports=function(r){if(!r)throw Error("hashlru must have a max value, of type number, greater than 0");var t=0,e=Object.create(null),n=Object.create(null);function o(s,i){e[s]=i,t++,t>=r&&(t=0,n=e,e=Object.create(null))}return{has:function(s){return e[s]!==void 0||n[s]!==void 0},remove:function(s){e[s]!==void 0&&(e[s]=void 0),n[s]!==void 0&&(n[s]=void 0)},get:function(s){var i=e[s];if(i!==void 0)return i;if((i=n[s])!==void 0)return o(s,i),i},set:function(s,i){e[s]!==void 0?e[s]=i:o(s,i)},clear:function(){e=Object.create(null),n=Object.create(null)}}}});var w0=Pr(Ho=>{(function(){var r,t,e,n,o,s,i,a;a=function(c){var u,l,f,d;return u=(c&255<<24)>>>24,l=(c&255<<16)>>>16,f=(c&65280)>>>8,d=c&255,[u,l,f,d].join(".")},i=function(c){var u,l,f,d,h,g;for(u=[],f=d=0;d<=3&&c.length!==0;f=++d){if(f>0){if(c[0]!==".")throw new Error("Invalid IP");c=c.substring(1)}g=t(c),h=g[0],l=g[1],c=c.substring(l),u.push(h)}if(c.length!==0)throw new Error("Invalid IP");switch(u.length){case 1:if(u[0]>4294967295)throw new Error("Invalid IP");return u[0]>>>0;case 2:if(u[0]>255||u[1]>16777215)throw new Error("Invalid IP");return(u[0]<<24|u[1])>>>0;case 3:if(u[0]>255||u[1]>255||u[2]>65535)throw new Error("Invalid IP");return(u[0]<<24|u[1]<<16|u[2])>>>0;case 4:if(u[0]>255||u[1]>255||u[2]>255||u[3]>255)throw new Error("Invalid IP");return(u[0]<<24|u[1]<<16|u[2]<<8|u[3])>>>0;default:throw new Error("Invalid IP")}},e=function(c){return c.charCodeAt(0)},n=e("0"),s=e("a"),o=e("A"),t=function(c){var u,l,f,d,h;for(d=0,u=10,l="9",f=0,c.length>1&&c[f]==="0"&&(c[f+1]==="x"||c[f+1]==="X"?(f+=2,u=16):"0"<=c[f+1]&&c[f+1]<="9"&&(f++,u=8,l="7")),h=f;f<c.length;){if("0"<=c[f]&&c[f]<=l)d=d*u+(e(c[f])-n)>>>0;else if(u===16)if("a"<=c[f]&&c[f]<="f")d=d*u+(10+e(c[f])-s)>>>0;else if("A"<=c[f]&&c[f]<="F")d=d*u+(10+e(c[f])-o)>>>0;else break;else break;if(d>4294967295)throw new Error("too large");f++}if(f===h)throw new Error("empty octet");return[d,f]},r=function(){function c(u,l){var f,d,h,g;if(typeof u!="string")throw new Error("Missing `net' parameter");if(l||(g=u.split("/",2),u=g[0],l=g[1]),l||(l=32),typeof l=="string"&&l.indexOf(".")>-1){try{this.maskLong=i(l)}catch(m){throw f=m,new Error("Invalid mask: "+l)}for(d=h=32;h>=0;d=--h)if(this.maskLong===4294967295<<32-d>>>0){this.bitmask=d;break}}else if(l||l===0)this.bitmask=parseInt(l,10),this.maskLong=0,this.bitmask>0&&(this.maskLong=4294967295<<32-this.bitmask>>>0);else throw new Error("Invalid mask: empty");try{this.netLong=(i(u)&this.maskLong)>>>0}catch(m){throw f=m,new Error("Invalid net address: "+u)}if(!(this.bitmask<=32))throw new Error("Invalid mask for ip4: "+l);this.size=Math.pow(2,32-this.bitmask),this.base=a(this.netLong),this.mask=a(this.maskLong),this.hostmask=a(~this.maskLong),this.first=this.bitmask<=30?a(this.netLong+1):this.base,this.last=this.bitmask<=30?a(this.netLong+this.size-2):a(this.netLong+this.size-1),this.broadcast=this.bitmask<=30?a(this.netLong+this.size-1):void 0}return c.prototype.contains=function(u){return typeof u=="string"&&(u.indexOf("/")>0||u.split(".").length!==4)&&(u=new c(u)),u instanceof c?this.contains(u.base)&&this.contains(u.broadcast||u.last):(i(u)&this.maskLong)>>>0===(this.netLong&this.maskLong)>>>0},c.prototype.next=function(u){return u==null&&(u=1),new c(a(this.netLong+this.size*u),this.mask)},c.prototype.forEach=function(u){var l,f,d;for(d=i(this.first),f=i(this.last),l=0;d<=f;)u(a(d),d,l),l++,d++},c.prototype.toString=function(){return this.base+"/"+this.bitmask},c}(),Ho.ip2long=i,Ho.long2ip=a,Ho.Netmask=r}).call(Ho)});var Ul=Pr((jI,Rl)=>{var qI=function(){typeof Rl<"u"&&(Rl.exports=m);var r=86400,t=3200,e=146097*t/400,n=r*e,o=1e3*n,s=864e13,i=4294967296,a=1e6,c="000000000",u=Math.trunc||function(v){var k=v-v%1;return k==0&&(v<0||v===0&&1/v!=1/0)?-0:k},l=m.prototype,f=(m.fromDate=function(v){return new m(+v)},m.fromInt64BE=S(0,1,2,3,0,4),m.fromInt64LE=S(3,2,1,0,4,0),m.fromString=function(D){var k,O=new m,D=(D+="").replace(/^\s*[+\-]?\d+/,function(P){var P=+P,C=1970+(P-1970)%400;return O.year=P-C,C}).replace(/(?:Z|([+\-]\d{2}):?(\d{2}))$/,function(U,P,C){return P<0&&(C*=-1),k=6e4*(60*+P+ +C),""}).replace(/\.\d+$/,function(U){return O.nano=+(U+c).substr(1,9),""}).split(/\D+/);if(1<D.length?D[1]--:D[1]=0,O.time=k=Date.UTC.apply(Date,D)-(k||0),isNaN(k))throw new TypeError("Invalid Date");return w(O)},m.fromTimeT=function(v){return b(v,0)},l.year=0,l.time=0,l.nano=0,l.addNano=function(v){return this.nano+=+v||0,this},l.getNano=function(){var v=w(this);return(v.time%1e3*a+ +v.nano+1e9)%1e9},l.getTimeT=function(){var k=w(this),v=Math.floor(k.time/1e3),k=k.year;return k&&(v+=k*e*r/t),v},l.getYear=function(){return this.toDate().getUTCFullYear()+this.year},l.toDate=function(){return x(w(this).time)},l.toJSON=function(){return this.toString().replace(/0{1,6}Z$/,"Z")},l.toString=function(v){var k=this,O=k.toDate(),D={H:function(){return N(O.getUTCHours())},L:function(){return E(O.getUTCMilliseconds(),3)},M:function(){return N(O.getUTCMinutes())},N:function(){return E(k.getNano(),9)},S:function(){return N(O.getUTCSeconds())},Y:function(){var U=k.getYear();return 999999<U?"+"+U:9999<U?"+"+E(U,6):0<=U?E(U,4):-999999<=U?"-"+E(-U,6):U},a:function(){return h[O.getUTCDay()]},b:function(){return d[O.getUTCMonth()]},d:function(){return N(O.getUTCDate())},e:function(){return function(U){return(9<U?"":" ")+(0|U)}(O.getUTCDate())},m:function(){return N(O.getUTCMonth()+1)}};return function U(P){return P.replace(/%./g,function(C){var B=C[1],L=g[B],B=D[B];return L?U(L):B?B():C})}(v||f)},l.writeInt64BE=y(0,1,2,3,0,4),l.writeInt64LE=y(3,2,1,0,4,0),"%Y-%m-%dT%H:%M:%S.%NZ"),d=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],h=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],g={"%":"%",F:"%Y-%m-%d",n:`
3
+ `,R:"%H:%M",T:"%H:%M:%S",t:" ",X:"%T",Z:"GMT",z:"+0000"};return m;function m(v,k,O){var D=this;if(!(D instanceof m))return new m(v,k,O);D.time=+v||0,D.nano=+k||0,D.year=+O||0,w(D)}function w(v){var k,O,D,U=v.year,P=v.time,C=v.nano,L=((C<0||a<=C)&&(C-=(O=Math.floor(C/a))*a,P+=O,O=1),U%t);return(P<-s||s<P||L)&&((k=u(P/o))&&(U+=k*t,P-=k*o),(D=x(P)).setUTCFullYear(L+D.getUTCFullYear()),D=(P=+D)+(k=u((U-=L)/t))*o,k&&-s<=D&&D<=s&&(U-=k*t,P=D),O=1),O&&(v.year=U,v.time=P,v.nano=C),v}function x(v){var k=new Date(0);return k.setTime(v),k}function b(U,D){U=+U||0;var O=u((D=(D|0)*i)/n)+u(U/n),D=D%n+U%n,U=u(D/n);return U&&(O+=U,D-=U*n),new m(1e3*D,0,O*t)}function y(v,k,O,D,U,P){return function(L,B){var T=w(this);L=L||new Array(8),_(L,B|=0);var F=Math.floor(T.time/1e3),T=T.year*(e*r/t),A=u(T/i)+u(F/i),T=T%i+F%i,F=Math.floor(T/i);return F&&(A+=F,T-=F*i),C(L,B+U,A),C(L,B+P,T),L};function C(L,B,A){L[B+v]=A>>24&255,L[B+k]=A>>16&255,L[B+O]=A>>8&255,L[B+D]=255&A}}function S(v,k,O,D,U,P){return function(L,B){_(L,B|=0);var A=C(L,B+U);return b(C(L,B+P),A)};function C(L,B){return 16777216*L[B+v]+(L[B+k]<<16|L[B+O]<<8|L[B+D])}}function _(v,k){if(v=v&&v.length,v==null)throw new TypeError("Invalid Buffer");if(v<k+8)throw new RangeError("Out of range")}function N(v){return(9<v?"":"0")+(0|v)}function E(v,k){return(c+(0|v)).substr(-k)}}()});var tv={};gt(tv,{DEFAULT_SESSION_MAX_PROVIDERS:()=>Du,DEFAULT_SESSION_MIN_PROVIDERS:()=>Uu,InsufficientProvidersError:()=>Fo,NoRoutersAvailableError:()=>Tr,UnknownCodecError:()=>Vo,UnknownHashAlgorithmError:()=>Mo,createHeliaHTTP:()=>Qb});var Zn=Symbol.for("@libp2p/content-routing");var Ma=Symbol.for("@libp2p/peer-id");var Yn=Symbol.for("@libp2p/peer-routing");var Oe=class extends Error{static name="AbortError";constructor(t="The operation was aborted"){super(t),this.name="AbortError"}};var Et=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},nn=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var Pt=class extends Error{static name="NotFoundError";constructor(t="Not found"){super(t),this.name="NotFoundError"}};var Xo=class extends Error{static name="InvalidCIDError";constructor(t="Invalid CID"){super(t),this.name="InvalidCIDError"}},ur=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var on=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var ht=(r,...t)=>{try{[...t]}catch{}};var sn=class extends EventTarget{#t=new Map;constructor(){super(),ht(1/0,this)}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let o=this.#t.get(t);o==null&&(o=[],this.#t.set(t,o)),o.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let o=this.#t.get(t);o!=null&&(o=o.filter(({callback:s})=>s!==e),this.#t.set(t,o))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:o})=>!o),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new CustomEvent(t,e))}};function rf(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function lr(...r){let t=[];for(let e of r)rf(e)&&t.push(e);await Promise.all(t.map(async e=>{e.beforeStart!=null&&await e.beforeStart()})),await Promise.all(t.map(async e=>{await e.start()})),await Promise.all(t.map(async e=>{e.afterStart!=null&&await e.afterStart()}))}async function fr(...r){let t=[];for(let e of r)rf(e)&&t.push(e);await Promise.all(t.map(async e=>{e.beforeStop!=null&&await e.beforeStop()})),await Promise.all(t.map(async e=>{await e.stop()})),await Promise.all(t.map(async e=>{e.afterStop!=null&&await e.afterStop()}))}function $t(r){let t=new globalThis.AbortController;function e(){t.abort();for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",e)}for(let s of r){if(s?.aborted===!0){e();break}s?.addEventListener!=null&&s.addEventListener("abort",e)}function n(){for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",e)}let o=t.signal;return o.clear=n,o}function At(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Qo=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},an=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Qo(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new Qo(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var Va=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Ur(r={}){return Lm(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function Lm(r,t){t=t??{};let e=t.onEnd,n=new an,o,s,i,a=At(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((w,x)=>{s=b=>{s=null,n.push(b);try{w(r(n))}catch(y){x(y)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=At()})}},u=w=>s!=null?s(w):(n.push(w),o),l=w=>(n=new an,s!=null?s({error:w}):(n.push({error:w}),o)),f=w=>{if(i)return o;if(t?.objectMode!==!0&&w?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return u({done:!1,value:w})},d=w=>i?o:(i=!0,w!=null?l(w):u({done:!0})),h=()=>(n=new an,d(),{done:!0}),g=w=>(d(w),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:h,throw:g,push:f,end:d,get readableLength(){return n.size},onEmpty:async w=>{let x=w?.signal;if(x?.throwIfAborted(),n.isEmpty())return;let b,y;x!=null&&(b=new Promise((S,_)=>{y=()=>{_(new Va)},x.addEventListener("abort",y)}));try{await Promise.race([a.promise,b])}finally{y!=null&&x!=null&&x?.removeEventListener("abort",y)}}},e==null)return o;let m=o;return o={[Symbol.asyncIterator](){return this},next(){return m.next()},throw(w){return m.throw(w),e!=null&&(e(w),e=void 0),{done:!0}},return(){return m.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(w){return m.end(w),e!=null&&(e(w),e=void 0),o},get readableLength(){return m.readableLength},onEmpty:w=>m.onEmpty(w)},o}var Oa=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=e??"ABORT_ERR"}};async function ts(r,t,e,n){let o=new Oa(n?.errorMessage,n?.errorCode);return e?.aborted===!0?Promise.reject(o):new Promise((s,i)=>{function a(){e?.removeEventListener("abort",l),r.removeEventListener(t,c),n?.errorEvent!=null&&r.removeEventListener(n.errorEvent,u)}let c=f=>{try{if(n?.filter?.(f)===!1)return}catch(d){a(),i(d);return}a(),s(f)},u=f=>{a(),i(f.detail)},l=()=>{a(),i(o)};e?.addEventListener("abort",l),r.addEventListener(t,c),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,u)})}var es=class extends Error{static name="QueueFullError";constructor(t="The queue was full"){super(t),this.name="QueueFullError"}};var rs=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};async function nf(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new rs(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new rs(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var ns=class{deferred;signal;constructor(t){this.signal=t,this.deferred=At(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new Oe)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function Pm(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var os=class{id;fn;options;recipients;status;timeline;controller;constructor(t,e){this.id=Pm(),this.status="queued",this.fn=t,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,ht(1/0,this.controller.signal),this.onAbort=this.onAbort.bind(this)}abort(t){this.controller.abort(t)}onAbort(){this.recipients.reduce((e,n)=>e&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new Oe),this.cleanup())}async join(t={}){let e=new ns(t.signal);return this.recipients.push(e),t.signal?.addEventListener("abort",this.onAbort),e.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let t=await nf(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(e=>{e.deferred.resolve(t)}),this.status="complete"}catch(t){this.recipients.forEach(e=>{e.deferred.reject(t)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(t=>{t.cleanup(),t.signal?.removeEventListener("abort",this.onAbort)})}};var $e=class extends sn{concurrency;maxSize;queue;pending;sort;constructor(t={}){super(),this.concurrency=t.concurrency??Number.POSITIVE_INFINITY,this.maxSize=t.maxSize??Number.POSITIVE_INFINITY,this.pending=0,t.metricName!=null&&t.metrics?.registerMetricGroup(t.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.sort=t.sort,this.queue=[]}tryToStartAnother(){if(this.size===0)return queueMicrotask(()=>{this.safeDispatchEvent("empty")}),this.running===0&&queueMicrotask(()=>{this.safeDispatchEvent("idle")}),!1;if(this.pending<this.concurrency){let t;for(let e of this.queue)if(e.status==="queued"){t=e;break}return t==null?!1:(this.safeDispatchEvent("active"),this.pending++,t.run().finally(()=>{for(let e=0;e<this.queue.length;e++)if(this.queue[e]===t){this.queue.splice(e,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(t){this.queue.push(t),this.sort!=null&&this.queue.sort(this.sort)}async add(t,e){if(e?.signal?.throwIfAborted(),this.size===this.maxSize)throw new es;let n=new os(t,e);return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),n.join(e).then(o=>(this.safeDispatchEvent("completed",{detail:o}),this.safeDispatchEvent("success",{detail:{job:n,result:o}}),o)).catch(o=>{if(n.status==="queued"){for(let s=0;s<this.queue.length;s++)if(this.queue[s]===n){this.queue.splice(s,1);break}}throw this.safeDispatchEvent("error",{detail:o}),this.safeDispatchEvent("failure",{detail:{job:n,error:o}}),o})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(t=>{t.abort(new Oe)}),this.clear()}async onEmpty(t){this.size!==0&&await ts(this,"empty",t?.signal)}async onSizeLessThan(t,e){this.size<t||await ts(this,"next",e?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await ts(this,"idle",t?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(t){t?.signal?.throwIfAborted();let e=Ur({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),e.end(c)},o=c=>{c.detail!=null&&e.push(c.detail)},s=c=>{n(c.detail)},i=()=>{n()},a=()=>{n(new Oe("Queue aborted"))};this.addEventListener("completed",o),this.addEventListener("error",s),this.addEventListener("idle",i),t?.signal?.addEventListener("abort",a);try{yield*e}finally{this.removeEventListener("completed",o),this.removeEventListener("error",s),this.removeEventListener("idle",i),t?.signal?.removeEventListener("abort",a),n()}}};var ss=class extends $e{has(t){return this.find(t)!=null}find(t){return this.queue.find(e=>t.equals(e.options.peerId))}};function Rm(r){return r[Symbol.asyncIterator]!=null}function Um(r){if(Rm(r))return(async()=>{for await(let t of r);})();for(let t of r);}var Dr=Um;function of(r=0){return new Uint8Array(r)}function ue(r=0){return new Uint8Array(r)}var Dm=Math.pow(2,7),Fm=Math.pow(2,14),Mm=Math.pow(2,21),$a=Math.pow(2,28),Ha=Math.pow(2,35),za=Math.pow(2,42),Ka=Math.pow(2,49),nt=128,Rt=127;function qt(r){if(r<Dm)return 1;if(r<Fm)return 2;if(r<Mm)return 3;if(r<$a)return 4;if(r<Ha)return 5;if(r<za)return 6;if(r<Ka)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function qa(r,t,e=0){switch(qt(r)){case 8:t[e++]=r&255|nt,r/=128;case 7:t[e++]=r&255|nt,r/=128;case 6:t[e++]=r&255|nt,r/=128;case 5:t[e++]=r&255|nt,r/=128;case 4:t[e++]=r&255|nt,r>>>=7;case 3:t[e++]=r&255|nt,r>>>=7;case 2:t[e++]=r&255|nt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Vm(r,t,e=0){switch(qt(r)){case 8:t.set(e++,r&255|nt),r/=128;case 7:t.set(e++,r&255|nt),r/=128;case 6:t.set(e++,r&255|nt),r/=128;case 5:t.set(e++,r&255|nt),r/=128;case 4:t.set(e++,r&255|nt),r>>>=7;case 3:t.set(e++,r&255|nt),r>>>=7;case 2:t.set(e++,r&255|nt),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function ja(r,t){let e=r[t],n=0;if(n+=e&Rt,e<nt||(e=r[t+1],n+=(e&Rt)<<7,e<nt)||(e=r[t+2],n+=(e&Rt)<<14,e<nt)||(e=r[t+3],n+=(e&Rt)<<21,e<nt)||(e=r[t+4],n+=(e&Rt)*$a,e<nt)||(e=r[t+5],n+=(e&Rt)*Ha,e<nt)||(e=r[t+6],n+=(e&Rt)*za,e<nt)||(e=r[t+7],n+=(e&Rt)*Ka,e<nt))return n;throw new RangeError("Could not decode varint")}function Om(r,t){let e=r.get(t),n=0;if(n+=e&Rt,e<nt||(e=r.get(t+1),n+=(e&Rt)<<7,e<nt)||(e=r.get(t+2),n+=(e&Rt)<<14,e<nt)||(e=r.get(t+3),n+=(e&Rt)<<21,e<nt)||(e=r.get(t+4),n+=(e&Rt)*$a,e<nt)||(e=r.get(t+5),n+=(e&Rt)*Ha,e<nt)||(e=r.get(t+6),n+=(e&Rt)*za,e<nt)||(e=r.get(t+7),n+=(e&Rt)*Ka,e<nt))return n;throw new RangeError("Could not decode varint")}function cn(r,t,e=0){return t==null&&(t=ue(qt(r))),t instanceof Uint8Array?qa(r,t,e):Vm(r,t,e)}function Fr(r,t=0){return r instanceof Uint8Array?ja(r,t):Om(r,t)}function Jt(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=ue(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}function st(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function $m(r){let[t,e]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>t.next(),push:o=>{n.push(o)},next:()=>n.length>0?{done:!1,value:n.shift()}:t.next(),[e](){return this}}}var un=$m;function Hm(r){return r[Symbol.asyncIterator]!=null}function zm(r,t){let e=0;if(Hm(r))return async function*(){for await(let c of r)yield t(c,e++)}();let n=un(r),{value:o,done:s}=n.next();if(s===!0)return function*(){}();let i=t(o,e++);if(typeof i.then=="function")return async function*(){yield await i;for await(let c of n)yield t(c,e++)}();let a=t;return function*(){yield i;for(let c of n)yield a(c,e++)}()}var ln=zm;function Km(r){return r[Symbol.asyncIterator]!=null}function qm(...r){let t=[];for(let e of r)Km(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Ur({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let o of n)e.push(o)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var Mr=qm;function jm(r){return r[Symbol.asyncIterator]!=null}function Gm(r,t){return jm(r)?async function*(){let e=0;if(!(t<1)){for await(let n of r)if(yield n,e++,e===t)return}}():function*(){let e=0;if(!(t<1)){for(let n of r)if(yield n,e++,e===t)return}}()}var is=Gm;var tt=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};var Ga=new Float32Array([-0]),hr=new Uint8Array(Ga.buffer);function af(r,t,e){Ga[0]=r,t[e]=hr[0],t[e+1]=hr[1],t[e+2]=hr[2],t[e+3]=hr[3]}function cf(r,t){return hr[0]=r[t],hr[1]=r[t+1],hr[2]=r[t+2],hr[3]=r[t+3],Ga[0]}var Wa=new Float64Array([-0]),Ut=new Uint8Array(Wa.buffer);function uf(r,t,e){Wa[0]=r,t[e]=Ut[0],t[e+1]=Ut[1],t[e+2]=Ut[2],t[e+3]=Ut[3],t[e+4]=Ut[4],t[e+5]=Ut[5],t[e+6]=Ut[6],t[e+7]=Ut[7]}function lf(r,t){return Ut[0]=r[t],Ut[1]=r[t+1],Ut[2]=r[t+2],Ut[3]=r[t+3],Ut[4]=r[t+4],Ut[5]=r[t+5],Ut[6]=r[t+6],Ut[7]=r[t+7],Wa[0]}var Wm=BigInt(Number.MAX_SAFE_INTEGER),Zm=BigInt(Number.MIN_SAFE_INTEGER),Xt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Vr;if(t<Wm&&t>Zm)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,o=t-(n<<32n);return e&&(n=~n|0n,o=~o|0n,++o>ff&&(o=0n,++n>ff&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Vr;let e=t<0;e&&(t=-t);let n=t>>>0,o=(t-n)/4294967296>>>0;return e&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new r(n,o)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Vr}},Vr=new Xt(0,0);Vr.toBigInt=function(){return 0n};Vr.zzEncode=Vr.zzDecode=function(){return this};Vr.length=function(){return 1};var ff=4294967296n;function hf(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function df(r,t,e){if(e-t<1)return"";let o,s=[],i=0,a;for(;t<e;)a=r[t++],a<128?s[i++]=a:a>191&&a<224?s[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,s)),i=0);return o!=null?(i>0&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))}function Za(r,t,e){let n=e,o,s;for(let i=0;i<r.length;++i)o=r.charCodeAt(i),o<128?t[e++]=o:o<2048?(t[e++]=o>>6|192,t[e++]=o&63|128):(o&64512)===55296&&((s=r.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,t[e++]=o>>18|240,t[e++]=o>>12&63|128,t[e++]=o>>6&63|128,t[e++]=o&63|128):(t[e++]=o>>12|224,t[e++]=o>>6&63|128,t[e++]=o&63|128);return e-n}function le(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function as(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Ya=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,le(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw le(this,4);return as(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw le(this,4);return as(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw le(this,4);let t=cf(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw le(this,4);let t=lf(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw le(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return df(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw le(this,t);this.pos+=t}else do if(this.pos>=this.len)throw le(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new Xt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw le(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw le(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw le(this,8);let t=as(this.buf,this.pos+=4),e=as(this.buf,this.pos+=4);return new Xt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=ja(this.buf,this.pos);return this.pos+=qt(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Ja(r){return new Ya(r instanceof Uint8Array?r:r.subarray())}function fn(r,t,e){let n=Ja(r);return t.decode(n,void 0,e)}var nc={};gt(nc,{base10:()=>eg});var a2=new Uint8Array(0);function mf(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function fe(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 gf(r){return new TextEncoder().encode(r)}function yf(r){return new TextDecoder().decode(r)}function Ym(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(e[i]!==255)throw new TypeError(s+" is ambiguous");e[i]=o}var a=r.length,c=r.charAt(0),u=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function f(g){if(g instanceof Uint8Array||(ArrayBuffer.isView(g)?g=new Uint8Array(g.buffer,g.byteOffset,g.byteLength):Array.isArray(g)&&(g=Uint8Array.from(g))),!(g instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(g.length===0)return"";for(var m=0,w=0,x=0,b=g.length;x!==b&&g[x]===0;)x++,m++;for(var y=(b-x)*l+1>>>0,S=new Uint8Array(y);x!==b;){for(var _=g[x],N=0,E=y-1;(_!==0||N<w)&&E!==-1;E--,N++)_+=256*S[E]>>>0,S[E]=_%a>>>0,_=_/a>>>0;if(_!==0)throw new Error("Non-zero carry");w=N,x++}for(var v=y-w;v!==y&&S[v]===0;)v++;for(var k=c.repeat(m);v<y;++v)k+=r.charAt(S[v]);return k}function d(g){if(typeof g!="string")throw new TypeError("Expected String");if(g.length===0)return new Uint8Array;var m=0;if(g[m]!==" "){for(var w=0,x=0;g[m]===c;)w++,m++;for(var b=(g.length-m)*u+1>>>0,y=new Uint8Array(b);g[m];){var S=e[g.charCodeAt(m)];if(S===255)return;for(var _=0,N=b-1;(S!==0||_<x)&&N!==-1;N--,_++)S+=a*y[N]>>>0,y[N]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");x=_,m++}if(g[m]!==" "){for(var E=b-x;E!==b&&y[E]===0;)E++;for(var v=new Uint8Array(w+(b-E)),k=w;E!==b;)v[k++]=y[E++];return v}}}function h(g){var m=d(g);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:d,decode:h}}var Jm=Ym,Xm=Jm,wf=Xm;var Qa=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},tc=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let o=e.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return xf(this,t)}},ec=class{decoders;constructor(t){this.decoders=t}or(t){return xf(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function xf(r,t){return new ec({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var rc=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,o){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=o,this.encoder=new Qa(t,e,n),this.decoder=new tc(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function hn({name:r,prefix:t,encode:e,decode:n}){return new rc(r,t,e,n)}function dr({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=wf(e,r);return hn({prefix:t,name:r,encode:n,decode:s=>fe(o(s))})}function Qm(r,t,e,n){let o={};for(let l=0;l<t.length;++l)o[t[l]]=l;let s=r.length;for(;r[s-1]==="=";)--s;let i=new Uint8Array(s*e/8|0),a=0,c=0,u=0;for(let l=0;l<s;++l){let f=o[r[l]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|f,a+=e,a>=8&&(a-=8,i[u++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function tg(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,s+=t[o&a>>i];if(i!==0&&(s+=t[o&a<<e-i]),n)for(;s.length*e&7;)s+="=";return s}function mt({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return hn({prefix:t,name:r,encode(o){return tg(o,n,e)},decode(o){return Qm(o,n,e,r)}})}var eg=dr({prefix:"9",name:"base10",alphabet:"0123456789"});var oc={};gt(oc,{base16:()=>rg,base16upper:()=>ng});var rg=mt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),ng=mt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var sc={};gt(sc,{base2:()=>og});var og=mt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ic={};gt(ic,{base256emoji:()=>ug});var bf=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}"),sg=bf.reduce((r,t,e)=>(r[e]=t,r),[]),ig=bf.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function ag(r){return r.reduce((t,e)=>(t+=sg[e],t),"")}function cg(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=ig[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var ug=hn({prefix:"\u{1F680}",name:"base256emoji",encode:ag,decode:cg});var ac={};gt(ac,{base32:()=>_t,base32hex:()=>dg,base32hexpad:()=>mg,base32hexpadupper:()=>gg,base32hexupper:()=>pg,base32pad:()=>fg,base32padupper:()=>hg,base32upper:()=>lg,base32z:()=>yg});var _t=mt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),lg=mt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),fg=mt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),hg=mt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),dg=mt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),pg=mt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),mg=mt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),gg=mt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),yg=mt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var cc={};gt(cc,{base36:()=>Te,base36upper:()=>wg});var Te=dr({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),wg=dr({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var uc={};gt(uc,{base58btc:()=>it,base58flickr:()=>xg});var it=dr({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),xg=dr({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var fc={};gt(fc,{base64:()=>Ce,base64pad:()=>bg,base64url:()=>lc,base64urlpad:()=>vg});var Ce=mt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),bg=mt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),lc=mt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),vg=mt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var hc={};gt(hc,{base8:()=>Eg});var Eg=mt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var dc={};gt(dc,{identity:()=>Ag});var Ag=hn({prefix:"\0",name:"identity",encode:r=>yf(r),decode:r=>gf(r)});var cs={};gt(cs,{code:()=>pc,decode:()=>_g,encode:()=>Ig,name:()=>kg});var Sg=new TextEncoder,Bg=new TextDecoder,kg="json",pc=512;function Ig(r){return Sg.encode(JSON.stringify(r))}function _g(r){return JSON.parse(Bg.decode(r))}var Xn={};gt(Xn,{code:()=>Jn,decode:()=>Ng,encode:()=>Cg,name:()=>Tg});var Tg="raw",Jn=85;function Cg(r){return fe(r)}function Ng(r){return fe(r)}var gc={};gt(gc,{identity:()=>jt});var Lg=Af,vf=128,Pg=127,Rg=~Pg,Ug=Math.pow(2,31);function Af(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Ug;)t[e++]=r&255|vf,r/=128;for(;r&Rg;)t[e++]=r&255|vf,r>>>=7;return t[e]=r|0,Af.bytes=e-n+1,t}var Dg=mc,Fg=128,Ef=127;function mc(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw mc.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&Ef)<<o:(i&Ef)*Math.pow(2,o),o+=7}while(i>=Fg);return mc.bytes=s-n,e}var Mg=Math.pow(2,7),Vg=Math.pow(2,14),Og=Math.pow(2,21),$g=Math.pow(2,28),Hg=Math.pow(2,35),zg=Math.pow(2,42),Kg=Math.pow(2,49),qg=Math.pow(2,56),jg=Math.pow(2,63),Gg=function(r){return r<Mg?1:r<Vg?2:r<Og?3:r<$g?4:r<Hg?5:r<zg?6:r<Kg?7:r<qg?8:r<jg?9:10},Wg={encode:Lg,decode:Dg,encodingLength:Gg},Zg=Wg,Qn=Zg;function to(r,t=0){return[Qn.decode(r,t),Qn.decode.bytes]}function dn(r,t,e=0){return Qn.encode(r,t,e),t}function pn(r){return Qn.encodingLength(r)}function he(r,t){let e=t.byteLength,n=pn(r),o=n+pn(e),s=new Uint8Array(o+e);return dn(r,s,0),dn(e,s,n),s.set(t,o),new mn(r,e,t,s)}function de(r){let t=fe(r),[e,n]=to(t),[o,s]=to(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new mn(e,o,i,t)}function Sf(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&mf(r.bytes,e.bytes)}}var mn=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};var Bf=0,Yg="identity",kf=fe;function Jg(r){return he(Bf,kf(r))}var jt={code:Bf,name:Yg,encode:kf,digest:Jg};var xc={};gt(xc,{sha256:()=>pr,sha512:()=>ls});function wc({name:r,code:t,encode:e}){return new yc(r,t,e)}var yc=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?he(this.code,e):e.then(n=>he(this.code,n))}else throw Error("Unknown type, must be binary type")}};function _f(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var pr=wc({name:"sha2-256",code:18,encode:_f("SHA-256")}),ls=wc({name:"sha2-512",code:19,encode:_f("SHA-512")});function Tf(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Qg(e,bc(r),t??it.encoder);default:return ty(e,bc(r),t??_t.encoder)}}var Cf=new WeakMap;function bc(r){let t=Cf.get(r);if(t==null){let e=new Map;return Cf.set(r,e),e}return t}var $=class r{code;version;multihash;bytes;"/";constructor(t,e,n,o){this.code=e,this.version=t,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==eo)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==ey)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=he(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&Sf(t.multihash,n.multihash)}toString(t){return Tf(this,t)}toJSON(){return{"/":Tf(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:o,multihash:s,bytes:i}=e;return new r(n,o,s,i??Nf(n,o,s.bytes))}else if(e[ry]===!0){let{version:n,multihash:o,code:s}=e,i=de(o);return r.create(n,s,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==eo)throw new Error(`Version 0 CID must use dag-pb (code: ${eo}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=Nf(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,eo,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,o=fe(t.subarray(n,n+e.multihashSize));if(o.byteLength!==e.multihashSize)throw new Error("Incorrect length");let s=o.subarray(e.multihashSize-e.digestSize),i=new mn(e.multihashCode,e.digestSize,s,o);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[f,d]=to(t.subarray(e));return e+=d,f},o=n(),s=eo;if(o===18?(o=0,e=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=e,a=n(),c=n(),u=e+c,l=u-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:l,size:u}}static parse(t,e){let[n,o]=Xg(t,e),s=r.decode(o);if(s.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return bc(s).set(n,t),s}};function Xg(r,t){switch(r[0]){case"Q":{let e=t??it;return[it.prefix,e.decode(`${it.prefix}${r}`)]}case it.prefix:{let e=t??it;return[it.prefix,e.decode(r)]}case _t.prefix:{let e=t??_t;return[_t.prefix,e.decode(r)]}case Te.prefix:{let e=t??Te;return[Te.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Qg(r,t,e){let{prefix:n}=e;if(n!==it.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let o=t.get(n);if(o==null){let s=e.encode(r).slice(1);return t.set(n,s),s}else return o}function ty(r,t,e){let{prefix:n}=e,o=t.get(n);if(o==null){let s=e.encode(r);return t.set(n,s),s}else return o}var eo=112,ey=18;function Nf(r,t,e){let n=pn(r),o=n+pn(t),s=new Uint8Array(o+e.byteLength);return dn(r,s,0),dn(t,s,n),s.set(e,o),s}var ry=Symbol.for("@ipld/js-cid/CID");var ro={...dc,...sc,...hc,...nc,...oc,...ac,...cc,...uc,...fc,...ic},K2={...xc,...gc};function Pf(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Lf=Pf("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),vc=Pf("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=ue(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),ny={utf8:Lf,"utf-8":Lf,hex:ro.base16,latin1:vc,ascii:vc,binary:vc,...ro},fs=ny;function H(r,t="utf8"){let e=fs[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function Ec(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return ue(i);o+i>t&&(n=ue(t),o=0);let a=n.subarray(o,o+=i);return o&7&&(o=(o|7)+1),a}}var Or=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Ac(){}var Bc=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},oy=Ec();function sy(r){return globalThis.Buffer!=null?ue(r):oy(r)}var oo=class{len;head;tail;states;constructor(){this.len=0,this.head=new Or(Ac,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Or(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new kc((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(hs,10,Xt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Xt.fromBigInt(t);return this._push(hs,e.length(),e)}uint64Number(t){return this._push(qa,qt(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Xt.fromBigInt(t).zzEncode();return this._push(hs,e.length(),e)}sint64Number(t){let e=Xt.fromNumber(t).zzEncode();return this._push(hs,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Sc,1,t?1:0)}fixed32(t){return this._push(no,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Xt.fromBigInt(t);return this._push(no,4,e.lo)._push(no,4,e.hi)}fixed64Number(t){let e=Xt.fromNumber(t);return this._push(no,4,e.lo)._push(no,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(af,4,t)}double(t){return this._push(uf,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Sc,1,0):this.uint32(e)._push(ay,e,t)}string(t){let e=hf(t);return e!==0?this.uint32(e)._push(Za,e,t):this._push(Sc,1,0)}fork(){return this.states=new Bc(this),this.head=this.tail=new Or(Ac,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 Or(Ac,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=sy(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Sc(r,t,e){t[e]=r&255}function iy(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var kc=class extends Or{next;constructor(t,e){super(iy,t,e),this.next=void 0}};function hs(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function no(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function ay(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(oo.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(cy,t,r),this},oo.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(uy,t,r),this});function cy(r,t,e){t.set(r,e)}function uy(r,t,e){r.length<40?Za(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(H(r),e)}function Ic(){return new oo}function gn(r,t){let e=Ic();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var yn;(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"})(yn||(yn={}));function ds(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function so(r){function t(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let e=function(s,i){let a=t(s);i.int32(a)},n=function(s){let i=s.int32();return t(i)};return ds("enum",yn.VARINT,e,n)}function wn(r,t){return ds("message",yn.LENGTH_DELIMITED,r,t)}function Rf(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function ly(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function xn(r,...t){if(!ly(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function Uf(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Rf(r.outputLen),Rf(r.blockLen)}function bn(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function Df(r,t){xn(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var $r=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var ps=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),pe=(r,t)=>r<<32-t|r>>>t;function Ff(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function io(r){return typeof r=="string"&&(r=Ff(r)),xn(r),r}function _c(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];xn(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let s=r[n];e.set(s,o),o+=s.length}return e}var vn=class{clone(){return this._cloneInto()}};function ms(r){let t=n=>r().update(io(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function gs(r=32){if($r&&typeof $r.getRandomValues=="function")return $r.getRandomValues(new Uint8Array(r));if($r&&typeof $r.randomBytes=="function")return $r.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function fy(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(e>>o&s),a=Number(e&s),c=n?4:0,u=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+u,a,n)}var Mf=(r,t,e)=>r&t^~r&e,Vf=(r,t,e)=>r&t^r&e^t&e,En=class extends vn{constructor(t,e,n,o){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=o,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=ps(this.buffer)}update(t){bn(this);let{view:e,buffer:n,blockLen:o}=this;t=io(t);let s=t.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=ps(t);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){bn(this),Df(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>o-i&&(this.process(n,0),i=0);for(let f=i;f<o;f++)e[f]=0;fy(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=ps(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=c/4,l=this.get();if(u>l.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<u;f++)a.setUint32(4*f,l[f],s)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return t.length=o,t.pos=a,t.finished=s,t.destroyed=i,o%e&&t.buffer.set(n),t}};var ys=BigInt(4294967295),Tc=BigInt(32);function Of(r,t=!1){return t?{h:Number(r&ys),l:Number(r>>Tc&ys)}:{h:Number(r>>Tc&ys)|0,l:Number(r&ys)|0}}function hy(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let o=0;o<r.length;o++){let{h:s,l:i}=Of(r[o],t);[e[o],n[o]]=[s,i]}return[e,n]}var dy=(r,t)=>BigInt(r>>>0)<<Tc|BigInt(t>>>0),py=(r,t,e)=>r>>>e,my=(r,t,e)=>r<<32-e|t>>>e,gy=(r,t,e)=>r>>>e|t<<32-e,yy=(r,t,e)=>r<<32-e|t>>>e,wy=(r,t,e)=>r<<64-e|t>>>e-32,xy=(r,t,e)=>r>>>e-32|t<<64-e,by=(r,t)=>t,vy=(r,t)=>r,Ey=(r,t,e)=>r<<e|t>>>32-e,Ay=(r,t,e)=>t<<e|r>>>32-e,Sy=(r,t,e)=>t<<e-32|r>>>64-e,By=(r,t,e)=>r<<e-32|t>>>64-e;function ky(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var Iy=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),_y=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Ty=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Cy=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,Ny=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),Ly=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var Py={fromBig:Of,split:hy,toBig:dy,shrSH:py,shrSL:my,rotrSH:gy,rotrSL:yy,rotrBH:wy,rotrBL:xy,rotr32H:by,rotr32L:vy,rotlSH:Ey,rotlSL:Ay,rotlBH:Sy,rotlBL:By,add:ky,add3L:Iy,add3H:_y,add4L:Ty,add4H:Cy,add5H:Ly,add5L:Ny},j=Py;var[Ry,Uy]=j.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),mr=new Uint32Array(80),gr=new Uint32Array(80),Cc=class extends En{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:u,El:l,Fh:f,Fl:d,Gh:h,Gl:g,Hh:m,Hl:w}=this;return[t,e,n,o,s,i,a,c,u,l,f,d,h,g,m,w]}set(t,e,n,o,s,i,a,c,u,l,f,d,h,g,m,w){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=o|0,this.Ch=s|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=u|0,this.El=l|0,this.Fh=f|0,this.Fl=d|0,this.Gh=h|0,this.Gl=g|0,this.Hh=m|0,this.Hl=w|0}process(t,e){for(let y=0;y<16;y++,e+=4)mr[y]=t.getUint32(e),gr[y]=t.getUint32(e+=4);for(let y=16;y<80;y++){let S=mr[y-15]|0,_=gr[y-15]|0,N=j.rotrSH(S,_,1)^j.rotrSH(S,_,8)^j.shrSH(S,_,7),E=j.rotrSL(S,_,1)^j.rotrSL(S,_,8)^j.shrSL(S,_,7),v=mr[y-2]|0,k=gr[y-2]|0,O=j.rotrSH(v,k,19)^j.rotrBH(v,k,61)^j.shrSH(v,k,6),D=j.rotrSL(v,k,19)^j.rotrBL(v,k,61)^j.shrSL(v,k,6),U=j.add4L(E,D,gr[y-7],gr[y-16]),P=j.add4H(U,N,O,mr[y-7],mr[y-16]);mr[y]=P|0,gr[y]=U|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:d,Fh:h,Fl:g,Gh:m,Gl:w,Hh:x,Hl:b}=this;for(let y=0;y<80;y++){let S=j.rotrSH(f,d,14)^j.rotrSH(f,d,18)^j.rotrBH(f,d,41),_=j.rotrSL(f,d,14)^j.rotrSL(f,d,18)^j.rotrBL(f,d,41),N=f&h^~f&m,E=d&g^~d&w,v=j.add5L(b,_,E,Uy[y],gr[y]),k=j.add5H(v,x,S,N,Ry[y],mr[y]),O=v|0,D=j.rotrSH(n,o,28)^j.rotrBH(n,o,34)^j.rotrBH(n,o,39),U=j.rotrSL(n,o,28)^j.rotrBL(n,o,34)^j.rotrBL(n,o,39),P=n&s^n&a^s&a,C=o&i^o&c^i&c;x=m|0,b=w|0,m=h|0,w=g|0,h=f|0,g=d|0,{h:f,l:d}=j.add(u|0,l|0,k|0,O|0),u=a|0,l=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let L=j.add3L(O,U,C);n=j.add3H(L,k,D,P),o=L|0}({h:n,l:o}=j.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=j.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=j.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=j.add(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:d}=j.add(this.Eh|0,this.El|0,f|0,d|0),{h,l:g}=j.add(this.Fh|0,this.Fl|0,h|0,g|0),{h:m,l:w}=j.add(this.Gh|0,this.Gl|0,m|0,w|0),{h:x,l:b}=j.add(this.Hh|0,this.Hl|0,x|0,b|0),this.set(n,o,s,i,a,c,u,l,f,d,h,g,m,w,x,b)}roundClean(){mr.fill(0),gr.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var $f=ms(()=>new Cc);var bs={};gt(bs,{aInRange:()=>Gt,abool:()=>me,abytes:()=>An,bitGet:()=>$y,bitLen:()=>Rc,bitMask:()=>co,bitSet:()=>Hy,bytesToHex:()=>Ke,bytesToNumberBE:()=>qe,bytesToNumberLE:()=>wr,concatBytes:()=>je,createHmacDrbg:()=>Uc,ensureBytes:()=>dt,equalBytes:()=>Vy,hexToBytes:()=>zr,hexToNumber:()=>Pc,inRange:()=>ao,isBytes:()=>yr,memoized:()=>qr,notImplemented:()=>Ky,numberToBytesBE:()=>xr,numberToBytesLE:()=>Kr,numberToHexUnpadded:()=>Hr,numberToVarBytesBE:()=>My,utf8ToBytes:()=>Oy,validateObject:()=>Ne});var ws=BigInt(0),xs=BigInt(1),Dy=BigInt(2);function yr(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function An(r){if(!yr(r))throw new Error("Uint8Array expected")}function me(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var Fy=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Ke(r){An(r);let t="";for(let e=0;e<r.length;e++)t+=Fy[r[e]];return t}function Hr(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Pc(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?ws:BigInt("0x"+r)}var ze={_0:48,_9:57,A:65,F:70,a:97,f:102};function Hf(r){if(r>=ze._0&&r<=ze._9)return r-ze._0;if(r>=ze.A&&r<=ze.F)return r-(ze.A-10);if(r>=ze.a&&r<=ze.f)return r-(ze.a-10)}function zr(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let o=0,s=0;o<e;o++,s+=2){let i=Hf(r.charCodeAt(s)),a=Hf(r.charCodeAt(s+1));if(i===void 0||a===void 0){let c=r[s]+r[s+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+s)}n[o]=i*16+a}return n}function qe(r){return Pc(Ke(r))}function wr(r){return An(r),Pc(Ke(Uint8Array.from(r).reverse()))}function xr(r,t){return zr(r.toString(16).padStart(t*2,"0"))}function Kr(r,t){return xr(r,t).reverse()}function My(r){return zr(Hr(r))}function dt(r,t,e){let n;if(typeof t=="string")try{n=zr(t)}catch(s){throw new Error(r+" must be hex string or Uint8Array, cause: "+s)}else if(yr(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let o=n.length;if(typeof e=="number"&&o!==e)throw new Error(r+" of length "+e+" expected, got "+o);return n}function je(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];An(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let s=r[n];e.set(s,o),o+=s.length}return e}function Vy(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function Oy(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var Nc=r=>typeof r=="bigint"&&ws<=r;function ao(r,t,e){return Nc(r)&&Nc(t)&&Nc(e)&&t<=r&&r<e}function Gt(r,t,e,n){if(!ao(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Rc(r){let t;for(t=0;r>ws;r>>=xs,t+=1);return t}function $y(r,t){return r>>BigInt(t)&xs}function Hy(r,t,e){return r|(e?xs:ws)<<BigInt(t)}var co=r=>(Dy<<BigInt(r-1))-xs,Lc=r=>new Uint8Array(r),zf=r=>Uint8Array.from(r);function Uc(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=Lc(r),o=Lc(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...f)=>e(o,n,...f),c=(f=Lc())=>{o=a(zf([0]),f),n=a(),f.length!==0&&(o=a(zf([1]),f),n=a())},u=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,d=[];for(;f<t;){n=a();let h=n.slice();d.push(h),f+=n.length}return je(...d)};return(f,d)=>{i(),c(f);let h;for(;!(h=d(u()));)c();return i(),h}}var zy={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||yr(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Ne(r,t,e={}){let n=(o,s,i)=>{let a=zy[s];if(typeof a!="function")throw new Error("invalid validator function");let c=r[o];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(o)+" is invalid. Expected "+s+", got "+c)};for(let[o,s]of Object.entries(t))n(o,s,!1);for(let[o,s]of Object.entries(e))n(o,s,!0);return r}var Ky=()=>{throw new Error("not implemented")};function qr(r){let t=new WeakMap;return(e,...n)=>{let o=t.get(e);if(o!==void 0)return o;let s=r(e,...n);return t.set(e,s),s}}var wt=BigInt(0),lt=BigInt(1),jr=BigInt(2),qy=BigInt(3),Dc=BigInt(4),Kf=BigInt(5),qf=BigInt(8),jy=BigInt(9),Gy=BigInt(16);function at(r,t){let e=r%t;return e>=wt?e:t+e}function Wy(r,t,e){if(t<wt)throw new Error("invalid exponent, negatives unsupported");if(e<=wt)throw new Error("invalid modulus");if(e===lt)return wt;let n=lt;for(;t>wt;)t&lt&&(n=n*r%e),r=r*r%e,t>>=lt;return n}function ft(r,t,e){let n=r;for(;t-- >wt;)n*=n,n%=e;return n}function vs(r,t){if(r===wt)throw new Error("invert: expected non-zero number");if(t<=wt)throw new Error("invert: expected positive modulus, got "+t);let e=at(r,t),n=t,o=wt,s=lt,i=lt,a=wt;for(;e!==wt;){let u=n/e,l=n%e,f=o-i*u,d=s-a*u;n=e,e=l,o=i,s=a,i=f,a=d}if(n!==lt)throw new Error("invert: does not exist");return at(o,t)}function Zy(r){let t=(r-lt)/jr,e,n,o;for(e=r-lt,n=0;e%jr===wt;e/=jr,n++);for(o=jr;o<r&&Wy(o,t,r)!==r-lt;o++)if(o>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let i=(r+lt)/Dc;return function(c,u){let l=c.pow(u,i);if(!c.eql(c.sqr(l),u))throw new Error("Cannot find square root");return l}}let s=(e+lt)/jr;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let u=n,l=a.pow(a.mul(a.ONE,o),e),f=a.pow(c,s),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let h=1;for(let m=a.sqr(d);h<u&&!a.eql(m,a.ONE);h++)m=a.sqr(m);let g=a.pow(l,lt<<BigInt(u-h-1));l=a.sqr(g),f=a.mul(f,g),d=a.mul(d,l),u=h}return f}}function Yy(r){if(r%Dc===qy){let t=(r+lt)/Dc;return function(n,o){let s=n.pow(o,t);if(!n.eql(n.sqr(s),o))throw new Error("Cannot find square root");return s}}if(r%qf===Kf){let t=(r-Kf)/qf;return function(n,o){let s=n.mul(o,jr),i=n.pow(s,t),a=n.mul(o,i),c=n.mul(n.mul(a,jr),i),u=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(u),o))throw new Error("Cannot find square root");return u}}return r%Gy,Zy(r)}var jf=(r,t)=>(at(r,t)&lt)===lt,Jy=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Fc(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Jy.reduce((n,o)=>(n[o]="function",n),t);return Ne(r,e)}function Xy(r,t,e){if(e<wt)throw new Error("invalid exponent, negatives unsupported");if(e===wt)return r.ONE;if(e===lt)return t;let n=r.ONE,o=t;for(;e>wt;)e&lt&&(n=r.mul(n,o)),o=r.sqr(o),e>>=lt;return n}function Qy(r,t){let e=new Array(t.length),n=t.reduce((s,i,a)=>r.is0(i)?s:(e[a]=s,r.mul(s,i)),r.ONE),o=r.inv(n);return t.reduceRight((s,i,a)=>r.is0(i)?s:(e[a]=r.mul(s,e[a]),r.mul(s,i)),o),e}function Mc(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function br(r,t,e=!1,n={}){if(r<=wt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:o,nByteLength:s}=Mc(r,t);if(s>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,isLE:e,BITS:o,BYTES:s,MASK:co(o),ZERO:wt,ONE:lt,create:c=>at(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return wt<=c&&c<r},is0:c=>c===wt,isOdd:c=>(c&lt)===lt,neg:c=>at(-c,r),eql:(c,u)=>c===u,sqr:c=>at(c*c,r),add:(c,u)=>at(c+u,r),sub:(c,u)=>at(c-u,r),mul:(c,u)=>at(c*u,r),pow:(c,u)=>Xy(a,c,u),div:(c,u)=>at(c*vs(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>vs(c,r),sqrt:n.sqrt||(c=>(i||(i=Yy(r)),i(a,c))),invertBatch:c=>Qy(a,c),cmov:(c,u,l)=>l?u:c,toBytes:c=>e?Kr(c,s):xr(c,s),fromBytes:c=>{if(c.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+c.length);return e?wr(c):qe(c)}});return Object.freeze(a)}function Gf(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function Vc(r){let t=Gf(r);return t+Math.ceil(t/2)}function Wf(r,t,e=!1){let n=r.length,o=Gf(t),s=Vc(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?wr(r):qe(r),a=at(i,t-lt)+lt;return e?Kr(a,o):xr(a,o)}var Zf=BigInt(0),Es=BigInt(1);function Oc(r,t){let e=t.negate();return r?e:t}function Yf(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function $c(r,t){Yf(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function ew(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function rw(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var Hc=new WeakMap,Jf=new WeakMap;function zc(r){return Jf.get(r)||1}function As(r,t){return{constTimeNegate:Oc,hasPrecomputes(e){return zc(e)!==1},unsafeLadder(e,n,o=r.ZERO){let s=e;for(;n>Zf;)n&Es&&(o=o.add(s)),s=s.double(),n>>=Es;return o},precomputeWindow(e,n){let{windows:o,windowSize:s}=$c(n,t),i=[],a=e,c=a;for(let u=0;u<o;u++){c=a,i.push(c);for(let l=1;l<s;l++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,o){let{windows:s,windowSize:i}=$c(e,t),a=r.ZERO,c=r.BASE,u=BigInt(2**e-1),l=2**e,f=BigInt(e);for(let d=0;d<s;d++){let h=d*i,g=Number(o&u);o>>=f,g>i&&(g-=l,o+=Es);let m=h,w=h+Math.abs(g)-1,x=d%2!==0,b=g<0;g===0?c=c.add(Oc(x,n[m])):a=a.add(Oc(b,n[w]))}return{p:a,f:c}},wNAFUnsafe(e,n,o,s=r.ZERO){let{windows:i,windowSize:a}=$c(e,t),c=BigInt(2**e-1),u=2**e,l=BigInt(e);for(let f=0;f<i;f++){let d=f*a;if(o===Zf)break;let h=Number(o&c);if(o>>=l,h>a&&(h-=u,o+=Es),h===0)continue;let g=n[d+Math.abs(h)-1];h<0&&(g=g.negate()),s=s.add(g)}return s},getPrecomputes(e,n,o){let s=Hc.get(n);return s||(s=this.precomputeWindow(n,e),e!==1&&Hc.set(n,o(s))),s},wNAFCached(e,n,o){let s=zc(e);return this.wNAF(s,this.getPrecomputes(s,e,o),n)},wNAFCachedUnsafe(e,n,o,s){let i=zc(e);return i===1?this.unsafeLadder(e,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,e,o),n,s)},setWindowSize(e,n){Yf(n,t),Jf.set(e,n),Hc.delete(e)}}}function Ss(r,t,e,n){if(ew(e,r),rw(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let o=r.ZERO,s=Rc(BigInt(e.length)),i=s>12?s-3:s>4?s-2:s?2:1,a=(1<<i)-1,c=new Array(a+1).fill(o),u=Math.floor((t.BITS-1)/i)*i,l=o;for(let f=u;f>=0;f-=i){c.fill(o);for(let h=0;h<n.length;h++){let g=n[h],m=Number(g>>BigInt(f)&BigInt(a));c[m]=c[m].add(e[h])}let d=o;for(let h=c.length-1,g=o;h>0;h--)g=g.add(c[h]),d=d.add(g);if(l=l.add(d),f!==0)for(let h=0;h<i;h++)l=l.double()}return l}function uo(r){return Fc(r.Fp),Ne(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Mc(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var ge=BigInt(0),Wt=BigInt(1),Bs=BigInt(2),nw=BigInt(8),ow={zip215:!0};function sw(r){let t=uo(r);return Ne(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Xf(r){let t=sw(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,u=Bs<<BigInt(a*8)-Wt,l=e.create,f=br(t.n,t.nBitLength),d=t.uvRatio||((B,A)=>{try{return{isValid:!0,value:e.sqrt(B*e.inv(A))}}catch{return{isValid:!1,value:ge}}}),h=t.adjustScalarBytes||(B=>B),g=t.domain||((B,A,T)=>{if(me("phflag",T),A.length||T)throw new Error("Contexts/pre-hash are not supported");return B});function m(B,A){Gt("coordinate "+B,A,ge,u)}function w(B){if(!(B instanceof y))throw new Error("ExtendedPoint expected")}let x=qr((B,A)=>{let{ex:T,ey:F,ez:z}=B,K=B.is0();A==null&&(A=K?nw:e.inv(z));let W=l(T*A),Y=l(F*A),q=l(z*A);if(K)return{x:ge,y:Wt};if(q!==Wt)throw new Error("invZ was invalid");return{x:W,y:Y}}),b=qr(B=>{let{a:A,d:T}=t;if(B.is0())throw new Error("bad point: ZERO");let{ex:F,ey:z,ez:K,et:W}=B,Y=l(F*F),q=l(z*z),ot=l(K*K),ut=l(ot*ot),bt=l(Y*A),vt=l(ot*l(bt+q)),It=l(ut+l(T*l(Y*q)));if(vt!==It)throw new Error("bad point: equation left != right (1)");let Lt=l(F*z),Kt=l(K*W);if(Lt!==Kt)throw new Error("bad point: equation left != right (2)");return!0});class y{constructor(A,T,F,z){this.ex=A,this.ey=T,this.ez=F,this.et=z,m("x",A),m("y",T),m("z",F),m("t",z),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(A){if(A instanceof y)throw new Error("extended point not allowed");let{x:T,y:F}=A||{};return m("x",T),m("y",F),new y(T,F,Wt,l(T*F))}static normalizeZ(A){let T=e.invertBatch(A.map(F=>F.ez));return A.map((F,z)=>F.toAffine(T[z])).map(y.fromAffine)}static msm(A,T){return Ss(y,f,A,T)}_setWindowSize(A){N.setWindowSize(this,A)}assertValidity(){b(this)}equals(A){w(A);let{ex:T,ey:F,ez:z}=this,{ex:K,ey:W,ez:Y}=A,q=l(T*Y),ot=l(K*z),ut=l(F*Y),bt=l(W*z);return q===ot&&ut===bt}is0(){return this.equals(y.ZERO)}negate(){return new y(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:A}=t,{ex:T,ey:F,ez:z}=this,K=l(T*T),W=l(F*F),Y=l(Bs*l(z*z)),q=l(A*K),ot=T+F,ut=l(l(ot*ot)-K-W),bt=q+W,vt=bt-Y,It=q-W,Lt=l(ut*vt),Kt=l(bt*It),Ot=l(ut*It),_e=l(vt*bt);return new y(Lt,Kt,_e,Ot)}add(A){w(A);let{a:T,d:F}=t,{ex:z,ey:K,ez:W,et:Y}=this,{ex:q,ey:ot,ez:ut,et:bt}=A;if(T===BigInt(-1)){let Wl=l((K-z)*(ot+q)),Zl=l((K+z)*(ot-q)),Fa=l(Zl-Wl);if(Fa===ge)return this.double();let Yl=l(W*Bs*bt),Jl=l(Y*Bs*ut),Xl=Jl+Yl,Ql=Zl+Wl,tf=Jl-Yl,Em=l(Xl*Fa),Am=l(Ql*tf),Sm=l(Xl*tf),Bm=l(Fa*Ql);return new y(Em,Am,Bm,Sm)}let vt=l(z*q),It=l(K*ot),Lt=l(Y*F*bt),Kt=l(W*ut),Ot=l((z+K)*(q+ot)-vt-It),_e=Kt-Lt,Ve=Kt+Lt,Wn=l(It-T*vt),wm=l(Ot*_e),xm=l(Ve*Wn),bm=l(Ot*Wn),vm=l(_e*Ve);return new y(wm,xm,vm,bm)}subtract(A){return this.add(A.negate())}wNAF(A){return N.wNAFCached(this,A,y.normalizeZ)}multiply(A){let T=A;Gt("scalar",T,Wt,n);let{p:F,f:z}=this.wNAF(T);return y.normalizeZ([F,z])[0]}multiplyUnsafe(A,T=y.ZERO){let F=A;return Gt("scalar",F,ge,n),F===ge?_:this.is0()||F===Wt?this:N.wNAFCachedUnsafe(this,F,y.normalizeZ,T)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return N.unsafeLadder(this,n).is0()}toAffine(A){return x(this,A)}clearCofactor(){let{h:A}=t;return A===Wt?this:this.multiplyUnsafe(A)}static fromHex(A,T=!1){let{d:F,a:z}=t,K=e.BYTES;A=dt("pointHex",A,K),me("zip215",T);let W=A.slice(),Y=A[K-1];W[K-1]=Y&-129;let q=wr(W),ot=T?u:e.ORDER;Gt("pointHex.y",q,ge,ot);let ut=l(q*q),bt=l(ut-Wt),vt=l(F*ut-z),{isValid:It,value:Lt}=d(bt,vt);if(!It)throw new Error("Point.fromHex: invalid y coordinate");let Kt=(Lt&Wt)===Wt,Ot=(Y&128)!==0;if(!T&&Lt===ge&&Ot)throw new Error("Point.fromHex: x=0 and x_0=1");return Ot!==Kt&&(Lt=l(-Lt)),y.fromAffine({x:Lt,y:q})}static fromPrivateKey(A){return k(A).point}toRawBytes(){let{x:A,y:T}=this.toAffine(),F=Kr(T,e.BYTES);return F[F.length-1]|=A&Wt?128:0,F}toHex(){return Ke(this.toRawBytes())}}y.BASE=new y(t.Gx,t.Gy,Wt,l(t.Gx*t.Gy)),y.ZERO=new y(ge,Wt,Wt,ge);let{BASE:S,ZERO:_}=y,N=As(y,a*8);function E(B){return at(B,n)}function v(B){return E(wr(B))}function k(B){let A=e.BYTES;B=dt("private key",B,A);let T=dt("hashed private key",s(B),2*A),F=h(T.slice(0,A)),z=T.slice(A,2*A),K=v(F),W=S.multiply(K),Y=W.toRawBytes();return{head:F,prefix:z,scalar:K,point:W,pointBytes:Y}}function O(B){return k(B).pointBytes}function D(B=new Uint8Array,...A){let T=je(...A);return v(s(g(T,dt("context",B),!!o)))}function U(B,A,T={}){B=dt("message",B),o&&(B=o(B));let{prefix:F,scalar:z,pointBytes:K}=k(A),W=D(T.context,F,B),Y=S.multiply(W).toRawBytes(),q=D(T.context,Y,K,B),ot=E(W+q*z);Gt("signature.s",ot,ge,n);let ut=je(Y,Kr(ot,e.BYTES));return dt("result",ut,e.BYTES*2)}let P=ow;function C(B,A,T,F=P){let{context:z,zip215:K}=F,W=e.BYTES;B=dt("signature",B,2*W),A=dt("message",A),T=dt("publicKey",T,W),K!==void 0&&me("zip215",K),o&&(A=o(A));let Y=wr(B.slice(W,2*W)),q,ot,ut;try{q=y.fromHex(T,K),ot=y.fromHex(B.slice(0,W),K),ut=S.multiplyUnsafe(Y)}catch{return!1}if(!K&&q.isSmallOrder())return!1;let bt=D(z,ot.toRawBytes(),q.toRawBytes(),A);return ot.add(q.multiplyUnsafe(bt)).subtract(ut).clearCofactor().equals(y.ZERO)}return S._setWindowSize(8),{CURVE:t,getPublicKey:O,sign:U,verify:C,ExtendedPoint:y,utils:{getExtendedPublicKey:k,randomPrivateKey:()=>i(e.BYTES),precompute(B=8,A=y.BASE){return A._setWindowSize(B),A.multiply(BigInt(3)),A}}}}var Kc=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Qf=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),jE=BigInt(0),iw=BigInt(1),th=BigInt(2),GE=BigInt(3),aw=BigInt(5),cw=BigInt(8);function uw(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=Kc,a=r*r%s*r%s,c=ft(a,th,s)*a%s,u=ft(c,iw,s)*r%s,l=ft(u,aw,s)*u%s,f=ft(l,t,s)*l%s,d=ft(f,e,s)*f%s,h=ft(d,n,s)*d%s,g=ft(h,o,s)*h%s,m=ft(g,o,s)*h%s,w=ft(m,t,s)*l%s;return{pow_p_5_8:ft(w,th,s)*r%s,b2:a}}function lw(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function fw(r,t){let e=Kc,n=at(t*t*t,e),o=at(n*n*t,e),s=uw(r*o).pow_p_5_8,i=at(r*n*s,e),a=at(t*i*i,e),c=i,u=at(i*Qf,e),l=a===r,f=a===at(-r,e),d=a===at(-r*Qf,e);return l&&(i=c),(f||d)&&(i=u),jf(i,e)&&(i=at(-i,e)),{isValid:l||f,value:i}}var hw=br(Kc,void 0,!0),dw={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:hw,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:cw,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:$f,randomBytes:gs,adjustScalarBytes:lw,uvRatio:fw},eh=Xf(dw);var ks=32;function rh(r,t,e){return eh.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var Is=class{type="Ed25519";raw;constructor(t){this.raw=qc(t,ks)}toMultihash(){return jt.digest(_s(this))}toCID(){return $.createV1(114,this.toMultihash())}toString(){return it.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:st(this.raw,t.raw)}verify(t,e){return rh(this.raw,e,t)}};function jc(r){return r=qc(r,ks),new Is(r)}function qc(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new Et(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var xt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(xt||(xt={}));var Gc;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(Gc||(Gc={}));(function(r){r.codec=()=>so(Gc)})(xt||(xt={}));var Le;(function(r){let t;r.codec=()=>(t==null&&(t=wn((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),xt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.Type=xt.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>gn(e,r.codec()),r.decode=(e,n)=>fn(e,r.codec(),n)})(Le||(Le={}));var Wc;(function(r){let t;r.codec=()=>(t==null&&(t=wn((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),xt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.Type=xt.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>gn(e,r.codec()),r.decode=(e,n)=>fn(e,r.codec(),n)})(Wc||(Wc={}));var bo={};gt(bo,{MAX_RSA_KEY_SIZE:()=>xi,generateRSAKeyPair:()=>td,jwkToJWKKeyPair:()=>ed,jwkToPkcs1:()=>Cw,jwkToPkix:()=>nu,jwkToRSAPrivateKey:()=>Qh,pkcs1ToJwk:()=>Yh,pkcs1ToRSAPrivateKey:()=>Xh,pkixToJwk:()=>Jh,pkixToRSAPublicKey:()=>ou});var mw=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),vr=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Er=new Uint32Array(64),Zc=class extends En{constructor(){super(64,32,8,!1),this.A=vr[0]|0,this.B=vr[1]|0,this.C=vr[2]|0,this.D=vr[3]|0,this.E=vr[4]|0,this.F=vr[5]|0,this.G=vr[6]|0,this.H=vr[7]|0}get(){let{A:t,B:e,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[t,e,n,o,s,i,a,c]}set(t,e,n,o,s,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)Er[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let d=Er[f-15],h=Er[f-2],g=pe(d,7)^pe(d,18)^d>>>3,m=pe(h,17)^pe(h,19)^h>>>10;Er[f]=m+Er[f-7]+g+Er[f-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:u,H:l}=this;for(let f=0;f<64;f++){let d=pe(a,6)^pe(a,11)^pe(a,25),h=l+d+Mf(a,c,u)+mw[f]+Er[f]|0,m=(pe(n,2)^pe(n,13)^pe(n,22))+Vf(n,o,s)|0;l=u,u=c,c=a,a=i+h|0,i=s,s=o,o=n,n=h+m|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,l=l+this.H|0,this.set(n,o,s,i,a,c,u,l)}roundClean(){Er.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Sn=ms(()=>new Zc);var Z=Rr(sh());function Gr(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function Ar(r,t,e=-1){let n=e,o=r,s=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),s=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),s=n}let u=new Uint8Array(c);for(let l=a-1;l>=0;l--){let f=Math.pow(2,l*t);u[s-l-1]=Math.floor(o/f),o-=u[s-l-1]*f}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Ns(...r){let t=0,e=0;for(let s of r)t+=s.length;let n=new ArrayBuffer(t),o=new Uint8Array(n);for(let s of r)o.set(s,e),e+=s.length;return o}function Jc(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=Gr(e,8),o=new ArrayBuffer(this.valueHex.byteLength),s=new Uint8Array(o);for(let a=0;a<this.valueHex.byteLength;a++)s[a]=r[a];return s[0]&=127,Gr(s,8)-n}function ih(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=Ar(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=Ar(t,8,n),s=new Uint8Array(o);if(s[0]&128){let i=o.slice(0),a=new Uint8Array(i);o=new ArrayBuffer(o.byteLength+1),s=new Uint8Array(o);for(let c=0;c<i.byteLength;c++)s[c+1]=a[c];s[0]=0}return o}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function ah(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let o=0;o<e.length;o++)if(e[o]!==n[o])return!1;return!0}function Zt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,o=new Array(n);for(let i=0;i<n;i++)o[i]="0";return o.join("").concat(e)}var g8=Math.log(2);function Ls(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Xc(r){let t=0,e=0;for(let o=0;o<r.length;o++){let s=r[o];t+=s.byteLength}let n=new Uint8Array(t);for(let o=0;o<r.length;o++){let s=r[o];n.set(new Uint8Array(s),e),e+=s.byteLength}return n.buffer}function Je(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var fo=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Xc(this.items)}},lo=[new Uint8Array([1])],ch="0123456789";var Tn="",ye=new ArrayBuffer(0),Qc=new Uint8Array(0),ho="EndOfContent",lh="OCTET STRING",fh="BIT STRING";function Xe(r){var t;return t=class extends r{constructor(...n){var o;super(...n);let s=n[0]||{};this.isHexOnly=(o=s.isHexOnly)!==null&&o!==void 0?o:!1,this.valueHexView=s.valueHex?Z.BufferSourceConverter.toUint8Array(s.valueHex):Qc}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,o,s){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Je(this,i,o,s))return-1;let a=o+s;return this.valueHexView=i.subarray(o,a),this.valueHexView.length?(this.blockLength=s,a):(this.warnings.push("Zero buffer length"),o)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",ye)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Z.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var We=class{constructor({blockLength:t=0,error:e=Tn,warnings:n=[],valueBeforeDecode:o=Qc}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=Z.BufferSourceConverter.toUint8Array(o)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:Z.Convert.ToHex(this.valueBeforeDecodeView)}}};We.NAME="baseBlock";var Dt=class extends We{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};Dt.NAME="valueBlock";var Ps=class extends Xe(We){constructor({idBlock:t={}}={}){var e,n,o,s;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?Z.BufferSourceConverter.toUint8Array(t.valueHex):Qc,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(o=t.tagNumber)!==null&&o!==void 0?o:-1,this.isConstructed=(s=t.isConstructed)!==null&&s!==void 0?s:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",ye}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let o=new Uint8Array(1);if(!t){let s=this.tagNumber;s&=31,e|=s,o[0]=e}return o.buffer}if(!this.isHexOnly){let o=Ar(this.tagNumber,7),s=new Uint8Array(o),i=o.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=s[c]|128;a[i]=s[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let o=this.valueHexView;for(let s=0;s<o.length-1;s++)n[s+1]=o[s]|128;n[this.valueHexView.byteLength]=o[o.length-1]}return n.buffer}fromBER(t,e,n){let o=Z.BufferSourceConverter.toUint8Array(t);if(!Je(this,o,e,n))return-1;let s=o.subarray(e,e+n);if(s.length===0)return this.error="Zero buffer length",-1;switch(s[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(s[0]&32)===32,this.isHexOnly=!1;let a=s[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,u=this.valueHexView=new Uint8Array(255),l=255;for(;s[c]&128;){if(u[c-1]=s[c]&127,c++,c>=s.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let d=new Uint8Array(l);for(let h=0;h<u.length;h++)d[h]=u[h];u=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,u[c-1]=s[c]&127;let f=new Uint8Array(c);for(let d=0;d<c;d++)f[d]=u[d];u=this.valueHexView=new Uint8Array(c),u.set(f),this.blockLength<=9?this.tagNumber=Gr(u,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};Ps.NAME="identificationBlock";var Rs=class extends We{constructor({lenBlock:t={}}={}){var e,n,o;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(o=t.length)!==null&&o!==void 0?o:0}fromBER(t,e,n){let o=Z.BufferSourceConverter.toUint8Array(t);if(!Je(this,o,e,n))return-1;let s=o.subarray(e,e+n);if(s.length===0)return this.error="Zero buffer length",-1;if(s[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=s[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(s[0]&128),this.longFormUsed===!1)return this.length=s[0],this.blockLength=1,e+this.blockLength;let i=s[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>s.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=o.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Gr(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let o=Ar(this.length,8);if(o.byteLength>127)return this.error="Too big length",ye;if(e=new ArrayBuffer(o.byteLength+1),t)return e;let s=new Uint8Array(o);n=new Uint8Array(e),n[0]=o.byteLength|128;for(let i=0;i<o.byteLength;i++)n[i+1]=s[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Rs.NAME="lengthBlock";var M={},Tt=class extends We{constructor({name:t=Tn,optional:e=!1,primitiveSchema:n,...o}={},s){super(o),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Ps(o),this.lenBlock=new Rs(o),this.valueBlock=s?new s(o):new Dt(o)}fromBER(t,e,n){let o=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return o===-1?(this.error=this.valueBlock.error,o):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),o)}toBER(t,e){let n=e||new fo;e||hh(this);let o=this.idBlock.toBER(t);if(n.write(o),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let s=this.valueBlock.toBER(t);this.lenBlock.length=s.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(s)}return e?ye:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():Z.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${Z.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return ah(e,n)}};Tt.NAME="BaseBlock";function hh(r){if(r instanceof M.Constructed)for(let t of r.valueBlock.value)hh(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Us=class extends Tt{constructor({value:t=Tn,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let o=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return o===-1?(this.error=this.valueBlock.error,o):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),o)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};Us.NAME="BaseStringBlock";var Ds=class extends Xe(Dt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Ds.NAME="PrimitiveValueBlock";var dh,Fs=class extends Tt{constructor(t={}){super(t,Ds),this.idBlock.isConstructed=!1}};dh=Fs;M.Primitive=dh;Fs.NAME="PRIMITIVE";function Sw(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function yi(r,t=0,e=r.length){let n=t,o=new Tt({},Dt),s=new We;if(!Je(s,r,t,e))return o.error=s.error,{offset:-1,result:o};if(!r.subarray(t,t+e).length)return o.error="Zero buffer length",{offset:-1,result:o};let a=o.idBlock.fromBER(r,t,e);if(o.idBlock.warnings.length&&o.warnings.concat(o.idBlock.warnings),a===-1)return o.error=o.idBlock.error,{offset:-1,result:o};if(t=a,e-=o.idBlock.blockLength,a=o.lenBlock.fromBER(r,t,e),o.lenBlock.warnings.length&&o.warnings.concat(o.lenBlock.warnings),a===-1)return o.error=o.lenBlock.error,{offset:-1,result:o};if(t=a,e-=o.lenBlock.blockLength,!o.idBlock.isConstructed&&o.lenBlock.isIndefiniteForm)return o.error="Indefinite length form used for primitive encoding form",{offset:-1,result:o};let c=Tt;switch(o.idBlock.tagClass){case 1:if(o.idBlock.tagNumber>=37&&o.idBlock.isHexOnly===!1)return o.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:o};switch(o.idBlock.tagNumber){case 0:if(o.idBlock.isConstructed&&o.lenBlock.length>0)return o.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:o};c=M.EndOfContent;break;case 1:c=M.Boolean;break;case 2:c=M.Integer;break;case 3:c=M.BitString;break;case 4:c=M.OctetString;break;case 5:c=M.Null;break;case 6:c=M.ObjectIdentifier;break;case 10:c=M.Enumerated;break;case 12:c=M.Utf8String;break;case 13:c=M.RelativeObjectIdentifier;break;case 14:c=M.TIME;break;case 15:return o.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:o};case 16:c=M.Sequence;break;case 17:c=M.Set;break;case 18:c=M.NumericString;break;case 19:c=M.PrintableString;break;case 20:c=M.TeletexString;break;case 21:c=M.VideotexString;break;case 22:c=M.IA5String;break;case 23:c=M.UTCTime;break;case 24:c=M.GeneralizedTime;break;case 25:c=M.GraphicString;break;case 26:c=M.VisibleString;break;case 27:c=M.GeneralString;break;case 28:c=M.UniversalString;break;case 29:c=M.CharacterString;break;case 30:c=M.BmpString;break;case 31:c=M.DATE;break;case 32:c=M.TimeOfDay;break;case 33:c=M.DateTime;break;case 34:c=M.Duration;break;default:{let u=o.idBlock.isConstructed?new M.Constructed:new M.Primitive;u.idBlock=o.idBlock,u.lenBlock=o.lenBlock,u.warnings=o.warnings,o=u}}break;case 2:case 3:case 4:default:c=o.idBlock.isConstructed?M.Constructed:M.Primitive}return o=Sw(o,c),a=o.fromBER(r,t,o.lenBlock.isIndefiniteForm?e:o.lenBlock.length),o.valueBeforeDecodeView=r.subarray(n,n+o.blockLength),{offset:a,result:o}}function tu(r){if(!r.byteLength){let t=new Tt({},Dt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return yi(Z.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Bw(r,t){return r?1:t}var Pe=class extends Dt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let o=Z.BufferSourceConverter.toUint8Array(t);if(!Je(this,o,e,n))return-1;if(this.valueBeforeDecodeView=o.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let s=e;for(;Bw(this.isIndefiniteForm,n)>0;){let i=yi(o,s,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(s=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===ho)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===ho?this.value.pop():this.warnings.push("No EndOfContent block encoded")),s}toBER(t,e){let n=e||new fo;for(let o=0;o<this.value.length;o++)this.value[o].toBER(t,n);return e?ye:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Pe.NAME="ConstructedValueBlock";var ph,Sr=class extends Tt{constructor(t={}){super(t,Pe),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let o=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return o===-1?(this.error=this.valueBlock.error,o):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),o)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
4
4
  `).map(o=>` ${o}`).join(`
5
5
  `));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
6
6
  ${t.join(`
7
- `)}`:`${e} :`}};kh=Br;M.Constructed=kh;Br.NAME="CONSTRUCTED";var Ks=class extends Dt{fromBER(t,e,n){return e}toBER(t){return we}};Ks.override="EndOfContentValueBlock";var Ih,qs=class extends Tt{constructor(t={}){super(t,Ks),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Ih=qs;M.EndOfContent=Ih;qs.NAME=mo;var _h,_n=class extends Tt{constructor(t={}){super(t,Dt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let o=new Uint8Array(n);o[0]=5,o[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};_h=_n;M.Null=_h;_n.NAME="NULL";var js=class extends Qe(Dt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=Z.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let o=Z.BufferSourceConverter.toUint8Array(t);return Xe(this,o,e,n)?(this.valueHexView=o.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,su.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};js.NAME="BooleanValueBlock";var Th,Gs=class extends Tt{constructor(t={}){super(t,js),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Th=Gs;M.Boolean=Th;Gs.NAME="BOOLEAN";var Ws=class extends Qe(Pe){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let o=0;if(this.isConstructed){if(this.isHexOnly=!1,o=Pe.prototype.fromBER.call(this,t,e,n),o===-1)return o;for(let s=0;s<this.value.length;s++){let i=this.value[s].constructor.NAME;if(i===mo){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Eh)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,o=super.fromBER(t,e,n),this.blockLength=n;return o}toBER(t,e){return this.isConstructed?Pe.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Ws.NAME="OctetStringValueBlock";var Ch,Zs=class r extends Tt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var o,s;(o=n.isConstructed)!==null&&o!==void 0||(n.isConstructed=!!(!((s=n.value)===null||s===void 0)&&s.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Ws),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let s=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(s.byteLength){let i=Ai(s,0,s.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?Br.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${Z.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return Z.BufferSourceConverter.concat(t)}};Ch=Zs;M.OctetString=Ch;Zs.NAME=Eh;var Ys=class extends Qe(Pe){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let o=-1;if(this.isConstructed){if(o=Pe.prototype.fromBER.call(this,t,e,n),o===-1)return o;for(let a of this.value){let c=a.constructor.NAME;if(c===mo){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Ah)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let u=a.valueBlock;if(this.unusedBits>0&&u.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=u.unusedBits}return o}let s=Z.BufferSourceConverter.toUint8Array(t);if(!Xe(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=Ai(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Pe.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return we;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};Ys.NAME="BitStringValueBlock";var Nh,Tn=class extends Tt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var o,s;(o=n.isConstructed)!==null&&o!==void 0||(n.isConstructed=!!(!((s=n.value)===null||s===void 0)&&s.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Ys),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Br.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let o of e)t.push(o.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};Nh=Tn;M.BitString=Nh;Tn.NAME=Ah;var Lh;function Hw(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),o=new Uint8Array(t),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,u=0,f=c<i?i:c,l=0;for(let d=f;d>=0;d--,l++){switch(!0){case l<a.length:u=s[i-l]+a[c-l]+e[0];break;default:u=s[i-l]+e[0]}switch(e[0]=u/10,!0){case l>=s.length:s=Fs(new Uint8Array([u%10]),s);break;default:s[i-l]=u%10}}return e[0]>0&&(s=Fs(e,s)),s}function vh(r){if(r>=ho.length)for(let t=ho.length;t<=r;t++){let e=new Uint8Array([0]),n=ho[t-1].slice(0);for(let o=n.length-1;o>=0;o--){let s=new Uint8Array([(n[o]<<1)+e[0]]);e[0]=s[0]/10,n[o]=s[0]%10}e[0]>0&&(n=Fs(e,n)),ho.push(n)}return ho[r]}function zw(r,t){let e=0,n=new Uint8Array(r),o=new Uint8Array(t),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,u,f=0;for(let l=c;l>=0;l--,f++)switch(u=s[i-f]-a[c-f]-e,!0){case u<0:e=1,s[i-f]=u+10;break;default:e=0,s[i-f]=u}if(e>0)for(let l=i-c+1;l>=0;l--,f++)if(u=s[i-f]-e,u<0)e=1,s[i-f]=u+10;else{e=0,s[i-f]=u;break}return s.slice()}var go=class extends Qe(Dt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=su.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(wh(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,o=0){let s=this.fromBER(t,e,n);if(s===-1)return s;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):o!==0&&i.length<o&&(o-i.length>1&&(o=i.length+1),this.valueHexView=i.subarray(o-i.length)),s}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let o=super.fromBER(t,e,n);return o===-1||this.setValueHex(),o}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,o,s=this.valueHexView,i="",a=!1;for(let c=s.byteLength-1;c>=0;c--){o=s[c];for(let u=0;u<8;u++){if((o&1)===1)switch(n){case t:e=zw(vh(n),e),i="-";break;default:e=Hw(e,vh(n))}n++,o>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=bh.charAt(e[c]));return a===!1&&(i+=bh.charAt(0)),i}};Lh=go;go.NAME="IntegerValueBlock";Object.defineProperty(Lh.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Uh,Ct=class r extends Tt{constructor(t={}){super(t,go),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Ms(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Ms();let e=BigInt(t),n=new po,o=e.toString(16).replace(/^-/,""),s=new Uint8Array(Z.Convert.FromHex(o));if(e<0){let a=new Uint8Array(s.length+(s[0]&128?1:0));a[0]|=128;let u=BigInt(`0x${Z.Convert.ToHex(a)}`)+e,f=Z.BufferSourceConverter.toUint8Array(Z.Convert.FromHex(u.toString(16)));f[0]|=128,n.write(f)}else s[0]&128&&n.write(new Uint8Array([0])),n.write(s);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};Uh=Ct;M.Integer=Uh;Ct.NAME="INTEGER";var Ph,Js=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Ph=Js;M.Enumerated=Ph;Js.NAME="ENUMERATED";var yo=class extends Qe(Dt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let o=Z.BufferSourceConverter.toUint8Array(t);if(!Xe(this,o,e,n))return-1;let s=o.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=s[a]&127,this.blockLength++,!!(s[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,s[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Yr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Ms();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let o=0;o<n.length;o++)n[o]=parseInt(e.slice(o*7,o*7+7),2)+(o+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let o=this.valueHexView,s=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)s[i]=o[i]|128;return s[this.blockLength-1]=o[this.blockLength-1],s.buffer}let e=Sr(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",we;let n=new Uint8Array(e.byteLength);if(!t){let o=new Uint8Array(e),s=e.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n}toString(){let t="";if(this.isHexOnly)t=Z.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};yo.NAME="sidBlock";var Xs=class extends Dt{constructor({value:t=Nn,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let o=e;for(;n>0;){let s=new yo;if(o=s.fromBER(t,o,n),o===-1)return this.blockLength=0,this.error=s.error,o;this.value.length===0&&(s.isFirstSid=!0),this.blockLength+=s.blockLength,n-=s.blockLength,this.value.push(s)}return o}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let o=this.value[n].toBER(t);if(o.byteLength===0)return this.error=this.value[n].error,we;e.push(o)}return iu(e)}fromString(t){this.value=[];let e=0,n=0,o="",s=!1;do if(n=t.indexOf(".",e),n===-1?o=t.substring(e):o=t.substring(e,n),e=n+1,s){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(o,10);if(isNaN(c))return;i.valueDec=c+a,s=!1}else{let i=new yo;if(o>Number.MAX_SAFE_INTEGER){Ms();let a=BigInt(o);i.valueBigInt=a}else if(i.valueDec=parseInt(o,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,s=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let o=this.value[n].toString();n!==0&&(t=`${t}.`),e?(o=`{${o}}`,this.value[n].isFirstSid?t=`2.{${o} - 80}`:t+=o):t+=o}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Xs.NAME="ObjectIdentifierValueBlock";var Rh,Cn=class extends Tt{constructor(t={}){super(t,Xs),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Rh=Cn;M.ObjectIdentifier=Rh;Cn.NAME="OBJECT IDENTIFIER";var wo=class extends Qe(Ze){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let o=Z.BufferSourceConverter.toUint8Array(t);if(!Xe(this,o,e,n))return-1;let s=o.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=s[a]&127,this.blockLength++,!!(s[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,s[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Yr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let o=this.valueHexView,s=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)s[i]=o[i]|128;return s[this.blockLength-1]=o[this.blockLength-1],s.buffer}let e=Sr(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",we;let n=new Uint8Array(e.byteLength);if(!t){let o=new Uint8Array(e),s=e.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n.buffer}toString(){let t="";return this.isHexOnly?t=Z.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};wo.NAME="relativeSidBlock";var Qs=class extends Dt{constructor({value:t=Nn,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let o=e;for(;n>0;){let s=new wo;if(o=s.fromBER(t,o,n),o===-1)return this.blockLength=0,this.error=s.error,o;this.blockLength+=s.blockLength,n-=s.blockLength,this.value.push(s)}return o}toBER(t,e){let n=[];for(let o=0;o<this.value.length;o++){let s=this.value[o].toBER(t);if(s.byteLength===0)return this.error=this.value[o].error,we;n.push(s)}return iu(n)}fromString(t){this.value=[];let e=0,n=0,o="";do{n=t.indexOf(".",e),n===-1?o=t.substring(e):o=t.substring(e,n),e=n+1;let s=new wo;if(s.valueDec=parseInt(o,10),isNaN(s.valueDec))return!0;this.value.push(s)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let o=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(o=`{${o}}`),t+=o}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Qs.NAME="RelativeObjectIdentifierValueBlock";var Dh,ti=class extends Tt{constructor(t={}){super(t,Qs),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Dh=ti;M.RelativeObjectIdentifier=Dh;ti.NAME="RelativeObjectIdentifier";var Fh,Ye=class extends Br{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Fh=Ye;M.Sequence=Fh;Ye.NAME="SEQUENCE";var Mh,ei=class extends Br{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Mh=ei;M.Set=Mh;ei.NAME="SET";var ri=class extends Qe(Dt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Nn}toJSON(){return{...super.toJSON(),value:this.value}}};ri.NAME="StringValueBlock";var ni=class extends ri{};ni.NAME="SimpleStringValueBlock";var Ht=class extends $s{constructor({...t}={}){super(t,ni)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,Z.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let o=0;o<e;o++)n[o]=t.charCodeAt(o);this.valueBlock.value=t}};Ht.NAME="SIMPLE STRING";var oi=class extends Ht{fromBuffer(t){this.valueBlock.valueHexView=Z.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=Z.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=Z.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(Z.Convert.FromUtf8String(t)),this.valueBlock.value=t}};oi.NAME="Utf8StringValueBlock";var Vh,Je=class extends oi{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Vh=Je;M.Utf8String=Vh;Je.NAME="UTF8String";var si=class extends Ht{fromBuffer(t){this.valueBlock.value=Z.Convert.ToUtf16String(t),this.valueBlock.valueHexView=Z.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(Z.Convert.FromUtf16String(t))}};si.NAME="BmpStringValueBlock";var Oh,ii=class extends si{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Oh=ii;M.BmpString=Oh;ii.NAME="BMPString";var ai=class extends Ht{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let o=0;o<n.length;o+=4)n[o]=n[o+3],n[o+1]=n[o+2],n[o+2]=0,n[o+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let o=0;o<e;o++){let s=Sr(t.charCodeAt(o),8),i=new Uint8Array(s);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[o*4+c+a]=i[c]}this.valueBlock.value=t}};ai.NAME="UniversalStringValueBlock";var $h,ci=class extends ai{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};$h=ci;M.UniversalString=$h;ci.NAME="UniversalString";var Hh,ui=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Hh=ui;M.NumericString=Hh;ui.NAME="NumericString";var zh,li=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};zh=li;M.PrintableString=zh;li.NAME="PrintableString";var Kh,fi=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Kh=fi;M.TeletexString=Kh;fi.NAME="TeletexString";var qh,hi=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};qh=hi;M.VideotexString=qh;hi.NAME="VideotexString";var jh,di=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};jh=di;M.IA5String=jh;di.NAME="IA5String";var Gh,pi=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Gh=pi;M.GraphicString=Gh;pi.NAME="GraphicString";var Wh,xo=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Wh=xo;M.VisibleString=Wh;xo.NAME="VisibleString";var Zh,mi=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Zh=mi;M.GeneralString=Zh;mi.NAME="GeneralString";var Yh,gi=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Yh=gi;M.CharacterString=Yh;gi.NAME="CharacterString";var Jh,bo=class extends xo{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let o=0;o<t.length;o++)this.valueBlock.valueHexView[o]=t.charCodeAt(o)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,Z.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let o=0;o<t.length;o++)n[o]=t.charCodeAt(o);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let o=parseInt(n[1],10);o>=50?this.year=1900+o:this.year=2e3+o,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Zt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Zt(this.month,2),e[2]=Zt(this.day,2),e[3]=Zt(this.hour,2),e[4]=Zt(this.minute,2),e[5]=Zt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};Jh=bo;M.UTCTime=Jh;bo.NAME="UTCTime";var Xh,yi=class extends bo{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",o="",s=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let l=new Number(t[t.length-1]);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let l=1,d=n.indexOf("+"),h="";if(d===-1&&(d=n.indexOf("-"),l=-1),d!==-1){if(h=n.substring(d+1),n=n.substring(0,d),h.length!==2&&h.length!==4)throw new Error("Wrong input string for conversion");let g=parseInt(h.substring(0,2),10);if(isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*g,h.length===4){if(g=parseInt(h.substring(2,4),10),isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");c=l*g}}}let u=n.indexOf(".");if(u===-1&&(u=n.indexOf(",")),u!==-1){let l=new Number(`0${n.substring(u)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");s=l.valueOf(),o=n.substring(0,u)}else o=n;switch(!0){case o.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,u!==-1)throw new Error("Wrong input string for conversion");break;case o.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let l=60*s;this.minute=Math.floor(l),l=60*(l-this.minute),this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case o.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let l=60*s;this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case o.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let l=1e3*s;this.millisecond=Math.floor(l)}break;default:throw new Error("Wrong input string for conversion")}let f=i.exec(o);if(f===null)throw new Error("Wrong input string for conversion");for(let l=1;l<f.length;l++)switch(l){case 1:this.year=parseInt(f[l],10);break;case 2:this.month=parseInt(f[l],10);break;case 3:this.day=parseInt(f[l],10);break;case 4:this.hour=parseInt(f[l],10)+a;break;case 5:this.minute=parseInt(f[l],10)+c;break;case 6:this.second=parseInt(f[l],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let l=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=l.getUTCFullYear(),this.month=l.getUTCMonth(),this.day=l.getUTCDay(),this.hour=l.getUTCHours(),this.minute=l.getUTCMinutes(),this.second=l.getUTCSeconds(),this.millisecond=l.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Zt(this.year,4)),e.push(Zt(this.month,2)),e.push(Zt(this.day,2)),e.push(Zt(this.hour,2)),e.push(Zt(this.minute,2)),e.push(Zt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Zt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Xh=yi;M.GeneralizedTime=Xh;yi.NAME="GeneralizedTime";var Qh,wi=class extends Je{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Qh=wi;M.DATE=Qh;wi.NAME="DATE";var td,xi=class extends Je{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};td=xi;M.TimeOfDay=td;xi.NAME="TimeOfDay";var ed,bi=class extends Je{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};ed=bi;M.DateTime=ed;bi.NAME="DateTime";var rd,vi=class extends Je{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};rd=vi;M.Duration=rd;vi.NAME="Duration";var nd,Ei=class extends Je{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};nd=Ei;M.TIME=nd;Ei.NAME="TIME";function nt(r,t="utf8"){let e=ds[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var vo=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Si=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var od={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Si("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var kr=od;async function sd(r){let t=await kr.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await qw(t);return{privateKey:e[0],publicKey:e[1]}}async function id(r,t){let e=await kr.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await kr.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function ad(r,t,e){let n=await kr.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return kr.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function qw(r){if(r.privateKey==null||r.publicKey==null)throw new Et("Private and public key are required");return Promise.all([kr.get().subtle.exportKey("jwk",r.privateKey),kr.get().subtle.exportKey("jwk",r.publicKey)])}function uu(r){if(r.kty!=="RSA")throw new Et("invalid key type");if(r.n==null)throw new Et("invalid key modulus");return K(r.n,"base64url").length*8}var Ln=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Eo.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return $.createV1(114,this._multihash)}toString(){return it.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:st(this.raw,t.raw)}verify(t,e){return ad(this._key,e,t)}},Ao=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Eo.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:st(this.raw,t.raw)}sign(t){return id(this._key,t)}};var Bi=8192,lu=18;function cd(r){let{result:t}=cu(r),e=t.valueBlock.value;return{n:Re(e[1]),e:Re(e[2]),d:Re(e[3]),p:Re(e[4]),q:Re(e[5]),dp:Re(e[6]),dq:Re(e[7]),qi:Re(e[8]),kty:"RSA",alg:"RS256"}}function jw(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new Et("JWK was missing components");let e=new Ye({value:[new Ct({value:0}),Ct.fromBigInt(De(K(r.n,"base64url"))),Ct.fromBigInt(De(K(r.e,"base64url"))),Ct.fromBigInt(De(K(r.d,"base64url"))),Ct.fromBigInt(De(K(r.p,"base64url"))),Ct.fromBigInt(De(K(r.q,"base64url"))),Ct.fromBigInt(De(K(r.dp,"base64url"))),Ct.fromBigInt(De(K(r.dq,"base64url"))),Ct.fromBigInt(De(K(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function ud(r){let{result:t}=cu(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:Re(e[0]),e:Re(e[1])}}function fu(r){if(r.n==null||r.e==null)throw new Et("JWK was missing components");let e=new Ye({value:[new Ye({value:[new Cn({value:"1.2.840.113549.1.1.1"}),new _n]}),new Tn({valueHex:new Ye({value:[Ct.fromBigInt(De(K(r.n,"base64url"))),Ct.fromBigInt(De(K(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Re(r){let t=r.valueBlock.valueHexView;for(;t[0]===0;)t=t.subarray(1);return nt(t,"base64url")}function De(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}function ld(r){let t=cd(r);return fd(t)}function hu(r){let t=ud(r);if(uu(t)>Bi)throw new an("Key size is too large");let e=Ps(Ue.encode({Type:xt.RSA,Data:r})),n=he(lu,e);return new Ln(t,n)}function fd(r){if(uu(r)>Bi)throw new Et("Key size is too large");let t=dd(r),e=Ps(Ue.encode({Type:xt.RSA,Data:fu(t.publicKey)})),n=he(lu,e);return new Ao(t.privateKey,new Ln(t.publicKey,n))}async function hd(r){if(r>Bi)throw new Et("Key size is too large");let t=await sd(r),e=Ps(Ue.encode({Type:xt.RSA,Data:fu(t.publicKey)})),n=he(lu,e);return new Ao(t.privateKey,new Ln(t.publicKey,n))}function dd(r){if(r==null)throw new Et("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var Gw=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Ir=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),_r=new Uint32Array(64),du=class extends Bn{constructor(){super(64,32,8,!1),this.A=Ir[0]|0,this.B=Ir[1]|0,this.C=Ir[2]|0,this.D=Ir[3]|0,this.E=Ir[4]|0,this.F=Ir[5]|0,this.G=Ir[6]|0,this.H=Ir[7]|0}get(){let{A:t,B:e,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[t,e,n,o,s,i,a,c]}set(t,e,n,o,s,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let l=0;l<16;l++,e+=4)_r[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let d=_r[l-15],h=_r[l-2],g=pe(d,7)^pe(d,18)^d>>>3,p=pe(h,17)^pe(h,19)^h>>>10;_r[l]=p+_r[l-7]+g+_r[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:u,H:f}=this;for(let l=0;l<64;l++){let d=pe(a,6)^pe(a,11)^pe(a,25),h=f+d+jf(a,c,u)+Gw[l]+_r[l]|0,p=(pe(n,2)^pe(n,13)^pe(n,22))+Gf(n,o,s)|0;f=u,u=c,c=a,a=i+h|0,i=s,s=o,o=n,n=h+p|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,f=f+this.H|0,this.set(n,o,s,i,a,c,u,f)}roundClean(){_r.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var pd=ys(()=>new du);var ki=class extends Sn{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,zf(t);let n=co(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let o=this.blockLen,s=new Uint8Array(o);s.set(n.length>o?t.create().update(n).digest():n);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=t.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),s.fill(0)}update(t){return An(this),this.iHash.update(t),this}digestInto(t){An(this),En(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return t=t,t.finished=o,t.destroyed=s,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},pu=(r,t,e)=>new ki(r,t).update(e).digest();pu.create=(r,t)=>new ki(r,t);function md(r){r.lowS!==void 0&&me("lowS",r.lowS),r.prehash!==void 0&&me("prehash",r.prehash)}function Ww(r){let t=fo(r);Le(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:o}=t;if(e){if(!n.eql(o,n.ZERO))throw new Error("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Zw,hexToBytes:Yw}=Es,tr={Err:class extends Error{constructor(t=""){super(t)}},_tlv:{encode:(r,t)=>{let{Err:e}=tr;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,o=qr(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?qr(o.length/2|128):"";return qr(r)+s+o+t},decode(r,t){let{Err:e}=tr,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let o=t[n++],s=!!(o&128),i=0;if(!s)i=o;else{let c=o&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let u=t.subarray(n,n+c);if(u.length!==c)throw new e("tlv.decode: length bytes not complete");if(u[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let f of u)i=i<<8|f;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=tr;if(r<er)throw new t("integer: negative integers are not allowed");let e=qr(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=tr;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Zw(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=tr,o=typeof r=="string"?Yw(r):r;kn(o);let{v:s,l:i}=n.decode(48,o);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,s),{v:u,l:f}=n.decode(2,c);if(f.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(u)}},hexFromSig(r){let{_tlv:t,_int:e}=tr,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}},er=BigInt(0),St=BigInt(1),b6=BigInt(2),gd=BigInt(3),v6=BigInt(4);function Jw(r){let t=Ww(r),{Fp:e}=t,n=vr(t.n,t.nBitLength),o=t.toBytes||((p,w,x)=>{let b=w.toAffine();return Ge(Uint8Array.from([4]),e.toBytes(b.x),e.toBytes(b.y))}),s=t.fromBytes||(p=>{let w=p.subarray(1),x=e.fromBytes(w.subarray(0,e.BYTES)),b=e.fromBytes(w.subarray(e.BYTES,2*e.BYTES));return{x,y:b}});function i(p){let{a:w,b:x}=t,b=e.sqr(p),y=e.mul(b,p);return e.add(e.add(y,e.mul(p,w)),x)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(p){return uo(p,St,t.n)}function c(p){let{allowedPrivateKeyLengths:w,nByteLength:x,wrapPrivateKey:b,n:y}=t;if(w&&typeof p!="bigint"){if(wr(p)&&(p=qe(p)),typeof p!="string"||!w.includes(p.length))throw new Error("invalid private key");p=p.padStart(x*2,"0")}let S;try{S=typeof p=="bigint"?p:je(dt("private key",p,x))}catch{throw new Error("invalid private key, expected hex or "+x+" bytes, got "+typeof p)}return b&&(S=at(S,y)),Gt("private key",S,St,y),S}function u(p){if(!(p instanceof d))throw new Error("ProjectivePoint expected")}let f=Wr((p,w)=>{let{px:x,py:b,pz:y}=p;if(e.eql(y,e.ONE))return{x,y:b};let S=p.is0();w==null&&(w=S?e.ONE:e.inv(y));let _=e.mul(x,w),N=e.mul(b,w),E=e.mul(y,w);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(E,e.ONE))throw new Error("invZ was invalid");return{x:_,y:N}}),l=Wr(p=>{if(p.is0()){if(t.allowInfinityPoint&&!e.is0(p.py))return;throw new Error("bad point: ZERO")}let{x:w,y:x}=p.toAffine();if(!e.isValid(w)||!e.isValid(x))throw new Error("bad point: x or y not FE");let b=e.sqr(x),y=i(w);if(!e.eql(b,y))throw new Error("bad point: equation left != right");if(!p.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class d{constructor(w,x,b){if(this.px=w,this.py=x,this.pz=b,w==null||!e.isValid(w))throw new Error("x required");if(x==null||!e.isValid(x))throw new Error("y required");if(b==null||!e.isValid(b))throw new Error("z required");Object.freeze(this)}static fromAffine(w){let{x,y:b}=w||{};if(!w||!e.isValid(x)||!e.isValid(b))throw new Error("invalid affine point");if(w instanceof d)throw new Error("projective point not allowed");let y=S=>e.eql(S,e.ZERO);return y(x)&&y(b)?d.ZERO:new d(x,b,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(w){let x=e.invertBatch(w.map(b=>b.pz));return w.map((b,y)=>b.toAffine(x[y])).map(d.fromAffine)}static fromHex(w){let x=d.fromAffine(s(dt("pointHex",w)));return x.assertValidity(),x}static fromPrivateKey(w){return d.BASE.multiply(c(w))}static msm(w,x){return ks(d,n,w,x)}_setWindowSize(w){g.setWindowSize(this,w)}assertValidity(){l(this)}hasEvenY(){let{y:w}=this.toAffine();if(e.isOdd)return!e.isOdd(w);throw new Error("Field doesn't support isOdd")}equals(w){u(w);let{px:x,py:b,pz:y}=this,{px:S,py:_,pz:N}=w,E=e.eql(e.mul(x,N),e.mul(S,y)),v=e.eql(e.mul(b,N),e.mul(_,y));return E&&v}negate(){return new d(this.px,e.neg(this.py),this.pz)}double(){let{a:w,b:x}=t,b=e.mul(x,gd),{px:y,py:S,pz:_}=this,N=e.ZERO,E=e.ZERO,v=e.ZERO,k=e.mul(y,y),O=e.mul(S,S),D=e.mul(_,_),R=e.mul(y,S);return R=e.add(R,R),v=e.mul(y,_),v=e.add(v,v),N=e.mul(w,v),E=e.mul(b,D),E=e.add(N,E),N=e.sub(O,E),E=e.add(O,E),E=e.mul(N,E),N=e.mul(R,N),v=e.mul(b,v),D=e.mul(w,D),R=e.sub(k,D),R=e.mul(w,R),R=e.add(R,v),v=e.add(k,k),k=e.add(v,k),k=e.add(k,D),k=e.mul(k,R),E=e.add(E,k),D=e.mul(S,_),D=e.add(D,D),k=e.mul(D,R),N=e.sub(N,k),v=e.mul(D,O),v=e.add(v,v),v=e.add(v,v),new d(N,E,v)}add(w){u(w);let{px:x,py:b,pz:y}=this,{px:S,py:_,pz:N}=w,E=e.ZERO,v=e.ZERO,k=e.ZERO,O=t.a,D=e.mul(t.b,gd),R=e.mul(x,S),U=e.mul(b,_),C=e.mul(y,N),L=e.add(x,b),B=e.add(S,_);L=e.mul(L,B),B=e.add(R,U),L=e.sub(L,B),B=e.add(x,y);let A=e.add(S,N);return B=e.mul(B,A),A=e.add(R,C),B=e.sub(B,A),A=e.add(b,y),E=e.add(_,N),A=e.mul(A,E),E=e.add(U,C),A=e.sub(A,E),k=e.mul(O,B),E=e.mul(D,C),k=e.add(E,k),E=e.sub(U,k),k=e.add(U,k),v=e.mul(E,k),U=e.add(R,R),U=e.add(U,R),C=e.mul(O,C),B=e.mul(D,B),U=e.add(U,C),C=e.sub(R,C),C=e.mul(O,C),B=e.add(B,C),R=e.mul(U,B),v=e.add(v,R),R=e.mul(A,B),E=e.mul(L,E),E=e.sub(E,R),R=e.mul(L,U),k=e.mul(A,k),k=e.add(k,R),new d(E,v,k)}subtract(w){return this.add(w.negate())}is0(){return this.equals(d.ZERO)}wNAF(w){return g.wNAFCached(this,w,d.normalizeZ)}multiplyUnsafe(w){let{endo:x,n:b}=t;Gt("scalar",w,er,b);let y=d.ZERO;if(w===er)return y;if(this.is0()||w===St)return this;if(!x||g.hasPrecomputes(this))return g.wNAFCachedUnsafe(this,w,d.normalizeZ);let{k1neg:S,k1:_,k2neg:N,k2:E}=x.splitScalar(w),v=y,k=y,O=this;for(;_>er||E>er;)_&St&&(v=v.add(O)),E&St&&(k=k.add(O)),O=O.double(),_>>=St,E>>=St;return S&&(v=v.negate()),N&&(k=k.negate()),k=new d(e.mul(k.px,x.beta),k.py,k.pz),v.add(k)}multiply(w){let{endo:x,n:b}=t;Gt("scalar",w,St,b);let y,S;if(x){let{k1neg:_,k1:N,k2neg:E,k2:v}=x.splitScalar(w),{p:k,f:O}=this.wNAF(N),{p:D,f:R}=this.wNAF(v);k=g.constTimeNegate(_,k),D=g.constTimeNegate(E,D),D=new d(e.mul(D.px,x.beta),D.py,D.pz),y=k.add(D),S=O.add(R)}else{let{p:_,f:N}=this.wNAF(w);y=_,S=N}return d.normalizeZ([y,S])[0]}multiplyAndAddUnsafe(w,x,b){let y=d.BASE,S=(N,E)=>E===er||E===St||!N.equals(y)?N.multiplyUnsafe(E):N.multiply(E),_=S(this,x).add(S(w,b));return _.is0()?void 0:_}toAffine(w){return f(this,w)}isTorsionFree(){let{h:w,isTorsionFree:x}=t;if(w===St)return!0;if(x)return x(d,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:w,clearCofactor:x}=t;return w===St?this:x?x(d,this):this.multiplyUnsafe(t.h)}toRawBytes(w=!0){return me("isCompressed",w),this.assertValidity(),o(d,this,w)}toHex(w=!0){return me("isCompressed",w),qe(this.toRawBytes(w))}}d.BASE=new d(t.Gx,t.Gy,e.ONE),d.ZERO=new d(e.ZERO,e.ONE,e.ZERO);let h=t.nBitLength,g=Bs(d,t.endo?Math.ceil(h/2):h);return{CURVE:t,ProjectivePoint:d,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function Xw(r){let t=fo(r);return Le(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function yd(r){let t=Xw(r),{Fp:e,n}=t,o=e.BYTES+1,s=2*e.BYTES+1;function i(C){return at(C,n)}function a(C){return As(C,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:u,weierstrassEquation:f,isWithinCurveOrder:l}=Jw({...t,toBytes(C,L,B){let A=L.toAffine(),T=e.toBytes(A.x),F=Ge;return me("isCompressed",B),B?F(Uint8Array.from([L.hasEvenY()?2:3]),T):F(Uint8Array.from([4]),T,e.toBytes(A.y))},fromBytes(C){let L=C.length,B=C[0],A=C.subarray(1);if(L===o&&(B===2||B===3)){let T=je(A);if(!uo(T,St,e.ORDER))throw new Error("Point is not on curve");let F=f(T),H;try{H=e.sqrt(F)}catch(Y){let q=Y instanceof Error?": "+Y.message:"";throw new Error("Point is not on curve"+q)}let z=(H&St)===St;return(B&1)===1!==z&&(H=e.neg(H)),{x:T,y:H}}else if(L===s&&B===4){let T=e.fromBytes(A.subarray(0,e.BYTES)),F=e.fromBytes(A.subarray(e.BYTES,2*e.BYTES));return{x:T,y:F}}else{let T=o,F=s;throw new Error("invalid Point, expected length of "+T+", or uncompressed "+F+", got "+L)}}}),d=C=>qe(br(C,t.nByteLength));function h(C){let L=n>>St;return C>L}function g(C){return h(C)?i(-C):C}let p=(C,L,B)=>je(C.slice(L,B));class w{constructor(L,B,A){this.r=L,this.s=B,this.recovery=A,this.assertValidity()}static fromCompact(L){let B=t.nByteLength;return L=dt("compactSignature",L,B*2),new w(p(L,0,B),p(L,B,2*B))}static fromDER(L){let{r:B,s:A}=tr.toSig(dt("DER",L));return new w(B,A)}assertValidity(){Gt("r",this.r,St,n),Gt("s",this.s,St,n)}addRecoveryBit(L){return new w(this.r,this.s,L)}recoverPublicKey(L){let{r:B,s:A,recovery:T}=this,F=N(dt("msgHash",L));if(T==null||![0,1,2,3].includes(T))throw new Error("recovery id invalid");let H=T===2||T===3?B+t.n:B;if(H>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let z=T&1?"03":"02",W=c.fromHex(z+d(H)),Y=a(H),q=i(-F*Y),ot=i(A*Y),ut=c.BASE.multiplyAndAddUnsafe(W,q,ot);if(!ut)throw new Error("point at infinify");return ut.assertValidity(),ut}hasHighS(){return h(this.s)}normalizeS(){return this.hasHighS()?new w(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return jr(this.toDERHex())}toDERHex(){return tr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return jr(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}let x={isValidPrivateKey(C){try{return u(C),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let C=Kc(t.n);return rh(t.randomBytes(C),t.n)},precompute(C=8,L=c.BASE){return L._setWindowSize(C),L.multiply(BigInt(3)),L}};function b(C,L=!0){return c.fromPrivateKey(C).toRawBytes(L)}function y(C){let L=wr(C),B=typeof C=="string",A=(L||B)&&C.length;return L?A===o||A===s:B?A===2*o||A===2*s:C instanceof c}function S(C,L,B=!0){if(y(C))throw new Error("first arg must be private key");if(!y(L))throw new Error("second arg must be public key");return c.fromHex(L).multiply(u(C)).toRawBytes(B)}let _=t.bits2int||function(C){if(C.length>8192)throw new Error("input is too large");let L=je(C),B=C.length*8-t.nBitLength;return B>0?L>>BigInt(B):L},N=t.bits2int_modN||function(C){return i(_(C))},E=lo(t.nBitLength);function v(C){return Gt("num < 2^"+t.nBitLength,C,er,E),br(C,t.nByteLength)}function k(C,L,B=O){if(["recovered","canonical"].some(vt=>vt in B))throw new Error("sign() legacy options not supported");let{hash:A,randomBytes:T}=t,{lowS:F,prehash:H,extraEntropy:z}=B;F==null&&(F=!0),C=dt("msgHash",C),md(B),H&&(C=dt("prehashed msgHash",A(C)));let W=N(C),Y=u(L),q=[v(Y),v(W)];if(z!=null&&z!==!1){let vt=z===!0?T(e.BYTES):z;q.push(dt("extraEntropy",vt))}let ot=Ge(...q),ut=W;function bt(vt){let It=_(vt);if(!l(It))return;let Lt=a(It),Kt=c.BASE.multiply(It).toAffine(),Ot=i(Kt.x);if(Ot===er)return;let Te=i(Lt*i(ut+Ot*Y));if(Te===er)return;let Oe=(Kt.x===Ot?0:2)|Number(Kt.y&St),Yn=Te;return F&&h(Te)&&(Yn=g(Te),Oe^=1),new w(Ot,Yn,Oe)}return{seed:ot,k2sig:bt}}let O={lowS:t.lowS,prehash:!1},D={lowS:t.lowS,prehash:!1};function R(C,L,B=O){let{seed:A,k2sig:T}=k(C,L,B),F=t;return Oc(F.hash.outputLen,F.nByteLength,F.hmac)(A,T)}c.BASE._setWindowSize(8);function U(C,L,B,A=D){let T=C;L=dt("msgHash",L),B=dt("publicKey",B);let{lowS:F,prehash:H,format:z}=A;if(md(A),"strict"in A)throw new Error("options.strict was renamed to lowS");if(z!==void 0&&z!=="compact"&&z!=="der")throw new Error("format must be compact or der");let W=typeof T=="string"||wr(T),Y=!W&&!z&&typeof T=="object"&&T!==null&&typeof T.r=="bigint"&&typeof T.s=="bigint";if(!W&&!Y)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let q,ot;try{if(Y&&(q=new w(T.r,T.s)),W){try{z!=="compact"&&(q=w.fromDER(T))}catch(Oe){if(!(Oe instanceof tr.Err))throw Oe}!q&&z!=="der"&&(q=w.fromCompact(T))}ot=c.fromHex(B)}catch{return!1}if(!q||F&&q.hasHighS())return!1;H&&(L=t.hash(L));let{r:ut,s:bt}=q,vt=N(L),It=a(bt),Lt=i(vt*It),Kt=i(ut*It),Ot=c.BASE.multiplyAndAddUnsafe(ot,Lt,Kt)?.toAffine();return Ot?i(Ot.x)===ut:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:S,sign:R,verify:U,ProjectivePoint:c,Signature:w,utils:x}}function Qw(r){return{hash:r,hmac:(t,...e)=>pu(r,t,Uc(...e)),randomBytes:ws}}function wd(r,t){let e=n=>yd({...r,...Qw(n)});return Object.freeze({...e(t),create:e})}var vd=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),xd=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),tx=BigInt(1),mu=BigInt(2),bd=(r,t)=>(r+t/mu)/t;function ex(r){let t=vd,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=r*r*r%t,f=u*u*r%t,l=ft(f,e,t)*f%t,d=ft(l,e,t)*f%t,h=ft(d,mu,t)*u%t,g=ft(h,o,t)*h%t,p=ft(g,s,t)*g%t,w=ft(p,a,t)*p%t,x=ft(w,c,t)*w%t,b=ft(x,a,t)*p%t,y=ft(b,e,t)*f%t,S=ft(y,i,t)*g%t,_=ft(S,n,t)*u%t,N=ft(_,mu,t);if(!gu.eql(gu.sqr(N),r))throw new Error("Cannot find square root");return N}var gu=vr(vd,void 0,void 0,{sqrt:ex}),Jr=wd({a:BigInt(0),b:BigInt(7),Fp:gu,n:xd,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=xd,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-tx*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=bd(s*r,t),c=bd(-n*r,t),u=at(r-a*e-c*o,t),f=at(-a*n-c*s,t),l=u>i,d=f>i;if(l&&(u=t-u),d&&(f=t-f),u>i||f>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:u,k2neg:d,k2:f}}}},pd),C6=BigInt(0);var N6=Jr.ProjectivePoint;function Ed(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Ad(r,t,e){let n=mr.digest(e instanceof Uint8Array?e:e.subarray());if(Ed(n))return n.then(({digest:o})=>Jr.verify(t,o,r)).catch(o=>{throw new vo(String(o))});try{return Jr.verify(t,n.digest,r)}catch(o){throw new vo(String(o))}}var Ii=class{type="secp256k1";raw;_key;constructor(t){this._key=Bd(t),this.raw=Sd(this._key)}toMultihash(){return jt.digest(Cs(this))}toCID(){return $.createV1(114,this.toMultihash())}toString(){return it.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:st(this.raw,t.raw)}verify(t,e){return Ad(this._key,e,t)}};function yu(r){return new Ii(r)}function Sd(r){return Jr.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Bd(r){try{return Jr.ProjectivePoint.fromHex(r),r}catch(t){throw new an(String(t))}}function kd(r){let{Type:t,Data:e}=Ue.decode(r),n=e??new Uint8Array;switch(t){case xt.RSA:return hu(n);case xt.Ed25519:return Jc(n);case xt.secp256k1:return yu(n);default:throw new cn}}function _i(r){let{Type:t,Data:e}=Ue.decode(r.digest),n=e??new Uint8Array;switch(t){case xt.Ed25519:return Jc(n);case xt.secp256k1:return yu(n);default:throw new cn}}function Cs(r){return Ue.encode({Type:xt[r.type],Data:r.raw})}var Id=Symbol.for("nodejs.util.inspect.custom"),rx=114,So=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[za]=!0;toString(){return this.string==null&&(this.string=it.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return $.createV1(rx,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return st(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return st(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Id](){return`PeerId(${this.toString()})`}},Ti=class extends So{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Ci=class extends So{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Ni=class extends So{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},nx=2336,Bo=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=jt.digest(K(this.url))}[Id](){return`PeerId(${this.url})`}[za]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return $.createV1(nx,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=nt(t)),t.toString()===this.toString())}};var ox=114,_d=2336;function Td(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=de(it.decode(`z${r}`));else{if(t==null)throw new Et('Please pass a multibase decoder for strings that do not start with "1" or "Q"');e=de(t.decode(r))}return Cd(e)}function Cd(r){if(ix(r))return new Ti({multihash:r});if(sx(r))try{let t=_i(r);if(t.type==="Ed25519")return new Ci({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Ni({multihash:r,publicKey:t})}catch{let e=nt(r.digest);return new Bo(new URL(e))}throw new lr("Supplied PeerID Multihash is invalid")}function Nd(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==ox&&r.code!==_d)throw new ts("Supplied PeerID CID is invalid");if(r.code===_d){let t=nt(r.multihash.digest);return new Bo(new URL(t))}return Cd(r.multihash)}function sx(r){return r.code===jt.code}function ix(r){return r.code===mr.code}var wu=64,xe=class{fp;h;seed;constructor(t,e,n,o=2){if(o>wu)throw new TypeError("Invalid Fingerprint Size");let s=e.hashV(t,n),i=df(o);for(let a=0;a<i.length;a++)i[a]=s[a];i.length===0&&(i[0]=7),this.fp=i,this.h=e,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(t){return t?.fp instanceof Uint8Array?st(this.fp,t.fp):!1}};function Xr(r,t){return Math.floor(Math.random()*(t-r))+r}var Qr=class{contents;constructor(t){this.contents=new Array(t).fill(null)}has(t){if(!(t instanceof xe))throw new TypeError("Invalid Fingerprint");return this.contents.some(e=>t.equals(e))}add(t){if(!(t instanceof xe))throw new TypeError("Invalid Fingerprint");for(let e=0;e<this.contents.length;e++)if(this.contents[e]==null)return this.contents[e]=t,!0;return!0}swap(t){if(!(t instanceof xe))throw new TypeError("Invalid Fingerprint");let e=Xr(0,this.contents.length-1),n=this.contents[e];return this.contents[e]=t,n}remove(t){if(!(t instanceof xe))throw new TypeError("Invalid Fingerprint");let e=this.contents.findIndex(n=>t.equals(n));return e>-1?(this.contents[e]=null,!0):!1}};var xu={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},Rd={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},Dd=new globalThis.TextEncoder;function ax(r,t){let e=xu[t],n=Rd[t];for(let o=0;o<r.length;o++)n^=BigInt(r[o]),n=BigInt.asUintN(t,n*e);return n}function cx(r,t,e){if(e.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=xu[t],o=Rd[t],s=r;for(;s.length>0;){let i=Dd.encodeInto(s,e);s=s.slice(i.read);for(let a=0;a<i.written;a++)o^=BigInt(e[a]),o=BigInt.asUintN(t,o*n)}return o}function bu(r,{size:t=32,utf8Buffer:e}={}){if(!xu[t])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof r=="string"){if(e)return cx(r,t,e);r=Dd.encode(r)}return ax(r,t)}var ux=Fr(Pd(),1);var Io={hash:r=>Number(bu(r,{size:32})),hashV:(r,t)=>lx(Io.hash(r,t))};function lx(r){let t=r.toString(16);return t.length%2===1&&(t=`0${t}`),K(t,"base16")}var fx=500,_o=class{bucketSize;filterSize;fingerprintSize;buckets;count;hash;seed;constructor(t){this.filterSize=t.filterSize,this.bucketSize=t.bucketSize??4,this.fingerprintSize=t.fingerprintSize??2,this.count=0,this.buckets=[],this.hash=t.hash??Io,this.seed=t.seed??Xr(0,Math.pow(2,10))}add(t){typeof t=="string"&&(t=K(t));let e=new xe(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=(n^e.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new Qr(this.bucketSize)),this.buckets[o]==null&&(this.buckets[o]=new Qr(this.bucketSize)),this.buckets[n].add(e)||this.buckets[o].add(e))return this.count++,!0;let s=[n,o],i=s[Xr(0,s.length-1)];this.buckets[i]==null&&(this.buckets[i]=new Qr(this.bucketSize));for(let a=0;a<fx;a++){let c=this.buckets[i].swap(e);if(c!=null&&(i=(i^c.hash())%this.filterSize,this.buckets[i]==null&&(this.buckets[i]=new Qr(this.bucketSize)),this.buckets[i].add(c)))return this.count++,!0}return!1}has(t){typeof t=="string"&&(t=K(t));let e=new xe(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.has(e)??!1;if(o)return o;let s=(n^e.hash())%this.filterSize;return this.buckets[s]?.has(e)??!1}remove(t){typeof t=="string"&&(t=K(t));let e=new xe(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.remove(e)??!1;if(o)return this.count--,o;let s=(n^e.hash())%this.filterSize,i=this.buckets[s]?.remove(e)??!1;return i&&this.count--,i}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}},hx={1:.5,2:.84,4:.95,8:.98};function dx(r=.001){return r>.002?2:r>1e-5?4:8}function Fd(r,t=.001){let e=dx(t),n=hx[e],o=Math.round(r/n),s=Math.min(Math.ceil(Math.log2(1/t)+Math.log2(2*e)),wu);return{filterSize:o,bucketSize:e,fingerprintSize:s}}var Ui=class{filterSize;bucketSize;fingerprintSize;scale;filterSeries;hash;seed;constructor(t){this.bucketSize=t.bucketSize??4,this.filterSize=t.filterSize??(1<<18)/this.bucketSize,this.fingerprintSize=t.fingerprintSize??2,this.scale=t.scale??2,this.hash=t.hash??Io,this.seed=t.seed??Xr(0,Math.pow(2,10)),this.filterSeries=[new _o({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(t){if(typeof t=="string"&&(t=K(t)),this.has(t))return!0;let e=this.filterSeries.find(n=>n.reliable);if(e==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);e=new _o({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(e)}return e.add(t)}has(t){typeof t=="string"&&(t=K(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].has(t))return!0;return!1}remove(t){typeof t=="string"&&(t=K(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].remove(t))return!0;return!1}get count(){return this.filterSeries.reduce((t,e)=>t+e.count,0)}};function vu(r,t=.001,e){return new Ui({...Fd(r,t),...e??{}})}function px(r,t){try{if(typeof r=="string"&&r.length>0)return mx(r);if(typeof r=="number"&&isFinite(r))return t?.long?yx(r):gx(r);throw new Error("Value is not a string or number.")}catch(e){let n=wx(e)?`${e.message}. value=${JSON.stringify(r)}`:"An unknown error has occured.";throw new Error(n)}}function mx(r){if(r=String(r),r.length>100)throw new Error("Value exceeds the maximum length of 100 characters.");let t=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(r);if(!t)return NaN;let e=parseFloat(t[1]),n=(t[2]||"ms").toLowerCase();switch(n){case"years":case"year":case"yrs":case"yr":case"y":return e*315576e5;case"weeks":case"week":case"w":return e*6048e5;case"days":case"day":case"d":return e*864e5;case"hours":case"hour":case"hrs":case"hr":case"h":return e*36e5;case"minutes":case"minute":case"mins":case"min":case"m":return e*6e4;case"seconds":case"second":case"secs":case"sec":case"s":return e*1e3;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return e;default:throw new Error(`The unit ${n} was matched, but no matching case exists.`)}}var Ri=px;function gx(r){let t=Math.abs(r);return t>=864e5?`${Math.round(r/864e5)}d`:t>=36e5?`${Math.round(r/36e5)}h`:t>=6e4?`${Math.round(r/6e4)}m`:t>=1e3?`${Math.round(r/1e3)}s`:`${r}ms`}function yx(r){let t=Math.abs(r);return t>=864e5?Pi(r,t,864e5,"day"):t>=36e5?Pi(r,t,36e5,"hour"):t>=6e4?Pi(r,t,6e4,"minute"):t>=1e3?Pi(r,t,1e3,"second"):`${r} ms`}function Pi(r,t,e,n){let o=t>=e*1.5;return`${Math.round(r/e)} ${n}${o?"s":""}`}function wx(r){return typeof r=="object"&&r!==null&&"message"in r}function Eu(r){e.debug=e,e.default=e,e.coerce=c,e.disable=s,e.enable=o,e.enabled=i,e.humanize=Ri,e.destroy=u,Object.keys(r).forEach(f=>{e[f]=r[f]}),e.names=[],e.skips=[],e.formatters={};function t(f){let l=0;for(let d=0;d<f.length;d++)l=(l<<5)-l+f.charCodeAt(d),l|=0;return e.colors[Math.abs(l)%e.colors.length]}e.selectColor=t;function e(f){let l,d=null,h,g;function p(...w){if(!p.enabled)return;let x=p,b=Number(new Date),y=b-(l||b);x.diff=y,x.prev=l,x.curr=b,l=b,w[0]=e.coerce(w[0]),typeof w[0]!="string"&&w.unshift("%O");let S=0;w[0]=w[0].replace(/%([a-zA-Z%])/g,(N,E)=>{if(N==="%%")return"%";S++;let v=e.formatters[E];if(typeof v=="function"){let k=w[S];N=v.call(x,k),w.splice(S,1),S--}return N}),e.formatArgs.call(x,w),(x.log||e.log).apply(x,w)}return p.namespace=f,p.useColors=e.useColors(),p.color=e.selectColor(f),p.extend=n,p.destroy=e.destroy,Object.defineProperty(p,"enabled",{enumerable:!0,configurable:!1,get:()=>d!==null?d:(h!==e.namespaces&&(h=e.namespaces,g=e.enabled(f)),g),set:w=>{d=w}}),typeof e.init=="function"&&e.init(p),p}function n(f,l){let d=e(this.namespace+(typeof l>"u"?":":l)+f);return d.log=this.log,d}function o(f){e.save(f),e.namespaces=f,e.names=[],e.skips=[];let l,d=(typeof f=="string"?f:"").split(/[\s,]+/),h=d.length;for(l=0;l<h;l++)d[l]&&(f=d[l].replace(/\*/g,".*?"),f[0]==="-"?e.skips.push(new RegExp("^"+f.substr(1)+"$")):e.names.push(new RegExp("^"+f+"$")))}function s(){let f=[...e.names.map(a),...e.skips.map(a).map(l=>"-"+l)].join(",");return e.enable(""),f}function i(f){if(f[f.length-1]==="*")return!0;let l,d;for(l=0,d=e.skips.length;l<d;l++)if(e.skips[l].test(f))return!1;for(l=0,d=e.names.length;l<d;l++)if(e.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 u(){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 e.setupFormatters(e.formatters),e.enable(e.load()),e}var Di=Bx(),xx=["#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 bx(){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 vx(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+Ri(this.diff),!this.useColors)return;let t="color: "+this.color;r.splice(1,0,t,"color: inherit");let e=0,n=0;r[0].replace(/%[a-zA-Z%]/g,o=>{o!=="%%"&&(e++,o==="%c"&&(n=e))}),r.splice(n,0,t)}var Ex=console.debug??console.log??(()=>{});function Ax(r){try{r?Di?.setItem("debug",r):Di?.removeItem("debug")}catch{}}function Sx(){let r;try{r=Di?.getItem("debug")}catch{}return!r&&typeof globalThis.process<"u"&&"env"in globalThis.process&&(r=globalThis.process.env.DEBUG),r}function Bx(){try{return localStorage}catch{}}function kx(r){r.j=function(t){try{return JSON.stringify(t)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}}var Md=Eu({formatArgs:vx,save:Ax,load:Sx,useColors:bx,setupFormatters:kx,colors:xx,storage:Di,log:Ex});var Yt=Md;Yt.formatters.b=r=>r==null?"undefined":it.baseEncode(r);Yt.formatters.t=r=>r==null?"undefined":_t.baseEncode(r);Yt.formatters.m=r=>r==null?"undefined":Ne.baseEncode(r);Yt.formatters.p=r=>r==null?"undefined":r.toString();Yt.formatters.c=r=>r==null?"undefined":r.toString();Yt.formatters.k=r=>r==null?"undefined":r.toString();Yt.formatters.a=r=>r==null?"undefined":r.toString();Yt.formatters.e=r=>r==null?"undefined":Vd(r.stack)??Vd(r.message)??r.toString();function Ix(r){let t=()=>{};return t.enabled=!1,t.color="",t.diff=0,t.log=()=>{},t.namespace=r,t.destroy=()=>!0,t.extend=()=>t,t}function Od(){return{forComponent(r){return Qt(r)}}}function Qt(r){let t=Ix(`${r}:trace`);return Yt.enabled(`${r}:trace`)&&Yt.names.map(e=>e.toString()).find(e=>e.includes(":trace"))!=null&&(t=Yt(`${r}:trace`)),Object.assign(Yt(r),{error:Yt(`${r}:error`),trace:t})}function Vd(r){if(r!=null&&(r=r.trim(),r.length!==0))return r}var Su=Fr(Hd(),1);var Co=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},Bu=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},zd=r=>globalThis.DOMException===void 0?new Bu(r):new DOMException(r),Kd=r=>{let t=r.reason===void 0?zd("This operation was aborted."):r.reason;return t instanceof Error?t:zd(t)};function No(r,t){let{milliseconds:e,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout}}=t,i,c=new Promise((u,f)=>{if(typeof e!="number"||Math.sign(e)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${e}\``);if(t.signal){let{signal:d}=t;d.aborted&&f(Kd(d));let h=()=>{f(Kd(d))};d.addEventListener("abort",h,{once:!0}),r.finally(()=>{d.removeEventListener("abort",h)})}if(e===Number.POSITIVE_INFINITY){r.then(u,f);return}let l=new Co;i=s.setTimeout.call(void 0,()=>{if(n){try{u(n())}catch(d){f(d)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?u():o instanceof Error?f(o):(l.message=o??`Promise timed out after ${e} milliseconds`,f(l))},e),(async()=>{try{u(await r)}catch(d){f(d)}})()}).finally(()=>{c.clear()});return c.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},c}function ku(r,t,e){let n=0,o=r.length;for(;o>0;){let s=Math.trunc(o/2),i=n+s;e(r[i],t)<=0?(n=++i,o-=s+1):o=s}return n}var Lo=class{#t=[];enqueue(t,e){e={priority:0,...e};let n={priority:e.priority,run:t};if(this.size&&this.#t[this.size-1].priority>=e.priority){this.#t.push(n);return}let o=ku(this.#t,n,(s,i)=>i.priority-s.priority);this.#t.splice(o,0,n)}dequeue(){return this.#t.shift()?.run}filter(t){return this.#t.filter(e=>e.priority===t.priority).map(e=>e.run)}get size(){return this.#t.length}};var Fe=class extends Su.default{#t;#e;#r=0;#o;#a;#u=0;#s;#l;#n;#m;#i=0;#f;#c;#g;timeout;constructor(t){if(super(),t={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:Lo,...t},!(typeof t.intervalCap=="number"&&t.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${t.intervalCap?.toString()??""}\` (${typeof t.intervalCap})`);if(t.interval===void 0||!(Number.isFinite(t.interval)&&t.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${t.interval?.toString()??""}\` (${typeof t.interval})`);this.#t=t.carryoverConcurrencyCount,this.#e=t.intervalCap===Number.POSITIVE_INFINITY||t.interval===0,this.#o=t.intervalCap,this.#a=t.interval,this.#n=new t.queueClass,this.#m=t.queueClass,this.concurrency=t.concurrency,this.timeout=t.timeout,this.#g=t.throwOnTimeout===!0,this.#c=t.autoStart===!1}get#x(){return this.#e||this.#r<this.#o}get#b(){return this.#i<this.#f}#v(){this.#i--,this.#h(),this.emit("next")}#E(){this.#w(),this.#y(),this.#l=void 0}get#A(){let t=Date.now();if(this.#s===void 0){let e=this.#u-t;if(e<0)this.#r=this.#t?this.#i:0;else return this.#l===void 0&&(this.#l=setTimeout(()=>{this.#E()},e)),!0}return!1}#h(){if(this.#n.size===0)return this.#s&&clearInterval(this.#s),this.#s=void 0,this.emit("empty"),this.#i===0&&this.emit("idle"),!1;if(!this.#c){let t=!this.#A;if(this.#x&&this.#b){let e=this.#n.dequeue();return e?(this.emit("active"),e(),t&&this.#y(),!0):!1}}return!1}#y(){this.#e||this.#s!==void 0||(this.#s=setInterval(()=>{this.#w()},this.#a),this.#u=Date.now()+this.#a)}#w(){this.#r===0&&this.#i===0&&this.#s&&(clearInterval(this.#s),this.#s=void 0),this.#r=this.#t?this.#i:0,this.#d()}#d(){for(;this.#h(););}get concurrency(){return this.#f}set concurrency(t){if(!(typeof t=="number"&&t>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${t}\` (${typeof t})`);this.#f=t,this.#d()}async#S(t){return new Promise((e,n)=>{t.addEventListener("abort",()=>{n(t.reason)},{once:!0})})}async add(t,e={}){return e={timeout:this.timeout,throwOnTimeout:this.#g,...e},new Promise((n,o)=>{this.#n.enqueue(async()=>{this.#i++,this.#r++;try{e.signal?.throwIfAborted();let s=t({signal:e.signal});e.timeout&&(s=No(Promise.resolve(s),{milliseconds:e.timeout})),e.signal&&(s=Promise.race([s,this.#S(e.signal)]));let i=await s;n(i),this.emit("completed",i)}catch(s){if(s instanceof Co&&!e.throwOnTimeout){n();return}o(s),this.emit("error",s)}finally{this.#v()}},e),this.emit("add"),this.#h()})}async addAll(t,e){return Promise.all(t.map(async n=>this.add(n,e)))}start(){return this.#c?(this.#c=!1,this.#d(),this):this}pause(){this.#c=!0}clear(){this.#n=new this.#m}async onEmpty(){this.#n.size!==0&&await this.#p("empty")}async onSizeLessThan(t){this.#n.size<t||await this.#p("next",()=>this.#n.size<t)}async onIdle(){this.#i===0&&this.#n.size===0||await this.#p("idle")}async#p(t,e){return new Promise(n=>{let o=()=>{e&&!e()||(this.off(t,o),n())};this.on(t,o)})}get size(){return this.#n.size}sizeBy(t){return this.#n.filter(t).length}get pending(){return this.#i}get isPaused(){return this.#c}};function Mi(r){let t=[be.A];return r==null?t:Array.isArray(r)?r.length===0?t:r:[r]}var Iu=60;function Vi(r){return{Status:r.Status??0,TC:r.TC??r.flag_tc??!1,RD:r.RD??r.flag_rd??!1,RA:r.RA??r.flag_ra??!1,AD:r.AD??r.flag_ad??!1,CD:r.CD??r.flag_cd??!1,Question:(r.Question??r.questions??[]).map(t=>({name:t.name,type:be[t.type]})),Answer:(r.Answer??r.answers??[]).map(t=>({name:t.name,type:be[t.type],TTL:t.TTL??t.ttl??Iu,data:t.data instanceof Uint8Array?nt(t.data):t.data}))}}var Cx=4;function _u(r,t={}){let e=new Fe({concurrency:t.queryConcurrency??Cx});return async(n,o={})=>{let s=new URLSearchParams;s.set("name",n),Mi(o.types).forEach(a=>{s.append("type",be[a])}),o.onProgress?.(new tt("dns:query",{detail:n}));let i=await e.add(async()=>{let a=await fetch(`${r}?${s}`,{headers:{accept:"application/dns-json"},signal:o?.signal});if(a.status!==200)throw new Error(`Unexpected HTTP status: ${a.status} - ${a.statusText}`);let c=Vi(await a.json());return o.onProgress?.(new tt("dns:response",{detail:c})),c},{signal:o.signal});if(i==null)throw new Error("No DNS response received");return i}}function qd(){return[_u("https://cloudflare-dns.com/dns-query"),_u("https://dns.google/resolve")]}var Wd=Fr(Gd(),1);var Tu=class{lru;constructor(t){this.lru=(0,Wd.default)(t)}get(t,e){let n=!0,o=[];for(let s of e){let i=this.getAnswers(t,s);if(i.length===0){n=!1;break}o.push(...i)}if(n)return Vi({answers:o})}getAnswers(t,e){let n=`${t.toLowerCase()}-${e}`,o=this.lru.get(n);if(o!=null){let s=o.filter(i=>i.expires>Date.now()).map(({expires:i,value:a})=>({...a,TTL:Math.round((i-Date.now())/1e3),type:be[a.type]}));return s.length===0&&this.lru.remove(n),s}return[]}add(t,e){let n=`${t.toLowerCase()}-${e.type}`,o=this.lru.get(n)??[];o.push({expires:Date.now()+(e.TTL??Iu)*1e3,value:e}),this.lru.set(n,o)}remove(t,e){let n=`${t.toLowerCase()}-${e}`;this.lru.remove(n)}clear(){this.lru.clear()}};function Zd(r){return new Tu(r)}var Nx=1e3,Oi=class{resolvers;cache;constructor(t){this.resolvers={},this.cache=Zd(t.cacheSize??Nx),Object.entries(t.resolvers??{}).forEach(([e,n])=>{Array.isArray(n)||(n=[n]),e.endsWith(".")||(e=`${e}.`),this.resolvers[e]=n}),this.resolvers["."]==null&&(this.resolvers["."]=qd())}async query(t,e={}){let n=Mi(e.types),o=e.cached!==!1?this.cache.get(t,n):void 0;if(o!=null)return e.onProgress?.(new tt("dns:cache",{detail:o})),o;let s=`${t.split(".").pop()}.`,i=(this.resolvers[s]??this.resolvers["."]).sort(()=>Math.random()>.5?-1:1),a=[];for(let c of i){if(e.signal?.aborted===!0)break;try{let u=await c(t,{...e,types:n});for(let f of u.Answer)this.cache.add(t,f);return u}catch(u){a.push(u),e.onProgress?.(new tt("dns:error",{detail:u}))}}throw a.length===1?a[0]:new AggregateError(a,`DNS lookup of ${t} ${n} failed`)}};var be;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(be||(be={}));function Yd(r={}){return new Oi(r)}var Lx=["string","number","bigint","symbol"],Ux=["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 Jd(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let t=typeof r;if(Lx.includes(t))return t;if(t==="function")return"Function";if(Array.isArray(r))return"Array";if(Px(r))return"Buffer";let e=Rx(r);return e||"Object"}function Px(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function Rx(r){let t=Object.prototype.toString.call(r).slice(8,-1);if(Ux.includes(t))return t}var m=class{constructor(t,e,n){this.major=t,this.majorEncoded=t<<5,this.name=e,this.terminal=n}toString(){return`Type[${this.major}].${this.name}`}compare(t){return this.major<t.major?-1:this.major>t.major?1:0}};m.uint=new m(0,"uint",!0);m.negint=new m(1,"negint",!0);m.bytes=new m(2,"bytes",!0);m.string=new m(3,"string",!0);m.array=new m(4,"array",!1);m.map=new m(5,"map",!1);m.tag=new m(6,"tag",!1);m.float=new m(7,"float",!0);m.false=new m(7,"false",!0);m.true=new m(7,"true",!0);m.null=new m(7,"null",!0);m.undefined=new m(7,"undefined",!0);m.break=new m(7,"break",!0);var I=class{constructor(t,e,n){this.type=t,this.value=e,this.encodedLength=n,this.encodedBytes=void 0,this.byteValue=void 0}toString(){return`Token[${this.type}].${this.value}`}};var Un=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",Dx=new TextDecoder,Fx=new TextEncoder;function $i(r){return Un&&globalThis.Buffer.isBuffer(r)}function Uo(r){return r instanceof Uint8Array?$i(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var ep=Un?(r,t,e)=>e-t>64?globalThis.Buffer.from(r.subarray(t,e)).toString("utf8"):Qd(r,t,e):(r,t,e)=>e-t>64?Dx.decode(r.subarray(t,e)):Qd(r,t,e),Hi=Un?r=>r.length>64?globalThis.Buffer.from(r):Xd(r):r=>r.length>64?Fx.encode(r):Xd(r),Me=r=>Uint8Array.from(r),Pn=Un?(r,t,e)=>$i(r)?new Uint8Array(r.subarray(t,e)):r.slice(t,e):(r,t,e)=>r.slice(t,e),rp=Un?(r,t)=>(r=r.map(e=>e instanceof Uint8Array?e:globalThis.Buffer.from(e)),Uo(globalThis.Buffer.concat(r,t))):(r,t)=>{let e=new Uint8Array(t),n=0;for(let o of r)n+o.length>e.length&&(o=o.subarray(0,e.length-n)),e.set(o,n),n+=o.length;return e},np=Un?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function op(r,t){if($i(r)&&$i(t))return r.compare(t);for(let e=0;e<r.length;e++)if(r[e]!==t[e])return r[e]<t[e]?-1:1;return 0}function Xd(r){let t=[],e=0;for(let n=0;n<r.length;n++){let o=r.charCodeAt(n);o<128?t[e++]=o:o<2048?(t[e++]=o>>6|192,t[e++]=o&63|128):(o&64512)===55296&&n+1<r.length&&(r.charCodeAt(n+1)&64512)===56320?(o=65536+((o&1023)<<10)+(r.charCodeAt(++n)&1023),t[e++]=o>>18|240,t[e++]=o>>12&63|128,t[e++]=o>>6&63|128,t[e++]=o&63|128):(t[e++]=o>>12|224,t[e++]=o>>6&63|128,t[e++]=o&63|128)}return t}function Qd(r,t,e){let n=[];for(;t<e;){let o=r[t],s=null,i=o>239?4:o>223?3:o>191?2:1;if(t+i<=e){let a,c,u,f;switch(i){case 1:o<128&&(s=o);break;case 2:a=r[t+1],(a&192)===128&&(f=(o&31)<<6|a&63,f>127&&(s=f));break;case 3:a=r[t+1],c=r[t+2],(a&192)===128&&(c&192)===128&&(f=(o&15)<<12|(a&63)<<6|c&63,f>2047&&(f<55296||f>57343)&&(s=f));break;case 4:a=r[t+1],c=r[t+2],u=r[t+3],(a&192)===128&&(c&192)===128&&(u&192)===128&&(f=(o&15)<<18|(a&63)<<12|(c&63)<<6|u&63,f>65535&&f<1114112&&(s=f))}}s===null?(s=65533,i=1):s>65535&&(s-=65536,n.push(s>>>10&1023|55296),s=56320|s&1023),n.push(s),t+=i}return Cu(n)}var tp=4096;function Cu(r){let t=r.length;if(t<=tp)return String.fromCharCode.apply(String,r);let e="",n=0;for(;n<t;)e+=String.fromCharCode.apply(String,r.slice(n,n+=tp));return e}var Mx=256,Po=class{constructor(t=Mx){this.chunkSize=t,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(t){let e=this.chunks[this.chunks.length-1];if(this.cursor+t.length<=this.maxCursor+1){let o=e.length-(this.maxCursor-this.cursor)-1;e.set(t,o)}else{if(e){let o=e.length-(this.maxCursor-this.cursor)-1;o<e.length&&(this.chunks[this.chunks.length-1]=e.subarray(0,o),this.maxCursor=this.cursor-1)}t.length<64&&t.length<this.chunkSize?(e=np(this.chunkSize),this.chunks.push(e),this.maxCursor+=e.length,this._initReuseChunk===null&&(this._initReuseChunk=e),e.set(t,0)):(this.chunks.push(t),this.maxCursor+=t.length)}this.cursor+=t.length}toBytes(t=!1){let e;if(this.chunks.length===1){let n=this.chunks[0];t&&this.cursor>n.length/2?(e=this.cursor===n.length?n:n.subarray(0,this.cursor),this._initReuseChunk=null,this.chunks=[]):e=Pn(n,0,this.cursor)}else e=rp(this.chunks,this.cursor);return t&&this.reset(),e}};var V="CBOR decode error:",rr="CBOR encode error:",Ro=[];Ro[23]=1;Ro[24]=2;Ro[25]=3;Ro[26]=5;Ro[27]=9;function nr(r,t,e){if(r.length-t<e)throw new Error(`${V} not enough data for type`)}var Bt=[24,256,65536,4294967296,BigInt("18446744073709551616")];function te(r,t,e){nr(r,t,1);let n=r[t];if(e.strict===!0&&n<Bt[0])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function ee(r,t,e){nr(r,t,2);let n=r[t]<<8|r[t+1];if(e.strict===!0&&n<Bt[1])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function re(r,t,e){nr(r,t,4);let n=r[t]*16777216+(r[t+1]<<16)+(r[t+2]<<8)+r[t+3];if(e.strict===!0&&n<Bt[2])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function ne(r,t,e){nr(r,t,8);let n=r[t]*16777216+(r[t+1]<<16)+(r[t+2]<<8)+r[t+3],o=r[t+4]*16777216+(r[t+5]<<16)+(r[t+6]<<8)+r[t+7],s=(BigInt(n)<<BigInt(32))+BigInt(o);if(e.strict===!0&&s<Bt[3])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);if(s<=Number.MAX_SAFE_INTEGER)return Number(s);if(e.allowBigInt===!0)return s;throw new Error(`${V} integers outside of the safe integer range are not supported`)}function sp(r,t,e,n){return new I(m.uint,te(r,t+1,n),2)}function ip(r,t,e,n){return new I(m.uint,ee(r,t+1,n),3)}function ap(r,t,e,n){return new I(m.uint,re(r,t+1,n),5)}function cp(r,t,e,n){return new I(m.uint,ne(r,t+1,n),9)}function ie(r,t){return Nt(r,0,t.value)}function Nt(r,t,e){if(e<Bt[0]){let n=Number(e);r.push([t|n])}else if(e<Bt[1]){let n=Number(e);r.push([t|24,n])}else if(e<Bt[2]){let n=Number(e);r.push([t|25,n>>>8,n&255])}else if(e<Bt[3]){let n=Number(e);r.push([t|26,n>>>24&255,n>>>16&255,n>>>8&255,n&255])}else{let n=BigInt(e);if(n<Bt[4]){let o=[t|27,0,0,0,0,0,0,0],s=Number(n&BigInt(4294967295)),i=Number(n>>BigInt(32)&BigInt(4294967295));o[8]=s&255,s=s>>8,o[7]=s&255,s=s>>8,o[6]=s&255,s=s>>8,o[5]=s&255,o[4]=i&255,i=i>>8,o[3]=i&255,i=i>>8,o[2]=i&255,i=i>>8,o[1]=i&255,r.push(o)}else throw new Error(`${V} encountered BigInt larger than allowable range`)}}ie.encodedSize=function(t){return Nt.encodedSize(t.value)};Nt.encodedSize=function(t){return t<Bt[0]?1:t<Bt[1]?2:t<Bt[2]?3:t<Bt[3]?5:9};ie.compareTokens=function(t,e){return t.value<e.value?-1:t.value>e.value?1:0};function up(r,t,e,n){return new I(m.negint,-1-te(r,t+1,n),2)}function lp(r,t,e,n){return new I(m.negint,-1-ee(r,t+1,n),3)}function fp(r,t,e,n){return new I(m.negint,-1-re(r,t+1,n),5)}var Nu=BigInt(-1),hp=BigInt(1);function dp(r,t,e,n){let o=ne(r,t+1,n);if(typeof o!="bigint"){let s=-1-o;if(s>=Number.MIN_SAFE_INTEGER)return new I(m.negint,s,9)}if(n.allowBigInt!==!0)throw new Error(`${V} integers outside of the safe integer range are not supported`);return new I(m.negint,Nu-BigInt(o),9)}function zi(r,t){let e=t.value,n=typeof e=="bigint"?e*Nu-hp:e*-1-1;Nt(r,t.type.majorEncoded,n)}zi.encodedSize=function(t){let e=t.value,n=typeof e=="bigint"?e*Nu-hp:e*-1-1;return n<Bt[0]?1:n<Bt[1]?2:n<Bt[2]?3:n<Bt[3]?5:9};zi.compareTokens=function(t,e){return t.value<e.value?1:t.value>e.value?-1:0};function Do(r,t,e,n){nr(r,t,e+n);let o=Pn(r,t+e,t+e+n);return new I(m.bytes,o,e+n)}function pp(r,t,e,n){return Do(r,t,1,e)}function mp(r,t,e,n){return Do(r,t,2,te(r,t+1,n))}function gp(r,t,e,n){return Do(r,t,3,ee(r,t+1,n))}function yp(r,t,e,n){return Do(r,t,5,re(r,t+1,n))}function wp(r,t,e,n){let o=ne(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer bytes lengths not supported`);return Do(r,t,9,o)}function Ki(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===m.string?Hi(r.value):r.value),r.encodedBytes}function Rn(r,t){let e=Ki(t);Nt(r,t.type.majorEncoded,e.length),r.push(e)}Rn.encodedSize=function(t){let e=Ki(t);return Nt.encodedSize(e.length)+e.length};Rn.compareTokens=function(t,e){return Ox(Ki(t),Ki(e))};function Ox(r,t){return r.length<t.length?-1:r.length>t.length?1:op(r,t)}function Fo(r,t,e,n,o){let s=e+n;nr(r,t,s);let i=new I(m.string,ep(r,t+e,t+s),s);return o.retainStringBytes===!0&&(i.byteValue=Pn(r,t+e,t+s)),i}function xp(r,t,e,n){return Fo(r,t,1,e,n)}function bp(r,t,e,n){return Fo(r,t,2,te(r,t+1,n),n)}function vp(r,t,e,n){return Fo(r,t,3,ee(r,t+1,n),n)}function Ep(r,t,e,n){return Fo(r,t,5,re(r,t+1,n),n)}function Ap(r,t,e,n){let o=ne(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer string lengths not supported`);return Fo(r,t,9,o,n)}var Sp=Rn;function Dn(r,t,e,n){return new I(m.array,n,e)}function Bp(r,t,e,n){return Dn(r,t,1,e)}function kp(r,t,e,n){return Dn(r,t,2,te(r,t+1,n))}function Ip(r,t,e,n){return Dn(r,t,3,ee(r,t+1,n))}function _p(r,t,e,n){return Dn(r,t,5,re(r,t+1,n))}function Tp(r,t,e,n){let o=ne(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer array lengths not supported`);return Dn(r,t,9,o)}function Cp(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Dn(r,t,1,1/0)}function qi(r,t){Nt(r,m.array.majorEncoded,t.value)}qi.compareTokens=ie.compareTokens;qi.encodedSize=function(t){return Nt.encodedSize(t.value)};function Fn(r,t,e,n){return new I(m.map,n,e)}function Np(r,t,e,n){return Fn(r,t,1,e)}function Lp(r,t,e,n){return Fn(r,t,2,te(r,t+1,n))}function Up(r,t,e,n){return Fn(r,t,3,ee(r,t+1,n))}function Pp(r,t,e,n){return Fn(r,t,5,re(r,t+1,n))}function Rp(r,t,e,n){let o=ne(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer map lengths not supported`);return Fn(r,t,9,o)}function Dp(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Fn(r,t,1,1/0)}function ji(r,t){Nt(r,m.map.majorEncoded,t.value)}ji.compareTokens=ie.compareTokens;ji.encodedSize=function(t){return Nt.encodedSize(t.value)};function Fp(r,t,e,n){return new I(m.tag,e,1)}function Mp(r,t,e,n){return new I(m.tag,te(r,t+1,n),2)}function Vp(r,t,e,n){return new I(m.tag,ee(r,t+1,n),3)}function Op(r,t,e,n){return new I(m.tag,re(r,t+1,n),5)}function $p(r,t,e,n){return new I(m.tag,ne(r,t+1,n),9)}function Gi(r,t){Nt(r,m.tag.majorEncoded,t.value)}Gi.compareTokens=ie.compareTokens;Gi.encodedSize=function(t){return Nt.encodedSize(t.value)};var jx=20,Gx=21,Wx=22,Zx=23;function Hp(r,t,e,n){if(n.allowUndefined===!1)throw new Error(`${V} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new I(m.null,null,1):new I(m.undefined,void 0,1)}function zp(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return new I(m.break,void 0,1)}function Lu(r,t,e){if(e){if(e.allowNaN===!1&&Number.isNaN(r))throw new Error(`${V} NaN values are not supported`);if(e.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${V} Infinity values are not supported`)}return new I(m.float,r,t)}function Kp(r,t,e,n){return Lu(Uu(r,t+1),3,n)}function qp(r,t,e,n){return Lu(Pu(r,t+1),5,n)}function jp(r,t,e,n){return Lu(Yp(r,t+1),9,n)}function Wi(r,t,e){let n=t.value;if(n===!1)r.push([m.float.majorEncoded|jx]);else if(n===!0)r.push([m.float.majorEncoded|Gx]);else if(n===null)r.push([m.float.majorEncoded|Wx]);else if(n===void 0)r.push([m.float.majorEncoded|Zx]);else{let o,s=!1;(!e||e.float64!==!0)&&(Wp(n),o=Uu(ve,1),n===o||Number.isNaN(n)?(ve[0]=249,r.push(ve.slice(0,3)),s=!0):(Zp(n),o=Pu(ve,1),n===o&&(ve[0]=250,r.push(ve.slice(0,5)),s=!0))),s||(Yx(n),o=Yp(ve,1),ve[0]=251,r.push(ve.slice(0,9)))}}Wi.encodedSize=function(t,e){let n=t.value;if(n===!1||n===!0||n===null||n===void 0)return 1;if(!e||e.float64!==!0){Wp(n);let o=Uu(ve,1);if(n===o||Number.isNaN(n))return 3;if(Zp(n),o=Pu(ve,1),n===o)return 5}return 9};var Gp=new ArrayBuffer(9),ae=new DataView(Gp,1),ve=new Uint8Array(Gp,0);function Wp(r){if(r===1/0)ae.setUint16(0,31744,!1);else if(r===-1/0)ae.setUint16(0,64512,!1);else if(Number.isNaN(r))ae.setUint16(0,32256,!1);else{ae.setFloat32(0,r);let t=ae.getUint32(0),e=(t&2139095040)>>23,n=t&8388607;if(e===255)ae.setUint16(0,31744,!1);else if(e===0)ae.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let o=e-127;o<-24?ae.setUint16(0,0):o<-14?ae.setUint16(0,(t&2147483648)>>16|1<<24+o,!1):ae.setUint16(0,(t&2147483648)>>16|o+15<<10|n>>13,!1)}}}function Uu(r,t){if(r.length-t<2)throw new Error(`${V} not enough data for float16`);let e=(r[t]<<8)+r[t+1];if(e===31744)return 1/0;if(e===64512)return-1/0;if(e===32256)return NaN;let n=e>>10&31,o=e&1023,s;return n===0?s=o*2**-24:n!==31?s=(o+1024)*2**(n-25):s=o===0?1/0:NaN,e&32768?-s:s}function Zp(r){ae.setFloat32(0,r,!1)}function Pu(r,t){if(r.length-t<4)throw new Error(`${V} not enough data for float32`);let e=(r.byteOffset||0)+t;return new DataView(r.buffer,e,4).getFloat32(0,!1)}function Yx(r){ae.setFloat64(0,r,!1)}function Yp(r,t){if(r.length-t<8)throw new Error(`${V} not enough data for float64`);let e=(r.byteOffset||0)+t;return new DataView(r.buffer,e,8).getFloat64(0,!1)}Wi.compareTokens=ie.compareTokens;function Q(r,t,e){throw new Error(`${V} encountered invalid minor (${e}) for major ${r[t]>>>5}`)}function Zi(r){return()=>{throw new Error(`${V} ${r}`)}}var P=[];for(let r=0;r<=23;r++)P[r]=Q;P[24]=sp;P[25]=ip;P[26]=ap;P[27]=cp;P[28]=Q;P[29]=Q;P[30]=Q;P[31]=Q;for(let r=32;r<=55;r++)P[r]=Q;P[56]=up;P[57]=lp;P[58]=fp;P[59]=dp;P[60]=Q;P[61]=Q;P[62]=Q;P[63]=Q;for(let r=64;r<=87;r++)P[r]=pp;P[88]=mp;P[89]=gp;P[90]=yp;P[91]=wp;P[92]=Q;P[93]=Q;P[94]=Q;P[95]=Zi("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)P[r]=xp;P[120]=bp;P[121]=vp;P[122]=Ep;P[123]=Ap;P[124]=Q;P[125]=Q;P[126]=Q;P[127]=Zi("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)P[r]=Bp;P[152]=kp;P[153]=Ip;P[154]=_p;P[155]=Tp;P[156]=Q;P[157]=Q;P[158]=Q;P[159]=Cp;for(let r=160;r<=183;r++)P[r]=Np;P[184]=Lp;P[185]=Up;P[186]=Pp;P[187]=Rp;P[188]=Q;P[189]=Q;P[190]=Q;P[191]=Dp;for(let r=192;r<=215;r++)P[r]=Fp;P[216]=Mp;P[217]=Vp;P[218]=Op;P[219]=$p;P[220]=Q;P[221]=Q;P[222]=Q;P[223]=Q;for(let r=224;r<=243;r++)P[r]=Zi("simple values are not supported");P[244]=Q;P[245]=Q;P[246]=Q;P[247]=Hp;P[248]=Zi("simple values are not supported");P[249]=Kp;P[250]=qp;P[251]=jp;P[252]=Q;P[253]=Q;P[254]=Q;P[255]=zp;var Ee=[];for(let r=0;r<24;r++)Ee[r]=new I(m.uint,r,1);for(let r=-1;r>=-24;r--)Ee[31-r]=new I(m.negint,r,1);Ee[64]=new I(m.bytes,new Uint8Array(0),1);Ee[96]=new I(m.string,"",1);Ee[128]=new I(m.array,0,1);Ee[160]=new I(m.map,0,1);Ee[244]=new I(m.false,!1,1);Ee[245]=new I(m.true,!0,1);Ee[246]=new I(m.null,null,1);function Jp(r){switch(r.type){case m.false:return Me([244]);case m.true:return Me([245]);case m.null:return Me([246]);case m.bytes:return r.value.length?void 0:Me([64]);case m.string:return r.value===""?Me([96]):void 0;case m.array:return r.value===0?Me([128]):void 0;case m.map:return r.value===0?Me([160]):void 0;case m.uint:return r.value<24?Me([Number(r.value)]):void 0;case m.negint:if(r.value>=-24)return Me([31-Number(r.value)])}}var Xx={float64:!1,mapSorter:e1,quickEncodeToken:Jp};function Qx(){let r=[];return r[m.uint.major]=ie,r[m.negint.major]=zi,r[m.bytes.major]=Rn,r[m.string.major]=Sp,r[m.array.major]=qi,r[m.map.major]=ji,r[m.tag.major]=Gi,r[m.float.major]=Wi,r}var Xp=Qx(),Ru=new Po,Ji=class r{constructor(t,e){this.obj=t,this.parent=e}includes(t){let e=this;do if(e.obj===t)return!0;while(e=e.parent);return!1}static createCheck(t,e){if(t&&t.includes(e))throw new Error(`${rr} object contains circular references`);return new r(e,t)}},Tr={null:new I(m.null,null),undefined:new I(m.undefined,void 0),true:new I(m.true,!0),false:new I(m.false,!1),emptyArray:new I(m.array,0),emptyMap:new I(m.map,0)},Cr={number(r,t,e,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new I(m.float,r):r>=0?new I(m.uint,r):new I(m.negint,r)},bigint(r,t,e,n){return r>=BigInt(0)?new I(m.uint,r):new I(m.negint,r)},Uint8Array(r,t,e,n){return new I(m.bytes,r)},string(r,t,e,n){return new I(m.string,r)},boolean(r,t,e,n){return r?Tr.true:Tr.false},null(r,t,e,n){return Tr.null},undefined(r,t,e,n){return Tr.undefined},ArrayBuffer(r,t,e,n){return new I(m.bytes,new Uint8Array(r))},DataView(r,t,e,n){return new I(m.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,t,e,n){if(!r.length)return e.addBreakTokens===!0?[Tr.emptyArray,new I(m.break)]:Tr.emptyArray;n=Ji.createCheck(n,r);let o=[],s=0;for(let i of r)o[s++]=Yi(i,e,n);return e.addBreakTokens?[new I(m.array,r.length),o,new I(m.break)]:[new I(m.array,r.length),o]},Object(r,t,e,n){let o=t!=="Object",s=o?r.keys():Object.keys(r),i=o?r.size:s.length;if(!i)return e.addBreakTokens===!0?[Tr.emptyMap,new I(m.break)]:Tr.emptyMap;n=Ji.createCheck(n,r);let a=[],c=0;for(let u of s)a[c++]=[Yi(u,e,n),Yi(o?r.get(u):r[u],e,n)];return t1(a,e),e.addBreakTokens?[new I(m.map,i),a,new I(m.break)]:[new I(m.map,i),a]}};Cr.Map=Cr.Object;Cr.Buffer=Cr.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))Cr[`${r}Array`]=Cr.DataView;function Yi(r,t={},e){let n=Jd(r),o=t&&t.typeEncoders&&t.typeEncoders[n]||Cr[n];if(typeof o=="function"){let i=o(r,n,t,e);if(i!=null)return i}let s=Cr[n];if(!s)throw new Error(`${rr} unsupported type: ${n}`);return s(r,n,t,e)}function t1(r,t){t.mapSorter&&r.sort(t.mapSorter)}function e1(r,t){let e=Array.isArray(r[0])?r[0][0]:r[0],n=Array.isArray(t[0])?t[0][0]:t[0];if(e.type!==n.type)return e.type.compare(n.type);let o=e.type.major,s=Xp[o].compareTokens(e,n);return s===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),s}function Qp(r,t,e,n){if(Array.isArray(t))for(let o of t)Qp(r,o,e,n);else e[t.type.major](r,t,n)}function Du(r,t,e){let n=Yi(r,e);if(!Array.isArray(n)&&e.quickEncodeToken){let o=e.quickEncodeToken(n);if(o)return o;let s=t[n.type.major];if(s.encodedSize){let i=s.encodedSize(n,e),a=new Po(i);if(s(a,n,e),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return Uo(a.chunks[0])}}return Ru.reset(),Qp(Ru,n,t,e),Ru.toBytes(!0)}function Nr(r,t){return t=Object.assign({},Xx,t),Du(r,Xp,t)}var r1={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},Xi=class{constructor(t,e={}){this._pos=0,this.data=t,this.options=e}pos(){return this._pos}done(){return this._pos>=this.data.length}next(){let t=this.data[this._pos],e=Ee[t];if(e===void 0){let n=P[t];if(!n)throw new Error(`${V} no decoder for major type ${t>>>5} (byte 0x${t.toString(16).padStart(2,"0")})`);let o=t&31;e=n(this.data,this._pos,o,this.options)}return this._pos+=e.encodedLength,e}},Mo=Symbol.for("DONE"),Qi=Symbol.for("BREAK");function n1(r,t,e){let n=[];for(let o=0;o<r.value;o++){let s=Mn(t,e);if(s===Qi){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed array`)}if(s===Mo)throw new Error(`${V} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=s}return n}function o1(r,t,e){let n=e.useMaps===!0,o=n?void 0:{},s=n?new Map:void 0;for(let i=0;i<r.value;i++){let a=Mn(t,e);if(a===Qi){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed map`)}if(a===Mo)throw new Error(`${V} found map but not enough entries (got ${i} [no key], expected ${r.value})`);if(n!==!0&&typeof a!="string")throw new Error(`${V} non-string keys not supported (got ${typeof a})`);if(e.rejectDuplicateMapKeys===!0&&(n&&s.has(a)||!n&&a in o))throw new Error(`${V} found repeat map key "${a}"`);let c=Mn(t,e);if(c===Mo)throw new Error(`${V} found map but not enough entries (got ${i} [no value], expected ${r.value})`);n?s.set(a,c):o[a]=c}return n?s:o}function Mn(r,t){if(r.done())return Mo;let e=r.next();if(e.type===m.break)return Qi;if(e.type.terminal)return e.value;if(e.type===m.array)return n1(e,r,t);if(e.type===m.map)return o1(e,r,t);if(e.type===m.tag){if(t.tags&&typeof t.tags[e.value]=="function"){let n=Mn(r,t);return t.tags[e.value](n)}throw new Error(`${V} tag not supported (${e.value})`)}throw new Error("unsupported")}function Fu(r,t){if(!(r instanceof Uint8Array))throw new Error(`${V} data to decode must be a Uint8Array`);t=Object.assign({},r1,t);let e=t.tokenizer||new Xi(r,t),n=Mn(e,t);if(n===Mo)throw new Error(`${V} did not find any content to decode`);if(n===Qi)throw new Error(`${V} got unexpected break`);return[n,r.subarray(e.pos())]}function oe(r,t){let[e,n]=Fu(r,t);if(n.length>0)throw new Error(`${V} too many terminals, data makes no sense`);return e}var or="/",t0=new TextEncoder().encode(or),ta=t0[0],Mt=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=K(t);else if(t instanceof Uint8Array)this._buf=t;else throw new Error("Invalid key, should be String of Uint8Array");if(e==null&&(e=!0),e&&this.clean(),this._buf.byteLength===0||this._buf[0]!==ta)throw new Error("Invalid key")}toString(t="utf8"){return nt(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(or))}static random(){return new r(Math.random().toString().substring(2))}static asKey(t){return t instanceof Uint8Array||typeof t=="string"?new r(t):typeof t.uint8Array=="function"?new r(t.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=t0),this._buf[0]!==ta){let t=new Uint8Array(this._buf.byteLength+1);t.fill(ta,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===ta;)this._buf=this._buf.subarray(0,-1)}less(t){let e=this.list(),n=t.list();for(let o=0;o<e.length;o++){if(n.length<o+1)return!1;let s=e[o],i=n[o];if(s<i)return!0;if(s>i)return!1}return e.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let t=this.namespaces();return t[t.length-1]}list(){return this.toString().split(or).slice(1)}type(){return s1(this.baseNamespace())}name(){return i1(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(or)||(t+=or),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(or):new r(t.slice(0,-1).join(or))}child(t){return this.toString()===or?t:t.toString()===or?this:new r(this.toString()+t.toString(),!1)}isAncestorOf(t){return t.toString()===this.toString()?!1:t.toString().startsWith(this.toString())}isDecendantOf(t){return t.toString()===this.toString()?!1:this.toString().startsWith(t.toString())}isTopLevel(){return this.list().length===1}concat(...t){return r.withNamespaces([...this.namespaces(),...a1(t.map(e=>e.namespaces()))])}};function s1(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function i1(r){let t=r.split(":");return t[t.length-1]}function a1(r){return[].concat(...r)}function ea({enumerable:r=!0,configurable:t=!1}={}){return{enumerable:r,configurable:t,writable:!1}}function*c1(r,t){if(t!=null&&typeof t=="object")if(Array.isArray(t))for(let[e,n]of t.entries()){let o=[...r,e],s=$.asCID(n);s!=null?yield[o.join("/"),s]:typeof n=="object"&&(yield*Vu(n,o))}else{let e=$.asCID(t);e!=null?yield[r.join("/"),e]:yield*Vu(t,r)}}function*Vu(r,t){if(r==null||r instanceof Uint8Array)return;let e=$.asCID(r);e!=null&&(yield[t.join("/"),e]);for(let[n,o]of Object.entries(r)){let s=[...t,n];yield*c1(s,o)}}function*u1(r,t){if(Array.isArray(t))for(let[e,n]of t.entries()){let o=[...r,e];yield o.join("/"),typeof n=="object"&&$.asCID(n)==null&&(yield*Ou(n,o))}else yield*Ou(t,r)}function*Ou(r,t){if(!(r==null||typeof r!="object"))for(let[e,n]of Object.entries(r)){let o=[...t,e];yield o.join("/"),n!=null&&!(n instanceof Uint8Array)&&typeof n=="object"&&$.asCID(n)==null&&(yield*u1(o,n))}}function l1(r,t){let e=r;for(let[n,o]of t.entries()){if(e=e[o],e==null)throw new Error(`Object has no property at ${t.slice(0,n+1).map(i=>`[${JSON.stringify(i)}]`).join("")}`);let s=$.asCID(e);if(s!=null)return{value:s,remaining:t.slice(n+1).join("/")}}return{value:e}}var $u=class{cid;bytes;value;asBlock;constructor({cid:t,bytes:e,value:n}){if(t==null||e==null||typeof n>"u")throw new Error("Missing required argument");this.cid=t,this.bytes=e,this.value=n,this.asBlock=this,Object.defineProperties(this,{cid:ea(),bytes:ea(),value:ea(),asBlock:ea()})}links(){return Vu(this.value,[])}tree(){return Ou(this.value,[])}get(t="/"){return l1(this.value,t.split("/").filter(Boolean))}};function e0({bytes:r,cid:t,value:e,codec:n}){let o=e!==void 0?e:n?.decode(r);if(o===void 0)throw new Error('Missing required argument, must either provide "value" or "codec"');return new $u({cid:t,bytes:r,value:o})}var o0="/pin/",r0="/pinned-block/",Hu=Ce,n0=1;function ra(r){return r.version===0&&(r=r.toV1()),new Mt(`${o0}${r.toString(Hu)}`)}var na=class{datastore;blockstore;getCodec;constructor(t,e,n){this.datastore=t,this.blockstore=e,this.getCodec=n}async*add(t,e={}){let n=ra(t);if(await this.datastore.has(n))throw new Error("Already pinned");let o=Math.round(e.depth??1/0);if(o<0)throw new Error("Depth must be greater than or equal to 0");let s=new He({concurrency:n0});for await(let a of this.#t(t,s,{...e,depth:o}))await this.#e(a,c=>c.pinnedBy.find(u=>st(u,t.bytes))!=null?!1:(c.pinCount++,c.pinnedBy.push(t.bytes),!0),e),yield a;let i={depth:o,metadata:e.metadata??{}};await this.datastore.put(n,Nr(i),e)}async*#t(t,e,n){if(n.depth===-1)return;let o=await this.getCodec(t.code),s=await this.blockstore.get(t,n),i=e0({bytes:s,cid:t,codec:o});yield t;for await(let[,a]of i.links())yield*await e.add(async()=>this.#t(a,e,{...n,depth:n.depth-1}))}async#e(t,e,n){let o=new Mt(`${r0}${Hu.encode(t.multihash.bytes)}`),s={pinCount:0,pinnedBy:[]};try{s=oe(await this.datastore.get(o,n))}catch(a){if(a.name!=="NotFoundError")throw a}if(e(s)){if(s.pinCount===0&&await this.datastore.has(o)){await this.datastore.delete(o);return}await this.datastore.put(o,Nr(s),n),n.onProgress?.(new tt("helia:pin:add",t))}}async*rm(t,e={}){let n=ra(t),o=await this.datastore.get(n,e),s=oe(o);await this.datastore.delete(n,e);let i=new He({concurrency:n0});for await(let a of this.#t(t,i,{...e,depth:s.depth}))await this.#e(a,c=>(c.pinCount--,c.pinnedBy=c.pinnedBy.filter(u=>st(u,t.bytes)),!0),{...e,depth:s.depth}),yield a}async*ls(t={}){for await(let{key:e,value:n}of this.datastore.query({prefix:o0+(t.cid!=null?`${t.cid.toString(Ce)}`:"")},t)){let o=$.parse(e.toString().substring(5),Ce),s=oe(n);yield{cid:o,...s}}}async isPinned(t,e={}){let n=new Mt(`${r0}${Hu.encode(t.multihash.bytes)}`);return this.datastore.has(n,e)}async get(t,e){let n=ra(t),o=await this.datastore.get(n,e);return oe(o)}async setMetadata(t,e,n){let o=ra(t),s=await this.datastore.get(o,n),i=oe(s);i.metadata=e??{},await this.datastore.put(o,Nr(i),n)}};var zu=1,Ku=5;var Vo=class extends Error{static name="InsufficientProvidersError";constructor(t="Insufficient providers found"){super(t),this.name="InsufficientProvidersError"}},Lr=class extends Error{static name="NoRoutersAvailableError";constructor(t="No routers available"){super(t),this.name="NoRoutersAvailableError"}},Oo=class extends Error{static name="UnknownHashAlgorithmError";constructor(t="Unknown hash algorithm"){super(t),this.name="UnknownHashAlgorithmError"}},$o=class extends Error{static name="UnknownCodecError";constructor(t="Unknown codec"){super(t),this.name="UnknownCodecError"}};var f1=5,oa=class{log;routers;providerLookupConcurrency;constructor(t,e){this.log=t.logger.forComponent("helia:routing"),this.routers=e.routers??[],this.providerLookupConcurrency=e.providerLookupConcurrency??f1}async start(){await fr(...this.routers)}async stop(){await hr(...this.routers)}async*findProviders(t,e={}){if(this.routers.length===0)throw new Lr("No content routers available");let n=new as({concurrency:this.providerLookupConcurrency});n.addEventListener("error",()=>{});for await(let o of $r(n.toGenerator(),...en(this.routers,"findProviders").map(s=>s.findProviders(t,e))))if(o!=null){if(o.multiaddrs.length===0){if(n.find(o.id)!=null)continue;n.add(async()=>{try{let s=await this.findPeer(o.id,e);return s.multiaddrs.length===0?null:s}catch(s){return this.log.error("could not load multiaddrs for peer %p",o.id,s),null}},{peerId:o.id,signal:e.signal}).catch(s=>{this.log.error("could not load multiaddrs for peer %p",o.id,s)})}yield o}}async provide(t,e={}){if(this.routers.length===0)throw new Lr("No content routers available");await Promise.all(en(this.routers,"provide").map(async n=>{await n.provide(t,e)}))}async cancelReprovide(t,e={}){await Promise.all(en(this.routers,"cancelReprovide").map(async n=>{await n.cancelReprovide(t,e)}))}async put(t,e,n){await Promise.all(en(this.routers,"put").map(async o=>{await o.put(t,e,n)}))}async get(t,e){return Promise.any(en(this.routers,"get").map(async n=>n.get(t,e)))}async findPeer(t,e){if(this.routers.length===0)throw new Lr("No peer routers available");let n=this,o=$r(...en(this.routers,"findPeer").map(s=>async function*(){try{yield await s.findPeer(t,e)}catch(i){n.log.error(i)}}()));for await(let s of o)if(s!=null)return s;throw new Ut("Could not find peer in routing")}async*getClosestPeers(t,e={}){if(this.routers.length===0)throw new Lr("No peer routers available");for await(let n of $r(...en(this.routers,"getClosestPeers").map(o=>o.getClosestPeers(t,e))))n!=null&&(yield n)}};function en(r,t){return r.filter(e=>e[t]!=null)}var Ur={},Vn=r=>{r.addEventListener("message",t=>{Vn.dispatchEvent("message",r,t)}),r.port!=null&&r.port.addEventListener("message",t=>{Vn.dispatchEvent("message",r,t)})};Vn.addEventListener=(r,t)=>{Ur[r]==null&&(Ur[r]=[]),Ur[r].push(t)};Vn.removeEventListener=(r,t)=>{Ur[r]!=null&&(Ur[r]=Ur[r].filter(e=>e===t))};Vn.dispatchEvent=function(r,t,e){Ur[r]!=null&&Ur[r].forEach(n=>n(t,e))};var qu=Vn;var ju="lock:worker:request-read",Gu="lock:worker:release-read",Wu="lock:master:grant-read",Zu="lock:worker:request-write",Yu="lock:worker:release-write",Ju="lock:master:grant-write";var s0=(r=21)=>Math.random().toString().substring(2);var i0=(r,t,e,n,o)=>(s,i)=>{if(i.data.type!==e)return;let a={type:i.data.type,name:i.data.name,identifier:i.data.identifier};r.dispatchEvent(new MessageEvent(t,{data:{name:a.name,handler:async()=>{s.postMessage({type:o,name:a.name,identifier:a.identifier}),await new Promise(c=>{let u=f=>{if(f?.data==null)return;let l={type:f.data.type,name:f.data.name,identifier:f.data.identifier};l.type===n&&l.identifier===a.identifier&&(s.removeEventListener("message",u),c())};s.addEventListener("message",u)})}}}))},a0=(r,t,e,n)=>async()=>{let o=s0();return globalThis.postMessage({type:t,identifier:o,name:r}),new Promise(s=>{let i=a=>{if(a?.data==null)return;let c={type:a.data.type,identifier:a.data.identifier};c.type===e&&c.identifier===o&&(globalThis.removeEventListener("message",i),s(()=>{globalThis.postMessage({type:n,identifier:o,name:r})}))};globalThis.addEventListener("message",i)})},h1={singleProcess:!1},c0=r=>{if(r=Object.assign({},h1,r),!!globalThis.document||r.singleProcess){let e=new EventTarget;return qu.addEventListener("message",i0(e,"requestReadLock",ju,Gu,Wu)),qu.addEventListener("message",i0(e,"requestWriteLock",Zu,Yu,Ju)),e}return{isWorker:!0,readLock:e=>a0(e,ju,Wu,Gu),writeLock:e=>a0(e,Zu,Ju,Yu)}};var rn={},Pr;async function Xu(r,t){let e,n=new Promise(o=>{e=o});return r.add(async()=>No((async()=>{await new Promise(o=>{e(()=>{o()})})})(),{milliseconds:t.timeout})),n}var d1=(r,t)=>{if(Pr.isWorker===!0)return{readLock:Pr.readLock(r,t),writeLock:Pr.writeLock(r,t)};let e=new Fe({concurrency:1}),n;return{async readLock(){if(n!=null)return Xu(n,t);n=new Fe({concurrency:t.concurrency,autoStart:!1});let o=n,s=Xu(n,t);return e.add(async()=>{o.start(),await o.onIdle().then(()=>{n===o&&(n=null)})}),s},async writeLock(){return n=null,Xu(e,t)}}},p1={name:"lock",concurrency:1/0,timeout:846e5,singleProcess:!1};function Qu(r){let t=Object.assign({},p1,r);return Pr==null&&(Pr=c0(t),Pr.isWorker!==!0&&(Pr.addEventListener("requestReadLock",e=>{rn[e.data.name]!=null&&rn[e.data.name].readLock().then(async n=>e.data.handler().finally(()=>{n()}))}),Pr.addEventListener("requestWriteLock",async e=>{rn[e.data.name]!=null&&rn[e.data.name].writeLock().then(async n=>e.data.handler().finally(()=>{n()}))}))),rn[t.name]==null&&(rn[t.name]=d1(t.name,t)),rn[t.name]}var sa=class{lock;child;pins;started;constructor(t,e,n={}){this.child=t,this.pins=e,this.lock=Qu({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await fr(this.child),this.started=!0}async stop(){await hr(this.child),this.started=!1}unwrap(){return this.child}async put(t,e,n={}){n?.signal?.throwIfAborted();let o=await this.lock.readLock();try{return await this.child.put(t,e,n)}finally{o()}}async*putMany(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{yield*this.child.putMany(t,e)}finally{n()}}async get(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{return await this.child.get(t,e)}finally{n()}}async*getMany(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{yield*this.child.getMany(t,e)}finally{n()}}async delete(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.writeLock();try{if(await this.pins.isPinned(t))throw new Error("CID was pinned");await this.child.delete(t,e)}finally{n()}}async*deleteMany(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.writeLock();try{let o=this;yield*this.child.deleteMany(async function*(){for await(let s of t){if(await o.pins.isPinned(s))throw new Error("CID was pinned");yield s}}(),e)}finally{n()}}async has(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{return await this.child.has(t,e)}finally{n()}}async*getAll(t={}){t?.signal?.throwIfAborted();let e=await this.lock.readLock();try{yield*this.child.getAll(t)}finally{e()}}createSession(t,e){return e?.signal?.throwIfAborted(),this.child.createSession(t,e)}};var tl=new Mt("/version"),u0=1;async function l0(r){if(!await r.has(tl)){await r.put(tl,K(`${u0}`));return}let t=await r.get(tl),e=nt(t);if(parseInt(e,10)!==u0)throw new Error("Unknown datastore version, a datastore migration may be required")}var nl={};gt(nl,{code:()=>rl,decode:()=>A1,decodeOptions:()=>b1,encode:()=>E1,encodeOptions:()=>w1,name:()=>v1,toByteView:()=>h0});var f0=42;function h0(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}function m1(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let t=$.asCID(r);if(!t)return null;let e=new Uint8Array(t.bytes.byteLength+1);return e.set(t.bytes,1),[new I(m.tag,f0),new I(m.bytes,e)]}function g1(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function y1(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}var el={float64:!0,typeEncoders:{Object:m1,undefined:g1,number:y1}},w1={...el,typeEncoders:{...el.typeEncoders}};function x1(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return $.decode(r.subarray(1))}var ia={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};ia.tags[f0]=x1;var b1={...ia,tags:ia.tags.slice()},v1="dag-cbor",rl=113,E1=r=>Nr(r,el),A1=r=>oe(h0(r),ia);var ll={};gt(ll,{code:()=>ul,decode:()=>p0,encode:()=>d0,format:()=>P1,name:()=>U1,parse:()=>D1,stringify:()=>P1});var ol=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(t){let e=this.inRecursive[this.inRecursive.length-1];e&&(e.type===m.array&&(e.elements++,e.elements!==1&&t.push([44])),e.type===m.map&&(e.elements++,e.elements!==1&&(e.elements%2===1?t.push([44]):t.push([58]))))}[m.uint.major](t,e){this.prefix(t);let n=String(e.value),o=[];for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);t.push(o)}[m.negint.major](t,e){this[m.uint.major](t,e)}[m.bytes.major](t,e){throw new Error(`${rr} unsupported type: Uint8Array`)}[m.string.major](t,e){this.prefix(t);let n=Hi(JSON.stringify(e.value));t.push(n.length>32?Uo(n):n)}[m.array.major](t,e){this.prefix(t),this.inRecursive.push({type:m.array,elements:0}),t.push([91])}[m.map.major](t,e){this.prefix(t),this.inRecursive.push({type:m.map,elements:0}),t.push([123])}[m.tag.major](t,e){}[m.float.major](t,e){if(e.type.name==="break"){let i=this.inRecursive.pop();if(i){if(i.type===m.array)t.push([93]);else if(i.type===m.map)t.push([125]);else throw new Error("Unexpected recursive type; this should not happen!");return}throw new Error("Unexpected break; this should not happen!")}if(e.value===void 0)throw new Error(`${rr} unsupported type: undefined`);if(this.prefix(t),e.type.name==="true"){t.push([116,114,117,101]);return}else if(e.type.name==="false"){t.push([102,97,108,115,101]);return}else if(e.type.name==="null"){t.push([110,117,108,108]);return}let n=String(e.value),o=[],s=!1;for(let i=0;i<n.length;i++)o[i]=n.charCodeAt(i),!s&&(o[i]===46||o[i]===101||o[i]===69)&&(s=!0);s||(o.push(46),o.push(48)),t.push(o)}};function S1(r,t){if(Array.isArray(r[0])||Array.isArray(t[0]))throw new Error(`${rr} complex map keys are not supported`);let e=r[0],n=t[0];if(e.type!==m.string||n.type!==m.string)throw new Error(`${rr} non-string map keys are not supported`);if(e<n)return-1;if(e>n)return 1;throw new Error(`${rr} unexpected duplicate map keys, this is not supported`)}var B1={addBreakTokens:!0,mapSorter:S1};function sl(r,t){return t=Object.assign({},B1,t),Du(r,new ol,t)}var On=class{constructor(t,e={}){this._pos=0,this.data=t,this.options=e,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 t=this.ch();for(;t===32||t===9||t===13||t===10;)t=this.data[++this._pos]}expect(t){if(this.data.length-this._pos<t.length)throw new Error(`${V} unexpected end of input at position ${this._pos}`);for(let e=0;e<t.length;e++)if(this.data[this._pos++]!==t[e])throw new Error(`${V} unexpected token at position ${this._pos}, expected to find '${String.fromCharCode(...t)}'`)}parseNumber(){let t=this._pos,e=!1,n=!1,o=a=>{for(;!this.done();){let c=this.ch();if(a.includes(c))this._pos++;else break}};if(this.ch()===45&&(e=!0,this._pos++),this.ch()===48)if(this._pos++,this.ch()===46)this._pos++,n=!0;else return new I(m.uint,0,this._pos-t);if(o([48,49,50,51,52,53,54,55,56,57]),e&&this._pos===t+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++,o([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++,o([48,49,50,51,52,53,54,55,56,57]));let s=String.fromCharCode.apply(null,this.data.subarray(t,this._pos)),i=parseFloat(s);return n?new I(m.float,i,this._pos-t):this.options.allowBigInt!==!0||Number.isSafeInteger(i)?new I(i>=0?m.uint:m.negint,i,this._pos-t):new I(i>=0?m.uint:m.negint,BigInt(s),this._pos-t)}parseString(){if(this.ch()!==34)throw new Error(`${V} unexpected character at position ${this._pos}; this shouldn't happen`);this._pos++;for(let s=this._pos,i=0;s<this.data.length&&i<65536;s++,i++){let a=this.data[s];if(a===92||a<32||a>=128)break;if(a===34){let c=String.fromCharCode.apply(null,this.data.subarray(this._pos,s));return this._pos=s+1,new I(m.string,c,i)}}let t=this._pos,e=[],n=()=>{if(this._pos+4>=this.data.length)throw new Error(`${V} unexpected end of unicode escape sequence at position ${this._pos}`);let s=0;for(let i=0;i<4;i++){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}`);s=s*16+a,this._pos++}return s},o=()=>{let s=this.ch(),i=null,a=s>239?4:s>223?3:s>191?2:1;if(this._pos+a>this.data.length)throw new Error(`${V} unexpected unicode sequence at position ${this._pos}`);let c,u,f,l;switch(a){case 1:s<128&&(i=s);break;case 2:c=this.data[this._pos+1],(c&192)===128&&(l=(s&31)<<6|c&63,l>127&&(i=l));break;case 3:c=this.data[this._pos+1],u=this.data[this._pos+2],(c&192)===128&&(u&192)===128&&(l=(s&15)<<12|(c&63)<<6|u&63,l>2047&&(l<55296||l>57343)&&(i=l));break;case 4:c=this.data[this._pos+1],u=this.data[this._pos+2],f=this.data[this._pos+3],(c&192)===128&&(u&192)===128&&(f&192)===128&&(l=(s&15)<<18|(c&63)<<12|(u&63)<<6|f&63,l>65535&&l<1114112&&(i=l))}i===null?(i=65533,a=1):i>65535&&(i-=65536,e.push(i>>>10&1023|55296),i=56320|i&1023),e.push(i),this._pos+=a};for(;!this.done();){let s=this.ch(),i;switch(s){case 92:if(this._pos++,this.done())throw new Error(`${V} unexpected string termination at position ${this._pos}`);switch(i=this.ch(),this._pos++,i){case 34:case 39:case 92:case 47:e.push(i);break;case 98:e.push(8);break;case 116:e.push(9);break;case 110:e.push(10);break;case 102:e.push(12);break;case 114:e.push(13);break;case 117:e.push(n());break;default:throw new Error(`${V} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new I(m.string,Cu(e),this._pos-t);default:if(s<32)throw new Error(`${V} invalid control character at position ${this._pos}`);s<128?(e.push(s),this._pos++):o()}}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 I(m.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new I(m.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new I(m.null,null,4);case 102:return this.expect([102,97,108,115,101]),new I(m.false,!1,5);case 116:return this.expect([116,114,117,101]),new I(m.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 I(m.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 I(m.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 I(m.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 I(m.break,void 0,1);let t=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"),t}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 il(r,t){return t=Object.assign({tokenizer:new On(r,t)},t),oe(r,t)}function I1(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}function _1(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let t=$.asCID(r);if(!t)return null;let e=t.toString();return[new I(m.map,1/0,1),new I(m.string,"/",1),new I(m.string,e,e.length),new I(m.break,void 0,1)]}function aa(r){let t=Ne.encode(r).slice(1);return[new I(m.map,1/0,1),new I(m.string,"/",1),new I(m.map,1/0,1),new I(m.string,"bytes",5),new I(m.string,t,t.length),new I(m.break,void 0,1),new I(m.break,void 0,1)]}function Ae(r){return aa(new Uint8Array(r.buffer,r.byteOffset,r.byteLength))}function T1(r){return aa(new Uint8Array(r))}function C1(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function N1(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}var L1={typeEncoders:{Object:_1,Buffer:aa,Uint8Array:aa,Int8Array:Ae,Uint16Array:Ae,Int16Array:Ae,Uint32Array:Ae,Int32Array:Ae,Float32Array:Ae,Float64Array:Ae,Uint8ClampedArray:Ae,BigInt64Array:Ae,BigUint64Array:Ae,DataView:Ae,ArrayBuffer:T1,undefined:C1,number:N1}},al=class extends On{constructor(t,e){super(t,e),this.tokenBuffer=[]}done(){return this.tokenBuffer.length===0&&super.done()}_next(){return this.tokenBuffer.length>0?this.tokenBuffer.pop():super.next()}next(){let t=this._next();if(t.type===m.map){let e=this._next();if(e.type===m.string&&e.value==="/"){let n=this._next();if(n.type===m.string){if(this._next().type!==m.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new I(m.tag,42,0)}if(n.type===m.map){let o=this._next();if(o.type===m.string&&o.value==="bytes"){let s=this._next();if(s.type===m.string){for(let a=0;a<2;a++)if(this._next().type!==m.break)throw new Error("Invalid encoded Bytes form");let i=Ne.decode(`m${s.value}`);return new I(m.bytes,i,s.value.length)}this.tokenBuffer.push(s)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(e)}return t}},cl={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};cl.tags[42]=$.parse;var U1="dag-json",ul=297,d0=r=>sl(r,L1),p0=r=>{let t=I1(r),e=Object.assign(cl,{tokenizer:new al(t,cl)});return il(t,e)},P1=r=>R1.decode(d0(r));var R1=new TextDecoder,D1=r=>p0(F1.encode(r)),F1=new TextEncoder;var gl={};gt(gl,{code:()=>ml,createLink:()=>S0,createNode:()=>A0,decode:()=>Y1,encode:()=>Z1,name:()=>W1,prepare:()=>dl,validate:()=>pl});var M1=new TextDecoder;function fl(r,t){let e=0;for(let n=0;;n+=7){if(n>=64)throw new Error("protobuf: varint overflow");if(t>=r.length)throw new Error("protobuf: unexpected end of data");let o=r[t++];if(e+=n<28?(o&127)<<n:(o&127)*2**n,o<128)break}return[e,t]}function ca(r,t){let e;[e,t]=fl(r,t);let n=t+e;if(e<0||n<0)throw new Error("protobuf: invalid length");if(n>r.length)throw new Error("protobuf: unexpected end of data");return[r.subarray(t,n),n]}function m0(r,t){let e;return[e,t]=fl(r,t),[e&7,e>>3,t]}function V1(r){let t={},e=r.length,n=0;for(;n<e;){let o,s;if([o,s,n]=m0(r,n),s===1){if(t.Hash)throw new Error("protobuf: (PBLink) duplicate Hash section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Hash`);if(t.Name!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Name before Hash");if(t.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Hash");[t.Hash,n]=ca(r,n)}else if(s===2){if(t.Name!==void 0)throw new Error("protobuf: (PBLink) duplicate Name section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Name`);if(t.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Name");let i;[i,n]=ca(r,n),t.Name=M1.decode(i)}else if(s===3){if(t.Tsize!==void 0)throw new Error("protobuf: (PBLink) duplicate Tsize section");if(o!==0)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Tsize`);[t.Tsize,n]=fl(r,n)}else throw new Error(`protobuf: (PBLink) invalid fieldNumber, expected 1, 2 or 3, got ${s}`)}if(n>e)throw new Error("protobuf: (PBLink) unexpected end of data");return t}function g0(r){let t=r.length,e=0,n,o=!1,s;for(;e<t;){let a,c;if([a,c,e]=m0(r,e),a!==2)throw new Error(`protobuf: (PBNode) invalid wireType, expected 2, got ${a}`);if(c===1){if(s)throw new Error("protobuf: (PBNode) duplicate Data section");[s,e]=ca(r,e),n&&(o=!0)}else if(c===2){if(o)throw new Error("protobuf: (PBNode) duplicate Links section");n||(n=[]);let u;[u,e]=ca(r,e),n.push(V1(u))}else throw new Error(`protobuf: (PBNode) invalid fieldNumber, expected 1 or 2, got ${c}`)}if(e>t)throw new Error("protobuf: (PBNode) unexpected end of data");let i={};return s&&(i.Data=s),i.Links=n||[],i}var w0=new TextEncoder,y0=2**32,O1=2**31;function $1(r,t){let e=t.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");e=Ho(t,e,r.Tsize)-1,t[e]=24}if(typeof r.Name=="string"){let n=w0.encode(r.Name);e-=n.length,t.set(n,e),e=Ho(t,e,n.length)-1,t[e]=18}return r.Hash&&(e-=r.Hash.length,t.set(r.Hash,e),e=Ho(t,e,r.Hash.length)-1,t[e]=10),t.length-e}function x0(r){let t=z1(r),e=new Uint8Array(t),n=t;if(r.Data&&(n-=r.Data.length,e.set(r.Data,n),n=Ho(e,n,r.Data.length)-1,e[n]=10),r.Links)for(let o=r.Links.length-1;o>=0;o--){let s=$1(r.Links[o],e.subarray(0,n));n-=s,n=Ho(e,n,s)-1,e[n]=18}return e}function H1(r){let t=0;if(r.Hash){let e=r.Hash.length;t+=1+e+$n(e)}if(typeof r.Name=="string"){let e=w0.encode(r.Name).length;t+=1+e+$n(e)}return typeof r.Tsize=="number"&&(t+=1+$n(r.Tsize)),t}function z1(r){let t=0;if(r.Data){let e=r.Data.length;t+=1+e+$n(e)}if(r.Links)for(let e of r.Links){let n=H1(e);t+=1+n+$n(n)}return t}function Ho(r,t,e){t-=$n(e);let n=t;for(;e>=O1;)r[t++]=e&127|128,e/=128;for(;e>=128;)r[t++]=e&127|128,e>>>=7;return r[t]=e,n}function $n(r){return r%2===0&&r++,Math.floor((K1(r)+6)/7)}function K1(r){let t=0;return r>=y0&&(r=Math.floor(r/y0),t=32),r>=65536&&(r>>>=16,t+=16),r>=256&&(r>>>=8,t+=8),t+q1[r]}var q1=[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 j1=["Data","Links"],G1=["Hash","Name","Tsize"],hl=new TextEncoder;function v0(r,t){if(r===t)return 0;let e=r.Name?hl.encode(r.Name):[],n=t.Name?hl.encode(t.Name):[],o=e.length,s=n.length;for(let i=0,a=Math.min(o,s);i<a;++i)if(e[i]!==n[i]){o=e[i],s=n[i];break}return o<s?-1:s<o?1:0}function b0(r,t){return!Object.keys(r).some(e=>!t.includes(e))}function E0(r){if(typeof r.asCID=="object"){let e=$.asCID(r);if(!e)throw new TypeError("Invalid DAG-PB form");return{Hash:e}}if(typeof r!="object"||Array.isArray(r))throw new TypeError("Invalid DAG-PB form");let t={};if(r.Hash){let e=$.asCID(r.Hash);try{e||(typeof r.Hash=="string"?e=$.parse(r.Hash):r.Hash instanceof Uint8Array&&(e=$.decode(r.Hash)))}catch(n){throw new TypeError(`Invalid DAG-PB form: ${n.message}`)}e&&(t.Hash=e)}if(!t.Hash)throw new TypeError("Invalid DAG-PB form");return typeof r.Name=="string"&&(t.Name=r.Name),typeof r.Tsize=="number"&&(t.Tsize=r.Tsize),t}function dl(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 t={};if(r.Data!==void 0)if(typeof r.Data=="string")t.Data=hl.encode(r.Data);else if(r.Data instanceof Uint8Array)t.Data=r.Data;else throw new TypeError("Invalid DAG-PB form");if(r.Links!==void 0)if(Array.isArray(r.Links))t.Links=r.Links.map(E0),t.Links.sort(v0);else throw new TypeError("Invalid DAG-PB form");else t.Links=[];return t}function pl(r){if(!r||typeof r!="object"||Array.isArray(r)||r instanceof Uint8Array||r["/"]&&r["/"]===r.bytes)throw new TypeError("Invalid DAG-PB form");if(!b0(r,j1))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 t=0;t<r.Links.length;t++){let e=r.Links[t];if(!e||typeof e!="object"||Array.isArray(e)||e instanceof Uint8Array||e["/"]&&e["/"]===e.bytes)throw new TypeError("Invalid DAG-PB form (bad link)");if(!b0(e,G1))throw new TypeError("Invalid DAG-PB form (extraneous properties on link)");if(e.Hash===void 0)throw new TypeError("Invalid DAG-PB form (link must have a Hash)");if(e.Hash==null||!e.Hash["/"]||e.Hash["/"]!==e.Hash.bytes)throw new TypeError("Invalid DAG-PB form (link Hash must be a CID)");if(e.Name!==void 0&&typeof e.Name!="string")throw new TypeError("Invalid DAG-PB form (link Name must be a string)");if(e.Tsize!==void 0){if(typeof e.Tsize!="number"||e.Tsize%1!==0)throw new TypeError("Invalid DAG-PB form (link Tsize must be an integer)");if(e.Tsize<0)throw new TypeError("Invalid DAG-PB form (link Tsize cannot be negative)")}if(t>0&&v0(e,r.Links[t-1])===-1)throw new TypeError("Invalid DAG-PB form (links must be sorted by Name bytes)")}}function A0(r,t=[]){return dl({Data:r,Links:t})}function S0(r,t,e){return E0({Hash:e,Name:r,Tsize:t})}function B0(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var W1="dag-pb",ml=112;function Z1(r){pl(r);let t={};return r.Links&&(t.Links=r.Links.map(e=>{let n={};return e.Hash&&(n.Hash=e.Hash.bytes),e.Name!==void 0&&(n.Name=e.Name),e.Tsize!==void 0&&(n.Tsize=e.Tsize),n})),r.Data&&(t.Data=r.Data),x0(t)}function Y1(r){let t=B0(r),e=g0(t),n={};return e.Data&&(n.Data=e.Data),e.Links&&(n.Links=e.Links.map(o=>{let s={};try{s.Hash=$.decode(o.Hash)}catch{}if(!s.Hash)throw new Error("Invalid Hash field found in link, expected CID");return o.Name!==void 0&&(s.Name=o.Name),o.Tsize!==void 0&&(s.Tsize=o.Tsize),s})),n}function Hn(r){return r?.then!=null}function k0(r=[],t){let e={[ml]:gl,[Qn]:to,[rl]:nl,[ul]:ll,[xc]:ls};return r.forEach(n=>{e[n.code]=n}),async n=>{let o=e[n];if(o==null&&t!=null){let s=t(n);Hn(s)?o=await s:o=s,e[o.code]=o}if(o!=null)return o;throw new $o(`Could not load codec for ${n}`)}}function I0(r=[],t){let e={[mr.code]:mr,[hs.code]:hs,[jt.code]:jt};return r.forEach(n=>{e[n.code]=n}),async n=>{let o=e[n];if(o==null&&t!=null){let s=t(n);Hn(s)?o=await s:o=s,e[o.code]=o}if(o!=null)return o;throw new Oo(`No hasher configured for multihash code 0x${n.toString(16)}, please configure one. You can look up which hash this is at https://github.com/multiformats/multicodec/blob/master/table.csv`)}}var ce=class r extends Error{static name="NotFoundError";static code="ERR_NOT_FOUND";name=r.name;code=r.code;constructor(t="Not Found"){super(t)}};var sr=class{has(t,e){return Promise.reject(new Error(".has is not implemented"))}put(t,e,n){return Promise.reject(new Error(".put is not implemented"))}async*putMany(t,e){for await(let{cid:n,block:o}of t)await this.put(n,o,e),yield n}get(t,e){return Promise.reject(new Error(".get is not implemented"))}async*getMany(t,e){for await(let n of t)yield{cid:n,block:await this.get(n,e)}}delete(t,e){return Promise.reject(new Error(".delete is not implemented"))}async*deleteMany(t,e){for await(let n of t)await this.delete(n,e),yield n}async*getAll(t){throw new Error(".getAll is not implemented")}};var ua=0,la=class extends sr{child;constructor(t){super(),this.child=t}put(t,e){return t.multihash.code===ua||this.child==null?t:this.child.put(t,e)}get(t){if(t.multihash.code===ua)return t.multihash.digest;if(this.child==null)throw new ce;return this.child.get(t)}has(t){return t.multihash.code===ua?!0:this.child==null?!1:this.child.has(t)}delete(t){if(t.code!==ua&&this.child!=null)return this.child.delete(t)}getAll(t){return this.child!=null?this.child.getAll(t):[]}};function J1(r){return r[Symbol.asyncIterator]!=null}function X1(r,t){let e=0;if(J1(r))return async function*(){for await(let c of r)await t(c,e++)&&(yield c)}();let n=hn(r),{value:o,done:s}=n.next();if(s===!0)return function*(){}();let i=t(o,e++);if(typeof i.then=="function")return async function*(){await i&&(yield o);for await(let c of n)await t(c,e++)&&(yield c)}();let a=t;return function*(){i===!0&&(yield o);for(let c of n)a(c,e++)&&(yield c)}()}var Se=X1;function Q1(r){return r[Symbol.asyncIterator]!=null}function _0(r){return r?.then!=null}function tb(r,t){let e=0;if(Q1(r))return async function*(){for await(let c of r){let u=t(c,e++);_0(u)&&await u,yield c}}();let n=hn(r),{value:o,done:s}=n.next();if(s===!0)return function*(){}();if(typeof t(o,e++)?.then=="function")return async function*(){yield o;for await(let c of n){let u=t(c,e++);_0(u)&&await u,yield c}}();let a=t;return function*(){yield o;for(let c of n)a(c,e++),yield c}()}var yl=tb;var fa=class{child;getHasher;log;logger;components;constructor(t){this.log=t.logger.forComponent("helia:networked-storage"),this.logger=t.logger,this.components=t,this.child=new la(t.blockstore),this.getHasher=t.getHasher}async put(t,e,n={}){return await this.child.has(t,n)?(n.onProgress?.(new tt("blocks:put:duplicate",t)),t):(n.onProgress?.(new tt("blocks:put:providers:notify",t)),await Promise.all(this.components.blockBrokers.map(async o=>o.announce?.(t,e,n))),n.onProgress?.(new tt("blocks:put:blockstore:put",t)),this.child.put(t,e,n))}async*putMany(t,e={}){let n=Se(t,async({cid:s})=>{let i=await this.child.has(s,e);return i&&e.onProgress?.(new tt("blocks:put-many:duplicate",s)),!i}),o=yl(n,async({cid:s,block:i})=>{e.onProgress?.(new tt("blocks:put-many:providers:notify",s)),await Promise.all(this.components.blockBrokers.map(async a=>a.announce?.(s,i,e)))});e.onProgress?.(new tt("blocks:put-many:blockstore:put-many")),yield*this.child.putMany(o,e)}async get(t,e={}){if(e.offline!==!0&&!await this.child.has(t,e)){let n=await this.getHasher(t.multihash.code);e.onProgress?.(new tt("blocks:get:providers:get",t));let o=await T0(t,this.components.blockBrokers,n,{...e,log:this.log});return e.onProgress?.(new tt("blocks:get:blockstore:put",t)),await this.child.put(t,o,e),e.onProgress?.(new tt("blocks:get:providers:notify",t)),await Promise.all(this.components.blockBrokers.map(async s=>s.announce?.(t,o,e))),o}return e.onProgress?.(new tt("blocks:get:blockstore:get",t)),this.child.get(t,e)}async*getMany(t,e={}){e.onProgress?.(new tt("blocks:get-many:blockstore:get-many")),yield*this.child.getMany(yl(t,async n=>{if(e.offline!==!0&&!await this.child.has(n,e)){let o=await this.getHasher(n.multihash.code);e.onProgress?.(new tt("blocks:get-many:providers:get",n));let s=await T0(n,this.components.blockBrokers,o,{...e,log:this.log});e.onProgress?.(new tt("blocks:get-many:blockstore:put",n)),await this.child.put(n,s,e),e.onProgress?.(new tt("blocks:get-many:providers:notify",n)),await Promise.all(this.components.blockBrokers.map(async i=>i.announce?.(n,s,e)))}}))}async delete(t,e={}){e.onProgress?.(new tt("blocks:delete:blockstore:delete",t)),await this.child.delete(t,e)}async*deleteMany(t,e={}){e.onProgress?.(new tt("blocks:delete-many:blockstore:delete-many")),yield*this.child.deleteMany(async function*(){for await(let n of t)yield n}(),e)}async has(t,e={}){return this.child.has(t,e)}async*getAll(t={}){t.onProgress?.(new tt("blocks:get-all:blockstore:get-many")),yield*this.child.getAll(t)}},ha=class extends fa{started;constructor(t){super(t),this.started=!1}isStarted(){return this.started}async start(){await fr(this.child,...this.components.blockBrokers),this.started=!0}async stop(){await hr(this.child,...this.components.blockBrokers),this.started=!1}unwrap(){return this.child}createSession(t,e){let n=this.components.blockBrokers.map(o=>o.createSession==null?o:o.createSession(e));return new wl({blockstore:this.child,blockBrokers:n,getHasher:this.getHasher,logger:this.logger},{root:t})}},wl=class extends fa{closeController;constructor(t,e){super(t),this.closeController=new AbortController,ht(1/0,this.closeController.signal),this.log=t.logger.forComponent(`helia:session-storage:${e.root}`)}close(){this.closeController.abort()}async put(t,e,n={}){let o=$t([this.closeController.signal,n.signal]);ht(1/0,o);try{return await super.put(t,e,{...n,signal:o})}finally{o.clear()}}async*putMany(t,e={}){let n=$t([this.closeController.signal,e.signal]);ht(1/0,n);try{yield*super.putMany(t,{...e,signal:n})}finally{n.clear()}}async get(t,e={}){let n=$t([this.closeController.signal,e.signal]);ht(1/0,n);try{return await super.get(t,{...e,signal:n})}finally{n.clear()}}async*getMany(t,e={}){let n=$t([this.closeController.signal,e.signal]);ht(1/0,n);try{yield*super.getMany(t,{...e,signal:n})}finally{n.clear()}}async delete(t,e={}){let n=$t([this.closeController.signal,e.signal]);ht(1/0,n);try{await super.delete(t,{...e,signal:n})}finally{n.clear()}}async*deleteMany(t,e={}){let n=$t([this.closeController.signal,e.signal]);ht(1/0,n);try{yield*super.deleteMany(t,{...e,signal:n})}finally{n.clear()}}async has(t,e={}){let n=$t([this.closeController.signal,e.signal]);ht(1/0,n);try{return await super.has(t,{...e,signal:n})}finally{n.clear()}}async*getAll(t={}){let e=$t([this.closeController.signal,t.signal]);ht(1/0,e);try{yield*super.getAll({...t,signal:e})}finally{e.clear()}}};function eb(r){return typeof r.retrieve=="function"}var rb=(r,t)=>{if(t==null)throw new Et(`No hasher configured for multihash code 0x${r.multihash.code.toString(16)}, please configure one. You can look up which hash this is at https://github.com/multiformats/multicodec/blob/master/table.csv`);return async e=>{let n,o=t.digest(e);if(Hn(o)?n=await o:n=o,!st(n.digest,r.multihash.digest))throw new lr("Hash of downloaded block did not match multihash from passed CID")}};async function T0(r,t,e,n){let o=rb(r,e),s=new AbortController,i=$t([s.signal,n.signal]);ht(1/0,s.signal,i);let a=[];for(let c of t)eb(c)&&a.push(c);try{return await Promise.any(a.map(async c=>{try{let u=!1,f=await c.retrieve(r,{...n,signal:i,validateFn:async l=>{await o(l),u=!0}});return u||await o(f),f}catch(u){throw n.log.error("could not retrieve verified block for %c",r,u),u}}))}finally{s.abort(),i.clear()}}var zo=class extends un{intialPeerSearchComplete;requests;name;log;logger;minProviders;maxProviders;providers;evictionFilter;constructor(t,e){super(),ht(1/0,this),this.name=e.name,this.logger=t.logger,this.log=t.logger.forComponent(this.name),this.requests=new Map,this.minProviders=e.minProviders??1,this.maxProviders=e.maxProviders??5,this.providers=[],this.evictionFilter=vu(this.maxProviders)}async retrieve(t,e={}){let n=Ne.encode(t.multihash.bytes),o=this.requests.get(n);if(o!=null)return this.log("join existing request for %c",t),o;let s=At();if(this.requests.set(n,s.promise),this.providers.length===0){let u=!1;this.intialPeerSearchComplete==null&&(u=!0,this.log=this.logger.forComponent(`${this.name}:${t}`),this.intialPeerSearchComplete=this.findProviders(t,this.minProviders,e)),await this.intialPeerSearchComplete,u&&this.log("found initial session peers for %c",t)}let i=!1,a=new He({concurrency:this.maxProviders});a.addEventListener("error",()=>{}),a.addEventListener("failure",u=>{this.log.error("error querying provider %o, evicting from session",u.detail.job.options.provider,u.detail.error),this.evict(u.detail.job.options.provider)}),a.addEventListener("success",u=>{i=!0,s.resolve(u.detail.result)}),a.addEventListener("idle",()=>{i||e.signal?.aborted===!0||Promise.resolve().then(async()=>{this.log("no session peers had block for for %c, finding new providers",t);for(let u=0;u<this.minProviders&&this.providers.length!==0;u++){let f=this.providers[Math.floor(Math.random()*this.providers.length)];this.evict(f)}await this.findProviders(t,this.minProviders,e),this.log("found new providers re-retrieving %c",t),this.requests.delete(n),s.resolve(await this.retrieve(t,e))}).catch(u=>{this.log.error("could not find new providers for %c",t,u),s.reject(u)})});let c=u=>{a.add(async()=>this.queryProvider(t,u.detail,e),{provider:u.detail}).catch(f=>{e.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c",t,f)})};this.addEventListener("provider",c),Promise.all([...this.providers].map(async u=>a.add(async()=>this.queryProvider(t,u,e),{provider:u}))).catch(u=>{e.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c",t,u)});try{return await s.promise}finally{this.removeEventListener("provider",c),a.clear(),this.requests.delete(n)}}evict(t){this.evictionFilter.add(this.toEvictionKey(t));let e=this.providers.findIndex(n=>this.equals(n,t));e!==-1&&this.providers.splice(e,1)}isEvicted(t){return this.evictionFilter.has(this.toEvictionKey(t))}hasProvider(t){return!!(this.providers.find(e=>this.equals(e,t))!=null||this.isEvicted(t))}async findProviders(t,e,n){let o=At(),s=0;return Promise.resolve().then(async()=>{this.log("finding %d-%d new provider(s) for %c",e,this.maxProviders,t);for await(let i of this.findNewProviders(t,n)){if(s===this.maxProviders||n.signal?.aborted===!0)break;if(!this.hasProvider(i)&&(this.log("found %d/%d new providers",s,this.maxProviders),this.providers.push(i),this.safeDispatchEvent("provider",{detail:i}),s++,s===e&&(this.log("session is ready"),o.resolve()),this.providers.length===this.maxProviders)){this.log("found max session peers",s);break}}if(this.log("found %d/%d new session peers",s,this.maxProviders),s<e)throw new Vo(`Found ${s} of ${e} ${this.name} providers for ${t}`)}).catch(i=>{this.log.error("error searching routing for potential session peers for %c",t,i.errors??i),o.reject(i)}),o.promise}};var da=class{blockstore;datastore;pins;logger;routing;getCodec;getHasher;dns;metrics;log;constructor(t){this.logger=t.logger??Od(),this.log=this.logger.forComponent("helia"),this.getHasher=I0(t.hashers,t.loadHasher),this.getCodec=k0(t.codecs,t.loadCodec),this.dns=t.dns??Yd(),this.metrics=t.metrics;let e={blockstore:t.blockstore,datastore:t.datastore,logger:this.logger,blockBrokers:[],getHasher:this.getHasher,getCodec:this.getCodec,dns:this.dns,metrics:this.metrics,...t.components??{}};this.routing=e.routing=new oa(e,{routers:(t.routers??[]).flatMap(o=>{let s=[o];return o[Jn]!=null&&s.push(o[Jn]),o[Xn]!=null&&s.push(o[Xn]),s}),providerLookupConcurrency:t.providerLookupConcurrency});let n=new ha(e);this.pins=new na(t.datastore,n,this.getCodec),this.blockstore=new sa(n,this.pins,{holdGcLock:t.holdGcLock??!0}),this.datastore=t.datastore,e.blockBrokers=t.blockBrokers.map(o=>o(e))}async start(){await l0(this.datastore),await fr(this.blockstore,this.datastore,this.routing)}async stop(){await hr(this.blockstore,this.datastore,this.routing)}async gc(t={}){let e=await this.blockstore.lock.writeLock();try{let n=this,o=this.blockstore.unwrap();this.log("gc start"),await Vr(o.deleteMany(async function*(){for await(let{cid:s}of o.getAll())try{if(await n.pins.isPinned(s,t))continue;yield s,t.onProgress?.(new tt("helia:gc:deleted",s))}catch(i){n.log.error("Error during gc",i),t.onProgress?.(new tt("helia:gc:error",i))}}()))}finally{e()}this.log("gc finished")}};var pa=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",u=2**(8*o)-1;for(;;){let f=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let d=Number.parseInt(l,t);if(!Number.isNaN(d))return d});if(f===void 0)break;if(s*=t,s+=f,s>u||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&c&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let o=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[o]=i[0],e[o+1]=i[1],e[o+2]=i[2],e[o+3]=i[3],[o+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[o,!1];e[o]=s>>8,e[o+1]=s&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,o]=t(e);if(n===16)return e;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=t(s.subarray(0,i));return e.set(s.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var C0=45,nb=15,zn=new pa;function xl(r){if(!(r.length>nb))return zn.new(r).parseWith(()=>zn.readIPv4Addr())}function bl(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>C0))return zn.new(r).parseWith(()=>zn.readIPv6Addr())}function ma(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>C0))return zn.new(r).parseWith(()=>zn.readIPAddr())}function Kn(r){return!!xl(r)}function qn(r){return!!bl(r)}function ga(r){return!!ma(r)}var L0=Fr(N0(),1),ob=["0.0.0.0/8","10.0.0.0/8","100.64.0.0/10","127.0.0.0/8","169.254.0.0/16","172.16.0.0/12","192.0.0.0/24","192.0.0.0/29","192.0.0.8/32","192.0.0.9/32","192.0.0.10/32","192.0.0.170/32","192.0.0.171/32","192.0.2.0/24","192.31.196.0/24","192.52.193.0/24","192.88.99.0/24","192.168.0.0/16","192.175.48.0/24","198.18.0.0/15","198.51.100.0/24","203.0.113.0/24","240.0.0.0/4","255.255.255.255/32"],sb=ob.map(r=>new L0.Netmask(r));function vl(r){for(let t of sb)if(t.contains(r))return!0;return!1}function ib(r){return/^::ffff:([0-9a-fA-F]{1,4}):([0-9a-fA-F]{1,4})$/.test(r)}function ab(r){let t=r.split(":");if(t.length<2)return!1;let e=t[t.length-1].padStart(4,"0"),n=t[t.length-2].padStart(4,"0"),o=`${parseInt(n.substring(0,2),16)}.${parseInt(n.substring(2),16)}.${parseInt(e.substring(0,2),16)}.${parseInt(e.substring(2),16)}`;return vl(o)}function cb(r){return/^::ffff:([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)}function ub(r){let t=r.split(":"),e=t[t.length-1];return vl(e)}function lb(r){return/^::$/.test(r)||/^::1$/.test(r)||/^64:ff9b::([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)||/^100::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001:2[0-9a-fA-F]:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001:db8:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2002:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^f[c-d]([0-9a-fA-F]{2,2}):/i.test(r)||/^fe[8-9a-bA-B][0-9a-fA-F]:/i.test(r)||/^ff([0-9a-fA-F]{2,2}):/i.test(r)}function U0(r){return Kn(r)?vl(r):ib(r)?ab(r):cb(r)?ub(r):qn(r)?lb(r):void 0}var fb=r=>r.toString().split("/").slice(1),jn=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),J=r=>({match:t=>jn(e=>e===r).match(t),pattern:r}),nn=()=>({match:r=>jn(t=>typeof t=="string").match(r),pattern:"{string}"}),qo=()=>({match:r=>jn(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),ct=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{it.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),jo=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{mc.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),et=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),Vt=(...r)=>({match:t=>{let e;for(let n of r){let o=n.match(t);o!==!1&&(e==null||o.length<e.length)&&(e=o)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),X=(...r)=>({match:t=>{for(let e of r){let n=e.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${r.map(t=>t.pattern).join(", ")})`});function pt(...r){function t(o){let s=fb(o);for(let i of r){let a=i.match(s);if(a===!1)return!1;s=a}return s}function e(o){return t(o)!==!1}function n(o){let s=t(o);return s===!1?!1:s.length===0}return{matchers:r,matches:e,exactMatch:n}}var wa=X(J("dns4"),nn()),xa=X(J("dns6"),nn()),ba=X(J("dnsaddr"),nn()),Al=X(J("dns"),nn()),pk=pt(wa,et(ct())),mk=pt(xa,et(ct())),gk=pt(ba,et(ct())),P0=pt(Vt(Al,ba,wa,xa),et(ct())),R0=X(J("ip4"),jn(Kn)),D0=X(J("ip6"),jn(qn)),Sl=Vt(R0,D0),ir=Vt(Sl,Al,wa,xa,ba),yk=pt(Vt(Sl,X(Vt(Al,ba,wa,xa),et(ct())))),wk=pt(R0),xk=pt(D0),bk=pt(Sl),Bl=X(ir,J("tcp"),qo()),Go=X(ir,J("udp"),qo()),vk=pt(X(Bl,et(ct()))),Ek=pt(Go),kl=X(Go,J("quic"),et(ct())),va=X(Go,J("quic-v1"),et(ct())),hb=Vt(kl,va),Ak=pt(kl),Sk=pt(va),El=Vt(ir,Bl,Go,kl,va),F0=Vt(X(El,J("ws"),et(ct()))),Bk=pt(F0),M0=Vt(X(El,J("wss"),et(ct())),X(El,J("tls"),et(X(J("sni"),nn())),J("ws"),et(ct()))),kk=pt(M0),V0=X(Go,J("webrtc-direct"),et(jo()),et(jo()),et(ct())),Ik=pt(V0),O0=X(va,J("webtransport"),et(jo()),et(jo()),et(ct())),_k=pt(O0),ya=Vt(F0,M0,X(Bl,et(ct())),X(hb,et(ct())),X(ir,et(ct())),V0,O0,ct()),Tk=pt(ya),db=X(ya,J("p2p-circuit"),ct()),Ck=pt(db),pb=Vt(X(ya,J("p2p-circuit"),J("webrtc"),et(ct())),X(ya,J("webrtc"),et(ct())),X(J("webrtc"),et(ct()))),Nk=pt(pb),mb=Vt(X(ir,J("tcp"),qo(),J("http"),et(ct())),X(ir,J("http"),et(ct()))),$0=pt(mb),gb=Vt(X(ir,J("tcp"),Vt(X(J("443"),J("http")),X(qo(),J("https"))),et(ct())),X(ir,J("tls"),J("http"),et(ct())),X(ir,J("https"),et(ct()))),H0=pt(gb),yb=Vt(X(J("memory"),nn(),et(ct()))),Lk=pt(yb);var Ok=parseInt("0xFFFF",16),$k=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var q0=Kn,Eb=qn,Il=function(r){let t=0;if(r=r.toString().trim(),q0(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(Eb(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=q0(e[n]),i;s&&(i=Il(e[n]),e[n]=nt(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,nt(i.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let s=[n,1];for(n=9-e.length;n>0;n--)s.push("0");e.splice.apply(e,s)}let o=new Uint8Array(t+16);for(n=0;n<e.length;n++){let s=parseInt(e[n],16);o[t++]=s>>8&255,o[t++]=s&255}return o}throw new Error("invalid ip address")},j0=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let o=[];for(let s=0;s<e;s++)o.push(r[t+s]);return o.join(".")}if(e===16){let o=[];for(let s=0;s<e;s+=2)o.push(n.getUint16(t+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var Gn={},_l={},Sb=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[481,-1,"http-path"],[777,-1,"memory"]];Sb.forEach(r=>{let t=Bb(...r);_l[t.code]=t,Gn[t.name]=t});function Bb(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function G(r){if(typeof r=="number"){if(_l[r]!=null)return _l[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(Gn[r]!=null)return Gn[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var EI=G("ip4"),AI=G("ip6"),SI=G("ipcidr");function Ll(r,t){switch(G(r).code){case 4:case 41:return Ib(t);case 42:return Nl(t);case 6:case 273:case 33:case 132:return Z0(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Nl(t);case 421:return Nb(t);case 444:return W0(t);case 445:return W0(t);case 466:return Cb(t);case 481:return globalThis.encodeURIComponent(Nl(t));default:return nt(t,"base16")}}function Ul(r,t){switch(G(r).code){case 4:return G0(t);case 41:return G0(t);case 42:return Cl(t);case 6:case 273:case 33:case 132:return Pl(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Cl(t);case 421:return _b(t);case 444:return Lb(t);case 445:return Ub(t);case 466:return Tb(t);case 481:return Cl(globalThis.decodeURIComponent(t));default:return K(t,"base16")}}var Tl=Object.values(oo).map(r=>r.decoder),kb=function(){let r=Tl[0].or(Tl[1]);return Tl.slice(2).forEach(t=>r=r.or(t)),r}();function G0(r){if(!ga(r))throw new Error("invalid ip address");return Il(r)}function Ib(r){let t=j0(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!ga(t))throw new Error("invalid ip address");return t}function Pl(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Z0(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Cl(r){let t=K(r),e=Uint8Array.from(fn(t.length));return Jt([e,t],e.length+t.length)}function Nl(r){let t=Or(r);if(r=r.slice(qt(t)),r.length!==t)throw new Error("inconsistent lengths");return nt(r)}function _b(r){let t;r[0]==="Q"||r[0]==="1"?t=de(it.decode(`z${r}`)).bytes:t=$.parse(r).multihash.bytes;let e=Uint8Array.from(fn(t.length));return Jt([e,t],e.length+t.length)}function Tb(r){let t=kb.decode(r),e=Uint8Array.from(fn(t.length));return Jt([e,t],e.length+t.length)}function Cb(r){let t=Or(r),e=r.slice(qt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+nt(e,"base64url")}function Nb(r){let t=Or(r),e=r.slice(qt(t));if(e.length!==t)throw new Error("inconsistent lengths");return nt(e,"base58btc")}function Lb(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let e=_t.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Pl(n);return Jt([e,o],e.length+o.length)}function Ub(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let e=_t.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Pl(n);return Jt([e,o],e.length+o.length)}function W0(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=nt(t,"base32"),o=Z0(e);return`${n}:${o}`}function Y0(r){r=Rl(r);let t=[],e=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=G(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw X0("invalid address: "+r);if(a.path===!0){n=Rl(o.slice(s).join("/")),t.push([a.code,Ul(a.code,n)]),e.push([a.code,n]);break}let c=Ul(a.code,o[s]);t.push([a.code,c]),e.push([a.code,Ll(a.code,c)])}return{string:J0(e),bytes:Fl(t),tuples:t,stringTuples:e,path:n}}function Dl(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=Or(r,o),i=qt(s),a=G(s),c=Pb(a,r.slice(o+i));if(c===0){t.push([s]),e.push([s]),o+=i;continue}let u=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw X0("Invalid address Uint8Array: "+nt(r,"base16"));t.push([s,u]);let f=Ll(s,u);if(e.push([s,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(r),string:J0(e),tuples:t,stringTuples:e,path:n}}function J0(r){let t=[];return r.map(e=>{let n=G(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Rl(t.join("/"))}function Fl(r){return Jt(r.map(t=>{let e=G(t[0]),n=Uint8Array.from(fn(e.code));return t.length>1&&t[1]!=null&&(n=Jt([n,t[1]])),n}))}function Pb(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Or(t instanceof Uint8Array?t:Uint8Array.from(t));return e+qt(e)}}function Rl(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function X0(r){return new Error("Error parsing address: "+r)}var Rb=Symbol.for("nodejs.util.inspect.custom"),Vl=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Db=[G("dns").code,G("dns4").code,G("dns6").code,G("dnsaddr").code],Ml=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},Ea=class r{bytes;#t;#e;#r;#o;[Vl]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Dl(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Y0(t)}else if(tm(t))e=Dl(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#t=e.string,this.#e=e.tuples,this.#r=e.stringTuples,this.#o=e.path}toString(){return this.#t}toJSON(){return this.toString()}toOptions(){let t,e,n,o,s="",i=G("tcp"),a=G("udp"),c=G("ip4"),u=G("ip6"),f=G("dns6"),l=G("ip6zone");for(let[h,g]of this.stringTuples())h===l.code&&(s=`%${g??""}`),Db.includes(h)&&(e=i.name,o=443,n=`${g??""}${s}`,t=h===f.code?6:4),(h===i.code||h===a.code)&&(e=G(h).name,o=parseInt(g??"")),(h===c.code||h===u.code)&&(e=G(h).name,n=`${g??""}${s}`,t=h===u.code?6:4);if(t==null||e==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:o}}protos(){return this.#e.map(([t])=>Object.assign({},G(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>G(t).name)}tuples(){return this.#e.map(([t,e])=>e==null?[t]:[t,e])}stringTuples(){return this.#r.map(([t,e])=>e==null?[t]:[t,e])}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),o=n.lastIndexOf(e);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,o))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(Fl(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===Gn.p2p.code&&t.push([n,o]),n===Gn["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?nt(it.decode(`z${n}`),"base58btc"):nt($.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#o}equals(t){return st(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=Q0.get(e.name);if(n==null)throw new Ml(`no available resolver for ${e.name}`);return(await n(this,t)).map(s=>ar(s))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[Rb](){return`Multiaddr(${this.#t})`}};var Q0=new Map;function tm(r){return!!r?.[Vl]}function ar(r){return new Ea(r)}var Fb=[G("tcp").code,G("dns").code,G("dnsaddr").code,G("dns4").code,G("dns6").code];function em(r){return om("sni",r)?.[1]}function rm(r){let t=om("tcp",r)?.[1];return t==null?"":`:${t}`}function om(r,t){let e;try{e=G(r).code}catch{return}for(let[n,o]of t)if(n===e&&o!=null)return[n,o]}function nm(r){return r.some(([t,e])=>t===G("tls").code)}function Be(r,t,e){let n=sm[G(r).name];if(n==null)throw new Error(`Can't interpret protocol ${G(r).name}`);let o=n(t,e);return r===G("ip6").code?`[${o}]`:o}var sm={ip4:(r,t)=>r,ip6:(r,t)=>t.length===0?r:`[${r}]`,tcp:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");return`tcp://${Be(e[0],e[1]??"",t)}:${r}`},udp:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");return`udp://${Be(e[0],e[1]??"",t)}:${r}`},dnsaddr:(r,t)=>r,dns4:(r,t)=>r,dns6:(r,t)=>r,dns:(r,t)=>r,ipfs:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");return`${Be(e[0],e[1]??"",t)}`},p2p:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");return`${Be(e[0],e[1]??"",t)}`},http:(r,t)=>{let e=nm(t),n=em(t),o=rm(t);if(e&&n!=null)return`https://${n}${o}`;let s=e?"https://":"http://",i=t.pop();if(i==null)throw new Error("Unexpected end of multiaddr");let a=Be(i[0],i[1]??"",t);return a=a.replace("tcp://",""),`${s}${a}`},"http-path":(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");let n=Be(e[0],e[1]??"",t),o=decodeURIComponent(r);return`${n}/${o}`},tls:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");return Be(e[0],e[1]??"",t)},sni:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");return Be(e[0],e[1]??"",t)},https:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");let n=Be(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`https://${n}`},ws:(r,t)=>{let e=nm(t),n=em(t),o=rm(t);if(e&&n!=null)return`wss://${n}${o}`;let s=e?"wss://":"ws://",i=t.pop();if(i==null)throw new Error("Unexpected end of multiaddr");let a=Be(i[0],i[1]??"",t);return a=a.replace("tcp://",""),`${s}${a}`},wss:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");let n=Be(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`wss://${n}`}};function im(r,t){let n=ar(r).stringTuples(),o=n.pop();if(o==null)throw new Error("Unexpected end of multiaddr");let s=G(o[0]),i=sm[s.name];if(i==null)throw new Error(`No interpreter found for ${s.name}`);let a=i(o[1]??"",n);return t?.assumeHttp!==!1&&Fb.includes(o[0])&&(a=a.replace(/^.*:\/\//,""),o[1]==="443"?a=`https://${a}`:a=`http://${a}`),(a.startsWith("http://")||a.startsWith("https://")||a.startsWith("ws://")||a.startsWith("wss://"))&&(a=new URL(a).toString(),a.endsWith("/")&&(a=a.substring(0,a.length-1))),a}var Aa=class{url;#t=0;#e=0;#r=0;#o=0;#a=new Map;log;constructor(t,e){this.url=t instanceof URL?t:new URL(t),this.log=e.forComponent(`helia:trustless-gateway-block-broker:${this.url.hostname}`)}#u(t){let e=t.multihash.bytes;return Ne.encode(e)}async getRawBlock(t,e){let n=new URL(this.url.toString());if(n.pathname=`/ipfs/${t.toString()}`,n.search="?format=raw",e?.aborted===!0)throw new Error(`Signal to fetch raw block for CID ${t} from gateway ${this.url} was aborted prior to fetch`);let o=this.#u(t),s=new AbortController,i=()=>{s.abort()};e?.addEventListener("abort",i);try{let a=this.#a.get(o);return a==null&&(this.#t++,a=fetch(n.toString(),{signal:s.signal,headers:{Accept:"application/vnd.ipld.raw"},cache:"force-cache"}).then(async c=>{if(this.log("GET %s %d",n,c.status),!c.ok)throw this.#e++,new Error(`unable to fetch raw block for CID ${t} from gateway ${this.url}`);return this.#o++,new Uint8Array(await c.arrayBuffer())}),this.#a.set(o,a)),await a}catch{throw e?.aborted===!0?new Error(`fetching raw block for CID ${t} from gateway ${this.url} was aborted`):(this.#e++,new Error(`unable to fetch raw block for CID ${t}`))}finally{e?.removeEventListener("abort",i),this.#a.delete(o)}}reliability(){return this.#t===0?1:this.#r>0?-1/0:this.#o/(this.#t+this.#e*3)}incrementInvalidBlocks(){this.#r++}getStats(){return{attempts:this.#t,errors:this.#e,invalidBlocks:this.#r,successes:this.#o,pendingResponses:this.#a.size}}};function Mb(r,t,e){return r.filter(n=>{if(H0.matches(n)||t&&$0.matches(n))return e||P0.matches(n)?!0:U0(n.toOptions().host)===!1;if(!t&&e){let{host:o}=n.toOptions();if(o==="127.0.0.1"||o==="localhost"||o.endsWith(".localhost"))return!0}return!1})}async function*Sa(r,t,e,n,o,s){for await(let i of t.findProviders(r,s)){let a=Mb(i.multiaddrs,n,o);if(a.length===0)continue;let c=im(a[0]);yield new Aa(c,e)}}var Ol=class extends zo{routing;allowInsecure;allowLocal;constructor(t,e){super(t,{...e,name:"helia:trustless-gateway:session"}),this.routing=t.routing,this.allowInsecure=e.allowInsecure??Ba,this.allowLocal=e.allowLocal??ka}async queryProvider(t,e,n){this.log("fetching BLOCK for %c from %s",t,e.url);let o=await e.getRawBlock(t,n.signal);return this.log.trace("got block for %c from %s",t,e.url),await n.validateFn?.(o),o}async*findNewProviders(t,e={}){yield*Sa(t,this.routing,this.logger,this.allowInsecure,this.allowLocal,e)}toEvictionKey(t){return t.url.toString()}equals(t,e){return t.url.toString()===e.url.toString()}};function am(r,t){return new Ol(r,t)}var Ia=class{allowInsecure;allowLocal;routing;log;logger;constructor(t,e={}){this.log=t.logger.forComponent("helia:trustless-gateway-block-broker"),this.logger=t.logger,this.routing=t.routing,this.allowInsecure=e.allowInsecure??Ba,this.allowLocal=e.allowLocal??ka}async retrieve(t,e={}){let n=[];for await(let o of Sa(t,this.routing,this.logger,this.allowInsecure,this.allowLocal,e)){this.log("getting block for %c from %s",t,o.url);try{let s=await o.getRawBlock(t,e.signal);this.log.trace("got block for %c from %s",t,o.url);try{await e.validateFn?.(s)}catch(i){this.log.error("failed to validate block for %c from %s",t,o.url,i);continue}return s}catch(s){if(this.log.error("failed to get block for %c from %s",t,o.url,s),s instanceof Error?n.push(s):n.push(new Error(`Unable to fetch raw block for CID ${t} from gateway ${o.url}`)),e.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",t,o.url);break}}}throw n.length>0?new AggregateError(n,`Unable to fetch raw block for CID ${t} from any gateway`):new Error(`Unable to fetch raw block for CID ${t} from any gateway`)}createSession(t={}){return am({logger:this.logger,routing:this.routing},{...t,allowLocal:this.allowLocal,allowInsecure:this.allowInsecure})}};var Ba=!1,ka=!1;function $l(r={}){return t=>new Ia(t,r)}async function*_a(r,t={}){let e=r.getReader();try{for(;;){let n=await e.read();if(n.done)return;yield n.value}}finally{t.preventCancel!==!0&&await e.cancel(),e.releaseLock()}}var Kb=Fr(zl(),1);var ke=class extends Error{static name="SignatureVerificationError";constructor(t="Record signature verification failed"){super(t),this.name="SignatureVerificationError"}},Ta=class extends Error{static name="RecordExpiredError";constructor(t="Record has expired"){super(t),this.name="RecordExpiredError"}},Wn=class extends Error{static name="UnsupportedValidityError";constructor(t="The validity type is unsupported"){super(t),this.name="UnsupportedValidityError"}},Ca=class extends Error{static name="RecordTooLargeError";constructor(t="The record is too large"){super(t),this.name="RecordTooLargeError"}},Na=class extends Error{static name="InvalidValueError";constructor(t="Value must be a valid content path starting with /"){super(t),this.name="InvalidValueError"}},La=class extends Error{static name="InvalidRecordDataError";constructor(t="Invalid record data"){super(t),this.name="InvalidRecordDataError"}},Wo=class extends Error{static name="InvalidEmbeddedPublicKeyError";constructor(t="Invalid embedded public key"){super(t),this.name="InvalidEmbeddedPublicKeyError"}};var Ie;(function(r){let t;(function(o){o.EOL="EOL"})(t=r.ValidityType||(r.ValidityType={}));let e;(function(o){o[o.EOL=0]="EOL"})(e||(e={})),function(o){o.codec=()=>ao(e)}(t=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=vn((o,s,i={})=>{i.lengthDelimited!==!1&&s.fork(),o.value!=null&&(s.uint32(10),s.bytes(o.value)),o.signatureV1!=null&&(s.uint32(18),s.bytes(o.signatureV1)),o.validityType!=null&&(s.uint32(24),r.ValidityType.codec().encode(o.validityType,s)),o.validity!=null&&(s.uint32(34),s.bytes(o.validity)),o.sequence!=null&&(s.uint32(40),s.uint64(o.sequence)),o.ttl!=null&&(s.uint32(48),s.uint64(o.ttl)),o.pubKey!=null&&(s.uint32(58),s.bytes(o.pubKey)),o.signatureV2!=null&&(s.uint32(66),s.bytes(o.signatureV2)),o.data!=null&&(s.uint32(74),s.bytes(o.data)),i.lengthDelimited!==!1&&s.ldelim()},(o,s,i={})=>{let a={},c=s==null?o.len:o.pos+s;for(;o.pos<c;){let u=o.uint32();switch(u>>>3){case 1:{a.value=o.bytes();break}case 2:{a.signatureV1=o.bytes();break}case 3:{a.validityType=r.ValidityType.codec().decode(o);break}case 4:{a.validity=o.bytes();break}case 5:{a.sequence=o.uint64();break}case 6:{a.ttl=o.uint64();break}case 7:{a.pubKey=o.bytes();break}case 8:{a.signatureV2=o.bytes();break}case 9:{a.data=o.bytes();break}default:{o.skipType(u&7);break}}}return a})),n),r.encode=o=>xn(o,r.codec()),r.decode=(o,s)=>pn(o,r.codec(),s)})(Ie||(Ie={}));var Vb=Qt("ipns:utils"),cm=K("/ipns/");var Ob=0,$b=18;function um(r){let t;if(r.pubKey!=null)try{t=kd(r.pubKey)}catch(e){throw Vb.error(e),e}if(t!=null)return t}function lm(r){let t=K("ipns-signature:");return Jt([t,r])}function on(r){return"signatureV1"in r?Ie.encode({value:K(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:K(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):Ie.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data})}function Ve(r){let t=Ie.decode(r);if(t.sequence!=null&&(t.sequence=BigInt(t.sequence)),t.ttl!=null&&(t.ttl=BigInt(t.ttl)),t.signatureV2==null||t.data==null)throw new ke("Missing data or signatureV2");let e=fm(t.data),n=Hb(e.Value),o=nt(e.Validity);if(t.value!=null&&t.signatureV1!=null)return zb(t),{value:n,validityType:Ie.ValidityType.EOL,validity:o,sequence:e.Sequence,ttl:e.TTL,pubKey:t.pubKey,signatureV1:t.signatureV1,signatureV2:t.signatureV2,data:t.data};if(t.signatureV2!=null)return{value:n,validityType:Ie.ValidityType.EOL,validity:o,sequence:e.Sequence,ttl:e.TTL,pubKey:t.pubKey,signatureV2:t.signatureV2,data:t.data};throw new Error("invalid record: does not include signatureV1 or signatureV2")}function Zo(r){return Jt([cm,r.bytes])}function cr(r){let t=de(r.slice(cm.length));if(!Ua(t,Ob)&&!Ua(t,$b))throw new lr("Multihash in IPNS key was not identity or sha2-256");return t}function fm(r){let t=oe(r);if(t.ValidityType===0)t.ValidityType=Ie.ValidityType.EOL;else throw new Wn("The validity type is unsupported");return Number.isInteger(t.Sequence)&&(t.Sequence=BigInt(t.Sequence)),Number.isInteger(t.TTL)&&(t.TTL=BigInt(t.TTL)),t}function Hb(r){let t=nt(r).trim();if(t.startsWith("/"))return t;try{return`/ipfs/${$.decode(r).toV1().toString()}`}catch{}try{return`/ipfs/${$.parse(t).toV1().toString()}`}catch{}throw new Na("Value must be a valid content path starting with /")}function zb(r){if(r.data==null)throw new La("Record data is missing");let t=fm(r.data);if(!st(t.Value,r.value??new Uint8Array(0)))throw new ke('Field "value" did not match between protobuf and CBOR');if(!st(t.Validity,r.validity??new Uint8Array(0)))throw new ke('Field "validity" did not match between protobuf and CBOR');if(t.ValidityType!==r.validityType)throw new ke('Field "validityType" did not match between protobuf and CBOR');if(t.Sequence!==r.sequence)throw new ke('Field "sequence" did not match between protobuf and CBOR');if(t.TTL!==r.ttl)throw new ke('Field "ttl" did not match between protobuf and CBOR')}function Ua(r,t){return r.code===t}var M5=Qt("ipns"),V5=60*60*1e9,qb="/ipns/",O5=qb.length;var hm=Fr(zl(),1);var Pa=Qt("ipns:validator"),jb=1024*10,Gb=async(r,t)=>{let e=Ve(t),n;try{let o=lm(e.data);n=await r.verify(o,e.signatureV2)}catch{n=!1}if(!n)throw Pa.error("record signature verification failed"),new ke("Record signature verification failed");if(e.validityType===Ie.ValidityType.EOL){if(hm.default.fromString(e.validity).toDate().getTime()<Date.now())throw Pa.error("record has expired"),new Ta("record has expired")}else if(e.validityType!=null)throw Pa.error("the validity type is unsupported"),new Wn("The validity type is unsupported");Pa("ipns record for %s is valid",e.value)};async function dm(r,t){if(t.byteLength>jb)throw new Ca("The record is too large");let e=cr(r),n;Ua(e,0)&&(n=_i(e));let o=Ve(t),s=um(o)??n;if(s==null)throw new Wo("Could not extract public key from IPNS record or routing key");let i=Zo(s.toMultihash());if(!st(r,i))throw new Wo("Embedded public key did not match routing key");await Gb(s,t)}async function*Yo(r){let t=/\r?\n/,e=new TextDecoder("utf8"),n="";for await(let o of r){typeof o=="string"&&(o=new TextEncoder().encode(o)),n+=e.decode(o,{stream:!0});let s=n.split(t);n=s.pop()??"";for(let i=0;i<s.length;i++)yield JSON.parse(s[i])}n+=e.decode(),n!==""&&(yield JSON.parse(n))}var Zn=class extends Error{static name="InvalidRequestError";constructor(t="Invalid request"){super(t),this.name="InvalidRequestError"}},sn=class extends Error{static name="BadResponseError";constructor(t="Bad response"){super(t),this.name="BadResponseError"}};function Wb(r){return r[Symbol.asyncIterator]!=null}function Zb(r){if(Wb(r))return(async()=>{for await(let t of r)return t})();for(let t of r)return t}var Ra=Zb;var pm=K("/ipns/");function mm(r){return st(r.subarray(0,pm.byteLength),pm)}var Da=class{client;constructor(t){this.client=t}async*findProviders(t,e={}){yield*dn(this.client.getProviders(t,e),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async cancelReprovide(){}async put(t,e,n){if(!mm(t))return;let o=cr(t),s=$.createV1(114,o),i=Ve(e);await this.client.putIPNS(s,i,n)}async get(t,e){if(!mm(t))throw new Ut("Not found");let n=cr(t),o=$.createV1(114,n);try{let s=await this.client.getIPNS(o,e);return on(s)}catch(s){throw s.name==="BadResponseError"?new Ut("Not found"):s}}},Fa=class{client;constructor(t){this.client=t}async findPeer(t,e={}){let n=await Ra(this.client.getPeers(t,e));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new Ut("Not found")}async*getClosestPeers(t,e={}){}};var kt=Qt("delegated-routing-v1-http-api-client"),Ma={concurrentRequests:4,timeout:3e4,cacheTTL:5*60*1e3,cacheName:"delegated-routing-v1-cache"},Va=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;filterAddrs;filterProtocols;inFlightRequests;cacheName;cache;cacheTTL;constructor(t,e={}){this.started=!1,this.shutDownController=new AbortController,ht(1/0,this.shutDownController.signal),this.httpQueue=new Fe({concurrency:e.concurrentRequests??Ma.concurrentRequests}),this.inFlightRequests=new Map,this.clientUrl=t instanceof URL?t:new URL(t),this.timeout=e.timeout??Ma.timeout,this.filterAddrs=e.filterAddrs,this.filterProtocols=e.filterProtocols,this.contentRouting=new Da(this),this.peerRouting=new Fa(this),this.cacheName=e.cacheName??Ma.cacheName,this.cacheTTL=e.cacheTTL??Ma.cacheTTL}get[Jn](){return this.contentRouting}get[Xn](){return this.peerRouting}isStarted(){return this.started}async start(){this.started||(this.started=!0,this.cacheTTL>0&&(this.cache=await globalThis.caches?.open(this.cacheName),this.cache!=null&&kt("cache enabled with ttl %d",this.cacheTTL)))}async stop(){this.httpQueue.clear(),this.shutDownController.abort(),await globalThis.caches?.delete(this.cacheName),this.started=!1}async*getProviders(t,e={}){kt("getProviders starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=$t([this.shutDownController.signal,n,e.signal]);ht(1/0,n,o);let s=At(),i=At();this.httpQueue.add(async()=>(s.resolve(),i.promise));try{await s.promise;let a=new URL(`${this.clientUrl}routing/v1/providers/${t.toString()}`);this.#e(a,e.filterAddrs,e.filterProtocols);let c={headers:{Accept:"application/x-ndjson"},signal:o},u=await this.#r(a.toString(),c);if(u.status===404)throw new Ut("No matching records found");if(u.status===422)throw new Zn("Request does not conform to schema or semantic constraints");if(u.body==null)throw new sn("Routing response had no body");if(u.headers.get("Content-Type")==="application/json"){let l=await u.json();for(let d of l.Providers){let h=this.#t(d);h!=null&&(yield h)}}else for await(let l of Yo(_a(u.body))){let d=this.#t(l);d!=null&&(yield d)}}catch(a){kt.error("getProviders errored:",a)}finally{o.clear(),i.resolve(),kt("getProviders finished: %c",t)}}async*getPeers(t,e={}){kt("getPeers starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=$t([this.shutDownController.signal,n,e.signal]);ht(1/0,n,o);let s=At(),i=At();this.httpQueue.add(async()=>(s.resolve(),i.promise));try{await s.promise;let a=new URL(`${this.clientUrl}routing/v1/peers/${t.toCID().toString()}`);this.#e(a,e.filterAddrs,e.filterProtocols);let c={headers:{Accept:"application/x-ndjson"},signal:o},u=await this.#r(a.toString(),c);if(u.status===404)throw new Ut("No matching records found");if(u.status===422)throw new Zn("Request does not conform to schema or semantic constraints");if(u.body==null)throw new sn("Routing response had no body");if(u.headers.get("Content-Type")==="application/json"){let l=await u.json();for(let d of l.Peers){let h=this.#t(d);h!=null&&(yield h)}}else for await(let l of Yo(_a(u.body))){let d=this.#t(l);d!=null&&(yield d)}}catch(a){kt.error("getPeers errored:",a)}finally{o.clear(),i.resolve(),kt("getPeers finished: %c",t)}}async getIPNS(t,e={}){kt("getIPNS starts: %s",t);let n=AbortSignal.timeout(this.timeout),o=$t([this.shutDownController.signal,n,e.signal]);ht(1/0,n,o);let s=At(),i=At();this.httpQueue.add(async()=>(s.resolve(),i.promise));let a=`${this.clientUrl}routing/v1/ipns/${t}`;try{await s.promise;let c={headers:{Accept:"application/vnd.ipfs.ipns-record"},signal:o},u=await this.#r(a,c);if(kt("getIPNS GET %s %d",a,u.status),u.status===404)throw new Ut("No matching records found");if(u.status===422)throw new Zn("Request does not conform to schema or semantic constraints");if(u.body==null)throw new sn("GET ipns response had no body");let f=await u.arrayBuffer(),l=new Uint8Array(f,0,f.byteLength);return e.validate!==!1&&await dm(Zo(t.multihash),l),Ve(l)}catch(c){throw kt.error("getIPNS GET %s error:",a,c),c}finally{o.clear(),i.resolve(),kt("getIPNS finished: %s",t)}}async putIPNS(t,e,n={}){kt("putIPNS starts: %c",t);let o=AbortSignal.timeout(this.timeout),s=$t([this.shutDownController.signal,o,n.signal]);ht(1/0,o,s);let i=At(),a=At();this.httpQueue.add(async()=>(i.resolve(),a.promise));let c=`${this.clientUrl}routing/v1/ipns/${t}`;try{await i.promise;let u=on(e),f={method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:u,signal:s},l=await this.#r(c,f);if(kt("putIPNS PUT %s %d",c,l.status),l.status!==200)throw new sn("PUT ipns response had status other than 200")}catch(u){throw kt.error("putIPNS PUT %s error:",c,u.stack),u}finally{s.clear(),a.resolve(),kt("putIPNS finished: %c",t)}}#t(t){try{let e=[],n=t.Addrs?.map(ar)??[];return t.Protocols!=null&&e.push(...t.Protocols),t.Protocol!=null&&(e.push(t.Protocol),delete t.Protocol),{...t,Schema:"peer",ID:Td(t.ID),Addrs:n,Protocols:e}}catch(e){kt.error("could not conform record to peer schema",e)}}#e(t,e,n){if(e!=null||this.filterAddrs!=null){let o=e?.join(",")??this.filterAddrs?.join(",")??"";o!==""&&t.searchParams.set("filter-addrs",o)}if(n!=null||this.filterProtocols!=null){let o=n?.join(",")??this.filterProtocols?.join(",")??"";o!==""&&t.searchParams.set("filter-protocols",o)}}async#r(t,e){let n=e.method??"GET",o=`${n}-${t}`;if(n==="GET"){let c=await this.cache?.match(t);if(c!=null){if(parseInt(c.headers.get("x-cache-expires")??"0",10)>Date.now())return kt("returning cached response for %s",o),c;await this.cache?.delete(t)}}let s=this.inFlightRequests.get(o);if(s!=null){let c=await s;return kt("deduplicating outgoing request for %s",o),c.clone()}let i=fetch(t,e).then(async c=>{if(this.cache!=null&&c.ok&&n==="GET"){let u=Date.now()+this.cacheTTL,f=new Headers(c.headers);f.set("x-cache-expires",u.toString());let l=new Response(c.clone().body,{status:c.status,statusText:c.statusText,headers:f});await this.cache.put(t,l)}return c}).finally(()=>{this.inFlightRequests.delete(o)});return this.inFlightRequests.set(o,i),await i}};function gm(r,t={}){return new Va(new URL(r),t)}function ym(){return{filterProtocols:["unknown","transport-bitswap","transport-ipfs-gateway-http"],filterAddrs:["https","webtransport","webrtc","webrtc-direct","wss","tls"]}}var wm=K("/ipns/");function xm(r){return st(r.subarray(0,wm.byteLength),wm)}var Kl=class{client;constructor(t,e={}){this.client=gm(t,e)}async provide(t,e){}async cancelReprovide(t,e){}async*findProviders(t,e){yield*dn(this.client.getProviders(t,e),n=>({id:n.ID,multiaddrs:n.Addrs,protocols:n.Protocols}))}async put(t,e,n){if(!xm(t))return;let o=cr(t),s=$.createV1(114,o),i=Ve(e);await this.client.putIPNS(s,i,n)}async get(t,e){if(!xm(t))throw new Ut("Not found");let n=cr(t),o=$.createV1(114,n);try{let s=await this.client.getIPNS(o,e);return on(s)}catch(s){throw s.name==="BadResponseError"?new Ut("Not found"):s}}async findPeer(t,e){let n=await Ra(this.client.getPeers(t,e));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new Ut("Not found")}async*getClosestPeers(t,e){}};function ql(r,t){let e=t??ym();return new Kl(new URL(r),e)}var bm="[a-fA-F\\d:]",Rr=r=>r&&r.includeBoundaries?`(?:(?<=\\s|^)(?=${bm})|(?<=${bm})(?=\\s|$))`:"",_e="(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}",yt="[a-fA-F\\d]{1,4}",Oa=`
7
+ `)}`:`${e} :`}};ph=Sr;M.Constructed=ph;Sr.NAME="CONSTRUCTED";var Ms=class extends Dt{fromBER(t,e,n){return e}toBER(t){return ye}};Ms.override="EndOfContentValueBlock";var mh,Vs=class extends Tt{constructor(t={}){super(t,Ms),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};mh=Vs;M.EndOfContent=mh;Vs.NAME=ho;var gh,kn=class extends Tt{constructor(t={}){super(t,Dt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let o=new Uint8Array(n);o[0]=5,o[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};gh=kn;M.Null=gh;kn.NAME="NULL";var Os=class extends Xe(Dt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=Z.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let o=Z.BufferSourceConverter.toUint8Array(t);return Je(this,o,e,n)?(this.valueHexView=o.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,Jc.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Os.NAME="BooleanValueBlock";var yh,$s=class extends Tt{constructor(t={}){super(t,Os),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};yh=$s;M.Boolean=yh;$s.NAME="BOOLEAN";var Hs=class extends Xe(Pe){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let o=0;if(this.isConstructed){if(this.isHexOnly=!1,o=Pe.prototype.fromBER.call(this,t,e,n),o===-1)return o;for(let s=0;s<this.value.length;s++){let i=this.value[s].constructor.NAME;if(i===ho){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==lh)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,o=super.fromBER(t,e,n),this.blockLength=n;return o}toBER(t,e){return this.isConstructed?Pe.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Hs.NAME="OctetStringValueBlock";var wh,zs=class r extends Tt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var o,s;(o=n.isConstructed)!==null&&o!==void 0||(n.isConstructed=!!(!((s=n.value)===null||s===void 0)&&s.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Hs),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let s=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(s.byteLength){let i=yi(s,0,s.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?Sr.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${Z.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return Z.BufferSourceConverter.concat(t)}};wh=zs;M.OctetString=wh;zs.NAME=lh;var Ks=class extends Xe(Pe){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let o=-1;if(this.isConstructed){if(o=Pe.prototype.fromBER.call(this,t,e,n),o===-1)return o;for(let a of this.value){let c=a.constructor.NAME;if(c===ho){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==fh)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let u=a.valueBlock;if(this.unusedBits>0&&u.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=u.unusedBits}return o}let s=Z.BufferSourceConverter.toUint8Array(t);if(!Je(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=yi(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Pe.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return ye;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};Ks.NAME="BitStringValueBlock";var xh,In=class extends Tt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var o,s;(o=n.isConstructed)!==null&&o!==void 0||(n.isConstructed=!!(!((s=n.value)===null||s===void 0)&&s.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Ks),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Sr.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let o of e)t.push(o.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};xh=In;M.BitString=xh;In.NAME=fh;var bh;function kw(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),o=new Uint8Array(t),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,u=0,l=c<i?i:c,f=0;for(let d=l;d>=0;d--,f++){switch(!0){case f<a.length:u=s[i-f]+a[c-f]+e[0];break;default:u=s[i-f]+e[0]}switch(e[0]=u/10,!0){case f>=s.length:s=Ns(new Uint8Array([u%10]),s);break;default:s[i-f]=u%10}}return e[0]>0&&(s=Ns(e,s)),s}function uh(r){if(r>=lo.length)for(let t=lo.length;t<=r;t++){let e=new Uint8Array([0]),n=lo[t-1].slice(0);for(let o=n.length-1;o>=0;o--){let s=new Uint8Array([(n[o]<<1)+e[0]]);e[0]=s[0]/10,n[o]=s[0]%10}e[0]>0&&(n=Ns(e,n)),lo.push(n)}return lo[r]}function Iw(r,t){let e=0,n=new Uint8Array(r),o=new Uint8Array(t),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,u,l=0;for(let f=c;f>=0;f--,l++)switch(u=s[i-l]-a[c-l]-e,!0){case u<0:e=1,s[i-l]=u+10;break;default:e=0,s[i-l]=u}if(e>0)for(let f=i-c+1;f>=0;f--,l++)if(u=s[i-l]-e,u<0)e=1,s[i-l]=u+10;else{e=0,s[i-l]=u;break}return s.slice()}var po=class extends Xe(Dt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=Jc.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(ih(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,o=0){let s=this.fromBER(t,e,n);if(s===-1)return s;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):o!==0&&i.length<o&&(o-i.length>1&&(o=i.length+1),this.valueHexView=i.subarray(o-i.length)),s}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let o=super.fromBER(t,e,n);return o===-1||this.setValueHex(),o}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,o,s=this.valueHexView,i="",a=!1;for(let c=s.byteLength-1;c>=0;c--){o=s[c];for(let u=0;u<8;u++){if((o&1)===1)switch(n){case t:e=Iw(uh(n),e),i="-";break;default:e=kw(e,uh(n))}n++,o>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=ch.charAt(e[c]));return a===!1&&(i+=ch.charAt(0)),i}};bh=po;po.NAME="IntegerValueBlock";Object.defineProperty(bh.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var vh,Ct=class r extends Tt{constructor(t={}){super(t,po),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Ls(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Ls();let e=BigInt(t),n=new fo,o=e.toString(16).replace(/^-/,""),s=new Uint8Array(Z.Convert.FromHex(o));if(e<0){let a=new Uint8Array(s.length+(s[0]&128?1:0));a[0]|=128;let u=BigInt(`0x${Z.Convert.ToHex(a)}`)+e,l=Z.BufferSourceConverter.toUint8Array(Z.Convert.FromHex(u.toString(16)));l[0]|=128,n.write(l)}else s[0]&128&&n.write(new Uint8Array([0])),n.write(s);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};vh=Ct;M.Integer=vh;Ct.NAME="INTEGER";var Eh,qs=class extends Ct{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Eh=qs;M.Enumerated=Eh;qs.NAME="ENUMERATED";var mo=class extends Xe(Dt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let o=Z.BufferSourceConverter.toUint8Array(t);if(!Je(this,o,e,n))return-1;let s=o.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=s[a]&127,this.blockLength++,!!(s[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,s[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Gr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Ls();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let o=0;o<n.length;o++)n[o]=parseInt(e.slice(o*7,o*7+7),2)+(o+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let o=this.valueHexView,s=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)s[i]=o[i]|128;return s[this.blockLength-1]=o[this.blockLength-1],s.buffer}let e=Ar(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",ye;let n=new Uint8Array(e.byteLength);if(!t){let o=new Uint8Array(e),s=e.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n}toString(){let t="";if(this.isHexOnly)t=Z.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};mo.NAME="sidBlock";var js=class extends Dt{constructor({value:t=Tn,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let o=e;for(;n>0;){let s=new mo;if(o=s.fromBER(t,o,n),o===-1)return this.blockLength=0,this.error=s.error,o;this.value.length===0&&(s.isFirstSid=!0),this.blockLength+=s.blockLength,n-=s.blockLength,this.value.push(s)}return o}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let o=this.value[n].toBER(t);if(o.byteLength===0)return this.error=this.value[n].error,ye;e.push(o)}return Xc(e)}fromString(t){this.value=[];let e=0,n=0,o="",s=!1;do if(n=t.indexOf(".",e),n===-1?o=t.substring(e):o=t.substring(e,n),e=n+1,s){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(o,10);if(isNaN(c))return;i.valueDec=c+a,s=!1}else{let i=new mo;if(o>Number.MAX_SAFE_INTEGER){Ls();let a=BigInt(o);i.valueBigInt=a}else if(i.valueDec=parseInt(o,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,s=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let o=this.value[n].toString();n!==0&&(t=`${t}.`),e?(o=`{${o}}`,this.value[n].isFirstSid?t=`2.{${o} - 80}`:t+=o):t+=o}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};js.NAME="ObjectIdentifierValueBlock";var Ah,_n=class extends Tt{constructor(t={}){super(t,js),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Ah=_n;M.ObjectIdentifier=Ah;_n.NAME="OBJECT IDENTIFIER";var go=class extends Xe(We){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let o=Z.BufferSourceConverter.toUint8Array(t);if(!Je(this,o,e,n))return-1;let s=o.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=s[a]&127,this.blockLength++,!!(s[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,s[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Gr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let o=this.valueHexView,s=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)s[i]=o[i]|128;return s[this.blockLength-1]=o[this.blockLength-1],s.buffer}let e=Ar(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",ye;let n=new Uint8Array(e.byteLength);if(!t){let o=new Uint8Array(e),s=e.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n.buffer}toString(){let t="";return this.isHexOnly?t=Z.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};go.NAME="relativeSidBlock";var Gs=class extends Dt{constructor({value:t=Tn,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let o=e;for(;n>0;){let s=new go;if(o=s.fromBER(t,o,n),o===-1)return this.blockLength=0,this.error=s.error,o;this.blockLength+=s.blockLength,n-=s.blockLength,this.value.push(s)}return o}toBER(t,e){let n=[];for(let o=0;o<this.value.length;o++){let s=this.value[o].toBER(t);if(s.byteLength===0)return this.error=this.value[o].error,ye;n.push(s)}return Xc(n)}fromString(t){this.value=[];let e=0,n=0,o="";do{n=t.indexOf(".",e),n===-1?o=t.substring(e):o=t.substring(e,n),e=n+1;let s=new go;if(s.valueDec=parseInt(o,10),isNaN(s.valueDec))return!0;this.value.push(s)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let o=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(o=`{${o}}`),t+=o}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Gs.NAME="RelativeObjectIdentifierValueBlock";var Sh,Ws=class extends Tt{constructor(t={}){super(t,Gs),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Sh=Ws;M.RelativeObjectIdentifier=Sh;Ws.NAME="RelativeObjectIdentifier";var Bh,Ze=class extends Sr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Bh=Ze;M.Sequence=Bh;Ze.NAME="SEQUENCE";var kh,Zs=class extends Sr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};kh=Zs;M.Set=kh;Zs.NAME="SET";var Ys=class extends Xe(Dt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Tn}toJSON(){return{...super.toJSON(),value:this.value}}};Ys.NAME="StringValueBlock";var Js=class extends Ys{};Js.NAME="SimpleStringValueBlock";var Ht=class extends Us{constructor({...t}={}){super(t,Js)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,Z.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let o=0;o<e;o++)n[o]=t.charCodeAt(o);this.valueBlock.value=t}};Ht.NAME="SIMPLE STRING";var Xs=class extends Ht{fromBuffer(t){this.valueBlock.valueHexView=Z.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=Z.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=Z.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(Z.Convert.FromUtf8String(t)),this.valueBlock.value=t}};Xs.NAME="Utf8StringValueBlock";var Ih,Ye=class extends Xs{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Ih=Ye;M.Utf8String=Ih;Ye.NAME="UTF8String";var Qs=class extends Ht{fromBuffer(t){this.valueBlock.value=Z.Convert.ToUtf16String(t),this.valueBlock.valueHexView=Z.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(Z.Convert.FromUtf16String(t))}};Qs.NAME="BmpStringValueBlock";var _h,ti=class extends Qs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};_h=ti;M.BmpString=_h;ti.NAME="BMPString";var ei=class extends Ht{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let o=0;o<n.length;o+=4)n[o]=n[o+3],n[o+1]=n[o+2],n[o+2]=0,n[o+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let o=0;o<e;o++){let s=Ar(t.charCodeAt(o),8),i=new Uint8Array(s);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[o*4+c+a]=i[c]}this.valueBlock.value=t}};ei.NAME="UniversalStringValueBlock";var Th,ri=class extends ei{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Th=ri;M.UniversalString=Th;ri.NAME="UniversalString";var Ch,ni=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Ch=ni;M.NumericString=Ch;ni.NAME="NumericString";var Nh,oi=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Nh=oi;M.PrintableString=Nh;oi.NAME="PrintableString";var Lh,si=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Lh=si;M.TeletexString=Lh;si.NAME="TeletexString";var Ph,ii=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ph=ii;M.VideotexString=Ph;ii.NAME="VideotexString";var Rh,ai=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Rh=ai;M.IA5String=Rh;ai.NAME="IA5String";var Uh,ci=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Uh=ci;M.GraphicString=Uh;ci.NAME="GraphicString";var Dh,yo=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Dh=yo;M.VisibleString=Dh;yo.NAME="VisibleString";var Fh,ui=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Fh=ui;M.GeneralString=Fh;ui.NAME="GeneralString";var Mh,li=class extends Ht{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Mh=li;M.CharacterString=Mh;li.NAME="CharacterString";var Vh,wo=class extends yo{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let o=0;o<t.length;o++)this.valueBlock.valueHexView[o]=t.charCodeAt(o)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,Z.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let o=0;o<t.length;o++)n[o]=t.charCodeAt(o);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let o=parseInt(n[1],10);o>=50?this.year=1900+o:this.year=2e3+o,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Zt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Zt(this.month,2),e[2]=Zt(this.day,2),e[3]=Zt(this.hour,2),e[4]=Zt(this.minute,2),e[5]=Zt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};Vh=wo;M.UTCTime=Vh;wo.NAME="UTCTime";var Oh,fi=class extends wo{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",o="",s=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let f=new Number(t[t.length-1]);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let f=1,d=n.indexOf("+"),h="";if(d===-1&&(d=n.indexOf("-"),f=-1),d!==-1){if(h=n.substring(d+1),n=n.substring(0,d),h.length!==2&&h.length!==4)throw new Error("Wrong input string for conversion");let g=parseInt(h.substring(0,2),10);if(isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*g,h.length===4){if(g=parseInt(h.substring(2,4),10),isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");c=f*g}}}let u=n.indexOf(".");if(u===-1&&(u=n.indexOf(",")),u!==-1){let f=new Number(`0${n.substring(u)}`);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");s=f.valueOf(),o=n.substring(0,u)}else o=n;switch(!0){case o.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,u!==-1)throw new Error("Wrong input string for conversion");break;case o.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=60*s;this.minute=Math.floor(f),f=60*(f-this.minute),this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case o.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=60*s;this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case o.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=1e3*s;this.millisecond=Math.floor(f)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(o);if(l===null)throw new Error("Wrong input string for conversion");for(let f=1;f<l.length;f++)switch(f){case 1:this.year=parseInt(l[f],10);break;case 2:this.month=parseInt(l[f],10);break;case 3:this.day=parseInt(l[f],10);break;case 4:this.hour=parseInt(l[f],10)+a;break;case 5:this.minute=parseInt(l[f],10)+c;break;case 6:this.second=parseInt(l[f],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let f=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=f.getUTCFullYear(),this.month=f.getUTCMonth(),this.day=f.getUTCDay(),this.hour=f.getUTCHours(),this.minute=f.getUTCMinutes(),this.second=f.getUTCSeconds(),this.millisecond=f.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Zt(this.year,4)),e.push(Zt(this.month,2)),e.push(Zt(this.day,2)),e.push(Zt(this.hour,2)),e.push(Zt(this.minute,2)),e.push(Zt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Zt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Oh=fi;M.GeneralizedTime=Oh;fi.NAME="GeneralizedTime";var $h,hi=class extends Ye{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};$h=hi;M.DATE=$h;hi.NAME="DATE";var Hh,di=class extends Ye{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Hh=di;M.TimeOfDay=Hh;di.NAME="TimeOfDay";var zh,pi=class extends Ye{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};zh=pi;M.DateTime=zh;pi.NAME="DateTime";var Kh,mi=class extends Ye{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Kh=mi;M.Duration=Kh;mi.NAME="Duration";var qh,gi=class extends Ye{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};qh=gi;M.TIME=qh;gi.NAME="TIME";function et(r,t="utf8"){let e=fs[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var xo=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},wi=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var jh={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new wi("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var Br=jh;async function Gh(r){let t=await Br.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Tw(t);return{privateKey:e[0],publicKey:e[1]}}async function Wh(r,t){let e=await Br.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Br.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Zh(r,t,e){let n=await Br.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Br.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Tw(r){if(r.privateKey==null||r.publicKey==null)throw new Et("Private and public key are required");return Promise.all([Br.get().subtle.exportKey("jwk",r.privateKey),Br.get().subtle.exportKey("jwk",r.publicKey)])}function eu(r){if(r.kty!=="RSA")throw new Et("invalid key type");if(r.n==null)throw new Et("invalid key modulus");return H(r.n,"base64url").length*8}var Cn=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=bo.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return $.createV1(114,this._multihash)}toString(){return it.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:st(this.raw,t.raw)}verify(t,e){return Zh(this._key,e,t)}},vo=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=bo.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:st(this.raw,t.raw)}sign(t){return Wh(this._key,t)}};var xi=8192,ru=18;function Yh(r){let{result:t}=tu(r),e=t.valueBlock.value;return{n:Re(e[1]),e:Re(e[2]),d:Re(e[3]),p:Re(e[4]),q:Re(e[5]),dp:Re(e[6]),dq:Re(e[7]),qi:Re(e[8]),kty:"RSA",alg:"RS256"}}function Cw(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new Et("JWK was missing components");let e=new Ze({value:[new Ct({value:0}),Ct.fromBigInt(Ue(H(r.n,"base64url"))),Ct.fromBigInt(Ue(H(r.e,"base64url"))),Ct.fromBigInt(Ue(H(r.d,"base64url"))),Ct.fromBigInt(Ue(H(r.p,"base64url"))),Ct.fromBigInt(Ue(H(r.q,"base64url"))),Ct.fromBigInt(Ue(H(r.dp,"base64url"))),Ct.fromBigInt(Ue(H(r.dq,"base64url"))),Ct.fromBigInt(Ue(H(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Jh(r){let{result:t}=tu(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:Re(e[0]),e:Re(e[1])}}function nu(r){if(r.n==null||r.e==null)throw new Et("JWK was missing components");let e=new Ze({value:[new Ze({value:[new _n({value:"1.2.840.113549.1.1.1"}),new kn]}),new In({valueHex:new Ze({value:[Ct.fromBigInt(Ue(H(r.n,"base64url"))),Ct.fromBigInt(Ue(H(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Re(r){let t=r.valueBlock.valueHexView;for(;t[0]===0;)t=t.subarray(1);return et(t,"base64url")}function Ue(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}function Xh(r){let t=Yh(r);return Qh(t)}function ou(r){let t=Jh(r);if(eu(t)>xi)throw new nn("Key size is too large");let e=Sn(Le.encode({Type:xt.RSA,Data:r})),n=he(ru,e);return new Cn(t,n)}function Qh(r){if(eu(r)>xi)throw new Et("Key size is too large");let t=ed(r),e=Sn(Le.encode({Type:xt.RSA,Data:nu(t.publicKey)})),n=he(ru,e);return new vo(t.privateKey,new Cn(t.publicKey,n))}async function td(r){if(r>xi)throw new Et("Key size is too large");let t=await Gh(r),e=Sn(Le.encode({Type:xt.RSA,Data:nu(t.publicKey)})),n=he(ru,e);return new vo(t.privateKey,new Cn(t.publicKey,n))}function ed(r){if(r==null)throw new Et("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var bi=class extends vn{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Uf(t);let n=io(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let o=this.blockLen,s=new Uint8Array(o);s.set(n.length>o?t.create().update(n).digest():n);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=t.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),s.fill(0)}update(t){return bn(this),this.iHash.update(t),this}digestInto(t){bn(this),xn(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return t=t,t.finished=o,t.destroyed=s,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},su=(r,t,e)=>new bi(r,t).update(e).digest();su.create=(r,t)=>new bi(r,t);function rd(r){r.lowS!==void 0&&me("lowS",r.lowS),r.prehash!==void 0&&me("prehash",r.prehash)}function Nw(r){let t=uo(r);Ne(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:o}=t;if(e){if(!n.eql(o,n.ZERO))throw new Error("invalid endomorphism, can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Lw,hexToBytes:Pw}=bs,iu=class extends Error{constructor(t=""){super(t)}},Qe={Err:iu,_tlv:{encode:(r,t)=>{let{Err:e}=Qe;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,o=Hr(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?Hr(o.length/2|128):"";return Hr(r)+s+o+t},decode(r,t){let{Err:e}=Qe,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let o=t[n++],s=!!(o&128),i=0;if(!s)i=o;else{let c=o&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let u=t.subarray(n,n+c);if(u.length!==c)throw new e("tlv.decode: length bytes not complete");if(u[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let l of u)i=i<<8|l;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=Qe;if(r<tr)throw new t("integer: negative integers are not allowed");let e=Hr(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=Qe;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Lw(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=Qe,o=typeof r=="string"?Pw(r):r;An(o);let{v:s,l:i}=n.decode(48,o);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,s),{v:u,l}=n.decode(2,c);if(l.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(u)}},hexFromSig(r){let{_tlv:t,_int:e}=Qe,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}},tr=BigInt(0),St=BigInt(1),G8=BigInt(2),nd=BigInt(3),W8=BigInt(4);function Rw(r){let t=Nw(r),{Fp:e}=t,n=br(t.n,t.nBitLength),o=t.toBytes||((m,w,x)=>{let b=w.toAffine();return je(Uint8Array.from([4]),e.toBytes(b.x),e.toBytes(b.y))}),s=t.fromBytes||(m=>{let w=m.subarray(1),x=e.fromBytes(w.subarray(0,e.BYTES)),b=e.fromBytes(w.subarray(e.BYTES,2*e.BYTES));return{x,y:b}});function i(m){let{a:w,b:x}=t,b=e.sqr(m),y=e.mul(b,m);return e.add(e.add(y,e.mul(m,w)),x)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return ao(m,St,t.n)}function c(m){let{allowedPrivateKeyLengths:w,nByteLength:x,wrapPrivateKey:b,n:y}=t;if(w&&typeof m!="bigint"){if(yr(m)&&(m=Ke(m)),typeof m!="string"||!w.includes(m.length))throw new Error("invalid private key");m=m.padStart(x*2,"0")}let S;try{S=typeof m=="bigint"?m:qe(dt("private key",m,x))}catch{throw new Error("invalid private key, expected hex or "+x+" bytes, got "+typeof m)}return b&&(S=at(S,y)),Gt("private key",S,St,y),S}function u(m){if(!(m instanceof d))throw new Error("ProjectivePoint expected")}let l=qr((m,w)=>{let{px:x,py:b,pz:y}=m;if(e.eql(y,e.ONE))return{x,y:b};let S=m.is0();w==null&&(w=S?e.ONE:e.inv(y));let _=e.mul(x,w),N=e.mul(b,w),E=e.mul(y,w);if(S)return{x:e.ZERO,y:e.ZERO};if(!e.eql(E,e.ONE))throw new Error("invZ was invalid");return{x:_,y:N}}),f=qr(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:w,y:x}=m.toAffine();if(!e.isValid(w)||!e.isValid(x))throw new Error("bad point: x or y not FE");let b=e.sqr(x),y=i(w);if(!e.eql(b,y))throw new Error("bad point: equation left != right");if(!m.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class d{constructor(w,x,b){if(this.px=w,this.py=x,this.pz=b,w==null||!e.isValid(w))throw new Error("x required");if(x==null||!e.isValid(x))throw new Error("y required");if(b==null||!e.isValid(b))throw new Error("z required");Object.freeze(this)}static fromAffine(w){let{x,y:b}=w||{};if(!w||!e.isValid(x)||!e.isValid(b))throw new Error("invalid affine point");if(w instanceof d)throw new Error("projective point not allowed");let y=S=>e.eql(S,e.ZERO);return y(x)&&y(b)?d.ZERO:new d(x,b,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(w){let x=e.invertBatch(w.map(b=>b.pz));return w.map((b,y)=>b.toAffine(x[y])).map(d.fromAffine)}static fromHex(w){let x=d.fromAffine(s(dt("pointHex",w)));return x.assertValidity(),x}static fromPrivateKey(w){return d.BASE.multiply(c(w))}static msm(w,x){return Ss(d,n,w,x)}_setWindowSize(w){g.setWindowSize(this,w)}assertValidity(){f(this)}hasEvenY(){let{y:w}=this.toAffine();if(e.isOdd)return!e.isOdd(w);throw new Error("Field doesn't support isOdd")}equals(w){u(w);let{px:x,py:b,pz:y}=this,{px:S,py:_,pz:N}=w,E=e.eql(e.mul(x,N),e.mul(S,y)),v=e.eql(e.mul(b,N),e.mul(_,y));return E&&v}negate(){return new d(this.px,e.neg(this.py),this.pz)}double(){let{a:w,b:x}=t,b=e.mul(x,nd),{px:y,py:S,pz:_}=this,N=e.ZERO,E=e.ZERO,v=e.ZERO,k=e.mul(y,y),O=e.mul(S,S),D=e.mul(_,_),U=e.mul(y,S);return U=e.add(U,U),v=e.mul(y,_),v=e.add(v,v),N=e.mul(w,v),E=e.mul(b,D),E=e.add(N,E),N=e.sub(O,E),E=e.add(O,E),E=e.mul(N,E),N=e.mul(U,N),v=e.mul(b,v),D=e.mul(w,D),U=e.sub(k,D),U=e.mul(w,U),U=e.add(U,v),v=e.add(k,k),k=e.add(v,k),k=e.add(k,D),k=e.mul(k,U),E=e.add(E,k),D=e.mul(S,_),D=e.add(D,D),k=e.mul(D,U),N=e.sub(N,k),v=e.mul(D,O),v=e.add(v,v),v=e.add(v,v),new d(N,E,v)}add(w){u(w);let{px:x,py:b,pz:y}=this,{px:S,py:_,pz:N}=w,E=e.ZERO,v=e.ZERO,k=e.ZERO,O=t.a,D=e.mul(t.b,nd),U=e.mul(x,S),P=e.mul(b,_),C=e.mul(y,N),L=e.add(x,b),B=e.add(S,_);L=e.mul(L,B),B=e.add(U,P),L=e.sub(L,B),B=e.add(x,y);let A=e.add(S,N);return B=e.mul(B,A),A=e.add(U,C),B=e.sub(B,A),A=e.add(b,y),E=e.add(_,N),A=e.mul(A,E),E=e.add(P,C),A=e.sub(A,E),k=e.mul(O,B),E=e.mul(D,C),k=e.add(E,k),E=e.sub(P,k),k=e.add(P,k),v=e.mul(E,k),P=e.add(U,U),P=e.add(P,U),C=e.mul(O,C),B=e.mul(D,B),P=e.add(P,C),C=e.sub(U,C),C=e.mul(O,C),B=e.add(B,C),U=e.mul(P,B),v=e.add(v,U),U=e.mul(A,B),E=e.mul(L,E),E=e.sub(E,U),U=e.mul(L,P),k=e.mul(A,k),k=e.add(k,U),new d(E,v,k)}subtract(w){return this.add(w.negate())}is0(){return this.equals(d.ZERO)}wNAF(w){return g.wNAFCached(this,w,d.normalizeZ)}multiplyUnsafe(w){let{endo:x,n:b}=t;Gt("scalar",w,tr,b);let y=d.ZERO;if(w===tr)return y;if(this.is0()||w===St)return this;if(!x||g.hasPrecomputes(this))return g.wNAFCachedUnsafe(this,w,d.normalizeZ);let{k1neg:S,k1:_,k2neg:N,k2:E}=x.splitScalar(w),v=y,k=y,O=this;for(;_>tr||E>tr;)_&St&&(v=v.add(O)),E&St&&(k=k.add(O)),O=O.double(),_>>=St,E>>=St;return S&&(v=v.negate()),N&&(k=k.negate()),k=new d(e.mul(k.px,x.beta),k.py,k.pz),v.add(k)}multiply(w){let{endo:x,n:b}=t;Gt("scalar",w,St,b);let y,S;if(x){let{k1neg:_,k1:N,k2neg:E,k2:v}=x.splitScalar(w),{p:k,f:O}=this.wNAF(N),{p:D,f:U}=this.wNAF(v);k=g.constTimeNegate(_,k),D=g.constTimeNegate(E,D),D=new d(e.mul(D.px,x.beta),D.py,D.pz),y=k.add(D),S=O.add(U)}else{let{p:_,f:N}=this.wNAF(w);y=_,S=N}return d.normalizeZ([y,S])[0]}multiplyAndAddUnsafe(w,x,b){let y=d.BASE,S=(N,E)=>E===tr||E===St||!N.equals(y)?N.multiplyUnsafe(E):N.multiply(E),_=S(this,x).add(S(w,b));return _.is0()?void 0:_}toAffine(w){return l(this,w)}isTorsionFree(){let{h:w,isTorsionFree:x}=t;if(w===St)return!0;if(x)return x(d,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:w,clearCofactor:x}=t;return w===St?this:x?x(d,this):this.multiplyUnsafe(t.h)}toRawBytes(w=!0){return me("isCompressed",w),this.assertValidity(),o(d,this,w)}toHex(w=!0){return me("isCompressed",w),Ke(this.toRawBytes(w))}}d.BASE=new d(t.Gx,t.Gy,e.ONE),d.ZERO=new d(e.ZERO,e.ONE,e.ZERO);let h=t.nBitLength,g=As(d,t.endo?Math.ceil(h/2):h);return{CURVE:t,ProjectivePoint:d,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function Uw(r){let t=uo(r);return Ne(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function od(r){let t=Uw(r),{Fp:e,n}=t,o=e.BYTES+1,s=2*e.BYTES+1;function i(C){return at(C,n)}function a(C){return vs(C,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:f}=Rw({...t,toBytes(C,L,B){let A=L.toAffine(),T=e.toBytes(A.x),F=je;return me("isCompressed",B),B?F(Uint8Array.from([L.hasEvenY()?2:3]),T):F(Uint8Array.from([4]),T,e.toBytes(A.y))},fromBytes(C){let L=C.length,B=C[0],A=C.subarray(1);if(L===o&&(B===2||B===3)){let T=qe(A);if(!ao(T,St,e.ORDER))throw new Error("Point is not on curve");let F=l(T),z;try{z=e.sqrt(F)}catch(Y){let q=Y instanceof Error?": "+Y.message:"";throw new Error("Point is not on curve"+q)}let K=(z&St)===St;return(B&1)===1!==K&&(z=e.neg(z)),{x:T,y:z}}else if(L===s&&B===4){let T=e.fromBytes(A.subarray(0,e.BYTES)),F=e.fromBytes(A.subarray(e.BYTES,2*e.BYTES));return{x:T,y:F}}else{let T=o,F=s;throw new Error("invalid Point, expected length of "+T+", or uncompressed "+F+", got "+L)}}}),d=C=>Ke(xr(C,t.nByteLength));function h(C){let L=n>>St;return C>L}function g(C){return h(C)?i(-C):C}let m=(C,L,B)=>qe(C.slice(L,B));class w{constructor(L,B,A){this.r=L,this.s=B,this.recovery=A,this.assertValidity()}static fromCompact(L){let B=t.nByteLength;return L=dt("compactSignature",L,B*2),new w(m(L,0,B),m(L,B,2*B))}static fromDER(L){let{r:B,s:A}=Qe.toSig(dt("DER",L));return new w(B,A)}assertValidity(){Gt("r",this.r,St,n),Gt("s",this.s,St,n)}addRecoveryBit(L){return new w(this.r,this.s,L)}recoverPublicKey(L){let{r:B,s:A,recovery:T}=this,F=N(dt("msgHash",L));if(T==null||![0,1,2,3].includes(T))throw new Error("recovery id invalid");let z=T===2||T===3?B+t.n:B;if(z>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let K=T&1?"03":"02",W=c.fromHex(K+d(z)),Y=a(z),q=i(-F*Y),ot=i(A*Y),ut=c.BASE.multiplyAndAddUnsafe(W,q,ot);if(!ut)throw new Error("point at infinify");return ut.assertValidity(),ut}hasHighS(){return h(this.s)}normalizeS(){return this.hasHighS()?new w(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return zr(this.toDERHex())}toDERHex(){return Qe.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return zr(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}let x={isValidPrivateKey(C){try{return u(C),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let C=Vc(t.n);return Wf(t.randomBytes(C),t.n)},precompute(C=8,L=c.BASE){return L._setWindowSize(C),L.multiply(BigInt(3)),L}};function b(C,L=!0){return c.fromPrivateKey(C).toRawBytes(L)}function y(C){let L=yr(C),B=typeof C=="string",A=(L||B)&&C.length;return L?A===o||A===s:B?A===2*o||A===2*s:C instanceof c}function S(C,L,B=!0){if(y(C))throw new Error("first arg must be private key");if(!y(L))throw new Error("second arg must be public key");return c.fromHex(L).multiply(u(C)).toRawBytes(B)}let _=t.bits2int||function(C){if(C.length>8192)throw new Error("input is too large");let L=qe(C),B=C.length*8-t.nBitLength;return B>0?L>>BigInt(B):L},N=t.bits2int_modN||function(C){return i(_(C))},E=co(t.nBitLength);function v(C){return Gt("num < 2^"+t.nBitLength,C,tr,E),xr(C,t.nByteLength)}function k(C,L,B=O){if(["recovered","canonical"].some(vt=>vt in B))throw new Error("sign() legacy options not supported");let{hash:A,randomBytes:T}=t,{lowS:F,prehash:z,extraEntropy:K}=B;F==null&&(F=!0),C=dt("msgHash",C),rd(B),z&&(C=dt("prehashed msgHash",A(C)));let W=N(C),Y=u(L),q=[v(Y),v(W)];if(K!=null&&K!==!1){let vt=K===!0?T(e.BYTES):K;q.push(dt("extraEntropy",vt))}let ot=je(...q),ut=W;function bt(vt){let It=_(vt);if(!f(It))return;let Lt=a(It),Kt=c.BASE.multiply(It).toAffine(),Ot=i(Kt.x);if(Ot===tr)return;let _e=i(Lt*i(ut+Ot*Y));if(_e===tr)return;let Ve=(Kt.x===Ot?0:2)|Number(Kt.y&St),Wn=_e;return F&&h(_e)&&(Wn=g(_e),Ve^=1),new w(Ot,Wn,Ve)}return{seed:ot,k2sig:bt}}let O={lowS:t.lowS,prehash:!1},D={lowS:t.lowS,prehash:!1};function U(C,L,B=O){let{seed:A,k2sig:T}=k(C,L,B),F=t;return Uc(F.hash.outputLen,F.nByteLength,F.hmac)(A,T)}c.BASE._setWindowSize(8);function P(C,L,B,A=D){let T=C;L=dt("msgHash",L),B=dt("publicKey",B);let{lowS:F,prehash:z,format:K}=A;if(rd(A),"strict"in A)throw new Error("options.strict was renamed to lowS");if(K!==void 0&&K!=="compact"&&K!=="der")throw new Error("format must be compact or der");let W=typeof T=="string"||yr(T),Y=!W&&!K&&typeof T=="object"&&T!==null&&typeof T.r=="bigint"&&typeof T.s=="bigint";if(!W&&!Y)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let q,ot;try{if(Y&&(q=new w(T.r,T.s)),W){try{K!=="compact"&&(q=w.fromDER(T))}catch(Ve){if(!(Ve instanceof Qe.Err))throw Ve}!q&&K!=="der"&&(q=w.fromCompact(T))}ot=c.fromHex(B)}catch{return!1}if(!q||F&&q.hasHighS())return!1;z&&(L=t.hash(L));let{r:ut,s:bt}=q,vt=N(L),It=a(bt),Lt=i(vt*It),Kt=i(ut*It),Ot=c.BASE.multiplyAndAddUnsafe(ot,Lt,Kt)?.toAffine();return Ot?i(Ot.x)===ut:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:S,sign:U,verify:P,ProjectivePoint:c,Signature:w,utils:x}}function Dw(r){return{hash:r,hmac:(t,...e)=>su(r,t,_c(...e)),randomBytes:gs}}function sd(r,t){let e=n=>od({...r,...Dw(n)});return{...e(t),create:e}}var cd=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),id=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Fw=BigInt(1),au=BigInt(2),ad=(r,t)=>(r+t/au)/t;function Mw(r){let t=cd,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=r*r*r%t,l=u*u*r%t,f=ft(l,e,t)*l%t,d=ft(f,e,t)*l%t,h=ft(d,au,t)*u%t,g=ft(h,o,t)*h%t,m=ft(g,s,t)*g%t,w=ft(m,a,t)*m%t,x=ft(w,c,t)*w%t,b=ft(x,a,t)*m%t,y=ft(b,e,t)*l%t,S=ft(y,i,t)*g%t,_=ft(S,n,t)*u%t,N=ft(_,au,t);if(!cu.eql(cu.sqr(N),r))throw new Error("Cannot find square root");return N}var cu=br(cd,void 0,void 0,{sqrt:Mw}),Wr=sd({a:BigInt(0),b:BigInt(7),Fp:cu,n:id,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=id,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Fw*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=ad(s*r,t),c=ad(-n*r,t),u=at(r-a*e-c*o,t),l=at(-a*n-c*s,t),f=u>i,d=l>i;if(f&&(u=t-u),d&&(l=t-l),u>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:u,k2neg:d,k2:l}}}},Sn),n6=BigInt(0);var o6=Wr.ProjectivePoint;function ud(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function ld(r,t,e){let n=pr.digest(e instanceof Uint8Array?e:e.subarray());if(ud(n))return n.then(({digest:o})=>Wr.verify(t,o,r)).catch(o=>{throw new xo(String(o))});try{return Wr.verify(t,n.digest,r)}catch(o){throw new xo(String(o))}}var vi=class{type="secp256k1";raw;_key;constructor(t){this._key=hd(t),this.raw=fd(this._key)}toMultihash(){return jt.digest(_s(this))}toCID(){return $.createV1(114,this.toMultihash())}toString(){return it.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:st(this.raw,t.raw)}verify(t,e){return ld(this._key,e,t)}};function uu(r){return new vi(r)}function fd(r){return Wr.ProjectivePoint.fromHex(r).toRawBytes(!0)}function hd(r){try{return Wr.ProjectivePoint.fromHex(r),r}catch(t){throw new nn(String(t))}}function dd(r){let{Type:t,Data:e}=Le.decode(r),n=e??new Uint8Array;switch(t){case xt.RSA:return ou(n);case xt.Ed25519:return jc(n);case xt.secp256k1:return uu(n);default:throw new on}}function Ei(r){let{Type:t,Data:e}=Le.decode(r.digest),n=e??new Uint8Array;switch(t){case xt.Ed25519:return jc(n);case xt.secp256k1:return uu(n);default:throw new on}}function _s(r){return Le.encode({Type:xt[r.type],Data:r.raw})}var pd=Symbol.for("nodejs.util.inspect.custom"),Vw=114,Eo=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Ma]=!0;toString(){return this.string==null&&(this.string=it.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return $.createV1(Vw,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return st(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return st(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[pd](){return`PeerId(${this.toString()})`}},Ai=class extends Eo{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Si=class extends Eo{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Bi=class extends Eo{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},Ow=2336,Ao=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=jt.digest(H(this.url))}[pd](){return`PeerId(${this.url})`}[Ma]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return $.createV1(Ow,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=et(t)),t.toString()===this.toString())}};var $w=114,md=2336;function gd(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=de(it.decode(`z${r}`));else{if(t==null)throw new Et('Please pass a multibase decoder for strings that do not start with "1" or "Q"');e=de(t.decode(r))}return yd(e)}function yd(r){if(zw(r))return new Ai({multihash:r});if(Hw(r))try{let t=Ei(r);if(t.type==="Ed25519")return new Si({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Bi({multihash:r,publicKey:t})}catch{let e=et(r.digest);return new Ao(new URL(e))}throw new ur("Supplied PeerID Multihash is invalid")}function wd(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==$w&&r.code!==md)throw new Xo("Supplied PeerID CID is invalid");if(r.code===md){let t=et(r.multihash.digest);return new Ao(new URL(t))}return yd(r.multihash)}function Hw(r){return r.code===jt.code}function zw(r){return r.code===pr.code}var lu=64,we=class{fp;h;seed;constructor(t,e,n,o=2){if(o>lu)throw new TypeError("Invalid Fingerprint Size");let s=e.hashV(t,n),i=of(o);for(let a=0;a<i.length;a++)i[a]=s[a];i.length===0&&(i[0]=7),this.fp=i,this.h=e,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(t){return t?.fp instanceof Uint8Array?st(this.fp,t.fp):!1}};function Zr(r,t){return Math.floor(Math.random()*(t-r))+r}var Yr=class{contents;constructor(t){this.contents=new Array(t).fill(null)}has(t){if(!(t instanceof we))throw new TypeError("Invalid Fingerprint");return this.contents.some(e=>t.equals(e))}add(t){if(!(t instanceof we))throw new TypeError("Invalid Fingerprint");for(let e=0;e<this.contents.length;e++)if(this.contents[e]==null)return this.contents[e]=t,!0;return!0}swap(t){if(!(t instanceof we))throw new TypeError("Invalid Fingerprint");let e=Zr(0,this.contents.length-1),n=this.contents[e];return this.contents[e]=t,n}remove(t){if(!(t instanceof we))throw new TypeError("Invalid Fingerprint");let e=this.contents.findIndex(n=>t.equals(n));return e>-1?(this.contents[e]=null,!0):!1}};var fu={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},Ed={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},Ad=new globalThis.TextEncoder;function Kw(r,t){let e=fu[t],n=Ed[t];for(let o=0;o<r.length;o++)n^=BigInt(r[o]),n=BigInt.asUintN(t,n*e);return n}function qw(r,t,e){if(e.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=fu[t],o=Ed[t],s=r;for(;s.length>0;){let i=Ad.encodeInto(s,e);s=s.slice(i.read);for(let a=0;a<i.written;a++)o^=BigInt(e[a]),o=BigInt.asUintN(t,o*n)}return o}function hu(r,{size:t=32,utf8Buffer:e}={}){if(!fu[t])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof r=="string"){if(e)return qw(r,t,e);r=Ad.encode(r)}return Kw(r,t)}var jw=Rr(vd(),1);var Bo={hash:r=>Number(hu(r,{size:32})),hashV:(r,t)=>Gw(Bo.hash(r,t))};function Gw(r){let t=r.toString(16);return t.length%2===1&&(t=`0${t}`),H(t,"base16")}var Ww=500,ko=class{bucketSize;filterSize;fingerprintSize;buckets;count;hash;seed;constructor(t){this.filterSize=t.filterSize,this.bucketSize=t.bucketSize??4,this.fingerprintSize=t.fingerprintSize??2,this.count=0,this.buckets=[],this.hash=t.hash??Bo,this.seed=t.seed??Zr(0,Math.pow(2,10))}add(t){typeof t=="string"&&(t=H(t));let e=new we(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=(n^e.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new Yr(this.bucketSize)),this.buckets[o]==null&&(this.buckets[o]=new Yr(this.bucketSize)),this.buckets[n].add(e)||this.buckets[o].add(e))return this.count++,!0;let s=[n,o],i=s[Zr(0,s.length-1)];this.buckets[i]==null&&(this.buckets[i]=new Yr(this.bucketSize));for(let a=0;a<Ww;a++){let c=this.buckets[i].swap(e);if(c!=null&&(i=(i^c.hash())%this.filterSize,this.buckets[i]==null&&(this.buckets[i]=new Yr(this.bucketSize)),this.buckets[i].add(c)))return this.count++,!0}return!1}has(t){typeof t=="string"&&(t=H(t));let e=new we(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.has(e)??!1;if(o)return o;let s=(n^e.hash())%this.filterSize;return this.buckets[s]?.has(e)??!1}remove(t){typeof t=="string"&&(t=H(t));let e=new we(t,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(t,this.seed)%this.filterSize,o=this.buckets[n]?.remove(e)??!1;if(o)return this.count--,o;let s=(n^e.hash())%this.filterSize,i=this.buckets[s]?.remove(e)??!1;return i&&this.count--,i}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}},Zw={1:.5,2:.84,4:.95,8:.98};function Yw(r=.001){return r>.002?2:r>1e-5?4:8}function Sd(r,t=.001){let e=Yw(t),n=Zw[e],o=Math.round(r/n),s=Math.min(Math.ceil(Math.log2(1/t)+Math.log2(2*e)),lu);return{filterSize:o,bucketSize:e,fingerprintSize:s}}var Ii=class{filterSize;bucketSize;fingerprintSize;scale;filterSeries;hash;seed;constructor(t){this.bucketSize=t.bucketSize??4,this.filterSize=t.filterSize??(1<<18)/this.bucketSize,this.fingerprintSize=t.fingerprintSize??2,this.scale=t.scale??2,this.hash=t.hash??Bo,this.seed=t.seed??Zr(0,Math.pow(2,10)),this.filterSeries=[new ko({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(t){if(typeof t=="string"&&(t=H(t)),this.has(t))return!0;let e=this.filterSeries.find(n=>n.reliable);if(e==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);e=new ko({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(e)}return e.add(t)}has(t){typeof t=="string"&&(t=H(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].has(t))return!0;return!1}remove(t){typeof t=="string"&&(t=H(t));for(let e=0;e<this.filterSeries.length;e++)if(this.filterSeries[e].remove(t))return!0;return!1}get count(){return this.filterSeries.reduce((t,e)=>t+e.count,0)}};function du(r,t=.001,e){return new Ii({...Sd(r,t),...e??{}})}function Jw(r,t){try{if(typeof r=="string"&&r.length>0)return Xw(r);if(typeof r=="number"&&isFinite(r))return t?.long?tx(r):Qw(r);throw new Error("Value is not a string or number.")}catch(e){let n=ex(e)?`${e.message}. value=${JSON.stringify(r)}`:"An unknown error has occured.";throw new Error(n)}}function Xw(r){if(r=String(r),r.length>100)throw new Error("Value exceeds the maximum length of 100 characters.");let t=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(r);if(!t)return NaN;let e=parseFloat(t[1]),n=(t[2]||"ms").toLowerCase();switch(n){case"years":case"year":case"yrs":case"yr":case"y":return e*315576e5;case"weeks":case"week":case"w":return e*6048e5;case"days":case"day":case"d":return e*864e5;case"hours":case"hour":case"hrs":case"hr":case"h":return e*36e5;case"minutes":case"minute":case"mins":case"min":case"m":return e*6e4;case"seconds":case"second":case"secs":case"sec":case"s":return e*1e3;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return e;default:throw new Error(`The unit ${n} was matched, but no matching case exists.`)}}var Ti=Jw;function Qw(r){let t=Math.abs(r);return t>=864e5?`${Math.round(r/864e5)}d`:t>=36e5?`${Math.round(r/36e5)}h`:t>=6e4?`${Math.round(r/6e4)}m`:t>=1e3?`${Math.round(r/1e3)}s`:`${r}ms`}function tx(r){let t=Math.abs(r);return t>=864e5?_i(r,t,864e5,"day"):t>=36e5?_i(r,t,36e5,"hour"):t>=6e4?_i(r,t,6e4,"minute"):t>=1e3?_i(r,t,1e3,"second"):`${r} ms`}function _i(r,t,e,n){let o=t>=e*1.5;return`${Math.round(r/e)} ${n}${o?"s":""}`}function ex(r){return typeof r=="object"&&r!==null&&"message"in r}function pu(r){e.debug=e,e.default=e,e.coerce=c,e.disable=s,e.enable=o,e.enabled=i,e.humanize=Ti,e.destroy=u,Object.keys(r).forEach(l=>{e[l]=r[l]}),e.names=[],e.skips=[],e.formatters={};function t(l){let f=0;for(let d=0;d<l.length;d++)f=(f<<5)-f+l.charCodeAt(d),f|=0;return e.colors[Math.abs(f)%e.colors.length]}e.selectColor=t;function e(l){let f,d=null,h,g;function m(...w){if(!m.enabled)return;let x=m,b=Number(new Date),y=b-(f||b);x.diff=y,x.prev=f,x.curr=b,f=b,w[0]=e.coerce(w[0]),typeof w[0]!="string"&&w.unshift("%O");let S=0;w[0]=w[0].replace(/%([a-zA-Z%])/g,(N,E)=>{if(N==="%%")return"%";S++;let v=e.formatters[E];if(typeof v=="function"){let k=w[S];N=v.call(x,k),w.splice(S,1),S--}return N}),e.formatArgs.call(x,w),(x.log||e.log).apply(x,w)}return m.namespace=l,m.useColors=e.useColors(),m.color=e.selectColor(l),m.extend=n,m.destroy=e.destroy,Object.defineProperty(m,"enabled",{enumerable:!0,configurable:!1,get:()=>d!==null?d:(h!==e.namespaces&&(h=e.namespaces,g=e.enabled(l)),g),set:w=>{d=w}}),typeof e.init=="function"&&e.init(m),m}function n(l,f){let d=e(this.namespace+(typeof f>"u"?":":f)+l);return d.log=this.log,d}function o(l){e.save(l),e.namespaces=l,e.names=[],e.skips=[];let f,d=(typeof l=="string"?l:"").split(/[\s,]+/),h=d.length;for(f=0;f<h;f++)d[f]&&(l=d[f].replace(/\*/g,".*?"),l[0]==="-"?e.skips.push(new RegExp("^"+l.substr(1)+"$")):e.names.push(new RegExp("^"+l+"$")))}function s(){let l=[...e.names.map(a),...e.skips.map(a).map(f=>"-"+f)].join(",");return e.enable(""),l}function i(l){if(l[l.length-1]==="*")return!0;let f,d;for(f=0,d=e.skips.length;f<d;f++)if(e.skips[f].test(l))return!1;for(f=0,d=e.names.length;f<d;f++)if(e.names[f].test(l))return!0;return!1}function a(l){return l.toString().substring(2,l.toString().length-2).replace(/\.\*\?$/,"*")}function c(l){return l instanceof Error?l.stack??l.message:l}function u(){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 e.setupFormatters(e.formatters),e.enable(e.load()),e}var Ci=cx(),rx=["#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 nx(){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 ox(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+Ti(this.diff),!this.useColors)return;let t="color: "+this.color;r.splice(1,0,t,"color: inherit");let e=0,n=0;r[0].replace(/%[a-zA-Z%]/g,o=>{o!=="%%"&&(e++,o==="%c"&&(n=e))}),r.splice(n,0,t)}var sx=console.debug??console.log??(()=>{});function ix(r){try{r?Ci?.setItem("debug",r):Ci?.removeItem("debug")}catch{}}function ax(){let r;try{r=Ci?.getItem("debug")}catch{}return!r&&typeof globalThis.process<"u"&&"env"in globalThis.process&&(r=globalThis.process.env.DEBUG),r}function cx(){try{return localStorage}catch{}}function ux(r){r.j=function(t){try{return JSON.stringify(t)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}}var Bd=pu({formatArgs:ox,save:ix,load:ax,useColors:nx,setupFormatters:ux,colors:rx,storage:Ci,log:sx});var Yt=Bd;Yt.formatters.b=r=>r==null?"undefined":it.baseEncode(r);Yt.formatters.t=r=>r==null?"undefined":_t.baseEncode(r);Yt.formatters.m=r=>r==null?"undefined":Ce.baseEncode(r);Yt.formatters.p=r=>r==null?"undefined":r.toString();Yt.formatters.c=r=>r==null?"undefined":r.toString();Yt.formatters.k=r=>r==null?"undefined":r.toString();Yt.formatters.a=r=>r==null?"undefined":r.toString();Yt.formatters.e=r=>r==null?"undefined":kd(r.stack)??kd(r.message)??r.toString();function lx(r){let t=()=>{};return t.enabled=!1,t.color="",t.diff=0,t.log=()=>{},t.namespace=r,t.destroy=()=>!0,t.extend=()=>t,t}function Id(){return{forComponent(r){return Qt(r)}}}function Qt(r){let t=lx(`${r}:trace`);return Yt.enabled(`${r}:trace`)&&Yt.names.map(e=>e.toString()).find(e=>e.includes(":trace"))!=null&&(t=Yt(`${r}:trace`)),Object.assign(Yt(r),{error:Yt(`${r}:error`),trace:t})}function kd(r){if(r!=null&&(r=r.trim(),r.length!==0))return r}var gu=Rr(Td(),1);var _o=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},yu=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},Cd=r=>globalThis.DOMException===void 0?new yu(r):new DOMException(r),Nd=r=>{let t=r.reason===void 0?Cd("This operation was aborted."):r.reason;return t instanceof Error?t:Cd(t)};function To(r,t){let{milliseconds:e,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout}}=t,i,a,u=new Promise((l,f)=>{if(typeof e!="number"||Math.sign(e)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${e}\``);if(t.signal){let{signal:h}=t;h.aborted&&f(Nd(h)),a=()=>{f(Nd(h))},h.addEventListener("abort",a,{once:!0})}if(e===Number.POSITIVE_INFINITY){r.then(l,f);return}let d=new _o;i=s.setTimeout.call(void 0,()=>{if(n){try{l(n())}catch(h){f(h)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?l():o instanceof Error?f(o):(d.message=o??`Promise timed out after ${e} milliseconds`,f(d))},e),(async()=>{try{l(await r)}catch(h){f(h)}})()}).finally(()=>{u.clear(),a&&t.signal&&t.signal.removeEventListener("abort",a)});return u.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},u}function wu(r,t,e){let n=0,o=r.length;for(;o>0;){let s=Math.trunc(o/2),i=n+s;e(r[i],t)<=0?(n=++i,o-=s+1):o=s}return n}var Co=class{#t=[];enqueue(t,e){e={priority:0,...e};let n={priority:e.priority,run:t};if(this.size&&this.#t[this.size-1].priority>=e.priority){this.#t.push(n);return}let o=wu(this.#t,n,(s,i)=>i.priority-s.priority);this.#t.splice(o,0,n)}dequeue(){return this.#t.shift()?.run}filter(t){return this.#t.filter(e=>e.priority===t.priority).map(e=>e.run)}get size(){return this.#t.length}};var De=class extends gu.default{#t;#e;#r=0;#o;#a;#u=0;#s;#l;#n;#m;#i=0;#f;#c;#g;timeout;constructor(t){if(super(),t={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:Co,...t},!(typeof t.intervalCap=="number"&&t.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${t.intervalCap?.toString()??""}\` (${typeof t.intervalCap})`);if(t.interval===void 0||!(Number.isFinite(t.interval)&&t.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${t.interval?.toString()??""}\` (${typeof t.interval})`);this.#t=t.carryoverConcurrencyCount,this.#e=t.intervalCap===Number.POSITIVE_INFINITY||t.interval===0,this.#o=t.intervalCap,this.#a=t.interval,this.#n=new t.queueClass,this.#m=t.queueClass,this.concurrency=t.concurrency,this.timeout=t.timeout,this.#g=t.throwOnTimeout===!0,this.#c=t.autoStart===!1}get#x(){return this.#e||this.#r<this.#o}get#b(){return this.#i<this.#f}#v(){this.#i--,this.#h(),this.emit("next")}#E(){this.#w(),this.#y(),this.#l=void 0}get#A(){let t=Date.now();if(this.#s===void 0){let e=this.#u-t;if(e<0)this.#r=this.#t?this.#i:0;else return this.#l===void 0&&(this.#l=setTimeout(()=>{this.#E()},e)),!0}return!1}#h(){if(this.#n.size===0)return this.#s&&clearInterval(this.#s),this.#s=void 0,this.emit("empty"),this.#i===0&&this.emit("idle"),!1;if(!this.#c){let t=!this.#A;if(this.#x&&this.#b){let e=this.#n.dequeue();return e?(this.emit("active"),e(),t&&this.#y(),!0):!1}}return!1}#y(){this.#e||this.#s!==void 0||(this.#s=setInterval(()=>{this.#w()},this.#a),this.#u=Date.now()+this.#a)}#w(){this.#r===0&&this.#i===0&&this.#s&&(clearInterval(this.#s),this.#s=void 0),this.#r=this.#t?this.#i:0,this.#d()}#d(){for(;this.#h(););}get concurrency(){return this.#f}set concurrency(t){if(!(typeof t=="number"&&t>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${t}\` (${typeof t})`);this.#f=t,this.#d()}async#S(t){return new Promise((e,n)=>{t.addEventListener("abort",()=>{n(t.reason)},{once:!0})})}async add(t,e={}){return e={timeout:this.timeout,throwOnTimeout:this.#g,...e},new Promise((n,o)=>{this.#n.enqueue(async()=>{this.#i++,this.#r++;try{e.signal?.throwIfAborted();let s=t({signal:e.signal});e.timeout&&(s=To(Promise.resolve(s),{milliseconds:e.timeout})),e.signal&&(s=Promise.race([s,this.#S(e.signal)]));let i=await s;n(i),this.emit("completed",i)}catch(s){if(s instanceof _o&&!e.throwOnTimeout){n();return}o(s),this.emit("error",s)}finally{this.#v()}},e),this.emit("add"),this.#h()})}async addAll(t,e){return Promise.all(t.map(async n=>this.add(n,e)))}start(){return this.#c?(this.#c=!1,this.#d(),this):this}pause(){this.#c=!0}clear(){this.#n=new this.#m}async onEmpty(){this.#n.size!==0&&await this.#p("empty")}async onSizeLessThan(t){this.#n.size<t||await this.#p("next",()=>this.#n.size<t)}async onIdle(){this.#i===0&&this.#n.size===0||await this.#p("idle")}async#p(t,e){return new Promise(n=>{let o=()=>{e&&!e()||(this.off(t,o),n())};this.on(t,o)})}get size(){return this.#n.size}sizeBy(t){return this.#n.filter(t).length}get pending(){return this.#i}get isPaused(){return this.#c}};function Li(r){let t=[xe.A];return r==null?t:Array.isArray(r)?r.length===0?t:r:[r]}var xu=60;function Pi(r){return{Status:r.Status??0,TC:r.TC??r.flag_tc??!1,RD:r.RD??r.flag_rd??!1,RA:r.RA??r.flag_ra??!1,AD:r.AD??r.flag_ad??!1,CD:r.CD??r.flag_cd??!1,Question:(r.Question??r.questions??[]).map(t=>({name:t.name,type:xe[t.type]})),Answer:(r.Answer??r.answers??[]).map(t=>({name:t.name,type:xe[t.type],TTL:t.TTL??t.ttl??xu,data:t.data instanceof Uint8Array?et(t.data):t.data}))}}var dx=4;function bu(r,t={}){let e=new De({concurrency:t.queryConcurrency??dx});return async(n,o={})=>{let s=new URLSearchParams;s.set("name",n),Li(o.types).forEach(a=>{s.append("type",xe[a])}),o.onProgress?.(new tt("dns:query",{detail:n}));let i=await e.add(async()=>{let a=await fetch(`${r}?${s}`,{headers:{accept:"application/dns-json"},signal:o?.signal});if(a.status!==200)throw new Error(`Unexpected HTTP status: ${a.status} - ${a.statusText}`);let c=Pi(await a.json());return o.onProgress?.(new tt("dns:response",{detail:c})),c},{signal:o.signal});if(i==null)throw new Error("No DNS response received");return i}}function Ld(){return[bu("https://cloudflare-dns.com/dns-query"),bu("https://dns.google/resolve")]}var Ud=Rr(Rd(),1);var vu=class{lru;constructor(t){this.lru=(0,Ud.default)(t)}get(t,e){let n=!0,o=[];for(let s of e){let i=this.getAnswers(t,s);if(i.length===0){n=!1;break}o.push(...i)}if(n)return Pi({answers:o})}getAnswers(t,e){let n=`${t.toLowerCase()}-${e}`,o=this.lru.get(n);if(o!=null){let s=o.filter(i=>i.expires>Date.now()).map(({expires:i,value:a})=>({...a,TTL:Math.round((i-Date.now())/1e3),type:xe[a.type]}));return s.length===0&&this.lru.remove(n),s}return[]}add(t,e){let n=`${t.toLowerCase()}-${e.type}`,o=this.lru.get(n)??[];o.push({expires:Date.now()+(e.TTL??xu)*1e3,value:e}),this.lru.set(n,o)}remove(t,e){let n=`${t.toLowerCase()}-${e}`;this.lru.remove(n)}clear(){this.lru.clear()}};function Dd(r){return new vu(r)}var px=1e3,Ri=class{resolvers;cache;constructor(t){this.resolvers={},this.cache=Dd(t.cacheSize??px),Object.entries(t.resolvers??{}).forEach(([e,n])=>{Array.isArray(n)||(n=[n]),e.endsWith(".")||(e=`${e}.`),this.resolvers[e]=n}),this.resolvers["."]==null&&(this.resolvers["."]=Ld())}async query(t,e={}){let n=Li(e.types),o=e.cached!==!1?this.cache.get(t,n):void 0;if(o!=null)return e.onProgress?.(new tt("dns:cache",{detail:o})),o;let s=`${t.split(".").pop()}.`,i=(this.resolvers[s]??this.resolvers["."]).sort(()=>Math.random()>.5?-1:1),a=[];for(let c of i){if(e.signal?.aborted===!0)break;try{let u=await c(t,{...e,types:n});for(let l of u.Answer)this.cache.add(t,l);return u}catch(u){a.push(u),e.onProgress?.(new tt("dns:error",{detail:u}))}}throw a.length===1?a[0]:new AggregateError(a,`DNS lookup of ${t} ${n} failed`)}};var xe;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(xe||(xe={}));function Fd(r={}){return new Ri(r)}var mx=["string","number","bigint","symbol"],gx=["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 Md(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let t=typeof r;if(mx.includes(t))return t;if(t==="function")return"Function";if(Array.isArray(r))return"Array";if(yx(r))return"Buffer";let e=wx(r);return e||"Object"}function yx(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function wx(r){let t=Object.prototype.toString.call(r).slice(8,-1);if(gx.includes(t))return t}var p=class{constructor(t,e,n){this.major=t,this.majorEncoded=t<<5,this.name=e,this.terminal=n}toString(){return`Type[${this.major}].${this.name}`}compare(t){return this.major<t.major?-1:this.major>t.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 I=class{constructor(t,e,n){this.type=t,this.value=e,this.encodedLength=n,this.encodedBytes=void 0,this.byteValue=void 0}toString(){return`Token[${this.type}].${this.value}`}};var Nn=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",xx=new TextDecoder,bx=new TextEncoder;function Ui(r){return Nn&&globalThis.Buffer.isBuffer(r)}function No(r){return r instanceof Uint8Array?Ui(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var Hd=Nn?(r,t,e)=>e-t>64?globalThis.Buffer.from(r.subarray(t,e)).toString("utf8"):Od(r,t,e):(r,t,e)=>e-t>64?xx.decode(r.subarray(t,e)):Od(r,t,e),Di=Nn?r=>r.length>64?globalThis.Buffer.from(r):Vd(r):r=>r.length>64?bx.encode(r):Vd(r),Fe=r=>Uint8Array.from(r),Ln=Nn?(r,t,e)=>Ui(r)?new Uint8Array(r.subarray(t,e)):r.slice(t,e):(r,t,e)=>r.slice(t,e),zd=Nn?(r,t)=>(r=r.map(e=>e instanceof Uint8Array?e:globalThis.Buffer.from(e)),No(globalThis.Buffer.concat(r,t))):(r,t)=>{let e=new Uint8Array(t),n=0;for(let o of r)n+o.length>e.length&&(o=o.subarray(0,e.length-n)),e.set(o,n),n+=o.length;return e},Kd=Nn?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function qd(r,t){if(Ui(r)&&Ui(t))return r.compare(t);for(let e=0;e<r.length;e++)if(r[e]!==t[e])return r[e]<t[e]?-1:1;return 0}function Vd(r){let t=[],e=0;for(let n=0;n<r.length;n++){let o=r.charCodeAt(n);o<128?t[e++]=o:o<2048?(t[e++]=o>>6|192,t[e++]=o&63|128):(o&64512)===55296&&n+1<r.length&&(r.charCodeAt(n+1)&64512)===56320?(o=65536+((o&1023)<<10)+(r.charCodeAt(++n)&1023),t[e++]=o>>18|240,t[e++]=o>>12&63|128,t[e++]=o>>6&63|128,t[e++]=o&63|128):(t[e++]=o>>12|224,t[e++]=o>>6&63|128,t[e++]=o&63|128)}return t}function Od(r,t,e){let n=[];for(;t<e;){let o=r[t],s=null,i=o>239?4:o>223?3:o>191?2:1;if(t+i<=e){let a,c,u,l;switch(i){case 1:o<128&&(s=o);break;case 2:a=r[t+1],(a&192)===128&&(l=(o&31)<<6|a&63,l>127&&(s=l));break;case 3:a=r[t+1],c=r[t+2],(a&192)===128&&(c&192)===128&&(l=(o&15)<<12|(a&63)<<6|c&63,l>2047&&(l<55296||l>57343)&&(s=l));break;case 4:a=r[t+1],c=r[t+2],u=r[t+3],(a&192)===128&&(c&192)===128&&(u&192)===128&&(l=(o&15)<<18|(a&63)<<12|(c&63)<<6|u&63,l>65535&&l<1114112&&(s=l))}}s===null?(s=65533,i=1):s>65535&&(s-=65536,n.push(s>>>10&1023|55296),s=56320|s&1023),n.push(s),t+=i}return Eu(n)}var $d=4096;function Eu(r){let t=r.length;if(t<=$d)return String.fromCharCode.apply(String,r);let e="",n=0;for(;n<t;)e+=String.fromCharCode.apply(String,r.slice(n,n+=$d));return e}var vx=256,Lo=class{constructor(t=vx){this.chunkSize=t,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(t){let e=this.chunks[this.chunks.length-1];if(this.cursor+t.length<=this.maxCursor+1){let o=e.length-(this.maxCursor-this.cursor)-1;e.set(t,o)}else{if(e){let o=e.length-(this.maxCursor-this.cursor)-1;o<e.length&&(this.chunks[this.chunks.length-1]=e.subarray(0,o),this.maxCursor=this.cursor-1)}t.length<64&&t.length<this.chunkSize?(e=Kd(this.chunkSize),this.chunks.push(e),this.maxCursor+=e.length,this._initReuseChunk===null&&(this._initReuseChunk=e),e.set(t,0)):(this.chunks.push(t),this.maxCursor+=t.length)}this.cursor+=t.length}toBytes(t=!1){let e;if(this.chunks.length===1){let n=this.chunks[0];t&&this.cursor>n.length/2?(e=this.cursor===n.length?n:n.subarray(0,this.cursor),this._initReuseChunk=null,this.chunks=[]):e=Ln(n,0,this.cursor)}else e=zd(this.chunks,this.cursor);return t&&this.reset(),e}};var V="CBOR decode error:",er="CBOR encode error:",Po=[];Po[23]=1;Po[24]=2;Po[25]=3;Po[26]=5;Po[27]=9;function rr(r,t,e){if(r.length-t<e)throw new Error(`${V} not enough data for type`)}var Bt=[24,256,65536,4294967296,BigInt("18446744073709551616")];function te(r,t,e){rr(r,t,1);let n=r[t];if(e.strict===!0&&n<Bt[0])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function ee(r,t,e){rr(r,t,2);let n=r[t]<<8|r[t+1];if(e.strict===!0&&n<Bt[1])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function re(r,t,e){rr(r,t,4);let n=r[t]*16777216+(r[t+1]<<16)+(r[t+2]<<8)+r[t+3];if(e.strict===!0&&n<Bt[2])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function ne(r,t,e){rr(r,t,8);let n=r[t]*16777216+(r[t+1]<<16)+(r[t+2]<<8)+r[t+3],o=r[t+4]*16777216+(r[t+5]<<16)+(r[t+6]<<8)+r[t+7],s=(BigInt(n)<<BigInt(32))+BigInt(o);if(e.strict===!0&&s<Bt[3])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);if(s<=Number.MAX_SAFE_INTEGER)return Number(s);if(e.allowBigInt===!0)return s;throw new Error(`${V} integers outside of the safe integer range are not supported`)}function jd(r,t,e,n){return new I(p.uint,te(r,t+1,n),2)}function Gd(r,t,e,n){return new I(p.uint,ee(r,t+1,n),3)}function Wd(r,t,e,n){return new I(p.uint,re(r,t+1,n),5)}function Zd(r,t,e,n){return new I(p.uint,ne(r,t+1,n),9)}function ie(r,t){return Nt(r,0,t.value)}function Nt(r,t,e){if(e<Bt[0]){let n=Number(e);r.push([t|n])}else if(e<Bt[1]){let n=Number(e);r.push([t|24,n])}else if(e<Bt[2]){let n=Number(e);r.push([t|25,n>>>8,n&255])}else if(e<Bt[3]){let n=Number(e);r.push([t|26,n>>>24&255,n>>>16&255,n>>>8&255,n&255])}else{let n=BigInt(e);if(n<Bt[4]){let o=[t|27,0,0,0,0,0,0,0],s=Number(n&BigInt(4294967295)),i=Number(n>>BigInt(32)&BigInt(4294967295));o[8]=s&255,s=s>>8,o[7]=s&255,s=s>>8,o[6]=s&255,s=s>>8,o[5]=s&255,o[4]=i&255,i=i>>8,o[3]=i&255,i=i>>8,o[2]=i&255,i=i>>8,o[1]=i&255,r.push(o)}else throw new Error(`${V} encountered BigInt larger than allowable range`)}}ie.encodedSize=function(t){return Nt.encodedSize(t.value)};Nt.encodedSize=function(t){return t<Bt[0]?1:t<Bt[1]?2:t<Bt[2]?3:t<Bt[3]?5:9};ie.compareTokens=function(t,e){return t.value<e.value?-1:t.value>e.value?1:0};function Yd(r,t,e,n){return new I(p.negint,-1-te(r,t+1,n),2)}function Jd(r,t,e,n){return new I(p.negint,-1-ee(r,t+1,n),3)}function Xd(r,t,e,n){return new I(p.negint,-1-re(r,t+1,n),5)}var Au=BigInt(-1),Qd=BigInt(1);function tp(r,t,e,n){let o=ne(r,t+1,n);if(typeof o!="bigint"){let s=-1-o;if(s>=Number.MIN_SAFE_INTEGER)return new I(p.negint,s,9)}if(n.allowBigInt!==!0)throw new Error(`${V} integers outside of the safe integer range are not supported`);return new I(p.negint,Au-BigInt(o),9)}function Fi(r,t){let e=t.value,n=typeof e=="bigint"?e*Au-Qd:e*-1-1;Nt(r,t.type.majorEncoded,n)}Fi.encodedSize=function(t){let e=t.value,n=typeof e=="bigint"?e*Au-Qd:e*-1-1;return n<Bt[0]?1:n<Bt[1]?2:n<Bt[2]?3:n<Bt[3]?5:9};Fi.compareTokens=function(t,e){return t.value<e.value?1:t.value>e.value?-1:0};function Ro(r,t,e,n){rr(r,t,e+n);let o=Ln(r,t+e,t+e+n);return new I(p.bytes,o,e+n)}function ep(r,t,e,n){return Ro(r,t,1,e)}function rp(r,t,e,n){return Ro(r,t,2,te(r,t+1,n))}function np(r,t,e,n){return Ro(r,t,3,ee(r,t+1,n))}function op(r,t,e,n){return Ro(r,t,5,re(r,t+1,n))}function sp(r,t,e,n){let o=ne(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer bytes lengths not supported`);return Ro(r,t,9,o)}function Mi(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===p.string?Di(r.value):r.value),r.encodedBytes}function Pn(r,t){let e=Mi(t);Nt(r,t.type.majorEncoded,e.length),r.push(e)}Pn.encodedSize=function(t){let e=Mi(t);return Nt.encodedSize(e.length)+e.length};Pn.compareTokens=function(t,e){return Ax(Mi(t),Mi(e))};function Ax(r,t){return r.length<t.length?-1:r.length>t.length?1:qd(r,t)}function Uo(r,t,e,n,o){let s=e+n;rr(r,t,s);let i=new I(p.string,Hd(r,t+e,t+s),s);return o.retainStringBytes===!0&&(i.byteValue=Ln(r,t+e,t+s)),i}function ip(r,t,e,n){return Uo(r,t,1,e,n)}function ap(r,t,e,n){return Uo(r,t,2,te(r,t+1,n),n)}function cp(r,t,e,n){return Uo(r,t,3,ee(r,t+1,n),n)}function up(r,t,e,n){return Uo(r,t,5,re(r,t+1,n),n)}function lp(r,t,e,n){let o=ne(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer string lengths not supported`);return Uo(r,t,9,o,n)}var fp=Pn;function Rn(r,t,e,n){return new I(p.array,n,e)}function hp(r,t,e,n){return Rn(r,t,1,e)}function dp(r,t,e,n){return Rn(r,t,2,te(r,t+1,n))}function pp(r,t,e,n){return Rn(r,t,3,ee(r,t+1,n))}function mp(r,t,e,n){return Rn(r,t,5,re(r,t+1,n))}function gp(r,t,e,n){let o=ne(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer array lengths not supported`);return Rn(r,t,9,o)}function yp(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Rn(r,t,1,1/0)}function Vi(r,t){Nt(r,p.array.majorEncoded,t.value)}Vi.compareTokens=ie.compareTokens;Vi.encodedSize=function(t){return Nt.encodedSize(t.value)};function Un(r,t,e,n){return new I(p.map,n,e)}function wp(r,t,e,n){return Un(r,t,1,e)}function xp(r,t,e,n){return Un(r,t,2,te(r,t+1,n))}function bp(r,t,e,n){return Un(r,t,3,ee(r,t+1,n))}function vp(r,t,e,n){return Un(r,t,5,re(r,t+1,n))}function Ep(r,t,e,n){let o=ne(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer map lengths not supported`);return Un(r,t,9,o)}function Ap(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Un(r,t,1,1/0)}function Oi(r,t){Nt(r,p.map.majorEncoded,t.value)}Oi.compareTokens=ie.compareTokens;Oi.encodedSize=function(t){return Nt.encodedSize(t.value)};function Sp(r,t,e,n){return new I(p.tag,e,1)}function Bp(r,t,e,n){return new I(p.tag,te(r,t+1,n),2)}function kp(r,t,e,n){return new I(p.tag,ee(r,t+1,n),3)}function Ip(r,t,e,n){return new I(p.tag,re(r,t+1,n),5)}function _p(r,t,e,n){return new I(p.tag,ne(r,t+1,n),9)}function $i(r,t){Nt(r,p.tag.majorEncoded,t.value)}$i.compareTokens=ie.compareTokens;$i.encodedSize=function(t){return Nt.encodedSize(t.value)};var Tx=20,Cx=21,Nx=22,Lx=23;function Tp(r,t,e,n){if(n.allowUndefined===!1)throw new Error(`${V} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new I(p.null,null,1):new I(p.undefined,void 0,1)}function Cp(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return new I(p.break,void 0,1)}function Su(r,t,e){if(e){if(e.allowNaN===!1&&Number.isNaN(r))throw new Error(`${V} NaN values are not supported`);if(e.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${V} Infinity values are not supported`)}return new I(p.float,r,t)}function Np(r,t,e,n){return Su(Bu(r,t+1),3,n)}function Lp(r,t,e,n){return Su(ku(r,t+1),5,n)}function Pp(r,t,e,n){return Su(Fp(r,t+1),9,n)}function Hi(r,t,e){let n=t.value;if(n===!1)r.push([p.float.majorEncoded|Tx]);else if(n===!0)r.push([p.float.majorEncoded|Cx]);else if(n===null)r.push([p.float.majorEncoded|Nx]);else if(n===void 0)r.push([p.float.majorEncoded|Lx]);else{let o,s=!1;(!e||e.float64!==!0)&&(Up(n),o=Bu(be,1),n===o||Number.isNaN(n)?(be[0]=249,r.push(be.slice(0,3)),s=!0):(Dp(n),o=ku(be,1),n===o&&(be[0]=250,r.push(be.slice(0,5)),s=!0))),s||(Px(n),o=Fp(be,1),be[0]=251,r.push(be.slice(0,9)))}}Hi.encodedSize=function(t,e){let n=t.value;if(n===!1||n===!0||n===null||n===void 0)return 1;if(!e||e.float64!==!0){Up(n);let o=Bu(be,1);if(n===o||Number.isNaN(n))return 3;if(Dp(n),o=ku(be,1),n===o)return 5}return 9};var Rp=new ArrayBuffer(9),ae=new DataView(Rp,1),be=new Uint8Array(Rp,0);function Up(r){if(r===1/0)ae.setUint16(0,31744,!1);else if(r===-1/0)ae.setUint16(0,64512,!1);else if(Number.isNaN(r))ae.setUint16(0,32256,!1);else{ae.setFloat32(0,r);let t=ae.getUint32(0),e=(t&2139095040)>>23,n=t&8388607;if(e===255)ae.setUint16(0,31744,!1);else if(e===0)ae.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let o=e-127;o<-24?ae.setUint16(0,0):o<-14?ae.setUint16(0,(t&2147483648)>>16|1<<24+o,!1):ae.setUint16(0,(t&2147483648)>>16|o+15<<10|n>>13,!1)}}}function Bu(r,t){if(r.length-t<2)throw new Error(`${V} not enough data for float16`);let e=(r[t]<<8)+r[t+1];if(e===31744)return 1/0;if(e===64512)return-1/0;if(e===32256)return NaN;let n=e>>10&31,o=e&1023,s;return n===0?s=o*2**-24:n!==31?s=(o+1024)*2**(n-25):s=o===0?1/0:NaN,e&32768?-s:s}function Dp(r){ae.setFloat32(0,r,!1)}function ku(r,t){if(r.length-t<4)throw new Error(`${V} not enough data for float32`);let e=(r.byteOffset||0)+t;return new DataView(r.buffer,e,4).getFloat32(0,!1)}function Px(r){ae.setFloat64(0,r,!1)}function Fp(r,t){if(r.length-t<8)throw new Error(`${V} not enough data for float64`);let e=(r.byteOffset||0)+t;return new DataView(r.buffer,e,8).getFloat64(0,!1)}Hi.compareTokens=ie.compareTokens;function Q(r,t,e){throw new Error(`${V} encountered invalid minor (${e}) for major ${r[t]>>>5}`)}function zi(r){return()=>{throw new Error(`${V} ${r}`)}}var R=[];for(let r=0;r<=23;r++)R[r]=Q;R[24]=jd;R[25]=Gd;R[26]=Wd;R[27]=Zd;R[28]=Q;R[29]=Q;R[30]=Q;R[31]=Q;for(let r=32;r<=55;r++)R[r]=Q;R[56]=Yd;R[57]=Jd;R[58]=Xd;R[59]=tp;R[60]=Q;R[61]=Q;R[62]=Q;R[63]=Q;for(let r=64;r<=87;r++)R[r]=ep;R[88]=rp;R[89]=np;R[90]=op;R[91]=sp;R[92]=Q;R[93]=Q;R[94]=Q;R[95]=zi("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)R[r]=ip;R[120]=ap;R[121]=cp;R[122]=up;R[123]=lp;R[124]=Q;R[125]=Q;R[126]=Q;R[127]=zi("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)R[r]=hp;R[152]=dp;R[153]=pp;R[154]=mp;R[155]=gp;R[156]=Q;R[157]=Q;R[158]=Q;R[159]=yp;for(let r=160;r<=183;r++)R[r]=wp;R[184]=xp;R[185]=bp;R[186]=vp;R[187]=Ep;R[188]=Q;R[189]=Q;R[190]=Q;R[191]=Ap;for(let r=192;r<=215;r++)R[r]=Sp;R[216]=Bp;R[217]=kp;R[218]=Ip;R[219]=_p;R[220]=Q;R[221]=Q;R[222]=Q;R[223]=Q;for(let r=224;r<=243;r++)R[r]=zi("simple values are not supported");R[244]=Q;R[245]=Q;R[246]=Q;R[247]=Tp;R[248]=zi("simple values are not supported");R[249]=Np;R[250]=Lp;R[251]=Pp;R[252]=Q;R[253]=Q;R[254]=Q;R[255]=Cp;var ve=[];for(let r=0;r<24;r++)ve[r]=new I(p.uint,r,1);for(let r=-1;r>=-24;r--)ve[31-r]=new I(p.negint,r,1);ve[64]=new I(p.bytes,new Uint8Array(0),1);ve[96]=new I(p.string,"",1);ve[128]=new I(p.array,0,1);ve[160]=new I(p.map,0,1);ve[244]=new I(p.false,!1,1);ve[245]=new I(p.true,!0,1);ve[246]=new I(p.null,null,1);function Mp(r){switch(r.type){case p.false:return Fe([244]);case p.true:return Fe([245]);case p.null:return Fe([246]);case p.bytes:return r.value.length?void 0:Fe([64]);case p.string:return r.value===""?Fe([96]):void 0;case p.array:return r.value===0?Fe([128]):void 0;case p.map:return r.value===0?Fe([160]):void 0;case p.uint:return r.value<24?Fe([Number(r.value)]):void 0;case p.negint:if(r.value>=-24)return Fe([31-Number(r.value)])}}var Ux={float64:!1,mapSorter:Mx,quickEncodeToken:Mp};function Dx(){let r=[];return r[p.uint.major]=ie,r[p.negint.major]=Fi,r[p.bytes.major]=Pn,r[p.string.major]=fp,r[p.array.major]=Vi,r[p.map.major]=Oi,r[p.tag.major]=$i,r[p.float.major]=Hi,r}var Vp=Dx(),Iu=new Lo,qi=class r{constructor(t,e){this.obj=t,this.parent=e}includes(t){let e=this;do if(e.obj===t)return!0;while(e=e.parent);return!1}static createCheck(t,e){if(t&&t.includes(e))throw new Error(`${er} object contains circular references`);return new r(e,t)}},kr={null:new I(p.null,null),undefined:new I(p.undefined,void 0),true:new I(p.true,!0),false:new I(p.false,!1),emptyArray:new I(p.array,0),emptyMap:new I(p.map,0)},Ir={number(r,t,e,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new I(p.float,r):r>=0?new I(p.uint,r):new I(p.negint,r)},bigint(r,t,e,n){return r>=BigInt(0)?new I(p.uint,r):new I(p.negint,r)},Uint8Array(r,t,e,n){return new I(p.bytes,r)},string(r,t,e,n){return new I(p.string,r)},boolean(r,t,e,n){return r?kr.true:kr.false},null(r,t,e,n){return kr.null},undefined(r,t,e,n){return kr.undefined},ArrayBuffer(r,t,e,n){return new I(p.bytes,new Uint8Array(r))},DataView(r,t,e,n){return new I(p.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,t,e,n){if(!r.length)return e.addBreakTokens===!0?[kr.emptyArray,new I(p.break)]:kr.emptyArray;n=qi.createCheck(n,r);let o=[],s=0;for(let i of r)o[s++]=Ki(i,e,n);return e.addBreakTokens?[new I(p.array,r.length),o,new I(p.break)]:[new I(p.array,r.length),o]},Object(r,t,e,n){let o=t!=="Object",s=o?r.keys():Object.keys(r),i=o?r.size:s.length;if(!i)return e.addBreakTokens===!0?[kr.emptyMap,new I(p.break)]:kr.emptyMap;n=qi.createCheck(n,r);let a=[],c=0;for(let u of s)a[c++]=[Ki(u,e,n),Ki(o?r.get(u):r[u],e,n)];return Fx(a,e),e.addBreakTokens?[new I(p.map,i),a,new I(p.break)]:[new I(p.map,i),a]}};Ir.Map=Ir.Object;Ir.Buffer=Ir.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))Ir[`${r}Array`]=Ir.DataView;function Ki(r,t={},e){let n=Md(r),o=t&&t.typeEncoders&&t.typeEncoders[n]||Ir[n];if(typeof o=="function"){let i=o(r,n,t,e);if(i!=null)return i}let s=Ir[n];if(!s)throw new Error(`${er} unsupported type: ${n}`);return s(r,n,t,e)}function Fx(r,t){t.mapSorter&&r.sort(t.mapSorter)}function Mx(r,t){let e=Array.isArray(r[0])?r[0][0]:r[0],n=Array.isArray(t[0])?t[0][0]:t[0];if(e.type!==n.type)return e.type.compare(n.type);let o=e.type.major,s=Vp[o].compareTokens(e,n);return s===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),s}function Op(r,t,e,n){if(Array.isArray(t))for(let o of t)Op(r,o,e,n);else e[t.type.major](r,t,n)}function _u(r,t,e){let n=Ki(r,e);if(!Array.isArray(n)&&e.quickEncodeToken){let o=e.quickEncodeToken(n);if(o)return o;let s=t[n.type.major];if(s.encodedSize){let i=s.encodedSize(n,e),a=new Lo(i);if(s(a,n,e),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return No(a.chunks[0])}}return Iu.reset(),Op(Iu,n,t,e),Iu.toBytes(!0)}function _r(r,t){return t=Object.assign({},Ux,t),_u(r,Vp,t)}var Vx={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},ji=class{constructor(t,e={}){this._pos=0,this.data=t,this.options=e}pos(){return this._pos}done(){return this._pos>=this.data.length}next(){let t=this.data[this._pos],e=ve[t];if(e===void 0){let n=R[t];if(!n)throw new Error(`${V} no decoder for major type ${t>>>5} (byte 0x${t.toString(16).padStart(2,"0")})`);let o=t&31;e=n(this.data,this._pos,o,this.options)}return this._pos+=e.encodedLength,e}},Do=Symbol.for("DONE"),Gi=Symbol.for("BREAK");function Ox(r,t,e){let n=[];for(let o=0;o<r.value;o++){let s=Dn(t,e);if(s===Gi){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed array`)}if(s===Do)throw new Error(`${V} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=s}return n}function $x(r,t,e){let n=e.useMaps===!0,o=n?void 0:{},s=n?new Map:void 0;for(let i=0;i<r.value;i++){let a=Dn(t,e);if(a===Gi){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed map`)}if(a===Do)throw new Error(`${V} found map but not enough entries (got ${i} [no key], expected ${r.value})`);if(n!==!0&&typeof a!="string")throw new Error(`${V} non-string keys not supported (got ${typeof a})`);if(e.rejectDuplicateMapKeys===!0&&(n&&s.has(a)||!n&&a in o))throw new Error(`${V} found repeat map key "${a}"`);let c=Dn(t,e);if(c===Do)throw new Error(`${V} found map but not enough entries (got ${i} [no value], expected ${r.value})`);n?s.set(a,c):o[a]=c}return n?s:o}function Dn(r,t){if(r.done())return Do;let e=r.next();if(e.type===p.break)return Gi;if(e.type.terminal)return e.value;if(e.type===p.array)return Ox(e,r,t);if(e.type===p.map)return $x(e,r,t);if(e.type===p.tag){if(t.tags&&typeof t.tags[e.value]=="function"){let n=Dn(r,t);return t.tags[e.value](n)}throw new Error(`${V} tag not supported (${e.value})`)}throw new Error("unsupported")}function Tu(r,t){if(!(r instanceof Uint8Array))throw new Error(`${V} data to decode must be a Uint8Array`);t=Object.assign({},Vx,t);let e=t.tokenizer||new ji(r,t),n=Dn(e,t);if(n===Do)throw new Error(`${V} did not find any content to decode`);if(n===Gi)throw new Error(`${V} got unexpected break`);return[n,r.subarray(e.pos())]}function oe(r,t){let[e,n]=Tu(r,t);if(n.length>0)throw new Error(`${V} too many terminals, data makes no sense`);return e}var nr="/",$p=new TextEncoder().encode(nr),Wi=$p[0],Mt=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=H(t);else if(t instanceof Uint8Array)this._buf=t;else throw new Error("Invalid key, should be String of Uint8Array");if(e==null&&(e=!0),e&&this.clean(),this._buf.byteLength===0||this._buf[0]!==Wi)throw new Error("Invalid key")}toString(t="utf8"){return et(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(nr))}static random(){return new r(Math.random().toString().substring(2))}static asKey(t){return t instanceof Uint8Array||typeof t=="string"?new r(t):typeof t.uint8Array=="function"?new r(t.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=$p),this._buf[0]!==Wi){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Wi,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Wi;)this._buf=this._buf.subarray(0,-1)}less(t){let e=this.list(),n=t.list();for(let o=0;o<e.length;o++){if(n.length<o+1)return!1;let s=e[o],i=n[o];if(s<i)return!0;if(s>i)return!1}return e.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let t=this.namespaces();return t[t.length-1]}list(){return this.toString().split(nr).slice(1)}type(){return Hx(this.baseNamespace())}name(){return zx(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(nr)||(t+=nr),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(nr):new r(t.slice(0,-1).join(nr))}child(t){return this.toString()===nr?t:t.toString()===nr?this:new r(this.toString()+t.toString(),!1)}isAncestorOf(t){return t.toString()===this.toString()?!1:t.toString().startsWith(this.toString())}isDecendantOf(t){return t.toString()===this.toString()?!1:this.toString().startsWith(t.toString())}isTopLevel(){return this.list().length===1}concat(...t){return r.withNamespaces([...this.namespaces(),...Kx(t.map(e=>e.namespaces()))])}};function Hx(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function zx(r){let t=r.split(":");return t[t.length-1]}function Kx(r){return[].concat(...r)}function Zi({enumerable:r=!0,configurable:t=!1}={}){return{enumerable:r,configurable:t,writable:!1}}function*qx(r,t){if(t!=null&&typeof t=="object")if(Array.isArray(t))for(let[e,n]of t.entries()){let o=[...r,e],s=$.asCID(n);s!=null?yield[o.join("/"),s]:typeof n=="object"&&(yield*Nu(n,o))}else{let e=$.asCID(t);e!=null?yield[r.join("/"),e]:yield*Nu(t,r)}}function*Nu(r,t){if(r==null||r instanceof Uint8Array)return;let e=$.asCID(r);e!=null&&(yield[t.join("/"),e]);for(let[n,o]of Object.entries(r)){let s=[...t,n];yield*qx(s,o)}}function*jx(r,t){if(Array.isArray(t))for(let[e,n]of t.entries()){let o=[...r,e];yield o.join("/"),typeof n=="object"&&$.asCID(n)==null&&(yield*Lu(n,o))}else yield*Lu(t,r)}function*Lu(r,t){if(!(r==null||typeof r!="object"))for(let[e,n]of Object.entries(r)){let o=[...t,e];yield o.join("/"),n!=null&&!(n instanceof Uint8Array)&&typeof n=="object"&&$.asCID(n)==null&&(yield*jx(o,n))}}function Gx(r,t){let e=r;for(let[n,o]of t.entries()){if(e=e[o],e==null)throw new Error(`Object has no property at ${t.slice(0,n+1).map(i=>`[${JSON.stringify(i)}]`).join("")}`);let s=$.asCID(e);if(s!=null)return{value:s,remaining:t.slice(n+1).join("/")}}return{value:e}}var Pu=class{cid;bytes;value;asBlock;constructor({cid:t,bytes:e,value:n}){if(t==null||e==null||typeof n>"u")throw new Error("Missing required argument");this.cid=t,this.bytes=e,this.value=n,this.asBlock=this,Object.defineProperties(this,{cid:Zi(),bytes:Zi(),value:Zi(),asBlock:Zi()})}links(){return Nu(this.value,[])}tree(){return Lu(this.value,[])}get(t="/"){return Gx(this.value,t.split("/").filter(Boolean))}};function Hp({bytes:r,cid:t,value:e,codec:n}){let o=e!==void 0?e:n?.decode(r);if(o===void 0)throw new Error('Missing required argument, must either provide "value" or "codec"');return new Pu({cid:t,bytes:r,value:o})}var qp="/pin/",zp="/pinned-block/",Ru=Te,Kp=1;function Yi(r){return r.version===0&&(r=r.toV1()),new Mt(`${qp}${r.toString(Ru)}`)}var Ji=class{datastore;blockstore;getCodec;constructor(t,e,n){this.datastore=t,this.blockstore=e,this.getCodec=n}async*add(t,e={}){let n=Yi(t);if(await this.datastore.has(n))throw new Error("Already pinned");let o=Math.round(e.depth??1/0);if(o<0)throw new Error("Depth must be greater than or equal to 0");let s=new $e({concurrency:Kp});for await(let a of this.#t(t,s,{...e,depth:o}))await this.#e(a,c=>c.pinnedBy.find(u=>st(u,t.bytes))!=null?!1:(c.pinCount++,c.pinnedBy.push(t.bytes),!0),e),yield a;let i={depth:o,metadata:e.metadata??{}};await this.datastore.put(n,_r(i),e)}async*#t(t,e,n){if(n.depth===-1)return;let o=await this.getCodec(t.code),s=await this.blockstore.get(t,n),i=Hp({bytes:s,cid:t,codec:o});yield t;for await(let[,a]of i.links())yield*await e.add(async()=>this.#t(a,e,{...n,depth:n.depth-1}))}async#e(t,e,n){let o=new Mt(`${zp}${Ru.encode(t.multihash.bytes)}`),s={pinCount:0,pinnedBy:[]};try{s=oe(await this.datastore.get(o,n))}catch(a){if(a.name!=="NotFoundError")throw a}if(e(s)){if(s.pinCount===0&&await this.datastore.has(o)){await this.datastore.delete(o);return}await this.datastore.put(o,_r(s),n),n.onProgress?.(new tt("helia:pin:add",t))}}async*rm(t,e={}){let n=Yi(t),o=await this.datastore.get(n,e),s=oe(o);await this.datastore.delete(n,e);let i=new $e({concurrency:Kp});for await(let a of this.#t(t,i,{...e,depth:s.depth}))await this.#e(a,c=>(c.pinCount--,c.pinnedBy=c.pinnedBy.filter(u=>st(u,t.bytes)),!0),{...e,depth:s.depth}),yield a}async*ls(t={}){for await(let{key:e,value:n}of this.datastore.query({prefix:qp+(t.cid!=null?`${t.cid.toString(Te)}`:"")},t)){let o=$.parse(e.toString().substring(5),Te),s=oe(n);yield{cid:o,...s}}}async isPinned(t,e={}){let n=new Mt(`${zp}${Ru.encode(t.multihash.bytes)}`);return this.datastore.has(n,e)}async get(t,e){let n=Yi(t),o=await this.datastore.get(n,e);return oe(o)}async setMetadata(t,e,n){let o=Yi(t),s=await this.datastore.get(o,n),i=oe(s);i.metadata=e??{},await this.datastore.put(o,_r(i),n)}};var Uu=1,Du=5;var Fo=class extends Error{static name="InsufficientProvidersError";constructor(t="Insufficient providers found"){super(t),this.name="InsufficientProvidersError"}},Tr=class extends Error{static name="NoRoutersAvailableError";constructor(t="No routers available"){super(t),this.name="NoRoutersAvailableError"}},Mo=class extends Error{static name="UnknownHashAlgorithmError";constructor(t="Unknown hash algorithm"){super(t),this.name="UnknownHashAlgorithmError"}},Vo=class extends Error{static name="UnknownCodecError";constructor(t="Unknown codec"){super(t),this.name="UnknownCodecError"}};var Wx=5,Xi=class{log;routers;providerLookupConcurrency;constructor(t,e){this.log=t.logger.forComponent("helia:routing"),this.routers=e.routers??[],this.providerLookupConcurrency=e.providerLookupConcurrency??Wx}async start(){await lr(...this.routers)}async stop(){await fr(...this.routers)}async*findProviders(t,e={}){if(this.routers.length===0)throw new Tr("No content routers available");let n=new ss({concurrency:this.providerLookupConcurrency});n.addEventListener("error",()=>{});for await(let o of Mr(n.toGenerator(),...Xr(this.routers,"findProviders").map(s=>s.findProviders(t,e))))if(o!=null){if(o.multiaddrs.length===0){if(n.find(o.id)!=null)continue;n.add(async()=>{try{let s=await this.findPeer(o.id,e);return s.multiaddrs.length===0?null:s}catch(s){return this.log.error("could not load multiaddrs for peer %p",o.id,s),null}},{peerId:o.id,signal:e.signal}).catch(s=>{this.log.error("could not load multiaddrs for peer %p",o.id,s)})}yield o}}async provide(t,e={}){if(this.routers.length===0)throw new Tr("No content routers available");await Promise.all(Xr(this.routers,"provide").map(async n=>{await n.provide(t,e)}))}async cancelReprovide(t,e={}){await Promise.all(Xr(this.routers,"cancelReprovide").map(async n=>{await n.cancelReprovide(t,e)}))}async put(t,e,n){await Promise.all(Xr(this.routers,"put").map(async o=>{await o.put(t,e,n)}))}async get(t,e){return Promise.any(Xr(this.routers,"get").map(async n=>n.get(t,e)))}async findPeer(t,e){if(this.routers.length===0)throw new Tr("No peer routers available");let n=this,o=Mr(...Xr(this.routers,"findPeer").map(s=>async function*(){try{yield await s.findPeer(t,e)}catch(i){n.log.error(i)}}()));for await(let s of o)if(s!=null)return s;throw new Pt("Could not find peer in routing")}async*getClosestPeers(t,e={}){if(this.routers.length===0)throw new Tr("No peer routers available");for await(let n of Mr(...Xr(this.routers,"getClosestPeers").map(o=>o.getClosestPeers(t,e))))n!=null&&(yield n)}};function Xr(r,t){return r.filter(e=>e[t]!=null)}var Cr={},Fn=r=>{r.addEventListener("message",t=>{Fn.dispatchEvent("message",r,t)}),r.port!=null&&r.port.addEventListener("message",t=>{Fn.dispatchEvent("message",r,t)})};Fn.addEventListener=(r,t)=>{Cr[r]==null&&(Cr[r]=[]),Cr[r].push(t)};Fn.removeEventListener=(r,t)=>{Cr[r]!=null&&(Cr[r]=Cr[r].filter(e=>e===t))};Fn.dispatchEvent=function(r,t,e){Cr[r]!=null&&Cr[r].forEach(n=>n(t,e))};var Fu=Fn;var Mu="lock:worker:request-read",Vu="lock:worker:release-read",Ou="lock:master:grant-read",$u="lock:worker:request-write",Hu="lock:worker:release-write",zu="lock:master:grant-write";var jp=(r=21)=>Math.random().toString().substring(2);var Gp=(r,t,e,n,o)=>(s,i)=>{if(i.data.type!==e)return;let a={type:i.data.type,name:i.data.name,identifier:i.data.identifier};r.dispatchEvent(new MessageEvent(t,{data:{name:a.name,handler:async()=>{s.postMessage({type:o,name:a.name,identifier:a.identifier}),await new Promise(c=>{let u=l=>{if(l?.data==null)return;let f={type:l.data.type,name:l.data.name,identifier:l.data.identifier};f.type===n&&f.identifier===a.identifier&&(s.removeEventListener("message",u),c())};s.addEventListener("message",u)})}}}))},Wp=(r,t,e,n)=>async()=>{let o=jp();return globalThis.postMessage({type:t,identifier:o,name:r}),new Promise(s=>{let i=a=>{if(a?.data==null)return;let c={type:a.data.type,identifier:a.data.identifier};c.type===e&&c.identifier===o&&(globalThis.removeEventListener("message",i),s(()=>{globalThis.postMessage({type:n,identifier:o,name:r})}))};globalThis.addEventListener("message",i)})},Zx={singleProcess:!1},Zp=r=>{if(r=Object.assign({},Zx,r),!!globalThis.document||r.singleProcess){let e=new EventTarget;return Fu.addEventListener("message",Gp(e,"requestReadLock",Mu,Vu,Ou)),Fu.addEventListener("message",Gp(e,"requestWriteLock",$u,Hu,zu)),e}return{isWorker:!0,readLock:e=>Wp(e,Mu,Ou,Vu),writeLock:e=>Wp(e,$u,zu,Hu)}};var Qr={},Nr;async function Ku(r,t){let e,n=new Promise(o=>{e=o});return r.add(async()=>To((async()=>{await new Promise(o=>{e(()=>{o()})})})(),{milliseconds:t.timeout})),n}var Yx=(r,t)=>{if(Nr.isWorker===!0)return{readLock:Nr.readLock(r,t),writeLock:Nr.writeLock(r,t)};let e=new De({concurrency:1}),n;return{async readLock(){if(n!=null)return Ku(n,t);n=new De({concurrency:t.concurrency,autoStart:!1});let o=n,s=Ku(n,t);return e.add(async()=>{o.start(),await o.onIdle().then(()=>{n===o&&(n=null)})}),s},async writeLock(){return n=null,Ku(e,t)}}},Jx={name:"lock",concurrency:1/0,timeout:846e5,singleProcess:!1};function qu(r){let t=Object.assign({},Jx,r);return Nr==null&&(Nr=Zp(t),Nr.isWorker!==!0&&(Nr.addEventListener("requestReadLock",e=>{Qr[e.data.name]!=null&&Qr[e.data.name].readLock().then(async n=>e.data.handler().finally(()=>{n()}))}),Nr.addEventListener("requestWriteLock",async e=>{Qr[e.data.name]!=null&&Qr[e.data.name].writeLock().then(async n=>e.data.handler().finally(()=>{n()}))}))),Qr[t.name]==null&&(Qr[t.name]=Yx(t.name,t)),Qr[t.name]}var Qi=class{lock;child;pins;started;constructor(t,e,n={}){this.child=t,this.pins=e,this.lock=qu({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await lr(this.child),this.started=!0}async stop(){await fr(this.child),this.started=!1}unwrap(){return this.child}async put(t,e,n={}){n?.signal?.throwIfAborted();let o=await this.lock.readLock();try{return await this.child.put(t,e,n)}finally{o()}}async*putMany(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{yield*this.child.putMany(t,e)}finally{n()}}async get(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{return await this.child.get(t,e)}finally{n()}}async*getMany(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{yield*this.child.getMany(t,e)}finally{n()}}async delete(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.writeLock();try{if(await this.pins.isPinned(t))throw new Error("CID was pinned");await this.child.delete(t,e)}finally{n()}}async*deleteMany(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.writeLock();try{let o=this;yield*this.child.deleteMany(async function*(){for await(let s of t){if(await o.pins.isPinned(s))throw new Error("CID was pinned");yield s}}(),e)}finally{n()}}async has(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{return await this.child.has(t,e)}finally{n()}}async*getAll(t={}){t?.signal?.throwIfAborted();let e=await this.lock.readLock();try{yield*this.child.getAll(t)}finally{e()}}createSession(t,e){return e?.signal?.throwIfAborted(),this.child.createSession(t,e)}};var ju=new Mt("/version"),Yp=1;async function Jp(r){if(!await r.has(ju)){await r.put(ju,H(`${Yp}`));return}let t=await r.get(ju),e=et(t);if(parseInt(e,10)!==Yp)throw new Error("Unknown datastore version, a datastore migration may be required")}var Zu={};gt(Zu,{code:()=>Wu,decode:()=>i1,decodeOptions:()=>n1,encode:()=>s1,encodeOptions:()=>e1,name:()=>o1,toByteView:()=>Qp});var Xp=42;function Qp(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}function Xx(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let t=$.asCID(r);if(!t)return null;let e=new Uint8Array(t.bytes.byteLength+1);return e.set(t.bytes,1),[new I(p.tag,Xp),new I(p.bytes,e)]}function Qx(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function t1(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}var Gu={float64:!0,typeEncoders:{Object:Xx,undefined:Qx,number:t1}},e1={...Gu,typeEncoders:{...Gu.typeEncoders}};function r1(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return $.decode(r.subarray(1))}var ta={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};ta.tags[Xp]=r1;var n1={...ta,tags:ta.tags.slice()},o1="dag-cbor",Wu=113,s1=r=>_r(r,Gu),i1=r=>oe(Qp(r),ta);var rl={};gt(rl,{code:()=>el,decode:()=>e0,encode:()=>t0,format:()=>y1,name:()=>g1,parse:()=>x1,stringify:()=>y1});var Yu=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(t){let e=this.inRecursive[this.inRecursive.length-1];e&&(e.type===p.array&&(e.elements++,e.elements!==1&&t.push([44])),e.type===p.map&&(e.elements++,e.elements!==1&&(e.elements%2===1?t.push([44]):t.push([58]))))}[p.uint.major](t,e){this.prefix(t);let n=String(e.value),o=[];for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);t.push(o)}[p.negint.major](t,e){this[p.uint.major](t,e)}[p.bytes.major](t,e){throw new Error(`${er} unsupported type: Uint8Array`)}[p.string.major](t,e){this.prefix(t);let n=Di(JSON.stringify(e.value));t.push(n.length>32?No(n):n)}[p.array.major](t,e){this.prefix(t),this.inRecursive.push({type:p.array,elements:0}),t.push([91])}[p.map.major](t,e){this.prefix(t),this.inRecursive.push({type:p.map,elements:0}),t.push([123])}[p.tag.major](t,e){}[p.float.major](t,e){if(e.type.name==="break"){let i=this.inRecursive.pop();if(i){if(i.type===p.array)t.push([93]);else if(i.type===p.map)t.push([125]);else throw new Error("Unexpected recursive type; this should not happen!");return}throw new Error("Unexpected break; this should not happen!")}if(e.value===void 0)throw new Error(`${er} unsupported type: undefined`);if(this.prefix(t),e.type.name==="true"){t.push([116,114,117,101]);return}else if(e.type.name==="false"){t.push([102,97,108,115,101]);return}else if(e.type.name==="null"){t.push([110,117,108,108]);return}let n=String(e.value),o=[],s=!1;for(let i=0;i<n.length;i++)o[i]=n.charCodeAt(i),!s&&(o[i]===46||o[i]===101||o[i]===69)&&(s=!0);s||(o.push(46),o.push(48)),t.push(o)}};function a1(r,t){if(Array.isArray(r[0])||Array.isArray(t[0]))throw new Error(`${er} complex map keys are not supported`);let e=r[0],n=t[0];if(e.type!==p.string||n.type!==p.string)throw new Error(`${er} non-string map keys are not supported`);if(e<n)return-1;if(e>n)return 1;throw new Error(`${er} unexpected duplicate map keys, this is not supported`)}var c1={addBreakTokens:!0,mapSorter:a1};function Ju(r,t){return t=Object.assign({},c1,t),_u(r,new Yu,t)}var Mn=class{constructor(t,e={}){this._pos=0,this.data=t,this.options=e,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 t=this.ch();for(;t===32||t===9||t===13||t===10;)t=this.data[++this._pos]}expect(t){if(this.data.length-this._pos<t.length)throw new Error(`${V} unexpected end of input at position ${this._pos}`);for(let e=0;e<t.length;e++)if(this.data[this._pos++]!==t[e])throw new Error(`${V} unexpected token at position ${this._pos}, expected to find '${String.fromCharCode(...t)}'`)}parseNumber(){let t=this._pos,e=!1,n=!1,o=a=>{for(;!this.done();){let c=this.ch();if(a.includes(c))this._pos++;else break}};if(this.ch()===45&&(e=!0,this._pos++),this.ch()===48)if(this._pos++,this.ch()===46)this._pos++,n=!0;else return new I(p.uint,0,this._pos-t);if(o([48,49,50,51,52,53,54,55,56,57]),e&&this._pos===t+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++,o([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++,o([48,49,50,51,52,53,54,55,56,57]));let s=String.fromCharCode.apply(null,this.data.subarray(t,this._pos)),i=parseFloat(s);return n?new I(p.float,i,this._pos-t):this.options.allowBigInt!==!0||Number.isSafeInteger(i)?new I(i>=0?p.uint:p.negint,i,this._pos-t):new I(i>=0?p.uint:p.negint,BigInt(s),this._pos-t)}parseString(){if(this.ch()!==34)throw new Error(`${V} unexpected character at position ${this._pos}; this shouldn't happen`);this._pos++;for(let s=this._pos,i=0;s<this.data.length&&i<65536;s++,i++){let a=this.data[s];if(a===92||a<32||a>=128)break;if(a===34){let c=String.fromCharCode.apply(null,this.data.subarray(this._pos,s));return this._pos=s+1,new I(p.string,c,i)}}let t=this._pos,e=[],n=()=>{if(this._pos+4>=this.data.length)throw new Error(`${V} unexpected end of unicode escape sequence at position ${this._pos}`);let s=0;for(let i=0;i<4;i++){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}`);s=s*16+a,this._pos++}return s},o=()=>{let s=this.ch(),i=null,a=s>239?4:s>223?3:s>191?2:1;if(this._pos+a>this.data.length)throw new Error(`${V} unexpected unicode sequence at position ${this._pos}`);let c,u,l,f;switch(a){case 1:s<128&&(i=s);break;case 2:c=this.data[this._pos+1],(c&192)===128&&(f=(s&31)<<6|c&63,f>127&&(i=f));break;case 3:c=this.data[this._pos+1],u=this.data[this._pos+2],(c&192)===128&&(u&192)===128&&(f=(s&15)<<12|(c&63)<<6|u&63,f>2047&&(f<55296||f>57343)&&(i=f));break;case 4:c=this.data[this._pos+1],u=this.data[this._pos+2],l=this.data[this._pos+3],(c&192)===128&&(u&192)===128&&(l&192)===128&&(f=(s&15)<<18|(c&63)<<12|(u&63)<<6|l&63,f>65535&&f<1114112&&(i=f))}i===null?(i=65533,a=1):i>65535&&(i-=65536,e.push(i>>>10&1023|55296),i=56320|i&1023),e.push(i),this._pos+=a};for(;!this.done();){let s=this.ch(),i;switch(s){case 92:if(this._pos++,this.done())throw new Error(`${V} unexpected string termination at position ${this._pos}`);switch(i=this.ch(),this._pos++,i){case 34:case 39:case 92:case 47:e.push(i);break;case 98:e.push(8);break;case 116:e.push(9);break;case 110:e.push(10);break;case 102:e.push(12);break;case 114:e.push(13);break;case 117:e.push(n());break;default:throw new Error(`${V} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new I(p.string,Eu(e),this._pos-t);default:if(s<32)throw new Error(`${V} invalid control character at position ${this._pos}`);s<128?(e.push(s),this._pos++):o()}}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 I(p.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new I(p.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new I(p.null,null,4);case 102:return this.expect([102,97,108,115,101]),new I(p.false,!1,5);case 116:return this.expect([116,114,117,101]),new I(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 I(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 I(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 I(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 I(p.break,void 0,1);let t=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"),t}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 Xu(r,t){return t=Object.assign({tokenizer:new Mn(r,t)},t),oe(r,t)}function l1(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}function f1(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let t=$.asCID(r);if(!t)return null;let e=t.toString();return[new I(p.map,1/0,1),new I(p.string,"/",1),new I(p.string,e,e.length),new I(p.break,void 0,1)]}function ea(r){let t=Ce.encode(r).slice(1);return[new I(p.map,1/0,1),new I(p.string,"/",1),new I(p.map,1/0,1),new I(p.string,"bytes",5),new I(p.string,t,t.length),new I(p.break,void 0,1),new I(p.break,void 0,1)]}function Ee(r){return ea(new Uint8Array(r.buffer,r.byteOffset,r.byteLength))}function h1(r){return ea(new Uint8Array(r))}function d1(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function p1(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}var m1={typeEncoders:{Object:f1,Buffer:ea,Uint8Array:ea,Int8Array:Ee,Uint16Array:Ee,Int16Array:Ee,Uint32Array:Ee,Int32Array:Ee,Float32Array:Ee,Float64Array:Ee,Uint8ClampedArray:Ee,BigInt64Array:Ee,BigUint64Array:Ee,DataView:Ee,ArrayBuffer:h1,undefined:d1,number:p1}},Qu=class extends Mn{constructor(t,e){super(t,e),this.tokenBuffer=[]}done(){return this.tokenBuffer.length===0&&super.done()}_next(){return this.tokenBuffer.length>0?this.tokenBuffer.pop():super.next()}next(){let t=this._next();if(t.type===p.map){let e=this._next();if(e.type===p.string&&e.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 I(p.tag,42,0)}if(n.type===p.map){let o=this._next();if(o.type===p.string&&o.value==="bytes"){let s=this._next();if(s.type===p.string){for(let a=0;a<2;a++)if(this._next().type!==p.break)throw new Error("Invalid encoded Bytes form");let i=Ce.decode(`m${s.value}`);return new I(p.bytes,i,s.value.length)}this.tokenBuffer.push(s)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(e)}return t}},tl={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};tl.tags[42]=$.parse;var g1="dag-json",el=297,t0=r=>Ju(r,m1),e0=r=>{let t=l1(r),e=Object.assign(tl,{tokenizer:new Qu(t,tl)});return Xu(t,e)},y1=r=>w1.decode(t0(r));var w1=new TextDecoder,x1=r=>e0(b1.encode(r)),b1=new TextEncoder;var cl={};gt(cl,{code:()=>al,createLink:()=>f0,createNode:()=>l0,decode:()=>P1,encode:()=>L1,name:()=>N1,prepare:()=>sl,validate:()=>il});var v1=new TextDecoder;function nl(r,t){let e=0;for(let n=0;;n+=7){if(n>=64)throw new Error("protobuf: varint overflow");if(t>=r.length)throw new Error("protobuf: unexpected end of data");let o=r[t++];if(e+=n<28?(o&127)<<n:(o&127)*2**n,o<128)break}return[e,t]}function ra(r,t){let e;[e,t]=nl(r,t);let n=t+e;if(e<0||n<0)throw new Error("protobuf: invalid length");if(n>r.length)throw new Error("protobuf: unexpected end of data");return[r.subarray(t,n),n]}function r0(r,t){let e;return[e,t]=nl(r,t),[e&7,e>>3,t]}function E1(r){let t={},e=r.length,n=0;for(;n<e;){let o,s;if([o,s,n]=r0(r,n),s===1){if(t.Hash)throw new Error("protobuf: (PBLink) duplicate Hash section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Hash`);if(t.Name!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Name before Hash");if(t.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Hash");[t.Hash,n]=ra(r,n)}else if(s===2){if(t.Name!==void 0)throw new Error("protobuf: (PBLink) duplicate Name section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Name`);if(t.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Name");let i;[i,n]=ra(r,n),t.Name=v1.decode(i)}else if(s===3){if(t.Tsize!==void 0)throw new Error("protobuf: (PBLink) duplicate Tsize section");if(o!==0)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Tsize`);[t.Tsize,n]=nl(r,n)}else throw new Error(`protobuf: (PBLink) invalid fieldNumber, expected 1, 2 or 3, got ${s}`)}if(n>e)throw new Error("protobuf: (PBLink) unexpected end of data");return t}function n0(r){let t=r.length,e=0,n,o=!1,s;for(;e<t;){let a,c;if([a,c,e]=r0(r,e),a!==2)throw new Error(`protobuf: (PBNode) invalid wireType, expected 2, got ${a}`);if(c===1){if(s)throw new Error("protobuf: (PBNode) duplicate Data section");[s,e]=ra(r,e),n&&(o=!0)}else if(c===2){if(o)throw new Error("protobuf: (PBNode) duplicate Links section");n||(n=[]);let u;[u,e]=ra(r,e),n.push(E1(u))}else throw new Error(`protobuf: (PBNode) invalid fieldNumber, expected 1 or 2, got ${c}`)}if(e>t)throw new Error("protobuf: (PBNode) unexpected end of data");let i={};return s&&(i.Data=s),i.Links=n||[],i}var s0=new TextEncoder,o0=2**32,A1=2**31;function S1(r,t){let e=t.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");e=Oo(t,e,r.Tsize)-1,t[e]=24}if(typeof r.Name=="string"){let n=s0.encode(r.Name);e-=n.length,t.set(n,e),e=Oo(t,e,n.length)-1,t[e]=18}return r.Hash&&(e-=r.Hash.length,t.set(r.Hash,e),e=Oo(t,e,r.Hash.length)-1,t[e]=10),t.length-e}function i0(r){let t=k1(r),e=new Uint8Array(t),n=t;if(r.Data&&(n-=r.Data.length,e.set(r.Data,n),n=Oo(e,n,r.Data.length)-1,e[n]=10),r.Links)for(let o=r.Links.length-1;o>=0;o--){let s=S1(r.Links[o],e.subarray(0,n));n-=s,n=Oo(e,n,s)-1,e[n]=18}return e}function B1(r){let t=0;if(r.Hash){let e=r.Hash.length;t+=1+e+Vn(e)}if(typeof r.Name=="string"){let e=s0.encode(r.Name).length;t+=1+e+Vn(e)}return typeof r.Tsize=="number"&&(t+=1+Vn(r.Tsize)),t}function k1(r){let t=0;if(r.Data){let e=r.Data.length;t+=1+e+Vn(e)}if(r.Links)for(let e of r.Links){let n=B1(e);t+=1+n+Vn(n)}return t}function Oo(r,t,e){t-=Vn(e);let n=t;for(;e>=A1;)r[t++]=e&127|128,e/=128;for(;e>=128;)r[t++]=e&127|128,e>>>=7;return r[t]=e,n}function Vn(r){return r%2===0&&r++,Math.floor((I1(r)+6)/7)}function I1(r){let t=0;return r>=o0&&(r=Math.floor(r/o0),t=32),r>=65536&&(r>>>=16,t+=16),r>=256&&(r>>>=8,t+=8),t+_1[r]}var _1=[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 T1=["Data","Links"],C1=["Hash","Name","Tsize"],ol=new TextEncoder;function c0(r,t){if(r===t)return 0;let e=r.Name?ol.encode(r.Name):[],n=t.Name?ol.encode(t.Name):[],o=e.length,s=n.length;for(let i=0,a=Math.min(o,s);i<a;++i)if(e[i]!==n[i]){o=e[i],s=n[i];break}return o<s?-1:s<o?1:0}function a0(r,t){return!Object.keys(r).some(e=>!t.includes(e))}function u0(r){if(typeof r.asCID=="object"){let e=$.asCID(r);if(!e)throw new TypeError("Invalid DAG-PB form");return{Hash:e}}if(typeof r!="object"||Array.isArray(r))throw new TypeError("Invalid DAG-PB form");let t={};if(r.Hash){let e=$.asCID(r.Hash);try{e||(typeof r.Hash=="string"?e=$.parse(r.Hash):r.Hash instanceof Uint8Array&&(e=$.decode(r.Hash)))}catch(n){throw new TypeError(`Invalid DAG-PB form: ${n.message}`)}e&&(t.Hash=e)}if(!t.Hash)throw new TypeError("Invalid DAG-PB form");return typeof r.Name=="string"&&(t.Name=r.Name),typeof r.Tsize=="number"&&(t.Tsize=r.Tsize),t}function sl(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 t={};if(r.Data!==void 0)if(typeof r.Data=="string")t.Data=ol.encode(r.Data);else if(r.Data instanceof Uint8Array)t.Data=r.Data;else throw new TypeError("Invalid DAG-PB form");if(r.Links!==void 0)if(Array.isArray(r.Links))t.Links=r.Links.map(u0),t.Links.sort(c0);else throw new TypeError("Invalid DAG-PB form");else t.Links=[];return t}function il(r){if(!r||typeof r!="object"||Array.isArray(r)||r instanceof Uint8Array||r["/"]&&r["/"]===r.bytes)throw new TypeError("Invalid DAG-PB form");if(!a0(r,T1))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 t=0;t<r.Links.length;t++){let e=r.Links[t];if(!e||typeof e!="object"||Array.isArray(e)||e instanceof Uint8Array||e["/"]&&e["/"]===e.bytes)throw new TypeError("Invalid DAG-PB form (bad link)");if(!a0(e,C1))throw new TypeError("Invalid DAG-PB form (extraneous properties on link)");if(e.Hash===void 0)throw new TypeError("Invalid DAG-PB form (link must have a Hash)");if(e.Hash==null||!e.Hash["/"]||e.Hash["/"]!==e.Hash.bytes)throw new TypeError("Invalid DAG-PB form (link Hash must be a CID)");if(e.Name!==void 0&&typeof e.Name!="string")throw new TypeError("Invalid DAG-PB form (link Name must be a string)");if(e.Tsize!==void 0){if(typeof e.Tsize!="number"||e.Tsize%1!==0)throw new TypeError("Invalid DAG-PB form (link Tsize must be an integer)");if(e.Tsize<0)throw new TypeError("Invalid DAG-PB form (link Tsize cannot be negative)")}if(t>0&&c0(e,r.Links[t-1])===-1)throw new TypeError("Invalid DAG-PB form (links must be sorted by Name bytes)")}}function l0(r,t=[]){return sl({Data:r,Links:t})}function f0(r,t,e){return u0({Hash:e,Name:r,Tsize:t})}function h0(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var N1="dag-pb",al=112;function L1(r){il(r);let t={};return r.Links&&(t.Links=r.Links.map(e=>{let n={};return e.Hash&&(n.Hash=e.Hash.bytes),e.Name!==void 0&&(n.Name=e.Name),e.Tsize!==void 0&&(n.Tsize=e.Tsize),n})),r.Data&&(t.Data=r.Data),i0(t)}function P1(r){let t=h0(r),e=n0(t),n={};return e.Data&&(n.Data=e.Data),e.Links&&(n.Links=e.Links.map(o=>{let s={};try{s.Hash=$.decode(o.Hash)}catch{}if(!s.Hash)throw new Error("Invalid Hash field found in link, expected CID");return o.Name!==void 0&&(s.Name=o.Name),o.Tsize!==void 0&&(s.Tsize=o.Tsize),s})),n}function On(r){return r?.then!=null}function d0(r=[],t){let e={[al]:cl,[Jn]:Xn,[Wu]:Zu,[el]:rl,[pc]:cs};return r.forEach(n=>{e[n.code]=n}),async n=>{let o=e[n];if(o==null&&t!=null){let s=t(n);On(s)?o=await s:o=s,e[o.code]=o}if(o!=null)return o;throw new Vo(`Could not load codec for ${n}`)}}function p0(r=[],t){let e={[pr.code]:pr,[ls.code]:ls,[jt.code]:jt};return r.forEach(n=>{e[n.code]=n}),async n=>{let o=e[n];if(o==null&&t!=null){let s=t(n);On(s)?o=await s:o=s,e[o.code]=o}if(o!=null)return o;throw new Mo(`No hasher configured for multihash code 0x${n.toString(16)}, please configure one. You can look up which hash this is at https://github.com/multiformats/multicodec/blob/master/table.csv`)}}var ce=class r extends Error{static name="NotFoundError";static code="ERR_NOT_FOUND";name=r.name;code=r.code;constructor(t="Not Found"){super(t)}};var or=class{has(t,e){return Promise.reject(new Error(".has is not implemented"))}put(t,e,n){return Promise.reject(new Error(".put is not implemented"))}async*putMany(t,e){for await(let{cid:n,block:o}of t)await this.put(n,o,e),yield n}get(t,e){return Promise.reject(new Error(".get is not implemented"))}async*getMany(t,e){for await(let n of t)yield{cid:n,block:await this.get(n,e)}}delete(t,e){return Promise.reject(new Error(".delete is not implemented"))}async*deleteMany(t,e){for await(let n of t)await this.delete(n,e),yield n}async*getAll(t){throw new Error(".getAll is not implemented")}};var na=0,oa=class extends or{child;constructor(t){super(),this.child=t}put(t,e){return t.multihash.code===na||this.child==null?t:this.child.put(t,e)}get(t){if(t.multihash.code===na)return t.multihash.digest;if(this.child==null)throw new ce;return this.child.get(t)}has(t){return t.multihash.code===na?!0:this.child==null?!1:this.child.has(t)}delete(t){if(t.code!==na&&this.child!=null)return this.child.delete(t)}getAll(t){return this.child!=null?this.child.getAll(t):[]}};function R1(r){return r[Symbol.asyncIterator]!=null}function U1(r,t){let e=0;if(R1(r))return async function*(){for await(let c of r)await t(c,e++)&&(yield c)}();let n=un(r),{value:o,done:s}=n.next();if(s===!0)return function*(){}();let i=t(o,e++);if(typeof i.then=="function")return async function*(){await i&&(yield o);for await(let c of n)await t(c,e++)&&(yield c)}();let a=t;return function*(){i===!0&&(yield o);for(let c of n)a(c,e++)&&(yield c)}()}var Ae=U1;function D1(r){return r[Symbol.asyncIterator]!=null}function m0(r){return r?.then!=null}function F1(r,t){let e=0;if(D1(r))return async function*(){for await(let c of r){let u=t(c,e++);m0(u)&&await u,yield c}}();let n=un(r),{value:o,done:s}=n.next();if(s===!0)return function*(){}();if(typeof t(o,e++)?.then=="function")return async function*(){yield o;for await(let c of n){let u=t(c,e++);m0(u)&&await u,yield c}}();let a=t;return function*(){yield o;for(let c of n)a(c,e++),yield c}()}var ul=F1;var sa=class{child;getHasher;log;logger;components;constructor(t){this.log=t.logger.forComponent("helia:networked-storage"),this.logger=t.logger,this.components=t,this.child=new oa(t.blockstore),this.getHasher=t.getHasher}async put(t,e,n={}){return await this.child.has(t,n)?(n.onProgress?.(new tt("blocks:put:duplicate",t)),t):(n.onProgress?.(new tt("blocks:put:providers:notify",t)),await Promise.all(this.components.blockBrokers.map(async o=>o.announce?.(t,e,n))),n.onProgress?.(new tt("blocks:put:blockstore:put",t)),this.child.put(t,e,n))}async*putMany(t,e={}){let n=Ae(t,async({cid:s})=>{let i=await this.child.has(s,e);return i&&e.onProgress?.(new tt("blocks:put-many:duplicate",s)),!i}),o=ul(n,async({cid:s,block:i})=>{e.onProgress?.(new tt("blocks:put-many:providers:notify",s)),await Promise.all(this.components.blockBrokers.map(async a=>a.announce?.(s,i,e)))});e.onProgress?.(new tt("blocks:put-many:blockstore:put-many")),yield*this.child.putMany(o,e)}async get(t,e={}){if(e.offline!==!0&&!await this.child.has(t,e)){let n=await this.getHasher(t.multihash.code);e.onProgress?.(new tt("blocks:get:providers:get",t));let o=await g0(t,this.components.blockBrokers,n,{...e,log:this.log});return e.onProgress?.(new tt("blocks:get:blockstore:put",t)),await this.child.put(t,o,e),e.onProgress?.(new tt("blocks:get:providers:notify",t)),await Promise.all(this.components.blockBrokers.map(async s=>s.announce?.(t,o,e))),o}return e.onProgress?.(new tt("blocks:get:blockstore:get",t)),this.child.get(t,e)}async*getMany(t,e={}){e.onProgress?.(new tt("blocks:get-many:blockstore:get-many")),yield*this.child.getMany(ul(t,async n=>{if(e.offline!==!0&&!await this.child.has(n,e)){let o=await this.getHasher(n.multihash.code);e.onProgress?.(new tt("blocks:get-many:providers:get",n));let s=await g0(n,this.components.blockBrokers,o,{...e,log:this.log});e.onProgress?.(new tt("blocks:get-many:blockstore:put",n)),await this.child.put(n,s,e),e.onProgress?.(new tt("blocks:get-many:providers:notify",n)),await Promise.all(this.components.blockBrokers.map(async i=>i.announce?.(n,s,e)))}}))}async delete(t,e={}){e.onProgress?.(new tt("blocks:delete:blockstore:delete",t)),await this.child.delete(t,e)}async*deleteMany(t,e={}){e.onProgress?.(new tt("blocks:delete-many:blockstore:delete-many")),yield*this.child.deleteMany(async function*(){for await(let n of t)yield n}(),e)}async has(t,e={}){return this.child.has(t,e)}async*getAll(t={}){t.onProgress?.(new tt("blocks:get-all:blockstore:get-many")),yield*this.child.getAll(t)}},ia=class extends sa{started;constructor(t){super(t),this.started=!1}isStarted(){return this.started}async start(){await lr(this.child,...this.components.blockBrokers),this.started=!0}async stop(){await fr(this.child,...this.components.blockBrokers),this.started=!1}unwrap(){return this.child}createSession(t,e){let n=this.components.blockBrokers.map(o=>o.createSession==null?o:o.createSession(e));return new ll({blockstore:this.child,blockBrokers:n,getHasher:this.getHasher,logger:this.logger},{root:t})}},ll=class extends sa{closeController;constructor(t,e){super(t),this.closeController=new AbortController,ht(1/0,this.closeController.signal),this.log=t.logger.forComponent(`helia:session-storage:${e.root}`)}close(){this.closeController.abort()}async put(t,e,n={}){let o=$t([this.closeController.signal,n.signal]);ht(1/0,o);try{return await super.put(t,e,{...n,signal:o})}finally{o.clear()}}async*putMany(t,e={}){let n=$t([this.closeController.signal,e.signal]);ht(1/0,n);try{yield*super.putMany(t,{...e,signal:n})}finally{n.clear()}}async get(t,e={}){let n=$t([this.closeController.signal,e.signal]);ht(1/0,n);try{return await super.get(t,{...e,signal:n})}finally{n.clear()}}async*getMany(t,e={}){let n=$t([this.closeController.signal,e.signal]);ht(1/0,n);try{yield*super.getMany(t,{...e,signal:n})}finally{n.clear()}}async delete(t,e={}){let n=$t([this.closeController.signal,e.signal]);ht(1/0,n);try{await super.delete(t,{...e,signal:n})}finally{n.clear()}}async*deleteMany(t,e={}){let n=$t([this.closeController.signal,e.signal]);ht(1/0,n);try{yield*super.deleteMany(t,{...e,signal:n})}finally{n.clear()}}async has(t,e={}){let n=$t([this.closeController.signal,e.signal]);ht(1/0,n);try{return await super.has(t,{...e,signal:n})}finally{n.clear()}}async*getAll(t={}){let e=$t([this.closeController.signal,t.signal]);ht(1/0,e);try{yield*super.getAll({...t,signal:e})}finally{e.clear()}}};function M1(r){return typeof r.retrieve=="function"}var V1=(r,t)=>{if(t==null)throw new Et(`No hasher configured for multihash code 0x${r.multihash.code.toString(16)}, please configure one. You can look up which hash this is at https://github.com/multiformats/multicodec/blob/master/table.csv`);return async e=>{let n,o=t.digest(e);if(On(o)?n=await o:n=o,!st(n.digest,r.multihash.digest))throw new ur("Hash of downloaded block did not match multihash from passed CID")}};async function g0(r,t,e,n){let o=V1(r,e),s=new AbortController,i=$t([s.signal,n.signal]);ht(1/0,s.signal,i);let a=[];for(let c of t)M1(c)&&a.push(c);try{return await Promise.any(a.map(async c=>{try{let u=!1,l=await c.retrieve(r,{...n,signal:i,validateFn:async f=>{await o(f),u=!0}});return u||await o(l),l}catch(u){throw n.log.error("could not retrieve verified block for %c",r,u),u}}))}finally{s.abort(),i.clear()}}var $o=class extends sn{intialPeerSearchComplete;requests;name;log;logger;minProviders;maxProviders;providers;evictionFilter;constructor(t,e){super(),ht(1/0,this),this.name=e.name,this.logger=t.logger,this.log=t.logger.forComponent(this.name),this.requests=new Map,this.minProviders=e.minProviders??1,this.maxProviders=e.maxProviders??5,this.providers=[],this.evictionFilter=du(this.maxProviders)}async retrieve(t,e={}){let n=Ce.encode(t.multihash.bytes),o=this.requests.get(n);if(o!=null)return this.log("join existing request for %c",t),o;let s=At();if(this.requests.set(n,s.promise),this.providers.length===0){let u=!1;this.intialPeerSearchComplete==null&&(u=!0,this.log=this.logger.forComponent(`${this.name}:${t}`),this.intialPeerSearchComplete=this.findProviders(t,this.minProviders,e)),await this.intialPeerSearchComplete,u&&this.log("found initial session peers for %c",t)}let i=!1,a=new $e({concurrency:this.maxProviders});a.addEventListener("error",()=>{}),a.addEventListener("failure",u=>{this.log.error("error querying provider %o, evicting from session",u.detail.job.options.provider,u.detail.error),this.evict(u.detail.job.options.provider)}),a.addEventListener("success",u=>{i=!0,s.resolve(u.detail.result)}),a.addEventListener("idle",()=>{i||e.signal?.aborted===!0||Promise.resolve().then(async()=>{this.log("no session peers had block for for %c, finding new providers",t);for(let u=0;u<this.minProviders&&this.providers.length!==0;u++){let l=this.providers[Math.floor(Math.random()*this.providers.length)];this.evict(l)}await this.findProviders(t,this.minProviders,e),this.log("found new providers re-retrieving %c",t),this.requests.delete(n),s.resolve(await this.retrieve(t,e))}).catch(u=>{this.log.error("could not find new providers for %c",t,u),s.reject(u)})});let c=u=>{a.add(async()=>this.queryProvider(t,u.detail,e),{provider:u.detail}).catch(l=>{e.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c",t,l)})};this.addEventListener("provider",c),Promise.all([...this.providers].map(async u=>a.add(async()=>this.queryProvider(t,u,e),{provider:u}))).catch(u=>{e.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c",t,u)});try{return await s.promise}finally{this.removeEventListener("provider",c),a.clear(),this.requests.delete(n)}}evict(t){this.evictionFilter.add(this.toEvictionKey(t));let e=this.providers.findIndex(n=>this.equals(n,t));e!==-1&&this.providers.splice(e,1)}isEvicted(t){return this.evictionFilter.has(this.toEvictionKey(t))}hasProvider(t){return!!(this.providers.find(e=>this.equals(e,t))!=null||this.isEvicted(t))}async findProviders(t,e,n){let o=At(),s=0;return Promise.resolve().then(async()=>{this.log("finding %d-%d new provider(s) for %c",e,this.maxProviders,t);for await(let i of this.findNewProviders(t,n)){if(s===this.maxProviders||n.signal?.aborted===!0)break;if(!this.hasProvider(i)&&(this.log("found %d/%d new providers",s,this.maxProviders),this.providers.push(i),this.safeDispatchEvent("provider",{detail:i}),s++,s===e&&(this.log("session is ready"),o.resolve()),this.providers.length===this.maxProviders)){this.log("found max session peers",s);break}}if(this.log("found %d/%d new session peers",s,this.maxProviders),s<e)throw new Fo(`Found ${s} of ${e} ${this.name} providers for ${t}`)}).catch(i=>{this.log.error("error searching routing for potential session peers for %c",t,i.errors??i),o.reject(i)}),o.promise}};var aa=class{blockstore;datastore;pins;logger;routing;getCodec;getHasher;dns;metrics;log;constructor(t){this.logger=t.logger??Id(),this.log=this.logger.forComponent("helia"),this.getHasher=p0(t.hashers,t.loadHasher),this.getCodec=d0(t.codecs,t.loadCodec),this.dns=t.dns??Fd(),this.metrics=t.metrics;let e={blockstore:t.blockstore,datastore:t.datastore,logger:this.logger,blockBrokers:[],getHasher:this.getHasher,getCodec:this.getCodec,dns:this.dns,metrics:this.metrics,...t.components??{}};this.routing=e.routing=new Xi(e,{routers:(t.routers??[]).flatMap(o=>{let s=[o];return o[Zn]!=null&&s.push(o[Zn]),o[Yn]!=null&&s.push(o[Yn]),s}),providerLookupConcurrency:t.providerLookupConcurrency});let n=new ia(e);this.pins=new Ji(t.datastore,n,this.getCodec),this.blockstore=new Qi(n,this.pins,{holdGcLock:t.holdGcLock??!0}),this.datastore=t.datastore,e.blockBrokers=t.blockBrokers.map(o=>o(e))}async start(){await Jp(this.datastore),await lr(this.blockstore,this.datastore,this.routing)}async stop(){await fr(this.blockstore,this.datastore,this.routing)}async gc(t={}){let e=await this.blockstore.lock.writeLock();try{let n=this,o=this.blockstore.unwrap();this.log("gc start"),await Dr(o.deleteMany(async function*(){for await(let{cid:s}of o.getAll())try{if(await n.pins.isPinned(s,t))continue;yield s,t.onProgress?.(new tt("helia:gc:deleted",s))}catch(i){n.log.error("Error during gc",i),t.onProgress?.(new tt("helia:gc:error",i))}}()))}finally{e()}this.log("gc finished")}};var ca=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",u=2**(8*o)-1;for(;;){let l=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let d=Number.parseInt(f,t);if(!Number.isNaN(d))return d});if(l===void 0)break;if(s*=t,s+=l,s>u||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&c&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let o=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[o]=i[0],e[o+1]=i[1],e[o+2]=i[2],e[o+3]=i[3],[o+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[o,!1];e[o]=s>>8,e[o+1]=s&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,o]=t(e);if(n===16)return e;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=t(s.subarray(0,i));return e.set(s.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var y0=45,O1=15,$n=new ca;function fl(r){if(!(r.length>O1))return $n.new(r).parseWith(()=>$n.readIPv4Addr())}function hl(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>y0))return $n.new(r).parseWith(()=>$n.readIPv6Addr())}function ua(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>y0))return $n.new(r).parseWith(()=>$n.readIPAddr())}function Hn(r){return!!fl(r)}function zn(r){return!!hl(r)}function la(r){return!!ua(r)}var x0=Rr(w0(),1),$1=["0.0.0.0/8","10.0.0.0/8","100.64.0.0/10","127.0.0.0/8","169.254.0.0/16","172.16.0.0/12","192.0.0.0/24","192.0.0.0/29","192.0.0.8/32","192.0.0.9/32","192.0.0.10/32","192.0.0.170/32","192.0.0.171/32","192.0.2.0/24","192.31.196.0/24","192.52.193.0/24","192.88.99.0/24","192.168.0.0/16","192.175.48.0/24","198.18.0.0/15","198.51.100.0/24","203.0.113.0/24","240.0.0.0/4","255.255.255.255/32"],H1=$1.map(r=>new x0.Netmask(r));function dl(r){for(let t of H1)if(t.contains(r))return!0;return!1}function z1(r){return/^::ffff:([0-9a-fA-F]{1,4}):([0-9a-fA-F]{1,4})$/.test(r)}function K1(r){let t=r.split(":");if(t.length<2)return!1;let e=t[t.length-1].padStart(4,"0"),n=t[t.length-2].padStart(4,"0"),o=`${parseInt(n.substring(0,2),16)}.${parseInt(n.substring(2),16)}.${parseInt(e.substring(0,2),16)}.${parseInt(e.substring(2),16)}`;return dl(o)}function q1(r){return/^::ffff:([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)}function j1(r){let t=r.split(":"),e=t[t.length-1];return dl(e)}function G1(r){return/^::$/.test(r)||/^::1$/.test(r)||/^64:ff9b::([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)||/^100::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001:2[0-9a-fA-F]:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001:db8:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2002:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^f[c-d]([0-9a-fA-F]{2,2}):/i.test(r)||/^fe[8-9a-bA-B][0-9a-fA-F]:/i.test(r)||/^ff([0-9a-fA-F]{2,2}):/i.test(r)}function b0(r){return Hn(r)?dl(r):z1(r)?K1(r):q1(r)?j1(r):zn(r)?G1(r):void 0}var W1=r=>r.toString().split("/").slice(1),Kn=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),J=r=>({match:t=>Kn(e=>e===r).match(t),pattern:r}),tn=()=>({match:r=>Kn(t=>typeof t=="string").match(r),pattern:"{string}"}),zo=()=>({match:r=>Kn(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),ct=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{it.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),Ko=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{lc.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),rt=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),Vt=(...r)=>({match:t=>{let e;for(let n of r){let o=n.match(t);o!==!1&&(e==null||o.length<e.length)&&(e=o)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),X=(...r)=>({match:t=>{for(let e of r){let n=e.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${r.map(t=>t.pattern).join(", ")})`});function pt(...r){function t(o){let s=W1(o);for(let i of r){let a=i.match(s);if(a===!1)return!1;s=a}return s}function e(o){return t(o)!==!1}function n(o){let s=t(o);return s===!1?!1:s.length===0}return{matchers:r,matches:e,exactMatch:n}}var ha=X(J("dns4"),tn()),da=X(J("dns6"),tn()),pa=X(J("dnsaddr"),tn()),ml=X(J("dns"),tn()),$3=pt(ha,rt(ct())),H3=pt(da,rt(ct())),z3=pt(pa,rt(ct())),v0=pt(Vt(ml,pa,ha,da),rt(ct())),E0=X(J("ip4"),Kn(Hn)),A0=X(J("ip6"),Kn(zn)),gl=Vt(E0,A0),sr=Vt(gl,ml,ha,da,pa),K3=pt(Vt(gl,X(Vt(ml,pa,ha,da),rt(ct())))),q3=pt(E0),j3=pt(A0),G3=pt(gl),yl=X(sr,J("tcp"),zo()),qo=X(sr,J("udp"),zo()),W3=pt(X(yl,rt(ct()))),Z3=pt(qo),wl=X(qo,J("quic"),rt(ct())),ma=X(qo,J("quic-v1"),rt(ct())),Z1=Vt(wl,ma),Y3=pt(wl),J3=pt(ma),pl=Vt(sr,yl,qo,wl,ma),S0=Vt(X(pl,J("ws"),rt(ct()))),X3=pt(S0),B0=Vt(X(pl,J("wss"),rt(ct())),X(pl,J("tls"),rt(X(J("sni"),tn())),J("ws"),rt(ct()))),Q3=pt(B0),k0=X(qo,J("webrtc-direct"),rt(Ko()),rt(Ko()),rt(ct())),tk=pt(k0),I0=X(ma,J("webtransport"),rt(Ko()),rt(Ko()),rt(ct())),ek=pt(I0),fa=Vt(S0,B0,X(yl,rt(ct())),X(Z1,rt(ct())),X(sr,rt(ct())),k0,I0,ct()),rk=pt(fa),Y1=X(fa,J("p2p-circuit"),ct()),nk=pt(Y1),J1=Vt(X(fa,J("p2p-circuit"),J("webrtc"),rt(ct())),X(fa,J("webrtc"),rt(ct())),X(J("webrtc"),rt(ct()))),ok=pt(J1),X1=Vt(X(sr,J("tcp"),zo(),J("http"),rt(ct())),X(sr,J("http"),rt(ct()))),_0=pt(X1),Q1=Vt(X(sr,J("tcp"),Vt(X(J("443"),J("http")),X(zo(),J("https"))),rt(ct())),X(sr,J("tls"),J("http"),rt(ct())),X(sr,J("https"),rt(ct()))),T0=pt(Q1),tb=Vt(X(J("memory"),tn(),rt(ct()))),sk=pt(tb);var dk=parseInt("0xFFFF",16),pk=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var L0=Hn,sb=zn,xl=function(r){let t=0;if(r=r.toString().trim(),L0(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(sb(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=L0(e[n]),i;s&&(i=xl(e[n]),e[n]=et(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,et(i.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let s=[n,1];for(n=9-e.length;n>0;n--)s.push("0");e.splice.apply(e,s)}let o=new Uint8Array(t+16);for(n=0;n<e.length;n++){let s=parseInt(e[n],16);o[t++]=s>>8&255,o[t++]=s&255}return o}throw new Error("invalid ip address")},P0=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let o=[];for(let s=0;s<e;s++)o.push(r[t+s]);return o.join(".")}if(e===16){let o=[];for(let s=0;s<e;s+=2)o.push(n.getUint16(t+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var qn={},bl={},ab=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[481,-1,"http-path"],[777,-1,"memory"]];ab.forEach(r=>{let t=cb(...r);bl[t.code]=t,qn[t.name]=t});function cb(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function G(r){if(typeof r=="number"){if(bl[r]!=null)return bl[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(qn[r]!=null)return qn[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var Zk=G("ip4"),Yk=G("ip6"),Jk=G("ipcidr");function Sl(r,t){switch(G(r).code){case 4:case 41:return lb(t);case 42:return Al(t);case 43:return et(t,"base10");case 6:case 273:case 33:case 132:return D0(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Al(t);case 421:return pb(t);case 444:return U0(t);case 445:return U0(t);case 466:return db(t);case 481:return globalThis.encodeURIComponent(Al(t));default:return et(t,"base16")}}function Bl(r,t){switch(G(r).code){case 4:return R0(t);case 41:return R0(t);case 42:return El(t);case 43:return H(t,"base10");case 6:case 273:case 33:case 132:return kl(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return El(t);case 421:return fb(t);case 444:return mb(t);case 445:return gb(t);case 466:return hb(t);case 481:return El(globalThis.decodeURIComponent(t));default:return H(t,"base16")}}var vl=Object.values(ro).map(r=>r.decoder),ub=function(){let r=vl[0].or(vl[1]);return vl.slice(2).forEach(t=>r=r.or(t)),r}();function R0(r){if(!la(r))throw new Error("invalid ip address");return xl(r)}function lb(r){let t=P0(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!la(t))throw new Error("invalid ip address");return t}function kl(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function D0(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function El(r){let t=H(r),e=Uint8Array.from(cn(t.length));return Jt([e,t],e.length+t.length)}function Al(r){let t=Fr(r);if(r=r.slice(qt(t)),r.length!==t)throw new Error("inconsistent lengths");return et(r)}function fb(r){let t;r[0]==="Q"||r[0]==="1"?t=de(it.decode(`z${r}`)).bytes:t=$.parse(r).multihash.bytes;let e=Uint8Array.from(cn(t.length));return Jt([e,t],e.length+t.length)}function hb(r){let t=ub.decode(r),e=Uint8Array.from(cn(t.length));return Jt([e,t],e.length+t.length)}function db(r){let t=Fr(r),e=r.slice(qt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+et(e,"base64url")}function pb(r){let t=Fr(r),e=r.slice(qt(t));if(e.length!==t)throw new Error("inconsistent lengths");return et(e,"base58btc")}function mb(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let e=_t.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=kl(n);return Jt([e,o],e.length+o.length)}function gb(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let e=_t.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=kl(n);return Jt([e,o],e.length+o.length)}function U0(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=et(t,"base32"),o=D0(e);return`${n}:${o}`}function F0(r){r=Il(r);let t=[],e=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=G(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw V0("invalid address: "+r);if(a.path===!0){n=Il(o.slice(s).join("/")),t.push([a.code,Bl(a.code,n)]),e.push([a.code,n]);break}let c=Bl(a.code,o[s]);t.push([a.code,c]),e.push([a.code,Sl(a.code,c)])}return{string:M0(e),bytes:Tl(t),tuples:t,stringTuples:e,path:n}}function _l(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=Fr(r,o),i=qt(s),a=G(s),c=yb(a,r.slice(o+i));if(c===0){t.push([s]),e.push([s]),o+=i;continue}let u=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw V0("Invalid address Uint8Array: "+et(r,"base16"));t.push([s,u]);let l=Sl(s,u);if(e.push([s,l]),a.path===!0){n=l;break}}return{bytes:Uint8Array.from(r),string:M0(e),tuples:t,stringTuples:e,path:n}}function M0(r){let t=[];return r.map(e=>{let n=G(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Il(t.join("/"))}function Tl(r){return Jt(r.map(t=>{let e=G(t[0]),n=Uint8Array.from(cn(e.code));return t.length>1&&t[1]!=null&&(n=Jt([n,t[1]])),n}))}function yb(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Fr(t instanceof Uint8Array?t:Uint8Array.from(t));return e+qt(e)}}function Il(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function V0(r){return new Error("Error parsing address: "+r)}var wb=Symbol.for("nodejs.util.inspect.custom"),Nl=Symbol.for("@multiformats/js-multiaddr/multiaddr"),xb=[G("dns").code,G("dns4").code,G("dns6").code,G("dnsaddr").code],Cl=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},ga=class r{bytes;#t;#e;#r;#o;[Nl]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=_l(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=F0(t)}else if($0(t))e=_l(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#t=e.string,this.#e=e.tuples,this.#r=e.stringTuples,this.#o=e.path}toString(){return this.#t}toJSON(){return this.toString()}toOptions(){let t,e,n,o,s="",i=G("tcp"),a=G("udp"),c=G("ip4"),u=G("ip6"),l=G("dns6"),f=G("ip6zone");for(let[h,g]of this.stringTuples())h===f.code&&(s=`%${g??""}`),xb.includes(h)&&(e=i.name,o=443,n=`${g??""}${s}`,t=h===l.code?6:4),(h===i.code||h===a.code)&&(e=G(h).name,o=parseInt(g??"")),(h===c.code||h===u.code)&&(e=G(h).name,n=`${g??""}${s}`,t=h===u.code?6:4);if(t==null||e==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:o}}protos(){return this.#e.map(([t])=>Object.assign({},G(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>G(t).name)}tuples(){return this.#e.map(([t,e])=>e==null?[t]:[t,e])}stringTuples(){return this.#r.map(([t,e])=>e==null?[t]:[t,e])}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),o=n.lastIndexOf(e);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,o))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(Tl(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===qn.p2p.code&&t.push([n,o]),n===qn["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?et(it.decode(`z${n}`),"base58btc"):et($.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#o}equals(t){return st(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=O0.get(e.name);if(n==null)throw new Cl(`no available resolver for ${e.name}`);return(await n(this,t)).map(s=>ir(s))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[wb](){return`Multiaddr(${this.#t})`}};var O0=new Map;function $0(r){return!!r?.[Nl]}function ir(r){return new ga(r)}var bb=[G("tcp").code,G("dns").code,G("dnsaddr").code,G("dns4").code,G("dns6").code];function H0(r){return q0("sni",r)?.[1]}function z0(r){let t=q0("tcp",r)?.[1];return t==null?"":`:${t}`}function q0(r,t){let e;try{e=G(r).code}catch{return}for(let[n,o]of t)if(n===e&&o!=null)return[n,o]}function K0(r){return r.some(([t,e])=>t===G("tls").code)}function Se(r,t,e){let n=j0[G(r).name];if(n==null)throw new Error(`Can't interpret protocol ${G(r).name}`);let o=n(t,e);return r===G("ip6").code?`[${o}]`:o}var j0={ip4:(r,t)=>r,ip6:(r,t)=>t.length===0?r:`[${r}]`,tcp:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");return`tcp://${Se(e[0],e[1]??"",t)}:${r}`},udp:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");return`udp://${Se(e[0],e[1]??"",t)}:${r}`},dnsaddr:(r,t)=>r,dns4:(r,t)=>r,dns6:(r,t)=>r,dns:(r,t)=>r,ipfs:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");return`${Se(e[0],e[1]??"",t)}`},p2p:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");return`${Se(e[0],e[1]??"",t)}`},http:(r,t)=>{let e=K0(t),n=H0(t),o=z0(t);if(e&&n!=null)return`https://${n}${o}`;let s=e?"https://":"http://",i=t.pop();if(i==null)throw new Error("Unexpected end of multiaddr");let a=Se(i[0],i[1]??"",t);return a=a.replace("tcp://",""),`${s}${a}`},"http-path":(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");let n=Se(e[0],e[1]??"",t),o=decodeURIComponent(r);return`${n}/${o}`},tls:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");return Se(e[0],e[1]??"",t)},sni:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");return Se(e[0],e[1]??"",t)},https:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");let n=Se(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`https://${n}`},ws:(r,t)=>{let e=K0(t),n=H0(t),o=z0(t);if(e&&n!=null)return`wss://${n}${o}`;let s=e?"wss://":"ws://",i=t.pop();if(i==null)throw new Error("Unexpected end of multiaddr");let a=Se(i[0],i[1]??"",t);return a=a.replace("tcp://",""),`${s}${a}`},wss:(r,t)=>{let e=t.pop();if(e==null)throw new Error("Unexpected end of multiaddr");let n=Se(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`wss://${n}`}};function G0(r,t){let n=ir(r).stringTuples(),o=n.pop();if(o==null)throw new Error("Unexpected end of multiaddr");let s=G(o[0]),i=j0[s.name];if(i==null)throw new Error(`No interpreter found for ${s.name}`);let a=i(o[1]??"",n);return t?.assumeHttp!==!1&&bb.includes(o[0])&&(a=a.replace(/^.*:\/\//,""),o[1]==="443"?a=`https://${a}`:a=`http://${a}`),(a.startsWith("http://")||a.startsWith("https://")||a.startsWith("ws://")||a.startsWith("wss://"))&&(a=new URL(a).toString(),a.endsWith("/")&&(a=a.substring(0,a.length-1))),a}var ya=class{url;#t=0;#e=0;#r=0;#o=0;#a=new Map;log;constructor(t,e){this.url=t instanceof URL?t:new URL(t),this.log=e.forComponent(`helia:trustless-gateway-block-broker:${this.url.hostname}`)}#u(t){let e=t.multihash.bytes;return Ce.encode(e)}async getRawBlock(t,e){let n=new URL(this.url.toString());if(n.pathname=`/ipfs/${t.toString()}`,n.search="?format=raw",e?.aborted===!0)throw new Error(`Signal to fetch raw block for CID ${t} from gateway ${this.url} was aborted prior to fetch`);let o=this.#u(t),s=new AbortController,i=()=>{s.abort()};e?.addEventListener("abort",i);try{let a=this.#a.get(o);return a==null&&(this.#t++,a=fetch(n.toString(),{signal:s.signal,headers:{Accept:"application/vnd.ipld.raw"},cache:"force-cache"}).then(async c=>{if(this.log("GET %s %d",n,c.status),!c.ok)throw this.#e++,new Error(`unable to fetch raw block for CID ${t} from gateway ${this.url}`);return this.#o++,new Uint8Array(await c.arrayBuffer())}),this.#a.set(o,a)),await a}catch{throw e?.aborted===!0?new Error(`fetching raw block for CID ${t} from gateway ${this.url} was aborted`):(this.#e++,new Error(`unable to fetch raw block for CID ${t}`))}finally{e?.removeEventListener("abort",i),this.#a.delete(o)}}reliability(){return this.#t===0?1:this.#r>0?-1/0:this.#o/(this.#t+this.#e*3)}incrementInvalidBlocks(){this.#r++}getStats(){return{attempts:this.#t,errors:this.#e,invalidBlocks:this.#r,successes:this.#o,pendingResponses:this.#a.size}}};function vb(r,t,e){return r.filter(n=>{if(T0.matches(n)||t&&_0.matches(n))return e||v0.matches(n)?!0:b0(n.toOptions().host)===!1;if(!t&&e){let{host:o}=n.toOptions();if(o==="127.0.0.1"||o==="localhost"||o.endsWith(".localhost"))return!0}return!1})}async function*wa(r,t,e,n,o,s){for await(let i of t.findProviders(r,s)){let a=vb(i.multiaddrs,n,o);if(a.length===0)continue;let c=G0(a[0]);yield new ya(c,e)}}var Ll=class extends $o{routing;allowInsecure;allowLocal;constructor(t,e){super(t,{...e,name:"helia:trustless-gateway:session"}),this.routing=t.routing,this.allowInsecure=e.allowInsecure??xa,this.allowLocal=e.allowLocal??ba}async queryProvider(t,e,n){this.log("fetching BLOCK for %c from %s",t,e.url);let o=await e.getRawBlock(t,n.signal);return this.log.trace("got block for %c from %s",t,e.url),await n.validateFn?.(o),o}async*findNewProviders(t,e={}){yield*wa(t,this.routing,this.logger,this.allowInsecure,this.allowLocal,e)}toEvictionKey(t){return t.url.toString()}equals(t,e){return t.url.toString()===e.url.toString()}};function W0(r,t){return new Ll(r,t)}var va=class{allowInsecure;allowLocal;routing;log;logger;constructor(t,e={}){this.log=t.logger.forComponent("helia:trustless-gateway-block-broker"),this.logger=t.logger,this.routing=t.routing,this.allowInsecure=e.allowInsecure??xa,this.allowLocal=e.allowLocal??ba}async retrieve(t,e={}){let n=[];for await(let o of wa(t,this.routing,this.logger,this.allowInsecure,this.allowLocal,e)){this.log("getting block for %c from %s",t,o.url);try{let s=await o.getRawBlock(t,e.signal);this.log.trace("got block for %c from %s",t,o.url);try{await e.validateFn?.(s)}catch(i){this.log.error("failed to validate block for %c from %s",t,o.url,i);continue}return s}catch(s){if(this.log.error("failed to get block for %c from %s",t,o.url,s),s instanceof Error?n.push(s):n.push(new Error(`Unable to fetch raw block for CID ${t} from gateway ${o.url}`)),e.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",t,o.url);break}}}throw n.length>0?new AggregateError(n,`Unable to fetch raw block for CID ${t} from any gateway`):new Error(`Unable to fetch raw block for CID ${t} from any gateway`)}createSession(t={}){return W0({logger:this.logger,routing:this.routing},{...t,allowLocal:this.allowLocal,allowInsecure:this.allowInsecure})}};var xa=!1,ba=!1;function Pl(r={}){return t=>new va(t,r)}async function*Ea(r,t={}){let e=r.getReader();try{for(;;){let n=await e.read();if(n.done)return;yield n.value}}finally{t.preventCancel!==!0&&await e.cancel(),e.releaseLock()}}var Ib=Rr(Ul(),1);var Be=class extends Error{static name="SignatureVerificationError";constructor(t="Record signature verification failed"){super(t),this.name="SignatureVerificationError"}},Aa=class extends Error{static name="RecordExpiredError";constructor(t="Record has expired"){super(t),this.name="RecordExpiredError"}},jn=class extends Error{static name="UnsupportedValidityError";constructor(t="The validity type is unsupported"){super(t),this.name="UnsupportedValidityError"}},Sa=class extends Error{static name="RecordTooLargeError";constructor(t="The record is too large"){super(t),this.name="RecordTooLargeError"}},Ba=class extends Error{static name="InvalidValueError";constructor(t="Value must be a valid content path starting with /"){super(t),this.name="InvalidValueError"}},ka=class extends Error{static name="InvalidRecordDataError";constructor(t="Invalid record data"){super(t),this.name="InvalidRecordDataError"}},jo=class extends Error{static name="InvalidEmbeddedPublicKeyError";constructor(t="Invalid embedded public key"){super(t),this.name="InvalidEmbeddedPublicKeyError"}};var ke;(function(r){let t;(function(o){o.EOL="EOL"})(t=r.ValidityType||(r.ValidityType={}));let e;(function(o){o[o.EOL=0]="EOL"})(e||(e={})),function(o){o.codec=()=>so(e)}(t=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=wn((o,s,i={})=>{i.lengthDelimited!==!1&&s.fork(),o.value!=null&&(s.uint32(10),s.bytes(o.value)),o.signatureV1!=null&&(s.uint32(18),s.bytes(o.signatureV1)),o.validityType!=null&&(s.uint32(24),r.ValidityType.codec().encode(o.validityType,s)),o.validity!=null&&(s.uint32(34),s.bytes(o.validity)),o.sequence!=null&&(s.uint32(40),s.uint64(o.sequence)),o.ttl!=null&&(s.uint32(48),s.uint64(o.ttl)),o.pubKey!=null&&(s.uint32(58),s.bytes(o.pubKey)),o.signatureV2!=null&&(s.uint32(66),s.bytes(o.signatureV2)),o.data!=null&&(s.uint32(74),s.bytes(o.data)),i.lengthDelimited!==!1&&s.ldelim()},(o,s,i={})=>{let a={},c=s==null?o.len:o.pos+s;for(;o.pos<c;){let u=o.uint32();switch(u>>>3){case 1:{a.value=o.bytes();break}case 2:{a.signatureV1=o.bytes();break}case 3:{a.validityType=r.ValidityType.codec().decode(o);break}case 4:{a.validity=o.bytes();break}case 5:{a.sequence=o.uint64();break}case 6:{a.ttl=o.uint64();break}case 7:{a.pubKey=o.bytes();break}case 8:{a.signatureV2=o.bytes();break}case 9:{a.data=o.bytes();break}default:{o.skipType(u&7);break}}}return a})),n),r.encode=o=>gn(o,r.codec()),r.decode=(o,s)=>fn(o,r.codec(),s)})(ke||(ke={}));var Eb=Qt("ipns:utils"),Z0=H("/ipns/");var Ab=0,Sb=18;function Y0(r){let t;if(r.pubKey!=null)try{t=dd(r.pubKey)}catch(e){throw Eb.error(e),e}if(t!=null)return t}function J0(r){let t=H("ipns-signature:");return Jt([t,r])}function en(r){return"signatureV1"in r?ke.encode({value:H(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:H(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):ke.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data})}function Me(r){let t=ke.decode(r);if(t.sequence!=null&&(t.sequence=BigInt(t.sequence)),t.ttl!=null&&(t.ttl=BigInt(t.ttl)),t.signatureV2==null||t.data==null)throw new Be("Missing data or signatureV2");let e=X0(t.data),n=Bb(e.Value),o=et(e.Validity);if(t.value!=null&&t.signatureV1!=null)return kb(t),{value:n,validityType:ke.ValidityType.EOL,validity:o,sequence:e.Sequence,ttl:e.TTL,pubKey:t.pubKey,signatureV1:t.signatureV1,signatureV2:t.signatureV2,data:t.data};if(t.signatureV2!=null)return{value:n,validityType:ke.ValidityType.EOL,validity:o,sequence:e.Sequence,ttl:e.TTL,pubKey:t.pubKey,signatureV2:t.signatureV2,data:t.data};throw new Error("invalid record: does not include signatureV1 or signatureV2")}function Go(r){return Jt([Z0,r.bytes])}function ar(r){let t=de(r.slice(Z0.length));if(!Ia(t,Ab)&&!Ia(t,Sb))throw new ur("Multihash in IPNS key was not identity or sha2-256");return t}function X0(r){let t=oe(r);if(t.ValidityType===0)t.ValidityType=ke.ValidityType.EOL;else throw new jn("The validity type is unsupported");return Number.isInteger(t.Sequence)&&(t.Sequence=BigInt(t.Sequence)),Number.isInteger(t.TTL)&&(t.TTL=BigInt(t.TTL)),t}function Bb(r){let t=et(r).trim();if(t.startsWith("/"))return t;try{return`/ipfs/${$.decode(r).toV1().toString()}`}catch{}try{return`/ipfs/${$.parse(t).toV1().toString()}`}catch{}throw new Ba("Value must be a valid content path starting with /")}function kb(r){if(r.data==null)throw new ka("Record data is missing");let t=X0(r.data);if(!st(t.Value,r.value??new Uint8Array(0)))throw new Be('Field "value" did not match between protobuf and CBOR');if(!st(t.Validity,r.validity??new Uint8Array(0)))throw new Be('Field "validity" did not match between protobuf and CBOR');if(t.ValidityType!==r.validityType)throw new Be('Field "validityType" did not match between protobuf and CBOR');if(t.Sequence!==r.sequence)throw new Be('Field "sequence" did not match between protobuf and CBOR');if(t.TTL!==r.ttl)throw new Be('Field "ttl" did not match between protobuf and CBOR')}function Ia(r,t){return r.code===t}var f_=Qt("ipns"),h_=60*60*1e9,_b="/ipns/",d_=_b.length;var Q0=Rr(Ul(),1);var _a=Qt("ipns:validator"),Tb=1024*10,Cb=async(r,t)=>{let e=Me(t),n;try{let o=J0(e.data);n=await r.verify(o,e.signatureV2)}catch{n=!1}if(!n)throw _a.error("record signature verification failed"),new Be("Record signature verification failed");if(e.validityType===ke.ValidityType.EOL){if(Q0.default.fromString(e.validity).toDate().getTime()<Date.now())throw _a.error("record has expired"),new Aa("record has expired")}else if(e.validityType!=null)throw _a.error("the validity type is unsupported"),new jn("The validity type is unsupported");_a("ipns record for %s is valid",e.value)};async function tm(r,t){if(t.byteLength>Tb)throw new Sa("The record is too large");let e=ar(r),n;Ia(e,0)&&(n=Ei(e));let o=Me(t),s=Y0(o)??n;if(s==null)throw new jo("Could not extract public key from IPNS record or routing key");let i=Go(s.toMultihash());if(!st(r,i))throw new jo("Embedded public key did not match routing key");await Cb(s,t)}var Ta=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MESSAGE_LENGTH"};async function*Wo(r,t={}){let e=/\r?\n/,n=new TextDecoder("utf8"),o="";for await(let s of r){if(typeof s=="string"&&(s=new TextEncoder().encode(s)),o+=n.decode(s,{stream:!0}),o.length>(t?.maxMessageLength??o.length))throw new Ta("Incoming message too long");let i=o.split(e);o=i.pop()??"";for(let a=0;a<i.length;a++)yield JSON.parse(i[a])}o+=n.decode(),o!==""&&(yield JSON.parse(o))}var Gn=class extends Error{static name="InvalidRequestError";constructor(t="Invalid request"){super(t),this.name="InvalidRequestError"}},rn=class extends Error{static name="BadResponseError";constructor(t="Bad response"){super(t),this.name="BadResponseError"}};function Nb(r){return r[Symbol.asyncIterator]!=null}function Lb(r){if(Nb(r))return(async()=>{for await(let t of r)return t})();for(let t of r)return t}var Ca=Lb;var em=H("/ipns/");function rm(r){return st(r.subarray(0,em.byteLength),em)}var Na=class{client;constructor(t){this.client=t}async*findProviders(t,e={}){yield*ln(this.client.getProviders(t,e),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async cancelReprovide(){}async put(t,e,n){if(!rm(t))return;let o=ar(t),s=$.createV1(114,o),i=Me(e);await this.client.putIPNS(s,i,n)}async get(t,e){if(!rm(t))throw new Pt("Not found");let n=ar(t),o=$.createV1(114,n);try{let s=await this.client.getIPNS(o,e);return en(s)}catch(s){throw s.name==="BadResponseError"?new Pt("Not found"):s}}},La=class{client;constructor(t){this.client=t}async findPeer(t,e={}){let n=await Ca(this.client.getPeers(t,e));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new Pt("Not found")}async*getClosestPeers(t,e={}){}};var kt=Qt("delegated-routing-v1-http-api-client"),Pa={concurrentRequests:4,timeout:3e4,cacheTTL:5*60*1e3,cacheName:"delegated-routing-v1-cache"},Ra=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;filterAddrs;filterProtocols;inFlightRequests;cacheName;cache;cacheTTL;constructor(t,e={}){this.started=!1,this.shutDownController=new AbortController,ht(1/0,this.shutDownController.signal),this.httpQueue=new De({concurrency:e.concurrentRequests??Pa.concurrentRequests}),this.inFlightRequests=new Map,this.clientUrl=t instanceof URL?t:new URL(t),this.timeout=e.timeout??Pa.timeout,this.filterAddrs=e.filterAddrs,this.filterProtocols=e.filterProtocols,this.contentRouting=new Na(this),this.peerRouting=new La(this),this.cacheName=e.cacheName??Pa.cacheName,this.cacheTTL=e.cacheTTL??Pa.cacheTTL}get[Zn](){return this.contentRouting}get[Yn](){return this.peerRouting}isStarted(){return this.started}async start(){this.started||(this.started=!0,this.cacheTTL>0&&(this.cache=await globalThis.caches?.open(this.cacheName),this.cache!=null&&kt("cache enabled with ttl %d",this.cacheTTL)))}async stop(){this.httpQueue.clear(),this.shutDownController.abort(),await globalThis.caches?.delete(this.cacheName),this.started=!1}async*getProviders(t,e={}){kt("getProviders starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=$t([this.shutDownController.signal,n,e.signal]);ht(1/0,n,o);let s=At(),i=At();this.httpQueue.add(async()=>(s.resolve(),i.promise));try{await s.promise;let a=new URL(`${this.clientUrl}routing/v1/providers/${t.toString()}`);this.#e(a,e.filterAddrs,e.filterProtocols);let c={headers:{Accept:"application/x-ndjson"},signal:o},u=await this.#r(a.toString(),c);if(u.status===404)throw new Pt("No matching records found");if(u.status===422)throw new Gn("Request does not conform to schema or semantic constraints");if(u.body==null)throw new rn("Routing response had no body");if(u.headers.get("Content-Type")==="application/json"){let f=await u.json();for(let d of f.Providers){let h=this.#t(d);h!=null&&(yield h)}}else for await(let f of Wo(Ea(u.body))){let d=this.#t(f);d!=null&&(yield d)}}catch(a){kt.error("getProviders errored:",a)}finally{o.clear(),i.resolve(),kt("getProviders finished: %c",t)}}async*getPeers(t,e={}){kt("getPeers starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=$t([this.shutDownController.signal,n,e.signal]);ht(1/0,n,o);let s=At(),i=At();this.httpQueue.add(async()=>(s.resolve(),i.promise));try{await s.promise;let a=new URL(`${this.clientUrl}routing/v1/peers/${t.toCID().toString()}`);this.#e(a,e.filterAddrs,e.filterProtocols);let c={headers:{Accept:"application/x-ndjson"},signal:o},u=await this.#r(a.toString(),c);if(u.status===404)throw new Pt("No matching records found");if(u.status===422)throw new Gn("Request does not conform to schema or semantic constraints");if(u.body==null)throw new rn("Routing response had no body");if(u.headers.get("Content-Type")==="application/json"){let f=await u.json();for(let d of f.Peers){let h=this.#t(d);h!=null&&(yield h)}}else for await(let f of Wo(Ea(u.body))){let d=this.#t(f);d!=null&&(yield d)}}catch(a){kt.error("getPeers errored:",a)}finally{o.clear(),i.resolve(),kt("getPeers finished: %c",t)}}async getIPNS(t,e={}){kt("getIPNS starts: %s",t);let n=AbortSignal.timeout(this.timeout),o=$t([this.shutDownController.signal,n,e.signal]);ht(1/0,n,o);let s=At(),i=At();this.httpQueue.add(async()=>(s.resolve(),i.promise));let a=`${this.clientUrl}routing/v1/ipns/${t}`;try{await s.promise;let c={headers:{Accept:"application/vnd.ipfs.ipns-record"},signal:o},u=await this.#r(a,c);if(kt("getIPNS GET %s %d",a,u.status),u.status===404)throw new Pt("No matching records found");if(u.status===422)throw new Gn("Request does not conform to schema or semantic constraints");if(u.body==null)throw new rn("GET ipns response had no body");let l=await u.arrayBuffer(),f=new Uint8Array(l,0,l.byteLength);return e.validate!==!1&&await tm(Go(t.multihash),f),Me(f)}catch(c){throw kt.error("getIPNS GET %s error:",a,c),c}finally{o.clear(),i.resolve(),kt("getIPNS finished: %s",t)}}async putIPNS(t,e,n={}){kt("putIPNS starts: %c",t);let o=AbortSignal.timeout(this.timeout),s=$t([this.shutDownController.signal,o,n.signal]);ht(1/0,o,s);let i=At(),a=At();this.httpQueue.add(async()=>(i.resolve(),a.promise));let c=`${this.clientUrl}routing/v1/ipns/${t}`;try{await i.promise;let u=en(e),l={method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:u,signal:s},f=await this.#r(c,l);if(kt("putIPNS PUT %s %d",c,f.status),f.status!==200)throw new rn("PUT ipns response had status other than 200")}catch(u){throw kt.error("putIPNS PUT %s error:",c,u.stack),u}finally{s.clear(),a.resolve(),kt("putIPNS finished: %c",t)}}#t(t){try{let e=[],n=t.Addrs?.map(ir)??[];return t.Protocols!=null&&e.push(...t.Protocols),t.Protocol!=null&&(e.push(t.Protocol),delete t.Protocol),{...t,Schema:"peer",ID:gd(t.ID),Addrs:n,Protocols:e}}catch(e){kt.error("could not conform record to peer schema",e)}}#e(t,e,n){if(e!=null||this.filterAddrs!=null){let o=e?.join(",")??this.filterAddrs?.join(",")??"";o!==""&&t.searchParams.set("filter-addrs",o)}if(n!=null||this.filterProtocols!=null){let o=n?.join(",")??this.filterProtocols?.join(",")??"";o!==""&&t.searchParams.set("filter-protocols",o)}}async#r(t,e){let n=e.method??"GET",o=`${n}-${t}`;if(n==="GET"){let c=await this.cache?.match(t);if(c!=null){if(parseInt(c.headers.get("x-cache-expires")??"0",10)>Date.now())return kt("returning cached response for %s",o),c;await this.cache?.delete(t)}}let s=this.inFlightRequests.get(o);if(s!=null){let c=await s;return kt("deduplicating outgoing request for %s",o),c.clone()}let i=fetch(t,e).then(async c=>{if(this.cache!=null&&c.ok&&n==="GET"){let u=Date.now()+this.cacheTTL,l=new Headers(c.headers);l.set("x-cache-expires",u.toString());let f=new Response(c.clone().body,{status:c.status,statusText:c.statusText,headers:l});await this.cache.put(t,f)}return c}).finally(()=>{this.inFlightRequests.delete(o)});return this.inFlightRequests.set(o,i),await i}};function nm(r,t={}){return new Ra(new URL(r),t)}function om(){return{filterProtocols:["unknown","transport-bitswap","transport-ipfs-gateway-http"],filterAddrs:["https","webtransport","webrtc","webrtc-direct","wss","tls"]}}var sm=H("/ipns/");function im(r){return st(r.subarray(0,sm.byteLength),sm)}var Dl=class{client;constructor(t,e={}){this.client=nm(t,e)}async provide(t,e){}async cancelReprovide(t,e){}async*findProviders(t,e){yield*ln(this.client.getProviders(t,e),n=>({id:n.ID,multiaddrs:n.Addrs,protocols:n.Protocols}))}async put(t,e,n){if(!im(t))return;let o=ar(t),s=$.createV1(114,o),i=Me(e);await this.client.putIPNS(s,i,n)}async get(t,e){if(!im(t))throw new Pt("Not found");let n=ar(t),o=$.createV1(114,n);try{let s=await this.client.getIPNS(o,e);return en(s)}catch(s){throw s.name==="BadResponseError"?new Pt("Not found"):s}}async findPeer(t,e){let n=await Ca(this.client.getPeers(t,e));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new Pt("Not found")}async*getClosestPeers(t,e){}};function Fl(r,t){let e=t??om();return new Dl(new URL(r),e)}var am="[a-fA-F\\d:]",Lr=r=>r&&r.includeBoundaries?`(?:(?<=\\s|^)(?=${am})|(?<=${am})(?=\\s|$))`:"",Ie="(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}",yt="[a-fA-F\\d]{1,4}",Ua=`
8
8
  (?:
9
9
  (?:${yt}:){7}(?:${yt}|:)| // 1:2:3:4:5:6:7:: 1:2:3:4:5:6:7:8
10
- (?:${yt}:){6}(?:${_e}|:${yt}|:)| // 1:2:3:4:5:6:: 1:2:3:4:5:6::8 1:2:3:4:5:6::8 1:2:3:4:5:6::1.2.3.4
11
- (?:${yt}:){5}(?::${_e}|(?::${yt}){1,2}|:)| // 1:2:3:4:5:: 1:2:3:4:5::7:8 1:2:3:4:5::8 1:2:3:4:5::7:1.2.3.4
12
- (?:${yt}:){4}(?:(?::${yt}){0,1}:${_e}|(?::${yt}){1,3}|:)| // 1:2:3:4:: 1:2:3:4::6:7:8 1:2:3:4::8 1:2:3:4::6:7:1.2.3.4
13
- (?:${yt}:){3}(?:(?::${yt}){0,2}:${_e}|(?::${yt}){1,4}|:)| // 1:2:3:: 1:2:3::5:6:7:8 1:2:3::8 1:2:3::5:6:7:1.2.3.4
14
- (?:${yt}:){2}(?:(?::${yt}){0,3}:${_e}|(?::${yt}){1,5}|:)| // 1:2:: 1:2::4:5:6:7:8 1:2::8 1:2::4:5:6:7:1.2.3.4
15
- (?:${yt}:){1}(?:(?::${yt}){0,4}:${_e}|(?::${yt}){1,6}|:)| // 1:: 1::3:4:5:6:7:8 1::8 1::3:4:5:6:7:1.2.3.4
16
- (?::(?:(?::${yt}){0,5}:${_e}|(?::${yt}){1,7}|:)) // ::2:3:4:5:6:7:8 ::2:3:4:5:6:7:8 ::8 ::1.2.3.4
10
+ (?:${yt}:){6}(?:${Ie}|:${yt}|:)| // 1:2:3:4:5:6:: 1:2:3:4:5:6::8 1:2:3:4:5:6::8 1:2:3:4:5:6::1.2.3.4
11
+ (?:${yt}:){5}(?::${Ie}|(?::${yt}){1,2}|:)| // 1:2:3:4:5:: 1:2:3:4:5::7:8 1:2:3:4:5::8 1:2:3:4:5::7:1.2.3.4
12
+ (?:${yt}:){4}(?:(?::${yt}){0,1}:${Ie}|(?::${yt}){1,3}|:)| // 1:2:3:4:: 1:2:3:4::6:7:8 1:2:3:4::8 1:2:3:4::6:7:1.2.3.4
13
+ (?:${yt}:){3}(?:(?::${yt}){0,2}:${Ie}|(?::${yt}){1,4}|:)| // 1:2:3:: 1:2:3::5:6:7:8 1:2:3::8 1:2:3::5:6:7:1.2.3.4
14
+ (?:${yt}:){2}(?:(?::${yt}){0,3}:${Ie}|(?::${yt}){1,5}|:)| // 1:2:: 1:2::4:5:6:7:8 1:2::8 1:2::4:5:6:7:1.2.3.4
15
+ (?:${yt}:){1}(?:(?::${yt}){0,4}:${Ie}|(?::${yt}){1,6}|:)| // 1:: 1::3:4:5:6:7:8 1::8 1::3:4:5:6:7:1.2.3.4
16
+ (?::(?:(?::${yt}){0,5}:${Ie}|(?::${yt}){1,7}|:)) // ::2:3:4:5:6:7:8 ::2:3:4:5:6:7:8 ::8 ::1.2.3.4
17
17
  )(?:%[0-9a-zA-Z]{1,})? // %eth0 %1
18
- `.replace(/\s*\/\/.*$/gm,"").replace(/\n/g,"").trim(),Yb=new RegExp(`(?:^${_e}$)|(?:^${Oa}$)`),Jb=new RegExp(`^${_e}$`),Xb=new RegExp(`^${Oa}$`),jl=r=>r&&r.exact?Yb:new RegExp(`(?:${Rr(r)}${_e}${Rr(r)})|(?:${Rr(r)}${Oa}${Rr(r)})`,"g");jl.v4=r=>r&&r.exact?Jb:new RegExp(`${Rr(r)}${_e}${Rr(r)}`,"g");jl.v6=r=>r&&r.exact?Xb:new RegExp(`${Rr(r)}${Oa}${Rr(r)}`,"g");var Gl=jl;function Wl(r){let t=(...e)=>r(...e);return Object.defineProperty(t,"name",{value:`functionTimeout(${r.name||"<anonymous>"})`,configurable:!0}),t}function vm(){return!1}var{toString:Qb}=Object.prototype;function Zl(r){return Qb.call(r)==="[object RegExp]"}var Em={global:"g",ignoreCase:"i",multiline:"m",dotAll:"s",sticky:"y",unicode:"u"};function Yl(r,t={}){if(!Zl(r))throw new TypeError("Expected a RegExp instance");let e=Object.keys(Em).map(o=>(typeof t[o]=="boolean"?t[o]:r[o])?Em[o]:"").join(""),n=new RegExp(t.source||r.source,e);return n.lastIndex=typeof t.lastIndex=="number"?t.lastIndex:r.lastIndex,n}function Jl(r,t,{timeout:e}={}){try{return Wl(()=>Yl(r).test(t),{timeout:e})()}catch(n){if(vm(n))return!1;throw n}}var t2=15,e2=45,Am={timeout:400};function Xl(r){return r.length>e2?!1:Jl(Gl.v6({exact:!0}),r,Am)}function Sm(r){return r.length>t2?!1:Jl(Gl.v4({exact:!0}),r,Am)}var Bm={http:"80",https:"443",ws:"80",wss:"443"},r2=["http","https","ws","wss"];function km(r,t){t=t??{};let e=t.defaultDnsType??"dns4",{scheme:n,hostname:o,port:s}=n2(r),a="/"+[o2(o,e),s2(s,n),i2(n)].filter(c=>!!c).reduce((c,u)=>c.concat(u),[]).join("/");return ar(a)}function n2(r){let[t]=r.split(":");r2.includes(t)||(r="http"+r.substring(t.length));let{protocol:e,hostname:n,port:o}=new URL(r);if(o==null||o===""){let s=a2(t);s!=null&&(o=s),s==null&&e==="http:"&&(o="80")}return{scheme:t,hostname:n,port:o}}function o2(r,t){if(!(r==null||r==="")){if(Sm(r))return["ip4",r];if(Xl(r))return["ip6",r];if(r[0]==="["){let e=r.substring(1,r.length-1);if(Xl(e))return["ip6",e]}return[t,r]}}function s2(r,t){if(!(r==null||r===""))return t==="udp"?["udp",r]:["tcp",r]}function i2(r){if(r.match(/^tcp$|^udp$/)==null)return[r]}function a2(r){if(!(r==null||r===""||Bm[r]==null))return Bm[r]}var c2=["https://trustless-gateway.link","https://4everland.io"],u2=2336;function l2(r){return r=r.toString(),{id:Nd($.createV1(u2,jt.digest(K(r)))),multiaddrs:[km(r)]}}var Ql=class{gateways;constructor(t={}){this.gateways=(t.gateways??c2).map(e=>l2(e))}async*findProviders(t,e){yield*this.gateways.toSorted(()=>Math.random()>.5?1:-1).map(n=>({...n,protocols:["transport-ipfs-gateway-http"]}))}};function tf(r={}){return new Ql(r)}var Jo=class extends sr{data;constructor(){super(),this.data=new Map}put(t,e){return this.data.set(_t.encode(t.multihash.bytes),e),t}get(t){let e=this.data.get(_t.encode(t.multihash.bytes));if(e==null)throw new ce;return e}has(t){return this.data.has(_t.encode(t.multihash.bytes))}async delete(t){this.data.delete(_t.encode(t.multihash.bytes))}async*getAll(){for(let[t,e]of this.data.entries())yield{cid:$.createV1(Qn,de(_t.decode(t))),block:e}}};var TT=Qt("blockstore:core:tiered");var Tm="SHARDING";function h2(r){return r[Symbol.asyncIterator]!=null}function d2(r){if(h2(r))return(async()=>{let e=[];for await(let n of r)e.push(n);return e})();let t=[];for(let e of r)t.push(e);return t}var ef=d2;function p2(r){return r[Symbol.asyncIterator]!=null}function m2(r,t){return p2(r)?async function*(){yield*(await ef(r)).sort(t)}():function*(){yield*ef(r).sort(t)}()}var $a=m2;var ur=class{put(t,e,n){return Promise.reject(new Error(".put is not implemented"))}get(t,e){return Promise.reject(new Error(".get is not implemented"))}has(t,e){return Promise.reject(new Error(".has is not implemented"))}delete(t,e){return Promise.reject(new Error(".delete is not implemented"))}async*putMany(t,e={}){for await(let{key:n,value:o}of t)await this.put(n,o,e),yield n}async*getMany(t,e={}){for await(let n of t)yield{key:n,value:await this.get(n,e)}}async*deleteMany(t,e={}){for await(let n of t)await this.delete(n,e),yield n}batch(){let t=[],e=[];return{put(n,o){t.push({key:n,value:o})},delete(n){e.push(n)},commit:async n=>{await Vr(this.putMany(t,n)),t=[],await Vr(this.deleteMany(e,n)),e=[]}}}async*_all(t,e){throw new Error("._all is not implemented")}async*_allKeys(t,e){throw new Error("._allKeys is not implemented")}query(t,e){let n=this._all(t,e);if(t.prefix!=null){let o=t.prefix;n=Se(n,s=>s.key.toString().startsWith(o))}if(Array.isArray(t.filters)&&(n=t.filters.reduce((o,s)=>Se(o,s),n)),Array.isArray(t.orders)&&(n=t.orders.reduce((o,s)=>$a(o,s),n)),t.offset!=null){let o=0,s=t.offset;n=Se(n,()=>o++>=s)}return t.limit!=null&&(n=cs(n,t.limit)),n}queryKeys(t,e){let n=this._allKeys(t,e);if(t.prefix!=null){let o=t.prefix;n=Se(n,s=>s.toString().startsWith(o))}if(Array.isArray(t.filters)&&(n=t.filters.reduce((o,s)=>Se(o,s),n)),Array.isArray(t.orders)&&(n=t.orders.reduce((o,s)=>$a(o,s),n)),t.offset!=null){let o=t.offset,s=0;n=Se(n,()=>s++>=o)}return t.limit!=null&&(n=cs(n,t.limit)),n}};var Xo=class extends ur{data;constructor(){super(),this.data=new Map}put(t,e){return this.data.set(t.toString(),e),t}get(t){let e=this.data.get(t.toString());if(e==null)throw new ce;return e}has(t){return this.data.has(t.toString())}delete(t){this.data.delete(t.toString())}*_all(){for(let[t,e]of this.data.entries())yield{key:new Mt(t),value:e}}*_allKeys(){for(let t of this.data.keys())yield new Mt(t)}};var uC=new Mt(Tm);var AC=Qt("datastore:core:tiered");async function g2(r={}){let t=r.datastore??new Xo,e=r.blockstore??new Jo,n=new da({...r,datastore:t,blockstore:e,blockBrokers:r.blockBrokers??[$l()],routers:r.routers??[ql("https://delegated-ipfs.dev"),tf()]});return r.start!==!1&&await n.start(),n}return Km(y2);})();
18
+ `.replace(/\s*\/\/.*$/gm,"").replace(/\n/g,"").trim(),Pb=new RegExp(`(?:^${Ie}$)|(?:^${Ua}$)`),Rb=new RegExp(`^${Ie}$`),Ub=new RegExp(`^${Ua}$`),Ml=r=>r&&r.exact?Pb:new RegExp(`(?:${Lr(r)}${Ie}${Lr(r)})|(?:${Lr(r)}${Ua}${Lr(r)})`,"g");Ml.v4=r=>r&&r.exact?Rb:new RegExp(`${Lr(r)}${Ie}${Lr(r)}`,"g");Ml.v6=r=>r&&r.exact?Ub:new RegExp(`${Lr(r)}${Ua}${Lr(r)}`,"g");var Vl=Ml;function Ol(r){let t=(...e)=>r(...e);return Object.defineProperty(t,"name",{value:`functionTimeout(${r.name||"<anonymous>"})`,configurable:!0}),t}function cm(){return!1}var{toString:Db}=Object.prototype;function $l(r){return Db.call(r)==="[object RegExp]"}var um={global:"g",ignoreCase:"i",multiline:"m",dotAll:"s",sticky:"y",unicode:"u"};function Hl(r,t={}){if(!$l(r))throw new TypeError("Expected a RegExp instance");let e=Object.keys(um).map(o=>(typeof t[o]=="boolean"?t[o]:r[o])?um[o]:"").join(""),n=new RegExp(t.source||r.source,e);return n.lastIndex=typeof t.lastIndex=="number"?t.lastIndex:r.lastIndex,n}function zl(r,t,{timeout:e}={}){try{return Ol(()=>Hl(r).test(t),{timeout:e})()}catch(n){if(cm(n))return!1;throw n}}var Fb=15,Mb=45,lm={timeout:400};function Kl(r){return r.length>Mb?!1:zl(Vl.v6({exact:!0}),r,lm)}function fm(r){return r.length>Fb?!1:zl(Vl.v4({exact:!0}),r,lm)}var hm={http:"80",https:"443",ws:"80",wss:"443"},Vb=["http","https","ws","wss"];function dm(r,t){t=t??{};let e=t.defaultDnsType??"dns4",{scheme:n,hostname:o,port:s}=Ob(r),a="/"+[$b(o,e),Hb(s,n),zb(n)].filter(c=>!!c).reduce((c,u)=>c.concat(u),[]).join("/");return ir(a)}function Ob(r){let[t]=r.split(":");Vb.includes(t)||(r="http"+r.substring(t.length));let{protocol:e,hostname:n,port:o}=new URL(r);if(o==null||o===""){let s=Kb(t);s!=null&&(o=s),s==null&&e==="http:"&&(o="80")}return{scheme:t,hostname:n,port:o}}function $b(r,t){if(!(r==null||r==="")){if(fm(r))return["ip4",r];if(Kl(r))return["ip6",r];if(r[0]==="["){let e=r.substring(1,r.length-1);if(Kl(e))return["ip6",e]}return[t,r]}}function Hb(r,t){if(!(r==null||r===""))return t==="udp"?["udp",r]:["tcp",r]}function zb(r){if(r.match(/^tcp$|^udp$/)==null)return[r]}function Kb(r){if(!(r==null||r===""||hm[r]==null))return hm[r]}var qb=["https://trustless-gateway.link","https://4everland.io"],jb=2336;function Gb(r){return r=r.toString(),{id:wd($.createV1(jb,jt.digest(H(r)))),multiaddrs:[dm(r)]}}var ql=class{gateways;constructor(t={}){this.gateways=(t.gateways??qb).map(e=>Gb(e))}async*findProviders(t,e){yield*this.gateways.toSorted(()=>Math.random()>.5?1:-1).map(n=>({...n,protocols:["transport-ipfs-gateway-http"]}))}};function jl(r={}){return new ql(r)}var Zo=class extends or{data;constructor(){super(),this.data=new Map}put(t,e){return this.data.set(_t.encode(t.multihash.bytes),e),t}get(t){let e=this.data.get(_t.encode(t.multihash.bytes));if(e==null)throw new ce;return e}has(t){return this.data.has(_t.encode(t.multihash.bytes))}async delete(t){this.data.delete(_t.encode(t.multihash.bytes))}async*getAll(){for(let[t,e]of this.data.entries())yield{cid:$.createV1(Jn,de(_t.decode(t))),block:e}}};var oT=Qt("blockstore:core:tiered");var gm="SHARDING";function Zb(r){return r[Symbol.asyncIterator]!=null}function Yb(r){if(Zb(r))return(async()=>{let e=[];for await(let n of r)e.push(n);return e})();let t=[];for(let e of r)t.push(e);return t}var Gl=Yb;function Jb(r){return r[Symbol.asyncIterator]!=null}function Xb(r,t){return Jb(r)?async function*(){yield*(await Gl(r)).sort(t)}():function*(){yield*Gl(r).sort(t)}()}var Da=Xb;var cr=class{put(t,e,n){return Promise.reject(new Error(".put is not implemented"))}get(t,e){return Promise.reject(new Error(".get is not implemented"))}has(t,e){return Promise.reject(new Error(".has is not implemented"))}delete(t,e){return Promise.reject(new Error(".delete is not implemented"))}async*putMany(t,e={}){for await(let{key:n,value:o}of t)await this.put(n,o,e),yield n}async*getMany(t,e={}){for await(let n of t)yield{key:n,value:await this.get(n,e)}}async*deleteMany(t,e={}){for await(let n of t)await this.delete(n,e),yield n}batch(){let t=[],e=[];return{put(n,o){t.push({key:n,value:o})},delete(n){e.push(n)},commit:async n=>{await Dr(this.putMany(t,n)),t=[],await Dr(this.deleteMany(e,n)),e=[]}}}async*_all(t,e){throw new Error("._all is not implemented")}async*_allKeys(t,e){throw new Error("._allKeys is not implemented")}query(t,e){let n=this._all(t,e);if(t.prefix!=null){let o=t.prefix;n=Ae(n,s=>s.key.toString().startsWith(o))}if(Array.isArray(t.filters)&&(n=t.filters.reduce((o,s)=>Ae(o,s),n)),Array.isArray(t.orders)&&(n=t.orders.reduce((o,s)=>Da(o,s),n)),t.offset!=null){let o=0,s=t.offset;n=Ae(n,()=>o++>=s)}return t.limit!=null&&(n=is(n,t.limit)),n}queryKeys(t,e){let n=this._allKeys(t,e);if(t.prefix!=null){let o=t.prefix;n=Ae(n,s=>s.toString().startsWith(o))}if(Array.isArray(t.filters)&&(n=t.filters.reduce((o,s)=>Ae(o,s),n)),Array.isArray(t.orders)&&(n=t.orders.reduce((o,s)=>Da(o,s),n)),t.offset!=null){let o=t.offset,s=0;n=Ae(n,()=>s++>=o)}return t.limit!=null&&(n=is(n,t.limit)),n}};var Yo=class extends cr{data;constructor(){super(),this.data=new Map}put(t,e){return this.data.set(t.toString(),e),t}get(t){let e=this.data.get(t.toString());if(e==null)throw new ce;return e}has(t){return this.data.has(t.toString())}delete(t){this.data.delete(t.toString())}*_all(){for(let[t,e]of this.data.entries())yield{key:new Mt(t),value:e}}*_allKeys(){for(let t of this.data.keys())yield new Mt(t)}};var MT=new Mt(gm);var XT=Qt("datastore:core:tiered");async function Qb(r={}){let t=r.datastore??new Yo,e=r.blockstore??new Zo,n=new aa({...r,datastore:t,blockstore:e,blockBrokers:r.blockBrokers??[Pl()],routers:r.routers??[Fl("https://delegated-ipfs.dev"),jl()]});return r.start!==!1&&await n.start(),n}return Nm(tv);})();
19
19
  /*! Bundled license information:
20
20
 
21
21
  pvtsutils/build/index.js:
@@ -62,9 +62,6 @@ pvtsutils/build/index.js:
62
62
  @noble/curves/esm/ed25519.js:
63
63
  (*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
64
64
 
65
- @noble/hashes/esm/utils.js:
66
- (*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
67
-
68
65
  pvutils/build/utils.es.js:
69
66
  (*!
70
67
  Copyright (c) Peculiar Ventures, LLC