@helia/http 1.0.5-5e98950 → 1.0.5-7419dfc

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.min.js CHANGED
@@ -1,11 +1,22 @@
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 O0=Object.create;var Jo=Object.defineProperty;var F0=Object.getOwnPropertyDescriptor;var V0=Object.getOwnPropertyNames;var M0=Object.getPrototypeOf,$0=Object.prototype.hasOwnProperty;var ge=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),Et=(r,t)=>{for(var e in t)Jo(r,e,{get:t[e],enumerable:!0})},nl=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of V0(t))!$0.call(r,o)&&o!==e&&Jo(r,o,{get:()=>t[o],enumerable:!(n=F0(t,o))||n.enumerable});return r};var Yt=(r,t,e)=>(e=r!=null?O0(M0(r)):{},nl(t||!r||!r.__esModule?Jo(e,"default",{value:r,enumerable:!0}):e,r)),H0=r=>nl(Jo({},"__esModule",{value:!0}),r);var nn=ge((N1,fl)=>{"use strict";function ll(r,t){for(let e in t)Object.defineProperty(r,e,{value:t[e],enumerable:!0,configurable:!0});return r}function tm(r,t,e){if(!r||typeof r=="string")throw new TypeError("Please pass an Error to err-code");e||(e={}),typeof t=="object"&&(e=t,t=""),t&&(e.code=t);try{return ll(r,e)}catch{e.message=r.message,e.stack=r.stack;let o=function(){};return o.prototype=Object.create(Object.getPrototypeOf(r)),ll(new o,e)}}fl.exports=tm});var jl=ge((Ev,Gl)=>{var wn=1e3,bn=wn*60,xn=bn*60,$r=xn*24,yg=$r*7,wg=$r*365.25;Gl.exports=function(r,t){t=t||{};var e=typeof r;if(e==="string"&&r.length>0)return bg(r);if(e==="number"&&isFinite(r))return t.long?Eg(r):xg(r);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(r))};function bg(r){if(r=String(r),!(r.length>100)){var 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){var e=parseFloat(t[1]),n=(t[2]||"ms").toLowerCase();switch(n){case"years":case"year":case"yrs":case"yr":case"y":return e*wg;case"weeks":case"week":case"w":return e*yg;case"days":case"day":case"d":return e*$r;case"hours":case"hour":case"hrs":case"hr":case"h":return e*xn;case"minutes":case"minute":case"mins":case"min":case"m":return e*bn;case"seconds":case"second":case"secs":case"sec":case"s":return e*wn;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return e;default:return}}}}function xg(r){var t=Math.abs(r);return t>=$r?Math.round(r/$r)+"d":t>=xn?Math.round(r/xn)+"h":t>=bn?Math.round(r/bn)+"m":t>=wn?Math.round(r/wn)+"s":r+"ms"}function Eg(r){var t=Math.abs(r);return t>=$r?ds(r,t,$r,"day"):t>=xn?ds(r,t,xn,"hour"):t>=bn?ds(r,t,bn,"minute"):t>=wn?ds(r,t,wn,"second"):r+" ms"}function ds(r,t,e,n){var o=t>=e*1.5;return Math.round(r/e)+" "+n+(o?"s":"")}});var Yl=ge((vv,Wl)=>{function vg(r){e.debug=e,e.default=e,e.coerce=c,e.disable=s,e.enable=o,e.enabled=i,e.humanize=jl(),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 m=0;m<f.length;m++)l=(l<<5)-l+f.charCodeAt(m),l|=0;return e.colors[Math.abs(l)%e.colors.length]}e.selectColor=t;function e(f){let l,m=null,h,p;function d(...w){if(!d.enabled)return;let g=d,x=Number(new Date),b=x-(l||x);g.diff=b,g.prev=l,g.curr=x,l=x,w[0]=e.coerce(w[0]),typeof w[0]!="string"&&w.unshift("%O");let B=0;w[0]=w[0].replace(/%([a-zA-Z%])/g,(I,v)=>{if(I==="%%")return"%";B++;let E=e.formatters[v];if(typeof E=="function"){let U=w[B];I=E.call(g,U),w.splice(B,1),B--}return I}),e.formatArgs.call(g,w),(g.log||e.log).apply(g,w)}return d.namespace=f,d.useColors=e.useColors(),d.color=e.selectColor(f),d.extend=n,d.destroy=e.destroy,Object.defineProperty(d,"enabled",{enumerable:!0,configurable:!1,get:()=>m!==null?m:(h!==e.namespaces&&(h=e.namespaces,p=e.enabled(f)),p),set:w=>{m=w}}),typeof e.init=="function"&&e.init(d),d}function n(f,l){let m=e(this.namespace+(typeof l>"u"?":":l)+f);return m.log=this.log,m}function o(f){e.save(f),e.namespaces=f,e.names=[],e.skips=[];let l,m=(typeof f=="string"?f:"").split(/[\s,]+/),h=m.length;for(l=0;l<h;l++)m[l]&&(f=m[l].replace(/\*/g,".*?"),f[0]==="-"?e.skips.push(new RegExp("^"+f.slice(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,m;for(l=0,m=e.skips.length;l<m;l++)if(e.skips[l].test(f))return!1;for(l=0,m=e.names.length;l<m;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.enable(e.load()),e}Wl.exports=vg});var Zl=ge((Jt,ps)=>{Jt.formatArgs=Bg;Jt.save=kg;Jt.load=Sg;Jt.useColors=Ag;Jt.storage=Ig();Jt.destroy=(()=>{let r=!1;return()=>{r||(r=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})();Jt.colors=["#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 Ag(){return typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs)?!0:typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)?!1:typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function Bg(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+ps.exports.humanize(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)}Jt.log=console.debug||console.log||(()=>{});function kg(r){try{r?Jt.storage.setItem("debug",r):Jt.storage.removeItem("debug")}catch{}}function Sg(){let r;try{r=Jt.storage.getItem("debug")}catch{}return!r&&typeof process<"u"&&"env"in process&&(r=process.env.DEBUG),r}function Ig(){try{return localStorage}catch{}}ps.exports=Yl()(Jt);var{formatters:_g}=ps.exports;_g.j=function(r){try{return JSON.stringify(r)}catch(t){return"[UnexpectedJSONParseError]: "+t.message}}});var Ql=ge((Iv,hc)=>{"use strict";var Tg=Object.prototype.hasOwnProperty,$t="~";function ho(){}Object.create&&(ho.prototype=Object.create(null),new ho().__proto__||($t=!1));function Cg(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function Xl(r,t,e,n,o){if(typeof e!="function")throw new TypeError("The listener must be a function");var s=new Cg(e,n||r,o),i=$t?$t+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 ms(r,t){--r._eventsCount===0?r._events=new ho:delete r._events[t]}function Ft(){this._events=new ho,this._eventsCount=0}Ft.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)Tg.call(e,n)&&t.push($t?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};Ft.prototype.listeners=function(t){var e=$t?$t+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=$t?$t+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=$t?$t+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 m=c.length,h;for(l=0;l<m;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 Xl(this,t,e,n,!1)};Ft.prototype.once=function(t,e,n){return Xl(this,t,e,n,!0)};Ft.prototype.removeListener=function(t,e,n,o){var s=$t?$t+t:t;if(!this._events[s])return this;if(!e)return ms(this,s),this;var i=this._events[s];if(i.fn)i.fn===e&&(!o||i.once)&&(!n||i.context===n)&&ms(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:ms(this,s)}return this};Ft.prototype.removeAllListeners=function(t){var e;return t?(e=$t?$t+t:t,this._events[e]&&ms(this,e)):(this._events=new ho,this._eventsCount=0),this};Ft.prototype.off=Ft.prototype.removeListener;Ft.prototype.addListener=Ft.prototype.on;Ft.prefixed=$t;Ft.EventEmitter=Ft;typeof hc<"u"&&(hc.exports=Ft)});var of=ge((Zv,nf)=>{nf.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 wd=ge(zn=>{"use strict";var Qw="[object ArrayBuffer]",rr=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Qw}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}},iu="string",tb=/^[0-9a-f]+$/i,eb=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,rb=/^[a-zA-Z0-9-_]+$/,oi=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=rr.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return decodeURIComponent(escape(n))}},pe=class{static toString(t,e=!1){let n=rr.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}},si=class r{static isHex(t){return typeof t===iu&&tb.test(t)}static isBase64(t){return typeof t===iu&&eb.test(t)}static isBase64Url(t){return typeof t===iu&&rb.test(t)}static ToString(t,e="utf8"){let n=rr.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 pe.toString(n,!0);case"utf16":case"utf16be":return pe.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 pe.fromString(t,!0);case"utf16":case"utf16be":return pe.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=rr.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 oi.fromString(t);case"utf16":case"utf16be":return pe.fromString(t);case"utf16le":case"usc2":return pe.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 oi.toString(t);case"utf16":case"utf16be":return pe.toString(t);case"utf16le":case"usc2":return pe.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=rr.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return n}static ToHex(t){let e=rr.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 pe.toString(t,e)}static FromUtf16String(t,e=!1){return pe.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,"")||""}};si.DEFAULT_UTF8_ENCODING="utf8";function nb(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 ob(...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 sb(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}zn.BufferSourceConverter=rr;zn.Convert=si;zn.assign=nb;zn.combine=ob;zn.isEqual=sb});var Ap=ge((Ho,Wi)=>{(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 p=0;p<h.length;p++)if(!Number.isInteger(h[p])||h[p]<0||h[p]>255)return!1;return!0}function o(h,p){return(h&65535)*p+(((h>>>16)*p&65535)<<16)}function s(h,p){return h<<p|h>>>32-p}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,p){h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535],p=[p[0]>>>16,p[0]&65535,p[1]>>>16,p[1]&65535];var d=[0,0,0,0];return d[3]+=h[3]+p[3],d[2]+=d[3]>>>16,d[3]&=65535,d[2]+=h[2]+p[2],d[1]+=d[2]>>>16,d[2]&=65535,d[1]+=h[1]+p[1],d[0]+=d[1]>>>16,d[1]&=65535,d[0]+=h[0]+p[0],d[0]&=65535,[d[0]<<16|d[1],d[2]<<16|d[3]]}function c(h,p){h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535],p=[p[0]>>>16,p[0]&65535,p[1]>>>16,p[1]&65535];var d=[0,0,0,0];return d[3]+=h[3]*p[3],d[2]+=d[3]>>>16,d[3]&=65535,d[2]+=h[2]*p[3],d[1]+=d[2]>>>16,d[2]&=65535,d[2]+=h[3]*p[2],d[1]+=d[2]>>>16,d[2]&=65535,d[1]+=h[1]*p[3],d[0]+=d[1]>>>16,d[1]&=65535,d[1]+=h[2]*p[2],d[0]+=d[1]>>>16,d[1]&=65535,d[1]+=h[3]*p[1],d[0]+=d[1]>>>16,d[1]&=65535,d[0]+=h[0]*p[3]+h[1]*p[2]+h[2]*p[1]+h[3]*p[0],d[0]&=65535,[d[0]<<16|d[1],d[2]<<16|d[3]]}function u(h,p){return p%=64,p===32?[h[1],h[0]]:p<32?[h[0]<<p|h[1]>>>32-p,h[1]<<p|h[0]>>>32-p]:(p-=32,[h[1]<<p|h[0]>>>32-p,h[0]<<p|h[1]>>>32-p])}function f(h,p){return p%=64,p===0?h:p<32?[h[0]<<p|h[1]>>>32-p,h[1]<<p]:[h[1]<<p-32,0]}function l(h,p){return[h[0]^p[0],h[1]^p[1]]}function m(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,p){if(e.inputValidation&&!n(h))return t;p=p||0;for(var d=h.length%4,w=h.length-d,g=p,x=0,b=3432918353,B=461845907,A=0;A<w;A=A+4)x=h[A]|h[A+1]<<8|h[A+2]<<16|h[A+3]<<24,x=o(x,b),x=s(x,15),x=o(x,B),g^=x,g=s(g,13),g=o(g,5)+3864292196;switch(x=0,d){case 3:x^=h[A+2]<<16;case 2:x^=h[A+1]<<8;case 1:x^=h[A],x=o(x,b),x=s(x,15),x=o(x,B),g^=x}return g^=h.length,g=i(g),g>>>0},e.x86.hash128=function(h,p){if(e.inputValidation&&!n(h))return t;p=p||0;for(var d=h.length%16,w=h.length-d,g=p,x=p,b=p,B=p,A=0,I=0,v=0,E=0,U=597399067,P=2869860233,N=951274213,M=2716044179,C=0;C<w;C=C+16)A=h[C]|h[C+1]<<8|h[C+2]<<16|h[C+3]<<24,I=h[C+4]|h[C+5]<<8|h[C+6]<<16|h[C+7]<<24,v=h[C+8]|h[C+9]<<8|h[C+10]<<16|h[C+11]<<24,E=h[C+12]|h[C+13]<<8|h[C+14]<<16|h[C+15]<<24,A=o(A,U),A=s(A,15),A=o(A,P),g^=A,g=s(g,19),g+=x,g=o(g,5)+1444728091,I=o(I,P),I=s(I,16),I=o(I,N),x^=I,x=s(x,17),x+=b,x=o(x,5)+197830471,v=o(v,N),v=s(v,17),v=o(v,M),b^=v,b=s(b,15),b+=B,b=o(b,5)+2530024501,E=o(E,M),E=s(E,18),E=o(E,U),B^=E,B=s(B,13),B+=g,B=o(B,5)+850148119;switch(A=0,I=0,v=0,E=0,d){case 15:E^=h[C+14]<<16;case 14:E^=h[C+13]<<8;case 13:E^=h[C+12],E=o(E,M),E=s(E,18),E=o(E,U),B^=E;case 12:v^=h[C+11]<<24;case 11:v^=h[C+10]<<16;case 10:v^=h[C+9]<<8;case 9:v^=h[C+8],v=o(v,N),v=s(v,17),v=o(v,M),b^=v;case 8:I^=h[C+7]<<24;case 7:I^=h[C+6]<<16;case 6:I^=h[C+5]<<8;case 5:I^=h[C+4],I=o(I,P),I=s(I,16),I=o(I,N),x^=I;case 4:A^=h[C+3]<<24;case 3:A^=h[C+2]<<16;case 2:A^=h[C+1]<<8;case 1:A^=h[C],A=o(A,U),A=s(A,15),A=o(A,P),g^=A}return g^=h.length,x^=h.length,b^=h.length,B^=h.length,g+=x,g+=b,g+=B,x+=g,b+=g,B+=g,g=i(g),x=i(x),b=i(b),B=i(B),g+=x,g+=b,g+=B,x+=g,b+=g,B+=g,("00000000"+(g>>>0).toString(16)).slice(-8)+("00000000"+(x>>>0).toString(16)).slice(-8)+("00000000"+(b>>>0).toString(16)).slice(-8)+("00000000"+(B>>>0).toString(16)).slice(-8)},e.x64.hash128=function(h,p){if(e.inputValidation&&!n(h))return t;p=p||0;for(var d=h.length%16,w=h.length-d,g=[0,p],x=[0,p],b=[0,0],B=[0,0],A=[2277735313,289559509],I=[1291169091,658871167],v=0;v<w;v=v+16)b=[h[v+4]|h[v+5]<<8|h[v+6]<<16|h[v+7]<<24,h[v]|h[v+1]<<8|h[v+2]<<16|h[v+3]<<24],B=[h[v+12]|h[v+13]<<8|h[v+14]<<16|h[v+15]<<24,h[v+8]|h[v+9]<<8|h[v+10]<<16|h[v+11]<<24],b=c(b,A),b=u(b,31),b=c(b,I),g=l(g,b),g=u(g,27),g=a(g,x),g=a(c(g,[0,5]),[0,1390208809]),B=c(B,I),B=u(B,33),B=c(B,A),x=l(x,B),x=u(x,31),x=a(x,g),x=a(c(x,[0,5]),[0,944331445]);switch(b=[0,0],B=[0,0],d){case 15:B=l(B,f([0,h[v+14]],48));case 14:B=l(B,f([0,h[v+13]],40));case 13:B=l(B,f([0,h[v+12]],32));case 12:B=l(B,f([0,h[v+11]],24));case 11:B=l(B,f([0,h[v+10]],16));case 10:B=l(B,f([0,h[v+9]],8));case 9:B=l(B,[0,h[v+8]]),B=c(B,I),B=u(B,33),B=c(B,A),x=l(x,B);case 8:b=l(b,f([0,h[v+7]],56));case 7:b=l(b,f([0,h[v+6]],48));case 6:b=l(b,f([0,h[v+5]],40));case 5:b=l(b,f([0,h[v+4]],32));case 4:b=l(b,f([0,h[v+3]],24));case 3:b=l(b,f([0,h[v+2]],16));case 2:b=l(b,f([0,h[v+1]],8));case 1:b=l(b,[0,h[v]]),b=c(b,A),b=u(b,31),b=c(b,I),g=l(g,b)}return g=l(g,[0,h.length]),x=l(x,[0,h.length]),g=a(g,x),x=a(x,g),g=m(g),x=m(x),g=a(g,x),x=a(x,g),("00000000"+(g[0]>>>0).toString(16)).slice(-8)+("00000000"+(g[1]>>>0).toString(16)).slice(-8)+("00000000"+(x[0]>>>0).toString(16)).slice(-8)+("00000000"+(x[1]>>>0).toString(16)).slice(-8)},typeof Ho<"u"?(typeof Wi<"u"&&Wi.exports&&(Ho=Wi.exports=e),Ho.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)})(Ho)});var kp=ge((IS,Bp)=>{Bp.exports=Ap()});var Ip=ge(qo=>{(function(){var r,t,e,n,o,s,i,a;a=function(c){var u,f,l,m;return u=(c&255<<24)>>>24,f=(c&255<<16)>>>16,l=(c&65280)>>>8,m=c&255,[u,f,l,m].join(".")},i=function(c){var u,f,l,m,h,p;for(u=[],l=m=0;m<=3&&c.length!==0;l=++m){if(l>0){if(c[0]!==".")throw new Error("Invalid IP");c=c.substring(1)}p=t(c),h=p[0],f=p[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,m,h;for(m=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)m=m*u+(e(c[l])-n)>>>0;else if(u===16)if("a"<=c[l]&&c[l]<="f")m=m*u+(10+e(c[l])-s)>>>0;else if("A"<=c[l]&&c[l]<="F")m=m*u+(10+e(c[l])-o)>>>0;else break;else break;if(m>4294967295)throw new Error("too large");l++}if(l===h)throw new Error("empty octet");return[m,l]},r=function(){function c(u,f){var l,m,h,p;if(typeof u!="string")throw new Error("Missing `net' parameter");if(f||(p=u.split("/",2),u=p[0],f=p[1]),f||(f=32),typeof f=="string"&&f.indexOf(".")>-1){try{this.maskLong=i(f)}catch(d){throw l=d,new Error("Invalid mask: "+f)}for(m=h=32;h>=0;m=--h)if(this.maskLong===4294967295<<32-m>>>0){this.bitmask=m;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(d){throw l=d,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,m;for(m=i(this.first),l=i(this.last),f=0;m<=l;)u(a(m),m,f),f++,m++},c.prototype.toString=function(){return this.base+"/"+this.bitmask},c}(),qo.ip2long=i,qo.long2ip=a,qo.Netmask=r}).call(qo)});var Ku=ge((m4,Hu)=>{var p4=function(){typeof Hu<"u"&&(Hu.exports=d);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(E){var U=E-E%1;return U==0&&(E<0||E===0&&1/E!=1/0)?-0:U},f=d.prototype,l=(d.fromDate=function(E){return new d(+E)},d.fromInt64BE=B(0,1,2,3,0,4),d.fromInt64LE=B(3,2,1,0,4,0),d.fromString=function(N){var U,P=new d,N=(N+="").replace(/^\s*[+\-]?\d+/,function(C){var C=+C,X=1970+(C-1970)%400;return P.year=C-X,X}).replace(/(?:Z|([+\-]\d{2}):?(\d{2}))$/,function(M,C,X){return C<0&&(X*=-1),U=6e4*(60*+C+ +X),""}).replace(/\.\d+$/,function(M){return P.nano=+(M+c).substr(1,9),""}).split(/\D+/);if(1<N.length?N[1]--:N[1]=0,P.time=U=Date.UTC.apply(Date,N)-(U||0),isNaN(U))throw new TypeError("Invalid Date");return w(P)},d.fromTimeT=function(E){return x(E,0)},f.year=0,f.time=0,f.nano=0,f.addNano=function(E){return this.nano+=+E||0,this},f.getNano=function(){var E=w(this);return(E.time%1e3*a+ +E.nano+1e9)%1e9},f.getTimeT=function(){var U=w(this),E=Math.floor(U.time/1e3),U=U.year;return U&&(E+=U*e*r/t),E},f.getYear=function(){return this.toDate().getUTCFullYear()+this.year},f.toDate=function(){return g(w(this).time)},f.toJSON=function(){return this.toString().replace(/0{1,6}Z$/,"Z")},f.toString=function(E){var U=this,P=U.toDate(),N={H:function(){return I(P.getUTCHours())},L:function(){return v(P.getUTCMilliseconds(),3)},M:function(){return I(P.getUTCMinutes())},N:function(){return v(U.getNano(),9)},S:function(){return I(P.getUTCSeconds())},Y:function(){var M=U.getYear();return 999999<M?"+"+M:9999<M?"+"+v(M,6):0<=M?v(M,4):-999999<=M?"-"+v(-M,6):M},a:function(){return h[P.getUTCDay()]},b:function(){return m[P.getUTCMonth()]},d:function(){return I(P.getUTCDate())},e:function(){return function(M){return(9<M?"":" ")+(0|M)}(P.getUTCDate())},m:function(){return I(P.getUTCMonth()+1)}};return function M(C){return C.replace(/%./g,function(X){var T=X[1],S=p[T],T=N[T];return S?M(S):T?T():X})}(E||l)},f.writeInt64BE=b(0,1,2,3,0,4),f.writeInt64LE=b(3,2,1,0,4,0),"%Y-%m-%dT%H:%M:%S.%NZ"),m=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],h=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],p={"%":"%",F:"%Y-%m-%d",n:`
3
- `,R:"%H:%M",T:"%H:%M:%S",t:" ",X:"%T",Z:"GMT",z:"+0000"};return d;function d(E,U,P){var N=this;if(!(N instanceof d))return new d(E,U,P);N.time=+E||0,N.nano=+U||0,N.year=+P||0,w(N)}function w(E){var U,P,N,M=E.year,C=E.time,X=E.nano,S=((X<0||a<=X)&&(X-=(P=Math.floor(X/a))*a,C+=P,P=1),M%t);return(C<-s||s<C||S)&&((U=u(C/o))&&(M+=U*t,C-=U*o),(N=g(C)).setUTCFullYear(S+N.getUTCFullYear()),N=(C=+N)+(U=u((M-=S)/t))*o,U&&-s<=N&&N<=s&&(M-=U*t,C=N),P=1),P&&(E.year=M,E.time=C,E.nano=X),E}function g(E){var U=new Date(0);return U.setTime(E),U}function x(M,N){M=+M||0;var P=u((N=(N|0)*i)/n)+u(M/n),N=N%n+M%n,M=u(N/n);return M&&(P+=M,N-=M*n),new d(1e3*N,0,P*t)}function b(E,U,P,N,M,C){return function(S,T){var R=w(this);S=S||new Array(8),A(S,T|=0);var k=Math.floor(R.time/1e3),R=R.year*(e*r/t),H=u(R/i)+u(k/i),R=R%i+k%i,k=Math.floor(R/i);return k&&(H+=k,R-=k*i),X(S,T+M,H),X(S,T+C,R),S};function X(S,T,H){S[T+E]=H>>24&255,S[T+U]=H>>16&255,S[T+P]=H>>8&255,S[T+N]=255&H}}function B(E,U,P,N,M,C){return function(S,T){A(S,T|=0);var H=X(S,T+M);return x(X(S,T+C),H)};function X(S,T){return 16777216*S[T+E]+(S[T+U]<<16|S[T+P]<<8|S[T+N])}}function A(E,U){if(E=E&&E.length,E==null)throw new TypeError("Invalid Buffer");if(E<U+8)throw new RangeError("Out of range")}function I(E){return(9<E?"":"0")+(0|E)}function v(E,U){return(c+(0|E)).substr(-U)}}()});var $x={};Et($x,{DEFAULT_SESSION_MAX_PROVIDERS:()=>qh,DEFAULT_SESSION_MIN_PROVIDERS:()=>Kh,createHeliaHTTP:()=>Mx});var ro=Symbol.for("@libp2p/content-routing");var wa=Symbol.for("@libp2p/peer-id");function ol(r){return r!=null&&!!r[wa]}var no=Symbol.for("@libp2p/peer-routing");var fr=class r extends Error{code;type;constructor(t="The operation was aborted"){super(t),this.name="AbortError",this.code=r.code,this.type=r.type}static code="ABORT_ERR";static type="aborted"},D=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var ft=(r,...t)=>{try{[...t]}catch{}};var tn=class extends EventTarget{#t=new Map;constructor(){super(),ft(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 K0(t,e))}},ba=class extends Event{detail;constructor(t,e){super(t,e),this.detail=e?.detail}},K0=globalThis.CustomEvent??ba;function sl(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function hr(...r){let t=[];for(let e of r)sl(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 dr(...r){let t=[];for(let e of r)sl(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 Mt(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 Bt(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Xo=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}},en=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Xo(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 Xo(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 xa=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Dr(r={}){return q0(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 q0(r,t){t=t??{};let e=t.onEnd,n=new en,o,s,i,a=Bt(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((w,g)=>{s=x=>{s=null,n.push(x);try{w(r(n))}catch(b){g(b)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Bt()})}},u=w=>s!=null?s(w):(n.push(w),o),f=w=>(n=new en,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})},m=w=>i?o:(i=!0,w!=null?f(w):u({done:!0})),h=()=>(n=new en,m(),{done:!0}),p=w=>(m(w),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:h,throw:p,push:l,end:m,get readableLength(){return n.size},onEmpty:async w=>{let g=w?.signal;if(g?.throwIfAborted(),n.isEmpty())return;let x,b;g!=null&&(x=new Promise((B,A)=>{b=()=>{A(new xa)},g.addEventListener("abort",b)}));try{await Promise.race([a.promise,x])}finally{b!=null&&g!=null&&g?.removeEventListener("abort",b)}}},e==null)return o;let d=o;return o={[Symbol.asyncIterator](){return this},next(){return d.next()},throw(w){return d.throw(w),e!=null&&(e(w),e=void 0),{done:!0}},return(){return d.return(),e!=null&&(e(),e=void 0),{done:!0}},push:l,end(w){return d.end(w),e!=null&&(e(w),e=void 0),o},get readableLength(){return d.readableLength},onEmpty:w=>d.onEmpty(w)},o}var Ea=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 Qo(r,t,e,n){let o=new Ea(n?.errorMessage,n?.errorCode);return e?.aborted===!0?Promise.reject(o):new Promise((s,i)=>{let a=u=>{try{if(n?.filter?.(u)===!1)return}catch(f){r.removeEventListener(t,a),e?.removeEventListener("abort",c),i(f);return}r.removeEventListener(t,a),e?.removeEventListener("abort",c),s(u)},c=()=>{r.removeEventListener(t,a),e?.removeEventListener("abort",c),i(o)};r.addEventListener(t,a),e?.addEventListener("abort",c)})}var ts=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 il(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new ts(e?.errorMessage,e?.errorCode));let n,o=new ts(e?.errorMessage,e?.errorCode);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 es=class{deferred;signal;where;constructor(t,e){this.signal=e,this.deferred=Bt(),this.where=t,this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new fr)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function z0(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var rs=class{id;fn;options;priority;recipients;status;timeline;controller;constructor(t,e,n=0){this.id=z0(),this.status="queued",this.fn=t,this.priority=n,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,ft(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 fr),this.cleanup())}async join(t={}){let e=new es(new Error("where").stack,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 il(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)})}};function G0(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 He=class extends tn{concurrency;queue;pending;constructor(t={}){super(),this.concurrency=t.concurrency??Number.POSITIVE_INFINITY,this.pending=0,t.metricName!=null&&t.metrics?.registerMetricGroup(t.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.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){if(this.queue[this.size-1]?.priority>=t.priority){this.queue.push(t);return}let e=G0(this.queue,t,(n,o)=>o.priority-n.priority);this.queue.splice(e,0,t)}async add(t,e){e?.signal?.throwIfAborted();let n=new rs(t,e,e?.priority),o=n.join(e).then(s=>(this.safeDispatchEvent("completed",{detail:s}),this.safeDispatchEvent("success",{detail:{job:n,result:s}}),s)).catch(s=>{if(n.status==="queued"){for(let i=0;i<this.queue.length;i++)if(this.queue[i]===n){this.queue.splice(i,1);break}}throw this.safeDispatchEvent("error",{detail:s}),this.safeDispatchEvent("failure",{detail:{job:n,error:s}}),s});return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),o}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(t=>{t.abort(new fr)}),this.clear()}async onEmpty(t){this.size!==0&&await Qo(this,"empty",t?.signal)}async onSizeLessThan(t,e){this.size<t||await Qo(this,"next",e?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await Qo(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=Dr({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 D("Queue aborted","ERR_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 ns=class extends He{has(t){return this.find(t)!=null}find(t){return this.queue.find(e=>t.equals(e.options.peerId))}};function j0(r){return r[Symbol.asyncIterator]!=null}function W0(r){if(j0(r))return(async()=>{for await(let t of r);})();for(let t of r);}var Pr=W0;function ye(r=0){return new Uint8Array(r)}function zt(r=0){return new Uint8Array(r)}var Y0=Math.pow(2,7),Z0=Math.pow(2,14),J0=Math.pow(2,21),va=Math.pow(2,28),Aa=Math.pow(2,35),Ba=Math.pow(2,42),ka=Math.pow(2,49),ot=128,Pt=127;function Gt(r){if(r<Y0)return 1;if(r<Z0)return 2;if(r<J0)return 3;if(r<va)return 4;if(r<Aa)return 5;if(r<Ba)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 Sa(r,t,e=0){switch(Gt(r)){case 8:t[e++]=r&255|ot,r/=128;case 7:t[e++]=r&255|ot,r/=128;case 6:t[e++]=r&255|ot,r/=128;case 5:t[e++]=r&255|ot,r/=128;case 4:t[e++]=r&255|ot,r>>>=7;case 3:t[e++]=r&255|ot,r>>>=7;case 2:t[e++]=r&255|ot,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function X0(r,t,e=0){switch(Gt(r)){case 8:t.set(e++,r&255|ot),r/=128;case 7:t.set(e++,r&255|ot),r/=128;case 6:t.set(e++,r&255|ot),r/=128;case 5:t.set(e++,r&255|ot),r/=128;case 4:t.set(e++,r&255|ot),r>>>=7;case 3:t.set(e++,r&255|ot),r>>>=7;case 2:t.set(e++,r&255|ot),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Ia(r,t){let e=r[t],n=0;if(n+=e&Pt,e<ot||(e=r[t+1],n+=(e&Pt)<<7,e<ot)||(e=r[t+2],n+=(e&Pt)<<14,e<ot)||(e=r[t+3],n+=(e&Pt)<<21,e<ot)||(e=r[t+4],n+=(e&Pt)*va,e<ot)||(e=r[t+5],n+=(e&Pt)*Aa,e<ot)||(e=r[t+6],n+=(e&Pt)*Ba,e<ot)||(e=r[t+7],n+=(e&Pt)*ka,e<ot))return n;throw new RangeError("Could not decode varint")}function Q0(r,t){let e=r.get(t),n=0;if(n+=e&Pt,e<ot||(e=r.get(t+1),n+=(e&Pt)<<7,e<ot)||(e=r.get(t+2),n+=(e&Pt)<<14,e<ot)||(e=r.get(t+3),n+=(e&Pt)<<21,e<ot)||(e=r.get(t+4),n+=(e&Pt)*va,e<ot)||(e=r.get(t+5),n+=(e&Pt)*Aa,e<ot)||(e=r.get(t+6),n+=(e&Pt)*Ba,e<ot)||(e=r.get(t+7),n+=(e&Pt)*ka,e<ot))return n;throw new RangeError("Could not decode varint")}function rn(r,t,e=0){return t==null&&(t=zt(Gt(r))),t instanceof Uint8Array?Sa(r,t,e):X0(r,t,e)}function Or(r,t=0){return r instanceof Uint8Array?Ia(r,t):Q0(r,t)}function kt(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=zt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}function it(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}var ul=Symbol.for("@achingbrain/uint8arraylist");function cl(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let o=e+n.byteLength;if(t<o)return{buf:n,index:t-e};e=o}throw new RangeError("index is out of bounds")}function os(r){return!!r?.[ul]}var ss=class r{bufs;length;[ul]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(os(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(os(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=cl(this.bufs,t);return e.buf[e.index]}set(t,e){let n=cl(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(os(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:o}=this._subList(t,e);return kt(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:kt(n,o)}sublist(t,e){let{bufs:n,length:o}=this._subList(t,e),s=new r;return s.length=o,s.bufs=[...n],s}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],o=0;for(let s=0;s<this.bufs.length;s++){let i=this.bufs[s],a=o,c=a+i.byteLength;if(o=c,t>=c)continue;let u=t>=a&&t<c,f=e>a&&e<=c;if(u&&f){if(t===a&&e===c){n.push(i);break}let l=t-a;n.push(i.subarray(l,l+(e-t)));break}if(u){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(f){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!os(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let s=256,i=new Int32Array(s);for(let l=0;l<s;l++)i[l]=-1;for(let l=0;l<o;l++)i[n[l]]=l;let a=i,c=this.byteLength-n.byteLength,u=n.byteLength-1,f;for(let l=e;l<=c;l+=f){f=0;for(let m=u;m>=0;m--){let h=this.get(l+m);if(n[m]!==h){f=Math.max(1,m-a[h]);break}}if(f===0)return l}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=zt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let o=ye(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,e,n),this.write(o,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let o=ye(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,e,n),this.write(o,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let o=ye(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,e,n),this.write(o,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=zt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let o=ye(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,e,n),this.write(o,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let o=ye(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,e,n),this.write(o,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let o=ye(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,e,n),this.write(o,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let o=ye(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,e,n),this.write(o,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let o=ye(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,e,n),this.write(o,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!it(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((o,s)=>o+s.byteLength,0)),n.length=e,n}};function em(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 on=em;function rm(r){return r[Symbol.asyncIterator]!=null}function nm(r,t){if(rm(r))return async function*(){for await(let a of r)yield t(a)}();let e=on(r),{value:n,done:o}=e.next();if(o===!0)return function*(){}();let s=t(n);if(typeof s.then=="function")return async function*(){yield await s;for await(let a of e)yield t(a)}();let i=t;return function*(){yield s;for(let a of e)yield i(a)}()}var sn=nm;function om(r){return r[Symbol.asyncIterator]!=null}function sm(...r){let t=[];for(let e of r)om(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Dr({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 Fr=sm;function im(r){return r[Symbol.asyncIterator]!=null}function am(r,t){return im(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=am;var rt=class extends Event{constructor(t,e){super(t),this.detail=e}};var _a=new Float32Array([-0]),pr=new Uint8Array(_a.buffer);function hl(r,t,e){_a[0]=r,t[e]=pr[0],t[e+1]=pr[1],t[e+2]=pr[2],t[e+3]=pr[3]}function dl(r,t){return pr[0]=r[t],pr[1]=r[t+1],pr[2]=r[t+2],pr[3]=r[t+3],_a[0]}var Ra=new Float64Array([-0]),Ot=new Uint8Array(Ra.buffer);function pl(r,t,e){Ra[0]=r,t[e]=Ot[0],t[e+1]=Ot[1],t[e+2]=Ot[2],t[e+3]=Ot[3],t[e+4]=Ot[4],t[e+5]=Ot[5],t[e+6]=Ot[6],t[e+7]=Ot[7]}function ml(r,t){return Ot[0]=r[t],Ot[1]=r[t+1],Ot[2]=r[t+2],Ot[3]=r[t+3],Ot[4]=r[t+4],Ot[5]=r[t+5],Ot[6]=r[t+6],Ot[7]=r[t+7],Ra[0]}var cm=BigInt(Number.MAX_SAFE_INTEGER),um=BigInt(Number.MIN_SAFE_INTEGER),Zt=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<cm&&t>um)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>gl&&(o=0n,++n>gl&&(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 Zt(0,0);Vr.toBigInt=function(){return 0n};Vr.zzEncode=Vr.zzDecode=function(){return this};Vr.length=function(){return 1};var gl=4294967296n;function yl(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 wl(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 Ta(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 we(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 Ca=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,we(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 we(this,4);return as(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw we(this,4);return as(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw we(this,4);let t=dl(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw we(this,4);let t=ml(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 we(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return wl(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw we(this,t);this.pos+=t}else do if(this.pos>=this.len)throw we(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 Zt(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 we(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 we(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 we(this,8);let t=as(this.buf,this.pos+=4),e=as(this.buf,this.pos+=4);return new Zt(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=Ia(this.buf,this.pos);return this.pos+=Gt(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 Na(r){return new Ca(r instanceof Uint8Array?r:r.subarray())}function an(r,t,e){let n=Na(r);return t.decode(n,void 0,e)}var Oa={};Et(Oa,{base10:()=>mm});var J1=new Uint8Array(0);function xl(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 Ke(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 El(r){return new TextEncoder().encode(r)}function vl(r){return new TextDecoder().decode(r)}function lm(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(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var d=0,w=0,g=0,x=p.length;g!==x&&p[g]===0;)g++,d++;for(var b=(x-g)*f+1>>>0,B=new Uint8Array(b);g!==x;){for(var A=p[g],I=0,v=b-1;(A!==0||I<w)&&v!==-1;v--,I++)A+=256*B[v]>>>0,B[v]=A%a>>>0,A=A/a>>>0;if(A!==0)throw new Error("Non-zero carry");w=I,g++}for(var E=b-w;E!==b&&B[E]===0;)E++;for(var U=c.repeat(d);E<b;++E)U+=r.charAt(B[E]);return U}function m(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var d=0;if(p[d]!==" "){for(var w=0,g=0;p[d]===c;)w++,d++;for(var x=(p.length-d)*u+1>>>0,b=new Uint8Array(x);p[d];){var B=e[p.charCodeAt(d)];if(B===255)return;for(var A=0,I=x-1;(B!==0||A<g)&&I!==-1;I--,A++)B+=a*b[I]>>>0,b[I]=B%256>>>0,B=B/256>>>0;if(B!==0)throw new Error("Non-zero carry");g=A,d++}if(p[d]!==" "){for(var v=x-g;v!==x&&b[v]===0;)v++;for(var E=new Uint8Array(w+(x-v)),U=w;v!==x;)E[U++]=b[v++];return E}}}function h(p){var d=m(p);if(d)return d;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:m,decode:h}}var fm=lm,hm=fm,Bl=hm;var La=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")}},Ua=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return kl(this,t)}},Da=class{decoders;constructor(t){this.decoders=t}or(t){return kl(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 kl(r,t){return new Da({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Pa=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 La(t,e,n),this.decoder=new Ua(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function cn({name:r,prefix:t,encode:e,decode:n}){return new Pa(r,t,e,n)}function mr({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Bl(e,r);return cn({prefix:t,name:r,encode:n,decode:s=>Ke(o(s))})}function dm(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 pm(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 pt({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return cn({prefix:t,name:r,encode(o){return pm(o,n,e)},decode(o){return dm(o,n,e,r)}})}var mm=mr({prefix:"9",name:"base10",alphabet:"0123456789"});var Fa={};Et(Fa,{base16:()=>gm,base16upper:()=>ym});var gm=pt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),ym=pt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Va={};Et(Va,{base2:()=>wm});var wm=pt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ma={};Et(Ma,{base256emoji:()=>Am});var Sl=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}"),bm=Sl.reduce((r,t,e)=>(r[e]=t,r),[]),xm=Sl.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Em(r){return r.reduce((t,e)=>(t+=bm[e],t),"")}function vm(r){let t=[];for(let e of r){let n=xm[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Am=cn({prefix:"\u{1F680}",name:"base256emoji",encode:Em,decode:vm});var $a={};Et($a,{base32:()=>Tt,base32hex:()=>Sm,base32hexpad:()=>_m,base32hexpadupper:()=>Rm,base32hexupper:()=>Im,base32pad:()=>Bm,base32padupper:()=>km,base32upper:()=>Il,base32z:()=>Tm});var Tt=pt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Il=pt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Bm=pt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),km=pt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Sm=pt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Im=pt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),_m=pt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Rm=pt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Tm=pt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ha={};Et(Ha,{base36:()=>gr,base36upper:()=>Cm});var gr=mr({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Cm=mr({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ka={};Et(Ka,{base58btc:()=>ht,base58flickr:()=>Nm});var ht=mr({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Nm=mr({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var za={};Et(za,{base64:()=>ce,base64pad:()=>Lm,base64url:()=>qa,base64urlpad:()=>Um});var ce=pt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Lm=pt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),qa=pt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Um=pt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ga={};Et(Ga,{base8:()=>Dm});var Dm=pt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ja={};Et(ja,{identity:()=>Pm});var Pm=cn({prefix:"\0",name:"identity",encode:r=>vl(r),decode:r=>El(r)});var dE=new TextEncoder,pE=new TextDecoder;var _l=512;var cs=85;var Za={};Et(Za,{identity:()=>ue});var Om=Nl,Tl=128,Fm=127,Vm=~Fm,Mm=Math.pow(2,31);function Nl(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Mm;)t[e++]=r&255|Tl,r/=128;for(;r&Vm;)t[e++]=r&255|Tl,r>>>=7;return t[e]=r|0,Nl.bytes=e-n+1,t}var $m=Ya,Hm=128,Cl=127;function Ya(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw Ya.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&Cl)<<o:(i&Cl)*Math.pow(2,o),o+=7}while(i>=Hm);return Ya.bytes=s-n,e}var Km=Math.pow(2,7),qm=Math.pow(2,14),zm=Math.pow(2,21),Gm=Math.pow(2,28),jm=Math.pow(2,35),Wm=Math.pow(2,42),Ym=Math.pow(2,49),Zm=Math.pow(2,56),Jm=Math.pow(2,63),Xm=function(r){return r<Km?1:r<qm?2:r<zm?3:r<Gm?4:r<jm?5:r<Wm?6:r<Ym?7:r<Zm?8:r<Jm?9:10},Qm={encode:Om,decode:$m,encodingLength:Xm},tg=Qm,oo=tg;function so(r,t=0){return[oo.decode(r,t),oo.decode.bytes]}function un(r,t,e=0){return oo.encode(r,t,e),t}function ln(r){return oo.encodingLength(r)}function Re(r,t){let e=t.byteLength,n=ln(r),o=n+ln(e),s=new Uint8Array(o+e);return un(r,s,0),un(e,s,n),s.set(t,o),new fn(r,e,t,s)}function Te(r){let t=Ke(r),[e,n]=so(t),[o,s]=so(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new fn(e,o,i,t)}function Ll(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&xl(r.bytes,e.bytes)}}var fn=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};var Ul=0,eg="identity",Dl=Ke;function rg(r){return Re(Ul,Dl(r))}var ue={code:Ul,name:eg,encode:Dl,digest:rg};var tc={};Et(tc,{sha256:()=>vt,sha512:()=>Qa});function Xa({name:r,code:t,encode:e}){return new Ja(r,t,e)}var Ja=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?Re(this.code,e):e.then(n=>Re(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Ol(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var vt=Xa({name:"sha2-256",code:18,encode:Ol("SHA-256")}),Qa=Xa({name:"sha2-512",code:19,encode:Ol("SHA-512")});function Fl(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return og(e,ec(r),t??ht.encoder);default:return sg(e,ec(r),t??Tt.encoder)}}var Vl=new WeakMap;function ec(r){let t=Vl.get(r);if(t==null){let e=new Map;return Vl.set(r,e),e}return t}var st=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!==io)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==ig)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=Re(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&&Ll(t.multihash,n.multihash)}toString(t){return Fl(this,t)}toJSON(){return{"/":Fl(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??Ml(n,o,s.bytes))}else if(e[ag]===!0){let{version:n,multihash:o,code:s}=e,i=Te(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!==io)throw new Error(`Version 0 CID must use dag-pb (code: ${io}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=Ml(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,io,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=Ke(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 fn(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,m]=so(t.subarray(e));return e+=m,l},o=n(),s=io;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]=ng(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 ec(s).set(n,t),s}};function ng(r,t){switch(r[0]){case"Q":{let e=t??ht;return[ht.prefix,e.decode(`${ht.prefix}${r}`)]}case ht.prefix:{let e=t??ht;return[ht.prefix,e.decode(r)]}case Tt.prefix:{let e=t??Tt;return[Tt.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function og(r,t,e){let{prefix:n}=e;if(n!==ht.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 sg(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 io=112,ig=18;function Ml(r,t,e){let n=ln(r),o=n+ln(t),s=new Uint8Array(o+e.byteLength);return un(r,s,0),un(t,s,n),s.set(e,o),s}var ag=Symbol.for("@ipld/js-cid/CID");var yr={...ja,...Va,...Ga,...Oa,...Fa,...$a,...Ha,...Ka,...za,...Ma},DE={...tc,...Za};function Hl(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var $l=Hl("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),rc=Hl("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=zt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),cg={utf8:$l,"utf-8":$l,hex:yr.base16,latin1:rc,ascii:rc,binary:rc,...yr},ls=cg;function q(r,t="utf8"){let e=ls[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function nc(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return zt(i);o+i>t&&(n=zt(t),o=0);let a=n.subarray(o,o+=i);return o&7&&(o=(o|7)+1),a}}var Mr=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function oc(){}var ic=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},ug=nc();function lg(r){return globalThis.Buffer!=null?zt(r):ug(r)}var co=class{len;head;tail;states;constructor(){this.len=0,this.head=new Mr(oc,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Mr(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new ac((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(fs,10,Zt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Zt.fromBigInt(t);return this._push(fs,e.length(),e)}uint64Number(t){return this._push(Sa,Gt(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=Zt.fromBigInt(t).zzEncode();return this._push(fs,e.length(),e)}sint64Number(t){let e=Zt.fromNumber(t).zzEncode();return this._push(fs,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(ao,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Zt.fromBigInt(t);return this._push(ao,4,e.lo)._push(ao,4,e.hi)}fixed64Number(t){let e=Zt.fromNumber(t);return this._push(ao,4,e.lo)._push(ao,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(hl,4,t)}double(t){return this._push(pl,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(sc,1,0):this.uint32(e)._push(hg,e,t)}string(t){let e=yl(t);return e!==0?this.uint32(e)._push(Ta,e,t):this._push(sc,1,0)}fork(){return this.states=new ic(this),this.head=this.tail=new Mr(oc,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 Mr(oc,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=lg(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 fg(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var ac=class extends Mr{next;constructor(t,e){super(fg,t,e),this.next=void 0}};function fs(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 ao(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 hg(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(co.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(dg,t,r),this},co.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(pg,t,r),this});function dg(r,t,e){t.set(r,e)}function pg(r,t,e){r.length<40?Ta(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(q(r),e)}function cc(){return new co}function hn(r,t){let e=cc();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var dn;(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"})(dn||(dn={}));function hs(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function uo(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 hs("enum",dn.VARINT,e,n)}function pn(r,t){return hs("message",dn.LENGTH_DELIMITED,r,t)}var mg=Symbol.for("nodejs.util.inspect.custom"),Kl=Object.values(yr).map(r=>r.decoder).reduce((r,t)=>r.or(t),yr.identity.decoder),ql=114,uc=36,lc=37,lo=class{type;multihash;privateKey;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,this.privateKey=t.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[wa]=!0;toString(){return this.string==null&&(this.string=ht.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return st.createV1(ql,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return it(this.multihash.bytes,t);if(typeof t=="string")return fc(t).equals(this);if(t?.multihash?.bytes!=null)return it(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[mg](){return`PeerId(${this.toString()})`}},mn=class extends lo{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},gn=class extends lo{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},yn=class extends lo{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function fc(r,t){if(t=t??Kl,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Te(ht.decode(`z${r}`));return r.startsWith("12D")?new gn({multihash:e}):r.startsWith("16U")?new yn({multihash:e}):new mn({multihash:e})}return fo(Kl.decode(r))}function fo(r){try{let t=Te(r);if(t.code===ue.code){if(t.digest.length===uc)return new gn({multihash:t});if(t.digest.length===lc)return new yn({multihash:t})}if(t.code===vt.code)return new mn({multihash:t})}catch{return gg(st.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function gg(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==ql)throw new Error("Supplied PeerID CID is invalid");let t=r.multihash;if(t.code===vt.code)return new mn({multihash:r.multihash});if(t.code===ue.code){if(t.digest.length===uc)return new gn({multihash:r.multihash});if(t.digest.length===lc)return new yn({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function zl(r,t){return r.length===uc?new gn({multihash:Re(ue.code,r),privateKey:t}):r.length===lc?new yn({multihash:Re(ue.code,r),privateKey:t}):new mn({multihash:await vt.digest(r),publicKey:r,privateKey:t})}function G(r,t="utf8"){let e=ls[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Xt=Yt(Zl(),1);Xt.default.formatters.b=r=>r==null?"undefined":ht.baseEncode(r);Xt.default.formatters.t=r=>r==null?"undefined":Tt.baseEncode(r);Xt.default.formatters.m=r=>r==null?"undefined":ce.baseEncode(r);Xt.default.formatters.p=r=>r==null?"undefined":r.toString();Xt.default.formatters.c=r=>r==null?"undefined":r.toString();Xt.default.formatters.k=r=>r==null?"undefined":r.toString();Xt.default.formatters.a=r=>r==null?"undefined":r.toString();function Rg(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 Jl(){return{forComponent(r){return Qt(r)}}}function Qt(r){let t=Rg(`${r}:trace`);return Xt.default.enabled(`${r}:trace`)&&Xt.default.names.map(e=>e.toString()).find(e=>e.includes(":trace"))!=null&&(t=(0,Xt.default)(`${r}:trace`)),Object.assign((0,Xt.default)(r),{error:(0,Xt.default)(`${r}:error`),trace:t})}var dc=Yt(Ql(),1);var po=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},pc=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},tf=r=>globalThis.DOMException===void 0?new pc(r):new DOMException(r),ef=r=>{let t=r.reason===void 0?tf("This operation was aborted."):r.reason;return t instanceof Error?t:tf(t)};function mo(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:m}=t;m.aborted&&f(ef(m)),m.addEventListener("abort",()=>{f(ef(m))})}if(e===Number.POSITIVE_INFINITY){r.then(u,f);return}let l=new po;i=s.setTimeout.call(void 0,()=>{if(n){try{u(n())}catch(m){f(m)}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(m){f(m)}})()}).finally(()=>{c.clear()});return c.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},c}function mc(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 go=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=mc(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 Ce=class extends dc.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:go,...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#b(){return this.#e||this.#r<this.#o}get#x(){return this.#i<this.#f}#E(){this.#i--,this.#h(),this.emit("next")}#v(){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.#v()},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.#b&&this.#x){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#B(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=mo(Promise.resolve(s),{milliseconds:e.timeout})),e.signal&&(s=Promise.race([s,this.#B(e.signal)]));let i=await s;n(i),this.emit("completed",i)}catch(s){if(s instanceof po&&!e.throwOnTimeout){n();return}o(s),this.emit("error",s)}finally{this.#E()}},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 gs(r){let t=[be.A];return r==null?t:Array.isArray(r)?r.length===0?t:r:[r]}var gc=60;function ys(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??gc,data:t.data instanceof Uint8Array?G(t.data):t.data}))}}var Ng=4;function yc(r,t={}){let e=new Ce({concurrency:t.queryConcurrency??Ng});return async(n,o={})=>{let s=new URLSearchParams;s.set("name",n),gs(o.types).forEach(a=>{s.append("type",be[a])}),o.onProgress?.(new rt("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=ys(await a.json());return o.onProgress?.(new rt("dns:response",{detail:c})),c},{signal:o.signal});if(i==null)throw new Error("No DNS response received");return i}}function rf(){return[yc("https://cloudflare-dns.com/dns-query"),yc("https://dns.google/resolve")]}var sf=Yt(of(),1);var wc=class{lru;constructor(t){this.lru=(0,sf.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 ys({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??gc)*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 af(r){return new wc(r)}var Lg=1e3,ws=class{resolvers;cache;constructor(t){this.resolvers={},this.cache=af(t.cacheSize??Lg),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["."]=rf())}async query(t,e={}){let n=gs(e.types),o=e.cached!==!1?this.cache.get(t,n):void 0;if(o!=null)return e.onProgress?.(new rt("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 rt("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 cf(r={}){return new ws(r)}var Ug=["string","number","bigint","symbol"],Dg=["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 uf(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let t=typeof r;if(Ug.includes(t))return t;if(t==="function")return"Function";if(Array.isArray(r))return"Array";if(Pg(r))return"Buffer";let e=Og(r);return e||"Object"}function Pg(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function Og(r){let t=Object.prototype.toString.call(r).slice(8,-1);if(Dg.includes(t))return t}var y=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}};y.uint=new y(0,"uint",!0);y.negint=new y(1,"negint",!0);y.bytes=new y(2,"bytes",!0);y.string=new y(3,"string",!0);y.array=new y(4,"array",!1);y.map=new y(5,"map",!1);y.tag=new y(6,"tag",!1);y.float=new y(7,"float",!0);y.false=new y(7,"false",!0);y.true=new y(7,"true",!0);y.null=new y(7,"null",!0);y.undefined=new y(7,"undefined",!0);y.break=new y(7,"break",!0);var _=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 En=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",Fg=new TextDecoder,Vg=new TextEncoder;function bs(r){return En&&globalThis.Buffer.isBuffer(r)}function yo(r){return r instanceof Uint8Array?bs(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var df=En?(r,t,e)=>e-t>64?globalThis.Buffer.from(r.subarray(t,e)).toString("utf8"):ff(r,t,e):(r,t,e)=>e-t>64?Fg.decode(r.subarray(t,e)):ff(r,t,e),xs=En?r=>r.length>64?globalThis.Buffer.from(r):lf(r):r=>r.length>64?Vg.encode(r):lf(r),Ne=r=>Uint8Array.from(r),vn=En?(r,t,e)=>bs(r)?new Uint8Array(r.subarray(t,e)):r.slice(t,e):(r,t,e)=>r.slice(t,e),pf=En?(r,t)=>(r=r.map(e=>e instanceof Uint8Array?e:globalThis.Buffer.from(e)),yo(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},mf=En?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function gf(r,t){if(bs(r)&&bs(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 lf(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 ff(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 bc(n)}var hf=4096;function bc(r){let t=r.length;if(t<=hf)return String.fromCharCode.apply(String,r);let e="",n=0;for(;n<t;)e+=String.fromCharCode.apply(String,r.slice(n,n+=hf));return e}var Mg=256,wo=class{constructor(t=Mg){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=mf(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=vn(n,0,this.cursor)}else e=pf(this.chunks,this.cursor);return t&&this.reset(),e}};var V="CBOR decode error:",An="CBOR encode error:",bo=[];bo[23]=1;bo[24]=2;bo[25]=3;bo[26]=5;bo[27]=9;function ze(r,t,e){if(r.length-t<e)throw new Error(`${V} not enough data for type`)}var St=[24,256,65536,4294967296,BigInt("18446744073709551616")];function te(r,t,e){ze(r,t,1);let n=r[t];if(e.strict===!0&&n<St[0])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function ee(r,t,e){ze(r,t,2);let n=r[t]<<8|r[t+1];if(e.strict===!0&&n<St[1])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function re(r,t,e){ze(r,t,4);let n=r[t]*16777216+(r[t+1]<<16)+(r[t+2]<<8)+r[t+3];if(e.strict===!0&&n<St[2])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function ne(r,t,e){ze(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<St[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 yf(r,t,e,n){return new _(y.uint,te(r,t+1,n),2)}function wf(r,t,e,n){return new _(y.uint,ee(r,t+1,n),3)}function bf(r,t,e,n){return new _(y.uint,re(r,t+1,n),5)}function xf(r,t,e,n){return new _(y.uint,ne(r,t+1,n),9)}function le(r,t){return Ct(r,0,t.value)}function Ct(r,t,e){if(e<St[0]){let n=Number(e);r.push([t|n])}else if(e<St[1]){let n=Number(e);r.push([t|24,n])}else if(e<St[2]){let n=Number(e);r.push([t|25,n>>>8,n&255])}else if(e<St[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<St[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`)}}le.encodedSize=function(t){return Ct.encodedSize(t.value)};Ct.encodedSize=function(t){return t<St[0]?1:t<St[1]?2:t<St[2]?3:t<St[3]?5:9};le.compareTokens=function(t,e){return t.value<e.value?-1:t.value>e.value?1:0};function Ef(r,t,e,n){return new _(y.negint,-1-te(r,t+1,n),2)}function vf(r,t,e,n){return new _(y.negint,-1-ee(r,t+1,n),3)}function Af(r,t,e,n){return new _(y.negint,-1-re(r,t+1,n),5)}var xc=BigInt(-1),Bf=BigInt(1);function kf(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 _(y.negint,s,9)}if(n.allowBigInt!==!0)throw new Error(`${V} integers outside of the safe integer range are not supported`);return new _(y.negint,xc-BigInt(o),9)}function Es(r,t){let e=t.value,n=typeof e=="bigint"?e*xc-Bf:e*-1-1;Ct(r,t.type.majorEncoded,n)}Es.encodedSize=function(t){let e=t.value,n=typeof e=="bigint"?e*xc-Bf:e*-1-1;return n<St[0]?1:n<St[1]?2:n<St[2]?3:n<St[3]?5:9};Es.compareTokens=function(t,e){return t.value<e.value?1:t.value>e.value?-1:0};function xo(r,t,e,n){ze(r,t,e+n);let o=vn(r,t+e,t+e+n);return new _(y.bytes,o,e+n)}function Sf(r,t,e,n){return xo(r,t,1,e)}function If(r,t,e,n){return xo(r,t,2,te(r,t+1,n))}function _f(r,t,e,n){return xo(r,t,3,ee(r,t+1,n))}function Rf(r,t,e,n){return xo(r,t,5,re(r,t+1,n))}function Tf(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 xo(r,t,9,o)}function vs(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===y.string?xs(r.value):r.value),r.encodedBytes}function Bn(r,t){let e=vs(t);Ct(r,t.type.majorEncoded,e.length),r.push(e)}Bn.encodedSize=function(t){let e=vs(t);return Ct.encodedSize(e.length)+e.length};Bn.compareTokens=function(t,e){return Hg(vs(t),vs(e))};function Hg(r,t){return r.length<t.length?-1:r.length>t.length?1:gf(r,t)}function Eo(r,t,e,n,o){let s=e+n;ze(r,t,s);let i=new _(y.string,df(r,t+e,t+s),s);return o.retainStringBytes===!0&&(i.byteValue=vn(r,t+e,t+s)),i}function Cf(r,t,e,n){return Eo(r,t,1,e,n)}function Nf(r,t,e,n){return Eo(r,t,2,te(r,t+1,n),n)}function Lf(r,t,e,n){return Eo(r,t,3,ee(r,t+1,n),n)}function Uf(r,t,e,n){return Eo(r,t,5,re(r,t+1,n),n)}function Df(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 Eo(r,t,9,o,n)}var Pf=Bn;function kn(r,t,e,n){return new _(y.array,n,e)}function Of(r,t,e,n){return kn(r,t,1,e)}function Ff(r,t,e,n){return kn(r,t,2,te(r,t+1,n))}function Vf(r,t,e,n){return kn(r,t,3,ee(r,t+1,n))}function Mf(r,t,e,n){return kn(r,t,5,re(r,t+1,n))}function $f(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 kn(r,t,9,o)}function Hf(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return kn(r,t,1,1/0)}function As(r,t){Ct(r,y.array.majorEncoded,t.value)}As.compareTokens=le.compareTokens;As.encodedSize=function(t){return Ct.encodedSize(t.value)};function Sn(r,t,e,n){return new _(y.map,n,e)}function Kf(r,t,e,n){return Sn(r,t,1,e)}function qf(r,t,e,n){return Sn(r,t,2,te(r,t+1,n))}function zf(r,t,e,n){return Sn(r,t,3,ee(r,t+1,n))}function Gf(r,t,e,n){return Sn(r,t,5,re(r,t+1,n))}function jf(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 Sn(r,t,9,o)}function Wf(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Sn(r,t,1,1/0)}function Bs(r,t){Ct(r,y.map.majorEncoded,t.value)}Bs.compareTokens=le.compareTokens;Bs.encodedSize=function(t){return Ct.encodedSize(t.value)};function Yf(r,t,e,n){return new _(y.tag,e,1)}function Zf(r,t,e,n){return new _(y.tag,te(r,t+1,n),2)}function Jf(r,t,e,n){return new _(y.tag,ee(r,t+1,n),3)}function Xf(r,t,e,n){return new _(y.tag,re(r,t+1,n),5)}function Qf(r,t,e,n){return new _(y.tag,ne(r,t+1,n),9)}function ks(r,t){Ct(r,y.tag.majorEncoded,t.value)}ks.compareTokens=le.compareTokens;ks.encodedSize=function(t){return Ct.encodedSize(t.value)};var Wg=20,Yg=21,Zg=22,Jg=23;function th(r,t,e,n){if(n.allowUndefined===!1)throw new Error(`${V} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new _(y.null,null,1):new _(y.undefined,void 0,1)}function eh(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return new _(y.break,void 0,1)}function Ec(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 _(y.float,r,t)}function rh(r,t,e,n){return Ec(vc(r,t+1),3,n)}function nh(r,t,e,n){return Ec(Ac(r,t+1),5,n)}function oh(r,t,e,n){return Ec(ch(r,t+1),9,n)}function Ss(r,t,e){let n=t.value;if(n===!1)r.push([y.float.majorEncoded|Wg]);else if(n===!0)r.push([y.float.majorEncoded|Yg]);else if(n===null)r.push([y.float.majorEncoded|Zg]);else if(n===void 0)r.push([y.float.majorEncoded|Jg]);else{let o,s=!1;(!e||e.float64!==!0)&&(ih(n),o=vc(xe,1),n===o||Number.isNaN(n)?(xe[0]=249,r.push(xe.slice(0,3)),s=!0):(ah(n),o=Ac(xe,1),n===o&&(xe[0]=250,r.push(xe.slice(0,5)),s=!0))),s||(Xg(n),o=ch(xe,1),xe[0]=251,r.push(xe.slice(0,9)))}}Ss.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){ih(n);let o=vc(xe,1);if(n===o||Number.isNaN(n))return 3;if(ah(n),o=Ac(xe,1),n===o)return 5}return 9};var sh=new ArrayBuffer(9),fe=new DataView(sh,1),xe=new Uint8Array(sh,0);function ih(r){if(r===1/0)fe.setUint16(0,31744,!1);else if(r===-1/0)fe.setUint16(0,64512,!1);else if(Number.isNaN(r))fe.setUint16(0,32256,!1);else{fe.setFloat32(0,r);let t=fe.getUint32(0),e=(t&2139095040)>>23,n=t&8388607;if(e===255)fe.setUint16(0,31744,!1);else if(e===0)fe.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let o=e-127;o<-24?fe.setUint16(0,0):o<-14?fe.setUint16(0,(t&2147483648)>>16|1<<24+o,!1):fe.setUint16(0,(t&2147483648)>>16|o+15<<10|n>>13,!1)}}}function vc(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 ah(r){fe.setFloat32(0,r,!1)}function Ac(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 Xg(r){fe.setFloat64(0,r,!1)}function ch(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)}Ss.compareTokens=le.compareTokens;function tt(r,t,e){throw new Error(`${V} encountered invalid minor (${e}) for major ${r[t]>>>5}`)}function Is(r){return()=>{throw new Error(`${V} ${r}`)}}var L=[];for(let r=0;r<=23;r++)L[r]=tt;L[24]=yf;L[25]=wf;L[26]=bf;L[27]=xf;L[28]=tt;L[29]=tt;L[30]=tt;L[31]=tt;for(let r=32;r<=55;r++)L[r]=tt;L[56]=Ef;L[57]=vf;L[58]=Af;L[59]=kf;L[60]=tt;L[61]=tt;L[62]=tt;L[63]=tt;for(let r=64;r<=87;r++)L[r]=Sf;L[88]=If;L[89]=_f;L[90]=Rf;L[91]=Tf;L[92]=tt;L[93]=tt;L[94]=tt;L[95]=Is("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)L[r]=Cf;L[120]=Nf;L[121]=Lf;L[122]=Uf;L[123]=Df;L[124]=tt;L[125]=tt;L[126]=tt;L[127]=Is("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)L[r]=Of;L[152]=Ff;L[153]=Vf;L[154]=Mf;L[155]=$f;L[156]=tt;L[157]=tt;L[158]=tt;L[159]=Hf;for(let r=160;r<=183;r++)L[r]=Kf;L[184]=qf;L[185]=zf;L[186]=Gf;L[187]=jf;L[188]=tt;L[189]=tt;L[190]=tt;L[191]=Wf;for(let r=192;r<=215;r++)L[r]=Yf;L[216]=Zf;L[217]=Jf;L[218]=Xf;L[219]=Qf;L[220]=tt;L[221]=tt;L[222]=tt;L[223]=tt;for(let r=224;r<=243;r++)L[r]=Is("simple values are not supported");L[244]=tt;L[245]=tt;L[246]=tt;L[247]=th;L[248]=Is("simple values are not supported");L[249]=rh;L[250]=nh;L[251]=oh;L[252]=tt;L[253]=tt;L[254]=tt;L[255]=eh;var Ee=[];for(let r=0;r<24;r++)Ee[r]=new _(y.uint,r,1);for(let r=-1;r>=-24;r--)Ee[31-r]=new _(y.negint,r,1);Ee[64]=new _(y.bytes,new Uint8Array(0),1);Ee[96]=new _(y.string,"",1);Ee[128]=new _(y.array,0,1);Ee[160]=new _(y.map,0,1);Ee[244]=new _(y.false,!1,1);Ee[245]=new _(y.true,!0,1);Ee[246]=new _(y.null,null,1);function uh(r){switch(r.type){case y.false:return Ne([244]);case y.true:return Ne([245]);case y.null:return Ne([246]);case y.bytes:return r.value.length?void 0:Ne([64]);case y.string:return r.value===""?Ne([96]):void 0;case y.array:return r.value===0?Ne([128]):void 0;case y.map:return r.value===0?Ne([160]):void 0;case y.uint:return r.value<24?Ne([Number(r.value)]):void 0;case y.negint:if(r.value>=-24)return Ne([31-Number(r.value)])}}var ty={float64:!1,mapSorter:ny,quickEncodeToken:uh};function ey(){let r=[];return r[y.uint.major]=le,r[y.negint.major]=Es,r[y.bytes.major]=Bn,r[y.string.major]=Pf,r[y.array.major]=As,r[y.map.major]=Bs,r[y.tag.major]=ks,r[y.float.major]=Ss,r}var lh=ey(),Bc=new wo,Rs=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(`${An} object contains circular references`);return new r(e,t)}},wr={null:new _(y.null,null),undefined:new _(y.undefined,void 0),true:new _(y.true,!0),false:new _(y.false,!1),emptyArray:new _(y.array,0),emptyMap:new _(y.map,0)},br={number(r,t,e,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new _(y.float,r):r>=0?new _(y.uint,r):new _(y.negint,r)},bigint(r,t,e,n){return r>=BigInt(0)?new _(y.uint,r):new _(y.negint,r)},Uint8Array(r,t,e,n){return new _(y.bytes,r)},string(r,t,e,n){return new _(y.string,r)},boolean(r,t,e,n){return r?wr.true:wr.false},null(r,t,e,n){return wr.null},undefined(r,t,e,n){return wr.undefined},ArrayBuffer(r,t,e,n){return new _(y.bytes,new Uint8Array(r))},DataView(r,t,e,n){return new _(y.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,t,e,n){if(!r.length)return e.addBreakTokens===!0?[wr.emptyArray,new _(y.break)]:wr.emptyArray;n=Rs.createCheck(n,r);let o=[],s=0;for(let i of r)o[s++]=_s(i,e,n);return e.addBreakTokens?[new _(y.array,r.length),o,new _(y.break)]:[new _(y.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?[wr.emptyMap,new _(y.break)]:wr.emptyMap;n=Rs.createCheck(n,r);let a=[],c=0;for(let u of s)a[c++]=[_s(u,e,n),_s(o?r.get(u):r[u],e,n)];return ry(a,e),e.addBreakTokens?[new _(y.map,i),a,new _(y.break)]:[new _(y.map,i),a]}};br.Map=br.Object;br.Buffer=br.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))br[`${r}Array`]=br.DataView;function _s(r,t={},e){let n=uf(r),o=t&&t.typeEncoders&&t.typeEncoders[n]||br[n];if(typeof o=="function"){let i=o(r,n,t,e);if(i!=null)return i}let s=br[n];if(!s)throw new Error(`${An} unsupported type: ${n}`);return s(r,n,t,e)}function ry(r,t){t.mapSorter&&r.sort(t.mapSorter)}function ny(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=lh[o].compareTokens(e,n);return s===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),s}function fh(r,t,e,n){if(Array.isArray(t))for(let o of t)fh(r,o,e,n);else e[t.type.major](r,t,n)}function hh(r,t,e){let n=_s(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 wo(i);if(s(a,n,e),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return yo(a.chunks[0])}}return Bc.reset(),fh(Bc,n,t,e),Bc.toBytes(!0)}function In(r,t){return t=Object.assign({},ty,t),hh(r,lh,t)}var oy={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},Ts=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=L[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}},vo=Symbol.for("DONE"),Cs=Symbol.for("BREAK");function sy(r,t,e){let n=[];for(let o=0;o<r.value;o++){let s=_n(t,e);if(s===Cs){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed array`)}if(s===vo)throw new Error(`${V} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=s}return n}function iy(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=_n(t,e);if(a===Cs){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed map`)}if(a===vo)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=_n(t,e);if(c===vo)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 _n(r,t){if(r.done())return vo;let e=r.next();if(e.type===y.break)return Cs;if(e.type.terminal)return e.value;if(e.type===y.array)return sy(e,r,t);if(e.type===y.map)return iy(e,r,t);if(e.type===y.tag){if(t.tags&&typeof t.tags[e.value]=="function"){let n=_n(r,t);return t.tags[e.value](n)}throw new Error(`${V} tag not supported (${e.value})`)}throw new Error("unsupported")}function kc(r,t){if(!(r instanceof Uint8Array))throw new Error(`${V} data to decode must be a Uint8Array`);t=Object.assign({},oy,t);let e=t.tokenizer||new Ts(r,t),n=_n(e,t);if(n===vo)throw new Error(`${V} did not find any content to decode`);if(n===Cs)throw new Error(`${V} got unexpected break`);return[n,r.subarray(e.pos())]}function he(r,t){let[e,n]=kc(r,t);if(n.length>0)throw new Error(`${V} too many terminals, data makes no sense`);return e}var Ge="/",dh=new TextEncoder().encode(Ge),Ls=dh[0],Nt=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=q(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]!==Ls)throw new Error("Invalid key")}toString(t="utf8"){return G(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(Ge))}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=dh),this._buf[0]!==Ls){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Ls,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Ls;)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(Ge).slice(1)}type(){return ay(this.baseNamespace())}name(){return cy(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(Ge)||(t+=Ge),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(Ge):new r(t.slice(0,-1).join(Ge))}child(t){return this.toString()===Ge?t:t.toString()===Ge?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(),...uy(t.map(e=>e.namespaces()))])}};function ay(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function cy(r){let t=r.split(":");return t[t.length-1]}function uy(r){return[].concat(...r)}var yh="/pin/",ph="/pinned-block/",Sc=gr,mh=1;function gh(r){return r.version===0&&(r=r.toV1()),new Nt(`${yh}${r.toString(Sc)}`)}var Us=class{datastore;blockstore;dagWalkers;constructor(t,e,n){this.datastore=t,this.blockstore=e,this.dagWalkers=n}async*add(t,e={}){let n=gh(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:mh});for await(let a of this.#t(t,s,{...e,depth:o}))await this.#e(a,c=>c.pinnedBy.find(u=>it(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,In(i),e)}async*#t(t,e,n){if(n.depth===-1)return;let o=this.dagWalkers[t.code];if(o==null)throw new Error(`No dag walker found for cid codec ${t.code}`);let s=await this.blockstore.get(t,n);yield t;for await(let i of o.walk(s))yield*await e.add(async()=>this.#t(i,e,{...n,depth:n.depth-1}))}async#e(t,e,n){let o=new Nt(`${ph}${Sc.encode(t.multihash.bytes)}`),s={pinCount:0,pinnedBy:[]};try{s=he(await this.datastore.get(o,n))}catch(a){if(a.code!=="ERR_NOT_FOUND")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,In(s),n),n.onProgress?.(new rt("helia:pin:add",t))}}async*rm(t,e={}){let n=gh(t),o=await this.datastore.get(n,e),s=he(o);await this.datastore.delete(n,e);let i=new He({concurrency:mh});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=>it(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:yh+(t.cid!=null?`${t.cid.toString(gr)}`:"")},t)){let o=st.parse(e.toString().substring(5),gr),s=he(n);yield{cid:o,...s}}}async isPinned(t,e={}){let n=new Nt(`${ph}${Sc.encode(t.multihash.bytes)}`);return this.datastore.has(n,e)}};var ly=5,Ds=class{log;routers;providerLookupConcurrency;constructor(t,e){this.log=t.logger.forComponent("helia:routing"),this.routers=e.routers??[],this.providerLookupConcurrency=e.providerLookupConcurrency??ly}async start(){await hr(...this.routers)}async stop(){await dr(...this.routers)}async*findProviders(t,e={}){if(this.routers.length===0)throw new D("No content routers available","ERR_NO_ROUTERS_AVAILABLE");let n=new ns({concurrency:this.providerLookupConcurrency});n.addEventListener("error",()=>{});for await(let o of Fr(n.toGenerator(),...Rn(this.routers,"findProviders").map(s=>s.findProviders(t,e))))if(o!=null){if(o.multiaddrs=o.multiaddrs.map(s=>s.getPeerId()!=null?s:s.encapsulate(`/p2p/${o.id}`)),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",o.id,s),null}},{peerId:o.id,signal:e.signal}).catch(s=>{this.log.error("could not load multiaddrs for peer",o.id,s)})}yield o}}async provide(t,e={}){if(this.routers.length===0)throw new D("No content routers available","ERR_NO_ROUTERS_AVAILABLE");await Promise.all(Rn(this.routers,"provide").map(async n=>{await n.provide(t,e)}))}async put(t,e,n){await Promise.all(Rn(this.routers,"put").map(async o=>{await o.put(t,e,n)}))}async get(t,e){return Promise.any(Rn(this.routers,"get").map(async n=>n.get(t,e)))}async findPeer(t,e){if(this.routers.length===0)throw new D("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");let n=this,o=Fr(...Rn(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 D("Could not find peer in routing","ERR_NOT_FOUND")}async*getClosestPeers(t,e={}){if(this.routers.length===0)throw new D("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");for await(let n of Fr(...Rn(this.routers,"getClosestPeers").map(o=>o.getClosestPeers(t,e))))n!=null&&(yield n)}};function Rn(r,t){return r.filter(e=>e[t]!=null)}var xr={},Tn=r=>{r.addEventListener("message",t=>{Tn.dispatchEvent("message",r,t)}),r.port!=null&&r.port.addEventListener("message",t=>{Tn.dispatchEvent("message",r,t)})};Tn.addEventListener=(r,t)=>{xr[r]==null&&(xr[r]=[]),xr[r].push(t)};Tn.removeEventListener=(r,t)=>{xr[r]!=null&&(xr[r]=xr[r].filter(e=>e===t))};Tn.dispatchEvent=function(r,t,e){xr[r]!=null&&xr[r].forEach(n=>n(t,e))};var Ic=Tn;var _c="lock:worker:request-read",Rc="lock:worker:release-read",Tc="lock:master:grant-read",Cc="lock:worker:request-write",Nc="lock:worker:release-write",Lc="lock:master:grant-write";var wh=(r=21)=>Math.random().toString().substring(2);var bh=(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==null||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)})}}}))},xh=(r,t,e,n)=>async()=>{let o=wh();return globalThis.postMessage({type:t,identifier:o,name:r}),new Promise(s=>{let i=a=>{if(a==null||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)})},fy={singleProcess:!1},Eh=r=>{if(r=Object.assign({},fy,r),!!globalThis.document||r.singleProcess){let e=new EventTarget;return Ic.addEventListener("message",bh(e,"requestReadLock",_c,Rc,Tc)),Ic.addEventListener("message",bh(e,"requestWriteLock",Cc,Nc,Lc)),e}return{isWorker:!0,readLock:e=>xh(e,_c,Tc,Rc),writeLock:e=>xh(e,Cc,Lc,Nc)}};var Kr={},Er;async function Uc(r,t){let e,n=new Promise(o=>{e=o});return r.add(async()=>mo((async()=>{await new Promise(o=>{e(()=>{o()})})})(),{milliseconds:t.timeout})),n}var hy=(r,t)=>{if(Er.isWorker===!0)return{readLock:Er.readLock(r,t),writeLock:Er.writeLock(r,t)};let e=new Ce({concurrency:1}),n;return{async readLock(){if(n!=null)return Uc(n,t);n=new Ce({concurrency:t.concurrency,autoStart:!1});let o=n,s=Uc(n,t);return e.add(async()=>{o.start(),await o.onIdle().then(()=>{n===o&&(n=null)})}),s},async writeLock(){return n=null,Uc(e,t)}}},dy={name:"lock",concurrency:1/0,timeout:846e5,singleProcess:!1};function Dc(r){let t=Object.assign({},dy,r);return Er==null&&(Er=Eh(t),Er.isWorker!==!0&&(Er.addEventListener("requestReadLock",e=>{Kr[e.data.name]!=null&&Kr[e.data.name].readLock().then(async n=>e.data.handler().finally(()=>{n()}))}),Er.addEventListener("requestWriteLock",async e=>{Kr[e.data.name]!=null&&Kr[e.data.name].writeLock().then(async n=>e.data.handler().finally(()=>{n()}))}))),Kr[t.name]==null&&(Kr[t.name]=hy(t.name,t)),Kr[t.name]}var Ps=class{lock;child;pins;started;constructor(t,e,n={}){this.child=t,this.pins=e,this.lock=Dc({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await hr(this.child),this.started=!0}async stop(){await dr(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 Ah=42;function py(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let t=st.asCID(r);if(!t)return null;let e=new Uint8Array(t.bytes.byteLength+1);return e.set(t.bytes,1),[new _(y.tag,Ah),new _(y.bytes,e)]}function my(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function gy(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 vh={float64:!0,typeEncoders:{Object:py,undefined:my,number:gy}},DA={...vh,typeEncoders:{...vh.typeEncoders}};function yy(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return st.decode(r.subarray(1))}var Pc={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Pc.tags[Ah]=yy;var PA={...Pc,tags:Pc.tags.slice()};var Bh=113;var kh=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(t){let e=this.inRecursive[this.inRecursive.length-1];e&&(e.type===y.array&&(e.elements++,e.elements!==1&&t.push([44])),e.type===y.map&&(e.elements++,e.elements!==1&&(e.elements%2===1?t.push([44]):t.push([58]))))}[y.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)}[y.negint.major](t,e){this[y.uint.major](t,e)}[y.bytes.major](t,e){throw new Error(`${An} unsupported type: Uint8Array`)}[y.string.major](t,e){this.prefix(t);let n=xs(JSON.stringify(e.value));t.push(n.length>32?yo(n):n)}[y.array.major](t,e){this.prefix(t),this.inRecursive.push({type:y.array,elements:0}),t.push([91])}[y.map.major](t,e){this.prefix(t),this.inRecursive.push({type:y.map,elements:0}),t.push([123])}[y.tag.major](t,e){}[y.float.major](t,e){if(e.type.name==="break"){let i=this.inRecursive.pop();if(i){if(i.type===y.array)t.push([93]);else if(i.type===y.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(`${An} 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)}};var qr=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 _(y.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 _(y.float,i,this._pos-t):this.options.allowBigInt!==!0||Number.isSafeInteger(i)?new _(i>=0?y.uint:y.negint,i,this._pos-t):new _(i>=0?y.uint:y.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 _(y.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 _(y.string,bc(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 _(y.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new _(y.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new _(y.null,null,4);case 102:return this.expect([102,97,108,115,101]),new _(y.false,!1,5);case 116:return this.expect([116,114,117,101]),new _(y.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 _(y.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 _(y.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 _(y.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 _(y.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 Os(r,t){return t=Object.assign({tokenizer:new qr(r,t)},t),he(r,t)}var xy={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};xy.tags[42]=st.parse;var Ih=297;var QA=new TextDecoder;var t8=new TextEncoder;var vy=new TextDecoder;function Oc(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 Fs(r,t){let e;[e,t]=Oc(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 _h(r,t){let e;return[e,t]=Oc(r,t),[e&7,e>>3,t]}function Ay(r){let t={},e=r.length,n=0;for(;n<e;){let o,s;if([o,s,n]=_h(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]=Fs(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]=Fs(r,n),t.Name=vy.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]=Oc(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 Rh(r){let t=r.length,e=0,n,o=!1,s;for(;e<t;){let a,c;if([a,c,e]=_h(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]=Fs(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]=Fs(r,e),n.push(Ay(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 r8=new TextEncoder,n8=2**32,o8=2**31;var a8=new TextEncoder;function Th(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var Ch=112;function Nh(r){let t=Th(r),e=Rh(t),n={};return e.Data&&(n.Data=e.Data),e.Links&&(n.Links=e.Links.map(o=>{let s={};try{s.Hash=st.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}var ky={codec:Ch,*walk(r){yield*Nh(r).Links.map(e=>e.Hash)}},Sy={codec:cs,*walk(){}},Lh=42,Iy={codec:Bh,*walk(r){let t=[],e=[];e[Lh]=n=>{if(n[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");let o=st.decode(n.subarray(1));return t.push(o),o},he(r,{tags:e}),yield*t}},Fc=class extends qr{tokenBuffer;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===y.map){let e=this._next();if(e.type===y.string&&e.value==="/"){let n=this._next();if(n.type===y.string){if(this._next().type!==y.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new _(y.tag,42,0)}if(n.type===y.map){let o=this._next();if(o.type===y.string&&o.value==="bytes"){let s=this._next();if(s.type===y.string){for(let a=0;a<2;a++)if(this._next().type!==y.break)throw new Error("Invalid encoded Bytes form");let i=ce.decode(`m${s.value}`);return new _(y.bytes,i,s.value.length)}this.tokenBuffer.push(s)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(e)}return t}},_y={codec:Ih,*walk(r){let t=[],e=[];e[Lh]=n=>{let o=st.parse(n);return t.push(o),o},Os(r,{tags:e,tokenizer:new Fc(r,{tags:e,allowIndefinite:!0,allowUndefined:!0,allowNaN:!0,allowInfinity:!0,allowBigInt:!0,strict:!1,rejectDuplicateMapKeys:!1})}),yield*t}},Ry={codec:_l,*walk(){}};function Uh(r=[]){let t={};return[ky,Sy,Iy,_y,Ry,...r].forEach(e=>{t[e.codec]=e}),t}var Vc=new Nt("/version"),Dh=1;async function Ph(r){if(!await r.has(Vc)){await r.put(Vc,q(`${Dh}`));return}let t=await r.get(Vc),e=G(t);if(parseInt(e,10)!==Dh)throw new Error("Unknown datastore version, a datastore migration may be required")}function Oh(r=[]){let t={};return[vt,Qa,ue,...r].forEach(e=>{t[e.code]=e}),t}var je=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 Cn={};Et(Cn,{abortedError:()=>Uy,closeFailedError:()=>Cy,deleteFailedError:()=>Vh,getFailedError:()=>Ny,hasFailedError:()=>Ly,notFoundError:()=>Ao,openFailedError:()=>Ty,putFailedError:()=>Fh});var We=Yt(nn(),1);function Ty(r){return r=r??new Error("Open failed"),(0,We.default)(r,"ERR_OPEN_FAILED")}function Cy(r){return r=r??new Error("Close failed"),(0,We.default)(r,"ERR_CLOSE_FAILED")}function Fh(r){return r=r??new Error("Put failed"),(0,We.default)(r,"ERR_PUT_FAILED")}function Ny(r){return r=r??new Error("Get failed"),(0,We.default)(r,"ERR_GET_FAILED")}function Vh(r){return r=r??new Error("Delete failed"),(0,We.default)(r,"ERR_DELETE_FAILED")}function Ly(r){return r=r??new Error("Has failed"),(0,We.default)(r,"ERR_HAS_FAILED")}function Ao(r){return r=r??new Error("Not Found"),(0,We.default)(r,"ERR_NOT_FOUND")}function Uy(r){return r=r??new Error("Aborted"),(0,We.default)(r,"ERR_ABORTED")}var Bo=class extends je{data;constructor(){super(),this.data=new Map}put(t,e){return this.data.set(Tt.encode(t.multihash.bytes),e),t}get(t){let e=this.data.get(Tt.encode(t.multihash.bytes));if(e==null)throw Ao();return e}has(t){return this.data.has(Tt.encode(t.multihash.bytes))}async delete(t){this.data.delete(Tt.encode(t.multihash.bytes))}async*getAll(){for(let[t,e]of this.data.entries())yield{cid:st.createV1(cs,Te(Tt.decode(t))),block:e}}};function Dy(r){return r[Symbol.asyncIterator]!=null}function Py(r,t){if(Dy(r))return async function*(){for await(let a of r)await t(a)&&(yield a)}();let e=on(r),{value:n,done:o}=e.next();if(o===!0)return function*(){}();let s=t(n);if(typeof s.then=="function")return async function*(){await s&&(yield n);for await(let a of e)await t(a)&&(yield a)}();let i=t;return function*(){s===!0&&(yield n);for(let a of e)i(a)&&(yield a)}()}var ve=Py;var q8=Qt("blockstore:core:tiered");var Mh={...Cn};var Vs=0,Ms=class extends je{child;constructor(t){super(),this.child=t}put(t,e){return t.multihash.code===Vs||this.child==null?t:this.child.put(t,e)}get(t){if(t.multihash.code===Vs)return t.multihash.digest;if(this.child==null)throw Mh.notFoundError();return this.child.get(t)}has(t){return t.multihash.code===Vs?!0:this.child==null?!1:this.child.has(t)}delete(t){if(t.code!==Vs&&this.child!=null)return this.child.delete(t)}getAll(t){return this.child!=null?this.child.getAll(t):[]}};function Oy(r){return r[Symbol.asyncIterator]!=null}function $h(r){return r?.then!=null}function Fy(r,t){if(Oy(r))return async function*(){for await(let a of r){let c=t(a);$h(c)&&await c,yield a}}();let e=on(r),{value:n,done:o}=e.next();if(o===!0)return function*(){}();if(typeof t(n)?.then=="function")return async function*(){yield n;for await(let a of e){let c=t(a);$h(c)&&await c,yield a}}();let i=t;return function*(){yield n;for(let a of e)i(a),yield a}()}var Mc=Fy;var $s=class{child;hashers;log;logger;components;constructor(t){this.log=t.logger.forComponent("helia:networked-storage"),this.logger=t.logger,this.components=t,this.child=new Ms(t.blockstore),this.hashers=t.hashers??{}}async put(t,e,n={}){return await this.child.has(t,n)?(n.onProgress?.(new rt("blocks:put:duplicate",t)),t):(n.onProgress?.(new rt("blocks:put:providers:notify",t)),await Promise.all(this.components.blockBrokers.map(async o=>o.announce?.(t,e,n))),n.onProgress?.(new rt("blocks:put:blockstore:put",t)),this.child.put(t,e,n))}async*putMany(t,e={}){let n=ve(t,async({cid:s})=>{let i=await this.child.has(s,e);return i&&e.onProgress?.(new rt("blocks:put-many:duplicate",s)),!i}),o=Mc(n,async({cid:s,block:i})=>{e.onProgress?.(new rt("blocks:put-many:providers:notify",s)),await Promise.all(this.components.blockBrokers.map(async a=>a.announce?.(s,i,e)))});e.onProgress?.(new rt("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)){e.onProgress?.(new rt("blocks:get:providers:get",t));let n=await Hh(t,this.components.blockBrokers,this.hashers[t.multihash.code],{...e,log:this.log});return e.onProgress?.(new rt("blocks:get:blockstore:put",t)),await this.child.put(t,n,e),e.onProgress?.(new rt("blocks:get:providers:notify",t)),await Promise.all(this.components.blockBrokers.map(async o=>o.announce?.(t,n,e))),n}return e.onProgress?.(new rt("blocks:get:blockstore:get",t)),this.child.get(t,e)}async*getMany(t,e={}){e.onProgress?.(new rt("blocks:get-many:blockstore:get-many")),yield*this.child.getMany(Mc(t,async n=>{if(e.offline!==!0&&!await this.child.has(n,e)){e.onProgress?.(new rt("blocks:get-many:providers:get",n));let o=await Hh(n,this.components.blockBrokers,this.hashers[n.multihash.code],{...e,log:this.log});e.onProgress?.(new rt("blocks:get-many:blockstore:put",n)),await this.child.put(n,o,e),e.onProgress?.(new rt("blocks:get-many:providers:notify",n)),await Promise.all(this.components.blockBrokers.map(async s=>s.announce?.(n,o,e)))}}))}async delete(t,e={}){e.onProgress?.(new rt("blocks:delete:blockstore:delete",t)),await this.child.delete(t,e)}async*deleteMany(t,e={}){e.onProgress?.(new rt("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 rt("blocks:get-all:blockstore:get-many")),yield*this.child.getAll(t)}},Hs=class extends $s{started;constructor(t){super(t),this.started=!1}isStarted(){return this.started}async start(){await hr(this.child,...this.components.blockBrokers),this.started=!0}async stop(){await dr(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 $c({blockstore:this.child,blockBrokers:n,hashers:this.hashers,logger:this.logger},{root:t})}},$c=class extends $s{closeController;constructor(t,e){super(t),this.closeController=new AbortController,ft(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=Mt([this.closeController.signal,n.signal]);ft(1/0,o);try{return await super.put(t,e,{...n,signal:o})}finally{o.clear()}}async*putMany(t,e={}){let n=Mt([this.closeController.signal,e.signal]);ft(1/0,n);try{yield*super.putMany(t,{...e,signal:n})}finally{n.clear()}}async get(t,e={}){let n=Mt([this.closeController.signal,e.signal]);ft(1/0,n);try{return await super.get(t,{...e,signal:n})}finally{n.clear()}}async*getMany(t,e={}){let n=Mt([this.closeController.signal,e.signal]);ft(1/0,n);try{yield*super.getMany(t,{...e,signal:n})}finally{n.clear()}}async delete(t,e={}){let n=Mt([this.closeController.signal,e.signal]);ft(1/0,n);try{await super.delete(t,{...e,signal:n})}finally{n.clear()}}async*deleteMany(t,e={}){let n=Mt([this.closeController.signal,e.signal]);ft(1/0,n);try{yield*super.deleteMany(t,{...e,signal:n})}finally{n.clear()}}async has(t,e={}){let n=Mt([this.closeController.signal,e.signal]);ft(1/0,n);try{return await super.has(t,{...e,signal:n})}finally{n.clear()}}async*getAll(t={}){let e=Mt([this.closeController.signal,t.signal]);ft(1/0,e);try{yield*super.getAll({...t,signal:e})}finally{e.clear()}}};function Vy(r){return typeof r.retrieve=="function"}var My=(r,t)=>{if(t==null)throw new D(`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`,"ERR_UNKNOWN_HASH_ALG");return async e=>{let n=await t.digest(e);if(!it(n.digest,r.multihash.digest))throw new D("Hash of downloaded block did not match multihash from passed CID","ERR_HASH_MISMATCH")}};async function Hh(r,t,e,n){let o=My(r,e),s=new AbortController,i=Mt([s.signal,n.signal]);ft(1/0,s.signal,i);let a=[];for(let c of t)Vy(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 Kh=1,qh=5;var Ht={get(r=globalThis){let t=r.crypto;if(t==null||t.subtle==null)throw Object.assign(new Error("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"),{code:"ERR_MISSING_WEB_CRYPTO"});return t}};var ou={};Et(ou,{Ed25519PrivateKey:()=>Wr,Ed25519PublicKey:()=>Io,generateKeyPair:()=>Zw,generateKeyPairFromSeed:()=>yd,unmarshalEd25519PrivateKey:()=>Ww,unmarshalEd25519PublicKey:()=>Yw});function de(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Nn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function $y(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Ln(r,...t){if(!$y(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function Ks(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Nn(r.outputLen),Nn(r.blockLen)}function Un(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 zh(r,t){Ln(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var qs=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Pn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Ae=(r,t)=>r<<32-t|r>>>t;var EB=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Hy=async()=>{};async function Gh(r,t,e){let n=Date.now();for(let o=0;o<r;o++){e(o);let s=Date.now()-n;s>=0&&s<t||(await Hy(),n+=s)}}function Hc(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function vr(r){return typeof r=="string"&&(r=Hc(r)),Ln(r),r}function zs(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Ln(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 Dn=class{clone(){return this._cloneInto()}},Ky={}.toString;function jh(r,t){if(t!==void 0&&Ky.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Gs(r){let t=n=>r().update(vr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function On(r=32){if(qs&&typeof qs.getRandomValues=="function")return qs.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function qy(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 Wh=(r,t,e)=>r&t^~r&e,Yh=(r,t,e)=>r&t^r&e^t&e,Fn=class extends Dn{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=Pn(this.buffer)}update(t){Un(this);let{view:e,buffer:n,blockLen:o}=this;t=vr(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=Pn(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){Un(this),zh(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;qy(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=Pn(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 js=BigInt(4294967295),Kc=BigInt(32);function Zh(r,t=!1){return t?{h:Number(r&js),l:Number(r>>Kc&js)}:{h:Number(r>>Kc&js)|0,l:Number(r&js)|0}}function zy(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}=Zh(r[o],t);[e[o],n[o]]=[s,i]}return[e,n]}var Gy=(r,t)=>BigInt(r>>>0)<<Kc|BigInt(t>>>0),jy=(r,t,e)=>r>>>e,Wy=(r,t,e)=>r<<32-e|t>>>e,Yy=(r,t,e)=>r>>>e|t<<32-e,Zy=(r,t,e)=>r<<32-e|t>>>e,Jy=(r,t,e)=>r<<64-e|t>>>e-32,Xy=(r,t,e)=>r>>>e-32|t<<64-e,Qy=(r,t)=>t,tw=(r,t)=>r,ew=(r,t,e)=>r<<e|t>>>32-e,rw=(r,t,e)=>t<<e|r>>>32-e,nw=(r,t,e)=>t<<e-32|r>>>64-e,ow=(r,t,e)=>r<<e-32|t>>>64-e;function sw(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var iw=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),aw=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,cw=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),uw=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,lw=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),fw=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var hw={fromBig:Zh,split:zy,toBig:Gy,shrSH:jy,shrSL:Wy,rotrSH:Yy,rotrSL:Zy,rotrBH:Jy,rotrBL:Xy,rotr32H:Qy,rotr32L:tw,rotlSH:ew,rotlSL:rw,rotlBH:nw,rotlBL:ow,add:sw,add3L:iw,add3H:aw,add4L:cw,add4H:uw,add5H:fw,add5L:lw},z=hw;var[dw,pw]=z.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))),Ar=new Uint32Array(80),Br=new Uint32Array(80),qc=class extends Fn{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:m,Gh:h,Gl:p,Hh:d,Hl:w}=this;return[t,e,n,o,s,i,a,c,u,f,l,m,h,p,d,w]}set(t,e,n,o,s,i,a,c,u,f,l,m,h,p,d,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=m|0,this.Gh=h|0,this.Gl=p|0,this.Hh=d|0,this.Hl=w|0}process(t,e){for(let b=0;b<16;b++,e+=4)Ar[b]=t.getUint32(e),Br[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let B=Ar[b-15]|0,A=Br[b-15]|0,I=z.rotrSH(B,A,1)^z.rotrSH(B,A,8)^z.shrSH(B,A,7),v=z.rotrSL(B,A,1)^z.rotrSL(B,A,8)^z.shrSL(B,A,7),E=Ar[b-2]|0,U=Br[b-2]|0,P=z.rotrSH(E,U,19)^z.rotrBH(E,U,61)^z.shrSH(E,U,6),N=z.rotrSL(E,U,19)^z.rotrBL(E,U,61)^z.shrSL(E,U,6),M=z.add4L(v,N,Br[b-7],Br[b-16]),C=z.add4H(M,I,P,Ar[b-7],Ar[b-16]);Ar[b]=C|0,Br[b]=M|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:u,Dl:f,Eh:l,El:m,Fh:h,Fl:p,Gh:d,Gl:w,Hh:g,Hl:x}=this;for(let b=0;b<80;b++){let B=z.rotrSH(l,m,14)^z.rotrSH(l,m,18)^z.rotrBH(l,m,41),A=z.rotrSL(l,m,14)^z.rotrSL(l,m,18)^z.rotrBL(l,m,41),I=l&h^~l&d,v=m&p^~m&w,E=z.add5L(x,A,v,pw[b],Br[b]),U=z.add5H(E,g,B,I,dw[b],Ar[b]),P=E|0,N=z.rotrSH(n,o,28)^z.rotrBH(n,o,34)^z.rotrBH(n,o,39),M=z.rotrSL(n,o,28)^z.rotrBL(n,o,34)^z.rotrBL(n,o,39),C=n&s^n&a^s&a,X=o&i^o&c^i&c;g=d|0,x=w|0,d=h|0,w=p|0,h=l|0,p=m|0,{h:l,l:m}=z.add(u|0,f|0,U|0,P|0),u=a|0,f=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let S=z.add3L(P,M,X);n=z.add3H(S,U,N,C),o=S|0}({h:n,l:o}=z.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=z.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=z.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l:f}=z.add(this.Dh|0,this.Dl|0,u|0,f|0),{h:l,l:m}=z.add(this.Eh|0,this.El|0,l|0,m|0),{h,l:p}=z.add(this.Fh|0,this.Fl|0,h|0,p|0),{h:d,l:w}=z.add(this.Gh|0,this.Gl|0,d|0,w|0),{h:g,l:x}=z.add(this.Hh|0,this.Hl|0,g|0,x|0),this.set(n,o,s,i,a,c,u,f,l,m,h,p,d,w,g,x)}roundClean(){Ar.fill(0),Br.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 Vn=Gs(()=>new qc);var Ys={};Et(Ys,{abytes:()=>Mn,bitGet:()=>Ew,bitLen:()=>xw,bitMask:()=>ko,bitSet:()=>vw,bytesToHex:()=>Ze,bytesToNumberBE:()=>Je,bytesToNumberLE:()=>Sr,concatBytes:()=>Xe,createHmacDrbg:()=>jc,ensureBytes:()=>mt,equalBytes:()=>ww,hexToBytes:()=>zr,hexToNumber:()=>Gc,isBytes:()=>kr,numberToBytesBE:()=>Ir,numberToBytesLE:()=>Gr,numberToHexUnpadded:()=>td,numberToVarBytesBE:()=>yw,utf8ToBytes:()=>bw,validateObject:()=>Le});var Qh=BigInt(0),Ws=BigInt(1),mw=BigInt(2);function kr(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Mn(r){if(!kr(r))throw new Error("Uint8Array expected")}var gw=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Ze(r){Mn(r);let t="";for(let e=0;e<r.length;e++)t+=gw[r[e]];return t}function td(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Gc(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Ye={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Jh(r){if(r>=Ye._0&&r<=Ye._9)return r-Ye._0;if(r>=Ye._A&&r<=Ye._F)return r-(Ye._A-10);if(r>=Ye._a&&r<=Ye._f)return r-(Ye._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("padded 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=Jh(r.charCodeAt(s)),a=Jh(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 Gc(Ze(r))}function Sr(r){return Mn(r),Gc(Ze(Uint8Array.from(r).reverse()))}function Ir(r,t){return zr(r.toString(16).padStart(t*2,"0"))}function Gr(r,t){return Ir(r,t).reverse()}function yw(r){return zr(td(r))}function mt(r,t,e){let n;if(typeof t=="string")try{n=zr(t)}catch(s){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${s}`)}else if(kr(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} expected ${e} bytes, got ${o}`);return n}function Xe(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Mn(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 ww(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 bw(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function xw(r){let t;for(t=0;r>Qh;r>>=Ws,t+=1);return t}function Ew(r,t){return r>>BigInt(t)&Ws}function vw(r,t,e){return r|(e?Ws:Qh)<<BigInt(t)}var ko=r=>(mw<<BigInt(r-1))-Ws,zc=r=>new Uint8Array(r),Xh=r=>Uint8Array.from(r);function jc(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=zc(r),o=zc(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>e(o,n,...l),c=(l=zc())=>{o=a(Xh([0]),l),n=a(),l.length!==0&&(o=a(Xh([1]),l),n=a())},u=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,m=[];for(;l<t;){n=a();let h=n.slice();m.push(h),l+=n.length}return Xe(...m)};return(l,m)=>{i(),c(l);let h;for(;!(h=m(u()));)c();return i(),h}}var Aw={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"||kr(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=Aw[s];if(typeof a!="function")throw new Error(`Invalid validator "${s}", expected function`);let c=r[o];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(o)}=${c} (${typeof c}), expected ${s}`)};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 At=BigInt(0),ut=BigInt(1),jr=BigInt(2),Bw=BigInt(3),Wc=BigInt(4),ed=BigInt(5),rd=BigInt(8),kw=BigInt(9),Sw=BigInt(16);function at(r,t){let e=r%t;return e>=At?e:t+e}function Iw(r,t,e){if(e<=At||t<At)throw new Error("Expected power/modulo > 0");if(e===ut)return At;let n=ut;for(;t>At;)t&ut&&(n=n*r%e),r=r*r%e,t>>=ut;return n}function lt(r,t,e){let n=r;for(;t-- >At;)n*=n,n%=e;return n}function Zs(r,t){if(r===At||t<=At)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=at(r,t),n=t,o=At,s=ut,i=ut,a=At;for(;e!==At;){let u=n/e,f=n%e,l=o-i*u,m=s-a*u;n=e,e=f,o=i,s=a,i=l,a=m}if(n!==ut)throw new Error("invert: does not exist");return at(o,t)}function _w(r){let t=(r-ut)/jr,e,n,o;for(e=r-ut,n=0;e%jr===At;e/=jr,n++);for(o=jr;o<r&&Iw(o,t,r)!==r-ut;o++);if(n===1){let i=(r+ut)/Wc;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+ut)/jr;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),m=a.pow(c,e);for(;!a.eql(m,a.ONE);){if(a.eql(m,a.ZERO))return a.ZERO;let h=1;for(let d=a.sqr(m);h<u&&!a.eql(d,a.ONE);h++)d=a.sqr(d);let p=a.pow(f,ut<<BigInt(u-h-1));f=a.sqr(p),l=a.mul(l,p),m=a.mul(m,f),u=h}return l}}function Rw(r){if(r%Wc===Bw){let t=(r+ut)/Wc;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%rd===ed){let t=(r-ed)/rd;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%Sw,_w(r)}var nd=(r,t)=>(at(r,t)&ut)===ut,Tw=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Yc(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Tw.reduce((n,o)=>(n[o]="function",n),t);return Le(r,e)}function Cw(r,t,e){if(e<At)throw new Error("Expected power > 0");if(e===At)return r.ONE;if(e===ut)return t;let n=r.ONE,o=t;for(;e>At;)e&ut&&(n=r.mul(n,o)),o=r.sqr(o),e>>=ut;return n}function Nw(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 Js(r,t,e=!1,n={}){if(r<=At)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:o,nByteLength:s}=Zc(r,t);if(s>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Rw(r),a=Object.freeze({ORDER:r,BITS:o,BYTES:s,MASK:ko(o),ZERO:At,ONE:ut,create:c=>at(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return At<=c&&c<r},is0:c=>c===At,isOdd:c=>(c&ut)===ut,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)=>Cw(a,c,u),div:(c,u)=>at(c*Zs(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>Zs(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Nw(a,c),cmov:(c,u,f)=>f?u:c,toBytes:c=>e?Gr(c,s):Ir(c,s),fromBytes:c=>{if(c.length!==s)throw new Error(`Fp.fromBytes: expected ${s}, got ${c.length}`);return e?Sr(c):Je(c)}});return Object.freeze(a)}function od(r,t){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let e=r.sqrt(t);return r.isOdd(e)?r.neg(e):e}function sd(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 Jc(r){let t=sd(r);return t+Math.ceil(t/2)}function id(r,t,e=!1){let n=r.length,o=sd(t),s=Jc(t);if(n<16||n<s||n>1024)throw new Error(`expected ${s}-1024 bytes of input, got ${n}`);let i=e?Je(r):Sr(r),a=at(i,t-ut)+ut;return e?Gr(a,o):Ir(a,o)}var Uw=BigInt(0),Xc=BigInt(1);function Xs(r,t){let e=(o,s)=>{let i=s.negate();return o?i:s},n=o=>{let s=Math.ceil(t/o)+1,i=2**(o-1);return{windows:s,windowSize:i}};return{constTimeNegate:e,unsafeLadder(o,s){let i=r.ZERO,a=o;for(;s>Uw;)s&Xc&&(i=i.add(a)),a=a.double(),s>>=Xc;return i},precomputeWindow(o,s){let{windows:i,windowSize:a}=n(s),c=[],u=o,f=u;for(let l=0;l<i;l++){f=u,c.push(f);for(let m=1;m<a;m++)f=f.add(u),c.push(f);u=f.double()}return c},wNAF(o,s,i){let{windows:a,windowSize:c}=n(o),u=r.ZERO,f=r.BASE,l=BigInt(2**o-1),m=2**o,h=BigInt(o);for(let p=0;p<a;p++){let d=p*c,w=Number(i&l);i>>=h,w>c&&(w-=m,i+=Xc);let g=d,x=d+Math.abs(w)-1,b=p%2!==0,B=w<0;w===0?f=f.add(e(b,s[g])):u=u.add(e(B,s[x]))}return{p:u,f}},wNAFCached(o,s,i,a){let c=o._WINDOW_SIZE||1,u=s.get(o);return u||(u=this.precomputeWindow(o,c),c!==1&&s.set(o,a(u))),this.wNAF(c,u,i)}}}function So(r){return Yc(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 Be=BigInt(0),oe=BigInt(1),Qs=BigInt(2),Dw=BigInt(8),Pw={zip215:!0};function Ow(r){let t=So(r);return Le(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function ti(r){let t=Ow(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,u=Qs<<BigInt(a*8)-oe,f=e.create,l=t.uvRatio||((R,k)=>{try{return{isValid:!0,value:e.sqrt(R*e.inv(k))}}catch{return{isValid:!1,value:Be}}}),m=t.adjustScalarBytes||(R=>R),h=t.domain||((R,k,F)=>{if(k.length||F)throw new Error("Contexts/pre-hash are not supported");return R}),p=R=>typeof R=="bigint"&&Be<R,d=(R,k)=>p(R)&&p(k)&&R<k,w=R=>R===Be||d(R,u);function g(R,k){if(d(R,k))return R;throw new Error(`Expected valid scalar < ${k}, got ${typeof R} ${R}`)}function x(R){return R===Be?R:g(R,n)}let b=new Map;function B(R){if(!(R instanceof A))throw new Error("ExtendedPoint expected")}class A{constructor(k,F,$,K){if(this.ex=k,this.ey=F,this.ez=$,this.et=K,!w(k))throw new Error("x required");if(!w(F))throw new Error("y required");if(!w($))throw new Error("z required");if(!w(K))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(k){if(k instanceof A)throw new Error("extended point not allowed");let{x:F,y:$}=k||{};if(!w(F)||!w($))throw new Error("invalid affine point");return new A(F,$,oe,f(F*$))}static normalizeZ(k){let F=e.invertBatch(k.map($=>$.ez));return k.map(($,K)=>$.toAffine(F[K])).map(A.fromAffine)}_setWindowSize(k){this._WINDOW_SIZE=k,b.delete(this)}assertValidity(){let{a:k,d:F}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:$,ey:K,ez:W,et:Y}=this,et=f($*$),J=f(K*K),Q=f(W*W),wt=f(Q*Q),dt=f(et*k),_t=f(Q*f(dt+J)),Rt=f(wt+f(F*f(et*J)));if(_t!==Rt)throw new Error("bad point: equation left != right (1)");let xt=f($*K),Dt=f(W*Y);if(xt!==Dt)throw new Error("bad point: equation left != right (2)")}equals(k){B(k);let{ex:F,ey:$,ez:K}=this,{ex:W,ey:Y,ez:et}=k,J=f(F*et),Q=f(W*K),wt=f($*et),dt=f(Y*K);return J===Q&&wt===dt}is0(){return this.equals(A.ZERO)}negate(){return new A(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:k}=t,{ex:F,ey:$,ez:K}=this,W=f(F*F),Y=f($*$),et=f(Qs*f(K*K)),J=f(k*W),Q=F+$,wt=f(f(Q*Q)-W-Y),dt=J+Y,_t=dt-et,Rt=J-Y,xt=f(wt*_t),Dt=f(dt*Rt),$e=f(wt*Rt),Ur=f(_t*dt);return new A(xt,Dt,Ur,$e)}add(k){B(k);let{a:F,d:$}=t,{ex:K,ey:W,ez:Y,et}=this,{ex:J,ey:Q,ez:wt,et:dt}=k;if(F===BigInt(-1)){let Zu=f((W-K)*(Q+J)),Ju=f((W+K)*(Q-J)),ya=f(Ju-Zu);if(ya===Be)return this.double();let Xu=f(Y*Qs*dt),Qu=f(et*Qs*wt),tl=Qu+Xu,el=Ju+Zu,rl=Qu-Xu,L0=f(tl*ya),U0=f(el*rl),D0=f(tl*rl),P0=f(ya*el);return new A(L0,U0,P0,D0)}let _t=f(K*J),Rt=f(W*Q),xt=f(et*$*dt),Dt=f(Y*wt),$e=f((K+W)*(J+Q)-_t-Rt),Ur=Dt-xt,eo=Dt+xt,Yu=f(Rt-F*_t),R0=f($e*Ur),T0=f(eo*Yu),C0=f($e*Yu),N0=f(Ur*eo);return new A(R0,T0,N0,C0)}subtract(k){return this.add(k.negate())}wNAF(k){return E.wNAFCached(this,b,k,A.normalizeZ)}multiply(k){let{p:F,f:$}=this.wNAF(g(k,n));return A.normalizeZ([F,$])[0]}multiplyUnsafe(k){let F=x(k);return F===Be?v:this.equals(v)||F===oe?this:this.equals(I)?this.wNAF(F).p:E.unsafeLadder(this,F)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return E.unsafeLadder(this,n).is0()}toAffine(k){let{ex:F,ey:$,ez:K}=this,W=this.is0();k==null&&(k=W?Dw:e.inv(K));let Y=f(F*k),et=f($*k),J=f(K*k);if(W)return{x:Be,y:oe};if(J!==oe)throw new Error("invZ was invalid");return{x:Y,y:et}}clearCofactor(){let{h:k}=t;return k===oe?this:this.multiplyUnsafe(k)}static fromHex(k,F=!1){let{d:$,a:K}=t,W=e.BYTES;k=mt("pointHex",k,W);let Y=k.slice(),et=k[W-1];Y[W-1]=et&-129;let J=Sr(Y);J===Be||(F?g(J,u):g(J,e.ORDER));let Q=f(J*J),wt=f(Q-oe),dt=f($*Q-K),{isValid:_t,value:Rt}=l(wt,dt);if(!_t)throw new Error("Point.fromHex: invalid y coordinate");let xt=(Rt&oe)===oe,Dt=(et&128)!==0;if(!F&&Rt===Be&&Dt)throw new Error("Point.fromHex: x=0 and x_0=1");return Dt!==xt&&(Rt=f(-Rt)),A.fromAffine({x:Rt,y:J})}static fromPrivateKey(k){return N(k).point}toRawBytes(){let{x:k,y:F}=this.toAffine(),$=Gr(F,e.BYTES);return $[$.length-1]|=k&oe?128:0,$}toHex(){return Ze(this.toRawBytes())}}A.BASE=new A(t.Gx,t.Gy,oe,f(t.Gx*t.Gy)),A.ZERO=new A(Be,oe,oe,Be);let{BASE:I,ZERO:v}=A,E=Xs(A,a*8);function U(R){return at(R,n)}function P(R){return U(Sr(R))}function N(R){let k=a;R=mt("private key",R,k);let F=mt("hashed private key",s(R),2*k),$=m(F.slice(0,k)),K=F.slice(k,2*k),W=P($),Y=I.multiply(W),et=Y.toRawBytes();return{head:$,prefix:K,scalar:W,point:Y,pointBytes:et}}function M(R){return N(R).pointBytes}function C(R=new Uint8Array,...k){let F=Xe(...k);return P(s(h(F,mt("context",R),!!o)))}function X(R,k,F={}){R=mt("message",R),o&&(R=o(R));let{prefix:$,scalar:K,pointBytes:W}=N(k),Y=C(F.context,$,R),et=I.multiply(Y).toRawBytes(),J=C(F.context,et,W,R),Q=U(Y+J*K);x(Q);let wt=Xe(et,Gr(Q,e.BYTES));return mt("result",wt,a*2)}let S=Pw;function T(R,k,F,$=S){let{context:K,zip215:W}=$,Y=e.BYTES;R=mt("signature",R,2*Y),k=mt("message",k),o&&(k=o(k));let et=Sr(R.slice(Y,2*Y)),J,Q,wt;try{J=A.fromHex(F,W),Q=A.fromHex(R.slice(0,Y),W),wt=I.multiplyUnsafe(et)}catch{return!1}if(!W&&J.isSmallOrder())return!1;let dt=C(K,Q.toRawBytes(),J.toRawBytes(),k);return Q.add(J.multiplyUnsafe(dt)).subtract(wt).clearCofactor().equals(A.ZERO)}return I._setWindowSize(8),{CURVE:t,getPublicKey:M,sign:X,verify:T,ExtendedPoint:A,utils:{getExtendedPublicKey:N,randomPrivateKey:()=>i(e.BYTES),precompute(R=8,k=A.BASE){return k._setWindowSize(R),k.multiply(BigInt(3)),k}}}}var tu=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ad=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),KB=BigInt(0),Fw=BigInt(1),Qc=BigInt(2),Vw=BigInt(5),cd=BigInt(10),Mw=BigInt(20),$w=BigInt(40),ud=BigInt(80);function Hw(r){let t=tu,n=r*r%t*r%t,o=lt(n,Qc,t)*n%t,s=lt(o,Fw,t)*r%t,i=lt(s,Vw,t)*s%t,a=lt(i,cd,t)*i%t,c=lt(a,Mw,t)*a%t,u=lt(c,$w,t)*c%t,f=lt(u,ud,t)*u%t,l=lt(f,ud,t)*u%t,m=lt(l,cd,t)*i%t;return{pow_p_5_8:lt(m,Qc,t)*r%t,b2:n}}function Kw(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function qw(r,t){let e=tu,n=at(t*t*t,e),o=at(n*n*t,e),s=Hw(r*o).pow_p_5_8,i=at(r*n*s,e),a=at(t*i*i,e),c=i,u=at(i*ad,e),f=a===r,l=a===at(-r,e),m=a===at(-r*ad,e);return f&&(i=c),(l||m)&&(i=u),nd(i,e)&&(i=at(-i,e)),{isValid:f||l,value:i}}var Qe=Js(tu,void 0,!0),eu={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Qe,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Vn,randomBytes:On,adjustScalarBytes:Kw,uvRatio:qw},$n=ti(eu);function ld(r,t,e){if(t.length>255)throw new Error("Context is too big");return zs(Hc("SigEd25519 no Ed25519 collisions"),new Uint8Array([e?1:0,t.length]),t,r)}var qB=ti({...eu,domain:ld}),zB=ti({...eu,domain:ld,prehash:Vn});var zw=(Qe.ORDER+BigInt(3))/BigInt(8),GB=Qe.pow(Qc,zw),jB=Qe.sqrt(Qe.neg(Qe.ONE)),WB=(Qe.ORDER-BigInt(5))/BigInt(8),YB=BigInt(486662);var ZB=od(Qe,Qe.neg(BigInt(486664)));var JB=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),XB=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),QB=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),tk=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var ek=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var Hn=32,tr=64,ei=32;function fd(){let r=$n.utils.randomPrivateKey(),t=$n.getPublicKey(r);return{privateKey:md(r,t),publicKey:t}}function hd(r){if(r.length!==ei)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let t=r,e=$n.getPublicKey(t);return{privateKey:md(t,e),publicKey:e}}function dd(r,t){let e=r.subarray(0,ei);return $n.sign(t instanceof Uint8Array?t:t.subarray(),e)}function pd(r,t,e){return $n.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function md(r,t){let e=new Uint8Array(tr);for(let n=0;n<ei;n++)e[n]=r[n],e[ei+n]=t[n];return e}var ru={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function gd(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,o=r?.digest??"SHA-256",s=r?.saltLength??16,i=r?.iterations??32767,a=Ht.get();e*=8;async function c(l,m){let h=a.getRandomValues(new Uint8Array(s)),p=a.getRandomValues(new Uint8Array(n)),d={name:t,iv:p};typeof m=="string"&&(m=q(m));let w;if(m.length===0){w=await a.subtle.importKey("jwk",ru,{name:"AES-GCM"},!0,["encrypt"]);try{let x={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},b=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(x,b,{name:t,length:e},!0,["encrypt"])}catch{w=await a.subtle.importKey("jwk",ru,{name:"AES-GCM"},!0,["encrypt"])}}else{let x={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},b=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(x,b,{name:t,length:e},!0,["encrypt"])}let g=await a.subtle.encrypt(d,w,l);return kt([h,d.iv,new Uint8Array(g)])}async function u(l,m){let h=l.subarray(0,s),p=l.subarray(s,s+n),d=l.subarray(s+n),w={name:t,iv:p};typeof m=="string"&&(m=q(m));let g;if(m.length===0)try{let b={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},B=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(b,B,{name:t,length:e},!0,["decrypt"])}catch{g=await a.subtle.importKey("jwk",ru,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},B=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(b,B,{name:t,length:e},!0,["decrypt"])}let x=await a.subtle.decrypt(w,g,d);return new Uint8Array(x)}return{encrypt:c,decrypt:u}}async function Kn(r,t){let n=await gd().encrypt(r,t);return ce.encode(n)}var gt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(gt||(gt={}));var nu;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(nu||(nu={}));(function(r){r.codec=()=>uo(nu)})(gt||(gt={}));var Ue;(function(r){let t;r.codec=()=>(t==null&&(t=pn((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),gt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let o={},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let i=e.uint32();switch(i>>>3){case 1:o.Type=gt.codec().decode(e);break;case 2:o.Data=e.bytes();break;default:e.skipType(i&7);break}}return o})),t),r.encode=e=>hn(e,r.codec()),r.decode=e=>an(e,r.codec())})(Ue||(Ue={}));var er;(function(r){let t;r.codec=()=>(t==null&&(t=pn((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),gt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let o={},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let i=e.uint32();switch(i>>>3){case 1:o.Type=gt.codec().decode(e);break;case 2:o.Data=e.bytes();break;default:e.skipType(i&7);break}}return o})),t),r.encode=e=>hn(e,r.codec()),r.decode=e=>an(e,r.codec())})(er||(er={}));var Io=class{_key;constructor(t){this._key=qn(t,Hn)}verify(t,e){return pd(this._key,e,t)}marshal(){return this._key}get bytes(){return Ue.encode({Type:gt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=vt.digest(this.bytes);return de(t)?t.then(({bytes:e})=>e):t.bytes}},Wr=class{_key;_publicKey;constructor(t,e){this._key=qn(t,tr),this._publicKey=qn(e,Hn)}sign(t){return dd(this._key,t)}get public(){return new Io(this._publicKey)}marshal(){return this._key}get bytes(){return er.encode({Type:gt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}async hash(){let t=vt.digest(this.bytes),e;return de(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=ue.digest(this.public.bytes);return ht.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Kn(this.bytes,t);throw new D(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Ww(r){if(r.length>tr){r=qn(r,tr+Hn);let n=r.subarray(0,tr),o=r.subarray(tr,r.length);return new Wr(n,o)}r=qn(r,tr);let t=r.subarray(0,tr),e=r.subarray(Hn);return new Wr(t,e)}function Yw(r){return r=qn(r,Hn),new Io(r)}async function Zw(){let{privateKey:r,publicKey:t}=fd();return new Wr(r,t)}async function yd(r){let{privateKey:t,publicKey:e}=hd(r);return new Wr(t,e)}function qn(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new D(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}var pu={};Et(pu,{MAX_RSA_KEY_SIZE:()=>Vo,RsaPrivateKey:()=>Yn,RsaPublicKey:()=>Fo,fromJwk:()=>Ab,generateKeyPair:()=>Bb,unmarshalRsaPrivateKey:()=>hu,unmarshalRsaPublicKey:()=>vb});function De(r){if(isNaN(r)||r<=0)throw new D("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return On(r)}var Cr={};Et(Cr,{exportToPem:()=>yb,importFromPem:()=>wb,jwkToPkcs1:()=>db,jwkToPkix:()=>mb,pkcs1ToJwk:()=>hb,pkixToJwk:()=>pb});var ni=class extends Dn{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Ks(t);let n=vr(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 Un(this),this.iHash.update(t),this}digestInto(t){Un(this),Ln(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()}},_o=(r,t,e)=>new ni(r,t).update(e).digest();_o.create=(r,t)=>new ni(r,t);function Jw(r,t,e,n){Ks(r);let o=jh({dkLen:32,asyncTick:10},n),{c:s,dkLen:i,asyncTick:a}=o;if(Nn(s),Nn(i),Nn(a),s<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=vr(t),u=vr(e),f=new Uint8Array(i),l=_o.create(r,c),m=l._cloneInto().update(u);return{c:s,dkLen:i,asyncTick:a,DK:f,PRF:l,PRFSalt:m}}function Xw(r,t,e,n,o){return r.destroy(),t.destroy(),n&&n.destroy(),o.fill(0),e}async function su(r,t,e,n){let{c:o,dkLen:s,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=Jw(r,t,e,n),f,l=new Uint8Array(4),m=Pn(l),h=new Uint8Array(c.outputLen);for(let p=1,d=0;d<s;p++,d+=c.outputLen){let w=a.subarray(d,d+c.outputLen);m.setInt32(0,p,!1),(f=u._cloneInto(f)).update(l).digestInto(h),w.set(h.subarray(0,w.length)),await Gh(o-1,i,()=>{c._cloneInto(f).update(h).digestInto(h);for(let g=0;g<w.length;g++)w[g]^=h[g]})}return Xw(c,u,a,f,h)}var Z=Yt(wd());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 _r(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 ii(...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 au(){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 bd(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=_r(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=_r(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 xd(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 jt(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 _k=Math.log(2);function ai(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function cu(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 ir(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 To=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return cu(this.items)}},Ro=[new Uint8Array([1])],Ed="0123456789";var jn="",Se=new ArrayBuffer(0),uu=new Uint8Array(0),Co="EndOfContent",Ad="OCTET STRING",Bd="BIT STRING";function ar(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):uu}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(!ir(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",Se)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Z.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var nr=class{constructor({blockLength:t=0,error:e=jn,warnings:n=[],valueBeforeDecode:o=uu}={}){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)}}};nr.NAME="baseBlock";var Vt=class extends nr{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'")}};Vt.NAME="valueBlock";var ci=class extends ar(nr){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):uu,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",Se}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=_r(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(!ir(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 m=new Uint8Array(f);for(let h=0;h<u.length;h++)m[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 m=0;m<c;m++)l[m]=u[m];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}}};ci.NAME="identificationBlock";var ui=class extends nr{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(!ir(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=_r(this.length,8);if(o.byteLength>127)return this.error="Too big length",Se;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}}};ui.NAME="lengthBlock";var O={},Lt=class extends nr{constructor({name:t=jn,optional:e=!1,primitiveSchema:n,...o}={},s){super(o),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new ci(o),this.lenBlock=new ui(o),this.valueBlock=s?new s(o):new Vt(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 To;e||kd(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?Se: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 xd(e,n)}};Lt.NAME="BaseBlock";function kd(r){if(r instanceof O.Constructed)for(let t of r.valueBlock.value)kd(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var li=class extends Lt{constructor({value:t=jn,...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}'`}};li.NAME="BaseStringBlock";var fi=class extends ar(Vt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};fi.NAME="PrimitiveValueBlock";var Sd,hi=class extends Lt{constructor(t={}){super(t,fi),this.idBlock.isConstructed=!1}};Sd=hi;O.Primitive=Sd;hi.NAME="PRIMITIVE";function ab(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 zi(r,t=0,e=r.length){let n=t,o=new Lt({},Vt),s=new nr;if(!ir(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=Lt;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=O.EndOfContent;break;case 1:c=O.Boolean;break;case 2:c=O.Integer;break;case 3:c=O.BitString;break;case 4:c=O.OctetString;break;case 5:c=O.Null;break;case 6:c=O.ObjectIdentifier;break;case 10:c=O.Enumerated;break;case 12:c=O.Utf8String;break;case 13:c=O.RelativeObjectIdentifier;break;case 14:c=O.TIME;break;case 15:return o.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:o};case 16:c=O.Sequence;break;case 17:c=O.Set;break;case 18:c=O.NumericString;break;case 19:c=O.PrintableString;break;case 20:c=O.TeletexString;break;case 21:c=O.VideotexString;break;case 22:c=O.IA5String;break;case 23:c=O.UTCTime;break;case 24:c=O.GeneralizedTime;break;case 25:c=O.GraphicString;break;case 26:c=O.VisibleString;break;case 27:c=O.GeneralString;break;case 28:c=O.UniversalString;break;case 29:c=O.CharacterString;break;case 30:c=O.BmpString;break;case 31:c=O.DATE;break;case 32:c=O.TimeOfDay;break;case 33:c=O.DateTime;break;case 34:c=O.Duration;break;default:{let u=o.idBlock.isConstructed?new O.Constructed:new O.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?O.Constructed:O.Primitive}return o=ab(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 Wn(r){if(!r.byteLength){let t=new Lt({},Vt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return zi(Z.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function cb(r,t){return r?1:t}var Pe=class extends Vt{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(!ir(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(;cb(this.isIndefiniteForm,n)>0;){let i=zi(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===Co)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Co?this.value.pop():this.warnings.push("No EndOfContent block encoded")),s}toBER(t,e){let n=e||new To;for(let o=0;o<this.value.length;o++)this.value[o].toBER(t,n);return e?Se: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 Id,Rr=class extends Lt{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 im=Object.create;var ts=Object.defineProperty;var am=Object.getOwnPropertyDescriptor;var cm=Object.getOwnPropertyNames;var um=Object.getPrototypeOf,lm=Object.prototype.hasOwnProperty;var ye=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),vt=(r,t)=>{for(var e in t)ts(r,e,{get:t[e],enumerable:!0})},xl=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of cm(t))!lm.call(r,o)&&o!==e&&ts(r,o,{get:()=>t[o],enumerable:!(n=am(t,o))||n.enumerable});return r};var Jt=(r,t,e)=>(e=r!=null?im(um(r)):{},xl(t||!r||!r.__esModule?ts(e,"default",{value:r,enumerable:!0}):e,r)),fm=r=>xl(ts({},"__esModule",{value:!0}),r);var sn=ye((mE,Rl)=>{"use strict";function Il(r,t){for(let e in t)Object.defineProperty(r,e,{value:t[e],enumerable:!0,configurable:!0});return r}function Am(r,t,e){if(!r||typeof r=="string")throw new TypeError("Please pass an Error to err-code");e||(e={}),typeof t=="object"&&(e=t,t=""),t&&(e.code=t);try{return Il(r,e)}catch{e.message=r.message,e.stack=r.stack;let o=function(){};return o.prototype=Object.create(Object.getPrototypeOf(r)),Il(new o,e)}}Rl.exports=Am});var ff=ye((o2,lf)=>{var xn=1e3,En=xn*60,vn=En*60,zr=vn*24,Mg=zr*7,$g=zr*365.25;lf.exports=function(r,t){t=t||{};var e=typeof r;if(e==="string"&&r.length>0)return Hg(r);if(e==="number"&&isFinite(r))return t.long?qg(r):Kg(r);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(r))};function Hg(r){if(r=String(r),!(r.length>100)){var 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){var e=parseFloat(t[1]),n=(t[2]||"ms").toLowerCase();switch(n){case"years":case"year":case"yrs":case"yr":case"y":return e*$g;case"weeks":case"week":case"w":return e*Mg;case"days":case"day":case"d":return e*zr;case"hours":case"hour":case"hrs":case"hr":case"h":return e*vn;case"minutes":case"minute":case"mins":case"min":case"m":return e*En;case"seconds":case"second":case"secs":case"sec":case"s":return e*xn;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return e;default:return}}}}function Kg(r){var t=Math.abs(r);return t>=zr?Math.round(r/zr)+"d":t>=vn?Math.round(r/vn)+"h":t>=En?Math.round(r/En)+"m":t>=xn?Math.round(r/xn)+"s":r+"ms"}function qg(r){var t=Math.abs(r);return t>=zr?gs(r,t,zr,"day"):t>=vn?gs(r,t,vn,"hour"):t>=En?gs(r,t,En,"minute"):t>=xn?gs(r,t,xn,"second"):r+" ms"}function gs(r,t,e,n){var o=t>=e*1.5;return Math.round(r/e)+" "+n+(o?"s":"")}});var df=ye((s2,hf)=>{function zg(r){e.debug=e,e.default=e,e.coerce=c,e.disable=s,e.enable=o,e.enabled=i,e.humanize=ff(),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 m=0;m<f.length;m++)l=(l<<5)-l+f.charCodeAt(m),l|=0;return e.colors[Math.abs(l)%e.colors.length]}e.selectColor=t;function e(f){let l,m=null,h,p;function d(...w){if(!d.enabled)return;let g=d,x=Number(new Date),b=x-(l||x);g.diff=b,g.prev=l,g.curr=x,l=x,w[0]=e.coerce(w[0]),typeof w[0]!="string"&&w.unshift("%O");let B=0;w[0]=w[0].replace(/%([a-zA-Z%])/g,(I,v)=>{if(I==="%%")return"%";B++;let E=e.formatters[v];if(typeof E=="function"){let U=w[B];I=E.call(g,U),w.splice(B,1),B--}return I}),e.formatArgs.call(g,w),(g.log||e.log).apply(g,w)}return d.namespace=f,d.useColors=e.useColors(),d.color=e.selectColor(f),d.extend=n,d.destroy=e.destroy,Object.defineProperty(d,"enabled",{enumerable:!0,configurable:!1,get:()=>m!==null?m:(h!==e.namespaces&&(h=e.namespaces,p=e.enabled(f)),p),set:w=>{m=w}}),typeof e.init=="function"&&e.init(d),d}function n(f,l){let m=e(this.namespace+(typeof l>"u"?":":l)+f);return m.log=this.log,m}function o(f){e.save(f),e.namespaces=f,e.names=[],e.skips=[];let l,m=(typeof f=="string"?f:"").split(/[\s,]+/),h=m.length;for(l=0;l<h;l++)m[l]&&(f=m[l].replace(/\*/g,".*?"),f[0]==="-"?e.skips.push(new RegExp("^"+f.slice(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,m;for(l=0,m=e.skips.length;l<m;l++)if(e.skips[l].test(f))return!1;for(l=0,m=e.names.length;l<m;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.enable(e.load()),e}hf.exports=zg});var pf=ye((Qt,ys)=>{Qt.formatArgs=jg;Qt.save=Wg;Qt.load=Yg;Qt.useColors=Gg;Qt.storage=Zg();Qt.destroy=(()=>{let r=!1;return()=>{r||(r=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})();Qt.colors=["#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 Gg(){return typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs)?!0:typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)?!1:typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function jg(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+ys.exports.humanize(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)}Qt.log=console.debug||console.log||(()=>{});function Wg(r){try{r?Qt.storage.setItem("debug",r):Qt.storage.removeItem("debug")}catch{}}function Yg(){let r;try{r=Qt.storage.getItem("debug")}catch{}return!r&&typeof process<"u"&&"env"in process&&(r=process.env.DEBUG),r}function Zg(){try{return localStorage}catch{}}ys.exports=df()(Qt);var{formatters:Jg}=ys.exports;Jg.j=function(r){try{return JSON.stringify(r)}catch(t){return"[UnexpectedJSONParseError]: "+t.message}}});var yf=ye((l2,bc)=>{"use strict";var Qg=Object.prototype.hasOwnProperty,Ht="~";function go(){}Object.create&&(go.prototype=Object.create(null),new go().__proto__||(Ht=!1));function ty(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function gf(r,t,e,n,o){if(typeof e!="function")throw new TypeError("The listener must be a function");var s=new ty(e,n||r,o),i=Ht?Ht+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 ws(r,t){--r._eventsCount===0?r._events=new go:delete r._events[t]}function Vt(){this._events=new go,this._eventsCount=0}Vt.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)Qg.call(e,n)&&t.push(Ht?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};Vt.prototype.listeners=function(t){var e=Ht?Ht+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};Vt.prototype.listenerCount=function(t){var e=Ht?Ht+t:t,n=this._events[e];return n?n.fn?1:n.length:0};Vt.prototype.emit=function(t,e,n,o,s,i){var a=Ht?Ht+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 m=c.length,h;for(l=0;l<m;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};Vt.prototype.on=function(t,e,n){return gf(this,t,e,n,!1)};Vt.prototype.once=function(t,e,n){return gf(this,t,e,n,!0)};Vt.prototype.removeListener=function(t,e,n,o){var s=Ht?Ht+t:t;if(!this._events[s])return this;if(!e)return ws(this,s),this;var i=this._events[s];if(i.fn)i.fn===e&&(!o||i.once)&&(!n||i.context===n)&&ws(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:ws(this,s)}return this};Vt.prototype.removeAllListeners=function(t){var e;return t?(e=Ht?Ht+t:t,this._events[e]&&ws(this,e)):(this._events=new go,this._eventsCount=0),this};Vt.prototype.off=Vt.prototype.removeListener;Vt.prototype.addListener=Vt.prototype.on;Vt.prefixed=Ht;Vt.EventEmitter=Vt;typeof bc<"u"&&(bc.exports=Vt)});var vf=ye((L2,Ef)=>{Ef.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 Dd=ye(jn=>{"use strict";var vb="[object ArrayBuffer]",or=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===vb}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}},du="string",Ab=/^[0-9a-f]+$/i,Bb=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,kb=/^[a-zA-Z0-9-_]+$/,ai=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=or.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return decodeURIComponent(escape(n))}},me=class{static toString(t,e=!1){let n=or.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}},ci=class r{static isHex(t){return typeof t===du&&Ab.test(t)}static isBase64(t){return typeof t===du&&Bb.test(t)}static isBase64Url(t){return typeof t===du&&kb.test(t)}static ToString(t,e="utf8"){let n=or.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 me.toString(n,!0);case"utf16":case"utf16be":return me.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 me.fromString(t,!0);case"utf16":case"utf16be":return me.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=or.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 ai.fromString(t);case"utf16":case"utf16be":return me.fromString(t);case"utf16le":case"usc2":return me.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 ai.toString(t);case"utf16":case"utf16be":return me.toString(t);case"utf16le":case"usc2":return me.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=or.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return n}static ToHex(t){let e=or.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 me.toString(t,e)}static FromUtf16String(t,e=!1){return me.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,"")||""}};ci.DEFAULT_UTF8_ENCODING="utf8";function Sb(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 Ib(...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 Rb(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}jn.BufferSourceConverter=or;jn.Convert=ci;jn.assign=Sb;jn.combine=Ib;jn.isEqual=Rb});var Mp=ye((zo,Ji)=>{(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 p=0;p<h.length;p++)if(!Number.isInteger(h[p])||h[p]<0||h[p]>255)return!1;return!0}function o(h,p){return(h&65535)*p+(((h>>>16)*p&65535)<<16)}function s(h,p){return h<<p|h>>>32-p}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,p){h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535],p=[p[0]>>>16,p[0]&65535,p[1]>>>16,p[1]&65535];var d=[0,0,0,0];return d[3]+=h[3]+p[3],d[2]+=d[3]>>>16,d[3]&=65535,d[2]+=h[2]+p[2],d[1]+=d[2]>>>16,d[2]&=65535,d[1]+=h[1]+p[1],d[0]+=d[1]>>>16,d[1]&=65535,d[0]+=h[0]+p[0],d[0]&=65535,[d[0]<<16|d[1],d[2]<<16|d[3]]}function c(h,p){h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535],p=[p[0]>>>16,p[0]&65535,p[1]>>>16,p[1]&65535];var d=[0,0,0,0];return d[3]+=h[3]*p[3],d[2]+=d[3]>>>16,d[3]&=65535,d[2]+=h[2]*p[3],d[1]+=d[2]>>>16,d[2]&=65535,d[2]+=h[3]*p[2],d[1]+=d[2]>>>16,d[2]&=65535,d[1]+=h[1]*p[3],d[0]+=d[1]>>>16,d[1]&=65535,d[1]+=h[2]*p[2],d[0]+=d[1]>>>16,d[1]&=65535,d[1]+=h[3]*p[1],d[0]+=d[1]>>>16,d[1]&=65535,d[0]+=h[0]*p[3]+h[1]*p[2]+h[2]*p[1]+h[3]*p[0],d[0]&=65535,[d[0]<<16|d[1],d[2]<<16|d[3]]}function u(h,p){return p%=64,p===32?[h[1],h[0]]:p<32?[h[0]<<p|h[1]>>>32-p,h[1]<<p|h[0]>>>32-p]:(p-=32,[h[1]<<p|h[0]>>>32-p,h[0]<<p|h[1]>>>32-p])}function f(h,p){return p%=64,p===0?h:p<32?[h[0]<<p|h[1]>>>32-p,h[1]<<p]:[h[1]<<p-32,0]}function l(h,p){return[h[0]^p[0],h[1]^p[1]]}function m(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,p){if(e.inputValidation&&!n(h))return t;p=p||0;for(var d=h.length%4,w=h.length-d,g=p,x=0,b=3432918353,B=461845907,A=0;A<w;A=A+4)x=h[A]|h[A+1]<<8|h[A+2]<<16|h[A+3]<<24,x=o(x,b),x=s(x,15),x=o(x,B),g^=x,g=s(g,13),g=o(g,5)+3864292196;switch(x=0,d){case 3:x^=h[A+2]<<16;case 2:x^=h[A+1]<<8;case 1:x^=h[A],x=o(x,b),x=s(x,15),x=o(x,B),g^=x}return g^=h.length,g=i(g),g>>>0},e.x86.hash128=function(h,p){if(e.inputValidation&&!n(h))return t;p=p||0;for(var d=h.length%16,w=h.length-d,g=p,x=p,b=p,B=p,A=0,I=0,v=0,E=0,U=597399067,P=2869860233,N=951274213,M=2716044179,C=0;C<w;C=C+16)A=h[C]|h[C+1]<<8|h[C+2]<<16|h[C+3]<<24,I=h[C+4]|h[C+5]<<8|h[C+6]<<16|h[C+7]<<24,v=h[C+8]|h[C+9]<<8|h[C+10]<<16|h[C+11]<<24,E=h[C+12]|h[C+13]<<8|h[C+14]<<16|h[C+15]<<24,A=o(A,U),A=s(A,15),A=o(A,P),g^=A,g=s(g,19),g+=x,g=o(g,5)+1444728091,I=o(I,P),I=s(I,16),I=o(I,N),x^=I,x=s(x,17),x+=b,x=o(x,5)+197830471,v=o(v,N),v=s(v,17),v=o(v,M),b^=v,b=s(b,15),b+=B,b=o(b,5)+2530024501,E=o(E,M),E=s(E,18),E=o(E,U),B^=E,B=s(B,13),B+=g,B=o(B,5)+850148119;switch(A=0,I=0,v=0,E=0,d){case 15:E^=h[C+14]<<16;case 14:E^=h[C+13]<<8;case 13:E^=h[C+12],E=o(E,M),E=s(E,18),E=o(E,U),B^=E;case 12:v^=h[C+11]<<24;case 11:v^=h[C+10]<<16;case 10:v^=h[C+9]<<8;case 9:v^=h[C+8],v=o(v,N),v=s(v,17),v=o(v,M),b^=v;case 8:I^=h[C+7]<<24;case 7:I^=h[C+6]<<16;case 6:I^=h[C+5]<<8;case 5:I^=h[C+4],I=o(I,P),I=s(I,16),I=o(I,N),x^=I;case 4:A^=h[C+3]<<24;case 3:A^=h[C+2]<<16;case 2:A^=h[C+1]<<8;case 1:A^=h[C],A=o(A,U),A=s(A,15),A=o(A,P),g^=A}return g^=h.length,x^=h.length,b^=h.length,B^=h.length,g+=x,g+=b,g+=B,x+=g,b+=g,B+=g,g=i(g),x=i(x),b=i(b),B=i(B),g+=x,g+=b,g+=B,x+=g,b+=g,B+=g,("00000000"+(g>>>0).toString(16)).slice(-8)+("00000000"+(x>>>0).toString(16)).slice(-8)+("00000000"+(b>>>0).toString(16)).slice(-8)+("00000000"+(B>>>0).toString(16)).slice(-8)},e.x64.hash128=function(h,p){if(e.inputValidation&&!n(h))return t;p=p||0;for(var d=h.length%16,w=h.length-d,g=[0,p],x=[0,p],b=[0,0],B=[0,0],A=[2277735313,289559509],I=[1291169091,658871167],v=0;v<w;v=v+16)b=[h[v+4]|h[v+5]<<8|h[v+6]<<16|h[v+7]<<24,h[v]|h[v+1]<<8|h[v+2]<<16|h[v+3]<<24],B=[h[v+12]|h[v+13]<<8|h[v+14]<<16|h[v+15]<<24,h[v+8]|h[v+9]<<8|h[v+10]<<16|h[v+11]<<24],b=c(b,A),b=u(b,31),b=c(b,I),g=l(g,b),g=u(g,27),g=a(g,x),g=a(c(g,[0,5]),[0,1390208809]),B=c(B,I),B=u(B,33),B=c(B,A),x=l(x,B),x=u(x,31),x=a(x,g),x=a(c(x,[0,5]),[0,944331445]);switch(b=[0,0],B=[0,0],d){case 15:B=l(B,f([0,h[v+14]],48));case 14:B=l(B,f([0,h[v+13]],40));case 13:B=l(B,f([0,h[v+12]],32));case 12:B=l(B,f([0,h[v+11]],24));case 11:B=l(B,f([0,h[v+10]],16));case 10:B=l(B,f([0,h[v+9]],8));case 9:B=l(B,[0,h[v+8]]),B=c(B,I),B=u(B,33),B=c(B,A),x=l(x,B);case 8:b=l(b,f([0,h[v+7]],56));case 7:b=l(b,f([0,h[v+6]],48));case 6:b=l(b,f([0,h[v+5]],40));case 5:b=l(b,f([0,h[v+4]],32));case 4:b=l(b,f([0,h[v+3]],24));case 3:b=l(b,f([0,h[v+2]],16));case 2:b=l(b,f([0,h[v+1]],8));case 1:b=l(b,[0,h[v]]),b=c(b,A),b=u(b,31),b=c(b,I),g=l(g,b)}return g=l(g,[0,h.length]),x=l(x,[0,h.length]),g=a(g,x),x=a(x,g),g=m(g),x=m(x),g=a(g,x),x=a(x,g),("00000000"+(g[0]>>>0).toString(16)).slice(-8)+("00000000"+(g[1]>>>0).toString(16)).slice(-8)+("00000000"+(x[0]>>>0).toString(16)).slice(-8)+("00000000"+(x[1]>>>0).toString(16)).slice(-8)},typeof zo<"u"?(typeof Ji<"u"&&Ji.exports&&(zo=Ji.exports=e),zo.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)})(zo)});var Hp=ye((lI,$p)=>{$p.exports=Mp()});var qp=ye(jo=>{(function(){var r,t,e,n,o,s,i,a;a=function(c){var u,f,l,m;return u=(c&255<<24)>>>24,f=(c&255<<16)>>>16,l=(c&65280)>>>8,m=c&255,[u,f,l,m].join(".")},i=function(c){var u,f,l,m,h,p;for(u=[],l=m=0;m<=3&&c.length!==0;l=++m){if(l>0){if(c[0]!==".")throw new Error("Invalid IP");c=c.substring(1)}p=t(c),h=p[0],f=p[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,m,h;for(m=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)m=m*u+(e(c[l])-n)>>>0;else if(u===16)if("a"<=c[l]&&c[l]<="f")m=m*u+(10+e(c[l])-s)>>>0;else if("A"<=c[l]&&c[l]<="F")m=m*u+(10+e(c[l])-o)>>>0;else break;else break;if(m>4294967295)throw new Error("too large");l++}if(l===h)throw new Error("empty octet");return[m,l]},r=function(){function c(u,f){var l,m,h,p;if(typeof u!="string")throw new Error("Missing `net' parameter");if(f||(p=u.split("/",2),u=p[0],f=p[1]),f||(f=32),typeof f=="string"&&f.indexOf(".")>-1){try{this.maskLong=i(f)}catch(d){throw l=d,new Error("Invalid mask: "+f)}for(m=h=32;h>=0;m=--h)if(this.maskLong===4294967295<<32-m>>>0){this.bitmask=m;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(d){throw l=d,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,m;for(m=i(this.first),l=i(this.last),f=0;m<=l;)u(a(m),m,f),f++,m++},c.prototype.toString=function(){return this.base+"/"+this.bitmask},c}(),jo.ip2long=i,jo.long2ip=a,jo.Netmask=r}).call(jo)});var Yu=ye((t3,Wu)=>{var Q4=function(){typeof Wu<"u"&&(Wu.exports=d);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(E){var U=E-E%1;return U==0&&(E<0||E===0&&1/E!=1/0)?-0:U},f=d.prototype,l=(d.fromDate=function(E){return new d(+E)},d.fromInt64BE=B(0,1,2,3,0,4),d.fromInt64LE=B(3,2,1,0,4,0),d.fromString=function(N){var U,P=new d,N=(N+="").replace(/^\s*[+\-]?\d+/,function(C){var C=+C,X=1970+(C-1970)%400;return P.year=C-X,X}).replace(/(?:Z|([+\-]\d{2}):?(\d{2}))$/,function(M,C,X){return C<0&&(X*=-1),U=6e4*(60*+C+ +X),""}).replace(/\.\d+$/,function(M){return P.nano=+(M+c).substr(1,9),""}).split(/\D+/);if(1<N.length?N[1]--:N[1]=0,P.time=U=Date.UTC.apply(Date,N)-(U||0),isNaN(U))throw new TypeError("Invalid Date");return w(P)},d.fromTimeT=function(E){return x(E,0)},f.year=0,f.time=0,f.nano=0,f.addNano=function(E){return this.nano+=+E||0,this},f.getNano=function(){var E=w(this);return(E.time%1e3*a+ +E.nano+1e9)%1e9},f.getTimeT=function(){var U=w(this),E=Math.floor(U.time/1e3),U=U.year;return U&&(E+=U*e*r/t),E},f.getYear=function(){return this.toDate().getUTCFullYear()+this.year},f.toDate=function(){return g(w(this).time)},f.toJSON=function(){return this.toString().replace(/0{1,6}Z$/,"Z")},f.toString=function(E){var U=this,P=U.toDate(),N={H:function(){return I(P.getUTCHours())},L:function(){return v(P.getUTCMilliseconds(),3)},M:function(){return I(P.getUTCMinutes())},N:function(){return v(U.getNano(),9)},S:function(){return I(P.getUTCSeconds())},Y:function(){var M=U.getYear();return 999999<M?"+"+M:9999<M?"+"+v(M,6):0<=M?v(M,4):-999999<=M?"-"+v(-M,6):M},a:function(){return h[P.getUTCDay()]},b:function(){return m[P.getUTCMonth()]},d:function(){return I(P.getUTCDate())},e:function(){return function(M){return(9<M?"":" ")+(0|M)}(P.getUTCDate())},m:function(){return I(P.getUTCMonth()+1)}};return function M(C){return C.replace(/%./g,function(X){var T=X[1],S=p[T],T=N[T];return S?M(S):T?T():X})}(E||l)},f.writeInt64BE=b(0,1,2,3,0,4),f.writeInt64LE=b(3,2,1,0,4,0),"%Y-%m-%dT%H:%M:%S.%NZ"),m=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],h=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],p={"%":"%",F:"%Y-%m-%d",n:`
3
+ `,R:"%H:%M",T:"%H:%M:%S",t:" ",X:"%T",Z:"GMT",z:"+0000"};return d;function d(E,U,P){var N=this;if(!(N instanceof d))return new d(E,U,P);N.time=+E||0,N.nano=+U||0,N.year=+P||0,w(N)}function w(E){var U,P,N,M=E.year,C=E.time,X=E.nano,S=((X<0||a<=X)&&(X-=(P=Math.floor(X/a))*a,C+=P,P=1),M%t);return(C<-s||s<C||S)&&((U=u(C/o))&&(M+=U*t,C-=U*o),(N=g(C)).setUTCFullYear(S+N.getUTCFullYear()),N=(C=+N)+(U=u((M-=S)/t))*o,U&&-s<=N&&N<=s&&(M-=U*t,C=N),P=1),P&&(E.year=M,E.time=C,E.nano=X),E}function g(E){var U=new Date(0);return U.setTime(E),U}function x(M,N){M=+M||0;var P=u((N=(N|0)*i)/n)+u(M/n),N=N%n+M%n,M=u(N/n);return M&&(P+=M,N-=M*n),new d(1e3*N,0,P*t)}function b(E,U,P,N,M,C){return function(S,T){var _=w(this);S=S||new Array(8),A(S,T|=0);var k=Math.floor(_.time/1e3),_=_.year*(e*r/t),H=u(_/i)+u(k/i),_=_%i+k%i,k=Math.floor(_/i);return k&&(H+=k,_-=k*i),X(S,T+M,H),X(S,T+C,_),S};function X(S,T,H){S[T+E]=H>>24&255,S[T+U]=H>>16&255,S[T+P]=H>>8&255,S[T+N]=255&H}}function B(E,U,P,N,M,C){return function(S,T){A(S,T|=0);var H=X(S,T+M);return x(X(S,T+C),H)};function X(S,T){return 16777216*S[T+E]+(S[T+U]<<16|S[T+P]<<8|S[T+N])}}function A(E,U){if(E=E&&E.length,E==null)throw new TypeError("Invalid Buffer");if(E<U+8)throw new RangeError("Out of range")}function I(E){return(9<E?"":"0")+(0|E)}function v(E,U){return(c+(0|E)).substr(-U)}}()});var B1={};vt(B1,{DEFAULT_SESSION_MAX_PROVIDERS:()=>ad,DEFAULT_SESSION_MIN_PROVIDERS:()=>id,createHeliaHTTP:()=>A1});var oo=Symbol.for("@libp2p/content-routing");var so=Symbol.for("@libp2p/peer-id");function El(r){return r!=null&&!!r[so]}var io=Symbol.for("@libp2p/peer-routing");var pr=class r extends Error{code;type;constructor(t="The operation was aborted"){super(t),this.name="AbortError",this.code=r.code,this.type=r.type}static code="ABORT_ERR";static type="aborted"},D=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var ft=(r,...t)=>{try{[...t]}catch{}};var rn=class extends EventTarget{#t=new Map;constructor(){super(),ft(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 hm(t,e))}},Sa=class extends Event{detail;constructor(t,e){super(t,e),this.detail=e?.detail}},hm=globalThis.CustomEvent??Sa;function vl(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function mr(...r){let t=[];for(let e of r)vl(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 gr(...r){let t=[];for(let e of r)vl(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 kt(){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}},nn=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 Ia=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Vr(r={}){return dm(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 dm(r,t){t=t??{};let e=t.onEnd,n=new nn,o,s,i,a=kt(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((w,g)=>{s=x=>{s=null,n.push(x);try{w(r(n))}catch(b){g(b)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=kt()})}},u=w=>s!=null?s(w):(n.push(w),o),f=w=>(n=new nn,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})},m=w=>i?o:(i=!0,w!=null?f(w):u({done:!0})),h=()=>(n=new nn,m(),{done:!0}),p=w=>(m(w),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:h,throw:p,push:l,end:m,get readableLength(){return n.size},onEmpty:async w=>{let g=w?.signal;if(g?.throwIfAborted(),n.isEmpty())return;let x,b;g!=null&&(x=new Promise((B,A)=>{b=()=>{A(new Ia)},g.addEventListener("abort",b)}));try{await Promise.race([a.promise,x])}finally{b!=null&&g!=null&&g?.removeEventListener("abort",b)}}},e==null)return o;let d=o;return o={[Symbol.asyncIterator](){return this},next(){return d.next()},throw(w){return d.throw(w),e!=null&&(e(w),e=void 0),{done:!0}},return(){return d.return(),e!=null&&(e(),e=void 0),{done:!0}},push:l,end(w){return d.end(w),e!=null&&(e(w),e=void 0),o},get readableLength(){return d.readableLength},onEmpty:w=>d.onEmpty(w)},o}var Ra=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 Ra(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(m){a(),i(m);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{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=e??"ABORT_ERR"}};async function Al(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new ns(e?.errorMessage,e?.errorCode));let n,o=new ns(e?.errorMessage,e?.errorCode);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 os=class{deferred;signal;where;constructor(t,e){this.signal=e,this.deferred=kt(),this.where=t,this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new pr)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function pm(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var ss=class{id;fn;options;priority;recipients;status;timeline;controller;constructor(t,e,n=0){this.id=pm(),this.status="queued",this.fn=t,this.priority=n,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,ft(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 pr),this.cleanup())}async join(t={}){let e=new os(new Error("where").stack,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 Al(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)})}};function mm(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 qe=class extends rn{concurrency;queue;pending;constructor(t={}){super(),this.concurrency=t.concurrency??Number.POSITIVE_INFINITY,this.pending=0,t.metricName!=null&&t.metrics?.registerMetricGroup(t.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.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){if(this.queue[this.size-1]?.priority>=t.priority){this.queue.push(t);return}let e=mm(this.queue,t,(n,o)=>o.priority-n.priority);this.queue.splice(e,0,t)}async add(t,e){e?.signal?.throwIfAborted();let n=new ss(t,e,e?.priority),o=n.join(e).then(s=>(this.safeDispatchEvent("completed",{detail:s}),this.safeDispatchEvent("success",{detail:{job:n,result:s}}),s)).catch(s=>{if(n.status==="queued"){for(let i=0;i<this.queue.length;i++)if(this.queue[i]===n){this.queue.splice(i,1);break}}throw this.safeDispatchEvent("error",{detail:s}),this.safeDispatchEvent("failure",{detail:{job:n,error:s}}),s});return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),o}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(t=>{t.abort(new pr)}),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=Vr({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 D("Queue aborted","ERR_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 is=class extends qe{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 ym(r){if(gm(r))return(async()=>{for await(let t of r);})();for(let t of r);}var Mr=ym;function we(r=0){return new Uint8Array(r)}function Gt(r=0){return new Uint8Array(r)}var wm=Math.pow(2,7),bm=Math.pow(2,14),xm=Math.pow(2,21),_a=Math.pow(2,28),Ta=Math.pow(2,35),Ca=Math.pow(2,42),Na=Math.pow(2,49),st=128,Ot=127;function jt(r){if(r<wm)return 1;if(r<bm)return 2;if(r<xm)return 3;if(r<_a)return 4;if(r<Ta)return 5;if(r<Ca)return 6;if(r<Na)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function La(r,t,e=0){switch(jt(r)){case 8:t[e++]=r&255|st,r/=128;case 7:t[e++]=r&255|st,r/=128;case 6:t[e++]=r&255|st,r/=128;case 5:t[e++]=r&255|st,r/=128;case 4:t[e++]=r&255|st,r>>>=7;case 3:t[e++]=r&255|st,r>>>=7;case 2:t[e++]=r&255|st,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function Em(r,t,e=0){switch(jt(r)){case 8:t.set(e++,r&255|st),r/=128;case 7:t.set(e++,r&255|st),r/=128;case 6:t.set(e++,r&255|st),r/=128;case 5:t.set(e++,r&255|st),r/=128;case 4:t.set(e++,r&255|st),r>>>=7;case 3:t.set(e++,r&255|st),r>>>=7;case 2:t.set(e++,r&255|st),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Ua(r,t){let e=r[t],n=0;if(n+=e&Ot,e<st||(e=r[t+1],n+=(e&Ot)<<7,e<st)||(e=r[t+2],n+=(e&Ot)<<14,e<st)||(e=r[t+3],n+=(e&Ot)<<21,e<st)||(e=r[t+4],n+=(e&Ot)*_a,e<st)||(e=r[t+5],n+=(e&Ot)*Ta,e<st)||(e=r[t+6],n+=(e&Ot)*Ca,e<st)||(e=r[t+7],n+=(e&Ot)*Na,e<st))return n;throw new RangeError("Could not decode varint")}function vm(r,t){let e=r.get(t),n=0;if(n+=e&Ot,e<st||(e=r.get(t+1),n+=(e&Ot)<<7,e<st)||(e=r.get(t+2),n+=(e&Ot)<<14,e<st)||(e=r.get(t+3),n+=(e&Ot)<<21,e<st)||(e=r.get(t+4),n+=(e&Ot)*_a,e<st)||(e=r.get(t+5),n+=(e&Ot)*Ta,e<st)||(e=r.get(t+6),n+=(e&Ot)*Ca,e<st)||(e=r.get(t+7),n+=(e&Ot)*Na,e<st))return n;throw new RangeError("Could not decode varint")}function on(r,t,e=0){return t==null&&(t=Gt(jt(r))),t instanceof Uint8Array?La(r,t,e):Em(r,t,e)}function $r(r,t=0){return r instanceof Uint8Array?Ua(r,t):vm(r,t)}function St(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=Gt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}function it(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}var Sl=Symbol.for("@achingbrain/uint8arraylist");function kl(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let o=e+n.byteLength;if(t<o)return{buf:n,index:t-e};e=o}throw new RangeError("index is out of bounds")}function as(r){return!!r?.[Sl]}var cs=class r{bufs;length;[Sl]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(as(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(as(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=kl(this.bufs,t);return e.buf[e.index]}set(t,e){let n=kl(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(as(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:o}=this._subList(t,e);return St(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:St(n,o)}sublist(t,e){let{bufs:n,length:o}=this._subList(t,e),s=new r;return s.length=o,s.bufs=[...n],s}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],o=0;for(let s=0;s<this.bufs.length;s++){let i=this.bufs[s],a=o,c=a+i.byteLength;if(o=c,t>=c)continue;let u=t>=a&&t<c,f=e>a&&e<=c;if(u&&f){if(t===a&&e===c){n.push(i);break}let l=t-a;n.push(i.subarray(l,l+(e-t)));break}if(u){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(f){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!as(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let s=256,i=new Int32Array(s);for(let l=0;l<s;l++)i[l]=-1;for(let l=0;l<o;l++)i[n[l]]=l;let a=i,c=this.byteLength-n.byteLength,u=n.byteLength-1,f;for(let l=e;l<=c;l+=f){f=0;for(let m=u;m>=0;m--){let h=this.get(l+m);if(n[m]!==h){f=Math.max(1,m-a[h]);break}}if(f===0)return l}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=Gt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let o=we(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,e,n),this.write(o,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let o=we(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,e,n),this.write(o,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let o=we(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,e,n),this.write(o,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=Gt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let o=we(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,e,n),this.write(o,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let o=we(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,e,n),this.write(o,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let o=we(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,e,n),this.write(o,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let o=we(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,e,n),this.write(o,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let o=we(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,e,n),this.write(o,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!it(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((o,s)=>o+s.byteLength,0)),n.length=e,n}};function Bm(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 an=Bm;function km(r){return r[Symbol.asyncIterator]!=null}function Sm(r,t){let e=0;if(km(r))return async function*(){for await(let c of r)yield t(c,e++)}();let n=an(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 cn=Sm;function Im(r){return r[Symbol.asyncIterator]!=null}function Rm(...r){let t=[];for(let e of r)Im(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Vr({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 Hr=Rm;function _m(r){return r[Symbol.asyncIterator]!=null}function Tm(r,t){return _m(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 us=Tm;var nt=class extends Event{constructor(t,e){super(t),this.detail=e}};var Da=new Float32Array([-0]),yr=new Uint8Array(Da.buffer);function _l(r,t,e){Da[0]=r,t[e]=yr[0],t[e+1]=yr[1],t[e+2]=yr[2],t[e+3]=yr[3]}function Tl(r,t){return yr[0]=r[t],yr[1]=r[t+1],yr[2]=r[t+2],yr[3]=r[t+3],Da[0]}var Pa=new Float64Array([-0]),Ft=new Uint8Array(Pa.buffer);function Cl(r,t,e){Pa[0]=r,t[e]=Ft[0],t[e+1]=Ft[1],t[e+2]=Ft[2],t[e+3]=Ft[3],t[e+4]=Ft[4],t[e+5]=Ft[5],t[e+6]=Ft[6],t[e+7]=Ft[7]}function Nl(r,t){return Ft[0]=r[t],Ft[1]=r[t+1],Ft[2]=r[t+2],Ft[3]=r[t+3],Ft[4]=r[t+4],Ft[5]=r[t+5],Ft[6]=r[t+6],Ft[7]=r[t+7],Pa[0]}var Cm=BigInt(Number.MAX_SAFE_INTEGER),Nm=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 Kr;if(t<Cm&&t>Nm)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>Ll&&(o=0n,++n>Ll&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Kr;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):Kr}},Kr=new Xt(0,0);Kr.toBigInt=function(){return 0n};Kr.zzEncode=Kr.zzDecode=function(){return this};Kr.length=function(){return 1};var Ll=4294967296n;function Ul(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 Dl(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 Oa(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 be(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function ls(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Fa=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,be(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 be(this,4);return ls(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw be(this,4);return ls(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw be(this,4);let t=Tl(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw be(this,4);let t=Nl(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 be(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Dl(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw be(this,t);this.pos+=t}else do if(this.pos>=this.len)throw be(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 be(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 be(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 be(this,8);let t=ls(this.buf,this.pos+=4),e=ls(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=Ua(this.buf,this.pos);return this.pos+=jt(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 Va(r){return new Fa(r instanceof Uint8Array?r:r.subarray())}function un(r,t,e){let n=Va(r);return t.decode(n,void 0,e)}var qa={};vt(qa,{base10:()=>Fm});var UE=new Uint8Array(0);function Ol(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 ze(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 Fl(r){return new TextEncoder().encode(r)}function Vl(r){return new TextDecoder().decode(r)}function Lm(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(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var d=0,w=0,g=0,x=p.length;g!==x&&p[g]===0;)g++,d++;for(var b=(x-g)*f+1>>>0,B=new Uint8Array(b);g!==x;){for(var A=p[g],I=0,v=b-1;(A!==0||I<w)&&v!==-1;v--,I++)A+=256*B[v]>>>0,B[v]=A%a>>>0,A=A/a>>>0;if(A!==0)throw new Error("Non-zero carry");w=I,g++}for(var E=b-w;E!==b&&B[E]===0;)E++;for(var U=c.repeat(d);E<b;++E)U+=r.charAt(B[E]);return U}function m(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var d=0;if(p[d]!==" "){for(var w=0,g=0;p[d]===c;)w++,d++;for(var x=(p.length-d)*u+1>>>0,b=new Uint8Array(x);p[d];){var B=e[p.charCodeAt(d)];if(B===255)return;for(var A=0,I=x-1;(B!==0||A<g)&&I!==-1;I--,A++)B+=a*b[I]>>>0,b[I]=B%256>>>0,B=B/256>>>0;if(B!==0)throw new Error("Non-zero carry");g=A,d++}if(p[d]!==" "){for(var v=x-g;v!==x&&b[v]===0;)v++;for(var E=new Uint8Array(w+(x-v)),U=w;v!==x;)E[U++]=b[v++];return E}}}function h(p){var d=m(p);if(d)return d;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:m,decode:h}}var Um=Lm,Dm=Um,$l=Dm;var Ma=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")}},$a=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Hl(this,t)}},Ha=class{decoders;constructor(t){this.decoders=t}or(t){return Hl(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 Hl(r,t){return new Ha({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Ka=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 Ma(t,e,n),this.decoder=new $a(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function ln({name:r,prefix:t,encode:e,decode:n}){return new Ka(r,t,e,n)}function wr({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=$l(e,r);return ln({prefix:t,name:r,encode:n,decode:s=>ze(o(s))})}function Pm(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 Om(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 pt({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return ln({prefix:t,name:r,encode(o){return Om(o,n,e)},decode(o){return Pm(o,n,e,r)}})}var Fm=wr({prefix:"9",name:"base10",alphabet:"0123456789"});var za={};vt(za,{base16:()=>Vm,base16upper:()=>Mm});var Vm=pt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Mm=pt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ga={};vt(Ga,{base2:()=>$m});var $m=pt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ja={};vt(ja,{base256emoji:()=>Gm});var Kl=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}"),Hm=Kl.reduce((r,t,e)=>(r[e]=t,r),[]),Km=Kl.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function qm(r){return r.reduce((t,e)=>(t+=Hm[e],t),"")}function zm(r){let t=[];for(let e of r){let n=Km[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Gm=ln({prefix:"\u{1F680}",name:"base256emoji",encode:qm,decode:zm});var Wa={};vt(Wa,{base32:()=>Ct,base32hex:()=>Ym,base32hexpad:()=>Jm,base32hexpadupper:()=>Xm,base32hexupper:()=>Zm,base32pad:()=>jm,base32padupper:()=>Wm,base32upper:()=>ql,base32z:()=>Qm});var Ct=pt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ql=pt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),jm=pt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Wm=pt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Ym=pt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Zm=pt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Jm=pt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Xm=pt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Qm=pt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ya={};vt(Ya,{base36:()=>br,base36upper:()=>tg});var br=wr({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),tg=wr({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Za={};vt(Za,{base58btc:()=>ht,base58flickr:()=>eg});var ht=wr({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),eg=wr({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Xa={};vt(Xa,{base64:()=>le,base64pad:()=>rg,base64url:()=>Ja,base64urlpad:()=>ng});var le=pt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),rg=pt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Ja=pt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),ng=pt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Qa={};vt(Qa,{base8:()=>og});var og=pt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var tc={};vt(tc,{identity:()=>sg});var sg=ln({prefix:"\0",name:"identity",encode:r=>Vl(r),decode:r=>Fl(r)});var ZE=new TextEncoder,JE=new TextDecoder;var zl=512;var fs=85;var nc={};vt(nc,{identity:()=>Wt});var ig=Yl,jl=128,ag=127,cg=~ag,ug=Math.pow(2,31);function Yl(r,t,e){t=t||[],e=e||0;for(var n=e;r>=ug;)t[e++]=r&255|jl,r/=128;for(;r&cg;)t[e++]=r&255|jl,r>>>=7;return t[e]=r|0,Yl.bytes=e-n+1,t}var lg=rc,fg=128,Wl=127;function rc(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw rc.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&Wl)<<o:(i&Wl)*Math.pow(2,o),o+=7}while(i>=fg);return rc.bytes=s-n,e}var hg=Math.pow(2,7),dg=Math.pow(2,14),pg=Math.pow(2,21),mg=Math.pow(2,28),gg=Math.pow(2,35),yg=Math.pow(2,42),wg=Math.pow(2,49),bg=Math.pow(2,56),xg=Math.pow(2,63),Eg=function(r){return r<hg?1:r<dg?2:r<pg?3:r<mg?4:r<gg?5:r<yg?6:r<wg?7:r<bg?8:r<xg?9:10},vg={encode:ig,decode:lg,encodingLength:Eg},Ag=vg,ao=Ag;function co(r,t=0){return[ao.decode(r,t),ao.decode.bytes]}function fn(r,t,e=0){return ao.encode(r,t,e),t}function hn(r){return ao.encodingLength(r)}function Ce(r,t){let e=t.byteLength,n=hn(r),o=n+hn(e),s=new Uint8Array(o+e);return fn(r,s,0),fn(e,s,n),s.set(t,o),new dn(r,e,t,s)}function Ne(r){let t=ze(r),[e,n]=co(t),[o,s]=co(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new dn(e,o,i,t)}function Zl(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Ol(r.bytes,e.bytes)}}var dn=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};var Jl=0,Bg="identity",Xl=ze;function kg(r){return Ce(Jl,Xl(r))}var Wt={code:Jl,name:Bg,encode:Xl,digest:kg};var ac={};vt(ac,{sha256:()=>At,sha512:()=>ic});function sc({name:r,code:t,encode:e}){return new oc(r,t,e)}var oc=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?Ce(this.code,e):e.then(n=>Ce(this.code,n))}else throw Error("Unknown type, must be binary type")}};function tf(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var At=sc({name:"sha2-256",code:18,encode:tf("SHA-256")}),ic=sc({name:"sha2-512",code:19,encode:tf("SHA-512")});function ef(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Ig(e,cc(r),t??ht.encoder);default:return Rg(e,cc(r),t??Ct.encoder)}}var rf=new WeakMap;function cc(r){let t=rf.get(r);if(t==null){let e=new Map;return rf.set(r,e),e}return t}var tt=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!==uo)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==_g)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=Ce(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&&Zl(t.multihash,n.multihash)}toString(t){return ef(this,t)}toJSON(){return{"/":ef(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[Tg]===!0){let{version:n,multihash:o,code:s}=e,i=Ne(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!==uo)throw new Error(`Version 0 CID must use dag-pb (code: ${uo}) 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,uo,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=ze(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 dn(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,m]=co(t.subarray(e));return e+=m,l},o=n(),s=uo;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]=Sg(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 cc(s).set(n,t),s}};function Sg(r,t){switch(r[0]){case"Q":{let e=t??ht;return[ht.prefix,e.decode(`${ht.prefix}${r}`)]}case ht.prefix:{let e=t??ht;return[ht.prefix,e.decode(r)]}case Ct.prefix:{let e=t??Ct;return[Ct.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Ig(r,t,e){let{prefix:n}=e;if(n!==ht.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 Rg(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 uo=112,_g=18;function nf(r,t,e){let n=hn(r),o=n+hn(t),s=new Uint8Array(o+e.byteLength);return fn(r,s,0),fn(t,s,n),s.set(e,o),s}var Tg=Symbol.for("@ipld/js-cid/CID");var xr={...tc,...Ga,...Qa,...qa,...za,...Wa,...Ya,...Za,...Xa,...ja},wv={...ac,...nc};function sf(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var of=sf("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),uc=sf("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=Gt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Cg={utf8:of,"utf-8":of,hex:xr.base16,latin1:uc,ascii:uc,binary:uc,...xr},ds=Cg;function q(r,t="utf8"){let e=ds[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function lc(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return Gt(i);o+i>t&&(n=Gt(t),o=0);let a=n.subarray(o,o+=i);return o&7&&(o=(o|7)+1),a}}var qr=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function fc(){}var dc=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Ng=lc();function Lg(r){return globalThis.Buffer!=null?Gt(r):Ng(r)}var fo=class{len;head;tail;states;constructor(){this.len=0,this.head=new qr(fc,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new qr(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new pc((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(La,jt(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(hc,1,t?1:0)}fixed32(t){return this._push(lo,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Xt.fromBigInt(t);return this._push(lo,4,e.lo)._push(lo,4,e.hi)}fixed64Number(t){let e=Xt.fromNumber(t);return this._push(lo,4,e.lo)._push(lo,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(_l,4,t)}double(t){return this._push(Cl,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(hc,1,0):this.uint32(e)._push(Dg,e,t)}string(t){let e=Ul(t);return e!==0?this.uint32(e)._push(Oa,e,t):this._push(hc,1,0)}fork(){return this.states=new dc(this),this.head=this.tail=new qr(fc,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 qr(fc,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=Lg(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function hc(r,t,e){t[e]=r&255}function Ug(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var pc=class extends qr{next;constructor(t,e){super(Ug,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 lo(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 Dg(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(fo.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Pg,t,r),this},fo.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Og,t,r),this});function Pg(r,t,e){t.set(r,e)}function Og(r,t,e){r.length<40?Oa(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(q(r),e)}function mc(){return new fo}function pn(r,t){let e=mc();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var mn;(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"})(mn||(mn={}));function ms(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function ho(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",mn.VARINT,e,n)}function gn(r,t){return ms("message",mn.LENGTH_DELIMITED,r,t)}var Fg=Symbol.for("nodejs.util.inspect.custom"),af=Object.values(xr).map(r=>r.decoder).reduce((r,t)=>r.or(t),xr.identity.decoder),cf=114,gc=36,yc=37,po=class{type;multihash;privateKey;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,this.privateKey=t.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[so]=!0;toString(){return this.string==null&&(this.string=ht.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return tt.createV1(cf,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return it(this.multihash.bytes,t);if(typeof t=="string")return wc(t).equals(this);if(t?.multihash?.bytes!=null)return it(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[Fg](){return`PeerId(${this.toString()})`}},yn=class extends po{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},wn=class extends po{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},bn=class extends po{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function wc(r,t){if(t=t??af,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Ne(ht.decode(`z${r}`));return r.startsWith("12D")?new wn({multihash:e}):r.startsWith("16U")?new bn({multihash:e}):new yn({multihash:e})}return mo(af.decode(r))}function mo(r){try{let t=Ne(r);if(t.code===Wt.code){if(t.digest.length===gc)return new wn({multihash:t});if(t.digest.length===yc)return new bn({multihash:t})}if(t.code===At.code)return new yn({multihash:t})}catch{return Vg(tt.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function Vg(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==cf)throw new Error("Supplied PeerID CID is invalid");let t=r.multihash;if(t.code===At.code)return new yn({multihash:r.multihash});if(t.code===Wt.code){if(t.digest.length===gc)return new wn({multihash:r.multihash});if(t.digest.length===yc)return new bn({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function uf(r,t){return r.length===gc?new wn({multihash:Ce(Wt.code,r),privateKey:t}):r.length===yc?new bn({multihash:Ce(Wt.code,r),privateKey:t}):new yn({multihash:await At.digest(r),publicKey:r,privateKey:t})}function z(r,t="utf8"){let e=ds[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var te=Jt(pf(),1);te.default.formatters.b=r=>r==null?"undefined":ht.baseEncode(r);te.default.formatters.t=r=>r==null?"undefined":Ct.baseEncode(r);te.default.formatters.m=r=>r==null?"undefined":le.baseEncode(r);te.default.formatters.p=r=>r==null?"undefined":r.toString();te.default.formatters.c=r=>r==null?"undefined":r.toString();te.default.formatters.k=r=>r==null?"undefined":r.toString();te.default.formatters.a=r=>r==null?"undefined":r.toString();function Xg(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 mf(){return{forComponent(r){return ee(r)}}}function ee(r){let t=Xg(`${r}:trace`);return te.default.enabled(`${r}:trace`)&&te.default.names.map(e=>e.toString()).find(e=>e.includes(":trace"))!=null&&(t=(0,te.default)(`${r}:trace`)),Object.assign((0,te.default)(r),{error:(0,te.default)(`${r}:error`),trace:t})}var xc=Jt(yf(),1);var yo=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},Ec=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},wf=r=>globalThis.DOMException===void 0?new Ec(r):new DOMException(r),bf=r=>{let t=r.reason===void 0?wf("This operation was aborted."):r.reason;return t instanceof Error?t:wf(t)};function wo(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:m}=t;m.aborted&&f(bf(m)),m.addEventListener("abort",()=>{f(bf(m))})}if(e===Number.POSITIVE_INFINITY){r.then(u,f);return}let l=new yo;i=s.setTimeout.call(void 0,()=>{if(n){try{u(n())}catch(m){f(m)}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(m){f(m)}})()}).finally(()=>{c.clear()});return c.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},c}function vc(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 bo=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=vc(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 Le=class extends xc.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:bo,...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#b(){return this.#e||this.#r<this.#o}get#x(){return this.#i<this.#f}#E(){this.#i--,this.#h(),this.emit("next")}#v(){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.#v()},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.#b&&this.#x){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#B(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=wo(Promise.resolve(s),{milliseconds:e.timeout})),e.signal&&(s=Promise.race([s,this.#B(e.signal)]));let i=await s;n(i),this.emit("completed",i)}catch(s){if(s instanceof yo&&!e.throwOnTimeout){n();return}o(s),this.emit("error",s)}finally{this.#E()}},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 bs(r){let t=[xe.A];return r==null?t:Array.isArray(r)?r.length===0?t:r:[r]}var Ac=60;function xs(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??Ac,data:t.data instanceof Uint8Array?z(t.data):t.data}))}}var ey=4;function Bc(r,t={}){let e=new Le({concurrency:t.queryConcurrency??ey});return async(n,o={})=>{let s=new URLSearchParams;s.set("name",n),bs(o.types).forEach(a=>{s.append("type",xe[a])}),o.onProgress?.(new nt("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=xs(await a.json());return o.onProgress?.(new nt("dns:response",{detail:c})),c},{signal:o.signal});if(i==null)throw new Error("No DNS response received");return i}}function xf(){return[Bc("https://cloudflare-dns.com/dns-query"),Bc("https://dns.google/resolve")]}var Af=Jt(vf(),1);var kc=class{lru;constructor(t){this.lru=(0,Af.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 xs({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??Ac)*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 Bf(r){return new kc(r)}var ry=1e3,Es=class{resolvers;cache;constructor(t){this.resolvers={},this.cache=Bf(t.cacheSize??ry),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["."]=xf())}async query(t,e={}){let n=bs(e.types),o=e.cached!==!1?this.cache.get(t,n):void 0;if(o!=null)return e.onProgress?.(new nt("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 nt("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 kf(r={}){return new Es(r)}var ny=["string","number","bigint","symbol"],oy=["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 Sf(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let t=typeof r;if(ny.includes(t))return t;if(t==="function")return"Function";if(Array.isArray(r))return"Array";if(sy(r))return"Buffer";let e=iy(r);return e||"Object"}function sy(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function iy(r){let t=Object.prototype.toString.call(r).slice(8,-1);if(oy.includes(t))return t}var y=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}};y.uint=new y(0,"uint",!0);y.negint=new y(1,"negint",!0);y.bytes=new y(2,"bytes",!0);y.string=new y(3,"string",!0);y.array=new y(4,"array",!1);y.map=new y(5,"map",!1);y.tag=new y(6,"tag",!1);y.float=new y(7,"float",!0);y.false=new y(7,"false",!0);y.true=new y(7,"true",!0);y.null=new y(7,"null",!0);y.undefined=new y(7,"undefined",!0);y.break=new y(7,"break",!0);var R=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 An=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",ay=new TextDecoder,cy=new TextEncoder;function vs(r){return An&&globalThis.Buffer.isBuffer(r)}function xo(r){return r instanceof Uint8Array?vs(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var Tf=An?(r,t,e)=>e-t>64?globalThis.Buffer.from(r.subarray(t,e)).toString("utf8"):Rf(r,t,e):(r,t,e)=>e-t>64?ay.decode(r.subarray(t,e)):Rf(r,t,e),As=An?r=>r.length>64?globalThis.Buffer.from(r):If(r):r=>r.length>64?cy.encode(r):If(r),Ue=r=>Uint8Array.from(r),Bn=An?(r,t,e)=>vs(r)?new Uint8Array(r.subarray(t,e)):r.slice(t,e):(r,t,e)=>r.slice(t,e),Cf=An?(r,t)=>(r=r.map(e=>e instanceof Uint8Array?e:globalThis.Buffer.from(e)),xo(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},Nf=An?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function Lf(r,t){if(vs(r)&&vs(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 If(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 Rf(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 Sc(n)}var _f=4096;function Sc(r){let t=r.length;if(t<=_f)return String.fromCharCode.apply(String,r);let e="",n=0;for(;n<t;)e+=String.fromCharCode.apply(String,r.slice(n,n+=_f));return e}var uy=256,Eo=class{constructor(t=uy){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=Nf(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=Bn(n,0,this.cursor)}else e=Cf(this.chunks,this.cursor);return t&&this.reset(),e}};var V="CBOR decode error:",kn="CBOR encode error:",vo=[];vo[23]=1;vo[24]=2;vo[25]=3;vo[26]=5;vo[27]=9;function je(r,t,e){if(r.length-t<e)throw new Error(`${V} not enough data for type`)}var It=[24,256,65536,4294967296,BigInt("18446744073709551616")];function re(r,t,e){je(r,t,1);let n=r[t];if(e.strict===!0&&n<It[0])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function ne(r,t,e){je(r,t,2);let n=r[t]<<8|r[t+1];if(e.strict===!0&&n<It[1])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function oe(r,t,e){je(r,t,4);let n=r[t]*16777216+(r[t+1]<<16)+(r[t+2]<<8)+r[t+3];if(e.strict===!0&&n<It[2])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function se(r,t,e){je(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<It[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 Uf(r,t,e,n){return new R(y.uint,re(r,t+1,n),2)}function Df(r,t,e,n){return new R(y.uint,ne(r,t+1,n),3)}function Pf(r,t,e,n){return new R(y.uint,oe(r,t+1,n),5)}function Of(r,t,e,n){return new R(y.uint,se(r,t+1,n),9)}function fe(r,t){return Nt(r,0,t.value)}function Nt(r,t,e){if(e<It[0]){let n=Number(e);r.push([t|n])}else if(e<It[1]){let n=Number(e);r.push([t|24,n])}else if(e<It[2]){let n=Number(e);r.push([t|25,n>>>8,n&255])}else if(e<It[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<It[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`)}}fe.encodedSize=function(t){return Nt.encodedSize(t.value)};Nt.encodedSize=function(t){return t<It[0]?1:t<It[1]?2:t<It[2]?3:t<It[3]?5:9};fe.compareTokens=function(t,e){return t.value<e.value?-1:t.value>e.value?1:0};function Ff(r,t,e,n){return new R(y.negint,-1-re(r,t+1,n),2)}function Vf(r,t,e,n){return new R(y.negint,-1-ne(r,t+1,n),3)}function Mf(r,t,e,n){return new R(y.negint,-1-oe(r,t+1,n),5)}var Ic=BigInt(-1),$f=BigInt(1);function Hf(r,t,e,n){let o=se(r,t+1,n);if(typeof o!="bigint"){let s=-1-o;if(s>=Number.MIN_SAFE_INTEGER)return new R(y.negint,s,9)}if(n.allowBigInt!==!0)throw new Error(`${V} integers outside of the safe integer range are not supported`);return new R(y.negint,Ic-BigInt(o),9)}function Bs(r,t){let e=t.value,n=typeof e=="bigint"?e*Ic-$f:e*-1-1;Nt(r,t.type.majorEncoded,n)}Bs.encodedSize=function(t){let e=t.value,n=typeof e=="bigint"?e*Ic-$f:e*-1-1;return n<It[0]?1:n<It[1]?2:n<It[2]?3:n<It[3]?5:9};Bs.compareTokens=function(t,e){return t.value<e.value?1:t.value>e.value?-1:0};function Ao(r,t,e,n){je(r,t,e+n);let o=Bn(r,t+e,t+e+n);return new R(y.bytes,o,e+n)}function Kf(r,t,e,n){return Ao(r,t,1,e)}function qf(r,t,e,n){return Ao(r,t,2,re(r,t+1,n))}function zf(r,t,e,n){return Ao(r,t,3,ne(r,t+1,n))}function Gf(r,t,e,n){return Ao(r,t,5,oe(r,t+1,n))}function jf(r,t,e,n){let o=se(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer bytes lengths not supported`);return Ao(r,t,9,o)}function ks(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===y.string?As(r.value):r.value),r.encodedBytes}function Sn(r,t){let e=ks(t);Nt(r,t.type.majorEncoded,e.length),r.push(e)}Sn.encodedSize=function(t){let e=ks(t);return Nt.encodedSize(e.length)+e.length};Sn.compareTokens=function(t,e){return fy(ks(t),ks(e))};function fy(r,t){return r.length<t.length?-1:r.length>t.length?1:Lf(r,t)}function Bo(r,t,e,n,o){let s=e+n;je(r,t,s);let i=new R(y.string,Tf(r,t+e,t+s),s);return o.retainStringBytes===!0&&(i.byteValue=Bn(r,t+e,t+s)),i}function Wf(r,t,e,n){return Bo(r,t,1,e,n)}function Yf(r,t,e,n){return Bo(r,t,2,re(r,t+1,n),n)}function Zf(r,t,e,n){return Bo(r,t,3,ne(r,t+1,n),n)}function Jf(r,t,e,n){return Bo(r,t,5,oe(r,t+1,n),n)}function Xf(r,t,e,n){let o=se(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer string lengths not supported`);return Bo(r,t,9,o,n)}var Qf=Sn;function In(r,t,e,n){return new R(y.array,n,e)}function th(r,t,e,n){return In(r,t,1,e)}function eh(r,t,e,n){return In(r,t,2,re(r,t+1,n))}function rh(r,t,e,n){return In(r,t,3,ne(r,t+1,n))}function nh(r,t,e,n){return In(r,t,5,oe(r,t+1,n))}function oh(r,t,e,n){let o=se(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer array lengths not supported`);return In(r,t,9,o)}function sh(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return In(r,t,1,1/0)}function Ss(r,t){Nt(r,y.array.majorEncoded,t.value)}Ss.compareTokens=fe.compareTokens;Ss.encodedSize=function(t){return Nt.encodedSize(t.value)};function Rn(r,t,e,n){return new R(y.map,n,e)}function ih(r,t,e,n){return Rn(r,t,1,e)}function ah(r,t,e,n){return Rn(r,t,2,re(r,t+1,n))}function ch(r,t,e,n){return Rn(r,t,3,ne(r,t+1,n))}function uh(r,t,e,n){return Rn(r,t,5,oe(r,t+1,n))}function lh(r,t,e,n){let o=se(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer map lengths not supported`);return Rn(r,t,9,o)}function fh(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 Is(r,t){Nt(r,y.map.majorEncoded,t.value)}Is.compareTokens=fe.compareTokens;Is.encodedSize=function(t){return Nt.encodedSize(t.value)};function hh(r,t,e,n){return new R(y.tag,e,1)}function dh(r,t,e,n){return new R(y.tag,re(r,t+1,n),2)}function ph(r,t,e,n){return new R(y.tag,ne(r,t+1,n),3)}function mh(r,t,e,n){return new R(y.tag,oe(r,t+1,n),5)}function gh(r,t,e,n){return new R(y.tag,se(r,t+1,n),9)}function Rs(r,t){Nt(r,y.tag.majorEncoded,t.value)}Rs.compareTokens=fe.compareTokens;Rs.encodedSize=function(t){return Nt.encodedSize(t.value)};var yy=20,wy=21,by=22,xy=23;function yh(r,t,e,n){if(n.allowUndefined===!1)throw new Error(`${V} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new R(y.null,null,1):new R(y.undefined,void 0,1)}function wh(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return new R(y.break,void 0,1)}function Rc(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 R(y.float,r,t)}function bh(r,t,e,n){return Rc(_c(r,t+1),3,n)}function xh(r,t,e,n){return Rc(Tc(r,t+1),5,n)}function Eh(r,t,e,n){return Rc(kh(r,t+1),9,n)}function _s(r,t,e){let n=t.value;if(n===!1)r.push([y.float.majorEncoded|yy]);else if(n===!0)r.push([y.float.majorEncoded|wy]);else if(n===null)r.push([y.float.majorEncoded|by]);else if(n===void 0)r.push([y.float.majorEncoded|xy]);else{let o,s=!1;(!e||e.float64!==!0)&&(Ah(n),o=_c(Ee,1),n===o||Number.isNaN(n)?(Ee[0]=249,r.push(Ee.slice(0,3)),s=!0):(Bh(n),o=Tc(Ee,1),n===o&&(Ee[0]=250,r.push(Ee.slice(0,5)),s=!0))),s||(Ey(n),o=kh(Ee,1),Ee[0]=251,r.push(Ee.slice(0,9)))}}_s.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){Ah(n);let o=_c(Ee,1);if(n===o||Number.isNaN(n))return 3;if(Bh(n),o=Tc(Ee,1),n===o)return 5}return 9};var vh=new ArrayBuffer(9),he=new DataView(vh,1),Ee=new Uint8Array(vh,0);function Ah(r){if(r===1/0)he.setUint16(0,31744,!1);else if(r===-1/0)he.setUint16(0,64512,!1);else if(Number.isNaN(r))he.setUint16(0,32256,!1);else{he.setFloat32(0,r);let t=he.getUint32(0),e=(t&2139095040)>>23,n=t&8388607;if(e===255)he.setUint16(0,31744,!1);else if(e===0)he.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let o=e-127;o<-24?he.setUint16(0,0):o<-14?he.setUint16(0,(t&2147483648)>>16|1<<24+o,!1):he.setUint16(0,(t&2147483648)>>16|o+15<<10|n>>13,!1)}}}function _c(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 Bh(r){he.setFloat32(0,r,!1)}function Tc(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 Ey(r){he.setFloat64(0,r,!1)}function kh(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)}_s.compareTokens=fe.compareTokens;function et(r,t,e){throw new Error(`${V} encountered invalid minor (${e}) for major ${r[t]>>>5}`)}function Ts(r){return()=>{throw new Error(`${V} ${r}`)}}var L=[];for(let r=0;r<=23;r++)L[r]=et;L[24]=Uf;L[25]=Df;L[26]=Pf;L[27]=Of;L[28]=et;L[29]=et;L[30]=et;L[31]=et;for(let r=32;r<=55;r++)L[r]=et;L[56]=Ff;L[57]=Vf;L[58]=Mf;L[59]=Hf;L[60]=et;L[61]=et;L[62]=et;L[63]=et;for(let r=64;r<=87;r++)L[r]=Kf;L[88]=qf;L[89]=zf;L[90]=Gf;L[91]=jf;L[92]=et;L[93]=et;L[94]=et;L[95]=Ts("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)L[r]=Wf;L[120]=Yf;L[121]=Zf;L[122]=Jf;L[123]=Xf;L[124]=et;L[125]=et;L[126]=et;L[127]=Ts("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)L[r]=th;L[152]=eh;L[153]=rh;L[154]=nh;L[155]=oh;L[156]=et;L[157]=et;L[158]=et;L[159]=sh;for(let r=160;r<=183;r++)L[r]=ih;L[184]=ah;L[185]=ch;L[186]=uh;L[187]=lh;L[188]=et;L[189]=et;L[190]=et;L[191]=fh;for(let r=192;r<=215;r++)L[r]=hh;L[216]=dh;L[217]=ph;L[218]=mh;L[219]=gh;L[220]=et;L[221]=et;L[222]=et;L[223]=et;for(let r=224;r<=243;r++)L[r]=Ts("simple values are not supported");L[244]=et;L[245]=et;L[246]=et;L[247]=yh;L[248]=Ts("simple values are not supported");L[249]=bh;L[250]=xh;L[251]=Eh;L[252]=et;L[253]=et;L[254]=et;L[255]=wh;var ve=[];for(let r=0;r<24;r++)ve[r]=new R(y.uint,r,1);for(let r=-1;r>=-24;r--)ve[31-r]=new R(y.negint,r,1);ve[64]=new R(y.bytes,new Uint8Array(0),1);ve[96]=new R(y.string,"",1);ve[128]=new R(y.array,0,1);ve[160]=new R(y.map,0,1);ve[244]=new R(y.false,!1,1);ve[245]=new R(y.true,!0,1);ve[246]=new R(y.null,null,1);function Sh(r){switch(r.type){case y.false:return Ue([244]);case y.true:return Ue([245]);case y.null:return Ue([246]);case y.bytes:return r.value.length?void 0:Ue([64]);case y.string:return r.value===""?Ue([96]):void 0;case y.array:return r.value===0?Ue([128]):void 0;case y.map:return r.value===0?Ue([160]):void 0;case y.uint:return r.value<24?Ue([Number(r.value)]):void 0;case y.negint:if(r.value>=-24)return Ue([31-Number(r.value)])}}var Ay={float64:!1,mapSorter:Sy,quickEncodeToken:Sh};function By(){let r=[];return r[y.uint.major]=fe,r[y.negint.major]=Bs,r[y.bytes.major]=Sn,r[y.string.major]=Qf,r[y.array.major]=Ss,r[y.map.major]=Is,r[y.tag.major]=Rs,r[y.float.major]=_s,r}var Ih=By(),Cc=new Eo,Ns=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(`${kn} object contains circular references`);return new r(e,t)}},Er={null:new R(y.null,null),undefined:new R(y.undefined,void 0),true:new R(y.true,!0),false:new R(y.false,!1),emptyArray:new R(y.array,0),emptyMap:new R(y.map,0)},vr={number(r,t,e,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new R(y.float,r):r>=0?new R(y.uint,r):new R(y.negint,r)},bigint(r,t,e,n){return r>=BigInt(0)?new R(y.uint,r):new R(y.negint,r)},Uint8Array(r,t,e,n){return new R(y.bytes,r)},string(r,t,e,n){return new R(y.string,r)},boolean(r,t,e,n){return r?Er.true:Er.false},null(r,t,e,n){return Er.null},undefined(r,t,e,n){return Er.undefined},ArrayBuffer(r,t,e,n){return new R(y.bytes,new Uint8Array(r))},DataView(r,t,e,n){return new R(y.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,t,e,n){if(!r.length)return e.addBreakTokens===!0?[Er.emptyArray,new R(y.break)]:Er.emptyArray;n=Ns.createCheck(n,r);let o=[],s=0;for(let i of r)o[s++]=Cs(i,e,n);return e.addBreakTokens?[new R(y.array,r.length),o,new R(y.break)]:[new R(y.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?[Er.emptyMap,new R(y.break)]:Er.emptyMap;n=Ns.createCheck(n,r);let a=[],c=0;for(let u of s)a[c++]=[Cs(u,e,n),Cs(o?r.get(u):r[u],e,n)];return ky(a,e),e.addBreakTokens?[new R(y.map,i),a,new R(y.break)]:[new R(y.map,i),a]}};vr.Map=vr.Object;vr.Buffer=vr.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))vr[`${r}Array`]=vr.DataView;function Cs(r,t={},e){let n=Sf(r),o=t&&t.typeEncoders&&t.typeEncoders[n]||vr[n];if(typeof o=="function"){let i=o(r,n,t,e);if(i!=null)return i}let s=vr[n];if(!s)throw new Error(`${kn} unsupported type: ${n}`);return s(r,n,t,e)}function ky(r,t){t.mapSorter&&r.sort(t.mapSorter)}function Sy(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=Ih[o].compareTokens(e,n);return s===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),s}function Rh(r,t,e,n){if(Array.isArray(t))for(let o of t)Rh(r,o,e,n);else e[t.type.major](r,t,n)}function _h(r,t,e){let n=Cs(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 Eo(i);if(s(a,n,e),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return xo(a.chunks[0])}}return Cc.reset(),Rh(Cc,n,t,e),Cc.toBytes(!0)}function _n(r,t){return t=Object.assign({},Ay,t),_h(r,Ih,t)}var Iy={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},Ls=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=L[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}},ko=Symbol.for("DONE"),Us=Symbol.for("BREAK");function Ry(r,t,e){let n=[];for(let o=0;o<r.value;o++){let s=Tn(t,e);if(s===Us){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed array`)}if(s===ko)throw new Error(`${V} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=s}return n}function _y(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=Tn(t,e);if(a===Us){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed map`)}if(a===ko)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=Tn(t,e);if(c===ko)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 Tn(r,t){if(r.done())return ko;let e=r.next();if(e.type===y.break)return Us;if(e.type.terminal)return e.value;if(e.type===y.array)return Ry(e,r,t);if(e.type===y.map)return _y(e,r,t);if(e.type===y.tag){if(t.tags&&typeof t.tags[e.value]=="function"){let n=Tn(r,t);return t.tags[e.value](n)}throw new Error(`${V} tag not supported (${e.value})`)}throw new Error("unsupported")}function Nc(r,t){if(!(r instanceof Uint8Array))throw new Error(`${V} data to decode must be a Uint8Array`);t=Object.assign({},Iy,t);let e=t.tokenizer||new Ls(r,t),n=Tn(e,t);if(n===ko)throw new Error(`${V} did not find any content to decode`);if(n===Us)throw new Error(`${V} got unexpected break`);return[n,r.subarray(e.pos())]}function de(r,t){let[e,n]=Nc(r,t);if(n.length>0)throw new Error(`${V} too many terminals, data makes no sense`);return e}var We="/",Th=new TextEncoder().encode(We),Ps=Th[0],Lt=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=q(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]!==Ps)throw new Error("Invalid key")}toString(t="utf8"){return z(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(We))}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=Th),this._buf[0]!==Ps){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Ps,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Ps;)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(We).slice(1)}type(){return Ty(this.baseNamespace())}name(){return Cy(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(We)||(t+=We),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(We):new r(t.slice(0,-1).join(We))}child(t){return this.toString()===We?t:t.toString()===We?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(),...Ny(t.map(e=>e.namespaces()))])}};function Ty(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function Cy(r){let t=r.split(":");return t[t.length-1]}function Ny(r){return[].concat(...r)}var Uh="/pin/",Ch="/pinned-block/",Lc=br,Nh=1;function Lh(r){return r.version===0&&(r=r.toV1()),new Lt(`${Uh}${r.toString(Lc)}`)}var Os=class{datastore;blockstore;dagWalkers;constructor(t,e,n){this.datastore=t,this.blockstore=e,this.dagWalkers=n}async*add(t,e={}){let n=Lh(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 qe({concurrency:Nh});for await(let a of this.#t(t,s,{...e,depth:o}))await this.#e(a,c=>c.pinnedBy.find(u=>it(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,_n(i),e)}async*#t(t,e,n){if(n.depth===-1)return;let o=this.dagWalkers[t.code];if(o==null)throw new Error(`No dag walker found for cid codec ${t.code}`);let s=await this.blockstore.get(t,n);yield t;for await(let i of o.walk(s))yield*await e.add(async()=>this.#t(i,e,{...n,depth:n.depth-1}))}async#e(t,e,n){let o=new Lt(`${Ch}${Lc.encode(t.multihash.bytes)}`),s={pinCount:0,pinnedBy:[]};try{s=de(await this.datastore.get(o,n))}catch(a){if(a.code!=="ERR_NOT_FOUND")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,_n(s),n),n.onProgress?.(new nt("helia:pin:add",t))}}async*rm(t,e={}){let n=Lh(t),o=await this.datastore.get(n,e),s=de(o);await this.datastore.delete(n,e);let i=new qe({concurrency:Nh});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=>it(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:Uh+(t.cid!=null?`${t.cid.toString(br)}`:"")},t)){let o=tt.parse(e.toString().substring(5),br),s=de(n);yield{cid:o,...s}}}async isPinned(t,e={}){let n=new Lt(`${Ch}${Lc.encode(t.multihash.bytes)}`);return this.datastore.has(n,e)}};var Ly=5,Fs=class{log;routers;providerLookupConcurrency;constructor(t,e){this.log=t.logger.forComponent("helia:routing"),this.routers=e.routers??[],this.providerLookupConcurrency=e.providerLookupConcurrency??Ly}async start(){await mr(...this.routers)}async stop(){await gr(...this.routers)}async*findProviders(t,e={}){if(this.routers.length===0)throw new D("No content routers available","ERR_NO_ROUTERS_AVAILABLE");let n=new is({concurrency:this.providerLookupConcurrency});n.addEventListener("error",()=>{});for await(let o of Hr(n.toGenerator(),...Cn(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 D("No content routers available","ERR_NO_ROUTERS_AVAILABLE");await Promise.all(Cn(this.routers,"provide").map(async n=>{await n.provide(t,e)}))}async put(t,e,n){await Promise.all(Cn(this.routers,"put").map(async o=>{await o.put(t,e,n)}))}async get(t,e){return Promise.any(Cn(this.routers,"get").map(async n=>n.get(t,e)))}async findPeer(t,e){if(this.routers.length===0)throw new D("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");let n=this,o=Hr(...Cn(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 D("Could not find peer in routing","ERR_NOT_FOUND")}async*getClosestPeers(t,e={}){if(this.routers.length===0)throw new D("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");for await(let n of Hr(...Cn(this.routers,"getClosestPeers").map(o=>o.getClosestPeers(t,e))))n!=null&&(yield n)}};function Cn(r,t){return r.filter(e=>e[t]!=null)}var Ar={},Nn=r=>{r.addEventListener("message",t=>{Nn.dispatchEvent("message",r,t)}),r.port!=null&&r.port.addEventListener("message",t=>{Nn.dispatchEvent("message",r,t)})};Nn.addEventListener=(r,t)=>{Ar[r]==null&&(Ar[r]=[]),Ar[r].push(t)};Nn.removeEventListener=(r,t)=>{Ar[r]!=null&&(Ar[r]=Ar[r].filter(e=>e===t))};Nn.dispatchEvent=function(r,t,e){Ar[r]!=null&&Ar[r].forEach(n=>n(t,e))};var Uc=Nn;var Dc="lock:worker:request-read",Pc="lock:worker:release-read",Oc="lock:master:grant-read",Fc="lock:worker:request-write",Vc="lock:worker:release-write",Mc="lock:master:grant-write";var Dh=(r=21)=>Math.random().toString().substring(2);var Ph=(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==null||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)})}}}))},Oh=(r,t,e,n)=>async()=>{let o=Dh();return globalThis.postMessage({type:t,identifier:o,name:r}),new Promise(s=>{let i=a=>{if(a==null||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)})},Uy={singleProcess:!1},Fh=r=>{if(r=Object.assign({},Uy,r),!!globalThis.document||r.singleProcess){let e=new EventTarget;return Uc.addEventListener("message",Ph(e,"requestReadLock",Dc,Pc,Oc)),Uc.addEventListener("message",Ph(e,"requestWriteLock",Fc,Vc,Mc)),e}return{isWorker:!0,readLock:e=>Oh(e,Dc,Oc,Pc),writeLock:e=>Oh(e,Fc,Mc,Vc)}};var jr={},Br;async function $c(r,t){let e,n=new Promise(o=>{e=o});return r.add(async()=>wo((async()=>{await new Promise(o=>{e(()=>{o()})})})(),{milliseconds:t.timeout})),n}var Dy=(r,t)=>{if(Br.isWorker===!0)return{readLock:Br.readLock(r,t),writeLock:Br.writeLock(r,t)};let e=new Le({concurrency:1}),n;return{async readLock(){if(n!=null)return $c(n,t);n=new Le({concurrency:t.concurrency,autoStart:!1});let o=n,s=$c(n,t);return e.add(async()=>{o.start(),await o.onIdle().then(()=>{n===o&&(n=null)})}),s},async writeLock(){return n=null,$c(e,t)}}},Py={name:"lock",concurrency:1/0,timeout:846e5,singleProcess:!1};function Hc(r){let t=Object.assign({},Py,r);return Br==null&&(Br=Fh(t),Br.isWorker!==!0&&(Br.addEventListener("requestReadLock",e=>{jr[e.data.name]!=null&&jr[e.data.name].readLock().then(async n=>e.data.handler().finally(()=>{n()}))}),Br.addEventListener("requestWriteLock",async e=>{jr[e.data.name]!=null&&jr[e.data.name].writeLock().then(async n=>e.data.handler().finally(()=>{n()}))}))),jr[t.name]==null&&(jr[t.name]=Dy(t.name,t)),jr[t.name]}var Vs=class{lock;child;pins;started;constructor(t,e,n={}){this.child=t,this.pins=e,this.lock=Hc({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await mr(this.child),this.started=!0}async stop(){await gr(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 Mh=42;function Oy(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let t=tt.asCID(r);if(!t)return null;let e=new Uint8Array(t.bytes.byteLength+1);return e.set(t.bytes,1),[new R(y.tag,Mh),new R(y.bytes,e)]}function Fy(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function Vy(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 Vh={float64:!0,typeEncoders:{Object:Oy,undefined:Fy,number:Vy}},w8={...Vh,typeEncoders:{...Vh.typeEncoders}};function My(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return tt.decode(r.subarray(1))}var Kc={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Kc.tags[Mh]=My;var b8={...Kc,tags:Kc.tags.slice()};var $h=113;var Hh=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(t){let e=this.inRecursive[this.inRecursive.length-1];e&&(e.type===y.array&&(e.elements++,e.elements!==1&&t.push([44])),e.type===y.map&&(e.elements++,e.elements!==1&&(e.elements%2===1?t.push([44]):t.push([58]))))}[y.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)}[y.negint.major](t,e){this[y.uint.major](t,e)}[y.bytes.major](t,e){throw new Error(`${kn} unsupported type: Uint8Array`)}[y.string.major](t,e){this.prefix(t);let n=As(JSON.stringify(e.value));t.push(n.length>32?xo(n):n)}[y.array.major](t,e){this.prefix(t),this.inRecursive.push({type:y.array,elements:0}),t.push([91])}[y.map.major](t,e){this.prefix(t),this.inRecursive.push({type:y.map,elements:0}),t.push([123])}[y.tag.major](t,e){}[y.float.major](t,e){if(e.type.name==="break"){let i=this.inRecursive.pop();if(i){if(i.type===y.array)t.push([93]);else if(i.type===y.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(`${kn} 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)}};var Wr=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 R(y.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 R(y.float,i,this._pos-t):this.options.allowBigInt!==!0||Number.isSafeInteger(i)?new R(i>=0?y.uint:y.negint,i,this._pos-t):new R(i>=0?y.uint:y.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 R(y.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 R(y.string,Sc(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 R(y.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new R(y.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new R(y.null,null,4);case 102:return this.expect([102,97,108,115,101]),new R(y.false,!1,5);case 116:return this.expect([116,114,117,101]),new R(y.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 R(y.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 R(y.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 R(y.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 R(y.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 Ms(r,t){return t=Object.assign({tokenizer:new Wr(r,t)},t),de(r,t)}var Ky={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Ky.tags[42]=tt.parse;var qh=297;var P8=new TextDecoder;var O8=new TextEncoder;var zy=new TextDecoder;function qc(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 $s(r,t){let e;[e,t]=qc(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 zh(r,t){let e;return[e,t]=qc(r,t),[e&7,e>>3,t]}function Gy(r){let t={},e=r.length,n=0;for(;n<e;){let o,s;if([o,s,n]=zh(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]=$s(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]=$s(r,n),t.Name=zy.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]=qc(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 Gh(r){let t=r.length,e=0,n,o=!1,s;for(;e<t;){let a,c;if([a,c,e]=zh(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]=$s(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]=$s(r,e),n.push(Gy(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 V8=new TextEncoder,M8=2**32,$8=2**31;var q8=new TextEncoder;function jh(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var Wh=112;function Yh(r){let t=jh(r),e=Gh(t),n={};return e.Data&&(n.Data=e.Data),e.Links&&(n.Links=e.Links.map(o=>{let s={};try{s.Hash=tt.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}var Wy={codec:Wh,*walk(r){yield*Yh(r).Links.map(e=>e.Hash)}},Yy={codec:fs,*walk(){}},Zh=42,Zy={codec:$h,*walk(r){let t=[],e=[];e[Zh]=n=>{if(n[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");let o=tt.decode(n.subarray(1));return t.push(o),o},de(r,{tags:e}),yield*t}},zc=class extends Wr{tokenBuffer;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===y.map){let e=this._next();if(e.type===y.string&&e.value==="/"){let n=this._next();if(n.type===y.string){if(this._next().type!==y.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new R(y.tag,42,0)}if(n.type===y.map){let o=this._next();if(o.type===y.string&&o.value==="bytes"){let s=this._next();if(s.type===y.string){for(let a=0;a<2;a++)if(this._next().type!==y.break)throw new Error("Invalid encoded Bytes form");let i=le.decode(`m${s.value}`);return new R(y.bytes,i,s.value.length)}this.tokenBuffer.push(s)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(e)}return t}},Jy={codec:qh,*walk(r){let t=[],e=[];e[Zh]=n=>{let o=tt.parse(n);return t.push(o),o},Ms(r,{tags:e,tokenizer:new zc(r,{tags:e,allowIndefinite:!0,allowUndefined:!0,allowNaN:!0,allowInfinity:!0,allowBigInt:!0,strict:!1,rejectDuplicateMapKeys:!1})}),yield*t}},Xy={codec:zl,*walk(){}};function Jh(r=[]){let t={};return[Wy,Yy,Zy,Jy,Xy,...r].forEach(e=>{t[e.codec]=e}),t}var Gc=new Lt("/version"),Xh=1;async function Qh(r){if(!await r.has(Gc)){await r.put(Gc,q(`${Xh}`));return}let t=await r.get(Gc),e=z(t);if(parseInt(e,10)!==Xh)throw new Error("Unknown datastore version, a datastore migration may be required")}function td(r=[]){let t={};return[At,ic,Wt,...r].forEach(e=>{t[e.code]=e}),t}var Ye=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 Ln={};vt(Ln,{abortedError:()=>nw,closeFailedError:()=>tw,deleteFailedError:()=>rd,getFailedError:()=>ew,hasFailedError:()=>rw,notFoundError:()=>So,openFailedError:()=>Qy,putFailedError:()=>ed});var Ze=Jt(sn(),1);function Qy(r){return r=r??new Error("Open failed"),(0,Ze.default)(r,"ERR_OPEN_FAILED")}function tw(r){return r=r??new Error("Close failed"),(0,Ze.default)(r,"ERR_CLOSE_FAILED")}function ed(r){return r=r??new Error("Put failed"),(0,Ze.default)(r,"ERR_PUT_FAILED")}function ew(r){return r=r??new Error("Get failed"),(0,Ze.default)(r,"ERR_GET_FAILED")}function rd(r){return r=r??new Error("Delete failed"),(0,Ze.default)(r,"ERR_DELETE_FAILED")}function rw(r){return r=r??new Error("Has failed"),(0,Ze.default)(r,"ERR_HAS_FAILED")}function So(r){return r=r??new Error("Not Found"),(0,Ze.default)(r,"ERR_NOT_FOUND")}function nw(r){return r=r??new Error("Aborted"),(0,Ze.default)(r,"ERR_ABORTED")}var Io=class extends Ye{data;constructor(){super(),this.data=new Map}put(t,e){return this.data.set(Ct.encode(t.multihash.bytes),e),t}get(t){let e=this.data.get(Ct.encode(t.multihash.bytes));if(e==null)throw So();return e}has(t){return this.data.has(Ct.encode(t.multihash.bytes))}async delete(t){this.data.delete(Ct.encode(t.multihash.bytes))}async*getAll(){for(let[t,e]of this.data.entries())yield{cid:tt.createV1(fs,Ne(Ct.decode(t))),block:e}}};function ow(r){return r[Symbol.asyncIterator]!=null}function sw(r,t){let e=0;if(ow(r))return async function*(){for await(let c of r)await t(c,e++)&&(yield c)}();let n=an(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=sw;var IB=ee("blockstore:core:tiered");var nd={...Ln};var Hs=0,Ks=class extends Ye{child;constructor(t){super(),this.child=t}put(t,e){return t.multihash.code===Hs||this.child==null?t:this.child.put(t,e)}get(t){if(t.multihash.code===Hs)return t.multihash.digest;if(this.child==null)throw nd.notFoundError();return this.child.get(t)}has(t){return t.multihash.code===Hs?!0:this.child==null?!1:this.child.has(t)}delete(t){if(t.code!==Hs&&this.child!=null)return this.child.delete(t)}getAll(t){return this.child!=null?this.child.getAll(t):[]}};function iw(r){return r[Symbol.asyncIterator]!=null}function od(r){return r?.then!=null}function aw(r,t){let e=0;if(iw(r))return async function*(){for await(let c of r){let u=t(c,e++);od(u)&&await u,yield c}}();let n=an(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++);od(u)&&await u,yield c}}();let a=t;return function*(){yield o;for(let c of n)a(c,e++),yield c}()}var jc=aw;var qs=class{child;hashers;log;logger;components;constructor(t){this.log=t.logger.forComponent("helia:networked-storage"),this.logger=t.logger,this.components=t,this.child=new Ks(t.blockstore),this.hashers=t.hashers??{}}async put(t,e,n={}){return await this.child.has(t,n)?(n.onProgress?.(new nt("blocks:put:duplicate",t)),t):(n.onProgress?.(new nt("blocks:put:providers:notify",t)),await Promise.all(this.components.blockBrokers.map(async o=>o.announce?.(t,e,n))),n.onProgress?.(new nt("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 nt("blocks:put-many:duplicate",s)),!i}),o=jc(n,async({cid:s,block:i})=>{e.onProgress?.(new nt("blocks:put-many:providers:notify",s)),await Promise.all(this.components.blockBrokers.map(async a=>a.announce?.(s,i,e)))});e.onProgress?.(new nt("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)){e.onProgress?.(new nt("blocks:get:providers:get",t));let n=await sd(t,this.components.blockBrokers,this.hashers[t.multihash.code],{...e,log:this.log});return e.onProgress?.(new nt("blocks:get:blockstore:put",t)),await this.child.put(t,n,e),e.onProgress?.(new nt("blocks:get:providers:notify",t)),await Promise.all(this.components.blockBrokers.map(async o=>o.announce?.(t,n,e))),n}return e.onProgress?.(new nt("blocks:get:blockstore:get",t)),this.child.get(t,e)}async*getMany(t,e={}){e.onProgress?.(new nt("blocks:get-many:blockstore:get-many")),yield*this.child.getMany(jc(t,async n=>{if(e.offline!==!0&&!await this.child.has(n,e)){e.onProgress?.(new nt("blocks:get-many:providers:get",n));let o=await sd(n,this.components.blockBrokers,this.hashers[n.multihash.code],{...e,log:this.log});e.onProgress?.(new nt("blocks:get-many:blockstore:put",n)),await this.child.put(n,o,e),e.onProgress?.(new nt("blocks:get-many:providers:notify",n)),await Promise.all(this.components.blockBrokers.map(async s=>s.announce?.(n,o,e)))}}))}async delete(t,e={}){e.onProgress?.(new nt("blocks:delete:blockstore:delete",t)),await this.child.delete(t,e)}async*deleteMany(t,e={}){e.onProgress?.(new nt("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 nt("blocks:get-all:blockstore:get-many")),yield*this.child.getAll(t)}},zs=class extends qs{started;constructor(t){super(t),this.started=!1}isStarted(){return this.started}async start(){await mr(this.child,...this.components.blockBrokers),this.started=!0}async stop(){await gr(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 Wc({blockstore:this.child,blockBrokers:n,hashers:this.hashers,logger:this.logger},{root:t})}},Wc=class extends qs{closeController;constructor(t,e){super(t),this.closeController=new AbortController,ft(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]);ft(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]);ft(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]);ft(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]);ft(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]);ft(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]);ft(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]);ft(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]);ft(1/0,e);try{yield*super.getAll({...t,signal:e})}finally{e.clear()}}};function cw(r){return typeof r.retrieve=="function"}var uw=(r,t)=>{if(t==null)throw new D(`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`,"ERR_UNKNOWN_HASH_ALG");return async e=>{let n=await t.digest(e);if(!it(n.digest,r.multihash.digest))throw new D("Hash of downloaded block did not match multihash from passed CID","ERR_HASH_MISMATCH")}};async function sd(r,t,e,n){let o=uw(r,e),s=new AbortController,i=$t([s.signal,n.signal]);ft(1/0,s.signal,i);let a=[];for(let c of t)cw(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 id=1,ad=5;var Kt={get(r=globalThis){let t=r.crypto;if(t==null||t.subtle==null)throw Object.assign(new Error("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"),{code:"ERR_MISSING_WEB_CRYPTO"});return t}};var fu={};vt(fu,{Ed25519PrivateKey:()=>Xr,Ed25519PublicKey:()=>To,generateKeyPair:()=>bb,generateKeyPairFromSeed:()=>Ud,unmarshalEd25519PrivateKey:()=>yb,unmarshalEd25519PublicKey:()=>wb});function pe(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Un(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function lw(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Dn(r,...t){if(!lw(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function Gs(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Un(r.outputLen),Un(r.blockLen)}function Pn(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 cd(r,t){Dn(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var js=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Fn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Be=(r,t)=>r<<32-t|r>>>t;var ok=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var fw=async()=>{};async function ud(r,t,e){let n=Date.now();for(let o=0;o<r;o++){e(o);let s=Date.now()-n;s>=0&&s<t||(await fw(),n+=s)}}function Yc(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function kr(r){return typeof r=="string"&&(r=Yc(r)),Dn(r),r}function Ws(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Dn(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 On=class{clone(){return this._cloneInto()}},hw={}.toString;function ld(r,t){if(t!==void 0&&hw.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function Ys(r){let t=n=>r().update(kr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Vn(r=32){if(js&&typeof js.getRandomValues=="function")return js.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function dw(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 fd=(r,t,e)=>r&t^~r&e,hd=(r,t,e)=>r&t^r&e^t&e,Mn=class extends On{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=Fn(this.buffer)}update(t){Pn(this);let{view:e,buffer:n,blockLen:o}=this;t=kr(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=Fn(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){Pn(this),cd(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;dw(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=Fn(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 Zs=BigInt(4294967295),Zc=BigInt(32);function dd(r,t=!1){return t?{h:Number(r&Zs),l:Number(r>>Zc&Zs)}:{h:Number(r>>Zc&Zs)|0,l:Number(r&Zs)|0}}function pw(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}=dd(r[o],t);[e[o],n[o]]=[s,i]}return[e,n]}var mw=(r,t)=>BigInt(r>>>0)<<Zc|BigInt(t>>>0),gw=(r,t,e)=>r>>>e,yw=(r,t,e)=>r<<32-e|t>>>e,ww=(r,t,e)=>r>>>e|t<<32-e,bw=(r,t,e)=>r<<32-e|t>>>e,xw=(r,t,e)=>r<<64-e|t>>>e-32,Ew=(r,t,e)=>r>>>e-32|t<<64-e,vw=(r,t)=>t,Aw=(r,t)=>r,Bw=(r,t,e)=>r<<e|t>>>32-e,kw=(r,t,e)=>t<<e|r>>>32-e,Sw=(r,t,e)=>t<<e-32|r>>>64-e,Iw=(r,t,e)=>r<<e-32|t>>>64-e;function Rw(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var _w=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Tw=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Cw=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Nw=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,Lw=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),Uw=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var Dw={fromBig:dd,split:pw,toBig:mw,shrSH:gw,shrSL:yw,rotrSH:ww,rotrSL:bw,rotrBH:xw,rotrBL:Ew,rotr32H:vw,rotr32L:Aw,rotlSH:Bw,rotlSL:kw,rotlBH:Sw,rotlBL:Iw,add:Rw,add3L:_w,add3H:Tw,add4L:Cw,add4H:Nw,add5H:Uw,add5L:Lw},G=Dw;var[Pw,Ow]=G.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))),Sr=new Uint32Array(80),Ir=new Uint32Array(80),Jc=class extends Mn{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:m,Gh:h,Gl:p,Hh:d,Hl:w}=this;return[t,e,n,o,s,i,a,c,u,f,l,m,h,p,d,w]}set(t,e,n,o,s,i,a,c,u,f,l,m,h,p,d,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=m|0,this.Gh=h|0,this.Gl=p|0,this.Hh=d|0,this.Hl=w|0}process(t,e){for(let b=0;b<16;b++,e+=4)Sr[b]=t.getUint32(e),Ir[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let B=Sr[b-15]|0,A=Ir[b-15]|0,I=G.rotrSH(B,A,1)^G.rotrSH(B,A,8)^G.shrSH(B,A,7),v=G.rotrSL(B,A,1)^G.rotrSL(B,A,8)^G.shrSL(B,A,7),E=Sr[b-2]|0,U=Ir[b-2]|0,P=G.rotrSH(E,U,19)^G.rotrBH(E,U,61)^G.shrSH(E,U,6),N=G.rotrSL(E,U,19)^G.rotrBL(E,U,61)^G.shrSL(E,U,6),M=G.add4L(v,N,Ir[b-7],Ir[b-16]),C=G.add4H(M,I,P,Sr[b-7],Sr[b-16]);Sr[b]=C|0,Ir[b]=M|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:u,Dl:f,Eh:l,El:m,Fh:h,Fl:p,Gh:d,Gl:w,Hh:g,Hl:x}=this;for(let b=0;b<80;b++){let B=G.rotrSH(l,m,14)^G.rotrSH(l,m,18)^G.rotrBH(l,m,41),A=G.rotrSL(l,m,14)^G.rotrSL(l,m,18)^G.rotrBL(l,m,41),I=l&h^~l&d,v=m&p^~m&w,E=G.add5L(x,A,v,Ow[b],Ir[b]),U=G.add5H(E,g,B,I,Pw[b],Sr[b]),P=E|0,N=G.rotrSH(n,o,28)^G.rotrBH(n,o,34)^G.rotrBH(n,o,39),M=G.rotrSL(n,o,28)^G.rotrBL(n,o,34)^G.rotrBL(n,o,39),C=n&s^n&a^s&a,X=o&i^o&c^i&c;g=d|0,x=w|0,d=h|0,w=p|0,h=l|0,p=m|0,{h:l,l:m}=G.add(u|0,f|0,U|0,P|0),u=a|0,f=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let S=G.add3L(P,M,X);n=G.add3H(S,U,N,C),o=S|0}({h:n,l:o}=G.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=G.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=G.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l:f}=G.add(this.Dh|0,this.Dl|0,u|0,f|0),{h:l,l:m}=G.add(this.Eh|0,this.El|0,l|0,m|0),{h,l:p}=G.add(this.Fh|0,this.Fl|0,h|0,p|0),{h:d,l:w}=G.add(this.Gh|0,this.Gl|0,d|0,w|0),{h:g,l:x}=G.add(this.Hh|0,this.Hl|0,g|0,x|0),this.set(n,o,s,i,a,c,u,f,l,m,h,p,d,w,g,x)}roundClean(){Sr.fill(0),Ir.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 $n=Ys(()=>new Jc);var Xs={};vt(Xs,{abytes:()=>Hn,bitGet:()=>qw,bitLen:()=>Kw,bitMask:()=>Ro,bitSet:()=>zw,bytesToHex:()=>Xe,bytesToNumberBE:()=>Qe,bytesToNumberLE:()=>_r,concatBytes:()=>tr,createHmacDrbg:()=>tu,ensureBytes:()=>mt,equalBytes:()=>$w,hexToBytes:()=>Yr,hexToNumber:()=>Qc,isBytes:()=>Rr,numberToBytesBE:()=>Tr,numberToBytesLE:()=>Zr,numberToHexUnpadded:()=>yd,numberToVarBytesBE:()=>Mw,utf8ToBytes:()=>Hw,validateObject:()=>De});var gd=BigInt(0),Js=BigInt(1),Fw=BigInt(2);function Rr(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Hn(r){if(!Rr(r))throw new Error("Uint8Array expected")}var Vw=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Xe(r){Hn(r);let t="";for(let e=0;e<r.length;e++)t+=Vw[r[e]];return t}function yd(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Qc(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Je={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function pd(r){if(r>=Je._0&&r<=Je._9)return r-Je._0;if(r>=Je._A&&r<=Je._F)return r-(Je._A-10);if(r>=Je._a&&r<=Je._f)return r-(Je._a-10)}function Yr(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("padded 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=pd(r.charCodeAt(s)),a=pd(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 Qc(Xe(r))}function _r(r){return Hn(r),Qc(Xe(Uint8Array.from(r).reverse()))}function Tr(r,t){return Yr(r.toString(16).padStart(t*2,"0"))}function Zr(r,t){return Tr(r,t).reverse()}function Mw(r){return Yr(yd(r))}function mt(r,t,e){let n;if(typeof t=="string")try{n=Yr(t)}catch(s){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${s}`)}else if(Rr(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} expected ${e} bytes, got ${o}`);return n}function tr(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Hn(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 $w(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 Hw(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Kw(r){let t;for(t=0;r>gd;r>>=Js,t+=1);return t}function qw(r,t){return r>>BigInt(t)&Js}function zw(r,t,e){return r|(e?Js:gd)<<BigInt(t)}var Ro=r=>(Fw<<BigInt(r-1))-Js,Xc=r=>new Uint8Array(r),md=r=>Uint8Array.from(r);function tu(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=Xc(r),o=Xc(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>e(o,n,...l),c=(l=Xc())=>{o=a(md([0]),l),n=a(),l.length!==0&&(o=a(md([1]),l),n=a())},u=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,m=[];for(;l<t;){n=a();let h=n.slice();m.push(h),l+=n.length}return tr(...m)};return(l,m)=>{i(),c(l);let h;for(;!(h=m(u()));)c();return i(),h}}var Gw={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"||Rr(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 De(r,t,e={}){let n=(o,s,i)=>{let a=Gw[s];if(typeof a!="function")throw new Error(`Invalid validator "${s}", expected function`);let c=r[o];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(o)}=${c} (${typeof c}), expected ${s}`)};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 Bt=BigInt(0),ut=BigInt(1),Jr=BigInt(2),jw=BigInt(3),eu=BigInt(4),wd=BigInt(5),bd=BigInt(8),Ww=BigInt(9),Yw=BigInt(16);function at(r,t){let e=r%t;return e>=Bt?e:t+e}function Zw(r,t,e){if(e<=Bt||t<Bt)throw new Error("Expected power/modulo > 0");if(e===ut)return Bt;let n=ut;for(;t>Bt;)t&ut&&(n=n*r%e),r=r*r%e,t>>=ut;return n}function lt(r,t,e){let n=r;for(;t-- >Bt;)n*=n,n%=e;return n}function Qs(r,t){if(r===Bt||t<=Bt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=at(r,t),n=t,o=Bt,s=ut,i=ut,a=Bt;for(;e!==Bt;){let u=n/e,f=n%e,l=o-i*u,m=s-a*u;n=e,e=f,o=i,s=a,i=l,a=m}if(n!==ut)throw new Error("invert: does not exist");return at(o,t)}function Jw(r){let t=(r-ut)/Jr,e,n,o;for(e=r-ut,n=0;e%Jr===Bt;e/=Jr,n++);for(o=Jr;o<r&&Zw(o,t,r)!==r-ut;o++);if(n===1){let i=(r+ut)/eu;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+ut)/Jr;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),m=a.pow(c,e);for(;!a.eql(m,a.ONE);){if(a.eql(m,a.ZERO))return a.ZERO;let h=1;for(let d=a.sqr(m);h<u&&!a.eql(d,a.ONE);h++)d=a.sqr(d);let p=a.pow(f,ut<<BigInt(u-h-1));f=a.sqr(p),l=a.mul(l,p),m=a.mul(m,f),u=h}return l}}function Xw(r){if(r%eu===jw){let t=(r+ut)/eu;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%bd===wd){let t=(r-wd)/bd;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%Yw,Jw(r)}var xd=(r,t)=>(at(r,t)&ut)===ut,Qw=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function ru(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Qw.reduce((n,o)=>(n[o]="function",n),t);return De(r,e)}function tb(r,t,e){if(e<Bt)throw new Error("Expected power > 0");if(e===Bt)return r.ONE;if(e===ut)return t;let n=r.ONE,o=t;for(;e>Bt;)e&ut&&(n=r.mul(n,o)),o=r.sqr(o),e>>=ut;return n}function eb(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 nu(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function ti(r,t,e=!1,n={}){if(r<=Bt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:o,nByteLength:s}=nu(r,t);if(s>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Xw(r),a=Object.freeze({ORDER:r,BITS:o,BYTES:s,MASK:Ro(o),ZERO:Bt,ONE:ut,create:c=>at(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return Bt<=c&&c<r},is0:c=>c===Bt,isOdd:c=>(c&ut)===ut,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)=>tb(a,c,u),div:(c,u)=>at(c*Qs(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>Qs(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>eb(a,c),cmov:(c,u,f)=>f?u:c,toBytes:c=>e?Zr(c,s):Tr(c,s),fromBytes:c=>{if(c.length!==s)throw new Error(`Fp.fromBytes: expected ${s}, got ${c.length}`);return e?_r(c):Qe(c)}});return Object.freeze(a)}function Ed(r,t){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let e=r.sqrt(t);return r.isOdd(e)?r.neg(e):e}function vd(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 ou(r){let t=vd(r);return t+Math.ceil(t/2)}function Ad(r,t,e=!1){let n=r.length,o=vd(t),s=ou(t);if(n<16||n<s||n>1024)throw new Error(`expected ${s}-1024 bytes of input, got ${n}`);let i=e?Qe(r):_r(r),a=at(i,t-ut)+ut;return e?Zr(a,o):Tr(a,o)}var nb=BigInt(0),su=BigInt(1);function ei(r,t){let e=(o,s)=>{let i=s.negate();return o?i:s},n=o=>{let s=Math.ceil(t/o)+1,i=2**(o-1);return{windows:s,windowSize:i}};return{constTimeNegate:e,unsafeLadder(o,s){let i=r.ZERO,a=o;for(;s>nb;)s&su&&(i=i.add(a)),a=a.double(),s>>=su;return i},precomputeWindow(o,s){let{windows:i,windowSize:a}=n(s),c=[],u=o,f=u;for(let l=0;l<i;l++){f=u,c.push(f);for(let m=1;m<a;m++)f=f.add(u),c.push(f);u=f.double()}return c},wNAF(o,s,i){let{windows:a,windowSize:c}=n(o),u=r.ZERO,f=r.BASE,l=BigInt(2**o-1),m=2**o,h=BigInt(o);for(let p=0;p<a;p++){let d=p*c,w=Number(i&l);i>>=h,w>c&&(w-=m,i+=su);let g=d,x=d+Math.abs(w)-1,b=p%2!==0,B=w<0;w===0?f=f.add(e(b,s[g])):u=u.add(e(B,s[x]))}return{p:u,f}},wNAFCached(o,s,i,a){let c=o._WINDOW_SIZE||1,u=s.get(o);return u||(u=this.precomputeWindow(o,c),c!==1&&s.set(o,a(u))),this.wNAF(c,u,i)}}}function _o(r){return ru(r.Fp),De(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...nu(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var ke=BigInt(0),ie=BigInt(1),ri=BigInt(2),ob=BigInt(8),sb={zip215:!0};function ib(r){let t=_o(r);return De(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function ni(r){let t=ib(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,u=ri<<BigInt(a*8)-ie,f=e.create,l=t.uvRatio||((_,k)=>{try{return{isValid:!0,value:e.sqrt(_*e.inv(k))}}catch{return{isValid:!1,value:ke}}}),m=t.adjustScalarBytes||(_=>_),h=t.domain||((_,k,F)=>{if(k.length||F)throw new Error("Contexts/pre-hash are not supported");return _}),p=_=>typeof _=="bigint"&&ke<_,d=(_,k)=>p(_)&&p(k)&&_<k,w=_=>_===ke||d(_,u);function g(_,k){if(d(_,k))return _;throw new Error(`Expected valid scalar < ${k}, got ${typeof _} ${_}`)}function x(_){return _===ke?_:g(_,n)}let b=new Map;function B(_){if(!(_ instanceof A))throw new Error("ExtendedPoint expected")}class A{constructor(k,F,$,K){if(this.ex=k,this.ey=F,this.ez=$,this.et=K,!w(k))throw new Error("x required");if(!w(F))throw new Error("y required");if(!w($))throw new Error("z required");if(!w(K))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(k){if(k instanceof A)throw new Error("extended point not allowed");let{x:F,y:$}=k||{};if(!w(F)||!w($))throw new Error("invalid affine point");return new A(F,$,ie,f(F*$))}static normalizeZ(k){let F=e.invertBatch(k.map($=>$.ez));return k.map(($,K)=>$.toAffine(F[K])).map(A.fromAffine)}_setWindowSize(k){this._WINDOW_SIZE=k,b.delete(this)}assertValidity(){let{a:k,d:F}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:$,ey:K,ez:W,et:Y}=this,rt=f($*$),J=f(K*K),Q=f(W*W),wt=f(Q*Q),dt=f(rt*k),_t=f(Q*f(dt+J)),Tt=f(wt+f(F*f(rt*J)));if(_t!==Tt)throw new Error("bad point: equation left != right (1)");let Et=f($*K),Pt=f(W*Y);if(Et!==Pt)throw new Error("bad point: equation left != right (2)")}equals(k){B(k);let{ex:F,ey:$,ez:K}=this,{ex:W,ey:Y,ez:rt}=k,J=f(F*rt),Q=f(W*K),wt=f($*rt),dt=f(Y*K);return J===Q&&wt===dt}is0(){return this.equals(A.ZERO)}negate(){return new A(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:k}=t,{ex:F,ey:$,ez:K}=this,W=f(F*F),Y=f($*$),rt=f(ri*f(K*K)),J=f(k*W),Q=F+$,wt=f(f(Q*Q)-W-Y),dt=J+Y,_t=dt-rt,Tt=J-Y,Et=f(wt*_t),Pt=f(dt*Tt),Ke=f(wt*Tt),Fr=f(_t*dt);return new A(Et,Pt,Fr,Ke)}add(k){B(k);let{a:F,d:$}=t,{ex:K,ey:W,ez:Y,et:rt}=this,{ex:J,ey:Q,ez:wt,et:dt}=k;if(F===BigInt(-1)){let dl=f((W-K)*(Q+J)),pl=f((W+K)*(Q-J)),ka=f(pl-dl);if(ka===ke)return this.double();let ml=f(Y*ri*dt),gl=f(rt*ri*wt),yl=gl+ml,wl=pl+dl,bl=gl-ml,rm=f(yl*ka),nm=f(wl*bl),om=f(yl*bl),sm=f(ka*wl);return new A(rm,nm,sm,om)}let _t=f(K*J),Tt=f(W*Q),Et=f(rt*$*dt),Pt=f(Y*wt),Ke=f((K+W)*(J+Q)-_t-Tt),Fr=Pt-Et,no=Pt+Et,hl=f(Tt-F*_t),X0=f(Ke*Fr),Q0=f(no*hl),tm=f(Ke*hl),em=f(Fr*no);return new A(X0,Q0,em,tm)}subtract(k){return this.add(k.negate())}wNAF(k){return E.wNAFCached(this,b,k,A.normalizeZ)}multiply(k){let{p:F,f:$}=this.wNAF(g(k,n));return A.normalizeZ([F,$])[0]}multiplyUnsafe(k){let F=x(k);return F===ke?v:this.equals(v)||F===ie?this:this.equals(I)?this.wNAF(F).p:E.unsafeLadder(this,F)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return E.unsafeLadder(this,n).is0()}toAffine(k){let{ex:F,ey:$,ez:K}=this,W=this.is0();k==null&&(k=W?ob:e.inv(K));let Y=f(F*k),rt=f($*k),J=f(K*k);if(W)return{x:ke,y:ie};if(J!==ie)throw new Error("invZ was invalid");return{x:Y,y:rt}}clearCofactor(){let{h:k}=t;return k===ie?this:this.multiplyUnsafe(k)}static fromHex(k,F=!1){let{d:$,a:K}=t,W=e.BYTES;k=mt("pointHex",k,W);let Y=k.slice(),rt=k[W-1];Y[W-1]=rt&-129;let J=_r(Y);J===ke||(F?g(J,u):g(J,e.ORDER));let Q=f(J*J),wt=f(Q-ie),dt=f($*Q-K),{isValid:_t,value:Tt}=l(wt,dt);if(!_t)throw new Error("Point.fromHex: invalid y coordinate");let Et=(Tt&ie)===ie,Pt=(rt&128)!==0;if(!F&&Tt===ke&&Pt)throw new Error("Point.fromHex: x=0 and x_0=1");return Pt!==Et&&(Tt=f(-Tt)),A.fromAffine({x:Tt,y:J})}static fromPrivateKey(k){return N(k).point}toRawBytes(){let{x:k,y:F}=this.toAffine(),$=Zr(F,e.BYTES);return $[$.length-1]|=k&ie?128:0,$}toHex(){return Xe(this.toRawBytes())}}A.BASE=new A(t.Gx,t.Gy,ie,f(t.Gx*t.Gy)),A.ZERO=new A(ke,ie,ie,ke);let{BASE:I,ZERO:v}=A,E=ei(A,a*8);function U(_){return at(_,n)}function P(_){return U(_r(_))}function N(_){let k=a;_=mt("private key",_,k);let F=mt("hashed private key",s(_),2*k),$=m(F.slice(0,k)),K=F.slice(k,2*k),W=P($),Y=I.multiply(W),rt=Y.toRawBytes();return{head:$,prefix:K,scalar:W,point:Y,pointBytes:rt}}function M(_){return N(_).pointBytes}function C(_=new Uint8Array,...k){let F=tr(...k);return P(s(h(F,mt("context",_),!!o)))}function X(_,k,F={}){_=mt("message",_),o&&(_=o(_));let{prefix:$,scalar:K,pointBytes:W}=N(k),Y=C(F.context,$,_),rt=I.multiply(Y).toRawBytes(),J=C(F.context,rt,W,_),Q=U(Y+J*K);x(Q);let wt=tr(rt,Zr(Q,e.BYTES));return mt("result",wt,a*2)}let S=sb;function T(_,k,F,$=S){let{context:K,zip215:W}=$,Y=e.BYTES;_=mt("signature",_,2*Y),k=mt("message",k),o&&(k=o(k));let rt=_r(_.slice(Y,2*Y)),J,Q,wt;try{J=A.fromHex(F,W),Q=A.fromHex(_.slice(0,Y),W),wt=I.multiplyUnsafe(rt)}catch{return!1}if(!W&&J.isSmallOrder())return!1;let dt=C(K,Q.toRawBytes(),J.toRawBytes(),k);return Q.add(J.multiplyUnsafe(dt)).subtract(wt).clearCofactor().equals(A.ZERO)}return I._setWindowSize(8),{CURVE:t,getPublicKey:M,sign:X,verify:T,ExtendedPoint:A,utils:{getExtendedPublicKey:N,randomPrivateKey:()=>i(e.BYTES),precompute(_=8,k=A.BASE){return k._setWindowSize(_),k.multiply(BigInt(3)),k}}}}var au=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Bd=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Sk=BigInt(0),ab=BigInt(1),iu=BigInt(2),cb=BigInt(5),kd=BigInt(10),ub=BigInt(20),lb=BigInt(40),Sd=BigInt(80);function fb(r){let t=au,n=r*r%t*r%t,o=lt(n,iu,t)*n%t,s=lt(o,ab,t)*r%t,i=lt(s,cb,t)*s%t,a=lt(i,kd,t)*i%t,c=lt(a,ub,t)*a%t,u=lt(c,lb,t)*c%t,f=lt(u,Sd,t)*u%t,l=lt(f,Sd,t)*u%t,m=lt(l,kd,t)*i%t;return{pow_p_5_8:lt(m,iu,t)*r%t,b2:n}}function hb(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function db(r,t){let e=au,n=at(t*t*t,e),o=at(n*n*t,e),s=fb(r*o).pow_p_5_8,i=at(r*n*s,e),a=at(t*i*i,e),c=i,u=at(i*Bd,e),f=a===r,l=a===at(-r,e),m=a===at(-r*Bd,e);return f&&(i=c),(l||m)&&(i=u),xd(i,e)&&(i=at(-i,e)),{isValid:f||l,value:i}}var er=ti(au,void 0,!0),cu={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:er,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:$n,randomBytes:Vn,adjustScalarBytes:hb,uvRatio:db},Kn=ni(cu);function Id(r,t,e){if(t.length>255)throw new Error("Context is too big");return Ws(Yc("SigEd25519 no Ed25519 collisions"),new Uint8Array([e?1:0,t.length]),t,r)}var Ik=ni({...cu,domain:Id}),Rk=ni({...cu,domain:Id,prehash:$n});var pb=(er.ORDER+BigInt(3))/BigInt(8),_k=er.pow(iu,pb),Tk=er.sqrt(er.neg(er.ONE)),Ck=(er.ORDER-BigInt(5))/BigInt(8),Nk=BigInt(486662);var Lk=Ed(er,er.neg(BigInt(486664)));var Uk=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Dk=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),Pk=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Ok=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var Fk=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var qn=32,rr=64,oi=32;function Rd(){let r=Kn.utils.randomPrivateKey(),t=Kn.getPublicKey(r);return{privateKey:Nd(r,t),publicKey:t}}function _d(r){if(r.length!==oi)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let t=r,e=Kn.getPublicKey(t);return{privateKey:Nd(t,e),publicKey:e}}function Td(r,t){let e=r.subarray(0,oi);return Kn.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Cd(r,t,e){return Kn.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Nd(r,t){let e=new Uint8Array(rr);for(let n=0;n<oi;n++)e[n]=r[n],e[oi+n]=t[n];return e}var uu={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Ld(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,o=r?.digest??"SHA-256",s=r?.saltLength??16,i=r?.iterations??32767,a=Kt.get();e*=8;async function c(l,m){let h=a.getRandomValues(new Uint8Array(s)),p=a.getRandomValues(new Uint8Array(n)),d={name:t,iv:p};typeof m=="string"&&(m=q(m));let w;if(m.length===0){w=await a.subtle.importKey("jwk",uu,{name:"AES-GCM"},!0,["encrypt"]);try{let x={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},b=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(x,b,{name:t,length:e},!0,["encrypt"])}catch{w=await a.subtle.importKey("jwk",uu,{name:"AES-GCM"},!0,["encrypt"])}}else{let x={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},b=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(x,b,{name:t,length:e},!0,["encrypt"])}let g=await a.subtle.encrypt(d,w,l);return St([h,d.iv,new Uint8Array(g)])}async function u(l,m){let h=l.subarray(0,s),p=l.subarray(s,s+n),d=l.subarray(s+n),w={name:t,iv:p};typeof m=="string"&&(m=q(m));let g;if(m.length===0)try{let b={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},B=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(b,B,{name:t,length:e},!0,["decrypt"])}catch{g=await a.subtle.importKey("jwk",uu,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},B=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(b,B,{name:t,length:e},!0,["decrypt"])}let x=await a.subtle.decrypt(w,g,d);return new Uint8Array(x)}return{encrypt:c,decrypt:u}}async function zn(r,t){let n=await Ld().encrypt(r,t);return le.encode(n)}var gt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(gt||(gt={}));var lu;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(lu||(lu={}));(function(r){r.codec=()=>ho(lu)})(gt||(gt={}));var Pe;(function(r){let t;r.codec=()=>(t==null&&(t=gn((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),gt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let o={},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let i=e.uint32();switch(i>>>3){case 1:o.Type=gt.codec().decode(e);break;case 2:o.Data=e.bytes();break;default:e.skipType(i&7);break}}return o})),t),r.encode=e=>pn(e,r.codec()),r.decode=e=>un(e,r.codec())})(Pe||(Pe={}));var nr;(function(r){let t;r.codec=()=>(t==null&&(t=gn((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),gt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let o={},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let i=e.uint32();switch(i>>>3){case 1:o.Type=gt.codec().decode(e);break;case 2:o.Data=e.bytes();break;default:e.skipType(i&7);break}}return o})),t),r.encode=e=>pn(e,r.codec()),r.decode=e=>un(e,r.codec())})(nr||(nr={}));var To=class{_key;constructor(t){this._key=Gn(t,qn)}verify(t,e){return Cd(this._key,e,t)}marshal(){return this._key}get bytes(){return Pe.encode({Type:gt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return pe(t)?t.then(({bytes:e})=>e):t.bytes}},Xr=class{_key;_publicKey;constructor(t,e){this._key=Gn(t,rr),this._publicKey=Gn(e,qn)}sign(t){return Td(this._key,t)}get public(){return new To(this._publicKey)}marshal(){return this._key}get bytes(){return nr.encode({Type:gt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return pe(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=Wt.digest(this.public.bytes);return ht.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return zn(this.bytes,t);throw new D(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function yb(r){if(r.length>rr){r=Gn(r,rr+qn);let n=r.subarray(0,rr),o=r.subarray(rr,r.length);return new Xr(n,o)}r=Gn(r,rr);let t=r.subarray(0,rr),e=r.subarray(qn);return new Xr(t,e)}function wb(r){return r=Gn(r,qn),new To(r)}async function bb(){let{privateKey:r,publicKey:t}=Rd();return new Xr(r,t)}async function Ud(r){let{privateKey:t,publicKey:e}=_d(r);return new Xr(t,e)}function Gn(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new D(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}var Eu={};vt(Eu,{MAX_RSA_KEY_SIZE:()=>Ho,RsaPrivateKey:()=>Jn,RsaPublicKey:()=>$o,fromJwk:()=>Gb,generateKeyPair:()=>jb,unmarshalRsaPrivateKey:()=>bu,unmarshalRsaPublicKey:()=>zb});function Oe(r){if(isNaN(r)||r<=0)throw new D("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return Vn(r)}var Ur={};vt(Ur,{exportToPem:()=>Mb,importFromPem:()=>$b,jwkToPkcs1:()=>Pb,jwkToPkix:()=>Fb,pkcs1ToJwk:()=>Db,pkixToJwk:()=>Ob});var ii=class extends On{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,Gs(t);let n=kr(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 Pn(this),this.iHash.update(t),this}digestInto(t){Pn(this),Dn(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()}},Co=(r,t,e)=>new ii(r,t).update(e).digest();Co.create=(r,t)=>new ii(r,t);function xb(r,t,e,n){Gs(r);let o=ld({dkLen:32,asyncTick:10},n),{c:s,dkLen:i,asyncTick:a}=o;if(Un(s),Un(i),Un(a),s<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=kr(t),u=kr(e),f=new Uint8Array(i),l=Co.create(r,c),m=l._cloneInto().update(u);return{c:s,dkLen:i,asyncTick:a,DK:f,PRF:l,PRFSalt:m}}function Eb(r,t,e,n,o){return r.destroy(),t.destroy(),n&&n.destroy(),o.fill(0),e}async function hu(r,t,e,n){let{c:o,dkLen:s,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=xb(r,t,e,n),f,l=new Uint8Array(4),m=Fn(l),h=new Uint8Array(c.outputLen);for(let p=1,d=0;d<s;p++,d+=c.outputLen){let w=a.subarray(d,d+c.outputLen);m.setInt32(0,p,!1),(f=u._cloneInto(f)).update(l).digestInto(h),w.set(h.subarray(0,w.length)),await ud(o-1,i,()=>{c._cloneInto(f).update(h).digestInto(h);for(let g=0;g<w.length;g++)w[g]^=h[g]})}return Eb(c,u,a,f,h)}var Z=Jt(Dd());function Qr(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 Cr(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 ui(...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 pu(){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=Qr(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,Qr(s,8)-n}function Pd(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=Cr(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=Cr(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 Od(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 Yt(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 fS=Math.log(2);function li(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function mu(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 cr(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 Lo=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return mu(this.items)}},No=[new Uint8Array([1])],Fd="0123456789";var Yn="",Ie=new ArrayBuffer(0),gu=new Uint8Array(0),Uo="EndOfContent",Md="OCTET STRING",$d="BIT STRING";function ur(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):gu}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(!cr(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",Ie)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Z.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var sr=class{constructor({blockLength:t=0,error:e=Yn,warnings:n=[],valueBeforeDecode:o=gu}={}){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)}}};sr.NAME="baseBlock";var Mt=class extends sr{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'")}};Mt.NAME="valueBlock";var fi=class extends ur(sr){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):gu,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",Ie}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=Cr(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(!cr(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 m=new Uint8Array(f);for(let h=0;h<u.length;h++)m[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 m=0;m<c;m++)l[m]=u[m];u=this.valueHexView=new Uint8Array(c),u.set(l),this.blockLength<=9?this.tagNumber=Qr(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}}};fi.NAME="identificationBlock";var hi=class extends sr{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(!cr(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=Qr(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=Cr(this.length,8);if(o.byteLength>127)return this.error="Too big length",Ie;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}}};hi.NAME="lengthBlock";var O={},Ut=class extends sr{constructor({name:t=Yn,optional:e=!1,primitiveSchema:n,...o}={},s){super(o),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new fi(o),this.lenBlock=new hi(o),this.valueBlock=s?new s(o):new Mt(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 Lo;e||Hd(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?Ie: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 Od(e,n)}};Ut.NAME="BaseBlock";function Hd(r){if(r instanceof O.Constructed)for(let t of r.valueBlock.value)Hd(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var di=class extends Ut{constructor({value:t=Yn,...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}'`}};di.NAME="BaseStringBlock";var pi=class extends ur(Mt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};pi.NAME="PrimitiveValueBlock";var Kd,mi=class extends Ut{constructor(t={}){super(t,pi),this.idBlock.isConstructed=!1}};Kd=mi;O.Primitive=Kd;mi.NAME="PRIMITIVE";function Tb(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 Wi(r,t=0,e=r.length){let n=t,o=new Ut({},Mt),s=new sr;if(!cr(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=Ut;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=O.EndOfContent;break;case 1:c=O.Boolean;break;case 2:c=O.Integer;break;case 3:c=O.BitString;break;case 4:c=O.OctetString;break;case 5:c=O.Null;break;case 6:c=O.ObjectIdentifier;break;case 10:c=O.Enumerated;break;case 12:c=O.Utf8String;break;case 13:c=O.RelativeObjectIdentifier;break;case 14:c=O.TIME;break;case 15:return o.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:o};case 16:c=O.Sequence;break;case 17:c=O.Set;break;case 18:c=O.NumericString;break;case 19:c=O.PrintableString;break;case 20:c=O.TeletexString;break;case 21:c=O.VideotexString;break;case 22:c=O.IA5String;break;case 23:c=O.UTCTime;break;case 24:c=O.GeneralizedTime;break;case 25:c=O.GraphicString;break;case 26:c=O.VisibleString;break;case 27:c=O.GeneralString;break;case 28:c=O.UniversalString;break;case 29:c=O.CharacterString;break;case 30:c=O.BmpString;break;case 31:c=O.DATE;break;case 32:c=O.TimeOfDay;break;case 33:c=O.DateTime;break;case 34:c=O.Duration;break;default:{let u=o.idBlock.isConstructed?new O.Constructed:new O.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?O.Constructed:O.Primitive}return o=Tb(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 Zn(r){if(!r.byteLength){let t=new Ut({},Mt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Wi(Z.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Cb(r,t){return r?1:t}var Fe=class extends Mt{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(!cr(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(;Cb(this.isIndefiniteForm,n)>0;){let i=Wi(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===Uo)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Uo?this.value.pop():this.warnings.push("No EndOfContent block encoded")),s}toBER(t,e){let n=e||new Lo;for(let o=0;o<this.value.length;o++)this.value[o].toBER(t,n);return e?Ie:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Fe.NAME="ConstructedValueBlock";var qd,Nr=class extends Ut{constructor(t={}){super(t,Fe),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} :`}};Id=Rr;O.Constructed=Id;Rr.NAME="CONSTRUCTED";var di=class extends Vt{fromBER(t,e,n){return e}toBER(t){return Se}};di.override="EndOfContentValueBlock";var _d,pi=class extends Lt{constructor(t={}){super(t,di),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};_d=pi;O.EndOfContent=_d;pi.NAME=Co;var Rd,Tr=class extends Lt{constructor(t={}){super(t,Vt),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}`}};Rd=Tr;O.Null=Rd;Tr.NAME="NULL";var mi=class extends ar(Vt){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 ir(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,au.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};mi.NAME="BooleanValueBlock";var Td,gi=class extends Lt{constructor(t={}){super(t,mi),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}`}};Td=gi;O.Boolean=Td;gi.NAME="BOOLEAN";var yi=class extends ar(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===Co){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Ad)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}}};yi.NAME="OctetStringValueBlock";var Cd,or=class r extends Lt{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},yi),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=zi(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?Rr.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)}};Cd=or;O.OctetString=Cd;or.NAME=Ad;var wi=class extends ar(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===Co){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Bd)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(!ir(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=zi(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 Se;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}}};wi.NAME="BitStringValueBlock";var Nd,Gn=class extends Lt{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},wi),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 Rr.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)}`}}};Nd=Gn;O.BitString=Nd;Gn.NAME=Bd;var Ld;function ub(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 m=f;m>=0;m--,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=ii(new Uint8Array([u%10]),s);break;default:s[i-l]=u%10}}return e[0]>0&&(s=ii(e,s)),s}function vd(r){if(r>=Ro.length)for(let t=Ro.length;t<=r;t++){let e=new Uint8Array([0]),n=Ro[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=ii(e,n)),Ro.push(n)}return Ro[r]}function lb(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 No=class extends ar(Vt){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=au.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(bd(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=lb(vd(n),e),i="-";break;default:e=ub(e,vd(n))}n++,o>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Ed.charAt(e[c]));return a===!1&&(i+=Ed.charAt(0)),i}};Ld=No;No.NAME="IntegerValueBlock";Object.defineProperty(Ld.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Ud,bt=class r extends Lt{constructor(t={}){super(t,No),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return ai(),BigInt(this.valueBlock.toString())}static fromBigInt(t){ai();let e=BigInt(t),n=new To,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()}`}};Ud=bt;O.Integer=Ud;bt.NAME="INTEGER";var Dd,bi=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Dd=bi;O.Enumerated=Dd;bi.NAME="ENUMERATED";var Lo=class extends ar(Vt){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(!ir(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){ai();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=_r(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Se;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}}};Lo.NAME="sidBlock";var xi=class extends Vt{constructor({value:t=jn,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let o=e;for(;n>0;){let s=new Lo;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,Se;e.push(o)}return cu(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 Lo;if(o>Number.MAX_SAFE_INTEGER){ai();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}};xi.NAME="ObjectIdentifierValueBlock";var Pd,ke=class extends Lt{constructor(t={}){super(t,xi),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()}}};Pd=ke;O.ObjectIdentifier=Pd;ke.NAME="OBJECT IDENTIFIER";var Uo=class extends ar(nr){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(!ir(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=_r(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Se;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}}};Uo.NAME="relativeSidBlock";var Ei=class extends Vt{constructor({value:t=jn,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let o=e;for(;n>0;){let s=new Uo;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,Se;n.push(s)}return cu(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 Uo;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}};Ei.NAME="RelativeObjectIdentifierValueBlock";var Od,vi=class extends Lt{constructor(t={}){super(t,Ei),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()}}};Od=vi;O.RelativeObjectIdentifier=Od;vi.NAME="RelativeObjectIdentifier";var Fd,It=class extends Rr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Fd=It;O.Sequence=Fd;It.NAME="SEQUENCE";var Vd,Ai=class extends Rr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Vd=Ai;O.Set=Vd;Ai.NAME="SET";var Bi=class extends ar(Vt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=jn}toJSON(){return{...super.toJSON(),value:this.value}}};Bi.NAME="StringValueBlock";var ki=class extends Bi{};ki.NAME="SimpleStringValueBlock";var Kt=class extends li{constructor({...t}={}){super(t,ki)}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}};Kt.NAME="SIMPLE STRING";var Si=class extends Kt{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}};Si.NAME="Utf8StringValueBlock";var Md,sr=class extends Si{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Md=sr;O.Utf8String=Md;sr.NAME="UTF8String";var Ii=class extends Kt{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))}};Ii.NAME="BmpStringValueBlock";var $d,_i=class extends Ii{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};$d=_i;O.BmpString=$d;_i.NAME="BMPString";var Ri=class extends Kt{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=_r(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}};Ri.NAME="UniversalStringValueBlock";var Hd,Ti=class extends Ri{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Hd=Ti;O.UniversalString=Hd;Ti.NAME="UniversalString";var Kd,Ci=class extends Kt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Kd=Ci;O.NumericString=Kd;Ci.NAME="NumericString";var qd,Ni=class extends Kt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};qd=Ni;O.PrintableString=qd;Ni.NAME="PrintableString";var zd,Li=class extends Kt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};zd=Li;O.TeletexString=zd;Li.NAME="TeletexString";var Gd,Ui=class extends Kt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Gd=Ui;O.VideotexString=Gd;Ui.NAME="VideotexString";var jd,Di=class extends Kt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};jd=Di;O.IA5String=jd;Di.NAME="IA5String";var Wd,Pi=class extends Kt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Wd=Pi;O.GraphicString=Wd;Pi.NAME="GraphicString";var Yd,Do=class extends Kt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Yd=Do;O.VisibleString=Yd;Do.NAME="VisibleString";var Zd,Oi=class extends Kt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Zd=Oi;O.GeneralString=Zd;Oi.NAME="GeneralString";var Jd,Fi=class extends Kt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Jd=Fi;O.CharacterString=Jd;Fi.NAME="CharacterString";var Xd,Po=class extends Do{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]=jt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=jt(this.month,2),e[2]=jt(this.day,2),e[3]=jt(this.hour,2),e[4]=jt(this.minute,2),e[5]=jt(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}}};Xd=Po;O.UTCTime=Xd;Po.NAME="UTCTime";var Qd,Vi=class extends Po{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,m=n.indexOf("+"),h="";if(m===-1&&(m=n.indexOf("-"),l=-1),m!==-1){if(h=n.substring(m+1),n=n.substring(0,m),h.length!==2&&h.length!==4)throw new Error("Wrong input string for conversion");let p=parseInt(h.substring(0,2),10);if(isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*p,h.length===4){if(p=parseInt(h.substring(2,4),10),isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");c=l*p}}}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(jt(this.year,4)),e.push(jt(this.month,2)),e.push(jt(this.day,2)),e.push(jt(this.hour,2)),e.push(jt(this.minute,2)),e.push(jt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(jt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Qd=Vi;O.GeneralizedTime=Qd;Vi.NAME="GeneralizedTime";var tp,Mi=class extends sr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};tp=Mi;O.DATE=tp;Mi.NAME="DATE";var ep,$i=class extends sr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};ep=$i;O.TimeOfDay=ep;$i.NAME="TimeOfDay";var rp,Hi=class extends sr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};rp=Hi;O.DateTime=rp;Hi.NAME="DateTime";var np,Ki=class extends sr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};np=Ki;O.Duration=np;Ki.NAME="Duration";var op,qi=class extends sr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};op=qi;O.TIME=op;qi.NAME="TIME";function hb(r){let{result:t}=Wn(r),e=t.valueBlock.value;return{n:G(Oe(e[1].toBigInt()),"base64url"),e:G(Oe(e[2].toBigInt()),"base64url"),d:G(Oe(e[3].toBigInt()),"base64url"),p:G(Oe(e[4].toBigInt()),"base64url"),q:G(Oe(e[5].toBigInt()),"base64url"),dp:G(Oe(e[6].toBigInt()),"base64url"),dq:G(Oe(e[7].toBigInt()),"base64url"),qi:G(Oe(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function db(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 D("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new It({value:[new bt({value:0}),bt.fromBigInt(Fe(q(r.n,"base64url"))),bt.fromBigInt(Fe(q(r.e,"base64url"))),bt.fromBigInt(Fe(q(r.d,"base64url"))),bt.fromBigInt(Fe(q(r.p,"base64url"))),bt.fromBigInt(Fe(q(r.q,"base64url"))),bt.fromBigInt(Fe(q(r.dp,"base64url"))),bt.fromBigInt(Fe(q(r.dq,"base64url"))),bt.fromBigInt(Fe(q(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function pb(r){let{result:t}=Wn(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:G(Oe(e[0].toBigInt()),"base64url"),e:G(Oe(e[1].toBigInt()),"base64url")}}function mb(r){if(r.n==null||r.e==null)throw new D("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new It({value:[new It({value:[new ke({value:"1.2.840.113549.1.1.1"}),new Tr]}),new Gn({valueHex:new It({value:[bt.fromBigInt(Fe(q(r.n,"base64url"))),bt.fromBigInt(Fe(q(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Oe(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),o=0,s=0;for(;o<e;)n[o]=parseInt(t.slice(s,s+2),16),o+=1,s+=2;return n}function Fe(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(""))}var gb=16,lu=32,fu=1e4;async function yb(r,t){let e=Ht.get(),o=new It({value:[new bt({value:0}),new It({value:[new ke({value:"1.2.840.113549.1.1.1"}),new Tr]}),new or({valueHex:r.marshal()})]}).toBER(),s=new Uint8Array(o,0,o.byteLength),i=De(gb),a=await su(Vn,t,i,{c:fu,dkLen:lu}),c=De(16),u=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),f=await e.subtle.encrypt({name:"AES-CBC",iv:c},u,s),l=new It({value:[new or({valueHex:i}),new bt({value:fu}),new bt({value:lu}),new It({value:[new ke({value:"1.2.840.113549.2.11"}),new Tr]})]}),m=new It({value:[new ke({value:"1.2.840.113549.1.5.13"}),new It({value:[new It({value:[new ke({value:"1.2.840.113549.1.5.12"}),l]}),new It({value:[new ke({value:"2.16.840.1.101.3.4.1.42"}),new or({valueHex:c})]})]})]}),p=new It({value:[m,new or({valueHex:f})]}).toBER(),d=new Uint8Array(p,0,p.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...G(d,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
8
- `)}async function wb(r,t){let e=Ht.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=q(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Wn(o),{iv:i,salt:a,iterations:c,keySize:u,cipherText:f}=bb(s),l=await su(Vn,t,a,{c,dkLen:u}),m=await e.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),h=Oo(await e.subtle.decrypt({name:"AES-CBC",iv:i},m,f)),{result:p}=Wn(h);n=sp(p)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=q(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Wn(o);n=sp(s)}else throw new D("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return hu(n)}function bb(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new D("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new D("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let s=n.valueBlock.value[1],i=Oo(s.valueBlock.value[0].getValue()),a=fu,c=lu;if(s.valueBlock.value.length===3)a=Number(s.valueBlock.value[1].toBigInt()),c=Number(s.valueBlock.value[2].toBigInt());else if(s.valueBlock.value.length===2)throw new D("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let u=t.valueBlock.value[1].valueBlock.value[1],f=u.valueBlock.value[0].toString();if(f!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(f!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new D("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=Oo(u.valueBlock.value[1].getValue());return{cipherText:Oo(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:l}}function sp(r){return Oo(r.valueBlock.value[2].getValue())}function Oo(r){return new Uint8Array(r,0,r.byteLength)}async function ip(r){let t=await Ht.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 up(t);return{privateKey:e[0],publicKey:e[1]}}async function du(r){let e=[await Ht.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await xb(r)],n=await up({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function ap(r,t){let e=await Ht.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ht.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function cp(r,t,e){let n=await Ht.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ht.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function up(r){if(r.privateKey==null||r.publicKey==null)throw new D("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Ht.get().subtle.exportKey("jwk",r.privateKey),Ht.get().subtle.exportKey("jwk",r.publicKey)])}async function xb(r){return Ht.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function Gi(r){if(r.kty!=="RSA")throw new D("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new D("invalid key modulus","ERR_INVALID_KEY_MODULUS");return q(r.n,"base64url").length*8}var Vo=8192,Fo=class{_key;constructor(t){this._key=t}verify(t,e){return cp(this._key,e,t)}marshal(){return Cr.jwkToPkix(this._key)}get bytes(){return Ue.encode({Type:gt.RSA,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=vt.digest(this.bytes);return de(t)?t.then(({bytes:e})=>e):t.bytes}},Yn=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return De(16)}sign(t){return ap(this._key,t)}get public(){if(this._publicKey==null)throw new D("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Fo(this._publicKey)}marshal(){return Cr.jwkToPkcs1(this._key)}get bytes(){return er.encode({Type:gt.RSA,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=vt.digest(this.bytes);return de(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return G(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Cr.exportToPem(this,t);if(e==="libp2p-key")return Kn(this.bytes,t);throw new D(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function hu(r){let t=Cr.pkcs1ToJwk(r);if(Gi(t)>Vo)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await du(t);return new Yn(e.privateKey,e.publicKey)}function vb(r){let t=Cr.pkixToJwk(r);if(Gi(t)>Vo)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Fo(t)}async function Ab(r){if(Gi(r)>Vo)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await du(r);return new Yn(t.privateKey,t.publicKey)}async function Bb(r){if(r>Vo)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await ip(r);return new Yn(t.privateKey,t.publicKey)}var bu={};Et(bu,{Secp256k1PrivateKey:()=>$o,Secp256k1PublicKey:()=>Mo,generateKeyPair:()=>Ob,unmarshalSecp256k1PrivateKey:()=>Db,unmarshalSecp256k1PublicKey:()=>Pb});var kb=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]),Nr=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Lr=new Uint32Array(64),mu=class extends Fn{constructor(){super(64,32,8,!1),this.A=Nr[0]|0,this.B=Nr[1]|0,this.C=Nr[2]|0,this.D=Nr[3]|0,this.E=Nr[4]|0,this.F=Nr[5]|0,this.G=Nr[6]|0,this.H=Nr[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)Lr[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let m=Lr[l-15],h=Lr[l-2],p=Ae(m,7)^Ae(m,18)^m>>>3,d=Ae(h,17)^Ae(h,19)^h>>>10;Lr[l]=d+Lr[l-7]+p+Lr[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 m=Ae(a,6)^Ae(a,11)^Ae(a,25),h=f+m+Wh(a,c,u)+kb[l]+Lr[l]|0,d=(Ae(n,2)^Ae(n,13)^Ae(n,22))+Yh(n,o,s)|0;f=u,u=c,c=a,a=i+h|0,i=s,s=o,o=n,n=h+d|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(){Lr.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var lp=Gs(()=>new mu);function Sb(r){let t=So(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("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("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Ib,hexToBytes:_b}=Ys,Zr={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=Zr;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:Ib(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=Zr,e=typeof r=="string"?_b(r):r;Mn(e);let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:o,l:s}=Zr._parseInt(e.subarray(2)),{d:i,l:a}=Zr._parseInt(s);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:o,s:i}},hexFromSig(r){let t=u=>Number.parseInt(u[0],16)&8?"00"+u:u,e=u=>{let f=u.toString(16);return f.length&1?`0${f}`:f},n=t(e(r.s)),o=t(e(r.r)),s=n.length/2,i=o.length/2,a=e(s),c=e(i);return`30${e(i+s+4)}02${c}${o}02${a}${n}`}},cr=BigInt(0),me=BigInt(1),tS=BigInt(2),fp=BigInt(3),eS=BigInt(4);function Rb(r){let t=Sb(r),{Fp:e}=t,n=t.toBytes||((p,d,w)=>{let g=d.toAffine();return Xe(Uint8Array.from([4]),e.toBytes(g.x),e.toBytes(g.y))}),o=t.fromBytes||(p=>{let d=p.subarray(1),w=e.fromBytes(d.subarray(0,e.BYTES)),g=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:w,y:g}});function s(p){let{a:d,b:w}=t,g=e.sqr(p),x=e.mul(g,p);return e.add(e.add(x,e.mul(p,d)),w)}if(!e.eql(e.sqr(t.Gy),s(t.Gx)))throw new Error("bad generator point: equation left != right");function i(p){return typeof p=="bigint"&&cr<p&&p<t.n}function a(p){if(!i(p))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(p){let{allowedPrivateKeyLengths:d,nByteLength:w,wrapPrivateKey:g,n:x}=t;if(d&&typeof p!="bigint"){if(kr(p)&&(p=Ze(p)),typeof p!="string"||!d.includes(p.length))throw new Error("Invalid key");p=p.padStart(w*2,"0")}let b;try{b=typeof p=="bigint"?p:Je(mt("private key",p,w))}catch{throw new Error(`private key must be ${w} bytes, hex or bigint, not ${typeof p}`)}return g&&(b=at(b,x)),a(b),b}let u=new Map;function f(p){if(!(p instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(d,w,g){if(this.px=d,this.py=w,this.pz=g,d==null||!e.isValid(d))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(g==null||!e.isValid(g))throw new Error("z required")}static fromAffine(d){let{x:w,y:g}=d||{};if(!d||!e.isValid(w)||!e.isValid(g))throw new Error("invalid affine point");if(d instanceof l)throw new Error("projective point not allowed");let x=b=>e.eql(b,e.ZERO);return x(w)&&x(g)?l.ZERO:new l(w,g,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let w=e.invertBatch(d.map(g=>g.pz));return d.map((g,x)=>g.toAffine(w[x])).map(l.fromAffine)}static fromHex(d){let w=l.fromAffine(o(mt("pointHex",d)));return w.assertValidity(),w}static fromPrivateKey(d){return l.BASE.multiply(c(d))}_setWindowSize(d){this._WINDOW_SIZE=d,u.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:d,y:w}=this.toAffine();if(!e.isValid(d)||!e.isValid(w))throw new Error("bad point: x or y not FE");let g=e.sqr(w),x=s(d);if(!e.eql(g,x))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:w,py:g,pz:x}=this,{px:b,py:B,pz:A}=d,I=e.eql(e.mul(w,A),e.mul(b,x)),v=e.eql(e.mul(g,A),e.mul(B,x));return I&&v}negate(){return new l(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:w}=t,g=e.mul(w,fp),{px:x,py:b,pz:B}=this,A=e.ZERO,I=e.ZERO,v=e.ZERO,E=e.mul(x,x),U=e.mul(b,b),P=e.mul(B,B),N=e.mul(x,b);return N=e.add(N,N),v=e.mul(x,B),v=e.add(v,v),A=e.mul(d,v),I=e.mul(g,P),I=e.add(A,I),A=e.sub(U,I),I=e.add(U,I),I=e.mul(A,I),A=e.mul(N,A),v=e.mul(g,v),P=e.mul(d,P),N=e.sub(E,P),N=e.mul(d,N),N=e.add(N,v),v=e.add(E,E),E=e.add(v,E),E=e.add(E,P),E=e.mul(E,N),I=e.add(I,E),P=e.mul(b,B),P=e.add(P,P),E=e.mul(P,N),A=e.sub(A,E),v=e.mul(P,U),v=e.add(v,v),v=e.add(v,v),new l(A,I,v)}add(d){f(d);let{px:w,py:g,pz:x}=this,{px:b,py:B,pz:A}=d,I=e.ZERO,v=e.ZERO,E=e.ZERO,U=t.a,P=e.mul(t.b,fp),N=e.mul(w,b),M=e.mul(g,B),C=e.mul(x,A),X=e.add(w,g),S=e.add(b,B);X=e.mul(X,S),S=e.add(N,M),X=e.sub(X,S),S=e.add(w,x);let T=e.add(b,A);return S=e.mul(S,T),T=e.add(N,C),S=e.sub(S,T),T=e.add(g,x),I=e.add(B,A),T=e.mul(T,I),I=e.add(M,C),T=e.sub(T,I),E=e.mul(U,S),I=e.mul(P,C),E=e.add(I,E),I=e.sub(M,E),E=e.add(M,E),v=e.mul(I,E),M=e.add(N,N),M=e.add(M,N),C=e.mul(U,C),S=e.mul(P,S),M=e.add(M,C),C=e.sub(N,C),C=e.mul(U,C),S=e.add(S,C),N=e.mul(M,S),v=e.add(v,N),N=e.mul(T,S),I=e.mul(X,I),I=e.sub(I,N),N=e.mul(X,M),E=e.mul(T,E),E=e.add(E,N),new l(I,v,E)}subtract(d){return this.add(d.negate())}is0(){return this.equals(l.ZERO)}wNAF(d){return h.wNAFCached(this,u,d,w=>{let g=e.invertBatch(w.map(x=>x.pz));return w.map((x,b)=>x.toAffine(g[b])).map(l.fromAffine)})}multiplyUnsafe(d){let w=l.ZERO;if(d===cr)return w;if(a(d),d===me)return this;let{endo:g}=t;if(!g)return h.unsafeLadder(this,d);let{k1neg:x,k1:b,k2neg:B,k2:A}=g.splitScalar(d),I=w,v=w,E=this;for(;b>cr||A>cr;)b&me&&(I=I.add(E)),A&me&&(v=v.add(E)),E=E.double(),b>>=me,A>>=me;return x&&(I=I.negate()),B&&(v=v.negate()),v=new l(e.mul(v.px,g.beta),v.py,v.pz),I.add(v)}multiply(d){a(d);let w=d,g,x,{endo:b}=t;if(b){let{k1neg:B,k1:A,k2neg:I,k2:v}=b.splitScalar(w),{p:E,f:U}=this.wNAF(A),{p:P,f:N}=this.wNAF(v);E=h.constTimeNegate(B,E),P=h.constTimeNegate(I,P),P=new l(e.mul(P.px,b.beta),P.py,P.pz),g=E.add(P),x=U.add(N)}else{let{p:B,f:A}=this.wNAF(w);g=B,x=A}return l.normalizeZ([g,x])[0]}multiplyAndAddUnsafe(d,w,g){let x=l.BASE,b=(A,I)=>I===cr||I===me||!A.equals(x)?A.multiplyUnsafe(I):A.multiply(I),B=b(this,w).add(b(d,g));return B.is0()?void 0:B}toAffine(d){let{px:w,py:g,pz:x}=this,b=this.is0();d==null&&(d=b?e.ONE:e.inv(x));let B=e.mul(w,d),A=e.mul(g,d),I=e.mul(x,d);if(b)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:B,y:A}}isTorsionFree(){let{h:d,isTorsionFree:w}=t;if(d===me)return!0;if(w)return w(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:w}=t;return d===me?this:w?w(l,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return this.assertValidity(),n(l,this,d)}toHex(d=!0){return Ze(this.toRawBytes(d))}}l.BASE=new l(t.Gx,t.Gy,e.ONE),l.ZERO=new l(e.ZERO,e.ONE,e.ZERO);let m=t.nBitLength,h=Xs(l,t.endo?Math.ceil(m/2):m);return{CURVE:t,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:s,isWithinCurveOrder:i}}function Tb(r){let t=So(r);return Le(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function hp(r){let t=Tb(r),{Fp:e,n}=t,o=e.BYTES+1,s=2*e.BYTES+1;function i(S){return cr<S&&S<e.ORDER}function a(S){return at(S,n)}function c(S){return Zs(S,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:m}=Rb({...t,toBytes(S,T,H){let R=T.toAffine(),k=e.toBytes(R.x),F=Xe;return H?F(Uint8Array.from([T.hasEvenY()?2:3]),k):F(Uint8Array.from([4]),k,e.toBytes(R.y))},fromBytes(S){let T=S.length,H=S[0],R=S.subarray(1);if(T===o&&(H===2||H===3)){let k=Je(R);if(!i(k))throw new Error("Point is not on curve");let F=l(k),$;try{$=e.sqrt(F)}catch(Y){let et=Y instanceof Error?": "+Y.message:"";throw new Error("Point is not on curve"+et)}let K=($&me)===me;return(H&1)===1!==K&&($=e.neg($)),{x:k,y:$}}else if(T===s&&H===4){let k=e.fromBytes(R.subarray(0,e.BYTES)),F=e.fromBytes(R.subarray(e.BYTES,2*e.BYTES));return{x:k,y:F}}else throw new Error(`Point of length ${T} was invalid. Expected ${o} compressed bytes or ${s} uncompressed bytes`)}}),h=S=>Ze(Ir(S,t.nByteLength));function p(S){let T=n>>me;return S>T}function d(S){return p(S)?a(-S):S}let w=(S,T,H)=>Je(S.slice(T,H));class g{constructor(T,H,R){this.r=T,this.s=H,this.recovery=R,this.assertValidity()}static fromCompact(T){let H=t.nByteLength;return T=mt("compactSignature",T,H*2),new g(w(T,0,H),w(T,H,2*H))}static fromDER(T){let{r:H,s:R}=Zr.toSig(mt("DER",T));return new g(H,R)}assertValidity(){if(!m(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!m(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(T){return new g(this.r,this.s,T)}recoverPublicKey(T){let{r:H,s:R,recovery:k}=this,F=v(mt("msgHash",T));if(k==null||![0,1,2,3].includes(k))throw new Error("recovery id invalid");let $=k===2||k===3?H+t.n:H;if($>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let K=k&1?"03":"02",W=u.fromHex(K+h($)),Y=c($),et=a(-F*Y),J=a(R*Y),Q=u.BASE.multiplyAndAddUnsafe(W,et,J);if(!Q)throw new Error("point at infinify");return Q.assertValidity(),Q}hasHighS(){return p(this.s)}normalizeS(){return this.hasHighS()?new g(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return zr(this.toDERHex())}toDERHex(){return Zr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return zr(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let x={isValidPrivateKey(S){try{return f(S),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let S=Jc(t.n);return id(t.randomBytes(S),t.n)},precompute(S=8,T=u.BASE){return T._setWindowSize(S),T.multiply(BigInt(3)),T}};function b(S,T=!0){return u.fromPrivateKey(S).toRawBytes(T)}function B(S){let T=kr(S),H=typeof S=="string",R=(T||H)&&S.length;return T?R===o||R===s:H?R===2*o||R===2*s:S instanceof u}function A(S,T,H=!0){if(B(S))throw new Error("first arg must be private key");if(!B(T))throw new Error("second arg must be public key");return u.fromHex(T).multiply(f(S)).toRawBytes(H)}let I=t.bits2int||function(S){let T=Je(S),H=S.length*8-t.nBitLength;return H>0?T>>BigInt(H):T},v=t.bits2int_modN||function(S){return a(I(S))},E=ko(t.nBitLength);function U(S){if(typeof S!="bigint")throw new Error("bigint expected");if(!(cr<=S&&S<E))throw new Error(`bigint expected < 2^${t.nBitLength}`);return Ir(S,t.nByteLength)}function P(S,T,H=N){if(["recovered","canonical"].some(dt=>dt in H))throw new Error("sign() legacy options not supported");let{hash:R,randomBytes:k}=t,{lowS:F,prehash:$,extraEntropy:K}=H;F==null&&(F=!0),S=mt("msgHash",S),$&&(S=mt("prehashed msgHash",R(S)));let W=v(S),Y=f(T),et=[U(Y),U(W)];if(K!=null&&K!==!1){let dt=K===!0?k(e.BYTES):K;et.push(mt("extraEntropy",dt))}let J=Xe(...et),Q=W;function wt(dt){let _t=I(dt);if(!m(_t))return;let Rt=c(_t),xt=u.BASE.multiply(_t).toAffine(),Dt=a(xt.x);if(Dt===cr)return;let $e=a(Rt*a(Q+Dt*Y));if($e===cr)return;let Ur=(xt.x===Dt?0:2)|Number(xt.y&me),eo=$e;return F&&p($e)&&(eo=d($e),Ur^=1),new g(Dt,eo,Ur)}return{seed:J,k2sig:wt}}let N={lowS:t.lowS,prehash:!1},M={lowS:t.lowS,prehash:!1};function C(S,T,H=N){let{seed:R,k2sig:k}=P(S,T,H),F=t;return jc(F.hash.outputLen,F.nByteLength,F.hmac)(R,k)}u.BASE._setWindowSize(8);function X(S,T,H,R=M){let k=S;if(T=mt("msgHash",T),H=mt("publicKey",H),"strict"in R)throw new Error("options.strict was renamed to lowS");let{lowS:F,prehash:$}=R,K,W;try{if(typeof k=="string"||kr(k))try{K=g.fromDER(k)}catch(xt){if(!(xt instanceof Zr.Err))throw xt;K=g.fromCompact(k)}else if(typeof k=="object"&&typeof k.r=="bigint"&&typeof k.s=="bigint"){let{r:xt,s:Dt}=k;K=new g(xt,Dt)}else throw new Error("PARSE");W=u.fromHex(H)}catch(xt){if(xt.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(F&&K.hasHighS())return!1;$&&(T=t.hash(T));let{r:Y,s:et}=K,J=v(T),Q=c(et),wt=a(J*Q),dt=a(Y*Q),_t=u.BASE.multiplyAndAddUnsafe(W,wt,dt)?.toAffine();return _t?a(_t.x)===Y:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:A,sign:C,verify:X,ProjectivePoint:u,Signature:g,utils:x}}function Cb(r){return{hash:r,hmac:(t,...e)=>_o(r,t,zs(...e)),randomBytes:On}}function dp(r,t){let e=n=>hp({...r,...Cb(n)});return Object.freeze({...e(t),create:e})}var gp=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),pp=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Nb=BigInt(1),gu=BigInt(2),mp=(r,t)=>(r+t/gu)/t;function Lb(r){let t=gp,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=lt(f,e,t)*f%t,m=lt(l,e,t)*f%t,h=lt(m,gu,t)*u%t,p=lt(h,o,t)*h%t,d=lt(p,s,t)*p%t,w=lt(d,a,t)*d%t,g=lt(w,c,t)*w%t,x=lt(g,a,t)*d%t,b=lt(x,e,t)*f%t,B=lt(b,i,t)*p%t,A=lt(B,n,t)*u%t,I=lt(A,gu,t);if(!yu.eql(yu.sqr(I),r))throw new Error("Cannot find square root");return I}var yu=Js(gp,void 0,void 0,{sqrt:Lb}),Ie=dp({a:BigInt(0),b:BigInt(7),Fp:yu,n:pp,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=pp,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Nb*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=mp(s*r,t),c=mp(-n*r,t),u=at(r-a*e-c*o,t),f=at(-a*n-c*s,t),l=u>i,m=f>i;if(l&&(u=t-u),m&&(f=t-f),u>i||f>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:u,k2neg:m,k2:f}}}},lp),lS=BigInt(0);var fS=Ie.ProjectivePoint;function yp(){return Ie.utils.randomPrivateKey()}function wp(r,t){let e=vt.digest(t instanceof Uint8Array?t:t.subarray());if(de(e))return e.then(({digest:n})=>Ie.sign(n,r).toDERRawBytes()).catch(n=>{throw new D(String(n),"ERR_INVALID_INPUT")});try{return Ie.sign(e.digest,r).toDERRawBytes()}catch(n){throw new D(String(n),"ERR_INVALID_INPUT")}}function bp(r,t,e){let n=vt.digest(e instanceof Uint8Array?e:e.subarray());if(de(n))return n.then(({digest:o})=>Ie.verify(t,o,r)).catch(o=>{throw new D(String(o),"ERR_INVALID_INPUT")});try{return Ie.verify(t,n.digest,r)}catch(o){throw new D(String(o),"ERR_INVALID_INPUT")}}function xp(r){return Ie.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ep(r){try{Ie.getPublicKey(r,!0)}catch(t){throw new D(String(t),"ERR_INVALID_PRIVATE_KEY")}}function wu(r){try{Ie.ProjectivePoint.fromHex(r)}catch(t){throw new D(String(t),"ERR_INVALID_PUBLIC_KEY")}}function vp(r){try{return Ie.getPublicKey(r,!0)}catch(t){throw new D(String(t),"ERR_INVALID_PRIVATE_KEY")}}var Mo=class{_key;constructor(t){wu(t),this._key=t}verify(t,e){return bp(this._key,e,t)}marshal(){return xp(this._key)}get bytes(){return Ue.encode({Type:gt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}async hash(){let t=vt.digest(this.bytes),e;return de(t)?{bytes:e}=await t:e=t.bytes,e}},$o=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??vp(t),Ep(this._key),wu(this._publicKey)}sign(t){return wp(this._key,t)}get public(){return new Mo(this._publicKey)}marshal(){return this._key}get bytes(){return er.encode({Type:gt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=vt.digest(this.bytes);return de(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return G(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Kn(this.bytes,t);throw new D(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Db(r){return new $o(r)}function Pb(r){return new Mo(r)}async function Ob(){let r=yp();return new $o(r)}var ji={rsa:pu,ed25519:ou,secp256k1:bu};function Fb(r){let t=Object.keys(ji).join(" / ");return new D(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function xu(r){let t=Ue.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case gt.RSA:return ji.rsa.unmarshalRsaPublicKey(e);case gt.Ed25519:return ji.ed25519.unmarshalEd25519PublicKey(e);case gt.Secp256k1:return ji.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw Fb(t.Type??"unknown")}}var Eu=Yt(kp(),1);var Vb=Math.LN2*Math.LN2,Yi=class r{static create(t,e=.005){let n=Mb(t,e);return new r(n)}seeds;bits;buffer;constructor(t={}){t.seeds!=null?this.seeds=t.seeds:this.seeds=$b(t.hashes??8),this.bits=t.bits??1024,this.buffer=ye(Math.ceil(this.bits/8))}add(t){typeof t=="string"&&(t=q(t));for(let e=0;e<this.seeds.length;e++){let o=Eu.default.x86.hash32(t,this.seeds[e])%this.bits;this.setbit(o)}}has(t){typeof t=="string"&&(t=q(t));for(let e=0;e<this.seeds.length;e++){let o=Eu.default.x86.hash32(t,this.seeds[e])%this.bits;if(!this.getbit(o))return!1}return!0}clear(){this.buffer.fill(0)}setbit(t){let e=0,n=t;for(;n>7;)e++,n-=8;let o=this.buffer[e];o|=1<<n,this.buffer[e]=o}getbit(t){let e=0,n=t;for(;n>7;)e++,n-=8;return(this.buffer[e]&1<<n)!==0}};function Mb(r,t=.005){let e=Math.round(-1*r*Math.log(t)/Vb),n=Math.round(e/r*Math.LN2);return{bits:e,hashes:n}}function $b(r){let t,e,n=[];for(let o=0;o<r;o++)for(t=new ss(De(4)),n[o]=t.getUint32(0,!0),e=0;e<o;e++)if(n[o]===n[e]){o--;break}return n}var Ko=class extends tn{intialPeerSearchComplete;requests;name;log;logger;minProviders;maxProviders;providers;evictionFilter;constructor(t,e){super(),ft(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=Yi.create(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=Bt();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.providers.some(e=>this.equals(e,t))}hasProvider(t){return!!(this.providers.find(e=>this.equals(e,t))!=null||this.isEvicted(t))}async findProviders(t,e,n){let o=Bt(),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 D(`Found ${s} of ${e} ${this.name} providers for ${t}`,"ERR_INSUFFICIENT_PROVIDERS_FOUND")}).catch(i=>{this.log.error("error searching routing for potential session peers for %c",t,i.errors??i),o.reject(i)}),o.promise}};var Zi=class{blockstore;datastore;pins;logger;routing;dagWalkers;hashers;dns;log;constructor(t){this.logger=t.logger??Jl(),this.log=this.logger.forComponent("helia"),this.hashers=Oh(t.hashers),this.dagWalkers=Uh(t.dagWalkers),this.dns=t.dns??cf();let e={blockstore:t.blockstore,datastore:t.datastore,hashers:this.hashers,dagWalkers:this.dagWalkers,logger:this.logger,blockBrokers:[],dns:this.dns,...t.components??{}};this.routing=e.routing=new Ds(e,{routers:(t.routers??[]).flatMap(o=>{let s=[o];return o[ro]!=null&&s.push(o[ro]),o[no]!=null&&s.push(o[no]),s}),providerLookupConcurrency:t.providerLookupConcurrency});let n=new Hs(e);this.pins=new Us(t.datastore,n,this.dagWalkers),this.blockstore=new Ps(n,this.pins,{holdGcLock:t.holdGcLock??!0}),this.datastore=t.datastore,e.blockBrokers=t.blockBrokers.map(o=>o(e))}async start(){await Ph(this.datastore),await hr(this.blockstore,this.datastore,this.routing)}async stop(){await dr(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 Pr(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 rt("helia:gc:deleted",s))}catch(i){n.log.error("Error during gc",i),t.onProgress?.(new rt("helia:gc:error",i))}}()))}finally{e()}this.log("gc finished")}};function Hb(r){return r[Symbol.asyncIterator]!=null}function Kb(r){if(Hb(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 vu=Kb;var Ji=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 m=Number.parseInt(l,t);if(!Number.isNaN(m))return m});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 Sp=45,qb=15,Zn=new Ji;function Au(r){if(!(r.length>qb))return Zn.new(r).parseWith(()=>Zn.readIPv4Addr())}function Bu(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Sp))return Zn.new(r).parseWith(()=>Zn.readIPv6Addr())}function Xi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Sp))return Zn.new(r).parseWith(()=>Zn.readIPAddr())}function Jn(r){return!!Au(r)}function Xn(r){return!!Bu(r)}function Qi(r){return!!Xi(r)}var _p=Yt(Ip(),1),zb=["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"],Gb=zb.map(r=>new _p.Netmask(r));function jb(r){for(let t of Gb)if(t.contains(r))return!0;return!1}function Wb(r){return/^::$/.test(r)||/^::1$/.test(r)||/^::f{4}:([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)||/^::f{4}:0.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.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 Rp(r){return Jn(r)?jb(r):Xn(r)?Wb(r):void 0}var mI=parseInt("0xFFFF",16),gI=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Np=Jn,Qb=Xn,ku=function(r){let t=0;if(r=r.toString().trim(),Np(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(Qb(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=Np(e[n]),i;s&&(i=ku(e[n]),e[n]=G(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,G(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")},Lp=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={},Su={},ex=[[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"],[777,-1,"memory"]];ex.forEach(r=>{let t=rx(...r);Su[t.code]=t,Qn[t.name]=t});function rx(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function j(r){if(typeof r=="number"){if(Su[r]!=null)return Su[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 JI=j("ip4"),XI=j("ip6"),QI=j("ipcidr");function _u(r,t){switch(j(r).code){case 4:case 41:return ox(t);case 42:return Pp(t);case 6:case 273:case 33:case 132:return Fp(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Pp(t);case 421:return cx(t);case 444:return Op(t);case 445:return Op(t);case 466:return ax(t);default:return G(t,"base16")}}function Ru(r,t){switch(j(r).code){case 4:return Up(t);case 41:return Up(t);case 42:return Dp(t);case 6:case 273:case 33:case 132:return Tu(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Dp(t);case 421:return sx(t);case 444:return ux(t);case 445:return lx(t);case 466:return ix(t);default:return q(t,"base16")}}var Iu=Object.values(yr).map(r=>r.decoder),nx=function(){let r=Iu[0].or(Iu[1]);return Iu.slice(2).forEach(t=>r=r.or(t)),r}();function Up(r){if(!Qi(r))throw new Error("invalid ip address");return ku(r)}function ox(r){let t=Lp(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!Qi(t))throw new Error("invalid ip address");return t}function Tu(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Fp(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Dp(r){let t=q(r),e=Uint8Array.from(rn(t.length));return kt([e,t],e.length+t.length)}function Pp(r){let t=Or(r);if(r=r.slice(Gt(t)),r.length!==t)throw new Error("inconsistent lengths");return G(r)}function sx(r){let t;r[0]==="Q"||r[0]==="1"?t=Te(ht.decode(`z${r}`)).bytes:t=st.parse(r).multihash.bytes;let e=Uint8Array.from(rn(t.length));return kt([e,t],e.length+t.length)}function ix(r){let t=nx.decode(r),e=Uint8Array.from(rn(t.length));return kt([e,t],e.length+t.length)}function ax(r){let t=Or(r),e=r.slice(Gt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+G(e,"base64url")}function cx(r){let t=Or(r),e=r.slice(Gt(t));if(e.length!==t)throw new Error("inconsistent lengths");return G(e,"base58btc")}function ux(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=Tt.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=Tu(n);return kt([e,o],e.length+o.length)}function lx(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=Tt.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=Tu(n);return kt([e,o],e.length+o.length)}function Op(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=G(t,"base32"),o=Fp(e);return`${n}:${o}`}function Vp(r){r=Cu(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=j(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw $p("invalid address: "+r);if(a.path===!0){n=Cu(o.slice(s).join("/")),t.push([a.code,Ru(a.code,n)]),e.push([a.code,n]);break}let c=Ru(a.code,o[s]);t.push([a.code,c]),e.push([a.code,_u(a.code,c)])}return{string:Mp(e),bytes:Lu(t),tuples:t,stringTuples:e,path:n}}function Nu(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=Or(r,o),i=Gt(s),a=j(s),c=fx(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 $p("Invalid address Uint8Array: "+G(r,"base16"));t.push([s,u]);let f=_u(s,u);if(e.push([s,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(r),string:Mp(e),tuples:t,stringTuples:e,path:n}}function Mp(r){let t=[];return r.map(e=>{let n=j(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Cu(t.join("/"))}function Lu(r){return kt(r.map(t=>{let e=j(t[0]),n=Uint8Array.from(rn(e.code));return t.length>1&&t[1]!=null&&(n=kt([n,t[1]])),n}))}function fx(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+Gt(e)}}function Cu(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function $p(r){return new Error("Error parsing address: "+r)}var hx=Symbol.for("nodejs.util.inspect.custom"),Uu=Symbol.for("@multiformats/js-multiaddr/multiaddr"),dx=[j("dns").code,j("dns4").code,j("dns6").code,j("dnsaddr").code],ta=class r{bytes;#t;#e;#r;#o;[Uu]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Nu(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Vp(t)}else if(Kp(t))e=Nu(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=j("tcp"),a=j("udp"),c=j("ip4"),u=j("ip6"),f=j("dns6"),l=j("ip6zone");for(let[h,p]of this.stringTuples())h===l.code&&(s=`%${p??""}`),dx.includes(h)&&(e=i.name,o=443,n=`${p??""}${s}`,t=h===f.code?6:4),(h===i.code||h===a.code)&&(e=j(h).name,o=parseInt(p??"")),(h===c.code||h===u.code)&&(e=j(h).name,n=`${p??""}${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({},j(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>j(t).name)}tuples(){return this.#e}stringTuples(){return this.#r}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),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(Lu(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"?G(ht.decode(`z${n}`),"base58btc"):G(st.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#o}equals(t){return it(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=Hp.get(e.name);if(n==null)throw new D(`no available resolver for ${e.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,t)).map(s=>Jr(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)}[hx](){return`Multiaddr(${this.#t})`}};var Hp=new Map;function Kp(r){return!!r?.[Uu]}function Jr(r){return new ta(r)}var px=r=>r.toString().split("/").slice(1),zo=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),nt=r=>({match:t=>zo(e=>e===r).match(t),pattern:r}),na=()=>({match:r=>zo(t=>typeof t=="string").match(r),pattern:"{string}"}),oa=()=>({match:r=>zo(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),Ut=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{ht.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),ea=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{qa.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),qt=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),se=(...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(", ")})`}),ct=(...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 yt(...r){function t(o){let s=px(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{matches:e,exactMatch:n}}var Pu=ct(nt("dns4"),na()),Ou=ct(nt("dns6"),na()),Fu=ct(nt("dnsaddr"),na()),qp=ct(nt("dns"),na()),_6=yt(Pu),R6=yt(Ou),T6=yt(Fu),zp=yt(se(qp,Fu,Pu,Ou)),Gp=ct(nt("ip4"),zo(Jn)),jp=ct(nt("ip6"),zo(Xn)),Wp=se(Gp,jp),Ve=se(Wp,qp,Pu,Ou,Fu),C6=yt(Ve),N6=yt(Gp),L6=yt(jp),U6=yt(Wp),sa=ct(Ve,nt("tcp"),oa()),Go=ct(Ve,nt("udp"),oa()),mx=se(sa,Go),D6=yt(sa),P6=yt(Go),Vu=ct(Go,nt("quic")),ia=ct(Go,nt("quic-v1")),gx=se(Vu,ia),O6=yt(Vu),F6=yt(ia),Du=se(Ve,sa,Go,Vu,ia),Yp=se(ct(Du,nt("ws"),qt(Ut()))),V6=yt(Yp),Zp=se(ct(Du,nt("wss"),qt(Ut())),ct(Du,nt("tls"),nt("ws"),qt(Ut()))),M6=yt(Zp),Jp=ct(mx,nt("webrtc-direct"),ea(),qt(ea()),qt(Ut())),$6=yt(Jp),Xp=ct(ia,nt("webtransport"),ea(),ea(),qt(Ut())),H6=yt(Xp),ra=se(Yp,Zp,ct(sa,qt(Ut())),ct(gx,qt(Ut())),ct(Ve,qt(Ut())),Jp,Xp,Ut()),K6=yt(ra),yx=ct(ra,nt("p2p-circuit"),Ut()),q6=yt(yx),wx=se(ct(ra,nt("p2p-circuit"),nt("webrtc"),Ut()),ct(ra,nt("webrtc"),qt(Ut())),nt("webrtc")),z6=yt(wx),bx=se(ct(Ve,nt("tcp"),oa(),nt("http"),qt(Ut())),ct(Ve,nt("http"),qt(Ut()))),Qp=yt(bx),xx=se(ct(Ve,nt("tcp"),se(ct(nt("443"),nt("http")),ct(oa(),nt("https"))),qt(Ut())),ct(Ve,nt("tls"),nt("http"),qt(Ut())),ct(Ve,nt("https"),qt(Ut()))),t0=yt(xx);var Ex=[j("tcp").code,j("dns").code,j("dnsaddr").code,j("dns4").code,j("dns6").code];function e0(r){let t;try{t=j("sni").code}catch{return null}for(let[e,n]of r)if(e===t&&n!==void 0)return n;return null}function r0(r){return r.some(([t,e])=>t===j("tls").code)}function ie(r,t,e){let n=n0[j(r).name];if(n===void 0)throw new Error(`Can't interpret protocol ${j(r).name}`);let o=n(t,e);return r===j("ip6").code?`[${o}]`:o}var n0={ip4:(r,t)=>r,ip6:(r,t)=>t.length===0?r:`[${r}]`,tcp:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`tcp://${ie(e[0],e[1]??"",t)}:${r}`},udp:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`udp://${ie(e[0],e[1]??"",t)}:${r}`},dnsaddr:(r,t)=>r,dns4:(r,t)=>r,dns6:(r,t)=>r,dns:(r,t)=>r,ipfs:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${ie(e[0],e[1]??"",t)}/ipfs/${r}`},p2p:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${ie(e[0],e[1]??"",t)}/p2p/${r}`},http:(r,t)=>{let e=r0(t),n=e0(t);if(e&&n!==null)return`https://${n}`;let o=e?"https://":"http://",s=t.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let i=ie(s[0],s[1]??"",t);return i=i.replace("tcp://",""),`${o}${i}`},tls:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return ie(e[0],e[1]??"",t)},sni:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return ie(e[0],e[1]??"",t)},https:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");let n=ie(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`https://${n}`},ws:(r,t)=>{let e=r0(t),n=e0(t);if(e&&n!==null)return`wss://${n}`;let o=e?"wss://":"ws://",s=t.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let i=ie(s[0],s[1]??"",t);return i=i.replace("tcp://",""),`${o}${i}`},wss:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");let n=ie(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`wss://${n}`},"p2p-websocket-star":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${ie(e[0],e[1]??"",t)}/p2p-websocket-star`},"p2p-webrtc-star":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${ie(e[0],e[1]??"",t)}/p2p-webrtc-star`},"p2p-webrtc-direct":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${ie(e[0],e[1]??"",t)}/p2p-webrtc-direct`}};function o0(r,t){let n=Jr(r).stringTuples(),o=n.pop();if(o===void 0)throw new Error("Unexpected end of multiaddr");let s=j(o[0]),i=n0[s.name];if(i==null)throw new Error(`No interpreter found for ${s.name}`);let a=i(o[1]??"",n);return t?.assumeHttp!==!1&&Ex.includes(o[0])&&(a=a.replace(/^.*:\/\//,""),o[1]==="443"?a=`https://${a}`:a=`http://${a}`),(a.startsWith("http://")||a.startsWith("https://"))&&(a=new URL(a).toString(),a.endsWith("/")&&(a=a.substring(0,a.length-1))),a}var Xr=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}}};var vx=!1,Ax=!1,Mu=class extends Ko{routing;allowInsecure;allowLocal;constructor(t,e){super(t,{...e,name:"helia:trustless-gateway:session"}),this.routing=t.routing,this.allowInsecure=e.allowInsecure??vx,this.allowLocal=e.allowLocal??Ax}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={}){for await(let n of this.routing.findProviders(t,e)){let o=Bx(n.multiaddrs,this.allowInsecure,this.allowLocal);if(o.length===0)continue;let s=o0(o[0]);this.log("found http-gateway provider %p %s for cid %c",n.id,s,t),yield new Xr(s,this.logger)}}toEvictionKey(t){return t.url.toString()}equals(t,e){return t.url.toString()===e.url.toString()}};function Bx(r,t,e){return r.filter(n=>t0.matches(n)||t&&Qp.matches(n)?e||zp.matches(n)?!0:Rp(n.toOptions().host)===!1:!1)}function s0(r,t){return new Mu(r,t)}var aa=class{components;gateways;routing;log;logger;constructor(t,e={}){this.components=t,this.log=t.logger.forComponent("helia:trustless-gateway-block-broker"),this.logger=t.logger,this.routing=t.routing,this.gateways=(e.gateways??i0).map(n=>new Xr(n,t.logger))}addGateway(t){this.gateways.push(new Xr(t,this.components.logger))}async retrieve(t,e={}){let n=this.gateways.sort((s,i)=>i.reliability()-s.reliability()),o=[];for(let s of n){this.log("getting block for %c from %s",t,s.url);try{let i=await s.getRawBlock(t,e.signal);this.log.trace("got block for %c from %s",t,s.url);try{await e.validateFn?.(i)}catch(a){throw this.log.error("failed to validate block for %c from %s",t,s.url,a),s.incrementInvalidBlocks(),new Error(`Block for CID ${t} from gateway ${s.url} failed validation`)}return i}catch(i){if(this.log.error("failed to get block for %c from %s",t,s.url,i),i instanceof Error?o.push(i):o.push(new Error(`Unable to fetch raw block for CID ${t} from gateway ${s.url}`)),e.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",t,s.url);break}}}throw o.length>0?new AggregateError(o,`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 s0({logger:this.logger,routing:this.routing},t)}};var i0=["https://trustless-gateway.link","https://cloudflare-ipfs.com","https://4everland.io"];function $u(r={}){return t=>new aa(t,r)}async function*ca(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 _x=Yt(nn(),1);var Rx=Yt(Ku(),1);var a0="ERR_IPNS_EXPIRED_RECORD",ua="ERR_UNRECOGNIZED_VALIDITY";var ur="ERR_SIGNATURE_VERIFICATION";var qu="ERR_UNDEFINED_PARAMETER",c0="ERR_INVALID_RECORD_DATA",u0="ERR_INVALID_VALUE",l0="ERR_INVALID_EMBEDDED_KEY";var f0="ERR_RECORD_TOO_LARGE";var _e;(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=()=>uo(e)}(t=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=pn((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)=>{let i={},a=s==null?o.len:o.pos+s;for(;o.pos<a;){let c=o.uint32();switch(c>>>3){case 1:i.value=o.bytes();break;case 2:i.signatureV1=o.bytes();break;case 3:i.validityType=r.ValidityType.codec().decode(o);break;case 4:i.validity=o.bytes();break;case 5:i.sequence=o.uint64();break;case 6:i.ttl=o.uint64();break;case 7:i.pubKey=o.bytes();break;case 8:i.signatureV2=o.bytes();break;case 9:i.data=o.bytes();break;default:o.skipType(c&7);break}}return i})),n),r.encode=o=>hn(o,r.codec()),r.decode=o=>an(o,r.codec())})(_e||(_e={}));var ae=Yt(nn(),1);var d0=Qt("ipns:utils"),p0=q("/ipns/"),kx=114,m0=async(r,t)=>{if(t==null||r==null){let n=new Error("one or more of the provided parameters are not defined");throw d0.error(n),(0,ae.default)(n,qu)}let e;if(t.pubKey!=null){try{e=xu(t.pubKey)}catch(o){throw d0.error(o),o}if(!(await zl(t.pubKey)).equals(r))throw(0,ae.default)(new Error("Embedded public key did not match PeerID"),l0)}else r.publicKey!=null&&(e=xu(r.publicKey));if(e!=null)return e;throw(0,ae.default)(new Error("no public key is available"),qu)};var g0=r=>{let t=q("ipns-signature:");return kt([t,r])},Qr=r=>"signatureV1"in r?_e.encode({value:q(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:q(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):_e.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data});function Me(r){let t=_e.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(0,ae.default)(new Error("missing data or signatureV2"),ur);let e=y0(t.data),n=Sx(e.Value),o=G(e.Validity);if(t.value!=null&&t.signatureV1!=null)return Ix(t),{value:n,validityType:_e.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:_e.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")}var zu=r=>kt([p0,r.toBytes()]),to=r=>fo(r.slice(p0.length));var y0=r=>{let t=he(r);if(t.ValidityType===0)t.ValidityType=_e.ValidityType.EOL;else throw(0,ae.default)(new Error("Unknown validity type"),ua);return Number.isInteger(t.Sequence)&&(t.Sequence=BigInt(t.Sequence)),Number.isInteger(t.TTL)&&(t.TTL=BigInt(t.TTL)),t},Sx=r=>{if(r!=null){if(ol(r))return`/ipns/${r.toCID().toString(gr)}`;if(r instanceof Uint8Array){let n=G(r);n.startsWith("/")&&(r=n)}let t=r.toString().trim();if(t.startsWith("/")&&t.length>1)return t;let e=st.asCID(r);if(e!=null)return e.code===kx?`/ipns/${e.toString(gr)}`:`/ipfs/${e.toV1().toString()}`;try{return r instanceof Uint8Array?`/ipfs/${st.decode(r).toV1().toString()}`:`/ipfs/${st.parse(t).toV1().toString()}`}catch{}}throw(0,ae.default)(new Error("Value must be a valid content path starting with /"),u0)},Ix=r=>{if(r.data==null)throw(0,ae.default)(new Error("Record data is missing"),c0);let t=y0(r.data);if(!it(t.Value,r.value??new Uint8Array(0)))throw(0,ae.default)(new Error('Field "value" did not match between protobuf and CBOR'),ur);if(!it(t.Validity,r.validity??new Uint8Array(0)))throw(0,ae.default)(new Error('Field "validity" did not match between protobuf and CBOR'),ur);if(t.ValidityType!==r.validityType)throw(0,ae.default)(new Error('Field "validityType" did not match between protobuf and CBOR'),ur);if(t.Sequence!==r.sequence)throw(0,ae.default)(new Error('Field "sequence" did not match between protobuf and CBOR'),ur);if(t.TTL!==r.ttl)throw(0,ae.default)(new Error('Field "ttl" did not match between protobuf and CBOR'),ur)};var P4=Qt("ipns"),O4=ue.code,F4=60*60*1e9,Tx="/ipns/",V4=Tx.length;var jo=Yt(nn(),1),w0=Yt(Ku(),1);var la=Qt("ipns:validator"),Cx=1024*10,Nx=async(r,t)=>{let e=Me(t),n;try{let o=g0(e.data);n=await r.verify(o,e.signatureV2)}catch{n=!1}if(!n)throw la.error("record signature verification failed"),(0,jo.default)(new Error("record signature verification failed"),ur);if(e.validityType===_e.ValidityType.EOL){if(w0.default.fromString(e.validity).toDate().getTime()<Date.now())throw la.error("record has expired"),(0,jo.default)(new Error("record has expired"),a0)}else if(e.validityType!=null)throw la.error("unrecognized validity type"),(0,jo.default)(new Error("unrecognized validity type"),ua);la("ipns record for %s is valid",e.value)};async function b0(r,t){if(t.byteLength>Cx)throw(0,jo.default)(new Error("record too large"),f0);let e=to(r),n=Me(t),o=await m0(e,n);await Nx(o,t)}async function*Wo(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))}function Lx(r){return r[Symbol.asyncIterator]!=null}function Ux(r){if(Lx(r))return(async()=>{for await(let t of r)return t})();for(let t of r)return t}var fa=Ux;var Gu=q("/ipns/");function x0(r){return it(r.subarray(0,Gu.byteLength),Gu)}var E0=r=>fo(r.slice(Gu.length)),ha=class{client;constructor(t){this.client=t}async*findProviders(t,e={}){yield*sn(this.client.getProviders(t,e),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async put(t,e,n){if(!x0(t))return;let o=E0(t),s=Me(e);await this.client.putIPNS(o,s,n)}async get(t,e){if(!x0(t))throw new D("Not found","ERR_NOT_FOUND");let n=E0(t);try{let o=await this.client.getIPNS(n,e);return Qr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new D("Not found","ERR_NOT_FOUND"):o}}},da=class{client;constructor(t){this.client=t}async findPeer(t,e={}){let n=await fa(this.client.getPeers(t,e));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new D("Not found","ERR_NOT_FOUND")}async*getClosestPeers(t,e={}){}};var Wt=Qt("delegated-routing-v1-http-api-client"),v0={concurrentRequests:4,timeout:3e4},pa=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;constructor(t,e={}){this.started=!1,this.shutDownController=new AbortController,ft(1/0,this.shutDownController.signal),this.httpQueue=new Ce({concurrency:e.concurrentRequests??v0.concurrentRequests}),this.clientUrl=t instanceof URL?t:new URL(t),this.timeout=e.timeout??v0.timeout,this.contentRouting=new ha(this),this.peerRouting=new da(this)}get[ro](){return this.contentRouting}get[no](){return this.peerRouting}isStarted(){return this.started}start(){this.started=!0}stop(){this.httpQueue.clear(),this.shutDownController.abort(),this.started=!1}async*getProviders(t,e={}){Wt("getProviders starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=Mt([this.shutDownController.signal,n,e.signal]);ft(1/0,n,o);let s=Bt(),i=Bt();this.httpQueue.add(async()=>(s.resolve(),i.promise));try{await s.promise;let a=`${this.clientUrl}routing/v1/providers/${t.toString()}`,u=await fetch(a,{headers:{Accept:"application/x-ndjson"},signal:o});if(u.status===404)throw new D("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new D("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new D("Routing response had no body","ERR_BAD_RESPONSE");if(u.headers.get("Content-Type")==="application/json"){let l=await u.json();for(let m of l.Providers){let h=this.#t(m);h!=null&&(yield h)}}else for await(let l of Wo(ca(u.body))){let m=this.#t(l);m!=null&&(yield m)}}catch(a){Wt.error("getProviders errored:",a)}finally{o.clear(),i.resolve(),Wt("getProviders finished: %c",t)}}async*getPeers(t,e={}){Wt("getPeers starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=Mt([this.shutDownController.signal,n,e.signal]);ft(1/0,n,o);let s=Bt(),i=Bt();this.httpQueue.add(async()=>(s.resolve(),i.promise));try{await s.promise;let a=`${this.clientUrl}routing/v1/peers/${t.toCID().toString()}`,u=await fetch(a,{headers:{Accept:"application/x-ndjson"},signal:o});if(u.status===404)throw new D("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new D("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new D("Routing response had no body","ERR_BAD_RESPONSE");if(u.headers.get("Content-Type")==="application/json"){let l=await u.json();for(let m of l.Peers){let h=this.#t(m);h!=null&&(yield h)}}else for await(let l of Wo(ca(u.body))){let m=this.#t(l);m!=null&&(yield m)}}catch(a){Wt.error("getPeers errored:",a)}finally{o.clear(),i.resolve(),Wt("getPeers finished: %c",t)}}async getIPNS(t,e={}){Wt("getIPNS starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=Mt([this.shutDownController.signal,n,e.signal]);ft(1/0,n,o);let s=Bt(),i=Bt();this.httpQueue.add(async()=>(s.resolve(),i.promise));let a=`${this.clientUrl}routing/v1/ipns/${t.toCID().toString()}`;try{await s.promise;let u=await fetch(a,{headers:{Accept:"application/vnd.ipfs.ipns-record"},signal:o});if(Wt("getIPNS GET %s %d",a,u.status),u.status===404)throw new D("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new D("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new D("GET ipns response had no body","ERR_BAD_RESPONSE");let f=await u.arrayBuffer(),l=new Uint8Array(f,0,f.byteLength);return e.validate!==!1&&await b0(zu(t),l),Me(l)}catch(c){throw Wt.error("getIPNS GET %s error:",a,c),c}finally{o.clear(),i.resolve(),Wt("getIPNS finished: %c",t)}}async putIPNS(t,e,n={}){Wt("putIPNS starts: %c",t);let o=AbortSignal.timeout(this.timeout),s=Mt([this.shutDownController.signal,o,n.signal]);ft(1/0,o,s);let i=Bt(),a=Bt();this.httpQueue.add(async()=>(i.resolve(),a.promise));let c=`${this.clientUrl}routing/v1/ipns/${t.toCID().toString()}`;try{await i.promise;let u=Qr(e),l=await fetch(c,{method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:u,signal:s});if(Wt("putIPNS PUT %s %d",c,l.status),l.status!==200)throw new D("PUT ipns response had status other than 200","ERR_BAD_RESPONSE")}catch(u){throw Wt.error("putIPNS PUT %s error:",c,u.stack),u}finally{s.clear(),a.resolve(),Wt("putIPNS finished: %c",t)}}#t(t){let e=[],n=t.Addrs?.map(Jr)??[];return t.Protocols!=null&&e.push(...t.Protocols),t.Protocol!=null&&(e.push(t.Protocol),delete t.Protocol),{...t,Schema:"peer",ID:fc(t.ID),Addrs:n,Protocols:e}}};function A0(r,t={}){return new pa(new URL(r),t)}var B0=q("/ipns/");function k0(r){return it(r.subarray(0,B0.byteLength),B0)}var ju=class{client;constructor(t){this.client=A0(t)}async provide(t,e){}async*findProviders(t,e){yield*sn(this.client.getProviders(t,e),n=>({id:n.ID,multiaddrs:n.Addrs,protocols:n.Protocols}))}async put(t,e,n){if(!k0(t))return;let o=to(t),s=Me(e);await this.client.putIPNS(o,s,n)}async get(t,e){if(!k0(t))throw new D("Not found","ERR_NOT_FOUND");let n=to(t);try{let o=await this.client.getIPNS(n,e);return Qr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new D("Not found","ERR_NOT_FOUND"):o}}async findPeer(t,e){let n=await fa(this.client.getPeers(t,e));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new D("Not found","ERR_NOT_FOUND")}async*getClosestPeers(t,e){}};function Wu(r){return new ju(new URL(r))}var S0=Yt(nn(),1);function ma(r){return r=r??new Error("Not Found"),(0,S0.default)(r,"ERR_NOT_FOUND")}var I0="SHARDING";function Px(r){return r[Symbol.asyncIterator]!=null}function Ox(r,t){return Px(r)?async function*(){yield*(await vu(r)).sort(t)}():function*(){yield*vu(r).sort(t)}()}var ga=Ox;var lr=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 Pr(this.putMany(t,n)),t=[],await Pr(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=ve(n,s=>s.key.toString().startsWith(o))}if(Array.isArray(t.filters)&&(n=t.filters.reduce((o,s)=>ve(o,s),n)),Array.isArray(t.orders)&&(n=t.orders.reduce((o,s)=>ga(o,s),n)),t.offset!=null){let o=0,s=t.offset;n=ve(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=ve(n,s=>s.toString().startsWith(o))}if(Array.isArray(t.filters)&&(n=t.filters.reduce((o,s)=>ve(o,s),n)),Array.isArray(t.orders)&&(n=t.orders.reduce((o,s)=>ga(o,s),n)),t.offset!=null){let o=t.offset,s=0;n=ve(n,()=>s++>=o)}return t.limit!=null&&(n=is(n,t.limit)),n}};var Zo=class extends lr{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 ma();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 Nt(t),value:e}}*_allKeys(){for(let t of this.data.keys())yield new Nt(t)}};var n_=new Nt(I0);var m_=Qt("datastore:core:tiered");async function Mx(r={}){let t=r.datastore??new Zo,e=r.blockstore??new Bo,n=new Zi({...r,datastore:t,blockstore:e,blockBrokers:r.blockBrokers??[$u()],routers:r.routers??[Wu("https://delegated-ipfs.dev")]});return r.start!==!1&&await n.start(),n}return H0($x);})();
7
+ `)}`:`${e} :`}};qd=Nr;O.Constructed=qd;Nr.NAME="CONSTRUCTED";var gi=class extends Mt{fromBER(t,e,n){return e}toBER(t){return Ie}};gi.override="EndOfContentValueBlock";var zd,yi=class extends Ut{constructor(t={}){super(t,gi),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};zd=yi;O.EndOfContent=zd;yi.NAME=Uo;var Gd,Lr=class extends Ut{constructor(t={}){super(t,Mt),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}`}};Gd=Lr;O.Null=Gd;Lr.NAME="NULL";var wi=class extends ur(Mt){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 cr(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,pu.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};wi.NAME="BooleanValueBlock";var jd,bi=class extends Ut{constructor(t={}){super(t,wi),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}`}};jd=bi;O.Boolean=jd;bi.NAME="BOOLEAN";var xi=class extends ur(Fe){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=Fe.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===Uo){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Md)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?Fe.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};xi.NAME="OctetStringValueBlock";var Wd,ir=class r extends Ut{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},xi),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=Wi(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?Nr.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)}};Wd=ir;O.OctetString=Wd;ir.NAME=Md;var Ei=class extends ur(Fe){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=Fe.prototype.fromBER.call(this,t,e,n),o===-1)return o;for(let a of this.value){let c=a.constructor.NAME;if(c===Uo){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==$d)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(!cr(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=Wi(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 Fe.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Ie;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}}};Ei.NAME="BitStringValueBlock";var Yd,Wn=class extends Ut{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},Ei),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 Nr.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)}`}}};Yd=Wn;O.BitString=Yd;Wn.NAME=$d;var Zd;function Nb(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 m=f;m>=0;m--,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=ui(new Uint8Array([u%10]),s);break;default:s[i-l]=u%10}}return e[0]>0&&(s=ui(e,s)),s}function Vd(r){if(r>=No.length)for(let t=No.length;t<=r;t++){let e=new Uint8Array([0]),n=No[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=ui(e,n)),No.push(n)}return No[r]}function Lb(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 Do=class extends ur(Mt){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=pu.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Pd(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=Lb(Vd(n),e),i="-";break;default:e=Nb(e,Vd(n))}n++,o>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Fd.charAt(e[c]));return a===!1&&(i+=Fd.charAt(0)),i}};Zd=Do;Do.NAME="IntegerValueBlock";Object.defineProperty(Zd.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Jd,bt=class r extends Ut{constructor(t={}){super(t,Do),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return li(),BigInt(this.valueBlock.toString())}static fromBigInt(t){li();let e=BigInt(t),n=new Lo,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()}`}};Jd=bt;O.Integer=Jd;bt.NAME="INTEGER";var Xd,vi=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Xd=vi;O.Enumerated=Xd;vi.NAME="ENUMERATED";var Po=class extends ur(Mt){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(!cr(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=Qr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){li();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=Cr(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ie;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}}};Po.NAME="sidBlock";var Ai=class extends Mt{constructor({value:t=Yn,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let o=e;for(;n>0;){let s=new Po;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,Ie;e.push(o)}return mu(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 Po;if(o>Number.MAX_SAFE_INTEGER){li();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}};Ai.NAME="ObjectIdentifierValueBlock";var Qd,Se=class extends Ut{constructor(t={}){super(t,Ai),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()}}};Qd=Se;O.ObjectIdentifier=Qd;Se.NAME="OBJECT IDENTIFIER";var Oo=class extends ur(sr){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(!cr(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=Qr(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=Cr(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ie;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}}};Oo.NAME="relativeSidBlock";var Bi=class extends Mt{constructor({value:t=Yn,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let o=e;for(;n>0;){let s=new Oo;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,Ie;n.push(s)}return mu(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 Oo;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}};Bi.NAME="RelativeObjectIdentifierValueBlock";var tp,ki=class extends Ut{constructor(t={}){super(t,Bi),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()}}};tp=ki;O.RelativeObjectIdentifier=tp;ki.NAME="RelativeObjectIdentifier";var ep,Rt=class extends Nr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};ep=Rt;O.Sequence=ep;Rt.NAME="SEQUENCE";var rp,Si=class extends Nr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};rp=Si;O.Set=rp;Si.NAME="SET";var Ii=class extends ur(Mt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Yn}toJSON(){return{...super.toJSON(),value:this.value}}};Ii.NAME="StringValueBlock";var Ri=class extends Ii{};Ri.NAME="SimpleStringValueBlock";var qt=class extends di{constructor({...t}={}){super(t,Ri)}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}};qt.NAME="SIMPLE STRING";var _i=class extends qt{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}};_i.NAME="Utf8StringValueBlock";var np,ar=class extends _i{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};np=ar;O.Utf8String=np;ar.NAME="UTF8String";var Ti=class extends qt{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))}};Ti.NAME="BmpStringValueBlock";var op,Ci=class extends Ti{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};op=Ci;O.BmpString=op;Ci.NAME="BMPString";var Ni=class extends qt{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=Cr(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}};Ni.NAME="UniversalStringValueBlock";var sp,Li=class extends Ni{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};sp=Li;O.UniversalString=sp;Li.NAME="UniversalString";var ip,Ui=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};ip=Ui;O.NumericString=ip;Ui.NAME="NumericString";var ap,Di=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ap=Di;O.PrintableString=ap;Di.NAME="PrintableString";var cp,Pi=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};cp=Pi;O.TeletexString=cp;Pi.NAME="TeletexString";var up,Oi=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};up=Oi;O.VideotexString=up;Oi.NAME="VideotexString";var lp,Fi=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};lp=Fi;O.IA5String=lp;Fi.NAME="IA5String";var fp,Vi=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};fp=Vi;O.GraphicString=fp;Vi.NAME="GraphicString";var hp,Fo=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};hp=Fo;O.VisibleString=hp;Fo.NAME="VisibleString";var dp,Mi=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};dp=Mi;O.GeneralString=dp;Mi.NAME="GeneralString";var pp,$i=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};pp=$i;O.CharacterString=pp;$i.NAME="CharacterString";var mp,Vo=class extends Fo{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]=Yt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Yt(this.month,2),e[2]=Yt(this.day,2),e[3]=Yt(this.hour,2),e[4]=Yt(this.minute,2),e[5]=Yt(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}}};mp=Vo;O.UTCTime=mp;Vo.NAME="UTCTime";var gp,Hi=class extends Vo{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,m=n.indexOf("+"),h="";if(m===-1&&(m=n.indexOf("-"),l=-1),m!==-1){if(h=n.substring(m+1),n=n.substring(0,m),h.length!==2&&h.length!==4)throw new Error("Wrong input string for conversion");let p=parseInt(h.substring(0,2),10);if(isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*p,h.length===4){if(p=parseInt(h.substring(2,4),10),isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");c=l*p}}}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(Yt(this.year,4)),e.push(Yt(this.month,2)),e.push(Yt(this.day,2)),e.push(Yt(this.hour,2)),e.push(Yt(this.minute,2)),e.push(Yt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Yt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};gp=Hi;O.GeneralizedTime=gp;Hi.NAME="GeneralizedTime";var yp,Ki=class extends ar{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};yp=Ki;O.DATE=yp;Ki.NAME="DATE";var wp,qi=class extends ar{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};wp=qi;O.TimeOfDay=wp;qi.NAME="TimeOfDay";var bp,zi=class extends ar{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};bp=zi;O.DateTime=bp;zi.NAME="DateTime";var xp,Gi=class extends ar{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};xp=Gi;O.Duration=xp;Gi.NAME="Duration";var Ep,ji=class extends ar{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Ep=ji;O.TIME=Ep;ji.NAME="TIME";function Db(r){let{result:t}=Zn(r),e=t.valueBlock.value;return{n:z(Ve(e[1].toBigInt()),"base64url"),e:z(Ve(e[2].toBigInt()),"base64url"),d:z(Ve(e[3].toBigInt()),"base64url"),p:z(Ve(e[4].toBigInt()),"base64url"),q:z(Ve(e[5].toBigInt()),"base64url"),dp:z(Ve(e[6].toBigInt()),"base64url"),dq:z(Ve(e[7].toBigInt()),"base64url"),qi:z(Ve(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Pb(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 D("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new Rt({value:[new bt({value:0}),bt.fromBigInt(Me(q(r.n,"base64url"))),bt.fromBigInt(Me(q(r.e,"base64url"))),bt.fromBigInt(Me(q(r.d,"base64url"))),bt.fromBigInt(Me(q(r.p,"base64url"))),bt.fromBigInt(Me(q(r.q,"base64url"))),bt.fromBigInt(Me(q(r.dp,"base64url"))),bt.fromBigInt(Me(q(r.dq,"base64url"))),bt.fromBigInt(Me(q(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Ob(r){let{result:t}=Zn(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:z(Ve(e[0].toBigInt()),"base64url"),e:z(Ve(e[1].toBigInt()),"base64url")}}function Fb(r){if(r.n==null||r.e==null)throw new D("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new Rt({value:[new Rt({value:[new Se({value:"1.2.840.113549.1.1.1"}),new Lr]}),new Wn({valueHex:new Rt({value:[bt.fromBigInt(Me(q(r.n,"base64url"))),bt.fromBigInt(Me(q(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Ve(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),o=0,s=0;for(;o<e;)n[o]=parseInt(t.slice(s,s+2),16),o+=1,s+=2;return n}function Me(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(""))}var Vb=16,yu=32,wu=1e4;async function Mb(r,t){let e=Kt.get(),o=new Rt({value:[new bt({value:0}),new Rt({value:[new Se({value:"1.2.840.113549.1.1.1"}),new Lr]}),new ir({valueHex:r.marshal()})]}).toBER(),s=new Uint8Array(o,0,o.byteLength),i=Oe(Vb),a=await hu($n,t,i,{c:wu,dkLen:yu}),c=Oe(16),u=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),f=await e.subtle.encrypt({name:"AES-CBC",iv:c},u,s),l=new Rt({value:[new ir({valueHex:i}),new bt({value:wu}),new bt({value:yu}),new Rt({value:[new Se({value:"1.2.840.113549.2.11"}),new Lr]})]}),m=new Rt({value:[new Se({value:"1.2.840.113549.1.5.13"}),new Rt({value:[new Rt({value:[new Se({value:"1.2.840.113549.1.5.12"}),l]}),new Rt({value:[new Se({value:"2.16.840.1.101.3.4.1.42"}),new ir({valueHex:c})]})]})]}),p=new Rt({value:[m,new ir({valueHex:f})]}).toBER(),d=new Uint8Array(p,0,p.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...z(d,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
8
+ `)}async function $b(r,t){let e=Kt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=q(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Zn(o),{iv:i,salt:a,iterations:c,keySize:u,cipherText:f}=Hb(s),l=await hu($n,t,a,{c,dkLen:u}),m=await e.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),h=Mo(await e.subtle.decrypt({name:"AES-CBC",iv:i},m,f)),{result:p}=Zn(h);n=vp(p)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=q(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Zn(o);n=vp(s)}else throw new D("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return bu(n)}function Hb(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new D("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new D("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let s=n.valueBlock.value[1],i=Mo(s.valueBlock.value[0].getValue()),a=wu,c=yu;if(s.valueBlock.value.length===3)a=Number(s.valueBlock.value[1].toBigInt()),c=Number(s.valueBlock.value[2].toBigInt());else if(s.valueBlock.value.length===2)throw new D("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let u=t.valueBlock.value[1].valueBlock.value[1],f=u.valueBlock.value[0].toString();if(f!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(f!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new D("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=Mo(u.valueBlock.value[1].getValue());return{cipherText:Mo(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:l}}function vp(r){return Mo(r.valueBlock.value[2].getValue())}function Mo(r){return new Uint8Array(r,0,r.byteLength)}async function Ap(r){let t=await Kt.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 Sp(t);return{privateKey:e[0],publicKey:e[1]}}async function xu(r){let e=[await Kt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Kb(r)],n=await Sp({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Bp(r,t){let e=await Kt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Kt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function kp(r,t,e){let n=await Kt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Kt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Sp(r){if(r.privateKey==null||r.publicKey==null)throw new D("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Kt.get().subtle.exportKey("jwk",r.privateKey),Kt.get().subtle.exportKey("jwk",r.publicKey)])}async function Kb(r){return Kt.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function Yi(r){if(r.kty!=="RSA")throw new D("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new D("invalid key modulus","ERR_INVALID_KEY_MODULUS");return q(r.n,"base64url").length*8}var Ho=8192,$o=class{_key;constructor(t){this._key=t}verify(t,e){return kp(this._key,e,t)}marshal(){return Ur.jwkToPkix(this._key)}get bytes(){return Pe.encode({Type:gt.RSA,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return pe(t)?t.then(({bytes:e})=>e):t.bytes}},Jn=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return Oe(16)}sign(t){return Bp(this._key,t)}get public(){if(this._publicKey==null)throw new D("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new $o(this._publicKey)}marshal(){return Ur.jwkToPkcs1(this._key)}get bytes(){return nr.encode({Type:gt.RSA,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return pe(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return z(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Ur.exportToPem(this,t);if(e==="libp2p-key")return zn(this.bytes,t);throw new D(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function bu(r){let t=Ur.pkcs1ToJwk(r);if(Yi(t)>Ho)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await xu(t);return new Jn(e.privateKey,e.publicKey)}function zb(r){let t=Ur.pkixToJwk(r);if(Yi(t)>Ho)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new $o(t)}async function Gb(r){if(Yi(r)>Ho)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await xu(r);return new Jn(t.privateKey,t.publicKey)}async function jb(r){if(r>Ho)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Ap(r);return new Jn(t.privateKey,t.publicKey)}var Su={};vt(Su,{Secp256k1PrivateKey:()=>qo,Secp256k1PublicKey:()=>Ko,generateKeyPair:()=>ix,unmarshalSecp256k1PrivateKey:()=>ox,unmarshalSecp256k1PublicKey:()=>sx});var Wb=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]),Dr=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Pr=new Uint32Array(64),vu=class extends Mn{constructor(){super(64,32,8,!1),this.A=Dr[0]|0,this.B=Dr[1]|0,this.C=Dr[2]|0,this.D=Dr[3]|0,this.E=Dr[4]|0,this.F=Dr[5]|0,this.G=Dr[6]|0,this.H=Dr[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)Pr[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let m=Pr[l-15],h=Pr[l-2],p=Be(m,7)^Be(m,18)^m>>>3,d=Be(h,17)^Be(h,19)^h>>>10;Pr[l]=d+Pr[l-7]+p+Pr[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 m=Be(a,6)^Be(a,11)^Be(a,25),h=f+m+fd(a,c,u)+Wb[l]+Pr[l]|0,d=(Be(n,2)^Be(n,13)^Be(n,22))+hd(n,o,s)|0;f=u,u=c,c=a,a=i+h|0,i=s,s=o,o=n,n=h+d|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(){Pr.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Ip=Ys(()=>new vu);function Yb(r){let t=_o(r);De(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("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("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Zb,hexToBytes:Jb}=Xs,tn={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=tn;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:Zb(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=tn,e=typeof r=="string"?Jb(r):r;Hn(e);let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:o,l:s}=tn._parseInt(e.subarray(2)),{d:i,l:a}=tn._parseInt(s);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:o,s:i}},hexFromSig(r){let t=u=>Number.parseInt(u[0],16)&8?"00"+u:u,e=u=>{let f=u.toString(16);return f.length&1?`0${f}`:f},n=t(e(r.s)),o=t(e(r.r)),s=n.length/2,i=o.length/2,a=e(s),c=e(i);return`30${e(i+s+4)}02${c}${o}02${a}${n}`}},lr=BigInt(0),ge=BigInt(1),OS=BigInt(2),Rp=BigInt(3),FS=BigInt(4);function Xb(r){let t=Yb(r),{Fp:e}=t,n=t.toBytes||((p,d,w)=>{let g=d.toAffine();return tr(Uint8Array.from([4]),e.toBytes(g.x),e.toBytes(g.y))}),o=t.fromBytes||(p=>{let d=p.subarray(1),w=e.fromBytes(d.subarray(0,e.BYTES)),g=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:w,y:g}});function s(p){let{a:d,b:w}=t,g=e.sqr(p),x=e.mul(g,p);return e.add(e.add(x,e.mul(p,d)),w)}if(!e.eql(e.sqr(t.Gy),s(t.Gx)))throw new Error("bad generator point: equation left != right");function i(p){return typeof p=="bigint"&&lr<p&&p<t.n}function a(p){if(!i(p))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(p){let{allowedPrivateKeyLengths:d,nByteLength:w,wrapPrivateKey:g,n:x}=t;if(d&&typeof p!="bigint"){if(Rr(p)&&(p=Xe(p)),typeof p!="string"||!d.includes(p.length))throw new Error("Invalid key");p=p.padStart(w*2,"0")}let b;try{b=typeof p=="bigint"?p:Qe(mt("private key",p,w))}catch{throw new Error(`private key must be ${w} bytes, hex or bigint, not ${typeof p}`)}return g&&(b=at(b,x)),a(b),b}let u=new Map;function f(p){if(!(p instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(d,w,g){if(this.px=d,this.py=w,this.pz=g,d==null||!e.isValid(d))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(g==null||!e.isValid(g))throw new Error("z required")}static fromAffine(d){let{x:w,y:g}=d||{};if(!d||!e.isValid(w)||!e.isValid(g))throw new Error("invalid affine point");if(d instanceof l)throw new Error("projective point not allowed");let x=b=>e.eql(b,e.ZERO);return x(w)&&x(g)?l.ZERO:new l(w,g,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let w=e.invertBatch(d.map(g=>g.pz));return d.map((g,x)=>g.toAffine(w[x])).map(l.fromAffine)}static fromHex(d){let w=l.fromAffine(o(mt("pointHex",d)));return w.assertValidity(),w}static fromPrivateKey(d){return l.BASE.multiply(c(d))}_setWindowSize(d){this._WINDOW_SIZE=d,u.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:d,y:w}=this.toAffine();if(!e.isValid(d)||!e.isValid(w))throw new Error("bad point: x or y not FE");let g=e.sqr(w),x=s(d);if(!e.eql(g,x))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:w,py:g,pz:x}=this,{px:b,py:B,pz:A}=d,I=e.eql(e.mul(w,A),e.mul(b,x)),v=e.eql(e.mul(g,A),e.mul(B,x));return I&&v}negate(){return new l(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:w}=t,g=e.mul(w,Rp),{px:x,py:b,pz:B}=this,A=e.ZERO,I=e.ZERO,v=e.ZERO,E=e.mul(x,x),U=e.mul(b,b),P=e.mul(B,B),N=e.mul(x,b);return N=e.add(N,N),v=e.mul(x,B),v=e.add(v,v),A=e.mul(d,v),I=e.mul(g,P),I=e.add(A,I),A=e.sub(U,I),I=e.add(U,I),I=e.mul(A,I),A=e.mul(N,A),v=e.mul(g,v),P=e.mul(d,P),N=e.sub(E,P),N=e.mul(d,N),N=e.add(N,v),v=e.add(E,E),E=e.add(v,E),E=e.add(E,P),E=e.mul(E,N),I=e.add(I,E),P=e.mul(b,B),P=e.add(P,P),E=e.mul(P,N),A=e.sub(A,E),v=e.mul(P,U),v=e.add(v,v),v=e.add(v,v),new l(A,I,v)}add(d){f(d);let{px:w,py:g,pz:x}=this,{px:b,py:B,pz:A}=d,I=e.ZERO,v=e.ZERO,E=e.ZERO,U=t.a,P=e.mul(t.b,Rp),N=e.mul(w,b),M=e.mul(g,B),C=e.mul(x,A),X=e.add(w,g),S=e.add(b,B);X=e.mul(X,S),S=e.add(N,M),X=e.sub(X,S),S=e.add(w,x);let T=e.add(b,A);return S=e.mul(S,T),T=e.add(N,C),S=e.sub(S,T),T=e.add(g,x),I=e.add(B,A),T=e.mul(T,I),I=e.add(M,C),T=e.sub(T,I),E=e.mul(U,S),I=e.mul(P,C),E=e.add(I,E),I=e.sub(M,E),E=e.add(M,E),v=e.mul(I,E),M=e.add(N,N),M=e.add(M,N),C=e.mul(U,C),S=e.mul(P,S),M=e.add(M,C),C=e.sub(N,C),C=e.mul(U,C),S=e.add(S,C),N=e.mul(M,S),v=e.add(v,N),N=e.mul(T,S),I=e.mul(X,I),I=e.sub(I,N),N=e.mul(X,M),E=e.mul(T,E),E=e.add(E,N),new l(I,v,E)}subtract(d){return this.add(d.negate())}is0(){return this.equals(l.ZERO)}wNAF(d){return h.wNAFCached(this,u,d,w=>{let g=e.invertBatch(w.map(x=>x.pz));return w.map((x,b)=>x.toAffine(g[b])).map(l.fromAffine)})}multiplyUnsafe(d){let w=l.ZERO;if(d===lr)return w;if(a(d),d===ge)return this;let{endo:g}=t;if(!g)return h.unsafeLadder(this,d);let{k1neg:x,k1:b,k2neg:B,k2:A}=g.splitScalar(d),I=w,v=w,E=this;for(;b>lr||A>lr;)b&ge&&(I=I.add(E)),A&ge&&(v=v.add(E)),E=E.double(),b>>=ge,A>>=ge;return x&&(I=I.negate()),B&&(v=v.negate()),v=new l(e.mul(v.px,g.beta),v.py,v.pz),I.add(v)}multiply(d){a(d);let w=d,g,x,{endo:b}=t;if(b){let{k1neg:B,k1:A,k2neg:I,k2:v}=b.splitScalar(w),{p:E,f:U}=this.wNAF(A),{p:P,f:N}=this.wNAF(v);E=h.constTimeNegate(B,E),P=h.constTimeNegate(I,P),P=new l(e.mul(P.px,b.beta),P.py,P.pz),g=E.add(P),x=U.add(N)}else{let{p:B,f:A}=this.wNAF(w);g=B,x=A}return l.normalizeZ([g,x])[0]}multiplyAndAddUnsafe(d,w,g){let x=l.BASE,b=(A,I)=>I===lr||I===ge||!A.equals(x)?A.multiplyUnsafe(I):A.multiply(I),B=b(this,w).add(b(d,g));return B.is0()?void 0:B}toAffine(d){let{px:w,py:g,pz:x}=this,b=this.is0();d==null&&(d=b?e.ONE:e.inv(x));let B=e.mul(w,d),A=e.mul(g,d),I=e.mul(x,d);if(b)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:B,y:A}}isTorsionFree(){let{h:d,isTorsionFree:w}=t;if(d===ge)return!0;if(w)return w(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:w}=t;return d===ge?this:w?w(l,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return this.assertValidity(),n(l,this,d)}toHex(d=!0){return Xe(this.toRawBytes(d))}}l.BASE=new l(t.Gx,t.Gy,e.ONE),l.ZERO=new l(e.ZERO,e.ONE,e.ZERO);let m=t.nBitLength,h=ei(l,t.endo?Math.ceil(m/2):m);return{CURVE:t,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:s,isWithinCurveOrder:i}}function Qb(r){let t=_o(r);return De(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function _p(r){let t=Qb(r),{Fp:e,n}=t,o=e.BYTES+1,s=2*e.BYTES+1;function i(S){return lr<S&&S<e.ORDER}function a(S){return at(S,n)}function c(S){return Qs(S,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:m}=Xb({...t,toBytes(S,T,H){let _=T.toAffine(),k=e.toBytes(_.x),F=tr;return H?F(Uint8Array.from([T.hasEvenY()?2:3]),k):F(Uint8Array.from([4]),k,e.toBytes(_.y))},fromBytes(S){let T=S.length,H=S[0],_=S.subarray(1);if(T===o&&(H===2||H===3)){let k=Qe(_);if(!i(k))throw new Error("Point is not on curve");let F=l(k),$;try{$=e.sqrt(F)}catch(Y){let rt=Y instanceof Error?": "+Y.message:"";throw new Error("Point is not on curve"+rt)}let K=($&ge)===ge;return(H&1)===1!==K&&($=e.neg($)),{x:k,y:$}}else if(T===s&&H===4){let k=e.fromBytes(_.subarray(0,e.BYTES)),F=e.fromBytes(_.subarray(e.BYTES,2*e.BYTES));return{x:k,y:F}}else throw new Error(`Point of length ${T} was invalid. Expected ${o} compressed bytes or ${s} uncompressed bytes`)}}),h=S=>Xe(Tr(S,t.nByteLength));function p(S){let T=n>>ge;return S>T}function d(S){return p(S)?a(-S):S}let w=(S,T,H)=>Qe(S.slice(T,H));class g{constructor(T,H,_){this.r=T,this.s=H,this.recovery=_,this.assertValidity()}static fromCompact(T){let H=t.nByteLength;return T=mt("compactSignature",T,H*2),new g(w(T,0,H),w(T,H,2*H))}static fromDER(T){let{r:H,s:_}=tn.toSig(mt("DER",T));return new g(H,_)}assertValidity(){if(!m(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!m(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(T){return new g(this.r,this.s,T)}recoverPublicKey(T){let{r:H,s:_,recovery:k}=this,F=v(mt("msgHash",T));if(k==null||![0,1,2,3].includes(k))throw new Error("recovery id invalid");let $=k===2||k===3?H+t.n:H;if($>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let K=k&1?"03":"02",W=u.fromHex(K+h($)),Y=c($),rt=a(-F*Y),J=a(_*Y),Q=u.BASE.multiplyAndAddUnsafe(W,rt,J);if(!Q)throw new Error("point at infinify");return Q.assertValidity(),Q}hasHighS(){return p(this.s)}normalizeS(){return this.hasHighS()?new g(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Yr(this.toDERHex())}toDERHex(){return tn.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Yr(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let x={isValidPrivateKey(S){try{return f(S),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let S=ou(t.n);return Ad(t.randomBytes(S),t.n)},precompute(S=8,T=u.BASE){return T._setWindowSize(S),T.multiply(BigInt(3)),T}};function b(S,T=!0){return u.fromPrivateKey(S).toRawBytes(T)}function B(S){let T=Rr(S),H=typeof S=="string",_=(T||H)&&S.length;return T?_===o||_===s:H?_===2*o||_===2*s:S instanceof u}function A(S,T,H=!0){if(B(S))throw new Error("first arg must be private key");if(!B(T))throw new Error("second arg must be public key");return u.fromHex(T).multiply(f(S)).toRawBytes(H)}let I=t.bits2int||function(S){let T=Qe(S),H=S.length*8-t.nBitLength;return H>0?T>>BigInt(H):T},v=t.bits2int_modN||function(S){return a(I(S))},E=Ro(t.nBitLength);function U(S){if(typeof S!="bigint")throw new Error("bigint expected");if(!(lr<=S&&S<E))throw new Error(`bigint expected < 2^${t.nBitLength}`);return Tr(S,t.nByteLength)}function P(S,T,H=N){if(["recovered","canonical"].some(dt=>dt in H))throw new Error("sign() legacy options not supported");let{hash:_,randomBytes:k}=t,{lowS:F,prehash:$,extraEntropy:K}=H;F==null&&(F=!0),S=mt("msgHash",S),$&&(S=mt("prehashed msgHash",_(S)));let W=v(S),Y=f(T),rt=[U(Y),U(W)];if(K!=null&&K!==!1){let dt=K===!0?k(e.BYTES):K;rt.push(mt("extraEntropy",dt))}let J=tr(...rt),Q=W;function wt(dt){let _t=I(dt);if(!m(_t))return;let Tt=c(_t),Et=u.BASE.multiply(_t).toAffine(),Pt=a(Et.x);if(Pt===lr)return;let Ke=a(Tt*a(Q+Pt*Y));if(Ke===lr)return;let Fr=(Et.x===Pt?0:2)|Number(Et.y&ge),no=Ke;return F&&p(Ke)&&(no=d(Ke),Fr^=1),new g(Pt,no,Fr)}return{seed:J,k2sig:wt}}let N={lowS:t.lowS,prehash:!1},M={lowS:t.lowS,prehash:!1};function C(S,T,H=N){let{seed:_,k2sig:k}=P(S,T,H),F=t;return tu(F.hash.outputLen,F.nByteLength,F.hmac)(_,k)}u.BASE._setWindowSize(8);function X(S,T,H,_=M){let k=S;if(T=mt("msgHash",T),H=mt("publicKey",H),"strict"in _)throw new Error("options.strict was renamed to lowS");let{lowS:F,prehash:$}=_,K,W;try{if(typeof k=="string"||Rr(k))try{K=g.fromDER(k)}catch(Et){if(!(Et instanceof tn.Err))throw Et;K=g.fromCompact(k)}else if(typeof k=="object"&&typeof k.r=="bigint"&&typeof k.s=="bigint"){let{r:Et,s:Pt}=k;K=new g(Et,Pt)}else throw new Error("PARSE");W=u.fromHex(H)}catch(Et){if(Et.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(F&&K.hasHighS())return!1;$&&(T=t.hash(T));let{r:Y,s:rt}=K,J=v(T),Q=c(rt),wt=a(J*Q),dt=a(Y*Q),_t=u.BASE.multiplyAndAddUnsafe(W,wt,dt)?.toAffine();return _t?a(_t.x)===Y:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:A,sign:C,verify:X,ProjectivePoint:u,Signature:g,utils:x}}function tx(r){return{hash:r,hmac:(t,...e)=>Co(r,t,Ws(...e)),randomBytes:Vn}}function Tp(r,t){let e=n=>_p({...r,...tx(n)});return Object.freeze({...e(t),create:e})}var Lp=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Cp=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),ex=BigInt(1),Au=BigInt(2),Np=(r,t)=>(r+t/Au)/t;function rx(r){let t=Lp,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=lt(f,e,t)*f%t,m=lt(l,e,t)*f%t,h=lt(m,Au,t)*u%t,p=lt(h,o,t)*h%t,d=lt(p,s,t)*p%t,w=lt(d,a,t)*d%t,g=lt(w,c,t)*w%t,x=lt(g,a,t)*d%t,b=lt(x,e,t)*f%t,B=lt(b,i,t)*p%t,A=lt(B,n,t)*u%t,I=lt(A,Au,t);if(!Bu.eql(Bu.sqr(I),r))throw new Error("Cannot find square root");return I}var Bu=ti(Lp,void 0,void 0,{sqrt:rx}),Re=Tp({a:BigInt(0),b:BigInt(7),Fp:Bu,n:Cp,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Cp,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-ex*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=Np(s*r,t),c=Np(-n*r,t),u=at(r-a*e-c*o,t),f=at(-a*n-c*s,t),l=u>i,m=f>i;if(l&&(u=t-u),m&&(f=t-f),u>i||f>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:u,k2neg:m,k2:f}}}},Ip),jS=BigInt(0);var WS=Re.ProjectivePoint;function Up(){return Re.utils.randomPrivateKey()}function Dp(r,t){let e=At.digest(t instanceof Uint8Array?t:t.subarray());if(pe(e))return e.then(({digest:n})=>Re.sign(n,r).toDERRawBytes()).catch(n=>{throw new D(String(n),"ERR_INVALID_INPUT")});try{return Re.sign(e.digest,r).toDERRawBytes()}catch(n){throw new D(String(n),"ERR_INVALID_INPUT")}}function Pp(r,t,e){let n=At.digest(e instanceof Uint8Array?e:e.subarray());if(pe(n))return n.then(({digest:o})=>Re.verify(t,o,r)).catch(o=>{throw new D(String(o),"ERR_INVALID_INPUT")});try{return Re.verify(t,n.digest,r)}catch(o){throw new D(String(o),"ERR_INVALID_INPUT")}}function Op(r){return Re.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Fp(r){try{Re.getPublicKey(r,!0)}catch(t){throw new D(String(t),"ERR_INVALID_PRIVATE_KEY")}}function ku(r){try{Re.ProjectivePoint.fromHex(r)}catch(t){throw new D(String(t),"ERR_INVALID_PUBLIC_KEY")}}function Vp(r){try{return Re.getPublicKey(r,!0)}catch(t){throw new D(String(t),"ERR_INVALID_PRIVATE_KEY")}}var Ko=class{_key;constructor(t){ku(t),this._key=t}verify(t,e){return Pp(this._key,e,t)}marshal(){return Op(this._key)}get bytes(){return Pe.encode({Type:gt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return pe(t)?{bytes:e}=await t:e=t.bytes,e}},qo=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??Vp(t),Fp(this._key),ku(this._publicKey)}sign(t){return Dp(this._key,t)}get public(){return new Ko(this._publicKey)}marshal(){return this._key}get bytes(){return nr.encode({Type:gt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return pe(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return z(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return zn(this.bytes,t);throw new D(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function ox(r){return new qo(r)}function sx(r){return new Ko(r)}async function ix(){let r=Up();return new qo(r)}var Zi={rsa:Eu,ed25519:fu,secp256k1:Su};function ax(r){let t=Object.keys(Zi).join(" / ");return new D(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function Iu(r){let t=Pe.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case gt.RSA:return Zi.rsa.unmarshalRsaPublicKey(e);case gt.Ed25519:return Zi.ed25519.unmarshalEd25519PublicKey(e);case gt.Secp256k1:return Zi.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw ax(t.Type??"unknown")}}var Ru=Jt(Hp(),1);var cx=Math.LN2*Math.LN2,Xi=class r{static create(t,e=.005){let n=ux(t,e);return new r(n)}seeds;bits;buffer;constructor(t={}){t.seeds!=null?this.seeds=t.seeds:this.seeds=lx(t.hashes??8),this.bits=t.bits??1024,this.buffer=we(Math.ceil(this.bits/8))}add(t){typeof t=="string"&&(t=q(t));for(let e=0;e<this.seeds.length;e++){let o=Ru.default.x86.hash32(t,this.seeds[e])%this.bits;this.setbit(o)}}has(t){typeof t=="string"&&(t=q(t));for(let e=0;e<this.seeds.length;e++){let o=Ru.default.x86.hash32(t,this.seeds[e])%this.bits;if(!this.getbit(o))return!1}return!0}clear(){this.buffer.fill(0)}setbit(t){let e=0,n=t;for(;n>7;)e++,n-=8;let o=this.buffer[e];o|=1<<n,this.buffer[e]=o}getbit(t){let e=0,n=t;for(;n>7;)e++,n-=8;return(this.buffer[e]&1<<n)!==0}};function ux(r,t=.005){let e=Math.round(-1*r*Math.log(t)/cx),n=Math.round(e/r*Math.LN2);return{bits:e,hashes:n}}function lx(r){let t,e,n=[];for(let o=0;o<r;o++)for(t=new cs(Oe(4)),n[o]=t.getUint32(0,!0),e=0;e<o;e++)if(n[o]===n[e]){o--;break}return n}var Go=class extends rn{intialPeerSearchComplete;requests;name;log;logger;minProviders;maxProviders;providers;evictionFilter;constructor(t,e){super(),ft(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=Xi.create(this.maxProviders)}async retrieve(t,e={}){let n=le.encode(t.multihash.bytes),o=this.requests.get(n);if(o!=null)return this.log("join existing request for %c",t),o;let s=kt();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 qe({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.providers.some(e=>this.equals(e,t))}hasProvider(t){return!!(this.providers.find(e=>this.equals(e,t))!=null||this.isEvicted(t))}async findProviders(t,e,n){let o=kt(),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 D(`Found ${s} of ${e} ${this.name} providers for ${t}`,"ERR_INSUFFICIENT_PROVIDERS_FOUND")}).catch(i=>{this.log.error("error searching routing for potential session peers for %c",t,i.errors??i),o.reject(i)}),o.promise}};var Qi=class{blockstore;datastore;pins;logger;routing;dagWalkers;hashers;dns;metrics;log;constructor(t){this.logger=t.logger??mf(),this.log=this.logger.forComponent("helia"),this.hashers=td(t.hashers),this.dagWalkers=Jh(t.dagWalkers),this.dns=t.dns??kf(),this.metrics=t.metrics;let e={blockstore:t.blockstore,datastore:t.datastore,hashers:this.hashers,dagWalkers:this.dagWalkers,logger:this.logger,blockBrokers:[],dns:this.dns,metrics:this.metrics,...t.components??{}};this.routing=e.routing=new Fs(e,{routers:(t.routers??[]).flatMap(o=>{let s=[o];return o[oo]!=null&&s.push(o[oo]),o[io]!=null&&s.push(o[io]),s}),providerLookupConcurrency:t.providerLookupConcurrency});let n=new zs(e);this.pins=new Os(t.datastore,n,this.dagWalkers),this.blockstore=new Vs(n,this.pins,{holdGcLock:t.holdGcLock??!0}),this.datastore=t.datastore,e.blockBrokers=t.blockBrokers.map(o=>o(e))}async start(){await Qh(this.datastore),await mr(this.blockstore,this.datastore,this.routing)}async stop(){await gr(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 Mr(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 nt("helia:gc:deleted",s))}catch(i){n.log.error("Error during gc",i),t.onProgress?.(new nt("helia:gc:error",i))}}()))}finally{e()}this.log("gc finished")}};var ta=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 m=Number.parseInt(l,t);if(!Number.isNaN(m))return m});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 Kp=45,fx=15,Xn=new ta;function _u(r){if(!(r.length>fx))return Xn.new(r).parseWith(()=>Xn.readIPv4Addr())}function Tu(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Kp))return Xn.new(r).parseWith(()=>Xn.readIPv6Addr())}function ea(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Kp))return Xn.new(r).parseWith(()=>Xn.readIPAddr())}function Qn(r){return!!_u(r)}function to(r){return!!Tu(r)}function ra(r){return!!ea(r)}var zp=Jt(qp(),1),hx=["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"],dx=hx.map(r=>new zp.Netmask(r));function px(r){for(let t of dx)if(t.contains(r))return!0;return!1}function mx(r){return/^::$/.test(r)||/^::1$/.test(r)||/^::f{4}:([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)||/^::f{4}:0.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.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 Gp(r){return Qn(r)?px(r):to(r)?mx(r):void 0}var JI=parseInt("0xFFFF",16),XI=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Yp=Qn,xx=to,Cu=function(r){let t=0;if(r=r.toString().trim(),Yp(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(xx(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=Yp(e[n]),i;s&&(i=Cu(e[n]),e[n]=z(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,z(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")},Zp=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 eo={},Nu={},vx=[[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"],[777,-1,"memory"]];vx.forEach(r=>{let t=Ax(...r);Nu[t.code]=t,eo[t.name]=t});function Ax(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function j(r){if(typeof r=="number"){if(Nu[r]!=null)return Nu[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(eo[r]!=null)return eo[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var L6=j("ip4"),U6=j("ip6"),D6=j("ipcidr");function Uu(r,t){switch(j(r).code){case 4:case 41:return kx(t);case 42:return Qp(t);case 6:case 273:case 33:case 132:return e0(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Qp(t);case 421:return _x(t);case 444:return t0(t);case 445:return t0(t);case 466:return Rx(t);default:return z(t,"base16")}}function Du(r,t){switch(j(r).code){case 4:return Jp(t);case 41:return Jp(t);case 42:return Xp(t);case 6:case 273:case 33:case 132:return Pu(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Xp(t);case 421:return Sx(t);case 444:return Tx(t);case 445:return Cx(t);case 466:return Ix(t);default:return q(t,"base16")}}var Lu=Object.values(xr).map(r=>r.decoder),Bx=function(){let r=Lu[0].or(Lu[1]);return Lu.slice(2).forEach(t=>r=r.or(t)),r}();function Jp(r){if(!ra(r))throw new Error("invalid ip address");return Cu(r)}function kx(r){let t=Zp(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!ra(t))throw new Error("invalid ip address");return t}function Pu(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function e0(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Xp(r){let t=q(r),e=Uint8Array.from(on(t.length));return St([e,t],e.length+t.length)}function Qp(r){let t=$r(r);if(r=r.slice(jt(t)),r.length!==t)throw new Error("inconsistent lengths");return z(r)}function Sx(r){let t;r[0]==="Q"||r[0]==="1"?t=Ne(ht.decode(`z${r}`)).bytes:t=tt.parse(r).multihash.bytes;let e=Uint8Array.from(on(t.length));return St([e,t],e.length+t.length)}function Ix(r){let t=Bx.decode(r),e=Uint8Array.from(on(t.length));return St([e,t],e.length+t.length)}function Rx(r){let t=$r(r),e=r.slice(jt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+z(e,"base64url")}function _x(r){let t=$r(r),e=r.slice(jt(t));if(e.length!==t)throw new Error("inconsistent lengths");return z(e,"base58btc")}function Tx(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=Ct.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=Pu(n);return St([e,o],e.length+o.length)}function Cx(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=Ct.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=Pu(n);return St([e,o],e.length+o.length)}function t0(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=z(t,"base32"),o=e0(e);return`${n}:${o}`}function r0(r){r=Ou(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=j(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw o0("invalid address: "+r);if(a.path===!0){n=Ou(o.slice(s).join("/")),t.push([a.code,Du(a.code,n)]),e.push([a.code,n]);break}let c=Du(a.code,o[s]);t.push([a.code,c]),e.push([a.code,Uu(a.code,c)])}return{string:n0(e),bytes:Vu(t),tuples:t,stringTuples:e,path:n}}function Fu(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=$r(r,o),i=jt(s),a=j(s),c=Nx(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 o0("Invalid address Uint8Array: "+z(r,"base16"));t.push([s,u]);let f=Uu(s,u);if(e.push([s,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(r),string:n0(e),tuples:t,stringTuples:e,path:n}}function n0(r){let t=[];return r.map(e=>{let n=j(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Ou(t.join("/"))}function Vu(r){return St(r.map(t=>{let e=j(t[0]),n=Uint8Array.from(on(e.code));return t.length>1&&t[1]!=null&&(n=St([n,t[1]])),n}))}function Nx(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=$r(t instanceof Uint8Array?t:Uint8Array.from(t));return e+jt(e)}}function Ou(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function o0(r){return new Error("Error parsing address: "+r)}var Lx=Symbol.for("nodejs.util.inspect.custom"),Mu=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Ux=[j("dns").code,j("dns4").code,j("dns6").code,j("dnsaddr").code],na=class r{bytes;#t;#e;#r;#o;[Mu]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Fu(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=r0(t)}else if(i0(t))e=Fu(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=j("tcp"),a=j("udp"),c=j("ip4"),u=j("ip6"),f=j("dns6"),l=j("ip6zone");for(let[h,p]of this.stringTuples())h===l.code&&(s=`%${p??""}`),Ux.includes(h)&&(e=i.name,o=443,n=`${p??""}${s}`,t=h===f.code?6:4),(h===i.code||h===a.code)&&(e=j(h).name,o=parseInt(p??"")),(h===c.code||h===u.code)&&(e=j(h).name,n=`${p??""}${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({},j(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>j(t).name)}tuples(){return this.#e}stringTuples(){return this.#r}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),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(Vu(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===eo.p2p.code&&t.push([n,o]),n===eo["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?z(ht.decode(`z${n}`),"base58btc"):z(tt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#o}equals(t){return it(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=s0.get(e.name);if(n==null)throw new D(`no available resolver for ${e.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,t)).map(s=>fr(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)}[Lx](){return`Multiaddr(${this.#t})`}};var s0=new Map;function i0(r){return!!r?.[Mu]}function fr(r){return new na(r)}var Dx=r=>r.toString().split("/").slice(1),Wo=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),ot=r=>({match:t=>Wo(e=>e===r).match(t),pattern:r}),ia=()=>({match:r=>Wo(t=>typeof t=="string").match(r),pattern:"{string}"}),aa=()=>({match:r=>Wo(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),Dt=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{ht.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),oa=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Ja.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),zt=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),ae=(...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(", ")})`}),ct=(...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 yt(...r){function t(o){let s=Dx(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{matches:e,exactMatch:n}}var Hu=ct(ot("dns4"),ia()),Ku=ct(ot("dns6"),ia()),qu=ct(ot("dnsaddr"),ia()),a0=ct(ot("dns"),ia()),l4=yt(Hu),f4=yt(Ku),h4=yt(qu),c0=yt(ae(a0,qu,Hu,Ku)),u0=ct(ot("ip4"),Wo(Qn)),l0=ct(ot("ip6"),Wo(to)),f0=ae(u0,l0),$e=ae(f0,a0,Hu,Ku,qu),d4=yt($e),p4=yt(u0),m4=yt(l0),g4=yt(f0),ca=ct($e,ot("tcp"),aa()),Yo=ct($e,ot("udp"),aa()),Px=ae(ca,Yo),y4=yt(ca),w4=yt(Yo),zu=ct(Yo,ot("quic")),ua=ct(Yo,ot("quic-v1")),Ox=ae(zu,ua),b4=yt(zu),x4=yt(ua),$u=ae($e,ca,Yo,zu,ua),h0=ae(ct($u,ot("ws"),zt(Dt()))),E4=yt(h0),d0=ae(ct($u,ot("wss"),zt(Dt())),ct($u,ot("tls"),ot("ws"),zt(Dt()))),v4=yt(d0),p0=ct(Px,ot("webrtc-direct"),oa(),zt(oa()),zt(Dt())),A4=yt(p0),m0=ct(ua,ot("webtransport"),oa(),oa(),zt(Dt())),B4=yt(m0),sa=ae(h0,d0,ct(ca,zt(Dt())),ct(Ox,zt(Dt())),ct($e,zt(Dt())),p0,m0,Dt()),k4=yt(sa),Fx=ct(sa,ot("p2p-circuit"),Dt()),S4=yt(Fx),Vx=ae(ct(sa,ot("p2p-circuit"),ot("webrtc"),Dt()),ct(sa,ot("webrtc"),zt(Dt())),ot("webrtc")),I4=yt(Vx),Mx=ae(ct($e,ot("tcp"),aa(),ot("http"),zt(Dt())),ct($e,ot("http"),zt(Dt()))),g0=yt(Mx),$x=ae(ct($e,ot("tcp"),ae(ct(ot("443"),ot("http")),ct(aa(),ot("https"))),zt(Dt())),ct($e,ot("tls"),ot("http"),zt(Dt())),ct($e,ot("https"),zt(Dt()))),y0=yt($x);var Hx=[j("tcp").code,j("dns").code,j("dnsaddr").code,j("dns4").code,j("dns6").code];function w0(r){let t;try{t=j("sni").code}catch{return null}for(let[e,n]of r)if(e===t&&n!==void 0)return n;return null}function b0(r){return r.some(([t,e])=>t===j("tls").code)}function ce(r,t,e){let n=x0[j(r).name];if(n===void 0)throw new Error(`Can't interpret protocol ${j(r).name}`);let o=n(t,e);return r===j("ip6").code?`[${o}]`:o}var x0={ip4:(r,t)=>r,ip6:(r,t)=>t.length===0?r:`[${r}]`,tcp:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`tcp://${ce(e[0],e[1]??"",t)}:${r}`},udp:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`udp://${ce(e[0],e[1]??"",t)}:${r}`},dnsaddr:(r,t)=>r,dns4:(r,t)=>r,dns6:(r,t)=>r,dns:(r,t)=>r,ipfs:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${ce(e[0],e[1]??"",t)}/ipfs/${r}`},p2p:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${ce(e[0],e[1]??"",t)}/p2p/${r}`},http:(r,t)=>{let e=b0(t),n=w0(t);if(e&&n!==null)return`https://${n}`;let o=e?"https://":"http://",s=t.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let i=ce(s[0],s[1]??"",t);return i=i.replace("tcp://",""),`${o}${i}`},tls:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return ce(e[0],e[1]??"",t)},sni:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return ce(e[0],e[1]??"",t)},https:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");let n=ce(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`https://${n}`},ws:(r,t)=>{let e=b0(t),n=w0(t);if(e&&n!==null)return`wss://${n}`;let o=e?"wss://":"ws://",s=t.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let i=ce(s[0],s[1]??"",t);return i=i.replace("tcp://",""),`${o}${i}`},wss:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");let n=ce(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`wss://${n}`},"p2p-websocket-star":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${ce(e[0],e[1]??"",t)}/p2p-websocket-star`},"p2p-webrtc-star":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${ce(e[0],e[1]??"",t)}/p2p-webrtc-star`},"p2p-webrtc-direct":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${ce(e[0],e[1]??"",t)}/p2p-webrtc-direct`}};function E0(r,t){let n=fr(r).stringTuples(),o=n.pop();if(o===void 0)throw new Error("Unexpected end of multiaddr");let s=j(o[0]),i=x0[s.name];if(i==null)throw new Error(`No interpreter found for ${s.name}`);let a=i(o[1]??"",n);return t?.assumeHttp!==!1&&Hx.includes(o[0])&&(a=a.replace(/^.*:\/\//,""),o[1]==="443"?a=`https://${a}`:a=`http://${a}`),(a.startsWith("http://")||a.startsWith("https://"))&&(a=new URL(a).toString(),a.endsWith("/")&&(a=a.substring(0,a.length-1))),a}var la=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 le.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 Kx(r,t,e){return r.filter(n=>y0.matches(n)||t&&g0.matches(n)?e||c0.matches(n)?!0:Gp(n.toOptions().host)===!1:!1)}async function*fa(r,t,e,n,o,s){for await(let i of t.findProviders(r,s)){let a=Kx(i.multiaddrs,n,o);if(a.length===0)continue;let c=E0(a[0]);yield new la(c,e)}}var Gu=class extends Go{routing;allowInsecure;allowLocal;constructor(t,e){super(t,{...e,name:"helia:trustless-gateway:session"}),this.routing=t.routing,this.allowInsecure=e.allowInsecure??ha,this.allowLocal=e.allowLocal??da}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*fa(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 v0(r,t){return new Gu(r,t)}var pa=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??ha,this.allowLocal=e.allowLocal??da}async retrieve(t,e={}){let n=[];for await(let o of fa(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 v0({logger:this.logger,routing:this.routing},t)}};var ha=!1,da=!1;function ju(r={}){return t=>new pa(t,r)}async function*ma(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 jx=Jt(sn(),1);var Wx=Jt(Yu(),1);var A0="ERR_IPNS_EXPIRED_RECORD",ga="ERR_UNRECOGNIZED_VALIDITY";var hr="ERR_SIGNATURE_VERIFICATION";var Zu="ERR_UNDEFINED_PARAMETER",B0="ERR_INVALID_RECORD_DATA",k0="ERR_INVALID_VALUE",S0="ERR_INVALID_EMBEDDED_KEY";var I0="ERR_RECORD_TOO_LARGE";var _e;(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=()=>ho(e)}(t=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=gn((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)=>{let i={},a=s==null?o.len:o.pos+s;for(;o.pos<a;){let c=o.uint32();switch(c>>>3){case 1:i.value=o.bytes();break;case 2:i.signatureV1=o.bytes();break;case 3:i.validityType=r.ValidityType.codec().decode(o);break;case 4:i.validity=o.bytes();break;case 5:i.sequence=o.uint64();break;case 6:i.ttl=o.uint64();break;case 7:i.pubKey=o.bytes();break;case 8:i.signatureV2=o.bytes();break;case 9:i.data=o.bytes();break;default:o.skipType(c&7);break}}return i})),n),r.encode=o=>pn(o,r.codec()),r.decode=o=>un(o,r.codec())})(_e||(_e={}));var ue=Jt(sn(),1);var _0=ee("ipns:utils"),T0=q("/ipns/"),qx=114,C0=async(r,t)=>{if(t==null||r==null){let n=new Error("one or more of the provided parameters are not defined");throw _0.error(n),(0,ue.default)(n,Zu)}let e;if(t.pubKey!=null){try{e=Iu(t.pubKey)}catch(o){throw _0.error(o),o}if(!(await uf(t.pubKey)).equals(r))throw(0,ue.default)(new Error("Embedded public key did not match PeerID"),S0)}else r.publicKey!=null&&(e=Iu(r.publicKey));if(e!=null)return e;throw(0,ue.default)(new Error("no public key is available"),Zu)};var N0=r=>{let t=q("ipns-signature:");return St([t,r])},en=r=>"signatureV1"in r?_e.encode({value:q(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:q(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):_e.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data});function He(r){let t=_e.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(0,ue.default)(new Error("missing data or signatureV2"),hr);let e=L0(t.data),n=zx(e.Value),o=z(e.Validity);if(t.value!=null&&t.signatureV1!=null)return Gx(t),{value:n,validityType:_e.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:_e.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")}var Ju=r=>St([T0,r.toBytes()]),ro=r=>mo(r.slice(T0.length));var L0=r=>{let t=de(r);if(t.ValidityType===0)t.ValidityType=_e.ValidityType.EOL;else throw(0,ue.default)(new Error("Unknown validity type"),ga);return Number.isInteger(t.Sequence)&&(t.Sequence=BigInt(t.Sequence)),Number.isInteger(t.TTL)&&(t.TTL=BigInt(t.TTL)),t},zx=r=>{if(r!=null){if(El(r))return`/ipns/${r.toCID().toString(br)}`;if(r instanceof Uint8Array){let n=z(r);n.startsWith("/")&&(r=n)}let t=r.toString().trim();if(t.startsWith("/")&&t.length>1)return t;let e=tt.asCID(r);if(e!=null)return e.code===qx?`/ipns/${e.toString(br)}`:`/ipfs/${e.toV1().toString()}`;try{return r instanceof Uint8Array?`/ipfs/${tt.decode(r).toV1().toString()}`:`/ipfs/${tt.parse(t).toV1().toString()}`}catch{}}throw(0,ue.default)(new Error("Value must be a valid content path starting with /"),k0)},Gx=r=>{if(r.data==null)throw(0,ue.default)(new Error("Record data is missing"),B0);let t=L0(r.data);if(!it(t.Value,r.value??new Uint8Array(0)))throw(0,ue.default)(new Error('Field "value" did not match between protobuf and CBOR'),hr);if(!it(t.Validity,r.validity??new Uint8Array(0)))throw(0,ue.default)(new Error('Field "validity" did not match between protobuf and CBOR'),hr);if(t.ValidityType!==r.validityType)throw(0,ue.default)(new Error('Field "validityType" did not match between protobuf and CBOR'),hr);if(t.Sequence!==r.sequence)throw(0,ue.default)(new Error('Field "sequence" did not match between protobuf and CBOR'),hr);if(t.TTL!==r.ttl)throw(0,ue.default)(new Error('Field "ttl" did not match between protobuf and CBOR'),hr)};var E3=ee("ipns"),v3=Wt.code,A3=60*60*1e9,Yx="/ipns/",B3=Yx.length;var Zo=Jt(sn(),1),U0=Jt(Yu(),1);var ya=ee("ipns:validator"),Zx=1024*10,Jx=async(r,t)=>{let e=He(t),n;try{let o=N0(e.data);n=await r.verify(o,e.signatureV2)}catch{n=!1}if(!n)throw ya.error("record signature verification failed"),(0,Zo.default)(new Error("record signature verification failed"),hr);if(e.validityType===_e.ValidityType.EOL){if(U0.default.fromString(e.validity).toDate().getTime()<Date.now())throw ya.error("record has expired"),(0,Zo.default)(new Error("record has expired"),A0)}else if(e.validityType!=null)throw ya.error("unrecognized validity type"),(0,Zo.default)(new Error("unrecognized validity type"),ga);ya("ipns record for %s is valid",e.value)};async function D0(r,t){if(t.byteLength>Zx)throw(0,Zo.default)(new Error("record too large"),I0);let e=ro(r),n=He(t),o=await C0(e,n);await Jx(o,t)}async function*Jo(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))}function Xx(r){return r[Symbol.asyncIterator]!=null}function Qx(r){if(Xx(r))return(async()=>{for await(let t of r)return t})();for(let t of r)return t}var wa=Qx;var Xu=q("/ipns/");function P0(r){return it(r.subarray(0,Xu.byteLength),Xu)}var O0=r=>mo(r.slice(Xu.length)),ba=class{client;constructor(t){this.client=t}async*findProviders(t,e={}){yield*cn(this.client.getProviders(t,e),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async put(t,e,n){if(!P0(t))return;let o=O0(t),s=He(e);await this.client.putIPNS(o,s,n)}async get(t,e){if(!P0(t))throw new D("Not found","ERR_NOT_FOUND");let n=O0(t);try{let o=await this.client.getIPNS(n,e);return en(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new D("Not found","ERR_NOT_FOUND"):o}}},xa=class{client;constructor(t){this.client=t}async findPeer(t,e={}){let n=await wa(this.client.getPeers(t,e));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new D("Not found","ERR_NOT_FOUND")}async*getClosestPeers(t,e={}){}};var Zt=ee("delegated-routing-v1-http-api-client"),F0={concurrentRequests:4,timeout:3e4},Ea=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;constructor(t,e={}){this.started=!1,this.shutDownController=new AbortController,ft(1/0,this.shutDownController.signal),this.httpQueue=new Le({concurrency:e.concurrentRequests??F0.concurrentRequests}),this.clientUrl=t instanceof URL?t:new URL(t),this.timeout=e.timeout??F0.timeout,this.contentRouting=new ba(this),this.peerRouting=new xa(this)}get[oo](){return this.contentRouting}get[io](){return this.peerRouting}isStarted(){return this.started}start(){this.started=!0}stop(){this.httpQueue.clear(),this.shutDownController.abort(),this.started=!1}async*getProviders(t,e={}){Zt("getProviders starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=$t([this.shutDownController.signal,n,e.signal]);ft(1/0,n,o);let s=kt(),i=kt();this.httpQueue.add(async()=>(s.resolve(),i.promise));try{await s.promise;let a=`${this.clientUrl}routing/v1/providers/${t.toString()}`,u=await fetch(a,{headers:{Accept:"application/x-ndjson"},signal:o});if(u.status===404)throw new D("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new D("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new D("Routing response had no body","ERR_BAD_RESPONSE");if(u.headers.get("Content-Type")==="application/json"){let l=await u.json();for(let m of l.Providers){let h=this.#t(m);h!=null&&(yield h)}}else for await(let l of Jo(ma(u.body))){let m=this.#t(l);m!=null&&(yield m)}}catch(a){Zt.error("getProviders errored:",a)}finally{o.clear(),i.resolve(),Zt("getProviders finished: %c",t)}}async*getPeers(t,e={}){Zt("getPeers starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=$t([this.shutDownController.signal,n,e.signal]);ft(1/0,n,o);let s=kt(),i=kt();this.httpQueue.add(async()=>(s.resolve(),i.promise));try{await s.promise;let a=`${this.clientUrl}routing/v1/peers/${t.toCID().toString()}`,u=await fetch(a,{headers:{Accept:"application/x-ndjson"},signal:o});if(u.status===404)throw new D("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new D("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new D("Routing response had no body","ERR_BAD_RESPONSE");if(u.headers.get("Content-Type")==="application/json"){let l=await u.json();for(let m of l.Peers){let h=this.#t(m);h!=null&&(yield h)}}else for await(let l of Jo(ma(u.body))){let m=this.#t(l);m!=null&&(yield m)}}catch(a){Zt.error("getPeers errored:",a)}finally{o.clear(),i.resolve(),Zt("getPeers finished: %c",t)}}async getIPNS(t,e={}){Zt("getIPNS starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=$t([this.shutDownController.signal,n,e.signal]);ft(1/0,n,o);let s=kt(),i=kt();this.httpQueue.add(async()=>(s.resolve(),i.promise));let a=`${this.clientUrl}routing/v1/ipns/${t.toCID().toString()}`;try{await s.promise;let u=await fetch(a,{headers:{Accept:"application/vnd.ipfs.ipns-record"},signal:o});if(Zt("getIPNS GET %s %d",a,u.status),u.status===404)throw new D("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new D("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new D("GET ipns response had no body","ERR_BAD_RESPONSE");let f=await u.arrayBuffer(),l=new Uint8Array(f,0,f.byteLength);return e.validate!==!1&&await D0(Ju(t),l),He(l)}catch(c){throw Zt.error("getIPNS GET %s error:",a,c),c}finally{o.clear(),i.resolve(),Zt("getIPNS finished: %c",t)}}async putIPNS(t,e,n={}){Zt("putIPNS starts: %c",t);let o=AbortSignal.timeout(this.timeout),s=$t([this.shutDownController.signal,o,n.signal]);ft(1/0,o,s);let i=kt(),a=kt();this.httpQueue.add(async()=>(i.resolve(),a.promise));let c=`${this.clientUrl}routing/v1/ipns/${t.toCID().toString()}`;try{await i.promise;let u=en(e),l=await fetch(c,{method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:u,signal:s});if(Zt("putIPNS PUT %s %d",c,l.status),l.status!==200)throw new D("PUT ipns response had status other than 200","ERR_BAD_RESPONSE")}catch(u){throw Zt.error("putIPNS PUT %s error:",c,u.stack),u}finally{s.clear(),a.resolve(),Zt("putIPNS finished: %c",t)}}#t(t){let e=[],n=t.Addrs?.map(fr)??[];return t.Protocols!=null&&e.push(...t.Protocols),t.Protocol!=null&&(e.push(t.Protocol),delete t.Protocol),{...t,Schema:"peer",ID:wc(t.ID),Addrs:n,Protocols:e}}};function V0(r,t={}){return new Ea(new URL(r),t)}var M0=q("/ipns/");function $0(r){return it(r.subarray(0,M0.byteLength),M0)}var Qu=class{client;constructor(t){this.client=V0(t)}async provide(t,e){}async*findProviders(t,e){yield*cn(this.client.getProviders(t,e),n=>({id:n.ID,multiaddrs:n.Addrs,protocols:n.Protocols}))}async put(t,e,n){if(!$0(t))return;let o=ro(t),s=He(e);await this.client.putIPNS(o,s,n)}async get(t,e){if(!$0(t))throw new D("Not found","ERR_NOT_FOUND");let n=ro(t);try{let o=await this.client.getIPNS(n,e);return en(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new D("Not found","ERR_NOT_FOUND"):o}}async findPeer(t,e){let n=await wa(this.client.getPeers(t,e));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new D("Not found","ERR_NOT_FOUND")}async*getClosestPeers(t,e){}};function tl(r){return new Qu(new URL(r))}var H0="[a-fA-F\\d:]",Or=r=>r&&r.includeBoundaries?`(?:(?<=\\s|^)(?=${H0})|(?<=${H0})(?=\\s|$))`:"",Te="(?: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}",xt="[a-fA-F\\d]{1,4}",va=`
9
+ (?:
10
+ (?:${xt}:){7}(?:${xt}|:)| // 1:2:3:4:5:6:7:: 1:2:3:4:5:6:7:8
11
+ (?:${xt}:){6}(?:${Te}|:${xt}|:)| // 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
12
+ (?:${xt}:){5}(?::${Te}|(?::${xt}){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
13
+ (?:${xt}:){4}(?:(?::${xt}){0,1}:${Te}|(?::${xt}){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
14
+ (?:${xt}:){3}(?:(?::${xt}){0,2}:${Te}|(?::${xt}){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
15
+ (?:${xt}:){2}(?:(?::${xt}){0,3}:${Te}|(?::${xt}){1,5}|:)| // 1:2:: 1:2::4:5:6:7:8 1:2::8 1:2::4:5:6:7:1.2.3.4
16
+ (?:${xt}:){1}(?:(?::${xt}){0,4}:${Te}|(?::${xt}){1,6}|:)| // 1:: 1::3:4:5:6:7:8 1::8 1::3:4:5:6:7:1.2.3.4
17
+ (?::(?:(?::${xt}){0,5}:${Te}|(?::${xt}){1,7}|:)) // ::2:3:4:5:6:7:8 ::2:3:4:5:6:7:8 ::8 ::1.2.3.4
18
+ )(?:%[0-9a-zA-Z]{1,})? // %eth0 %1
19
+ `.replace(/\s*\/\/.*$/gm,"").replace(/\n/g,"").trim(),t1=new RegExp(`(?:^${Te}$)|(?:^${va}$)`),e1=new RegExp(`^${Te}$`),r1=new RegExp(`^${va}$`),el=r=>r&&r.exact?t1:new RegExp(`(?:${Or(r)}${Te}${Or(r)})|(?:${Or(r)}${va}${Or(r)})`,"g");el.v4=r=>r&&r.exact?e1:new RegExp(`${Or(r)}${Te}${Or(r)}`,"g");el.v6=r=>r&&r.exact?r1:new RegExp(`${Or(r)}${va}${Or(r)}`,"g");var rl=el;function nl(r){let t=(...e)=>r(...e);return Object.defineProperty(t,"name",{value:`functionTimeout(${r.name||"<anonymous>"})`,configurable:!0}),t}function K0(){return!1}var{toString:n1}=Object.prototype;function ol(r){return n1.call(r)==="[object RegExp]"}var q0={global:"g",ignoreCase:"i",multiline:"m",dotAll:"s",sticky:"y",unicode:"u"};function sl(r,t={}){if(!ol(r))throw new TypeError("Expected a RegExp instance");let e=Object.keys(q0).map(o=>(typeof t[o]=="boolean"?t[o]:r[o])?q0[o]:"").join(""),n=new RegExp(t.source||r.source,e);return n.lastIndex=typeof t.lastIndex=="number"?t.lastIndex:r.lastIndex,n}function il(r,t,{timeout:e}={}){try{return nl(()=>sl(r).test(t),{timeout:e})()}catch(n){if(K0(n))return!1;throw n}}var o1=15,s1=45,z0={timeout:400};function al(r){return r.length>s1?!1:il(rl.v6({exact:!0}),r,z0)}function G0(r){return r.length>o1?!1:il(rl.v4({exact:!0}),r,z0)}var j0={http:"80",https:"443",ws:"80",wss:"443"},i1=["http","https","ws","wss"];function W0(r,t){t=t??{};let e=t.defaultDnsType??"dns4",{scheme:n,hostname:o,port:s}=a1(r),a="/"+[c1(o,e),u1(s,n),l1(n)].filter(c=>!!c).reduce((c,u)=>c.concat(u),[]).join("/");return fr(a)}function a1(r){let[t]=r.split(":");i1.includes(t)||(r="http"+r.substring(t.length));let{protocol:e,hostname:n,port:o}=new URL(r);if(o==null||o===""){let s=f1(t);s!=null&&(o=s),s==null&&e==="http:"&&(o="80")}return{scheme:t,hostname:n,port:o}}function c1(r,t){if(!(r==null||r==="")){if(G0(r))return["ip4",r];if(al(r))return["ip6",r];if(r[0]==="["){let e=r.substring(1,r.length-1);if(al(e))return["ip6",e]}return[t,r]}}function u1(r,t){if(!(r==null||r===""))return t==="udp"?["udp",r]:["tcp",r]}function l1(r){if(r.match(/^tcp$|^udp$/)==null)return[r]}function f1(r){if(!(r==null||r===""||j0[r]==null))return j0[r]}var h1=["https://trustless-gateway.link","https://4everland.io"],d1=2336,p1=Symbol.for("nodejs.util.inspect.custom"),cl=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Wt.digest(q(this.url))}[p1](){return`PeerId(${this.url})`}[so]=!0;toString(){return this.toCID().toString()}toCID(){return tt.createV1(d1,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=z(t)),t.toString()===this.toString())}};function m1(r){return r=r.toString(),{id:new cl(new URL(r)),multiaddrs:[W0(r)]}}var ul=class{gateways;constructor(t={}){this.gateways=(t.gateways??h1).map(e=>m1(e))}async*findProviders(t,e){yield*this.gateways.toSorted(()=>Math.random()>.5?1:-1).map(n=>({...n,protocols:["transport-ipfs-gateway-http"]}))}};function ll(r={}){return new ul(r)}var Y0=Jt(sn(),1);function Aa(r){return r=r??new Error("Not Found"),(0,Y0.default)(r,"ERR_NOT_FOUND")}var Z0="SHARDING";function y1(r){return r[Symbol.asyncIterator]!=null}function w1(r){if(y1(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 fl=w1;function b1(r){return r[Symbol.asyncIterator]!=null}function x1(r,t){return b1(r)?async function*(){yield*(await fl(r)).sort(t)}():function*(){yield*fl(r).sort(t)}()}var Ba=x1;var dr=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 Mr(this.putMany(t,n)),t=[],await Mr(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)=>Ba(o,s),n)),t.offset!=null){let o=0,s=t.offset;n=Ae(n,()=>o++>=s)}return t.limit!=null&&(n=us(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)=>Ba(o,s),n)),t.offset!=null){let o=t.offset,s=0;n=Ae(n,()=>s++>=o)}return t.limit!=null&&(n=us(n,t.limit)),n}};var Qo=class extends dr{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 Aa();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 Lt(t),value:e}}*_allKeys(){for(let t of this.data.keys())yield new Lt(t)}};var p_=new Lt(Z0);var S_=ee("datastore:core:tiered");async function A1(r={}){let t=r.datastore??new Qo,e=r.blockstore??new Io,n=new Qi({...r,datastore:t,blockstore:e,blockBrokers:r.blockBrokers??[ju()],routers:r.routers??[tl("https://delegated-ipfs.dev"),ll()]});return r.start!==!1&&await n.start(),n}return fm(B1);})();
9
20
  /*! Bundled license information:
10
21
 
11
22
  pvtsutils/build/index.js: