@helia/http 1.0.3-329652a → 1.0.3-395cd9e

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,11 @@
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 v0=Object.create;var Wo=Object.defineProperty;var A0=Object.getOwnPropertyDescriptor;var B0=Object.getOwnPropertyNames;var k0=Object.getPrototypeOf,S0=Object.prototype.hasOwnProperty;var Pt=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),xe=(r,e)=>{for(var t in e)Wo(r,t,{get:e[t],enumerable:!0})},Xu=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of B0(e))!S0.call(r,o)&&o!==t&&Wo(r,o,{get:()=>e[o],enumerable:!(n=A0(e,o))||n.enumerable});return r};var ot=(r,e,t)=>(t=r!=null?v0(k0(r)):{},Xu(e||!r||!r.__esModule?Wo(t,"default",{value:r,enumerable:!0}):t,r)),I0=r=>Xu(Wo({},"__esModule",{value:!0}),r);var Ql=Pt((jv,Xl)=>{var fn=1e3,hn=fn*60,dn=hn*60,Fr=dn*24,uy=Fr*7,ly=Fr*365.25;Xl.exports=function(r,e){e=e||{};var t=typeof r;if(t==="string"&&r.length>0)return fy(r);if(t==="number"&&isFinite(r))return e.long?dy(r):hy(r);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(r))};function fy(r){if(r=String(r),!(r.length>100)){var e=/^(-?(?:\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(e){var t=parseFloat(e[1]),n=(e[2]||"ms").toLowerCase();switch(n){case"years":case"year":case"yrs":case"yr":case"y":return t*ly;case"weeks":case"week":case"w":return t*uy;case"days":case"day":case"d":return t*Fr;case"hours":case"hour":case"hrs":case"hr":case"h":return t*dn;case"minutes":case"minute":case"mins":case"min":case"m":return t*hn;case"seconds":case"second":case"secs":case"sec":case"s":return t*fn;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return t;default:return}}}}function hy(r){var e=Math.abs(r);return e>=Fr?Math.round(r/Fr)+"d":e>=dn?Math.round(r/dn)+"h":e>=hn?Math.round(r/hn)+"m":e>=fn?Math.round(r/fn)+"s":r+"ms"}function dy(r){var e=Math.abs(r);return e>=Fr?ms(r,e,Fr,"day"):e>=dn?ms(r,e,dn,"hour"):e>=hn?ms(r,e,hn,"minute"):e>=fn?ms(r,e,fn,"second"):r+" ms"}function ms(r,e,t,n){var o=e>=t*1.5;return Math.round(r/t)+" "+n+(o?"s":"")}});var tf=Pt((Wv,ef)=>{function py(r){t.debug=t,t.default=t,t.coerce=c,t.disable=s,t.enable=o,t.enabled=i,t.humanize=Ql(),t.destroy=f,Object.keys(r).forEach(u=>{t[u]=r[u]}),t.names=[],t.skips=[],t.formatters={};function e(u){let l=0;for(let h=0;h<u.length;h++)l=(l<<5)-l+u.charCodeAt(h),l|=0;return t.colors[Math.abs(l)%t.colors.length]}t.selectColor=e;function t(u){let l,h=null,g,y;function p(...m){if(!p.enabled)return;let w=p,I=Number(new Date),v=I-(l||I);w.diff=v,w.prev=l,w.curr=I,l=I,m[0]=t.coerce(m[0]),typeof m[0]!="string"&&m.unshift("%O");let U=0;m[0]=m[0].replace(/%([a-zA-Z%])/g,(_,L)=>{if(_==="%%")return"%";U++;let b=t.formatters[L];if(typeof b=="function"){let C=m[U];_=b.call(w,C),m.splice(U,1),U--}return _}),t.formatArgs.call(w,m),(w.log||t.log).apply(w,m)}return p.namespace=u,p.useColors=t.useColors(),p.color=t.selectColor(u),p.extend=n,p.destroy=t.destroy,Object.defineProperty(p,"enabled",{enumerable:!0,configurable:!1,get:()=>h!==null?h:(g!==t.namespaces&&(g=t.namespaces,y=t.enabled(u)),y),set:m=>{h=m}}),typeof t.init=="function"&&t.init(p),p}function n(u,l){let h=t(this.namespace+(typeof l>"u"?":":l)+u);return h.log=this.log,h}function o(u){t.save(u),t.namespaces=u,t.names=[],t.skips=[];let l,h=(typeof u=="string"?u:"").split(/[\s,]+/),g=h.length;for(l=0;l<g;l++)h[l]&&(u=h[l].replace(/\*/g,".*?"),u[0]==="-"?t.skips.push(new RegExp("^"+u.slice(1)+"$")):t.names.push(new RegExp("^"+u+"$")))}function s(){let u=[...t.names.map(a),...t.skips.map(a).map(l=>"-"+l)].join(",");return t.enable(""),u}function i(u){if(u[u.length-1]==="*")return!0;let l,h;for(l=0,h=t.skips.length;l<h;l++)if(t.skips[l].test(u))return!1;for(l=0,h=t.names.length;l<h;l++)if(t.names[l].test(u))return!0;return!1}function a(u){return u.toString().substring(2,u.toString().length-2).replace(/\.\*\?$/,"*")}function c(u){return u instanceof Error?u.stack||u.message:u}function f(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return t.enable(t.load()),t}ef.exports=py});var rf=Pt((je,ys)=>{je.formatArgs=yy;je.save=gy;je.load=wy;je.useColors=my;je.storage=by();je.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`."))}})();je.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 my(){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 yy(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 e="color: "+this.color;r.splice(1,0,e,"color: inherit");let t=0,n=0;r[0].replace(/%[a-zA-Z%]/g,o=>{o!=="%%"&&(t++,o==="%c"&&(n=t))}),r.splice(n,0,e)}je.log=console.debug||console.log||(()=>{});function gy(r){try{r?je.storage.setItem("debug",r):je.storage.removeItem("debug")}catch{}}function wy(){let r;try{r=je.storage.getItem("debug")}catch{}return!r&&typeof process<"u"&&"env"in process&&(r=process.env.DEBUG),r}function by(){try{return localStorage}catch{}}ys.exports=tf()(je);var{formatters:xy}=ys.exports;xy.j=function(r){try{return JSON.stringify(r)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}});var pn=Pt((Zv,of)=>{"use strict";function nf(r,e){for(let t in e)Object.defineProperty(r,t,{value:e[t],enumerable:!0,configurable:!0});return r}function Ay(r,e,t){if(!r||typeof r=="string")throw new TypeError("Please pass an Error to err-code");t||(t={}),typeof e=="object"&&(t=e,e=""),e&&(t.code=e);try{return nf(r,t)}catch{t.message=r.message,t.stack=r.stack;let o=function(){};return o.prototype=Object.create(Object.getPrototypeOf(r)),nf(new o,t)}}of.exports=Ay});var gf=Pt(ho=>{(function(){var r,e,t,n,o,s,i,a;a=function(c){var f,u,l,h;return f=(c&255<<24)>>>24,u=(c&255<<16)>>>16,l=(c&65280)>>>8,h=c&255,[f,u,l,h].join(".")},i=function(c){var f,u,l,h,g,y;for(f=[],l=h=0;h<=3&&c.length!==0;l=++h){if(l>0){if(c[0]!==".")throw new Error("Invalid IP");c=c.substring(1)}y=e(c),g=y[0],u=y[1],c=c.substring(u),f.push(g)}if(c.length!==0)throw new Error("Invalid IP");switch(f.length){case 1:if(f[0]>4294967295)throw new Error("Invalid IP");return f[0]>>>0;case 2:if(f[0]>255||f[1]>16777215)throw new Error("Invalid IP");return(f[0]<<24|f[1])>>>0;case 3:if(f[0]>255||f[1]>255||f[2]>65535)throw new Error("Invalid IP");return(f[0]<<24|f[1]<<16|f[2])>>>0;case 4:if(f[0]>255||f[1]>255||f[2]>255||f[3]>255)throw new Error("Invalid IP");return(f[0]<<24|f[1]<<16|f[2]<<8|f[3])>>>0;default:throw new Error("Invalid IP")}},t=function(c){return c.charCodeAt(0)},n=t("0"),s=t("a"),o=t("A"),e=function(c){var f,u,l,h,g;for(h=0,f=10,u="9",l=0,c.length>1&&c[l]==="0"&&(c[l+1]==="x"||c[l+1]==="X"?(l+=2,f=16):"0"<=c[l+1]&&c[l+1]<="9"&&(l++,f=8,u="7")),g=l;l<c.length;){if("0"<=c[l]&&c[l]<=u)h=h*f+(t(c[l])-n)>>>0;else if(f===16)if("a"<=c[l]&&c[l]<="f")h=h*f+(10+t(c[l])-s)>>>0;else if("A"<=c[l]&&c[l]<="F")h=h*f+(10+t(c[l])-o)>>>0;else break;else break;if(h>4294967295)throw new Error("too large");l++}if(l===g)throw new Error("empty octet");return[h,l]},r=function(){function c(f,u){var l,h,g,y;if(typeof f!="string")throw new Error("Missing `net' parameter");if(u||(y=f.split("/",2),f=y[0],u=y[1]),u||(u=32),typeof u=="string"&&u.indexOf(".")>-1){try{this.maskLong=i(u)}catch(p){throw l=p,new Error("Invalid mask: "+u)}for(h=g=32;g>=0;h=--g)if(this.maskLong===4294967295<<32-h>>>0){this.bitmask=h;break}}else if(u||u===0)this.bitmask=parseInt(u,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(f)&this.maskLong)>>>0}catch(p){throw l=p,new Error("Invalid net address: "+f)}if(!(this.bitmask<=32))throw new Error("Invalid mask for ip4: "+u);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(f){return typeof f=="string"&&(f.indexOf("/")>0||f.split(".").length!==4)&&(f=new c(f)),f instanceof c?this.contains(f.base)&&this.contains(f.broadcast||f.last):(i(f)&this.maskLong)>>>0===(this.netLong&this.maskLong)>>>0},c.prototype.next=function(f){return f==null&&(f=1),new c(a(this.netLong+this.size*f),this.mask)},c.prototype.forEach=function(f){var u,l,h;for(h=i(this.first),l=i(this.last),u=0;h<=l;)f(a(h),h,u),u++,h++},c.prototype.toString=function(){return this.base+"/"+this.bitmask},c}(),ho.ip2long=i,ho.long2ip=a,ho.Netmask=r}).call(ho)});var Qf=Pt(On=>{"use strict";var uw="[object ArrayBuffer]",Wt=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===uw}static toArrayBuffer(e){return this.isArrayBuffer(e)?e:e.byteLength===e.buffer.byteLength||e.byteOffset===0&&e.byteLength===e.buffer.byteLength?e.buffer:this.toUint8Array(e.buffer).slice(e.byteOffset,e.byteOffset+e.byteLength).buffer}static toUint8Array(e){return this.toView(e,Uint8Array)}static toView(e,t){if(e.constructor===t)return e;if(this.isArrayBuffer(e))return new t(e);if(this.isArrayBufferView(e))return new t(e.buffer,e.byteOffset,e.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(e){return this.isArrayBufferView(e)||this.isArrayBuffer(e)}static isArrayBufferView(e){return ArrayBuffer.isView(e)||e&&this.isArrayBuffer(e.buffer)}static isEqual(e,t){let n=r.toUint8Array(e),o=r.toUint8Array(t);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(...e){let t;Array.isArray(e[0])&&!(e[1]instanceof Function)||Array.isArray(e[0])&&e[1]instanceof Function?t=e[0]:e[e.length-1]instanceof Function?t=e.slice(0,e.length-1):t=e;let n=0;for(let i of t)n+=i.byteLength;let o=new Uint8Array(n),s=0;for(let i of t){let a=this.toUint8Array(i);o.set(a,s),s+=a.length}return e[e.length-1]instanceof Function?this.toView(o,e[e.length-1]):o.buffer}},zc="string",lw=/^[0-9a-f]+$/i,fw=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,hw=/^[a-zA-Z0-9-_]+$/,Fs=class{static fromString(e){let t=unescape(encodeURIComponent(e)),n=new Uint8Array(t.length);for(let o=0;o<t.length;o++)n[o]=t.charCodeAt(o);return n.buffer}static toString(e){let t=Wt.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return decodeURIComponent(escape(n))}},ct=class{static toString(e,t=!1){let n=Wt.toArrayBuffer(e),o=new DataView(n),s="";for(let i=0;i<n.byteLength;i+=2){let a=o.getUint16(i,t);s+=String.fromCharCode(a)}return s}static fromString(e,t=!1){let n=new ArrayBuffer(e.length*2),o=new DataView(n);for(let s=0;s<e.length;s++)o.setUint16(s*2,e.charCodeAt(s),t);return n}},Vs=class r{static isHex(e){return typeof e===zc&&lw.test(e)}static isBase64(e){return typeof e===zc&&fw.test(e)}static isBase64Url(e){return typeof e===zc&&hw.test(e)}static ToString(e,t="utf8"){let n=Wt.toUint8Array(e);switch(t.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 ct.toString(n,!0);case"utf16":case"utf16be":return ct.toString(n);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromString(e,t="utf8"){if(!e)return new ArrayBuffer(0);switch(t.toLowerCase()){case"utf8":return this.FromUtf8String(e);case"binary":return this.FromBinary(e);case"hex":return this.FromHex(e);case"base64":return this.FromBase64(e);case"base64url":return this.FromBase64Url(e);case"utf16le":return ct.fromString(e,!0);case"utf16":case"utf16be":return ct.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=Wt.toUint8Array(e);if(typeof btoa<"u"){let n=this.ToString(t,"binary");return btoa(n)}else return Buffer.from(t).toString("base64")}static FromBase64(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64(t))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(t)):new Uint8Array(Buffer.from(t,"base64")).buffer}static FromBase64Url(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64Url(t))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(t.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(e){return this.ToBase64(e).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.FromBinary(e);case"utf8":return Fs.fromString(e);case"utf16":case"utf16be":return ct.fromString(e);case"utf16le":case"usc2":return ct.fromString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.ToBinary(e);case"utf8":return Fs.toString(e);case"utf16":case"utf16be":return ct.toString(e);case"utf16le":case"usc2":return ct.toString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromBinary(e){let t=e.length,n=new Uint8Array(t);for(let o=0;o<t;o++)n[o]=e.charCodeAt(o);return n.buffer}static ToBinary(e){let t=Wt.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return n}static ToHex(e){let t=Wt.toUint8Array(e),n="",o=t.length;for(let s=0;s<o;s++){let i=t[s];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isHex(t))throw new TypeError("Argument 'hexString' is not HEX encoded");t.length%2&&(t=`0${t}`);let n=new Uint8Array(t.length/2);for(let o=0;o<t.length;o=o+2){let s=t.slice(o,o+2);n[o/2]=parseInt(s,16)}return n.buffer}static ToUtf16String(e,t=!1){return ct.toString(e,t)}static FromUtf16String(e,t=!1){return ct.fromString(e,t)}static Base64Padding(e){let t=4-e.length%4;if(t<4)for(let n=0;n<t;n++)e+="=";return e}static formatString(e){return e?.replace(/[\n\r\t ]/g,"")||""}};Vs.DEFAULT_UTF8_ENCODING="utf8";function dw(r,...e){let t=arguments[0];for(let n=1;n<arguments.length;n++){let o=arguments[n];for(let s in o)t[s]=o[s]}return t}function pw(...r){let e=r.map(o=>o.byteLength).reduce((o,s)=>o+s),t=new Uint8Array(e),n=0;return r.map(o=>new Uint8Array(o)).forEach(o=>{for(let s of o)t[n++]=s}),t.buffer}function mw(r,e){if(!(r&&e)||r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let o=0;o<r.byteLength;o++)if(t[o]!==n[o])return!1;return!0}On.BufferSourceConverter=Wt;On.Convert=Vs;On.assign=dw;On.combine=pw;On.isEqual=mw});var au=Pt((Fk,iu)=>{var Ok=function(){typeof iu<"u"&&(iu.exports=p);var r=86400,e=3200,t=146097*e/400,n=r*t,o=1e3*n,s=864e13,i=4294967296,a=1e6,c="000000000",f=Math.trunc||function(b){var C=b-b%1;return C==0&&(b<0||b===0&&1/b!=1/0)?-0:C},u=p.prototype,l=(p.fromDate=function(b){return new p(+b)},p.fromInt64BE=U(0,1,2,3,0,4),p.fromInt64LE=U(3,2,1,0,4,0),p.fromString=function(T){var C,O=new p,T=(T+="").replace(/^\s*[+\-]?\d+/,function(H){var H=+H,X=1970+(H-1970)%400;return O.year=H-X,X}).replace(/(?:Z|([+\-]\d{2}):?(\d{2}))$/,function(V,H,X){return H<0&&(X*=-1),C=6e4*(60*+H+ +X),""}).replace(/\.\d+$/,function(V){return O.nano=+(V+c).substr(1,9),""}).split(/\D+/);if(1<T.length?T[1]--:T[1]=0,O.time=C=Date.UTC.apply(Date,T)-(C||0),isNaN(C))throw new TypeError("Invalid Date");return m(O)},p.fromTimeT=function(b){return I(b,0)},u.year=0,u.time=0,u.nano=0,u.addNano=function(b){return this.nano+=+b||0,this},u.getNano=function(){var b=m(this);return(b.time%1e3*a+ +b.nano+1e9)%1e9},u.getTimeT=function(){var C=m(this),b=Math.floor(C.time/1e3),C=C.year;return C&&(b+=C*t*r/e),b},u.getYear=function(){return this.toDate().getUTCFullYear()+this.year},u.toDate=function(){return w(m(this).time)},u.toJSON=function(){return this.toString().replace(/0{1,6}Z$/,"Z")},u.toString=function(b){var C=this,O=C.toDate(),T={H:function(){return _(O.getUTCHours())},L:function(){return L(O.getUTCMilliseconds(),3)},M:function(){return _(O.getUTCMinutes())},N:function(){return L(C.getNano(),9)},S:function(){return _(O.getUTCSeconds())},Y:function(){var V=C.getYear();return 999999<V?"+"+V:9999<V?"+"+L(V,6):0<=V?L(V,4):-999999<=V?"-"+L(-V,6):V},a:function(){return g[O.getUTCDay()]},b:function(){return h[O.getUTCMonth()]},d:function(){return _(O.getUTCDate())},e:function(){return function(V){return(9<V?"":" ")+(0|V)}(O.getUTCDate())},m:function(){return _(O.getUTCMonth()+1)}};return function V(H){return H.replace(/%./g,function(X){var k=X[1],E=y[k],k=T[k];return E?V(E):k?k():X})}(b||l)},u.writeInt64BE=v(0,1,2,3,0,4),u.writeInt64LE=v(3,2,1,0,4,0),"%Y-%m-%dT%H:%M:%S.%NZ"),h=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],g=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],y={"%":"%",F:"%Y-%m-%d",n:`
3
- `,R:"%H:%M",T:"%H:%M:%S",t:" ",X:"%T",Z:"GMT",z:"+0000"};return p;function p(b,C,O){var T=this;if(!(T instanceof p))return new p(b,C,O);T.time=+b||0,T.nano=+C||0,T.year=+O||0,m(T)}function m(b){var C,O,T,V=b.year,H=b.time,X=b.nano,E=((X<0||a<=X)&&(X-=(O=Math.floor(X/a))*a,H+=O,O=1),V%e);return(H<-s||s<H||E)&&((C=f(H/o))&&(V+=C*e,H-=C*o),(T=w(H)).setUTCFullYear(E+T.getUTCFullYear()),T=(H=+T)+(C=f((V-=E)/e))*o,C&&-s<=T&&T<=s&&(V-=C*e,H=T),O=1),O&&(b.year=V,b.time=H,b.nano=X),b}function w(b){var C=new Date(0);return C.setTime(b),C}function I(V,T){V=+V||0;var O=f((T=(T|0)*i)/n)+f(V/n),T=T%n+V%n,V=f(T/n);return V&&(O+=V,T-=V*n),new p(1e3*T,0,O*e)}function v(b,C,O,T,V,H){return function(E,k){var B=m(this);E=E||new Array(8),S(E,k|=0);var x=Math.floor(B.time/1e3),B=B.year*(t*r/e),$=f(B/i)+f(x/i),B=B%i+x%i,x=Math.floor(B/i);return x&&($+=x,B-=x*i),X(E,k+V,$),X(E,k+H,B),E};function X(E,k,$){E[k+b]=$>>24&255,E[k+C]=$>>16&255,E[k+O]=$>>8&255,E[k+T]=255&$}}function U(b,C,O,T,V,H){return function(E,k){S(E,k|=0);var $=X(E,k+V);return I(X(E,k+H),$)};function X(E,k){return 16777216*E[k+b]+(E[k+C]<<16|E[k+O]<<8|E[k+T])}}function S(b,C){if(b=b&&b.length,b==null)throw new TypeError("Invalid Buffer");if(b<C+8)throw new RangeError("Out of range")}function _(b){return(9<b?"":"0")+(0|b)}function L(b,C){return(c+(0|b)).substr(-C)}}()});var Ap=Pt((ES,gu)=>{"use strict";var Lb=Object.prototype.hasOwnProperty,He="~";function Mo(){}Object.create&&(Mo.prototype=Object.create(null),new Mo().__proto__||(He=!1));function Ub(r,e,t){this.fn=r,this.context=e,this.once=t||!1}function vp(r,e,t,n,o){if(typeof t!="function")throw new TypeError("The listener must be a function");var s=new Ub(t,n||r,o),i=He?He+e:e;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 zi(r,e){--r._eventsCount===0?r._events=new Mo:delete r._events[e]}function Oe(){this._events=new Mo,this._eventsCount=0}Oe.prototype.eventNames=function(){var e=[],t,n;if(this._eventsCount===0)return e;for(n in t=this._events)Lb.call(t,n)&&e.push(He?n.slice(1):n);return Object.getOwnPropertySymbols?e.concat(Object.getOwnPropertySymbols(t)):e};Oe.prototype.listeners=function(e){var t=He?He+e:e,n=this._events[t];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};Oe.prototype.listenerCount=function(e){var t=He?He+e:e,n=this._events[t];return n?n.fn?1:n.length:0};Oe.prototype.emit=function(e,t,n,o,s,i){var a=He?He+e:e;if(!this._events[a])return!1;var c=this._events[a],f=arguments.length,u,l;if(c.fn){switch(c.once&&this.removeListener(e,c.fn,void 0,!0),f){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,t),!0;case 3:return c.fn.call(c.context,t,n),!0;case 4:return c.fn.call(c.context,t,n,o),!0;case 5:return c.fn.call(c.context,t,n,o,s),!0;case 6:return c.fn.call(c.context,t,n,o,s,i),!0}for(l=1,u=new Array(f-1);l<f;l++)u[l-1]=arguments[l];c.fn.apply(c.context,u)}else{var h=c.length,g;for(l=0;l<h;l++)switch(c[l].once&&this.removeListener(e,c[l].fn,void 0,!0),f){case 1:c[l].fn.call(c[l].context);break;case 2:c[l].fn.call(c[l].context,t);break;case 3:c[l].fn.call(c[l].context,t,n);break;case 4:c[l].fn.call(c[l].context,t,n,o);break;default:if(!u)for(g=1,u=new Array(f-1);g<f;g++)u[g-1]=arguments[g];c[l].fn.apply(c[l].context,u)}}return!0};Oe.prototype.on=function(e,t,n){return vp(this,e,t,n,!1)};Oe.prototype.once=function(e,t,n){return vp(this,e,t,n,!0)};Oe.prototype.removeListener=function(e,t,n,o){var s=He?He+e:e;if(!this._events[s])return this;if(!t)return zi(this,s),this;var i=this._events[s];if(i.fn)i.fn===t&&(!o||i.once)&&(!n||i.context===n)&&zi(this,s);else{for(var a=0,c=[],f=i.length;a<f;a++)(i[a].fn!==t||o&&!i[a].once||n&&i[a].context!==n)&&c.push(i[a]);c.length?this._events[s]=c.length===1?c[0]:c:zi(this,s)}return this};Oe.prototype.removeAllListeners=function(e){var t;return e?(t=He?He+e:e,this._events[t]&&zi(this,t)):(this._events=new Mo,this._eventsCount=0),this};Oe.prototype.off=Oe.prototype.removeListener;Oe.prototype.addListener=Oe.prototype.on;Oe.prefixed=He;Oe.EventEmitter=Oe;typeof gu<"u"&&(gu.exports=Oe)});var Up=Pt((AI,Lp)=>{Lp.exports=function(r){if(!r)throw Error("hashlru must have a max value, of type number, greater than 0");var e=0,t=Object.create(null),n=Object.create(null);function o(s,i){t[s]=i,e++,e>=r&&(e=0,n=t,t=Object.create(null))}return{has:function(s){return t[s]!==void 0||n[s]!==void 0},remove:function(s){t[s]!==void 0&&(t[s]=void 0),n[s]!==void 0&&(n[s]=void 0)},get:function(s){var i=t[s];if(i!==void 0)return i;if((i=n[s])!==void 0)return o(s,i),i},set:function(s,i){t[s]!==void 0?t[s]=i:o(s,i)},clear:function(){t=Object.create(null),n=Object.create(null)}}}});var xx={};xe(xx,{DEFAULT_SESSION_MAX_PROVIDERS:()=>fa,DEFAULT_SESSION_MIN_PROVIDERS:()=>la,DEFAULT_SESSION_PROVIDER_QUERY_CONCURRENCY:()=>ha,DEFAULT_SESSION_PROVIDER_QUERY_TIMEOUT:()=>da,createHeliaHTTP:()=>bx});var la=1,fa=5,ha=5,da=5e3;var eo=Symbol.for("@libp2p/content-routing");var pa=Symbol.for("@libp2p/peer-id");function Qu(r){return r!=null&&!!r[pa]}var to=Symbol.for("@libp2p/peer-routing");var ar=class r extends Error{code;type;constructor(e="The operation was aborted"){super(e),this.name="AbortError",this.code=r.code,this.type=r.type}static code="ABORT_ERR";static type="aborted"},N=class extends Error{code;props;constructor(e,t,n){super(e),this.code=t,this.name=n?.name??"CodeError",this.props=n??{}}};var Qr=(r,...e)=>{try{[...e]}catch{}};var Yo=class extends EventTarget{#e=new Map;constructor(){super(),Qr(1/0,this)}listenerCount(e){let t=this.#e.get(e);return t==null?0:t.length}addEventListener(e,t,n){super.addEventListener(e,t,n);let o=this.#e.get(e);o==null&&(o=[],this.#e.set(e,o)),o.push({callback:t,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(e,t,n){super.removeEventListener(e.toString(),t??null,n);let o=this.#e.get(e);o!=null&&(o=o.filter(({callback:s})=>s!==t),this.#e.set(e,o))}dispatchEvent(e){let t=super.dispatchEvent(e),n=this.#e.get(e.type);return n==null||(n=n.filter(({once:o})=>!o),this.#e.set(e.type,n)),t}safeDispatchEvent(e,t={}){return this.dispatchEvent(new R0(e,t))}},ma=class extends Event{detail;constructor(e,t){super(e,t),this.detail=t?.detail}},R0=globalThis.CustomEvent??ma;function el(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function cr(...r){let e=[];for(let t of r)el(t)&&e.push(t);await Promise.all(e.map(async t=>{t.beforeStart!=null&&await t.beforeStart()})),await Promise.all(e.map(async t=>{await t.start()})),await Promise.all(e.map(async t=>{t.afterStart!=null&&await t.afterStart()}))}async function ur(...r){let e=[];for(let t of r)el(t)&&e.push(t);await Promise.all(e.map(async t=>{t.beforeStop!=null&&await t.beforeStop()})),await Promise.all(e.map(async t=>{await t.stop()})),await Promise.all(e.map(async t=>{t.afterStop!=null&&await t.afterStop()}))}function Ur(r){let e=new globalThis.AbortController;function t(){e.abort();for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",t)}for(let s of r){if(s?.aborted===!0){t();break}s?.addEventListener!=null&&s.addEventListener("abort",t)}function n(){for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",t)}let o=e.signal;return o.clear=n,o}function Ie(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var Zo=class{buffer;mask;top;btm;next;constructor(e){if(!(e>0)||e-1&e)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},en=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new Zo(this.hwm),this.tail=this.head,this.size=0}calculateSize(e){return e?.byteLength!=null?e.byteLength:1}push(e){if(e?.value!=null&&(this.size+=this.calculateSize(e.value)),!this.head.push(e)){let t=this.head;this.head=t.next=new Zo(2*this.head.buffer.length),this.head.push(e)}}shift(){let e=this.tail.shift();if(e===void 0&&this.tail.next!=null){let t=this.tail.next;this.tail.next=null,this.tail=t,e=this.tail.shift()}return e?.value!=null&&(this.size-=this.calculateSize(e.value)),e}isEmpty(){return this.head.isEmpty()}};var ya=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function Ot(r={}){return _0(t=>{let n=t.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function _0(r,e){e=e??{};let t=e.onEnd,n=new en,o,s,i,a=Ie(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((m,w)=>{s=I=>{s=null,n.push(I);try{m(r(n))}catch(v){w(v)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ie()})}},f=m=>s!=null?s(m):(n.push(m),o),u=m=>(n=new en,s!=null?s({error:m}):(n.push({error:m}),o)),l=m=>{if(i)return o;if(e?.objectMode!==!0&&m?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:m})},h=m=>i?o:(i=!0,m!=null?u(m):f({done:!0})),g=()=>(n=new en,h(),{done:!0}),y=m=>(h(m),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:g,throw:y,push:l,end:h,get readableLength(){return n.size},onEmpty:async m=>{let w=m?.signal;if(w?.throwIfAborted(),n.isEmpty())return;let I,v;w!=null&&(I=new Promise((U,S)=>{v=()=>{S(new ya)},w.addEventListener("abort",v)}));try{await Promise.race([a.promise,I])}finally{v!=null&&w!=null&&w?.removeEventListener("abort",v)}}},t==null)return o;let p=o;return o={[Symbol.asyncIterator](){return this},next(){return p.next()},throw(m){return p.throw(m),t!=null&&(t(m),t=void 0),{done:!0}},return(){return p.return(),t!=null&&(t(),t=void 0),{done:!0}},push:l,end(m){return p.end(m),t!=null&&(t(m),t=void 0),o},get readableLength(){return p.readableLength},onEmpty:m=>p.onEmpty(m)},o}var ga=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=t??"ABORT_ERR"}};async function Jo(r,e,t,n){let o=new ga(n?.errorMessage,n?.errorCode);return t?.aborted===!0?Promise.reject(o):new Promise((s,i)=>{let a=f=>{try{if(n?.filter?.(f)===!1)return}catch(u){r.removeEventListener(e,a),t?.removeEventListener("abort",c),i(u);return}r.removeEventListener(e,a),t?.removeEventListener("abort",c),s(f)},c=()=>{r.removeEventListener(e,a),t?.removeEventListener("abort",c),i(o)};r.addEventListener(e,a),t?.addEventListener("abort",c)})}var Xo=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=t??"ABORT_ERR"}};async function tl(r,e,t){if(e==null)return r;if(e.aborted)return Promise.reject(new Xo(t?.errorMessage,t?.errorCode));let n,o=new Xo(t?.errorMessage,t?.errorCode);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var Qo=class{deferred;signal;where;constructor(e,t){this.signal=t,this.deferred=Ie(),this.where=e,this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(new ar)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function T0(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var es=class{id;fn;options;priority;recipients;status;timeline;controller;constructor(e,t,n=0){this.id=T0(),this.status="queued",this.fn=e,this.priority=n,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,Qr(1/0,this.controller.signal),this.onAbort=this.onAbort.bind(this)}abort(e){this.controller.abort(e)}onAbort(){this.recipients.reduce((t,n)=>t&&n.signal?.aborted===!0,!0)&&this.controller.abort(new ar)}async join(e={}){let t=new Qo(new Error("where").stack,e.signal);return this.recipients.push(t),e.signal?.addEventListener("abort",this.onAbort),t.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let e=await tl(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(t=>{t.deferred.resolve(e)}),this.status="complete"}catch(e){this.recipients.forEach(t=>{t.deferred.reject(e)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(e=>{e.signal?.removeEventListener("abort",this.onAbort)})}};function N0(r,e,t){let n=0,o=r.length;for(;o>0;){let s=Math.trunc(o/2),i=n+s;t(r[i],e)<=0?(n=++i,o-=s+1):o=s}return n}var Dr=class extends Yo{concurrency;queue;pending;constructor(e={}){super(),this.concurrency=e.concurrency??Number.POSITIVE_INFINITY,this.pending=0,e.metricName!=null&&e.metrics?.registerMetricGroup(e.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 e;for(let t of this.queue)if(t.status==="queued"){e=t;break}return e==null?!1:(this.safeDispatchEvent("active"),this.pending++,e.run().finally(()=>{for(let t=0;t<this.queue.length;t++)if(this.queue[t]===e){this.queue.splice(t,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(e){if(this.queue[this.size-1]?.priority>=e.priority){this.queue.push(e);return}let t=N0(this.queue,e,(n,o)=>o.priority-n.priority);this.queue.splice(t,0,e)}async add(e,t){t?.signal?.throwIfAborted();let n=new es(e,t,t?.priority),o=n.join(t).then(s=>(this.safeDispatchEvent("completed",{detail:s}),s)).catch(s=>{throw this.safeDispatchEvent("error",{detail:s}),s});return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),o}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(e=>{e.abort(new ar)}),this.clear()}async onEmpty(e){this.size!==0&&await Jo(this,"empty",e?.signal)}async onSizeLessThan(e,t){this.size<e||await Jo(this,"next",t?.signal,{filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await Jo(this,"idle",e?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(e){e?.signal?.throwIfAborted();let t=Ot({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),t.end(c)},o=c=>{c.detail!=null&&t.push(c.detail)},s=c=>{n(c.detail)},i=()=>{n()},a=()=>{n(new N("Queue aborted","ERR_QUEUE_ABORTED"))};this.addEventListener("completed",o),this.addEventListener("error",s),this.addEventListener("idle",i),e?.signal?.addEventListener("abort",a);try{yield*t}finally{this.removeEventListener("completed",o),this.removeEventListener("error",s),this.removeEventListener("idle",i),e?.signal?.removeEventListener("abort",a),n()}}};var ts=class extends Dr{has(e){return this.find(e)!=null}find(e){return this.queue.find(t=>e.equals(t.options.peerId))}};var rs=class{index=0;input="";new(e){return this.index=0,this.input=e,this}readAtomically(e){let t=this.index,n=e();return n===void 0&&(this.index=t),n}parseWith(e){let t=e();if(this.index===this.input.length)return t}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(e){return this.readAtomically(()=>{let t=this.readChar();if(t===e)return t})}readSeparator(e,t,n){return this.readAtomically(()=>{if(!(t>0&&this.readGivenChar(e)===void 0))return n()})}readNumber(e,t,n,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",f=2**(8*o)-1;for(;;){let u=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let h=Number.parseInt(l,e);if(!Number.isNaN(h))return h});if(u===void 0)break;if(s*=e,s+=u,s>f||(i+=1,t!==void 0&&i>t))return}if(i!==0)return!n&&c&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let e=new Uint8Array(4);for(let t=0;t<e.length;t++){let n=this.readSeparator(".",t,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;e[t]=n}return e})}readIPv6Addr(){let e=t=>{for(let n=0;n<t.length/2;n++){let o=n*2;if(n<t.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return t[o]=i[0],t[o+1]=i[1],t[o+2]=i[2],t[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];t[o]=s>>8,t[o+1]=s&255}return[t.length,!1]};return this.readAtomically(()=>{let t=new Uint8Array(16),[n,o]=e(t);if(n===16)return t;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=e(s.subarray(0,i));return t.set(s.subarray(0,a),16-a),t})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var rl=45,C0=15,tn=new rs;function wa(r){if(!(r.length>C0))return tn.new(r).parseWith(()=>tn.readIPv4Addr())}function ba(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>rl))return tn.new(r).parseWith(()=>tn.readIPv6Addr())}function ns(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>rl))return tn.new(r).parseWith(()=>tn.readIPAddr())}function rn(r){return!!wa(r)}function nn(r){return!!ba(r)}function os(r){return!!ns(r)}var Ba={};xe(Ba,{base58btc:()=>fe,base58flickr:()=>F0});var c1=new Uint8Array(0);function nl(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function Ft(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 ol(r){return new TextEncoder().encode(r)}function sl(r){return new TextDecoder().decode(r)}function L0(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(t[i]!==255)throw new TypeError(s+" is ambiguous");t[i]=o}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(y){if(y instanceof Uint8Array||(ArrayBuffer.isView(y)?y=new Uint8Array(y.buffer,y.byteOffset,y.byteLength):Array.isArray(y)&&(y=Uint8Array.from(y))),!(y instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(y.length===0)return"";for(var p=0,m=0,w=0,I=y.length;w!==I&&y[w]===0;)w++,p++;for(var v=(I-w)*u+1>>>0,U=new Uint8Array(v);w!==I;){for(var S=y[w],_=0,L=v-1;(S!==0||_<m)&&L!==-1;L--,_++)S+=256*U[L]>>>0,U[L]=S%a>>>0,S=S/a>>>0;if(S!==0)throw new Error("Non-zero carry");m=_,w++}for(var b=v-m;b!==v&&U[b]===0;)b++;for(var C=c.repeat(p);b<v;++b)C+=r.charAt(U[b]);return C}function h(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var p=0;if(y[p]!==" "){for(var m=0,w=0;y[p]===c;)m++,p++;for(var I=(y.length-p)*f+1>>>0,v=new Uint8Array(I);y[p];){var U=t[y.charCodeAt(p)];if(U===255)return;for(var S=0,_=I-1;(U!==0||S<w)&&_!==-1;_--,S++)U+=a*v[_]>>>0,v[_]=U%256>>>0,U=U/256>>>0;if(U!==0)throw new Error("Non-zero carry");w=S,p++}if(y[p]!==" "){for(var L=I-w;L!==I&&v[L]===0;)L++;for(var b=new Uint8Array(m+(I-L)),C=m;L!==I;)b[C++]=v[L++];return b}}}function g(y){var p=h(y);if(p)return p;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:h,decode:g}}var U0=L0,D0=U0,al=D0;var xa=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},Ea=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){if(this.name=e,this.prefix=t,t.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=t.codePointAt(0),this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return cl(this,e)}},va=class{decoders;constructor(e){this.decoders=e}or(e){return cl(this,e)}decode(e){let t=e[0],n=this.decoders[t];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function cl(r,e){return new va({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var Aa=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,o){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=o,this.encoder=new xa(e,t,n),this.decoder=new Ea(e,t,o)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function on({name:r,prefix:e,encode:t,decode:n}){return new Aa(r,e,t,n)}function lr({name:r,prefix:e,alphabet:t}){let{encode:n,decode:o}=al(t,r);return on({prefix:e,name:r,encode:n,decode:s=>Ft(o(s))})}function P0(r,e,t,n){let o={};for(let u=0;u<e.length;++u)o[e[u]]=u;let s=r.length;for(;r[s-1]==="=";)--s;let i=new Uint8Array(s*t/8|0),a=0,c=0,f=0;for(let u=0;u<s;++u){let l=o[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<t|l,a+=t,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=t||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function O0(r,e,t){let n=e[e.length-1]==="=",o=(1<<t)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,s+=e[o&a>>i];if(i!==0&&(s+=e[o&a<<t-i]),n)for(;s.length*t&7;)s+="=";return s}function de({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return on({prefix:e,name:r,encode(o){return O0(o,n,t)},decode(o){return P0(o,n,t,r)}})}var fe=lr({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),F0=lr({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var ka={};xe(ka,{base32:()=>Re,base32hex:()=>$0,base32hexpad:()=>K0,base32hexpadupper:()=>q0,base32hexupper:()=>H0,base32pad:()=>V0,base32padupper:()=>M0,base32upper:()=>ul,base32z:()=>z0});var Re=de({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ul=de({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),V0=de({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),M0=de({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),$0=de({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),H0=de({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),K0=de({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),q0=de({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),z0=de({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var G0=hl,ll=128,j0=127,W0=~j0,Y0=Math.pow(2,31);function hl(r,e,t){e=e||[],t=t||0;for(var n=t;r>=Y0;)e[t++]=r&255|ll,r/=128;for(;r&W0;)e[t++]=r&255|ll,r>>>=7;return e[t]=r|0,hl.bytes=t-n+1,e}var Z0=Sa,J0=128,fl=127;function Sa(r,n){var t=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw Sa.bytes=0,new RangeError("Could not decode varint");i=r[s++],t+=o<28?(i&fl)<<o:(i&fl)*Math.pow(2,o),o+=7}while(i>=J0);return Sa.bytes=s-n,t}var X0=Math.pow(2,7),Q0=Math.pow(2,14),em=Math.pow(2,21),tm=Math.pow(2,28),rm=Math.pow(2,35),nm=Math.pow(2,42),om=Math.pow(2,49),sm=Math.pow(2,56),im=Math.pow(2,63),am=function(r){return r<X0?1:r<Q0?2:r<em?3:r<tm?4:r<rm?5:r<nm?6:r<om?7:r<sm?8:r<im?9:10},cm={encode:G0,decode:Z0,encodingLength:am},um=cm,ro=um;function no(r,e=0){return[ro.decode(r,e),ro.decode.bytes]}function sn(r,e,t=0){return ro.encode(r,e,t),e}function an(r){return ro.encodingLength(r)}function At(r,e){let t=e.byteLength,n=an(r),o=n+an(t),s=new Uint8Array(o+t);return sn(r,s,0),sn(t,s,n),s.set(e,o),new cn(r,t,e,s)}function Bt(r){let e=Ft(r),[t,n]=no(e),[o,s]=no(e.subarray(n)),i=e.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new cn(t,o,i,e)}function dl(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&nl(r.bytes,t.bytes)}}var cn=class{code;size;digest;bytes;constructor(e,t,n,o){this.code=e,this.size=t,this.digest=n,this.bytes=o}};function pl(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return fm(t,Ia(r),e??fe.encoder);default:return hm(t,Ia(r),e??Re.encoder)}}var ml=new WeakMap;function Ia(r){let e=ml.get(r);if(e==null){let t=new Map;return ml.set(r,t),t}return e}var oe=class r{code;version;multihash;bytes;"/";constructor(e,t,n,o){this.code=t,this.version=e,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:e,multihash:t}=this;if(e!==oo)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==dm)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:e,digest:t}=this.multihash,n=At(e,t);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&dl(e.multihash,n.multihash)}toString(e){return pl(this,e)}toJSON(){return{"/":pl(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:o,multihash:s,bytes:i}=t;return new r(n,o,s,i??yl(n,o,s.bytes))}else if(t[pm]===!0){let{version:n,multihash:o,code:s}=t,i=Bt(o);return r.create(n,s,i)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==oo)throw new Error(`Version 0 CID must use dag-pb (code: ${oo}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let o=yl(e,t,n.bytes);return new r(e,t,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,oo,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,o=Ft(e.subarray(n,n+t.multihashSize));if(o.byteLength!==t.multihashSize)throw new Error("Incorrect length");let s=o.subarray(t.multihashSize-t.digestSize),i=new cn(t.multihashCode,t.digestSize,s,o);return[t.version===0?r.createV0(i):r.createV1(t.codec,i),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[l,h]=no(e.subarray(t));return t+=h,l},o=n(),s=oo;if(o===18?(o=0,t=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=t,a=n(),c=n(),f=t+c,u=f-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(e,t){let[n,o]=lm(e,t),s=r.decode(o);if(s.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Ia(s).set(n,e),s}};function lm(r,e){switch(r[0]){case"Q":{let t=e??fe;return[fe.prefix,t.decode(`${fe.prefix}${r}`)]}case fe.prefix:{let t=e??fe;return[fe.prefix,t.decode(r)]}case Re.prefix:{let t=e??Re;return[Re.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function fm(r,e,t){let{prefix:n}=t;if(n!==fe.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let o=e.get(n);if(o==null){let s=t.encode(r).slice(1);return e.set(n,s),s}else return o}function hm(r,e,t){let{prefix:n}=t,o=e.get(n);if(o==null){let s=t.encode(r);return e.set(n,s),s}else return o}var oo=112,dm=18;function yl(r,e,t){let n=an(r),o=n+an(e),s=new Uint8Array(o+t.byteLength);return sn(r,s,0),sn(e,s,n),s.set(t,o),s}var pm=Symbol.for("@ipld/js-cid/CID");function ce(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}var Ra={};xe(Ra,{base10:()=>mm});var mm=lr({prefix:"9",name:"base10",alphabet:"0123456789"});var _a={};xe(_a,{base16:()=>ym,base16upper:()=>gm});var ym=de({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),gm=de({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ta={};xe(Ta,{base2:()=>wm});var wm=de({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Na={};xe(Na,{base256emoji:()=>Am});var gl=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=gl.reduce((r,e,t)=>(r[t]=e,r),[]),xm=gl.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function Em(r){return r.reduce((e,t)=>(e+=bm[t],e),"")}function vm(r){let e=[];for(let t of r){let n=xm[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var Am=on({prefix:"\u{1F680}",name:"base256emoji",encode:Em,decode:vm});var Ca={};xe(Ca,{base36:()=>fr,base36upper:()=>Bm});var fr=lr({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Bm=lr({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ua={};xe(Ua,{base64:()=>hr,base64pad:()=>km,base64url:()=>La,base64urlpad:()=>Sm});var hr=de({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),km=de({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),La=de({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Sm=de({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Da={};xe(Da,{base8:()=>Im});var Im=de({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Pa={};xe(Pa,{identity:()=>Rm});var Rm=on({prefix:"\0",name:"identity",encode:r=>sl(r),decode:r=>ol(r)});var L1=new TextEncoder,U1=new TextDecoder;var wl=512;var is=85;var Fa={};xe(Fa,{identity:()=>st});var xl=0,_m="identity",El=Ft;function Tm(r){return At(xl,El(r))}var st={code:xl,name:_m,encode:El,digest:Tm};var Ha={};xe(Ha,{sha256:()=>Ee,sha512:()=>$a});function Ma({name:r,code:e,encode:t}){return new Va(r,e,t)}var Va=class{name;code;encode;constructor(e,t,n){this.name=e,this.code=t,this.encode=n}digest(e){if(e instanceof Uint8Array){let t=this.encode(e);return t instanceof Uint8Array?At(this.code,t):t.then(n=>At(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Al(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var Ee=Ma({name:"sha2-256",code:18,encode:Al("SHA-256")}),$a=Ma({name:"sha2-512",code:19,encode:Al("SHA-512")});var dr={...Pa,...Ta,...Da,...Ra,..._a,...ka,...Ca,...Ba,...Ua,...Na},j1={...Ha,...Fa};function dt(r=0){return new Uint8Array(r)}function kl(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var Bl=kl("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Ka=kl("ascii","a",r=>{let e="a";for(let t=0;t<r.length;t++)e+=String.fromCharCode(r[t]);return e},r=>{r=r.substring(1);let e=dt(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),Nm={utf8:Bl,"utf-8":Bl,hex:dr.base16,latin1:Ka,ascii:Ka,binary:Ka,...dr},as=Nm;function z(r,e="utf8"){let t=as[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var Cm=Math.pow(2,7),Lm=Math.pow(2,14),Um=Math.pow(2,21),qa=Math.pow(2,28),za=Math.pow(2,35),Ga=Math.pow(2,42),ja=Math.pow(2,49),se=128,Ue=127;function Ke(r){if(r<Cm)return 1;if(r<Lm)return 2;if(r<Um)return 3;if(r<qa)return 4;if(r<za)return 5;if(r<Ga)return 6;if(r<ja)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Wa(r,e,t=0){switch(Ke(r)){case 8:e[t++]=r&255|se,r/=128;case 7:e[t++]=r&255|se,r/=128;case 6:e[t++]=r&255|se,r/=128;case 5:e[t++]=r&255|se,r/=128;case 4:e[t++]=r&255|se,r>>>=7;case 3:e[t++]=r&255|se,r>>>=7;case 2:e[t++]=r&255|se,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function Dm(r,e,t=0){switch(Ke(r)){case 8:e.set(t++,r&255|se),r/=128;case 7:e.set(t++,r&255|se),r/=128;case 6:e.set(t++,r&255|se),r/=128;case 5:e.set(t++,r&255|se),r/=128;case 4:e.set(t++,r&255|se),r>>>=7;case 3:e.set(t++,r&255|se),r>>>=7;case 2:e.set(t++,r&255|se),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function Ya(r,e){let t=r[e],n=0;if(n+=t&Ue,t<se||(t=r[e+1],n+=(t&Ue)<<7,t<se)||(t=r[e+2],n+=(t&Ue)<<14,t<se)||(t=r[e+3],n+=(t&Ue)<<21,t<se)||(t=r[e+4],n+=(t&Ue)*qa,t<se)||(t=r[e+5],n+=(t&Ue)*za,t<se)||(t=r[e+6],n+=(t&Ue)*Ga,t<se)||(t=r[e+7],n+=(t&Ue)*ja,t<se))return n;throw new RangeError("Could not decode varint")}function Pm(r,e){let t=r.get(e),n=0;if(n+=t&Ue,t<se||(t=r.get(e+1),n+=(t&Ue)<<7,t<se)||(t=r.get(e+2),n+=(t&Ue)<<14,t<se)||(t=r.get(e+3),n+=(t&Ue)<<21,t<se)||(t=r.get(e+4),n+=(t&Ue)*qa,t<se)||(t=r.get(e+5),n+=(t&Ue)*za,t<se)||(t=r.get(e+6),n+=(t&Ue)*Ga,t<se)||(t=r.get(e+7),n+=(t&Ue)*ja,t<se))return n;throw new RangeError("Could not decode varint")}function un(r,e,t=0){return e==null&&(e=dt(Ke(r))),e instanceof Uint8Array?Wa(r,e,t):Dm(r,e,t)}function Pr(r,e=0){return r instanceof Uint8Array?Ya(r,e):Pm(r,e)}function Fe(r,e){e==null&&(e=r.reduce((o,s)=>o+s.length,0));let t=dt(e),n=0;for(let o of r)t.set(o,n),n+=o.length;return t}var dE=parseInt("0xFFFF",16),pE=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function Y(r,e="utf8"){let t=as[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}var _l=rn,$m=nn,Za=function(r){let e=0;if(r=r.toString().trim(),_l(r)){let t=new Uint8Array(e+4);return r.split(/\./g).forEach(n=>{t[e++]=parseInt(n,10)&255}),t}if($m(r)){let t=r.split(":",8),n;for(n=0;n<t.length;n++){let s=_l(t[n]),i;s&&(i=Za(t[n]),t[n]=z(i.slice(0,2),"base16")),i!=null&&++n<8&&t.splice(n,0,z(i.slice(2,4),"base16"))}if(t[0]==="")for(;t.length<8;)t.unshift("0");else if(t[t.length-1]==="")for(;t.length<8;)t.push("0");else if(t.length<8){for(n=0;n<t.length&&t[n]!=="";n++);let s=[n,1];for(n=9-t.length;n>0;n--)s.push("0");t.splice.apply(t,s)}let o=new Uint8Array(e+16);for(n=0;n<t.length;n++){let s=parseInt(t[n],16);o[e++]=s>>8&255,o[e++]=s&255}return o}throw new Error("invalid ip address")},Tl=function(r,e=0,t){e=~~e,t=t??r.length-e;let n=new DataView(r.buffer);if(t===4){let o=[];for(let s=0;s<t;s++)o.push(r[e+s]);return o.join(".")}if(t===16){let o=[];for(let s=0;s<t;s+=2)o.push(n.getUint16(e+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var ln={},Ja={},Km=[[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"]];Km.forEach(r=>{let e=qm(...r);Ja[e.code]=e,ln[e.name]=e});function qm(r,e,t,n,o){return{code:r,size:e,name:t,resolvable:!!n,path:!!o}}function G(r){if(typeof r=="number"){if(Ja[r]!=null)return Ja[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(ln[r]!=null)return ln[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var JE=G("ip4"),XE=G("ip6"),QE=G("ipcidr");function Qa(r,e){switch(G(r).code){case 4:case 41:return Gm(e);case 42:return Ll(e);case 6:case 273:case 33:case 132:return Dl(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ll(e);case 421:return Zm(e);case 444:return Ul(e);case 445:return Ul(e);case 466:return Ym(e);default:return z(e,"base16")}}function ec(r,e){switch(G(r).code){case 4:return Nl(e);case 41:return Nl(e);case 42:return Cl(e);case 6:case 273:case 33:case 132:return tc(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Cl(e);case 421:return jm(e);case 444:return Jm(e);case 445:return Xm(e);case 466:return Wm(e);default:return Y(e,"base16")}}var Xa=Object.values(dr).map(r=>r.decoder),zm=function(){let r=Xa[0].or(Xa[1]);return Xa.slice(2).forEach(e=>r=r.or(e)),r}();function Nl(r){if(!os(r))throw new Error("invalid ip address");return Za(r)}function Gm(r){let e=Tl(r,0,r.length);if(e==null)throw new Error("ipBuff is required");if(!os(e))throw new Error("invalid ip address");return e}function tc(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,r),new Uint8Array(e)}function Dl(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Cl(r){let e=Y(r),t=Uint8Array.from(un(e.length));return Fe([t,e],t.length+e.length)}function Ll(r){let e=Pr(r);if(r=r.slice(Ke(e)),r.length!==e)throw new Error("inconsistent lengths");return z(r)}function jm(r){let e;r[0]==="Q"||r[0]==="1"?e=Bt(fe.decode(`z${r}`)).bytes:e=oe.parse(r).multihash.bytes;let t=Uint8Array.from(un(e.length));return Fe([t,e],t.length+e.length)}function Wm(r){let e=zm.decode(r),t=Uint8Array.from(un(e.length));return Fe([t,e],t.length+e.length)}function Ym(r){let e=Pr(r),t=r.slice(Ke(e));if(t.length!==e)throw new Error("inconsistent lengths");return"u"+z(t,"base64url")}function Zm(r){let e=Pr(r),t=r.slice(Ke(e));if(t.length!==e)throw new Error("inconsistent lengths");return z(t,"base58btc")}function Jm(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==16)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion address.`);let t=Re.decode("b"+e[0]),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=tc(n);return Fe([t,o],t.length+o.length)}function Xm(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==56)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion3 address.`);let t=Re.decode(`b${e[0]}`),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=tc(n);return Fe([t,o],t.length+o.length)}function Ul(r){let e=r.slice(0,r.length-2),t=r.slice(r.length-2),n=z(e,"base32"),o=Dl(t);return`${n}:${o}`}function Pl(r){r=rc(r);let e=[],t=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=G(i);if(a.size===0){e.push([a.code]),t.push([a.code]);continue}if(s++,s>=o.length)throw Fl("invalid address: "+r);if(a.path===!0){n=rc(o.slice(s).join("/")),e.push([a.code,ec(a.code,n)]),t.push([a.code,n]);break}let c=ec(a.code,o[s]);e.push([a.code,c]),t.push([a.code,Qa(a.code,c)])}return{string:Ol(t),bytes:oc(e),tuples:e,stringTuples:t,path:n}}function nc(r){let e=[],t=[],n=null,o=0;for(;o<r.length;){let s=Pr(r,o),i=Ke(s),a=G(s),c=Qm(a,r.slice(o+i));if(c===0){e.push([s]),t.push([s]),o+=i;continue}let f=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw Fl("Invalid address Uint8Array: "+z(r,"base16"));e.push([s,f]);let u=Qa(s,f);if(t.push([s,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:Ol(t),tuples:e,stringTuples:t,path:n}}function Ol(r){let e=[];return r.map(t=>{let n=G(t[0]);return e.push(n.name),t.length>1&&t[1]!=null&&e.push(t[1]),null}),rc(e.join("/"))}function oc(r){return Fe(r.map(e=>{let t=G(e[0]),n=Uint8Array.from(un(t.code));return e.length>1&&e[1]!=null&&(n=Fe([n,e[1]])),n}))}function Qm(r,e){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let t=Pr(e instanceof Uint8Array?e:Uint8Array.from(e));return t+Ke(t)}}function rc(r){return"/"+r.trim().split("/").filter(e=>e).join("/")}function Fl(r){return new Error("Error parsing address: "+r)}var ey=Symbol.for("nodejs.util.inspect.custom"),sc=Symbol.for("@multiformats/js-multiaddr/multiaddr"),ty=[G("dns").code,G("dns4").code,G("dns6").code,G("dnsaddr").code],cs=class r{bytes;#e;#t;#r;#i;[sc]=!0;constructor(e){e==null&&(e="");let t;if(e instanceof Uint8Array)t=nc(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);t=Pl(e)}else if(Ml(e))t=nc(e.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=t.bytes,this.#e=t.string,this.#t=t.tuples,this.#r=t.stringTuples,this.#i=t.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let e,t,n,o,s="",i=G("tcp"),a=G("udp"),c=G("ip4"),f=G("ip6"),u=G("dns6"),l=G("ip6zone");for(let[g,y]of this.stringTuples())g===l.code&&(s=`%${y??""}`),ty.includes(g)&&(t=i.name,o=443,n=`${y??""}${s}`,e=g===u.code?6:4),(g===i.code||g===a.code)&&(t=G(g).name,o=parseInt(y??"")),(g===c.code||g===f.code)&&(t=G(g).name,n=`${y??""}${s}`,e=g===f.code?6:4);if(e==null||t==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:e,host:n,transport:t,port:o}}protos(){return this.#t.map(([e])=>Object.assign({},G(e)))}protoCodes(){return this.#t.map(([e])=>e)}protoNames(){return this.#t.map(([e])=>G(e).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(e){return e=new r(e),new r(this.toString()+e.toString())}decapsulate(e){let t=e.toString(),n=this.toString(),o=n.lastIndexOf(t);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${e.toString()}`);return new r(n.slice(0,o))}decapsulateCode(e){let t=this.tuples();for(let n=t.length-1;n>=0;n--)if(t[n][0]===e)return new r(oc(t.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,o])=>{n===ln.p2p.code&&e.push([n,o]),n===ln["p2p-circuit"].code&&(e=[])});let t=e.pop();if(t?.[1]!=null){let n=t[1];return n[0]==="Q"||n[0]==="1"?z(fe.decode(`z${n}`),"base58btc"):z(oe.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#i}equals(e){return ce(this.bytes,e.bytes)}async resolve(e){let t=this.protos().find(s=>s.resolvable);if(t==null)return[this];let n=Vl.get(t.name);if(n==null)throw new N(`no available resolver for ${t.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,e)).map(s=>Or(s))}nodeAddress(){let e=this.toOptions();if(e.transport!=="tcp"&&e.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${e.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:e.family,address:e.host,port:e.port}}isThinWaistAddress(e){let t=(e??this).protos();return!(t.length!==2||t[0].code!==4&&t[0].code!==41||t[1].code!==6&&t[1].code!==273)}[ey](){return`Multiaddr(${this.#e})`}};var Vl=new Map;function Ml(r){return!!r?.[sc]}function Or(r){return new cs(r)}var ry=r=>r.toString().split("/").slice(1),so=r=>({match:e=>e.length<1?!1:r(e[0])?e.slice(1):!1,pattern:"fn"}),re=r=>({match:e=>so(t=>t===r).match(e),pattern:r}),fs=()=>({match:r=>so(e=>typeof e=="string").match(r),pattern:"{string}"}),hs=()=>({match:r=>so(e=>!isNaN(parseInt(e))).match(r),pattern:"{number}"}),_e=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{fe.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),us=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{La.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),Ve=r=>({match:e=>{let t=r.match(e);return t===!1?e:t},pattern:`optional(${r.pattern})`}),Ge=(...r)=>({match:e=>{let t;for(let n of r){let o=n.match(e);o!==!1&&(t==null||o.length<t.length)&&(t=o)}return t??!1},pattern:`or(${r.map(e=>e.pattern).join(", ")})`}),ie=(...r)=>({match:e=>{for(let t of r){let n=t.match(e);if(n===!1)return!1;e=n}return e},pattern:`and(${r.map(e=>e.pattern).join(", ")})`});function me(...r){function e(o){let s=ry(o);for(let i of r){let a=i.match(s);if(a===!1)return!1;s=a}return s}function t(o){return e(o)!==!1}function n(o){let s=e(o);return s===!1?!1:s.length===0}return{matches:t,exactMatch:n}}var ac=ie(re("dns4"),fs()),cc=ie(re("dns6"),fs()),uc=ie(re("dnsaddr"),fs()),$l=ie(re("dns"),fs()),Rv=me(ac),_v=me(cc),Tv=me(uc),Hl=me(Ge($l,uc,ac,cc)),Kl=ie(re("ip4"),so(rn)),ql=ie(re("ip6"),so(nn)),zl=Ge(Kl,ql),kt=Ge(zl,$l,ac,cc,uc),Nv=me(kt),Cv=me(Kl),Lv=me(ql),Uv=me(zl),ds=ie(kt,re("tcp"),hs()),io=ie(kt,re("udp"),hs()),ny=Ge(ds,io),Dv=me(ds),Pv=me(io),lc=ie(io,re("quic")),ps=ie(io,re("quic-v1")),oy=Ge(lc,ps),Ov=me(lc),Fv=me(ps),ic=Ge(kt,ds,io,lc,ps),Gl=Ge(ie(ic,re("ws"),Ve(_e()))),Vv=me(Gl),jl=Ge(ie(ic,re("wss"),Ve(_e())),ie(ic,re("tls"),re("ws"),Ve(_e()))),Mv=me(jl),Wl=ie(ny,re("webrtc-direct"),us(),Ve(us()),Ve(_e())),$v=me(Wl),Yl=ie(ps,re("webtransport"),us(),us(),Ve(_e())),Hv=me(Yl),ls=Ge(Gl,jl,ie(ds,Ve(_e())),ie(oy,Ve(_e())),ie(kt,Ve(_e())),Wl,Yl,_e()),Kv=me(ls),sy=ie(ls,re("p2p-circuit"),_e()),qv=me(sy),iy=Ge(ie(ls,re("p2p-circuit"),re("webrtc"),_e()),ie(ls,re("webrtc"),Ve(_e())),re("webrtc")),zv=me(iy),ay=Ge(ie(kt,re("tcp"),hs(),re("http"),Ve(_e())),ie(kt,re("http"),Ve(_e()))),Zl=me(ay),cy=Ge(ie(kt,re("tcp"),Ge(ie(re("443"),re("http")),ie(hs(),re("https"))),Ve(_e())),ie(kt,re("tls"),re("http"),Ve(_e())),ie(kt,re("https"),Ve(_e()))),Jl=me(cy);function Ey(r){return r[Symbol.asyncIterator]!=null}function vy(r){if(Ey(r))return(async()=>{for await(let e of r);})();for(let e of r);}var Mt=vy;function By(r){let[e,t]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>e.next(),push:o=>{n.push(o)},next:()=>n.length>0?{done:!1,value:n.shift()}:e.next(),[t](){return this}}}var mn=By;function ky(r){return r[Symbol.asyncIterator]!=null}function Sy(r,e){if(ky(r))return async function*(){for await(let a of r)yield e(a)}();let t=mn(r),{value:n,done:o}=t.next();if(o===!0)return function*(){}();let s=e(n);if(typeof s.then=="function")return async function*(){yield await s;for await(let a of t)yield e(a)}();let i=e;return function*(){yield s;for(let a of t)yield i(a)}()}var yn=Sy;function Iy(r){return r[Symbol.asyncIterator]!=null}function Ry(...r){let e=[];for(let t of r)Iy(t)||e.push(t);return e.length===r.length?function*(){for(let t of e)yield*t}():async function*(){let t=Ot({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let o of n)t.push(o)})),t.end()}catch(n){t.end(n)}}),yield*t}()}var pr=Ry;function _y(r){return r[Symbol.asyncIterator]!=null}function Ty(r,e){return _y(r)?async function*(){let t=0;if(!(e<1)){for await(let n of r)if(yield n,t++,t===e)return}}():function*(){let t=0;if(!(e<1)){for(let n of r)if(yield n,t++,t===e)return}}()}var gs=Ty;var ne=class extends Event{constructor(e,t){super(e),this.detail=t}};var fc=new Float32Array([-0]),mr=new Uint8Array(fc.buffer);function sf(r,e,t){fc[0]=r,e[t]=mr[0],e[t+1]=mr[1],e[t+2]=mr[2],e[t+3]=mr[3]}function af(r,e){return mr[0]=r[e],mr[1]=r[e+1],mr[2]=r[e+2],mr[3]=r[e+3],fc[0]}var hc=new Float64Array([-0]),De=new Uint8Array(hc.buffer);function cf(r,e,t){hc[0]=r,e[t]=De[0],e[t+1]=De[1],e[t+2]=De[2],e[t+3]=De[3],e[t+4]=De[4],e[t+5]=De[5],e[t+6]=De[6],e[t+7]=De[7]}function uf(r,e){return De[0]=r[e],De[1]=r[e+1],De[2]=r[e+2],De[3]=r[e+3],De[4]=r[e+4],De[5]=r[e+5],De[6]=r[e+6],De[7]=r[e+7],hc[0]}var Ny=BigInt(Number.MAX_SAFE_INTEGER),Cy=BigInt(Number.MIN_SAFE_INTEGER),We=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return Vr;if(e<Ny&&e>Cy)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,o=e-(n<<32n);return t&&(n=~n|0n,o=~o|0n,++o>lf&&(o=0n,++n>lf&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(e){if(e===0)return Vr;let t=e<0;t&&(e=-e);let n=e>>>0,o=(e-n)/4294967296>>>0;return t&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new r(n,o)}static from(e){return typeof e=="number"?r.fromNumber(e):typeof e=="bigint"?r.fromBigInt(e):typeof e=="string"?r.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new r(e.low>>>0,e.high>>>0):Vr}},Vr=new We(0,0);Vr.toBigInt=function(){return 0n};Vr.zzEncode=Vr.zzDecode=function(){return this};Vr.length=function(){return 1};var lf=4294967296n;function ff(r){let e=0,t=0;for(let n=0;n<r.length;++n)t=r.charCodeAt(n),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,e+=4):e+=3;return e}function hf(r,e,t){if(t-e<1)return"";let o,s=[],i=0,a;for(;e<t;)a=r[e++],a<128?s[i++]=a:a>191&&a<224?s[i++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&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 dc(r,e,t){let n=t,o,s;for(let i=0;i<r.length;++i)o=r.charCodeAt(i),o<128?e[t++]=o:o<2048?(e[t++]=o>>6|192,e[t++]=o&63|128):(o&64512)===55296&&((s=r.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,e[t++]=o>>18|240,e[t++]=o>>12&63|128,e[t++]=o>>6&63|128,e[t++]=o&63|128):(e[t++]=o>>12|224,e[t++]=o>>6&63|128,e[t++]=o&63|128);return t-n}function pt(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function ws(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var pc=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,pt(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw pt(this,4);return ws(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw pt(this,4);return ws(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw pt(this,4);let e=af(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw pt(this,4);let e=uf(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,n=this.pos+e;if(n>this.len)throw pt(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return hf(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw pt(this,e);this.pos+=e}else do if(this.pos>=this.len)throw pt(this);while(this.buf[this.pos++]&128);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new We(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw pt(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw pt(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw pt(this,8);let e=ws(this.buf,this.pos+=4),t=ws(this.buf,this.pos+=4);return new We(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=Ya(this.buf,this.pos);return this.pos+=Ke(e),e}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function mc(r){return new pc(r instanceof Uint8Array?r:r.subarray())}function gn(r,e,t){let n=mc(r);return e.decode(n,void 0,t)}function yc(r){let e=r??8192,t=e>>>1,n,o=e;return function(i){if(i<1||i>t)return dt(i);o+i>e&&(n=dt(e),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(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function gc(){}var bc=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},Ly=yc();function Uy(r){return globalThis.Buffer!=null?dt(r):Ly(r)}var co=class{len;head;tail;states;constructor(){this.len=0,this.head=new Mr(gc,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new Mr(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new xc((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(bs,10,We.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=We.fromBigInt(e);return this._push(bs,t.length(),t)}uint64Number(e){return this._push(Wa,Ke(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=We.fromBigInt(e).zzEncode();return this._push(bs,t.length(),t)}sint64Number(e){let t=We.fromNumber(e).zzEncode();return this._push(bs,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(wc,1,e?1:0)}fixed32(e){return this._push(ao,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=We.fromBigInt(e);return this._push(ao,4,t.lo)._push(ao,4,t.hi)}fixed64Number(e){let t=We.fromNumber(e);return this._push(ao,4,t.lo)._push(ao,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push(sf,4,e)}double(e){return this._push(cf,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(wc,1,0):this.uint32(t)._push(Py,t,e)}string(e){let t=ff(e);return t!==0?this.uint32(t)._push(dc,t,e):this._push(wc,1,0)}fork(){return this.states=new bc(this),this.head=this.tail=new Mr(gc,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(gc,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=e.next,this.tail=t,this.len+=n),this}finish(){let e=this.head.next,t=Uy(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function wc(r,e,t){e[t]=r&255}function Dy(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var xc=class extends Mr{next;constructor(e,t){super(Dy,e,t),this.next=void 0}};function bs(r,e,t){for(;r.hi!==0;)e[t++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)e[t++]=r.lo&127|128,r.lo=r.lo>>>7;e[t++]=r.lo}function ao(r,e,t){e[t]=r&255,e[t+1]=r>>>8&255,e[t+2]=r>>>16&255,e[t+3]=r>>>24}function Py(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(co.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(Oy,e,r),this},co.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(Fy,e,r),this});function Oy(r,e,t){e.set(r,t)}function Fy(r,e,t){r.length<40?dc(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(Y(r),t)}function Ec(){return new co}function wn(r,e){let t=Ec();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var bn;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(bn||(bn={}));function xs(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function uo(r){function e(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let t=function(s,i){let a=e(s);i.int32(a)},n=function(s){let i=s.int32();return e(i)};return xs("enum",bn.VARINT,t,n)}function xn(r,e){return xs("message",bn.LENGTH_DELIMITED,r,e)}var Vy=Symbol.for("nodejs.util.inspect.custom"),pf=Object.values(dr).map(r=>r.decoder).reduce((r,e)=>r.or(e),dr.identity.decoder),mf=114,vc=36,Ac=37,lo=class{type;multihash;privateKey;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,this.privateKey=e.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[pa]=!0;toString(){return this.string==null&&(this.string=fe.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return oe.createV1(mf,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return ce(this.multihash.bytes,e);if(typeof e=="string")return Bc(e).equals(this);if(e?.multihash?.bytes!=null)return ce(this.multihash.bytes,e.multihash.bytes);throw new Error("not valid Id")}[Vy](){return`PeerId(${this.toString()})`}},En=class extends lo{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},vn=class extends lo{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.multihash.digest}},An=class extends lo{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.multihash.digest}};function Bc(r,e){if(e=e??pf,r.charAt(0)==="1"||r.charAt(0)==="Q"){let t=Bt(fe.decode(`z${r}`));return r.startsWith("12D")?new vn({multihash:t}):r.startsWith("16U")?new An({multihash:t}):new En({multihash:t})}return fo(pf.decode(r))}function fo(r){try{let e=Bt(r);if(e.code===st.code){if(e.digest.length===vc)return new vn({multihash:e});if(e.digest.length===Ac)return new An({multihash:e})}if(e.code===Ee.code)return new En({multihash:e})}catch{return My(oe.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function My(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==mf)throw new Error("Supplied PeerID CID is invalid");let e=r.multihash;if(e.code===Ee.code)return new En({multihash:r.multihash});if(e.code===st.code){if(e.digest.length===vc)return new vn({multihash:r.multihash});if(e.digest.length===Ac)return new An({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function yf(r,e){return r.length===vc?new vn({multihash:At(st.code,r),privateKey:e}):r.length===Ac?new An({multihash:At(st.code,r),privateKey:e}):new En({multihash:await Ee.digest(r),publicKey:r,privateKey:e})}function $y(r){return r[Symbol.asyncIterator]!=null}function Hy(r){if($y(r))return(async()=>{let t=[];for await(let n of r)t.push(n);return t})();let e=[];for(let t of r)e.push(t);return e}var kc=Hy;function Ky(r){return r[Symbol.asyncIterator]!=null}function qy(r,e){if(Ky(r))return async function*(){for await(let a of r)await e(a)&&(yield a)}();let t=mn(r),{value:n,done:o}=t.next();if(o===!0)return function*(){}();let s=e(n);if(typeof s.then=="function")return async function*(){await s&&(yield n);for await(let a of t)await e(a)&&(yield a)}();let i=e;return function*(){s===!0&&(yield n);for(let a of t)i(a)&&(yield a)}()}var it=qy;var wf=ot(gf(),1),zy=["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"],Gy=zy.map(r=>new wf.Netmask(r));function jy(r){for(let e of Gy)if(e.contains(r))return!0;return!1}function Wy(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 bf(r){return rn(r)?jy(r):nn(r)?Wy(r):void 0}var Yy=[G("tcp").code,G("dns").code,G("dnsaddr").code,G("dns4").code,G("dns6").code];function xf(r){let e;try{e=G("sni").code}catch{return null}for(let[t,n]of r)if(t===e&&n!==void 0)return n;return null}function Ef(r){return r.some(([e,t])=>e===G("tls").code)}function Ye(r,e,t){let n=vf[G(r).name];if(n===void 0)throw new Error(`Can't interpret protocol ${G(r).name}`);let o=n(e,t);return r===G("ip6").code?`[${o}]`:o}var vf={ip4:(r,e)=>r,ip6:(r,e)=>e.length===0?r:`[${r}]`,tcp:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return`tcp://${Ye(t[0],t[1]??"",e)}:${r}`},udp:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return`udp://${Ye(t[0],t[1]??"",e)}:${r}`},dnsaddr:(r,e)=>r,dns4:(r,e)=>r,dns6:(r,e)=>r,dns:(r,e)=>r,ipfs:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return`${Ye(t[0],t[1]??"",e)}/ipfs/${r}`},p2p:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return`${Ye(t[0],t[1]??"",e)}/p2p/${r}`},http:(r,e)=>{let t=Ef(e),n=xf(e);if(t&&n!==null)return`https://${n}`;let o=t?"https://":"http://",s=e.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let i=Ye(s[0],s[1]??"",e);return i=i.replace("tcp://",""),`${o}${i}`},tls:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return Ye(t[0],t[1]??"",e)},sni:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return Ye(t[0],t[1]??"",e)},https:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");let n=Ye(t[0],t[1]??"",e);return n=n.replace("tcp://",""),`https://${n}`},ws:(r,e)=>{let t=Ef(e),n=xf(e);if(t&&n!==null)return`wss://${n}`;let o=t?"wss://":"ws://",s=e.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let i=Ye(s[0],s[1]??"",e);return i=i.replace("tcp://",""),`${o}${i}`},wss:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");let n=Ye(t[0],t[1]??"",e);return n=n.replace("tcp://",""),`wss://${n}`},"p2p-websocket-star":(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return`${Ye(t[0],t[1]??"",e)}/p2p-websocket-star`},"p2p-webrtc-star":(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return`${Ye(t[0],t[1]??"",e)}/p2p-webrtc-star`},"p2p-webrtc-direct":(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return`${Ye(t[0],t[1]??"",e)}/p2p-webrtc-direct`}};function Af(r,e){let n=Or(r).stringTuples(),o=n.pop();if(o===void 0)throw new Error("Unexpected end of multiaddr");let s=G(o[0]),i=vf[s.name];if(i==null)throw new Error(`No interpreter found for ${s.name}`);let a=i(o[1]??"",n);return e?.assumeHttp!==!1&&Yy.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 po=class{url;#e=0;#t=0;#r=0;#i=0;log;constructor(e,t){this.url=e instanceof URL?e:new URL(e),this.log=t.forComponent(`helia:trustless-gateway-block-broker:${this.url.hostname}`)}async getRawBlock(e,t){let n=this.url;if(n.pathname=`/ipfs/${e.toString()}`,n.search="?format=raw",t?.aborted===!0)throw new Error(`Signal to fetch raw block for CID ${e} from gateway ${this.url} was aborted prior to fetch`);try{this.#e++;let o=await fetch(n.toString(),{signal:t,headers:{Accept:"application/vnd.ipld.raw"},cache:"force-cache"});if(this.log("GET %s %d",n,o.status),!o.ok)throw this.#t++,new Error(`unable to fetch raw block for CID ${e} from gateway ${this.url}`);return this.#i++,new Uint8Array(await o.arrayBuffer())}catch{throw t?.aborted===!0?new Error(`fetching raw block for CID ${e} from gateway ${this.url} was aborted`):(this.#t++,new Error(`unable to fetch raw block for CID ${e}`))}}reliability(){return this.#e===0?1:this.#r>0?-1/0:this.#i/(this.#e+this.#t*3)}incrementInvalidBlocks(){this.#r++}};var Es=class r{components;gateways;routing;log;constructor(e,t={}){this.components=e,this.log=e.logger.forComponent("helia:trustless-gateway-block-broker"),this.routing=e.routing,this.gateways=(t.gateways??Bf).map(n=>new po(n,e.logger))}addGateway(e){this.gateways.push(new po(e,this.components.logger))}async retrieve(e,t={}){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",e,s.url);try{let i=await s.getRawBlock(e,t.signal);this.log.trace("got block for %c from %s",e,s.url);try{await t.validateFn?.(i)}catch(a){throw this.log.error("failed to validate block for %c from %s",e,s.url,a),s.incrementInvalidBlocks(),new Error(`Block for CID ${e} from gateway ${s.url} failed validation`)}return i}catch(i){if(this.log.error("failed to get block for %c from %s",e,s.url,i),i instanceof Error?o.push(i):o.push(new Error(`Unable to fetch raw block for CID ${e} from gateway ${s.url}`)),t.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",e,s.url);break}}}throw o.length>0?new AggregateError(o,`Unable to fetch raw block for CID ${e} from any gateway`):new Error(`Unable to fetch raw block for CID ${e} from any gateway`)}async createSession(e,t={}){let n=[],o=t.minProviders??1,s=t.minProviders??5,i=Ie(),a=new r(this.components,{gateways:n});this.log("finding transport-ipfs-gateway-http providers for cid %c",e);let c=new ts({concurrency:t.providerQueryConcurrency??5});return Promise.resolve().then(async()=>{for await(let f of this.routing.findProviders(e,t)){let u=f.multiaddrs.filter(l=>Jl.matches(l)||t.allowInsecure===!0&&Zl.matches(l)?t.allowLocal===!0||Hl.matches(l)?!0:bf(l.toOptions().host)===!1:!1);u.length!==0&&(this.log("found transport-ipfs-gateway-http provider %p for cid %c",f.id,e),c.add(async()=>{for(let l of u){let h;try{h=Af(l);let g=`${h}/ipfs/${e.toString()}?format=raw`,y=await fetch(g,{method:"HEAD",headers:{Accept:"application/vnd.ipld.raw","Cache-Control":t.cacheControl??"only-if-cached"},signal:AbortSignal.timeout(t.providerQueryTimeout??5e3)});this.log("HEAD %s %d",g,y.status),n.push(h),a.addGateway(h),this.log("found %d transport-ipfs-gateway-http providers for cid %c",n.length,e),n.length===o&&i.resolve(a),n.length===s&&c.clear()}catch(g){this.log.error("could not fetch %c from %a",e,h??l,g)}}}))}}).catch(f=>{this.log.error("error creating session for %c",e,f)}),i.promise}};var Bf=["https://trustless-gateway.link","https://cloudflare-ipfs.com","https://4everland.io"];function Sc(r={}){return e=>new Es(e,r)}var Ze=ot(rf(),1);Ze.default.formatters.b=r=>r==null?"undefined":fe.baseEncode(r);Ze.default.formatters.t=r=>r==null?"undefined":Re.baseEncode(r);Ze.default.formatters.m=r=>r==null?"undefined":hr.baseEncode(r);Ze.default.formatters.p=r=>r==null?"undefined":r.toString();Ze.default.formatters.c=r=>r==null?"undefined":r.toString();Ze.default.formatters.k=r=>r==null?"undefined":r.toString();Ze.default.formatters.a=r=>r==null?"undefined":r.toString();function Zy(r){let e=()=>{};return e.enabled=!1,e.color="",e.diff=0,e.log=()=>{},e.namespace=r,e.destroy=()=>!0,e.extend=()=>e,e}function kf(){return{forComponent(r){return Je(r)}}}function Je(r){let e=Zy(`${r}:trace`);return Ze.default.enabled(`${r}:trace`)&&Ze.default.names.map(t=>t.toString()).find(t=>t.includes(":trace"))!=null&&(e=(0,Ze.default)(`${r}:trace`)),Object.assign((0,Ze.default)(r),{error:(0,Ze.default)(`${r}:error`),trace:e})}async function*vs(r,e={}){let t=r.getReader();try{for(;;){let n=await t.read();if(n.done)return;yield n.value}}finally{e.preventCancel!==!0&&await t.cancel(),t.releaseLock()}}var Kc={};xe(Kc,{Ed25519PrivateKey:()=>qr,Ed25519PublicKey:()=>go,generateKeyPair:()=>iw,generateKeyPairFromSeed:()=>Xf,unmarshalEd25519PrivateKey:()=>ow,unmarshalEd25519PublicKey:()=>sw});function at(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Bn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Jy(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function kn(r,...e){if(!Jy(r))throw new Error("Uint8Array expected");if(e.length>0&&!e.includes(r.length))throw new Error(`Uint8Array expected of length ${e}, not of length=${r.length}`)}function As(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Bn(r.outputLen),Bn(r.blockLen)}function Sn(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function Sf(r,e){kn(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var Bs=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Rn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),mt=(r,e)=>r<<32-e|r>>>e;var _A=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Xy=async()=>{};async function If(r,e,t){let n=Date.now();for(let o=0;o<r;o++){t(o);let s=Date.now()-n;s>=0&&s<e||(await Xy(),n+=s)}}function Ic(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function yr(r){return typeof r=="string"&&(r=Ic(r)),kn(r),r}function ks(...r){let e=0;for(let n=0;n<r.length;n++){let o=r[n];kn(o),e+=o.length}let t=new Uint8Array(e);for(let n=0,o=0;n<r.length;n++){let s=r[n];t.set(s,o),o+=s.length}return t}var In=class{clone(){return this._cloneInto()}},Qy={}.toString;function Rf(r,e){if(e!==void 0&&Qy.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function Ss(r){let e=n=>r().update(yr(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function _n(r=32){if(Bs&&typeof Bs.getRandomValues=="function")return Bs.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function eg(r,e,t,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(e,t,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(t>>o&s),a=Number(t&s),c=n?4:0,f=n?0:4;r.setUint32(e+c,i,n),r.setUint32(e+f,a,n)}var _f=(r,e,t)=>r&e^~r&t,Tf=(r,e,t)=>r&e^r&t^e&t,Tn=class extends In{constructor(e,t,n,o){super(),this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=o,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=Rn(this.buffer)}update(e){Sn(this);let{view:t,buffer:n,blockLen:o}=this;e=yr(e);let s=e.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=Rn(e);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Sn(this),Sf(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;t[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++)t[l]=0;eg(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=Rn(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],s)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:t,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return e.length=o,e.pos=a,e.finished=s,e.destroyed=i,o%t&&e.buffer.set(n),e}};var Is=BigInt(4294967295),Rc=BigInt(32);function Nf(r,e=!1){return e?{h:Number(r&Is),l:Number(r>>Rc&Is)}:{h:Number(r>>Rc&Is)|0,l:Number(r&Is)|0}}function tg(r,e=!1){let t=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let o=0;o<r.length;o++){let{h:s,l:i}=Nf(r[o],e);[t[o],n[o]]=[s,i]}return[t,n]}var rg=(r,e)=>BigInt(r>>>0)<<Rc|BigInt(e>>>0),ng=(r,e,t)=>r>>>t,og=(r,e,t)=>r<<32-t|e>>>t,sg=(r,e,t)=>r>>>t|e<<32-t,ig=(r,e,t)=>r<<32-t|e>>>t,ag=(r,e,t)=>r<<64-t|e>>>t-32,cg=(r,e,t)=>r>>>t-32|e<<64-t,ug=(r,e)=>e,lg=(r,e)=>r,fg=(r,e,t)=>r<<t|e>>>32-t,hg=(r,e,t)=>e<<t|r>>>32-t,dg=(r,e,t)=>e<<t-32|r>>>64-t,pg=(r,e,t)=>r<<t-32|e>>>64-t;function mg(r,e,t,n){let o=(e>>>0)+(n>>>0);return{h:r+t+(o/2**32|0)|0,l:o|0}}var yg=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),gg=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,wg=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),bg=(r,e,t,n,o)=>e+t+n+o+(r/2**32|0)|0,xg=(r,e,t,n,o)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(o>>>0),Eg=(r,e,t,n,o,s)=>e+t+n+o+s+(r/2**32|0)|0;var vg={fromBig:Nf,split:tg,toBig:rg,shrSH:ng,shrSL:og,rotrSH:sg,rotrSL:ig,rotrBH:ag,rotrBL:cg,rotr32H:ug,rotr32L:lg,rotlSH:fg,rotlSL:hg,rotlBH:dg,rotlBL:pg,add:mg,add3L:yg,add3H:gg,add4L:wg,add4H:bg,add5H:Eg,add5L:xg},q=vg;var[Ag,Bg]=q.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),gr=new Uint32Array(80),wr=new Uint32Array(80),_c=class extends Tn{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:e,Al:t,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:f,El:u,Fh:l,Fl:h,Gh:g,Gl:y,Hh:p,Hl:m}=this;return[e,t,n,o,s,i,a,c,f,u,l,h,g,y,p,m]}set(e,t,n,o,s,i,a,c,f,u,l,h,g,y,p,m){this.Ah=e|0,this.Al=t|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=f|0,this.El=u|0,this.Fh=l|0,this.Fl=h|0,this.Gh=g|0,this.Gl=y|0,this.Hh=p|0,this.Hl=m|0}process(e,t){for(let v=0;v<16;v++,t+=4)gr[v]=e.getUint32(t),wr[v]=e.getUint32(t+=4);for(let v=16;v<80;v++){let U=gr[v-15]|0,S=wr[v-15]|0,_=q.rotrSH(U,S,1)^q.rotrSH(U,S,8)^q.shrSH(U,S,7),L=q.rotrSL(U,S,1)^q.rotrSL(U,S,8)^q.shrSL(U,S,7),b=gr[v-2]|0,C=wr[v-2]|0,O=q.rotrSH(b,C,19)^q.rotrBH(b,C,61)^q.shrSH(b,C,6),T=q.rotrSL(b,C,19)^q.rotrBL(b,C,61)^q.shrSL(b,C,6),V=q.add4L(L,T,wr[v-7],wr[v-16]),H=q.add4H(V,_,O,gr[v-7],gr[v-16]);gr[v]=H|0,wr[v]=V|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:h,Fh:g,Fl:y,Gh:p,Gl:m,Hh:w,Hl:I}=this;for(let v=0;v<80;v++){let U=q.rotrSH(l,h,14)^q.rotrSH(l,h,18)^q.rotrBH(l,h,41),S=q.rotrSL(l,h,14)^q.rotrSL(l,h,18)^q.rotrBL(l,h,41),_=l&g^~l&p,L=h&y^~h&m,b=q.add5L(I,S,L,Bg[v],wr[v]),C=q.add5H(b,w,U,_,Ag[v],gr[v]),O=b|0,T=q.rotrSH(n,o,28)^q.rotrBH(n,o,34)^q.rotrBH(n,o,39),V=q.rotrSL(n,o,28)^q.rotrBL(n,o,34)^q.rotrBL(n,o,39),H=n&s^n&a^s&a,X=o&i^o&c^i&c;w=p|0,I=m|0,p=g|0,m=y|0,g=l|0,y=h|0,{h:l,l:h}=q.add(f|0,u|0,C|0,O|0),f=a|0,u=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let E=q.add3L(O,V,X);n=q.add3H(E,C,T,H),o=E|0}({h:n,l:o}=q.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=q.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=q.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:u}=q.add(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:h}=q.add(this.Eh|0,this.El|0,l|0,h|0),{h:g,l:y}=q.add(this.Fh|0,this.Fl|0,g|0,y|0),{h:p,l:m}=q.add(this.Gh|0,this.Gl|0,p|0,m|0),{h:w,l:I}=q.add(this.Hh|0,this.Hl|0,w|0,I|0),this.set(n,o,s,i,a,c,f,u,l,h,g,y,p,m,w,I)}roundClean(){gr.fill(0),wr.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 Nn=Ss(()=>new _c);var _s={};xe(_s,{abytes:()=>Cn,bitGet:()=>Ng,bitLen:()=>Tg,bitMask:()=>mo,bitSet:()=>Cg,bytesToHex:()=>Ht,bytesToNumberBE:()=>Kt,bytesToNumberLE:()=>xr,concatBytes:()=>qt,createHmacDrbg:()=>Cc,ensureBytes:()=>pe,equalBytes:()=>Rg,hexToBytes:()=>$r,hexToNumber:()=>Nc,isBytes:()=>br,numberToBytesBE:()=>Er,numberToBytesLE:()=>Hr,numberToHexUnpadded:()=>Df,numberToVarBytesBE:()=>Ig,utf8ToBytes:()=>_g,validateObject:()=>St});var Uf=BigInt(0),Rs=BigInt(1),kg=BigInt(2);function br(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Cn(r){if(!br(r))throw new Error("Uint8Array expected")}var Sg=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function Ht(r){Cn(r);let e="";for(let t=0;t<r.length;t++)e+=Sg[r[t]];return e}function Df(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function Nc(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var $t={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Cf(r){if(r>=$t._0&&r<=$t._9)return r-$t._0;if(r>=$t._A&&r<=$t._F)return r-($t._A-10);if(r>=$t._a&&r<=$t._f)return r-($t._a-10)}function $r(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let e=r.length,t=e/2;if(e%2)throw new Error("padded hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let o=0,s=0;o<t;o++,s+=2){let i=Cf(r.charCodeAt(s)),a=Cf(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 Kt(r){return Nc(Ht(r))}function xr(r){return Cn(r),Nc(Ht(Uint8Array.from(r).reverse()))}function Er(r,e){return $r(r.toString(16).padStart(e*2,"0"))}function Hr(r,e){return Er(r,e).reverse()}function Ig(r){return $r(Df(r))}function pe(r,e,t){let n;if(typeof e=="string")try{n=$r(e)}catch(s){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${s}`)}else if(br(e))n=Uint8Array.from(e);else throw new Error(`${r} must be hex string or Uint8Array`);let o=n.length;if(typeof t=="number"&&o!==t)throw new Error(`${r} expected ${t} bytes, got ${o}`);return n}function qt(...r){let e=0;for(let n=0;n<r.length;n++){let o=r[n];Cn(o),e+=o.length}let t=new Uint8Array(e);for(let n=0,o=0;n<r.length;n++){let s=r[n];t.set(s,o),o+=s.length}return t}function Rg(r,e){if(r.length!==e.length)return!1;let t=0;for(let n=0;n<r.length;n++)t|=r[n]^e[n];return t===0}function _g(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Tg(r){let e;for(e=0;r>Uf;r>>=Rs,e+=1);return e}function Ng(r,e){return r>>BigInt(e)&Rs}function Cg(r,e,t){return r|(t?Rs:Uf)<<BigInt(e)}var mo=r=>(kg<<BigInt(r-1))-Rs,Tc=r=>new Uint8Array(r),Lf=r=>Uint8Array.from(r);function Cc(r,e,t){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof e!="number"||e<2)throw new Error("qByteLen must be a number");if(typeof t!="function")throw new Error("hmacFn must be a function");let n=Tc(r),o=Tc(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>t(o,n,...l),c=(l=Tc())=>{o=a(Lf([0]),l),n=a(),l.length!==0&&(o=a(Lf([1]),l),n=a())},f=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,h=[];for(;l<e;){n=a();let g=n.slice();h.push(g),l+=n.length}return qt(...h)};return(l,h)=>{i(),c(l);let g;for(;!(g=h(f()));)c();return i(),g}}var Lg={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"||br(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,e)=>e.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function St(r,e,t={}){let n=(o,s,i)=>{let a=Lg[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(e))n(o,s,!1);for(let[o,s]of Object.entries(t))n(o,s,!0);return r}var ve=BigInt(0),ue=BigInt(1),Kr=BigInt(2),Ug=BigInt(3),Lc=BigInt(4),Pf=BigInt(5),Of=BigInt(8),Dg=BigInt(9),Pg=BigInt(16);function ae(r,e){let t=r%e;return t>=ve?t:e+t}function Og(r,e,t){if(t<=ve||e<ve)throw new Error("Expected power/modulo > 0");if(t===ue)return ve;let n=ue;for(;e>ve;)e&ue&&(n=n*r%t),r=r*r%t,e>>=ue;return n}function le(r,e,t){let n=r;for(;e-- >ve;)n*=n,n%=t;return n}function Ts(r,e){if(r===ve||e<=ve)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=ae(r,e),n=e,o=ve,s=ue,i=ue,a=ve;for(;t!==ve;){let f=n/t,u=n%t,l=o-i*f,h=s-a*f;n=t,t=u,o=i,s=a,i=l,a=h}if(n!==ue)throw new Error("invert: does not exist");return ae(o,e)}function Fg(r){let e=(r-ue)/Kr,t,n,o;for(t=r-ue,n=0;t%Kr===ve;t/=Kr,n++);for(o=Kr;o<r&&Og(o,e,r)!==r-ue;o++);if(n===1){let i=(r+ue)/Lc;return function(c,f){let u=c.pow(f,i);if(!c.eql(c.sqr(u),f))throw new Error("Cannot find square root");return u}}let s=(t+ue)/Kr;return function(a,c){if(a.pow(c,e)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,u=a.pow(a.mul(a.ONE,o),t),l=a.pow(c,s),h=a.pow(c,t);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let g=1;for(let p=a.sqr(h);g<f&&!a.eql(p,a.ONE);g++)p=a.sqr(p);let y=a.pow(u,ue<<BigInt(f-g-1));u=a.sqr(y),l=a.mul(l,y),h=a.mul(h,u),f=g}return l}}function Vg(r){if(r%Lc===Ug){let e=(r+ue)/Lc;return function(n,o){let s=n.pow(o,e);if(!n.eql(n.sqr(s),o))throw new Error("Cannot find square root");return s}}if(r%Of===Pf){let e=(r-Pf)/Of;return function(n,o){let s=n.mul(o,Kr),i=n.pow(s,e),a=n.mul(o,i),c=n.mul(n.mul(a,Kr),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),o))throw new Error("Cannot find square root");return f}}return r%Pg,Fg(r)}var Ff=(r,e)=>(ae(r,e)&ue)===ue,Mg=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Uc(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=Mg.reduce((n,o)=>(n[o]="function",n),e);return St(r,t)}function $g(r,e,t){if(t<ve)throw new Error("Expected power > 0");if(t===ve)return r.ONE;if(t===ue)return e;let n=r.ONE,o=e;for(;t>ve;)t&ue&&(n=r.mul(n,o)),o=r.sqr(o),t>>=ue;return n}function Hg(r,e){let t=new Array(e.length),n=e.reduce((s,i,a)=>r.is0(i)?s:(t[a]=s,r.mul(s,i)),r.ONE),o=r.inv(n);return e.reduceRight((s,i,a)=>r.is0(i)?s:(t[a]=r.mul(s,t[a]),r.mul(s,i)),o),t}function Dc(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function Ns(r,e,t=!1,n={}){if(r<=ve)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:o,nByteLength:s}=Dc(r,e);if(s>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Vg(r),a=Object.freeze({ORDER:r,BITS:o,BYTES:s,MASK:mo(o),ZERO:ve,ONE:ue,create:c=>ae(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return ve<=c&&c<r},is0:c=>c===ve,isOdd:c=>(c&ue)===ue,neg:c=>ae(-c,r),eql:(c,f)=>c===f,sqr:c=>ae(c*c,r),add:(c,f)=>ae(c+f,r),sub:(c,f)=>ae(c-f,r),mul:(c,f)=>ae(c*f,r),pow:(c,f)=>$g(a,c,f),div:(c,f)=>ae(c*Ts(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>Ts(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Hg(a,c),cmov:(c,f,u)=>u?f:c,toBytes:c=>t?Hr(c,s):Er(c,s),fromBytes:c=>{if(c.length!==s)throw new Error(`Fp.fromBytes: expected ${s}, got ${c.length}`);return t?xr(c):Kt(c)}});return Object.freeze(a)}function Vf(r,e){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let t=r.sqrt(e);return r.isOdd(t)?r.neg(t):t}function Mf(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let e=r.toString(2).length;return Math.ceil(e/8)}function Pc(r){let e=Mf(r);return e+Math.ceil(e/2)}function $f(r,e,t=!1){let n=r.length,o=Mf(e),s=Pc(e);if(n<16||n<s||n>1024)throw new Error(`expected ${s}-1024 bytes of input, got ${n}`);let i=t?Kt(r):xr(r),a=ae(i,e-ue)+ue;return t?Hr(a,o):Er(a,o)}var qg=BigInt(0),Oc=BigInt(1);function Cs(r,e){let t=(o,s)=>{let i=s.negate();return o?i:s},n=o=>{let s=Math.ceil(e/o)+1,i=2**(o-1);return{windows:s,windowSize:i}};return{constTimeNegate:t,unsafeLadder(o,s){let i=r.ZERO,a=o;for(;s>qg;)s&Oc&&(i=i.add(a)),a=a.double(),s>>=Oc;return i},precomputeWindow(o,s){let{windows:i,windowSize:a}=n(s),c=[],f=o,u=f;for(let l=0;l<i;l++){u=f,c.push(u);for(let h=1;h<a;h++)u=u.add(f),c.push(u);f=u.double()}return c},wNAF(o,s,i){let{windows:a,windowSize:c}=n(o),f=r.ZERO,u=r.BASE,l=BigInt(2**o-1),h=2**o,g=BigInt(o);for(let y=0;y<a;y++){let p=y*c,m=Number(i&l);i>>=g,m>c&&(m-=h,i+=Oc);let w=p,I=p+Math.abs(m)-1,v=y%2!==0,U=m<0;m===0?u=u.add(t(v,s[w])):f=f.add(t(U,s[I]))}return{p:f,f:u}},wNAFCached(o,s,i,a){let c=o._WINDOW_SIZE||1,f=s.get(o);return f||(f=this.precomputeWindow(o,c),c!==1&&s.set(o,a(f))),this.wNAF(c,f,i)}}}function yo(r){return Uc(r.Fp),St(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Dc(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var yt=BigInt(0),Xe=BigInt(1),Ls=BigInt(2),zg=BigInt(8),Gg={zip215:!0};function jg(r){let e=yo(r);return St(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function Us(r){let e=jg(r),{Fp:t,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=e,f=Ls<<BigInt(a*8)-Xe,u=t.create,l=e.uvRatio||((B,x)=>{try{return{isValid:!0,value:t.sqrt(B*t.inv(x))}}catch{return{isValid:!1,value:yt}}}),h=e.adjustScalarBytes||(B=>B),g=e.domain||((B,x,P)=>{if(x.length||P)throw new Error("Contexts/pre-hash are not supported");return B}),y=B=>typeof B=="bigint"&&yt<B,p=(B,x)=>y(B)&&y(x)&&B<x,m=B=>B===yt||p(B,f);function w(B,x){if(p(B,x))return B;throw new Error(`Expected valid scalar < ${x}, got ${typeof B} ${B}`)}function I(B){return B===yt?B:w(B,n)}let v=new Map;function U(B){if(!(B instanceof S))throw new Error("ExtendedPoint expected")}class S{constructor(x,P,M,K){if(this.ex=x,this.ey=P,this.ez=M,this.et=K,!m(x))throw new Error("x required");if(!m(P))throw new Error("y required");if(!m(M))throw new Error("z required");if(!m(K))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(x){if(x instanceof S)throw new Error("extended point not allowed");let{x:P,y:M}=x||{};if(!m(P)||!m(M))throw new Error("invalid affine point");return new S(P,M,Xe,u(P*M))}static normalizeZ(x){let P=t.invertBatch(x.map(M=>M.ez));return x.map((M,K)=>M.toAffine(P[K])).map(S.fromAffine)}_setWindowSize(x){this._WINDOW_SIZE=x,v.delete(this)}assertValidity(){let{a:x,d:P}=e;if(this.is0())throw new Error("bad point: ZERO");let{ex:M,ey:K,ez:j,et:W}=this,te=u(M*M),J=u(K*K),Q=u(j*j),ge=u(Q*Q),he=u(te*x),ke=u(Q*u(he+J)),Se=u(ge+u(P*u(te*J)));if(ke!==Se)throw new Error("bad point: equation left != right (1)");let be=u(M*K),Le=u(j*W);if(be!==Le)throw new Error("bad point: equation left != right (2)")}equals(x){U(x);let{ex:P,ey:M,ez:K}=this,{ex:j,ey:W,ez:te}=x,J=u(P*te),Q=u(j*K),ge=u(M*te),he=u(W*K);return J===Q&&ge===he}is0(){return this.equals(S.ZERO)}negate(){return new S(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:x}=e,{ex:P,ey:M,ez:K}=this,j=u(P*P),W=u(M*M),te=u(Ls*u(K*K)),J=u(x*j),Q=P+M,ge=u(u(Q*Q)-j-W),he=J+W,ke=he-te,Se=J-W,be=u(ge*ke),Le=u(he*Se),Dt=u(ge*Se),Lr=u(ke*he);return new S(be,Le,Lr,Dt)}add(x){U(x);let{a:P,d:M}=e,{ex:K,ey:j,ez:W,et:te}=this,{ex:J,ey:Q,ez:ge,et:he}=x;if(P===BigInt(-1)){let zu=u((j-K)*(Q+J)),Gu=u((j+K)*(Q-J)),ua=u(Gu-zu);if(ua===yt)return this.double();let ju=u(W*Ls*he),Wu=u(te*Ls*ge),Yu=Wu+ju,Zu=Gu+zu,Ju=Wu-ju,w0=u(Yu*ua),b0=u(Zu*Ju),x0=u(Yu*Ju),E0=u(ua*Zu);return new S(w0,b0,E0,x0)}let ke=u(K*J),Se=u(j*Q),be=u(te*M*he),Le=u(W*ge),Dt=u((K+j)*(J+Q)-ke-Se),Lr=Le-be,Qn=Le+be,qu=u(Se-P*ke),p0=u(Dt*Lr),m0=u(Qn*qu),y0=u(Dt*qu),g0=u(Lr*Qn);return new S(p0,m0,g0,y0)}subtract(x){return this.add(x.negate())}wNAF(x){return b.wNAFCached(this,v,x,S.normalizeZ)}multiply(x){let{p:P,f:M}=this.wNAF(w(x,n));return S.normalizeZ([P,M])[0]}multiplyUnsafe(x){let P=I(x);return P===yt?L:this.equals(L)||P===Xe?this:this.equals(_)?this.wNAF(P).p:b.unsafeLadder(this,P)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return b.unsafeLadder(this,n).is0()}toAffine(x){let{ex:P,ey:M,ez:K}=this,j=this.is0();x==null&&(x=j?zg:t.inv(K));let W=u(P*x),te=u(M*x),J=u(K*x);if(j)return{x:yt,y:Xe};if(J!==Xe)throw new Error("invZ was invalid");return{x:W,y:te}}clearCofactor(){let{h:x}=e;return x===Xe?this:this.multiplyUnsafe(x)}static fromHex(x,P=!1){let{d:M,a:K}=e,j=t.BYTES;x=pe("pointHex",x,j);let W=x.slice(),te=x[j-1];W[j-1]=te&-129;let J=xr(W);J===yt||(P?w(J,f):w(J,t.ORDER));let Q=u(J*J),ge=u(Q-Xe),he=u(M*Q-K),{isValid:ke,value:Se}=l(ge,he);if(!ke)throw new Error("Point.fromHex: invalid y coordinate");let be=(Se&Xe)===Xe,Le=(te&128)!==0;if(!P&&Se===yt&&Le)throw new Error("Point.fromHex: x=0 and x_0=1");return Le!==be&&(Se=u(-Se)),S.fromAffine({x:Se,y:J})}static fromPrivateKey(x){return T(x).point}toRawBytes(){let{x,y:P}=this.toAffine(),M=Hr(P,t.BYTES);return M[M.length-1]|=x&Xe?128:0,M}toHex(){return Ht(this.toRawBytes())}}S.BASE=new S(e.Gx,e.Gy,Xe,u(e.Gx*e.Gy)),S.ZERO=new S(yt,Xe,Xe,yt);let{BASE:_,ZERO:L}=S,b=Cs(S,a*8);function C(B){return ae(B,n)}function O(B){return C(xr(B))}function T(B){let x=a;B=pe("private key",B,x);let P=pe("hashed private key",s(B),2*x),M=h(P.slice(0,x)),K=P.slice(x,2*x),j=O(M),W=_.multiply(j),te=W.toRawBytes();return{head:M,prefix:K,scalar:j,point:W,pointBytes:te}}function V(B){return T(B).pointBytes}function H(B=new Uint8Array,...x){let P=qt(...x);return O(s(g(P,pe("context",B),!!o)))}function X(B,x,P={}){B=pe("message",B),o&&(B=o(B));let{prefix:M,scalar:K,pointBytes:j}=T(x),W=H(P.context,M,B),te=_.multiply(W).toRawBytes(),J=H(P.context,te,j,B),Q=C(W+J*K);I(Q);let ge=qt(te,Hr(Q,t.BYTES));return pe("result",ge,a*2)}let E=Gg;function k(B,x,P,M=E){let{context:K,zip215:j}=M,W=t.BYTES;B=pe("signature",B,2*W),x=pe("message",x),o&&(x=o(x));let te=xr(B.slice(W,2*W)),J,Q,ge;try{J=S.fromHex(P,j),Q=S.fromHex(B.slice(0,W),j),ge=_.multiplyUnsafe(te)}catch{return!1}if(!j&&J.isSmallOrder())return!1;let he=H(K,Q.toRawBytes(),J.toRawBytes(),x);return Q.add(J.multiplyUnsafe(he)).subtract(ge).clearCofactor().equals(S.ZERO)}return _._setWindowSize(8),{CURVE:e,getPublicKey:V,sign:X,verify:k,ExtendedPoint:S,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>i(t.BYTES),precompute(B=8,x=S.BASE){return x._setWindowSize(B),x.multiply(BigInt(3)),x}}}}var Vc=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Hf=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),JA=BigInt(0),Wg=BigInt(1),Fc=BigInt(2),Yg=BigInt(5),Kf=BigInt(10),Zg=BigInt(20),Jg=BigInt(40),qf=BigInt(80);function Xg(r){let e=Vc,n=r*r%e*r%e,o=le(n,Fc,e)*n%e,s=le(o,Wg,e)*r%e,i=le(s,Yg,e)*s%e,a=le(i,Kf,e)*i%e,c=le(a,Zg,e)*a%e,f=le(c,Jg,e)*c%e,u=le(f,qf,e)*f%e,l=le(u,qf,e)*f%e,h=le(l,Kf,e)*i%e;return{pow_p_5_8:le(h,Fc,e)*r%e,b2:n}}function Qg(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function ew(r,e){let t=Vc,n=ae(e*e*e,t),o=ae(n*n*e,t),s=Xg(r*o).pow_p_5_8,i=ae(r*n*s,t),a=ae(e*i*i,t),c=i,f=ae(i*Hf,t),u=a===r,l=a===ae(-r,t),h=a===ae(-r*Hf,t);return u&&(i=c),(l||h)&&(i=f),Ff(i,t)&&(i=ae(-i,t)),{isValid:u||l,value:i}}var zt=Ns(Vc,void 0,!0),Mc={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:zt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Nn,randomBytes:_n,adjustScalarBytes:Qg,uvRatio:ew},Ln=Us(Mc);function zf(r,e,t){if(e.length>255)throw new Error("Context is too big");return ks(Ic("SigEd25519 no Ed25519 collisions"),new Uint8Array([t?1:0,e.length]),e,r)}var XA=Us({...Mc,domain:zf}),QA=Us({...Mc,domain:zf,prehash:Nn});var tw=(zt.ORDER+BigInt(3))/BigInt(8),eB=zt.pow(Fc,tw),tB=zt.sqrt(zt.neg(zt.ONE)),rB=(zt.ORDER-BigInt(5))/BigInt(8),nB=BigInt(486662);var oB=Vf(zt,zt.neg(BigInt(486664)));var sB=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),iB=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),aB=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),cB=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var uB=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var Un=32,Gt=64,Ds=32;function Gf(){let r=Ln.utils.randomPrivateKey(),e=Ln.getPublicKey(r);return{privateKey:Zf(r,e),publicKey:e}}function jf(r){if(r.length!==Ds)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 e=r,t=Ln.getPublicKey(e);return{privateKey:Zf(e,t),publicKey:t}}function Wf(r,e){let t=r.subarray(0,Ds);return Ln.sign(e instanceof Uint8Array?e:e.subarray(),t)}function Yf(r,e,t){return Ln.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function Zf(r,e){let t=new Uint8Array(Gt);for(let n=0;n<Ds;n++)t[n]=r[n],t[Ds+n]=e[n];return t}var Me={get(r=globalThis){let e=r.crypto;if(e==null||e.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 e}};var $c={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Jf(r){let e=r?.algorithm??"AES-GCM",t=r?.keyLength??16,n=r?.nonceLength??12,o=r?.digest??"SHA-256",s=r?.saltLength??16,i=r?.iterations??32767,a=Me.get();t*=8;async function c(l,h){let g=a.getRandomValues(new Uint8Array(s)),y=a.getRandomValues(new Uint8Array(n)),p={name:e,iv:y};typeof h=="string"&&(h=Y(h));let m;if(h.length===0){m=await a.subtle.importKey("jwk",$c,{name:"AES-GCM"},!0,["encrypt"]);try{let I={name:"PBKDF2",salt:g,iterations:i,hash:{name:o}},v=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(I,v,{name:e,length:t},!0,["encrypt"])}catch{m=await a.subtle.importKey("jwk",$c,{name:"AES-GCM"},!0,["encrypt"])}}else{let I={name:"PBKDF2",salt:g,iterations:i,hash:{name:o}},v=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(I,v,{name:e,length:t},!0,["encrypt"])}let w=await a.subtle.encrypt(p,m,l);return Fe([g,p.iv,new Uint8Array(w)])}async function f(l,h){let g=l.subarray(0,s),y=l.subarray(s,s+n),p=l.subarray(s+n),m={name:e,iv:y};typeof h=="string"&&(h=Y(h));let w;if(h.length===0)try{let v={name:"PBKDF2",salt:g,iterations:i,hash:{name:o}},U=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(v,U,{name:e,length:t},!0,["decrypt"])}catch{w=await a.subtle.importKey("jwk",$c,{name:"AES-GCM"},!0,["decrypt"])}else{let v={name:"PBKDF2",salt:g,iterations:i,hash:{name:o}},U=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(v,U,{name:e,length:t},!0,["decrypt"])}let I=await a.subtle.decrypt(m,w,p);return new Uint8Array(I)}return{encrypt:c,decrypt:f}}async function Dn(r,e){let n=await Jf().encrypt(r,e);return hr.encode(n)}var ye;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(ye||(ye={}));var Hc;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Hc||(Hc={}));(function(r){r.codec=()=>uo(Hc)})(ye||(ye={}));var It;(function(r){let e;r.codec=()=>(e==null&&(e=xn((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),ye.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),o.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let o={},s=n==null?t.len:t.pos+n;for(;t.pos<s;){let i=t.uint32();switch(i>>>3){case 1:o.Type=ye.codec().decode(t);break;case 2:o.Data=t.bytes();break;default:t.skipType(i&7);break}}return o})),e),r.encode=t=>wn(t,r.codec()),r.decode=t=>gn(t,r.codec())})(It||(It={}));var jt;(function(r){let e;r.codec=()=>(e==null&&(e=xn((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),ye.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),o.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let o={},s=n==null?t.len:t.pos+n;for(;t.pos<s;){let i=t.uint32();switch(i>>>3){case 1:o.Type=ye.codec().decode(t);break;case 2:o.Data=t.bytes();break;default:t.skipType(i&7);break}}return o})),e),r.encode=t=>wn(t,r.codec()),r.decode=t=>gn(t,r.codec())})(jt||(jt={}));var go=class{_key;constructor(e){this._key=Pn(e,Un)}verify(e,t){return Yf(this._key,t,e)}marshal(){return this._key}get bytes(){return It.encode({Type:ye.Ed25519,Data:this.marshal()}).subarray()}equals(e){return ce(this.bytes,e.bytes)}hash(){let e=Ee.digest(this.bytes);return at(e)?e.then(({bytes:t})=>t):e.bytes}},qr=class{_key;_publicKey;constructor(e,t){this._key=Pn(e,Gt),this._publicKey=Pn(t,Un)}sign(e){return Wf(this._key,e)}get public(){return new go(this._publicKey)}marshal(){return this._key}get bytes(){return jt.encode({Type:ye.Ed25519,Data:this.marshal()}).subarray()}equals(e){return ce(this.bytes,e.bytes)}async hash(){let e=Ee.digest(this.bytes),t;return at(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=st.digest(this.public.bytes);return fe.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return Dn(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function ow(r){if(r.length>Gt){r=Pn(r,Gt+Un);let n=r.subarray(0,Gt),o=r.subarray(Gt,r.length);return new qr(n,o)}r=Pn(r,Gt);let e=r.subarray(0,Gt),t=r.subarray(Un);return new qr(e,t)}function sw(r){return r=Pn(r,Un),new go(r)}async function iw(){let{privateKey:r,publicKey:e}=Gf();return new qr(r,e)}async function Xf(r){let{privateKey:e,publicKey:t}=jf(r);return new qr(e,t)}function Pn(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new N(`Key must be a Uint8Array of length ${e}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}var Qc={};xe(Qc,{MAX_RSA_KEY_SIZE:()=>_o,RsaPrivateKey:()=>$n,RsaPublicKey:()=>Ro,fromJwk:()=>Lw,generateKeyPair:()=>Uw,unmarshalRsaPrivateKey:()=>Jc,unmarshalRsaPublicKey:()=>Cw});function zr(r){if(isNaN(r)||r<=0)throw new N("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return _n(r)}var kr={};xe(kr,{exportToPem:()=>Iw,importFromPem:()=>Rw,jwkToPkcs1:()=>Aw,jwkToPkix:()=>kw,pkcs1ToJwk:()=>vw,pkixToJwk:()=>Bw});var Os=class extends In{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,As(e);let n=yr(t);if(this.iHash=e.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?e.create().update(n).digest():n);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=e.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),s.fill(0)}update(e){return Sn(this),this.iHash.update(e),this}digestInto(e){Sn(this),kn(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));let{oHash:t,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return e=e,e.finished=o,e.destroyed=s,e.blockLen=i,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},wo=(r,e,t)=>new Os(r,e).update(t).digest();wo.create=(r,e)=>new Os(r,e);function aw(r,e,t,n){As(r);let o=Rf({dkLen:32,asyncTick:10},n),{c:s,dkLen:i,asyncTick:a}=o;if(Bn(s),Bn(i),Bn(a),s<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=yr(e),f=yr(t),u=new Uint8Array(i),l=wo.create(r,c),h=l._cloneInto().update(f);return{c:s,dkLen:i,asyncTick:a,DK:u,PRF:l,PRFSalt:h}}function cw(r,e,t,n,o){return r.destroy(),e.destroy(),n&&n.destroy(),o.fill(0),t}async function qc(r,e,t,n){let{c:o,dkLen:s,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=aw(r,e,t,n),u,l=new Uint8Array(4),h=Rn(l),g=new Uint8Array(c.outputLen);for(let y=1,p=0;p<s;y++,p+=c.outputLen){let m=a.subarray(p,p+c.outputLen);h.setInt32(0,y,!1),(u=f._cloneInto(u)).update(l).digestInto(g),m.set(g.subarray(0,m.length)),await If(o-1,i,()=>{c._cloneInto(u).update(g).digestInto(g);for(let w=0;w<m.length;w++)m[w]^=g[w]})}return cw(c,f,a,u,g)}var Z=ot(Qf());function Gr(r,e){let t=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)t+=r[r.length-1-n]*Math.pow(2,e*n);return t}function vr(r,e,t=-1){let n=t,o=r,s=0,i=Math.pow(2,e);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 f=new Uint8Array(c);for(let u=a-1;u>=0;u--){let l=Math.pow(2,u*e);f[s-u-1]=Math.floor(o/l),o-=f[s-u-1]*l}return c}i*=Math.pow(2,e)}return new ArrayBuffer(0)}function Ms(...r){let e=0,t=0;for(let s of r)e+=s.length;let n=new ArrayBuffer(e),o=new Uint8Array(n);for(let s of r)o.set(s,t),t+=s.length;return o}function Gc(){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 e=new ArrayBuffer(this.valueHex.byteLength),t=new Uint8Array(e);for(let a=0;a<this.valueHex.byteLength;a++)t[a]=0;t[0]=r[0]&128;let n=Gr(t,8),o=new ArrayBuffer(this.valueHex.byteLength),s=new Uint8Array(o);for(let a=0;a<this.valueHex.byteLength;a++)s[a]=r[a];return s[0]&=127,Gr(s,8)-n}function eh(r){let e=r<0?r*-1:r,t=128;for(let n=1;n<8;n++){if(e<=t){if(r<0){let i=t-e,a=vr(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=vr(e,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}t*=Math.pow(2,8)}return new ArrayBuffer(0)}function th(r,e){if(r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let o=0;o<t.length;o++)if(t[o]!==n[o])return!1;return!0}function qe(r,e){let t=r.toString(10);if(e<t.length)return"";let n=e-t.length,o=new Array(n);for(let i=0;i<n;i++)o[i]="0";return o.join("").concat(t)}var OB=Math.log(2);function $s(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function jc(r){let e=0,t=0;for(let o=0;o<r.length;o++){let s=r[o];e+=s.byteLength}let n=new Uint8Array(e);for(let o=0;o<r.length;o++){let s=r[o];n.set(new Uint8Array(s),t),t+=s.byteLength}return n.buffer}function Xt(r,e,t,n){return e instanceof Uint8Array?e.byteLength?t<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):e.byteLength-t-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 xo=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return jc(this.items)}},bo=[new Uint8Array([1])],rh="0123456789";var Vn="",wt=new ArrayBuffer(0),Wc=new Uint8Array(0),Eo="EndOfContent",oh="OCTET STRING",sh="BIT STRING";function Qt(r){var e;return e=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):Wc}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(!Xt(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",wt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Z.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var Yt=class{constructor({blockLength:e=0,error:t=Vn,warnings:n=[],valueBeforeDecode:o=Wc}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=Z.BufferSourceConverter.toUint8Array(o)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(e){this.valueBeforeDecodeView=new Uint8Array(e)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:Z.Convert.ToHex(this.valueBeforeDecodeView)}}};Yt.NAME="baseBlock";var Pe=class extends Yt{fromBER(e,t,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(e,t){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};Pe.NAME="valueBlock";var Hs=class extends Qt(Yt){constructor({idBlock:e={}}={}){var t,n,o,s;super(),e?(this.isHexOnly=(t=e.isHexOnly)!==null&&t!==void 0?t:!1,this.valueHexView=e.valueHex?Z.BufferSourceConverter.toUint8Array(e.valueHex):Wc,this.tagClass=(n=e.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(o=e.tagNumber)!==null&&o!==void 0?o:-1,this.isConstructed=(s=e.isConstructed)!==null&&s!==void 0?s:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(e=!1){let t=0;switch(this.tagClass){case 1:t|=0;break;case 2:t|=64;break;case 3:t|=128;break;case 4:t|=192;break;default:return this.error="Unknown tag class",wt}if(this.isConstructed&&(t|=32),this.tagNumber<31&&!this.isHexOnly){let o=new Uint8Array(1);if(!e){let s=this.tagNumber;s&=31,t|=s,o[0]=t}return o.buffer}if(!this.isHexOnly){let o=vr(this.tagNumber,7),s=new Uint8Array(o),i=o.byteLength,a=new Uint8Array(i+1);if(a[0]=t|31,!e){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]=t|31,!e){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(e,t,n){let o=Z.BufferSourceConverter.toUint8Array(e);if(!Xt(this,o,t,n))return-1;let s=o.subarray(t,t+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,f=this.valueHexView=new Uint8Array(255),u=255;for(;s[c]&128;){if(f[c-1]=s[c]&127,c++,c>=s.length)return this.error="End of input reached before message was fully decoded",-1;if(c===u){u+=255;let h=new Uint8Array(u);for(let g=0;g<f.length;g++)h[g]=f[g];f=this.valueHexView=new Uint8Array(u)}}this.blockLength=c+1,f[c-1]=s[c]&127;let l=new Uint8Array(c);for(let h=0;h<c;h++)l[h]=f[h];f=this.valueHexView=new Uint8Array(c),f.set(l),this.blockLength<=9?this.tagNumber=Gr(f,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 t+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};Hs.NAME="identificationBlock";var Ks=class extends Yt{constructor({lenBlock:e={}}={}){var t,n,o;super(),this.isIndefiniteForm=(t=e.isIndefiniteForm)!==null&&t!==void 0?t:!1,this.longFormUsed=(n=e.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(o=e.length)!==null&&o!==void 0?o:0}fromBER(e,t,n){let o=Z.BufferSourceConverter.toUint8Array(e);if(!Xt(this,o,t,n))return-1;let s=o.subarray(t,t+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,t+this.blockLength;if(this.longFormUsed=!!(s[0]&128),this.longFormUsed===!1)return this.length=s[0],this.blockLength=1,t+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=t+1,c=o.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Gr(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,t+this.blockLength}toBER(e=!1){let t,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=128),t;if(this.longFormUsed){let o=vr(this.length,8);if(o.byteLength>127)return this.error="Too big length",wt;if(t=new ArrayBuffer(o.byteLength+1),e)return t;let s=new Uint8Array(o);n=new Uint8Array(t),n[0]=o.byteLength|128;for(let i=0;i<o.byteLength;i++)n[i+1]=s[i];return t}return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=this.length),t}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Ks.NAME="lengthBlock";var D={},Te=class extends Yt{constructor({name:e=Vn,optional:t=!1,primitiveSchema:n,...o}={},s){super(o),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new Hs(o),this.lenBlock=new Ks(o),this.valueBlock=s?new s(o):new Pe(o)}fromBER(e,t,n){let o=this.valueBlock.fromBER(e,t,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(e,t){let n=t||new xo;t||ih(this);let o=this.idBlock.toBER(e);if(n.write(o),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(e,n),n.write(new ArrayBuffer(2));else{let s=this.valueBlock.toBER(e);this.lenBlock.length=s.byteLength;let i=this.lenBlock.toBER(e);n.write(i),n.write(s)}return t?wt:n.final()}toJSON(){let e={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(e.primitiveSchema=this.primitiveSchema.toJSON()),e}toString(e="ascii"){return e==="ascii"?this.onAsciiEncoding():Z.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${Z.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(e){if(this===e)return!0;if(!(e instanceof this.constructor))return!1;let t=this.toBER(),n=e.toBER();return th(t,n)}};Te.NAME="BaseBlock";function ih(r){if(r instanceof D.Constructed)for(let e of r.valueBlock.value)ih(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var qs=class extends Te{constructor({value:e=Vn,...t}={},n){super(t,n),e&&this.fromString(e)}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}fromBER(e,t,n){let o=this.valueBlock.fromBER(e,t,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}'`}};qs.NAME="BaseStringBlock";var zs=class extends Qt(Pe){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};zs.NAME="PrimitiveValueBlock";var ah,Gs=class extends Te{constructor(e={}){super(e,zs),this.idBlock.isConstructed=!1}};ah=Gs;D.Primitive=ah;Gs.NAME="PRIMITIVE";function gw(r,e){if(r instanceof e)return r;let t=new e;return t.idBlock=r.idBlock,t.lenBlock=r.lenBlock,t.warnings=r.warnings,t.valueBeforeDecodeView=r.valueBeforeDecodeView,t}function ki(r,e=0,t=r.length){let n=e,o=new Te({},Pe),s=new Yt;if(!Xt(s,r,e,t))return o.error=s.error,{offset:-1,result:o};if(!r.subarray(e,e+t).length)return o.error="Zero buffer length",{offset:-1,result:o};let a=o.idBlock.fromBER(r,e,t);if(o.idBlock.warnings.length&&o.warnings.concat(o.idBlock.warnings),a===-1)return o.error=o.idBlock.error,{offset:-1,result:o};if(e=a,t-=o.idBlock.blockLength,a=o.lenBlock.fromBER(r,e,t),o.lenBlock.warnings.length&&o.warnings.concat(o.lenBlock.warnings),a===-1)return o.error=o.lenBlock.error,{offset:-1,result:o};if(e=a,t-=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=Te;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=D.EndOfContent;break;case 1:c=D.Boolean;break;case 2:c=D.Integer;break;case 3:c=D.BitString;break;case 4:c=D.OctetString;break;case 5:c=D.Null;break;case 6:c=D.ObjectIdentifier;break;case 10:c=D.Enumerated;break;case 12:c=D.Utf8String;break;case 13:c=D.RelativeObjectIdentifier;break;case 14:c=D.TIME;break;case 15:return o.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:o};case 16:c=D.Sequence;break;case 17:c=D.Set;break;case 18:c=D.NumericString;break;case 19:c=D.PrintableString;break;case 20:c=D.TeletexString;break;case 21:c=D.VideotexString;break;case 22:c=D.IA5String;break;case 23:c=D.UTCTime;break;case 24:c=D.GeneralizedTime;break;case 25:c=D.GraphicString;break;case 26:c=D.VisibleString;break;case 27:c=D.GeneralString;break;case 28:c=D.UniversalString;break;case 29:c=D.CharacterString;break;case 30:c=D.BmpString;break;case 31:c=D.DATE;break;case 32:c=D.TimeOfDay;break;case 33:c=D.DateTime;break;case 34:c=D.Duration;break;default:{let f=o.idBlock.isConstructed?new D.Constructed:new D.Primitive;f.idBlock=o.idBlock,f.lenBlock=o.lenBlock,f.warnings=o.warnings,o=f}}break;case 2:case 3:case 4:default:c=o.idBlock.isConstructed?D.Constructed:D.Primitive}return o=gw(o,c),a=o.fromBER(r,e,o.lenBlock.isIndefiniteForm?t:o.lenBlock.length),o.valueBeforeDecodeView=r.subarray(n,n+o.blockLength),{offset:a,result:o}}function Mn(r){if(!r.byteLength){let e=new Te({},Pe);return e.error="Input buffer has zero length",{offset:-1,result:e}}return ki(Z.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function ww(r,e){return r?1:e}var Rt=class extends Pe{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n){let o=Z.BufferSourceConverter.toUint8Array(e);if(!Xt(this,o,t,n))return-1;if(this.valueBeforeDecodeView=o.subarray(t,t+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),t;let s=t;for(;ww(this.isIndefiniteForm,n)>0;){let i=ki(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===Eo)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Eo?this.value.pop():this.warnings.push("No EndOfContent block encoded")),s}toBER(e,t){let n=t||new xo;for(let o=0;o<this.value.length;o++)this.value[o].toBER(e,n);return t?wt:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};Rt.NAME="ConstructedValueBlock";var ch,Ar=class extends Te{constructor(e={}){super(e,Rt),this.idBlock.isConstructed=!0}fromBER(e,t,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let o=this.valueBlock.fromBER(e,t,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 e=[];for(let n of this.valueBlock.value)e.push(n.toString("ascii").split(`
2
+ "use strict";var HeliaHttp=(()=>{var v0=Object.create;var Wo=Object.defineProperty;var A0=Object.getOwnPropertyDescriptor;var B0=Object.getOwnPropertyNames;var k0=Object.getPrototypeOf,S0=Object.prototype.hasOwnProperty;var Ot=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),xe=(r,e)=>{for(var t in e)Wo(r,t,{get:e[t],enumerable:!0})},Wu=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of B0(e))!S0.call(r,o)&&o!==t&&Wo(r,o,{get:()=>e[o],enumerable:!(n=A0(e,o))||n.enumerable});return r};var ot=(r,e,t)=>(t=r!=null?v0(k0(r)):{},Wu(e||!r||!r.__esModule?Wo(t,"default",{value:r,enumerable:!0}):t,r)),I0=r=>Wu(Wo({},"__esModule",{value:!0}),r);var Ql=Ot((Kv,Xl)=>{var fn=1e3,hn=fn*60,dn=hn*60,Vr=dn*24,uy=Vr*7,ly=Vr*365.25;Xl.exports=function(r,e){e=e||{};var t=typeof r;if(t==="string"&&r.length>0)return fy(r);if(t==="number"&&isFinite(r))return e.long?dy(r):hy(r);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(r))};function fy(r){if(r=String(r),!(r.length>100)){var e=/^(-?(?:\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(e){var t=parseFloat(e[1]),n=(e[2]||"ms").toLowerCase();switch(n){case"years":case"year":case"yrs":case"yr":case"y":return t*ly;case"weeks":case"week":case"w":return t*uy;case"days":case"day":case"d":return t*Vr;case"hours":case"hour":case"hrs":case"hr":case"h":return t*dn;case"minutes":case"minute":case"mins":case"min":case"m":return t*hn;case"seconds":case"second":case"secs":case"sec":case"s":return t*fn;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return t;default:return}}}}function hy(r){var e=Math.abs(r);return e>=Vr?Math.round(r/Vr)+"d":e>=dn?Math.round(r/dn)+"h":e>=hn?Math.round(r/hn)+"m":e>=fn?Math.round(r/fn)+"s":r+"ms"}function dy(r){var e=Math.abs(r);return e>=Vr?ms(r,e,Vr,"day"):e>=dn?ms(r,e,dn,"hour"):e>=hn?ms(r,e,hn,"minute"):e>=fn?ms(r,e,fn,"second"):r+" ms"}function ms(r,e,t,n){var o=e>=t*1.5;return Math.round(r/t)+" "+n+(o?"s":"")}});var tf=Ot((qv,ef)=>{function py(r){t.debug=t,t.default=t,t.coerce=c,t.disable=s,t.enable=o,t.enabled=i,t.humanize=Ql(),t.destroy=f,Object.keys(r).forEach(u=>{t[u]=r[u]}),t.names=[],t.skips=[],t.formatters={};function e(u){let l=0;for(let h=0;h<u.length;h++)l=(l<<5)-l+u.charCodeAt(h),l|=0;return t.colors[Math.abs(l)%t.colors.length]}t.selectColor=e;function t(u){let l,h=null,g,y;function p(...m){if(!p.enabled)return;let w=p,I=Number(new Date),v=I-(l||I);w.diff=v,w.prev=l,w.curr=I,l=I,m[0]=t.coerce(m[0]),typeof m[0]!="string"&&m.unshift("%O");let U=0;m[0]=m[0].replace(/%([a-zA-Z%])/g,(_,L)=>{if(_==="%%")return"%";U++;let b=t.formatters[L];if(typeof b=="function"){let C=m[U];_=b.call(w,C),m.splice(U,1),U--}return _}),t.formatArgs.call(w,m),(w.log||t.log).apply(w,m)}return p.namespace=u,p.useColors=t.useColors(),p.color=t.selectColor(u),p.extend=n,p.destroy=t.destroy,Object.defineProperty(p,"enabled",{enumerable:!0,configurable:!1,get:()=>h!==null?h:(g!==t.namespaces&&(g=t.namespaces,y=t.enabled(u)),y),set:m=>{h=m}}),typeof t.init=="function"&&t.init(p),p}function n(u,l){let h=t(this.namespace+(typeof l>"u"?":":l)+u);return h.log=this.log,h}function o(u){t.save(u),t.namespaces=u,t.names=[],t.skips=[];let l,h=(typeof u=="string"?u:"").split(/[\s,]+/),g=h.length;for(l=0;l<g;l++)h[l]&&(u=h[l].replace(/\*/g,".*?"),u[0]==="-"?t.skips.push(new RegExp("^"+u.slice(1)+"$")):t.names.push(new RegExp("^"+u+"$")))}function s(){let u=[...t.names.map(a),...t.skips.map(a).map(l=>"-"+l)].join(",");return t.enable(""),u}function i(u){if(u[u.length-1]==="*")return!0;let l,h;for(l=0,h=t.skips.length;l<h;l++)if(t.skips[l].test(u))return!1;for(l=0,h=t.names.length;l<h;l++)if(t.names[l].test(u))return!0;return!1}function a(u){return u.toString().substring(2,u.toString().length-2).replace(/\.\*\?$/,"*")}function c(u){return u instanceof Error?u.stack||u.message:u}function f(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return t.enable(t.load()),t}ef.exports=py});var rf=Ot((je,ys)=>{je.formatArgs=yy;je.save=gy;je.load=wy;je.useColors=my;je.storage=by();je.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`."))}})();je.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 my(){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 yy(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 e="color: "+this.color;r.splice(1,0,e,"color: inherit");let t=0,n=0;r[0].replace(/%[a-zA-Z%]/g,o=>{o!=="%%"&&(t++,o==="%c"&&(n=t))}),r.splice(n,0,e)}je.log=console.debug||console.log||(()=>{});function gy(r){try{r?je.storage.setItem("debug",r):je.storage.removeItem("debug")}catch{}}function wy(){let r;try{r=je.storage.getItem("debug")}catch{}return!r&&typeof process<"u"&&"env"in process&&(r=process.env.DEBUG),r}function by(){try{return localStorage}catch{}}ys.exports=tf()(je);var{formatters:xy}=ys.exports;xy.j=function(r){try{return JSON.stringify(r)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}});var pn=Ot((Gv,of)=>{"use strict";function nf(r,e){for(let t in e)Object.defineProperty(r,t,{value:e[t],enumerable:!0,configurable:!0});return r}function Ay(r,e,t){if(!r||typeof r=="string")throw new TypeError("Please pass an Error to err-code");t||(t={}),typeof e=="object"&&(t=e,e=""),e&&(t.code=e);try{return nf(r,t)}catch{t.message=r.message,t.stack=r.stack;let o=function(){};return o.prototype=Object.create(Object.getPrototypeOf(r)),nf(new o,t)}}of.exports=Ay});var gf=Ot(ho=>{(function(){var r,e,t,n,o,s,i,a;a=function(c){var f,u,l,h;return f=(c&255<<24)>>>24,u=(c&255<<16)>>>16,l=(c&65280)>>>8,h=c&255,[f,u,l,h].join(".")},i=function(c){var f,u,l,h,g,y;for(f=[],l=h=0;h<=3&&c.length!==0;l=++h){if(l>0){if(c[0]!==".")throw new Error("Invalid IP");c=c.substring(1)}y=e(c),g=y[0],u=y[1],c=c.substring(u),f.push(g)}if(c.length!==0)throw new Error("Invalid IP");switch(f.length){case 1:if(f[0]>4294967295)throw new Error("Invalid IP");return f[0]>>>0;case 2:if(f[0]>255||f[1]>16777215)throw new Error("Invalid IP");return(f[0]<<24|f[1])>>>0;case 3:if(f[0]>255||f[1]>255||f[2]>65535)throw new Error("Invalid IP");return(f[0]<<24|f[1]<<16|f[2])>>>0;case 4:if(f[0]>255||f[1]>255||f[2]>255||f[3]>255)throw new Error("Invalid IP");return(f[0]<<24|f[1]<<16|f[2]<<8|f[3])>>>0;default:throw new Error("Invalid IP")}},t=function(c){return c.charCodeAt(0)},n=t("0"),s=t("a"),o=t("A"),e=function(c){var f,u,l,h,g;for(h=0,f=10,u="9",l=0,c.length>1&&c[l]==="0"&&(c[l+1]==="x"||c[l+1]==="X"?(l+=2,f=16):"0"<=c[l+1]&&c[l+1]<="9"&&(l++,f=8,u="7")),g=l;l<c.length;){if("0"<=c[l]&&c[l]<=u)h=h*f+(t(c[l])-n)>>>0;else if(f===16)if("a"<=c[l]&&c[l]<="f")h=h*f+(10+t(c[l])-s)>>>0;else if("A"<=c[l]&&c[l]<="F")h=h*f+(10+t(c[l])-o)>>>0;else break;else break;if(h>4294967295)throw new Error("too large");l++}if(l===g)throw new Error("empty octet");return[h,l]},r=function(){function c(f,u){var l,h,g,y;if(typeof f!="string")throw new Error("Missing `net' parameter");if(u||(y=f.split("/",2),f=y[0],u=y[1]),u||(u=32),typeof u=="string"&&u.indexOf(".")>-1){try{this.maskLong=i(u)}catch(p){throw l=p,new Error("Invalid mask: "+u)}for(h=g=32;g>=0;h=--g)if(this.maskLong===4294967295<<32-h>>>0){this.bitmask=h;break}}else if(u||u===0)this.bitmask=parseInt(u,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(f)&this.maskLong)>>>0}catch(p){throw l=p,new Error("Invalid net address: "+f)}if(!(this.bitmask<=32))throw new Error("Invalid mask for ip4: "+u);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(f){return typeof f=="string"&&(f.indexOf("/")>0||f.split(".").length!==4)&&(f=new c(f)),f instanceof c?this.contains(f.base)&&this.contains(f.broadcast||f.last):(i(f)&this.maskLong)>>>0===(this.netLong&this.maskLong)>>>0},c.prototype.next=function(f){return f==null&&(f=1),new c(a(this.netLong+this.size*f),this.mask)},c.prototype.forEach=function(f){var u,l,h;for(h=i(this.first),l=i(this.last),u=0;h<=l;)f(a(h),h,u),u++,h++},c.prototype.toString=function(){return this.base+"/"+this.bitmask},c}(),ho.ip2long=i,ho.long2ip=a,ho.Netmask=r}).call(ho)});var Qf=Ot(On=>{"use strict";var uw="[object ArrayBuffer]",Yt=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===uw}static toArrayBuffer(e){return this.isArrayBuffer(e)?e:e.byteLength===e.buffer.byteLength||e.byteOffset===0&&e.byteLength===e.buffer.byteLength?e.buffer:this.toUint8Array(e.buffer).slice(e.byteOffset,e.byteOffset+e.byteLength).buffer}static toUint8Array(e){return this.toView(e,Uint8Array)}static toView(e,t){if(e.constructor===t)return e;if(this.isArrayBuffer(e))return new t(e);if(this.isArrayBufferView(e))return new t(e.buffer,e.byteOffset,e.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(e){return this.isArrayBufferView(e)||this.isArrayBuffer(e)}static isArrayBufferView(e){return ArrayBuffer.isView(e)||e&&this.isArrayBuffer(e.buffer)}static isEqual(e,t){let n=r.toUint8Array(e),o=r.toUint8Array(t);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(...e){let t;Array.isArray(e[0])&&!(e[1]instanceof Function)||Array.isArray(e[0])&&e[1]instanceof Function?t=e[0]:e[e.length-1]instanceof Function?t=e.slice(0,e.length-1):t=e;let n=0;for(let i of t)n+=i.byteLength;let o=new Uint8Array(n),s=0;for(let i of t){let a=this.toUint8Array(i);o.set(a,s),s+=a.length}return e[e.length-1]instanceof Function?this.toView(o,e[e.length-1]):o.buffer}},$c="string",lw=/^[0-9a-f]+$/i,fw=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,hw=/^[a-zA-Z0-9-_]+$/,Fs=class{static fromString(e){let t=unescape(encodeURIComponent(e)),n=new Uint8Array(t.length);for(let o=0;o<t.length;o++)n[o]=t.charCodeAt(o);return n.buffer}static toString(e){let t=Yt.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return decodeURIComponent(escape(n))}},ct=class{static toString(e,t=!1){let n=Yt.toArrayBuffer(e),o=new DataView(n),s="";for(let i=0;i<n.byteLength;i+=2){let a=o.getUint16(i,t);s+=String.fromCharCode(a)}return s}static fromString(e,t=!1){let n=new ArrayBuffer(e.length*2),o=new DataView(n);for(let s=0;s<e.length;s++)o.setUint16(s*2,e.charCodeAt(s),t);return n}},Vs=class r{static isHex(e){return typeof e===$c&&lw.test(e)}static isBase64(e){return typeof e===$c&&fw.test(e)}static isBase64Url(e){return typeof e===$c&&hw.test(e)}static ToString(e,t="utf8"){let n=Yt.toUint8Array(e);switch(t.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 ct.toString(n,!0);case"utf16":case"utf16be":return ct.toString(n);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromString(e,t="utf8"){if(!e)return new ArrayBuffer(0);switch(t.toLowerCase()){case"utf8":return this.FromUtf8String(e);case"binary":return this.FromBinary(e);case"hex":return this.FromHex(e);case"base64":return this.FromBase64(e);case"base64url":return this.FromBase64Url(e);case"utf16le":return ct.fromString(e,!0);case"utf16":case"utf16be":return ct.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=Yt.toUint8Array(e);if(typeof btoa<"u"){let n=this.ToString(t,"binary");return btoa(n)}else return Buffer.from(t).toString("base64")}static FromBase64(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64(t))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(t)):new Uint8Array(Buffer.from(t,"base64")).buffer}static FromBase64Url(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64Url(t))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(t.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(e){return this.ToBase64(e).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.FromBinary(e);case"utf8":return Fs.fromString(e);case"utf16":case"utf16be":return ct.fromString(e);case"utf16le":case"usc2":return ct.fromString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.ToBinary(e);case"utf8":return Fs.toString(e);case"utf16":case"utf16be":return ct.toString(e);case"utf16le":case"usc2":return ct.toString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromBinary(e){let t=e.length,n=new Uint8Array(t);for(let o=0;o<t;o++)n[o]=e.charCodeAt(o);return n.buffer}static ToBinary(e){let t=Yt.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return n}static ToHex(e){let t=Yt.toUint8Array(e),n="",o=t.length;for(let s=0;s<o;s++){let i=t[s];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isHex(t))throw new TypeError("Argument 'hexString' is not HEX encoded");t.length%2&&(t=`0${t}`);let n=new Uint8Array(t.length/2);for(let o=0;o<t.length;o=o+2){let s=t.slice(o,o+2);n[o/2]=parseInt(s,16)}return n.buffer}static ToUtf16String(e,t=!1){return ct.toString(e,t)}static FromUtf16String(e,t=!1){return ct.fromString(e,t)}static Base64Padding(e){let t=4-e.length%4;if(t<4)for(let n=0;n<t;n++)e+="=";return e}static formatString(e){return e?.replace(/[\n\r\t ]/g,"")||""}};Vs.DEFAULT_UTF8_ENCODING="utf8";function dw(r,...e){let t=arguments[0];for(let n=1;n<arguments.length;n++){let o=arguments[n];for(let s in o)t[s]=o[s]}return t}function pw(...r){let e=r.map(o=>o.byteLength).reduce((o,s)=>o+s),t=new Uint8Array(e),n=0;return r.map(o=>new Uint8Array(o)).forEach(o=>{for(let s of o)t[n++]=s}),t.buffer}function mw(r,e){if(!(r&&e)||r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let o=0;o<r.byteLength;o++)if(t[o]!==n[o])return!1;return!0}On.BufferSourceConverter=Yt;On.Convert=Vs;On.assign=dw;On.combine=pw;On.isEqual=mw});var nu=Ot((Lk,ru)=>{var Ck=function(){typeof ru<"u"&&(ru.exports=p);var r=86400,e=3200,t=146097*e/400,n=r*t,o=1e3*n,s=864e13,i=4294967296,a=1e6,c="000000000",f=Math.trunc||function(b){var C=b-b%1;return C==0&&(b<0||b===0&&1/b!=1/0)?-0:C},u=p.prototype,l=(p.fromDate=function(b){return new p(+b)},p.fromInt64BE=U(0,1,2,3,0,4),p.fromInt64LE=U(3,2,1,0,4,0),p.fromString=function(T){var C,O=new p,T=(T+="").replace(/^\s*[+\-]?\d+/,function(H){var H=+H,X=1970+(H-1970)%400;return O.year=H-X,X}).replace(/(?:Z|([+\-]\d{2}):?(\d{2}))$/,function(V,H,X){return H<0&&(X*=-1),C=6e4*(60*+H+ +X),""}).replace(/\.\d+$/,function(V){return O.nano=+(V+c).substr(1,9),""}).split(/\D+/);if(1<T.length?T[1]--:T[1]=0,O.time=C=Date.UTC.apply(Date,T)-(C||0),isNaN(C))throw new TypeError("Invalid Date");return m(O)},p.fromTimeT=function(b){return I(b,0)},u.year=0,u.time=0,u.nano=0,u.addNano=function(b){return this.nano+=+b||0,this},u.getNano=function(){var b=m(this);return(b.time%1e3*a+ +b.nano+1e9)%1e9},u.getTimeT=function(){var C=m(this),b=Math.floor(C.time/1e3),C=C.year;return C&&(b+=C*t*r/e),b},u.getYear=function(){return this.toDate().getUTCFullYear()+this.year},u.toDate=function(){return w(m(this).time)},u.toJSON=function(){return this.toString().replace(/0{1,6}Z$/,"Z")},u.toString=function(b){var C=this,O=C.toDate(),T={H:function(){return _(O.getUTCHours())},L:function(){return L(O.getUTCMilliseconds(),3)},M:function(){return _(O.getUTCMinutes())},N:function(){return L(C.getNano(),9)},S:function(){return _(O.getUTCSeconds())},Y:function(){var V=C.getYear();return 999999<V?"+"+V:9999<V?"+"+L(V,6):0<=V?L(V,4):-999999<=V?"-"+L(-V,6):V},a:function(){return g[O.getUTCDay()]},b:function(){return h[O.getUTCMonth()]},d:function(){return _(O.getUTCDate())},e:function(){return function(V){return(9<V?"":" ")+(0|V)}(O.getUTCDate())},m:function(){return _(O.getUTCMonth()+1)}};return function V(H){return H.replace(/%./g,function(X){var k=X[1],E=y[k],k=T[k];return E?V(E):k?k():X})}(b||l)},u.writeInt64BE=v(0,1,2,3,0,4),u.writeInt64LE=v(3,2,1,0,4,0),"%Y-%m-%dT%H:%M:%S.%NZ"),h=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],g=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],y={"%":"%",F:"%Y-%m-%d",n:`
3
+ `,R:"%H:%M",T:"%H:%M:%S",t:" ",X:"%T",Z:"GMT",z:"+0000"};return p;function p(b,C,O){var T=this;if(!(T instanceof p))return new p(b,C,O);T.time=+b||0,T.nano=+C||0,T.year=+O||0,m(T)}function m(b){var C,O,T,V=b.year,H=b.time,X=b.nano,E=((X<0||a<=X)&&(X-=(O=Math.floor(X/a))*a,H+=O,O=1),V%e);return(H<-s||s<H||E)&&((C=f(H/o))&&(V+=C*e,H-=C*o),(T=w(H)).setUTCFullYear(E+T.getUTCFullYear()),T=(H=+T)+(C=f((V-=E)/e))*o,C&&-s<=T&&T<=s&&(V-=C*e,H=T),O=1),O&&(b.year=V,b.time=H,b.nano=X),b}function w(b){var C=new Date(0);return C.setTime(b),C}function I(V,T){V=+V||0;var O=f((T=(T|0)*i)/n)+f(V/n),T=T%n+V%n,V=f(T/n);return V&&(O+=V,T-=V*n),new p(1e3*T,0,O*e)}function v(b,C,O,T,V,H){return function(E,k){var B=m(this);E=E||new Array(8),S(E,k|=0);var x=Math.floor(B.time/1e3),B=B.year*(t*r/e),$=f(B/i)+f(x/i),B=B%i+x%i,x=Math.floor(B/i);return x&&($+=x,B-=x*i),X(E,k+V,$),X(E,k+H,B),E};function X(E,k,$){E[k+b]=$>>24&255,E[k+C]=$>>16&255,E[k+O]=$>>8&255,E[k+T]=255&$}}function U(b,C,O,T,V,H){return function(E,k){S(E,k|=0);var $=X(E,k+V);return I(X(E,k+H),$)};function X(E,k){return 16777216*E[k+b]+(E[k+C]<<16|E[k+O]<<8|E[k+T])}}function S(b,C){if(b=b&&b.length,b==null)throw new TypeError("Invalid Buffer");if(b<C+8)throw new RangeError("Out of range")}function _(b){return(9<b?"":"0")+(0|b)}function L(b,C){return(c+(0|b)).substr(-C)}}()});var Ap=Ot((yS,du)=>{"use strict";var Lb=Object.prototype.hasOwnProperty,He="~";function Mo(){}Object.create&&(Mo.prototype=Object.create(null),new Mo().__proto__||(He=!1));function Ub(r,e,t){this.fn=r,this.context=e,this.once=t||!1}function vp(r,e,t,n,o){if(typeof t!="function")throw new TypeError("The listener must be a function");var s=new Ub(t,n||r,o),i=He?He+e:e;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 zi(r,e){--r._eventsCount===0?r._events=new Mo:delete r._events[e]}function Oe(){this._events=new Mo,this._eventsCount=0}Oe.prototype.eventNames=function(){var e=[],t,n;if(this._eventsCount===0)return e;for(n in t=this._events)Lb.call(t,n)&&e.push(He?n.slice(1):n);return Object.getOwnPropertySymbols?e.concat(Object.getOwnPropertySymbols(t)):e};Oe.prototype.listeners=function(e){var t=He?He+e:e,n=this._events[t];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};Oe.prototype.listenerCount=function(e){var t=He?He+e:e,n=this._events[t];return n?n.fn?1:n.length:0};Oe.prototype.emit=function(e,t,n,o,s,i){var a=He?He+e:e;if(!this._events[a])return!1;var c=this._events[a],f=arguments.length,u,l;if(c.fn){switch(c.once&&this.removeListener(e,c.fn,void 0,!0),f){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,t),!0;case 3:return c.fn.call(c.context,t,n),!0;case 4:return c.fn.call(c.context,t,n,o),!0;case 5:return c.fn.call(c.context,t,n,o,s),!0;case 6:return c.fn.call(c.context,t,n,o,s,i),!0}for(l=1,u=new Array(f-1);l<f;l++)u[l-1]=arguments[l];c.fn.apply(c.context,u)}else{var h=c.length,g;for(l=0;l<h;l++)switch(c[l].once&&this.removeListener(e,c[l].fn,void 0,!0),f){case 1:c[l].fn.call(c[l].context);break;case 2:c[l].fn.call(c[l].context,t);break;case 3:c[l].fn.call(c[l].context,t,n);break;case 4:c[l].fn.call(c[l].context,t,n,o);break;default:if(!u)for(g=1,u=new Array(f-1);g<f;g++)u[g-1]=arguments[g];c[l].fn.apply(c[l].context,u)}}return!0};Oe.prototype.on=function(e,t,n){return vp(this,e,t,n,!1)};Oe.prototype.once=function(e,t,n){return vp(this,e,t,n,!0)};Oe.prototype.removeListener=function(e,t,n,o){var s=He?He+e:e;if(!this._events[s])return this;if(!t)return zi(this,s),this;var i=this._events[s];if(i.fn)i.fn===t&&(!o||i.once)&&(!n||i.context===n)&&zi(this,s);else{for(var a=0,c=[],f=i.length;a<f;a++)(i[a].fn!==t||o&&!i[a].once||n&&i[a].context!==n)&&c.push(i[a]);c.length?this._events[s]=c.length===1?c[0]:c:zi(this,s)}return this};Oe.prototype.removeAllListeners=function(e){var t;return e?(t=He?He+e:e,this._events[t]&&zi(this,t)):(this._events=new Mo,this._eventsCount=0),this};Oe.prototype.off=Oe.prototype.removeListener;Oe.prototype.addListener=Oe.prototype.on;Oe.prefixed=He;Oe.EventEmitter=Oe;typeof du<"u"&&(du.exports=Oe)});var Up=Ot((bI,Lp)=>{Lp.exports=function(r){if(!r)throw Error("hashlru must have a max value, of type number, greater than 0");var e=0,t=Object.create(null),n=Object.create(null);function o(s,i){t[s]=i,e++,e>=r&&(e=0,n=t,t=Object.create(null))}return{has:function(s){return t[s]!==void 0||n[s]!==void 0},remove:function(s){t[s]!==void 0&&(t[s]=void 0),n[s]!==void 0&&(n[s]=void 0)},get:function(s){var i=t[s];if(i!==void 0)return i;if((i=n[s])!==void 0)return o(s,i),i},set:function(s,i){t[s]!==void 0?t[s]=i:o(s,i)},clear:function(){t=Object.create(null),n=Object.create(null)}}}});var xx={};xe(xx,{DEFAULT_SESSION_MAX_PROVIDERS:()=>Zu,DEFAULT_SESSION_MIN_PROVIDERS:()=>Yu,DEFAULT_SESSION_PROVIDER_QUERY_CONCURRENCY:()=>Ju,DEFAULT_SESSION_PROVIDER_QUERY_TIMEOUT:()=>Xu,createHeliaHTTP:()=>bx});var Yu=1,Zu=5,Ju=5,Xu=5e3;var eo=Symbol.for("@libp2p/content-routing");var la=Symbol.for("@libp2p/peer-id");function Qu(r){return r!=null&&!!r[la]}var to=Symbol.for("@libp2p/peer-routing");var ar=class r extends Error{code;type;constructor(e="The operation was aborted"){super(e),this.name="AbortError",this.code=r.code,this.type=r.type}static code="ABORT_ERR";static type="aborted"},N=class extends Error{code;props;constructor(e,t,n){super(e),this.code=t,this.name=n?.name??"CodeError",this.props=n??{}}};var cr=(r,...e)=>{try{[...e]}catch{}};var Yo=class extends EventTarget{#e=new Map;constructor(){super(),cr(1/0,this)}listenerCount(e){let t=this.#e.get(e);return t==null?0:t.length}addEventListener(e,t,n){super.addEventListener(e,t,n);let o=this.#e.get(e);o==null&&(o=[],this.#e.set(e,o)),o.push({callback:t,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(e,t,n){super.removeEventListener(e.toString(),t??null,n);let o=this.#e.get(e);o!=null&&(o=o.filter(({callback:s})=>s!==t),this.#e.set(e,o))}dispatchEvent(e){let t=super.dispatchEvent(e),n=this.#e.get(e.type);return n==null||(n=n.filter(({once:o})=>!o),this.#e.set(e.type,n)),t}safeDispatchEvent(e,t={}){return this.dispatchEvent(new R0(e,t))}},fa=class extends Event{detail;constructor(e,t){super(e,t),this.detail=t?.detail}},R0=globalThis.CustomEvent??fa;function el(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function ur(...r){let e=[];for(let t of r)el(t)&&e.push(t);await Promise.all(e.map(async t=>{t.beforeStart!=null&&await t.beforeStart()})),await Promise.all(e.map(async t=>{await t.start()})),await Promise.all(e.map(async t=>{t.afterStart!=null&&await t.afterStart()}))}async function lr(...r){let e=[];for(let t of r)el(t)&&e.push(t);await Promise.all(e.map(async t=>{t.beforeStop!=null&&await t.beforeStop()})),await Promise.all(e.map(async t=>{await t.stop()})),await Promise.all(e.map(async t=>{t.afterStop!=null&&await t.afterStop()}))}function Dr(r){let e=new globalThis.AbortController;function t(){e.abort();for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",t)}for(let s of r){if(s?.aborted===!0){t();break}s?.addEventListener!=null&&s.addEventListener("abort",t)}function n(){for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",t)}let o=e.signal;return o.clear=n,o}function Ie(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var Zo=class{buffer;mask;top;btm;next;constructor(e){if(!(e>0)||e-1&e)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},en=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new Zo(this.hwm),this.tail=this.head,this.size=0}calculateSize(e){return e?.byteLength!=null?e.byteLength:1}push(e){if(e?.value!=null&&(this.size+=this.calculateSize(e.value)),!this.head.push(e)){let t=this.head;this.head=t.next=new Zo(2*this.head.buffer.length),this.head.push(e)}}shift(){let e=this.tail.shift();if(e===void 0&&this.tail.next!=null){let t=this.tail.next;this.tail.next=null,this.tail=t,e=this.tail.shift()}return e?.value!=null&&(this.size-=this.calculateSize(e.value)),e}isEmpty(){return this.head.isEmpty()}};var ha=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function Ft(r={}){return _0(t=>{let n=t.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function _0(r,e){e=e??{};let t=e.onEnd,n=new en,o,s,i,a=Ie(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((m,w)=>{s=I=>{s=null,n.push(I);try{m(r(n))}catch(v){w(v)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ie()})}},f=m=>s!=null?s(m):(n.push(m),o),u=m=>(n=new en,s!=null?s({error:m}):(n.push({error:m}),o)),l=m=>{if(i)return o;if(e?.objectMode!==!0&&m?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:m})},h=m=>i?o:(i=!0,m!=null?u(m):f({done:!0})),g=()=>(n=new en,h(),{done:!0}),y=m=>(h(m),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:g,throw:y,push:l,end:h,get readableLength(){return n.size},onEmpty:async m=>{let w=m?.signal;if(w?.throwIfAborted(),n.isEmpty())return;let I,v;w!=null&&(I=new Promise((U,S)=>{v=()=>{S(new ha)},w.addEventListener("abort",v)}));try{await Promise.race([a.promise,I])}finally{v!=null&&w!=null&&w?.removeEventListener("abort",v)}}},t==null)return o;let p=o;return o={[Symbol.asyncIterator](){return this},next(){return p.next()},throw(m){return p.throw(m),t!=null&&(t(m),t=void 0),{done:!0}},return(){return p.return(),t!=null&&(t(),t=void 0),{done:!0}},push:l,end(m){return p.end(m),t!=null&&(t(m),t=void 0),o},get readableLength(){return p.readableLength},onEmpty:m=>p.onEmpty(m)},o}var da=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=t??"ABORT_ERR"}};async function Jo(r,e,t,n){let o=new da(n?.errorMessage,n?.errorCode);return t?.aborted===!0?Promise.reject(o):new Promise((s,i)=>{let a=f=>{try{if(n?.filter?.(f)===!1)return}catch(u){r.removeEventListener(e,a),t?.removeEventListener("abort",c),i(u);return}r.removeEventListener(e,a),t?.removeEventListener("abort",c),s(f)},c=()=>{r.removeEventListener(e,a),t?.removeEventListener("abort",c),i(o)};r.addEventListener(e,a),t?.addEventListener("abort",c)})}var Xo=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=t??"ABORT_ERR"}};async function tl(r,e,t){if(e==null)return r;if(e.aborted)return Promise.reject(new Xo(t?.errorMessage,t?.errorCode));let n,o=new Xo(t?.errorMessage,t?.errorCode);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var Qo=class{deferred;signal;where;constructor(e,t){this.signal=t,this.deferred=Ie(),this.where=e,this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(new ar)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function T0(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var es=class{id;fn;options;priority;recipients;status;timeline;controller;constructor(e,t,n=0){this.id=T0(),this.status="queued",this.fn=e,this.priority=n,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,cr(1/0,this.controller.signal),this.onAbort=this.onAbort.bind(this)}abort(e){this.controller.abort(e)}onAbort(){this.recipients.reduce((t,n)=>t&&n.signal?.aborted===!0,!0)&&this.controller.abort(new ar)}async join(e={}){let t=new Qo(new Error("where").stack,e.signal);return this.recipients.push(t),e.signal?.addEventListener("abort",this.onAbort),t.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let e=await tl(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(t=>{t.deferred.resolve(e)}),this.status="complete"}catch(e){this.recipients.forEach(t=>{t.deferred.reject(e)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(e=>{e.signal?.removeEventListener("abort",this.onAbort)})}};function N0(r,e,t){let n=0,o=r.length;for(;o>0;){let s=Math.trunc(o/2),i=n+s;t(r[i],e)<=0?(n=++i,o-=s+1):o=s}return n}var Pr=class extends Yo{concurrency;queue;pending;constructor(e={}){super(),this.concurrency=e.concurrency??Number.POSITIVE_INFINITY,this.pending=0,e.metricName!=null&&e.metrics?.registerMetricGroup(e.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 e;for(let t of this.queue)if(t.status==="queued"){e=t;break}return e==null?!1:(this.safeDispatchEvent("active"),this.pending++,e.run().finally(()=>{for(let t=0;t<this.queue.length;t++)if(this.queue[t]===e){this.queue.splice(t,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(e){if(this.queue[this.size-1]?.priority>=e.priority){this.queue.push(e);return}let t=N0(this.queue,e,(n,o)=>o.priority-n.priority);this.queue.splice(t,0,e)}async add(e,t){t?.signal?.throwIfAborted();let n=new es(e,t,t?.priority),o=n.join(t).then(s=>(this.safeDispatchEvent("completed",{detail:s}),s)).catch(s=>{throw this.safeDispatchEvent("error",{detail:s}),s});return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),o}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(e=>{e.abort(new ar)}),this.clear()}async onEmpty(e){this.size!==0&&await Jo(this,"empty",e?.signal)}async onSizeLessThan(e,t){this.size<e||await Jo(this,"next",t?.signal,{filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await Jo(this,"idle",e?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(e){e?.signal?.throwIfAborted();let t=Ft({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),t.end(c)},o=c=>{c.detail!=null&&t.push(c.detail)},s=c=>{n(c.detail)},i=()=>{n()},a=()=>{n(new N("Queue aborted","ERR_QUEUE_ABORTED"))};this.addEventListener("completed",o),this.addEventListener("error",s),this.addEventListener("idle",i),e?.signal?.addEventListener("abort",a);try{yield*t}finally{this.removeEventListener("completed",o),this.removeEventListener("error",s),this.removeEventListener("idle",i),e?.signal?.removeEventListener("abort",a),n()}}};var ts=class extends Pr{has(e){return this.find(e)!=null}find(e){return this.queue.find(t=>e.equals(t.options.peerId))}};var rs=class{index=0;input="";new(e){return this.index=0,this.input=e,this}readAtomically(e){let t=this.index,n=e();return n===void 0&&(this.index=t),n}parseWith(e){let t=e();if(this.index===this.input.length)return t}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(e){return this.readAtomically(()=>{let t=this.readChar();if(t===e)return t})}readSeparator(e,t,n){return this.readAtomically(()=>{if(!(t>0&&this.readGivenChar(e)===void 0))return n()})}readNumber(e,t,n,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",f=2**(8*o)-1;for(;;){let u=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let h=Number.parseInt(l,e);if(!Number.isNaN(h))return h});if(u===void 0)break;if(s*=e,s+=u,s>f||(i+=1,t!==void 0&&i>t))return}if(i!==0)return!n&&c&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let e=new Uint8Array(4);for(let t=0;t<e.length;t++){let n=this.readSeparator(".",t,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;e[t]=n}return e})}readIPv6Addr(){let e=t=>{for(let n=0;n<t.length/2;n++){let o=n*2;if(n<t.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return t[o]=i[0],t[o+1]=i[1],t[o+2]=i[2],t[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];t[o]=s>>8,t[o+1]=s&255}return[t.length,!1]};return this.readAtomically(()=>{let t=new Uint8Array(16),[n,o]=e(t);if(n===16)return t;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=e(s.subarray(0,i));return t.set(s.subarray(0,a),16-a),t})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var rl=45,C0=15,tn=new rs;function pa(r){if(!(r.length>C0))return tn.new(r).parseWith(()=>tn.readIPv4Addr())}function ma(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>rl))return tn.new(r).parseWith(()=>tn.readIPv6Addr())}function ns(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>rl))return tn.new(r).parseWith(()=>tn.readIPAddr())}function rn(r){return!!pa(r)}function nn(r){return!!ma(r)}function os(r){return!!ns(r)}var xa={};xe(xa,{base58btc:()=>fe,base58flickr:()=>F0});var o1=new Uint8Array(0);function nl(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function Vt(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 ol(r){return new TextEncoder().encode(r)}function sl(r){return new TextDecoder().decode(r)}function L0(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(t[i]!==255)throw new TypeError(s+" is ambiguous");t[i]=o}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(y){if(y instanceof Uint8Array||(ArrayBuffer.isView(y)?y=new Uint8Array(y.buffer,y.byteOffset,y.byteLength):Array.isArray(y)&&(y=Uint8Array.from(y))),!(y instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(y.length===0)return"";for(var p=0,m=0,w=0,I=y.length;w!==I&&y[w]===0;)w++,p++;for(var v=(I-w)*u+1>>>0,U=new Uint8Array(v);w!==I;){for(var S=y[w],_=0,L=v-1;(S!==0||_<m)&&L!==-1;L--,_++)S+=256*U[L]>>>0,U[L]=S%a>>>0,S=S/a>>>0;if(S!==0)throw new Error("Non-zero carry");m=_,w++}for(var b=v-m;b!==v&&U[b]===0;)b++;for(var C=c.repeat(p);b<v;++b)C+=r.charAt(U[b]);return C}function h(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var p=0;if(y[p]!==" "){for(var m=0,w=0;y[p]===c;)m++,p++;for(var I=(y.length-p)*f+1>>>0,v=new Uint8Array(I);y[p];){var U=t[y.charCodeAt(p)];if(U===255)return;for(var S=0,_=I-1;(U!==0||S<w)&&_!==-1;_--,S++)U+=a*v[_]>>>0,v[_]=U%256>>>0,U=U/256>>>0;if(U!==0)throw new Error("Non-zero carry");w=S,p++}if(y[p]!==" "){for(var L=I-w;L!==I&&v[L]===0;)L++;for(var b=new Uint8Array(m+(I-L)),C=m;L!==I;)b[C++]=v[L++];return b}}}function g(y){var p=h(y);if(p)return p;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:h,decode:g}}var U0=L0,D0=U0,al=D0;var ya=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},ga=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){if(this.name=e,this.prefix=t,t.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=t.codePointAt(0),this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return cl(this,e)}},wa=class{decoders;constructor(e){this.decoders=e}or(e){return cl(this,e)}decode(e){let t=e[0],n=this.decoders[t];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function cl(r,e){return new wa({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var ba=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,o){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=o,this.encoder=new ya(e,t,n),this.decoder=new ga(e,t,o)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function on({name:r,prefix:e,encode:t,decode:n}){return new ba(r,e,t,n)}function fr({name:r,prefix:e,alphabet:t}){let{encode:n,decode:o}=al(t,r);return on({prefix:e,name:r,encode:n,decode:s=>Vt(o(s))})}function P0(r,e,t,n){let o={};for(let u=0;u<e.length;++u)o[e[u]]=u;let s=r.length;for(;r[s-1]==="=";)--s;let i=new Uint8Array(s*t/8|0),a=0,c=0,f=0;for(let u=0;u<s;++u){let l=o[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<t|l,a+=t,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=t||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function O0(r,e,t){let n=e[e.length-1]==="=",o=(1<<t)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,s+=e[o&a>>i];if(i!==0&&(s+=e[o&a<<t-i]),n)for(;s.length*t&7;)s+="=";return s}function de({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return on({prefix:e,name:r,encode(o){return O0(o,n,t)},decode(o){return P0(o,n,t,r)}})}var fe=fr({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),F0=fr({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ea={};xe(Ea,{base32:()=>Re,base32hex:()=>$0,base32hexpad:()=>K0,base32hexpadupper:()=>q0,base32hexupper:()=>H0,base32pad:()=>V0,base32padupper:()=>M0,base32upper:()=>ul,base32z:()=>z0});var Re=de({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ul=de({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),V0=de({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),M0=de({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),$0=de({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),H0=de({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),K0=de({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),q0=de({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),z0=de({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var G0=hl,ll=128,j0=127,W0=~j0,Y0=Math.pow(2,31);function hl(r,e,t){e=e||[],t=t||0;for(var n=t;r>=Y0;)e[t++]=r&255|ll,r/=128;for(;r&W0;)e[t++]=r&255|ll,r>>>=7;return e[t]=r|0,hl.bytes=t-n+1,e}var Z0=va,J0=128,fl=127;function va(r,n){var t=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw va.bytes=0,new RangeError("Could not decode varint");i=r[s++],t+=o<28?(i&fl)<<o:(i&fl)*Math.pow(2,o),o+=7}while(i>=J0);return va.bytes=s-n,t}var X0=Math.pow(2,7),Q0=Math.pow(2,14),em=Math.pow(2,21),tm=Math.pow(2,28),rm=Math.pow(2,35),nm=Math.pow(2,42),om=Math.pow(2,49),sm=Math.pow(2,56),im=Math.pow(2,63),am=function(r){return r<X0?1:r<Q0?2:r<em?3:r<tm?4:r<rm?5:r<nm?6:r<om?7:r<sm?8:r<im?9:10},cm={encode:G0,decode:Z0,encodingLength:am},um=cm,ro=um;function no(r,e=0){return[ro.decode(r,e),ro.decode.bytes]}function sn(r,e,t=0){return ro.encode(r,e,t),e}function an(r){return ro.encodingLength(r)}function Bt(r,e){let t=e.byteLength,n=an(r),o=n+an(t),s=new Uint8Array(o+t);return sn(r,s,0),sn(t,s,n),s.set(e,o),new cn(r,t,e,s)}function kt(r){let e=Vt(r),[t,n]=no(e),[o,s]=no(e.subarray(n)),i=e.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new cn(t,o,i,e)}function dl(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&nl(r.bytes,t.bytes)}}var cn=class{code;size;digest;bytes;constructor(e,t,n,o){this.code=e,this.size=t,this.digest=n,this.bytes=o}};function pl(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return fm(t,Aa(r),e??fe.encoder);default:return hm(t,Aa(r),e??Re.encoder)}}var ml=new WeakMap;function Aa(r){let e=ml.get(r);if(e==null){let t=new Map;return ml.set(r,t),t}return e}var oe=class r{code;version;multihash;bytes;"/";constructor(e,t,n,o){this.code=t,this.version=e,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:e,multihash:t}=this;if(e!==oo)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==dm)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:e,digest:t}=this.multihash,n=Bt(e,t);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&dl(e.multihash,n.multihash)}toString(e){return pl(this,e)}toJSON(){return{"/":pl(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:o,multihash:s,bytes:i}=t;return new r(n,o,s,i??yl(n,o,s.bytes))}else if(t[pm]===!0){let{version:n,multihash:o,code:s}=t,i=kt(o);return r.create(n,s,i)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==oo)throw new Error(`Version 0 CID must use dag-pb (code: ${oo}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let o=yl(e,t,n.bytes);return new r(e,t,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,oo,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,o=Vt(e.subarray(n,n+t.multihashSize));if(o.byteLength!==t.multihashSize)throw new Error("Incorrect length");let s=o.subarray(t.multihashSize-t.digestSize),i=new cn(t.multihashCode,t.digestSize,s,o);return[t.version===0?r.createV0(i):r.createV1(t.codec,i),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[l,h]=no(e.subarray(t));return t+=h,l},o=n(),s=oo;if(o===18?(o=0,t=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=t,a=n(),c=n(),f=t+c,u=f-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(e,t){let[n,o]=lm(e,t),s=r.decode(o);if(s.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Aa(s).set(n,e),s}};function lm(r,e){switch(r[0]){case"Q":{let t=e??fe;return[fe.prefix,t.decode(`${fe.prefix}${r}`)]}case fe.prefix:{let t=e??fe;return[fe.prefix,t.decode(r)]}case Re.prefix:{let t=e??Re;return[Re.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function fm(r,e,t){let{prefix:n}=t;if(n!==fe.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let o=e.get(n);if(o==null){let s=t.encode(r).slice(1);return e.set(n,s),s}else return o}function hm(r,e,t){let{prefix:n}=t,o=e.get(n);if(o==null){let s=t.encode(r);return e.set(n,s),s}else return o}var oo=112,dm=18;function yl(r,e,t){let n=an(r),o=n+an(e),s=new Uint8Array(o+t.byteLength);return sn(r,s,0),sn(e,s,n),s.set(t,o),s}var pm=Symbol.for("@ipld/js-cid/CID");function ce(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}var Ba={};xe(Ba,{base10:()=>mm});var mm=fr({prefix:"9",name:"base10",alphabet:"0123456789"});var ka={};xe(ka,{base16:()=>ym,base16upper:()=>gm});var ym=de({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),gm=de({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Sa={};xe(Sa,{base2:()=>wm});var wm=de({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ia={};xe(Ia,{base256emoji:()=>Am});var gl=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=gl.reduce((r,e,t)=>(r[t]=e,r),[]),xm=gl.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function Em(r){return r.reduce((e,t)=>(e+=bm[t],e),"")}function vm(r){let e=[];for(let t of r){let n=xm[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var Am=on({prefix:"\u{1F680}",name:"base256emoji",encode:Em,decode:vm});var Ra={};xe(Ra,{base36:()=>hr,base36upper:()=>Bm});var hr=fr({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Bm=fr({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ta={};xe(Ta,{base64:()=>dr,base64pad:()=>km,base64url:()=>_a,base64urlpad:()=>Sm});var dr=de({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),km=de({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),_a=de({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Sm=de({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Na={};xe(Na,{base8:()=>Im});var Im=de({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ca={};xe(Ca,{identity:()=>Rm});var Rm=on({prefix:"\0",name:"identity",encode:r=>sl(r),decode:r=>ol(r)});var _1=new TextEncoder,T1=new TextDecoder;var wl=512;var is=85;var Ua={};xe(Ua,{identity:()=>st});var xl=0,_m="identity",El=Vt;function Tm(r){return Bt(xl,El(r))}var st={code:xl,name:_m,encode:El,digest:Tm};var Fa={};xe(Fa,{sha256:()=>Ee,sha512:()=>Oa});function Pa({name:r,code:e,encode:t}){return new Da(r,e,t)}var Da=class{name;code;encode;constructor(e,t,n){this.name=e,this.code=t,this.encode=n}digest(e){if(e instanceof Uint8Array){let t=this.encode(e);return t instanceof Uint8Array?Bt(this.code,t):t.then(n=>Bt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Al(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var Ee=Pa({name:"sha2-256",code:18,encode:Al("SHA-256")}),Oa=Pa({name:"sha2-512",code:19,encode:Al("SHA-512")});var pr={...Ca,...Sa,...Na,...Ba,...ka,...Ea,...Ra,...xa,...Ta,...Ia},K1={...Fa,...Ua};function dt(r=0){return new Uint8Array(r)}function kl(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var Bl=kl("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Va=kl("ascii","a",r=>{let e="a";for(let t=0;t<r.length;t++)e+=String.fromCharCode(r[t]);return e},r=>{r=r.substring(1);let e=dt(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),Nm={utf8:Bl,"utf-8":Bl,hex:pr.base16,latin1:Va,ascii:Va,binary:Va,...pr},as=Nm;function z(r,e="utf8"){let t=as[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var Cm=Math.pow(2,7),Lm=Math.pow(2,14),Um=Math.pow(2,21),Ma=Math.pow(2,28),$a=Math.pow(2,35),Ha=Math.pow(2,42),Ka=Math.pow(2,49),se=128,Ue=127;function Ke(r){if(r<Cm)return 1;if(r<Lm)return 2;if(r<Um)return 3;if(r<Ma)return 4;if(r<$a)return 5;if(r<Ha)return 6;if(r<Ka)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function qa(r,e,t=0){switch(Ke(r)){case 8:e[t++]=r&255|se,r/=128;case 7:e[t++]=r&255|se,r/=128;case 6:e[t++]=r&255|se,r/=128;case 5:e[t++]=r&255|se,r/=128;case 4:e[t++]=r&255|se,r>>>=7;case 3:e[t++]=r&255|se,r>>>=7;case 2:e[t++]=r&255|se,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function Dm(r,e,t=0){switch(Ke(r)){case 8:e.set(t++,r&255|se),r/=128;case 7:e.set(t++,r&255|se),r/=128;case 6:e.set(t++,r&255|se),r/=128;case 5:e.set(t++,r&255|se),r/=128;case 4:e.set(t++,r&255|se),r>>>=7;case 3:e.set(t++,r&255|se),r>>>=7;case 2:e.set(t++,r&255|se),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function za(r,e){let t=r[e],n=0;if(n+=t&Ue,t<se||(t=r[e+1],n+=(t&Ue)<<7,t<se)||(t=r[e+2],n+=(t&Ue)<<14,t<se)||(t=r[e+3],n+=(t&Ue)<<21,t<se)||(t=r[e+4],n+=(t&Ue)*Ma,t<se)||(t=r[e+5],n+=(t&Ue)*$a,t<se)||(t=r[e+6],n+=(t&Ue)*Ha,t<se)||(t=r[e+7],n+=(t&Ue)*Ka,t<se))return n;throw new RangeError("Could not decode varint")}function Pm(r,e){let t=r.get(e),n=0;if(n+=t&Ue,t<se||(t=r.get(e+1),n+=(t&Ue)<<7,t<se)||(t=r.get(e+2),n+=(t&Ue)<<14,t<se)||(t=r.get(e+3),n+=(t&Ue)<<21,t<se)||(t=r.get(e+4),n+=(t&Ue)*Ma,t<se)||(t=r.get(e+5),n+=(t&Ue)*$a,t<se)||(t=r.get(e+6),n+=(t&Ue)*Ha,t<se)||(t=r.get(e+7),n+=(t&Ue)*Ka,t<se))return n;throw new RangeError("Could not decode varint")}function un(r,e,t=0){return e==null&&(e=dt(Ke(r))),e instanceof Uint8Array?qa(r,e,t):Dm(r,e,t)}function Or(r,e=0){return r instanceof Uint8Array?za(r,e):Pm(r,e)}function Fe(r,e){e==null&&(e=r.reduce((o,s)=>o+s.length,0));let t=dt(e),n=0;for(let o of r)t.set(o,n),n+=o.length;return t}var uE=parseInt("0xFFFF",16),lE=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function Y(r,e="utf8"){let t=as[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}var _l=rn,$m=nn,Ga=function(r){let e=0;if(r=r.toString().trim(),_l(r)){let t=new Uint8Array(e+4);return r.split(/\./g).forEach(n=>{t[e++]=parseInt(n,10)&255}),t}if($m(r)){let t=r.split(":",8),n;for(n=0;n<t.length;n++){let s=_l(t[n]),i;s&&(i=Ga(t[n]),t[n]=z(i.slice(0,2),"base16")),i!=null&&++n<8&&t.splice(n,0,z(i.slice(2,4),"base16"))}if(t[0]==="")for(;t.length<8;)t.unshift("0");else if(t[t.length-1]==="")for(;t.length<8;)t.push("0");else if(t.length<8){for(n=0;n<t.length&&t[n]!=="";n++);let s=[n,1];for(n=9-t.length;n>0;n--)s.push("0");t.splice.apply(t,s)}let o=new Uint8Array(e+16);for(n=0;n<t.length;n++){let s=parseInt(t[n],16);o[e++]=s>>8&255,o[e++]=s&255}return o}throw new Error("invalid ip address")},Tl=function(r,e=0,t){e=~~e,t=t??r.length-e;let n=new DataView(r.buffer);if(t===4){let o=[];for(let s=0;s<t;s++)o.push(r[e+s]);return o.join(".")}if(t===16){let o=[];for(let s=0;s<t;s+=2)o.push(n.getUint16(e+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var ln={},ja={},Km=[[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"]];Km.forEach(r=>{let e=qm(...r);ja[e.code]=e,ln[e.name]=e});function qm(r,e,t,n,o){return{code:r,size:e,name:t,resolvable:!!n,path:!!o}}function G(r){if(typeof r=="number"){if(ja[r]!=null)return ja[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(ln[r]!=null)return ln[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var jE=G("ip4"),WE=G("ip6"),YE=G("ipcidr");function Ya(r,e){switch(G(r).code){case 4:case 41:return Gm(e);case 42:return Ll(e);case 6:case 273:case 33:case 132:return Dl(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ll(e);case 421:return Zm(e);case 444:return Ul(e);case 445:return Ul(e);case 466:return Ym(e);default:return z(e,"base16")}}function Za(r,e){switch(G(r).code){case 4:return Nl(e);case 41:return Nl(e);case 42:return Cl(e);case 6:case 273:case 33:case 132:return Ja(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Cl(e);case 421:return jm(e);case 444:return Jm(e);case 445:return Xm(e);case 466:return Wm(e);default:return Y(e,"base16")}}var Wa=Object.values(pr).map(r=>r.decoder),zm=function(){let r=Wa[0].or(Wa[1]);return Wa.slice(2).forEach(e=>r=r.or(e)),r}();function Nl(r){if(!os(r))throw new Error("invalid ip address");return Ga(r)}function Gm(r){let e=Tl(r,0,r.length);if(e==null)throw new Error("ipBuff is required");if(!os(e))throw new Error("invalid ip address");return e}function Ja(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,r),new Uint8Array(e)}function Dl(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Cl(r){let e=Y(r),t=Uint8Array.from(un(e.length));return Fe([t,e],t.length+e.length)}function Ll(r){let e=Or(r);if(r=r.slice(Ke(e)),r.length!==e)throw new Error("inconsistent lengths");return z(r)}function jm(r){let e;r[0]==="Q"||r[0]==="1"?e=kt(fe.decode(`z${r}`)).bytes:e=oe.parse(r).multihash.bytes;let t=Uint8Array.from(un(e.length));return Fe([t,e],t.length+e.length)}function Wm(r){let e=zm.decode(r),t=Uint8Array.from(un(e.length));return Fe([t,e],t.length+e.length)}function Ym(r){let e=Or(r),t=r.slice(Ke(e));if(t.length!==e)throw new Error("inconsistent lengths");return"u"+z(t,"base64url")}function Zm(r){let e=Or(r),t=r.slice(Ke(e));if(t.length!==e)throw new Error("inconsistent lengths");return z(t,"base58btc")}function Jm(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==16)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion address.`);let t=Re.decode("b"+e[0]),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Ja(n);return Fe([t,o],t.length+o.length)}function Xm(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==56)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion3 address.`);let t=Re.decode(`b${e[0]}`),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Ja(n);return Fe([t,o],t.length+o.length)}function Ul(r){let e=r.slice(0,r.length-2),t=r.slice(r.length-2),n=z(e,"base32"),o=Dl(t);return`${n}:${o}`}function Pl(r){r=Xa(r);let e=[],t=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=G(i);if(a.size===0){e.push([a.code]),t.push([a.code]);continue}if(s++,s>=o.length)throw Fl("invalid address: "+r);if(a.path===!0){n=Xa(o.slice(s).join("/")),e.push([a.code,Za(a.code,n)]),t.push([a.code,n]);break}let c=Za(a.code,o[s]);e.push([a.code,c]),t.push([a.code,Ya(a.code,c)])}return{string:Ol(t),bytes:ec(e),tuples:e,stringTuples:t,path:n}}function Qa(r){let e=[],t=[],n=null,o=0;for(;o<r.length;){let s=Or(r,o),i=Ke(s),a=G(s),c=Qm(a,r.slice(o+i));if(c===0){e.push([s]),t.push([s]),o+=i;continue}let f=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw Fl("Invalid address Uint8Array: "+z(r,"base16"));e.push([s,f]);let u=Ya(s,f);if(t.push([s,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:Ol(t),tuples:e,stringTuples:t,path:n}}function Ol(r){let e=[];return r.map(t=>{let n=G(t[0]);return e.push(n.name),t.length>1&&t[1]!=null&&e.push(t[1]),null}),Xa(e.join("/"))}function ec(r){return Fe(r.map(e=>{let t=G(e[0]),n=Uint8Array.from(un(t.code));return e.length>1&&e[1]!=null&&(n=Fe([n,e[1]])),n}))}function Qm(r,e){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let t=Or(e instanceof Uint8Array?e:Uint8Array.from(e));return t+Ke(t)}}function Xa(r){return"/"+r.trim().split("/").filter(e=>e).join("/")}function Fl(r){return new Error("Error parsing address: "+r)}var ey=Symbol.for("nodejs.util.inspect.custom"),tc=Symbol.for("@multiformats/js-multiaddr/multiaddr"),ty=[G("dns").code,G("dns4").code,G("dns6").code,G("dnsaddr").code],cs=class r{bytes;#e;#t;#r;#i;[tc]=!0;constructor(e){e==null&&(e="");let t;if(e instanceof Uint8Array)t=Qa(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);t=Pl(e)}else if(Ml(e))t=Qa(e.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=t.bytes,this.#e=t.string,this.#t=t.tuples,this.#r=t.stringTuples,this.#i=t.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let e,t,n,o,s="",i=G("tcp"),a=G("udp"),c=G("ip4"),f=G("ip6"),u=G("dns6"),l=G("ip6zone");for(let[g,y]of this.stringTuples())g===l.code&&(s=`%${y??""}`),ty.includes(g)&&(t=i.name,o=443,n=`${y??""}${s}`,e=g===u.code?6:4),(g===i.code||g===a.code)&&(t=G(g).name,o=parseInt(y??"")),(g===c.code||g===f.code)&&(t=G(g).name,n=`${y??""}${s}`,e=g===f.code?6:4);if(e==null||t==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:e,host:n,transport:t,port:o}}protos(){return this.#t.map(([e])=>Object.assign({},G(e)))}protoCodes(){return this.#t.map(([e])=>e)}protoNames(){return this.#t.map(([e])=>G(e).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(e){return e=new r(e),new r(this.toString()+e.toString())}decapsulate(e){let t=e.toString(),n=this.toString(),o=n.lastIndexOf(t);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${e.toString()}`);return new r(n.slice(0,o))}decapsulateCode(e){let t=this.tuples();for(let n=t.length-1;n>=0;n--)if(t[n][0]===e)return new r(ec(t.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,o])=>{n===ln.p2p.code&&e.push([n,o]),n===ln["p2p-circuit"].code&&(e=[])});let t=e.pop();if(t?.[1]!=null){let n=t[1];return n[0]==="Q"||n[0]==="1"?z(fe.decode(`z${n}`),"base58btc"):z(oe.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#i}equals(e){return ce(this.bytes,e.bytes)}async resolve(e){let t=this.protos().find(s=>s.resolvable);if(t==null)return[this];let n=Vl.get(t.name);if(n==null)throw new N(`no available resolver for ${t.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,e)).map(s=>Fr(s))}nodeAddress(){let e=this.toOptions();if(e.transport!=="tcp"&&e.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${e.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:e.family,address:e.host,port:e.port}}isThinWaistAddress(e){let t=(e??this).protos();return!(t.length!==2||t[0].code!==4&&t[0].code!==41||t[1].code!==6&&t[1].code!==273)}[ey](){return`Multiaddr(${this.#e})`}};var Vl=new Map;function Ml(r){return!!r?.[tc]}function Fr(r){return new cs(r)}var ry=r=>r.toString().split("/").slice(1),so=r=>({match:e=>e.length<1?!1:r(e[0])?e.slice(1):!1,pattern:"fn"}),re=r=>({match:e=>so(t=>t===r).match(e),pattern:r}),fs=()=>({match:r=>so(e=>typeof e=="string").match(r),pattern:"{string}"}),hs=()=>({match:r=>so(e=>!isNaN(parseInt(e))).match(r),pattern:"{number}"}),_e=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{fe.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),us=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{_a.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),Ve=r=>({match:e=>{let t=r.match(e);return t===!1?e:t},pattern:`optional(${r.pattern})`}),Ge=(...r)=>({match:e=>{let t;for(let n of r){let o=n.match(e);o!==!1&&(t==null||o.length<t.length)&&(t=o)}return t??!1},pattern:`or(${r.map(e=>e.pattern).join(", ")})`}),ie=(...r)=>({match:e=>{for(let t of r){let n=t.match(e);if(n===!1)return!1;e=n}return e},pattern:`and(${r.map(e=>e.pattern).join(", ")})`});function me(...r){function e(o){let s=ry(o);for(let i of r){let a=i.match(s);if(a===!1)return!1;s=a}return s}function t(o){return e(o)!==!1}function n(o){let s=e(o);return s===!1?!1:s.length===0}return{matches:t,exactMatch:n}}var nc=ie(re("dns4"),fs()),oc=ie(re("dns6"),fs()),sc=ie(re("dnsaddr"),fs()),$l=ie(re("dns"),fs()),Bv=me(nc),kv=me(oc),Sv=me(sc),Hl=me(Ge($l,sc,nc,oc)),Kl=ie(re("ip4"),so(rn)),ql=ie(re("ip6"),so(nn)),zl=Ge(Kl,ql),St=Ge(zl,$l,nc,oc,sc),Iv=me(St),Rv=me(Kl),_v=me(ql),Tv=me(zl),ds=ie(St,re("tcp"),hs()),io=ie(St,re("udp"),hs()),ny=Ge(ds,io),Nv=me(ds),Cv=me(io),ic=ie(io,re("quic")),ps=ie(io,re("quic-v1")),oy=Ge(ic,ps),Lv=me(ic),Uv=me(ps),rc=Ge(St,ds,io,ic,ps),Gl=Ge(ie(rc,re("ws"),Ve(_e()))),Dv=me(Gl),jl=Ge(ie(rc,re("wss"),Ve(_e())),ie(rc,re("tls"),re("ws"),Ve(_e()))),Pv=me(jl),Wl=ie(ny,re("webrtc-direct"),us(),Ve(us()),Ve(_e())),Ov=me(Wl),Yl=ie(ps,re("webtransport"),us(),us(),Ve(_e())),Fv=me(Yl),ls=Ge(Gl,jl,ie(ds,Ve(_e())),ie(oy,Ve(_e())),ie(St,Ve(_e())),Wl,Yl,_e()),Vv=me(ls),sy=ie(ls,re("p2p-circuit"),_e()),Mv=me(sy),iy=Ge(ie(ls,re("p2p-circuit"),re("webrtc"),_e()),ie(ls,re("webrtc"),Ve(_e())),re("webrtc")),$v=me(iy),ay=Ge(ie(St,re("tcp"),hs(),re("http"),Ve(_e())),ie(St,re("http"),Ve(_e()))),Zl=me(ay),cy=Ge(ie(St,re("tcp"),Ge(ie(re("443"),re("http")),ie(hs(),re("https"))),Ve(_e())),ie(St,re("tls"),re("http"),Ve(_e())),ie(St,re("https"),Ve(_e()))),Jl=me(cy);function Ey(r){return r[Symbol.asyncIterator]!=null}function vy(r){if(Ey(r))return(async()=>{for await(let e of r);})();for(let e of r);}var $t=vy;function By(r){let[e,t]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>e.next(),push:o=>{n.push(o)},next:()=>n.length>0?{done:!1,value:n.shift()}:e.next(),[t](){return this}}}var mn=By;function ky(r){return r[Symbol.asyncIterator]!=null}function Sy(r,e){if(ky(r))return async function*(){for await(let a of r)yield e(a)}();let t=mn(r),{value:n,done:o}=t.next();if(o===!0)return function*(){}();let s=e(n);if(typeof s.then=="function")return async function*(){yield await s;for await(let a of t)yield e(a)}();let i=e;return function*(){yield s;for(let a of t)yield i(a)}()}var yn=Sy;function Iy(r){return r[Symbol.asyncIterator]!=null}function Ry(...r){let e=[];for(let t of r)Iy(t)||e.push(t);return e.length===r.length?function*(){for(let t of e)yield*t}():async function*(){let t=Ft({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let o of n)t.push(o)})),t.end()}catch(n){t.end(n)}}),yield*t}()}var mr=Ry;function _y(r){return r[Symbol.asyncIterator]!=null}function Ty(r,e){return _y(r)?async function*(){let t=0;if(!(e<1)){for await(let n of r)if(yield n,t++,t===e)return}}():function*(){let t=0;if(!(e<1)){for(let n of r)if(yield n,t++,t===e)return}}()}var gs=Ty;var ne=class extends Event{constructor(e,t){super(e),this.detail=t}};var ac=new Float32Array([-0]),yr=new Uint8Array(ac.buffer);function sf(r,e,t){ac[0]=r,e[t]=yr[0],e[t+1]=yr[1],e[t+2]=yr[2],e[t+3]=yr[3]}function af(r,e){return yr[0]=r[e],yr[1]=r[e+1],yr[2]=r[e+2],yr[3]=r[e+3],ac[0]}var cc=new Float64Array([-0]),De=new Uint8Array(cc.buffer);function cf(r,e,t){cc[0]=r,e[t]=De[0],e[t+1]=De[1],e[t+2]=De[2],e[t+3]=De[3],e[t+4]=De[4],e[t+5]=De[5],e[t+6]=De[6],e[t+7]=De[7]}function uf(r,e){return De[0]=r[e],De[1]=r[e+1],De[2]=r[e+2],De[3]=r[e+3],De[4]=r[e+4],De[5]=r[e+5],De[6]=r[e+6],De[7]=r[e+7],cc[0]}var Ny=BigInt(Number.MAX_SAFE_INTEGER),Cy=BigInt(Number.MIN_SAFE_INTEGER),We=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return Mr;if(e<Ny&&e>Cy)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,o=e-(n<<32n);return t&&(n=~n|0n,o=~o|0n,++o>lf&&(o=0n,++n>lf&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(e){if(e===0)return Mr;let t=e<0;t&&(e=-e);let n=e>>>0,o=(e-n)/4294967296>>>0;return t&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new r(n,o)}static from(e){return typeof e=="number"?r.fromNumber(e):typeof e=="bigint"?r.fromBigInt(e):typeof e=="string"?r.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new r(e.low>>>0,e.high>>>0):Mr}},Mr=new We(0,0);Mr.toBigInt=function(){return 0n};Mr.zzEncode=Mr.zzDecode=function(){return this};Mr.length=function(){return 1};var lf=4294967296n;function ff(r){let e=0,t=0;for(let n=0;n<r.length;++n)t=r.charCodeAt(n),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,e+=4):e+=3;return e}function hf(r,e,t){if(t-e<1)return"";let o,s=[],i=0,a;for(;e<t;)a=r[e++],a<128?s[i++]=a:a>191&&a<224?s[i++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&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 uc(r,e,t){let n=t,o,s;for(let i=0;i<r.length;++i)o=r.charCodeAt(i),o<128?e[t++]=o:o<2048?(e[t++]=o>>6|192,e[t++]=o&63|128):(o&64512)===55296&&((s=r.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,e[t++]=o>>18|240,e[t++]=o>>12&63|128,e[t++]=o>>6&63|128,e[t++]=o&63|128):(e[t++]=o>>12|224,e[t++]=o>>6&63|128,e[t++]=o&63|128);return t-n}function pt(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function ws(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var lc=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,pt(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw pt(this,4);return ws(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw pt(this,4);return ws(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw pt(this,4);let e=af(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw pt(this,4);let e=uf(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,n=this.pos+e;if(n>this.len)throw pt(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return hf(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw pt(this,e);this.pos+=e}else do if(this.pos>=this.len)throw pt(this);while(this.buf[this.pos++]&128);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new We(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw pt(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw pt(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw pt(this,8);let e=ws(this.buf,this.pos+=4),t=ws(this.buf,this.pos+=4);return new We(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=za(this.buf,this.pos);return this.pos+=Ke(e),e}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function fc(r){return new lc(r instanceof Uint8Array?r:r.subarray())}function gn(r,e,t){let n=fc(r);return e.decode(n,void 0,t)}function hc(r){let e=r??8192,t=e>>>1,n,o=e;return function(i){if(i<1||i>t)return dt(i);o+i>e&&(n=dt(e),o=0);let a=n.subarray(o,o+=i);return o&7&&(o=(o|7)+1),a}}var $r=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function dc(){}var mc=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},Ly=hc();function Uy(r){return globalThis.Buffer!=null?dt(r):Ly(r)}var co=class{len;head;tail;states;constructor(){this.len=0,this.head=new $r(dc,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new $r(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new yc((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(bs,10,We.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=We.fromBigInt(e);return this._push(bs,t.length(),t)}uint64Number(e){return this._push(qa,Ke(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=We.fromBigInt(e).zzEncode();return this._push(bs,t.length(),t)}sint64Number(e){let t=We.fromNumber(e).zzEncode();return this._push(bs,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(pc,1,e?1:0)}fixed32(e){return this._push(ao,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=We.fromBigInt(e);return this._push(ao,4,t.lo)._push(ao,4,t.hi)}fixed64Number(e){let t=We.fromNumber(e);return this._push(ao,4,t.lo)._push(ao,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push(sf,4,e)}double(e){return this._push(cf,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(pc,1,0):this.uint32(t)._push(Py,t,e)}string(e){let t=ff(e);return t!==0?this.uint32(t)._push(uc,t,e):this._push(pc,1,0)}fork(){return this.states=new mc(this),this.head=this.tail=new $r(dc,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 $r(dc,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=e.next,this.tail=t,this.len+=n),this}finish(){let e=this.head.next,t=Uy(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function pc(r,e,t){e[t]=r&255}function Dy(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var yc=class extends $r{next;constructor(e,t){super(Dy,e,t),this.next=void 0}};function bs(r,e,t){for(;r.hi!==0;)e[t++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)e[t++]=r.lo&127|128,r.lo=r.lo>>>7;e[t++]=r.lo}function ao(r,e,t){e[t]=r&255,e[t+1]=r>>>8&255,e[t+2]=r>>>16&255,e[t+3]=r>>>24}function Py(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(co.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(Oy,e,r),this},co.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(Fy,e,r),this});function Oy(r,e,t){e.set(r,t)}function Fy(r,e,t){r.length<40?uc(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(Y(r),t)}function gc(){return new co}function wn(r,e){let t=gc();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var bn;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(bn||(bn={}));function xs(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function uo(r){function e(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let t=function(s,i){let a=e(s);i.int32(a)},n=function(s){let i=s.int32();return e(i)};return xs("enum",bn.VARINT,t,n)}function xn(r,e){return xs("message",bn.LENGTH_DELIMITED,r,e)}var Vy=Symbol.for("nodejs.util.inspect.custom"),pf=Object.values(pr).map(r=>r.decoder).reduce((r,e)=>r.or(e),pr.identity.decoder),mf=114,wc=36,bc=37,lo=class{type;multihash;privateKey;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,this.privateKey=e.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[la]=!0;toString(){return this.string==null&&(this.string=fe.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return oe.createV1(mf,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return ce(this.multihash.bytes,e);if(typeof e=="string")return xc(e).equals(this);if(e?.multihash?.bytes!=null)return ce(this.multihash.bytes,e.multihash.bytes);throw new Error("not valid Id")}[Vy](){return`PeerId(${this.toString()})`}},En=class extends lo{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},vn=class extends lo{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.multihash.digest}},An=class extends lo{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.multihash.digest}};function xc(r,e){if(e=e??pf,r.charAt(0)==="1"||r.charAt(0)==="Q"){let t=kt(fe.decode(`z${r}`));return r.startsWith("12D")?new vn({multihash:t}):r.startsWith("16U")?new An({multihash:t}):new En({multihash:t})}return fo(pf.decode(r))}function fo(r){try{let e=kt(r);if(e.code===st.code){if(e.digest.length===wc)return new vn({multihash:e});if(e.digest.length===bc)return new An({multihash:e})}if(e.code===Ee.code)return new En({multihash:e})}catch{return My(oe.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function My(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==mf)throw new Error("Supplied PeerID CID is invalid");let e=r.multihash;if(e.code===Ee.code)return new En({multihash:r.multihash});if(e.code===st.code){if(e.digest.length===wc)return new vn({multihash:r.multihash});if(e.digest.length===bc)return new An({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function yf(r,e){return r.length===wc?new vn({multihash:Bt(st.code,r),privateKey:e}):r.length===bc?new An({multihash:Bt(st.code,r),privateKey:e}):new En({multihash:await Ee.digest(r),publicKey:r,privateKey:e})}function $y(r){return r[Symbol.asyncIterator]!=null}function Hy(r){if($y(r))return(async()=>{let t=[];for await(let n of r)t.push(n);return t})();let e=[];for(let t of r)e.push(t);return e}var Ec=Hy;function Ky(r){return r[Symbol.asyncIterator]!=null}function qy(r,e){if(Ky(r))return async function*(){for await(let a of r)await e(a)&&(yield a)}();let t=mn(r),{value:n,done:o}=t.next();if(o===!0)return function*(){}();let s=e(n);if(typeof s.then=="function")return async function*(){await s&&(yield n);for await(let a of t)await e(a)&&(yield a)}();let i=e;return function*(){s===!0&&(yield n);for(let a of t)i(a)&&(yield a)}()}var it=qy;var wf=ot(gf(),1),zy=["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"],Gy=zy.map(r=>new wf.Netmask(r));function jy(r){for(let e of Gy)if(e.contains(r))return!0;return!1}function Wy(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 bf(r){return rn(r)?jy(r):nn(r)?Wy(r):void 0}var Yy=[G("tcp").code,G("dns").code,G("dnsaddr").code,G("dns4").code,G("dns6").code];function xf(r){let e;try{e=G("sni").code}catch{return null}for(let[t,n]of r)if(t===e&&n!==void 0)return n;return null}function Ef(r){return r.some(([e,t])=>e===G("tls").code)}function Ye(r,e,t){let n=vf[G(r).name];if(n===void 0)throw new Error(`Can't interpret protocol ${G(r).name}`);let o=n(e,t);return r===G("ip6").code?`[${o}]`:o}var vf={ip4:(r,e)=>r,ip6:(r,e)=>e.length===0?r:`[${r}]`,tcp:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return`tcp://${Ye(t[0],t[1]??"",e)}:${r}`},udp:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return`udp://${Ye(t[0],t[1]??"",e)}:${r}`},dnsaddr:(r,e)=>r,dns4:(r,e)=>r,dns6:(r,e)=>r,dns:(r,e)=>r,ipfs:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return`${Ye(t[0],t[1]??"",e)}/ipfs/${r}`},p2p:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return`${Ye(t[0],t[1]??"",e)}/p2p/${r}`},http:(r,e)=>{let t=Ef(e),n=xf(e);if(t&&n!==null)return`https://${n}`;let o=t?"https://":"http://",s=e.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let i=Ye(s[0],s[1]??"",e);return i=i.replace("tcp://",""),`${o}${i}`},tls:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return Ye(t[0],t[1]??"",e)},sni:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return Ye(t[0],t[1]??"",e)},https:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");let n=Ye(t[0],t[1]??"",e);return n=n.replace("tcp://",""),`https://${n}`},ws:(r,e)=>{let t=Ef(e),n=xf(e);if(t&&n!==null)return`wss://${n}`;let o=t?"wss://":"ws://",s=e.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let i=Ye(s[0],s[1]??"",e);return i=i.replace("tcp://",""),`${o}${i}`},wss:(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");let n=Ye(t[0],t[1]??"",e);return n=n.replace("tcp://",""),`wss://${n}`},"p2p-websocket-star":(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return`${Ye(t[0],t[1]??"",e)}/p2p-websocket-star`},"p2p-webrtc-star":(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return`${Ye(t[0],t[1]??"",e)}/p2p-webrtc-star`},"p2p-webrtc-direct":(r,e)=>{let t=e.pop();if(t===void 0)throw new Error("Unexpected end of multiaddr");return`${Ye(t[0],t[1]??"",e)}/p2p-webrtc-direct`}};function Af(r,e){let n=Fr(r).stringTuples(),o=n.pop();if(o===void 0)throw new Error("Unexpected end of multiaddr");let s=G(o[0]),i=vf[s.name];if(i==null)throw new Error(`No interpreter found for ${s.name}`);let a=i(o[1]??"",n);return e?.assumeHttp!==!1&&Yy.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 po=class{url;#e=0;#t=0;#r=0;#i=0;log;constructor(e,t){this.url=e instanceof URL?e:new URL(e),this.log=t.forComponent(`helia:trustless-gateway-block-broker:${this.url.hostname}`)}async getRawBlock(e,t){let n=this.url;if(n.pathname=`/ipfs/${e.toString()}`,n.search="?format=raw",t?.aborted===!0)throw new Error(`Signal to fetch raw block for CID ${e} from gateway ${this.url} was aborted prior to fetch`);try{this.#e++;let o=await fetch(n.toString(),{signal:t,headers:{Accept:"application/vnd.ipld.raw"},cache:"force-cache"});if(this.log("GET %s %d",n,o.status),!o.ok)throw this.#t++,new Error(`unable to fetch raw block for CID ${e} from gateway ${this.url}`);return this.#i++,new Uint8Array(await o.arrayBuffer())}catch{throw t?.aborted===!0?new Error(`fetching raw block for CID ${e} from gateway ${this.url} was aborted`):(this.#t++,new Error(`unable to fetch raw block for CID ${e}`))}}reliability(){return this.#e===0?1:this.#r>0?-1/0:this.#i/(this.#e+this.#t*3)}incrementInvalidBlocks(){this.#r++}};var Es=class r{components;gateways;routing;log;constructor(e,t={}){this.components=e,this.log=e.logger.forComponent("helia:trustless-gateway-block-broker"),this.routing=e.routing,this.gateways=(t.gateways??Bf).map(n=>new po(n,e.logger))}addGateway(e){this.gateways.push(new po(e,this.components.logger))}async retrieve(e,t={}){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",e,s.url);try{let i=await s.getRawBlock(e,t.signal);this.log.trace("got block for %c from %s",e,s.url);try{await t.validateFn?.(i)}catch(a){throw this.log.error("failed to validate block for %c from %s",e,s.url,a),s.incrementInvalidBlocks(),new Error(`Block for CID ${e} from gateway ${s.url} failed validation`)}return i}catch(i){if(this.log.error("failed to get block for %c from %s",e,s.url,i),i instanceof Error?o.push(i):o.push(new Error(`Unable to fetch raw block for CID ${e} from gateway ${s.url}`)),t.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",e,s.url);break}}}throw o.length>0?new AggregateError(o,`Unable to fetch raw block for CID ${e} from any gateway`):new Error(`Unable to fetch raw block for CID ${e} from any gateway`)}async createSession(e,t={}){let n=[],o=t.minProviders??1,s=t.minProviders??5,i=Ie(),a=new r(this.components,{gateways:n});this.log("finding transport-ipfs-gateway-http providers for cid %c",e);let c=new ts({concurrency:t.providerQueryConcurrency??5});return Promise.resolve().then(async()=>{for await(let f of this.routing.findProviders(e,t)){let u=f.multiaddrs.filter(l=>Jl.matches(l)||t.allowInsecure===!0&&Zl.matches(l)?t.allowLocal===!0||Hl.matches(l)?!0:bf(l.toOptions().host)===!1:!1);u.length!==0&&(this.log("found transport-ipfs-gateway-http provider %p for cid %c",f.id,e),c.add(async()=>{for(let l of u){let h;try{h=Af(l);let g=`${h}/ipfs/${e.toString()}?format=raw`,y=await fetch(g,{method:"HEAD",headers:{Accept:"application/vnd.ipld.raw","Cache-Control":t.cacheControl??"only-if-cached"},signal:AbortSignal.timeout(t.providerQueryTimeout??5e3)});this.log("HEAD %s %d",g,y.status),n.push(h),a.addGateway(h),this.log("found %d transport-ipfs-gateway-http providers for cid %c",n.length,e),n.length===o&&i.resolve(a),n.length===s&&c.clear()}catch(g){this.log.error("could not fetch %c from %a",e,h??l,g)}}}))}}).catch(f=>{this.log.error("error creating session for %c",e,f)}),i.promise}};var Bf=["https://trustless-gateway.link","https://cloudflare-ipfs.com","https://4everland.io"];function vc(r={}){return e=>new Es(e,r)}var Ze=ot(rf(),1);Ze.default.formatters.b=r=>r==null?"undefined":fe.baseEncode(r);Ze.default.formatters.t=r=>r==null?"undefined":Re.baseEncode(r);Ze.default.formatters.m=r=>r==null?"undefined":dr.baseEncode(r);Ze.default.formatters.p=r=>r==null?"undefined":r.toString();Ze.default.formatters.c=r=>r==null?"undefined":r.toString();Ze.default.formatters.k=r=>r==null?"undefined":r.toString();Ze.default.formatters.a=r=>r==null?"undefined":r.toString();function Zy(r){let e=()=>{};return e.enabled=!1,e.color="",e.diff=0,e.log=()=>{},e.namespace=r,e.destroy=()=>!0,e.extend=()=>e,e}function kf(){return{forComponent(r){return Je(r)}}}function Je(r){let e=Zy(`${r}:trace`);return Ze.default.enabled(`${r}:trace`)&&Ze.default.names.map(t=>t.toString()).find(t=>t.includes(":trace"))!=null&&(e=(0,Ze.default)(`${r}:trace`)),Object.assign((0,Ze.default)(r),{error:(0,Ze.default)(`${r}:error`),trace:e})}async function*vs(r,e={}){let t=r.getReader();try{for(;;){let n=await t.read();if(n.done)return;yield n.value}}finally{e.preventCancel!==!0&&await t.cancel(),t.releaseLock()}}var Vc={};xe(Vc,{Ed25519PrivateKey:()=>zr,Ed25519PublicKey:()=>go,generateKeyPair:()=>iw,generateKeyPairFromSeed:()=>Xf,unmarshalEd25519PrivateKey:()=>ow,unmarshalEd25519PublicKey:()=>sw});function at(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Bn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Jy(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function kn(r,...e){if(!Jy(r))throw new Error("Uint8Array expected");if(e.length>0&&!e.includes(r.length))throw new Error(`Uint8Array expected of length ${e}, not of length=${r.length}`)}function As(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Bn(r.outputLen),Bn(r.blockLen)}function Sn(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function Sf(r,e){kn(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var Bs=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Rn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),mt=(r,e)=>r<<32-e|r>>>e;var BA=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Xy=async()=>{};async function If(r,e,t){let n=Date.now();for(let o=0;o<r;o++){t(o);let s=Date.now()-n;s>=0&&s<e||(await Xy(),n+=s)}}function Ac(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function gr(r){return typeof r=="string"&&(r=Ac(r)),kn(r),r}function ks(...r){let e=0;for(let n=0;n<r.length;n++){let o=r[n];kn(o),e+=o.length}let t=new Uint8Array(e);for(let n=0,o=0;n<r.length;n++){let s=r[n];t.set(s,o),o+=s.length}return t}var In=class{clone(){return this._cloneInto()}},Qy={}.toString;function Rf(r,e){if(e!==void 0&&Qy.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function Ss(r){let e=n=>r().update(gr(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function _n(r=32){if(Bs&&typeof Bs.getRandomValues=="function")return Bs.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function eg(r,e,t,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(e,t,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(t>>o&s),a=Number(t&s),c=n?4:0,f=n?0:4;r.setUint32(e+c,i,n),r.setUint32(e+f,a,n)}var _f=(r,e,t)=>r&e^~r&t,Tf=(r,e,t)=>r&e^r&t^e&t,Tn=class extends In{constructor(e,t,n,o){super(),this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=o,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=Rn(this.buffer)}update(e){Sn(this);let{view:t,buffer:n,blockLen:o}=this;e=gr(e);let s=e.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=Rn(e);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Sn(this),Sf(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;t[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++)t[l]=0;eg(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=Rn(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],s)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:t,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return e.length=o,e.pos=a,e.finished=s,e.destroyed=i,o%t&&e.buffer.set(n),e}};var Is=BigInt(4294967295),Bc=BigInt(32);function Nf(r,e=!1){return e?{h:Number(r&Is),l:Number(r>>Bc&Is)}:{h:Number(r>>Bc&Is)|0,l:Number(r&Is)|0}}function tg(r,e=!1){let t=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let o=0;o<r.length;o++){let{h:s,l:i}=Nf(r[o],e);[t[o],n[o]]=[s,i]}return[t,n]}var rg=(r,e)=>BigInt(r>>>0)<<Bc|BigInt(e>>>0),ng=(r,e,t)=>r>>>t,og=(r,e,t)=>r<<32-t|e>>>t,sg=(r,e,t)=>r>>>t|e<<32-t,ig=(r,e,t)=>r<<32-t|e>>>t,ag=(r,e,t)=>r<<64-t|e>>>t-32,cg=(r,e,t)=>r>>>t-32|e<<64-t,ug=(r,e)=>e,lg=(r,e)=>r,fg=(r,e,t)=>r<<t|e>>>32-t,hg=(r,e,t)=>e<<t|r>>>32-t,dg=(r,e,t)=>e<<t-32|r>>>64-t,pg=(r,e,t)=>r<<t-32|e>>>64-t;function mg(r,e,t,n){let o=(e>>>0)+(n>>>0);return{h:r+t+(o/2**32|0)|0,l:o|0}}var yg=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),gg=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,wg=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),bg=(r,e,t,n,o)=>e+t+n+o+(r/2**32|0)|0,xg=(r,e,t,n,o)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(o>>>0),Eg=(r,e,t,n,o,s)=>e+t+n+o+s+(r/2**32|0)|0;var vg={fromBig:Nf,split:tg,toBig:rg,shrSH:ng,shrSL:og,rotrSH:sg,rotrSL:ig,rotrBH:ag,rotrBL:cg,rotr32H:ug,rotr32L:lg,rotlSH:fg,rotlSL:hg,rotlBH:dg,rotlBL:pg,add:mg,add3L:yg,add3H:gg,add4L:wg,add4H:bg,add5H:Eg,add5L:xg},q=vg;var[Ag,Bg]=q.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))),wr=new Uint32Array(80),br=new Uint32Array(80),kc=class extends Tn{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:e,Al:t,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:f,El:u,Fh:l,Fl:h,Gh:g,Gl:y,Hh:p,Hl:m}=this;return[e,t,n,o,s,i,a,c,f,u,l,h,g,y,p,m]}set(e,t,n,o,s,i,a,c,f,u,l,h,g,y,p,m){this.Ah=e|0,this.Al=t|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=f|0,this.El=u|0,this.Fh=l|0,this.Fl=h|0,this.Gh=g|0,this.Gl=y|0,this.Hh=p|0,this.Hl=m|0}process(e,t){for(let v=0;v<16;v++,t+=4)wr[v]=e.getUint32(t),br[v]=e.getUint32(t+=4);for(let v=16;v<80;v++){let U=wr[v-15]|0,S=br[v-15]|0,_=q.rotrSH(U,S,1)^q.rotrSH(U,S,8)^q.shrSH(U,S,7),L=q.rotrSL(U,S,1)^q.rotrSL(U,S,8)^q.shrSL(U,S,7),b=wr[v-2]|0,C=br[v-2]|0,O=q.rotrSH(b,C,19)^q.rotrBH(b,C,61)^q.shrSH(b,C,6),T=q.rotrSL(b,C,19)^q.rotrBL(b,C,61)^q.shrSL(b,C,6),V=q.add4L(L,T,br[v-7],br[v-16]),H=q.add4H(V,_,O,wr[v-7],wr[v-16]);wr[v]=H|0,br[v]=V|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:h,Fh:g,Fl:y,Gh:p,Gl:m,Hh:w,Hl:I}=this;for(let v=0;v<80;v++){let U=q.rotrSH(l,h,14)^q.rotrSH(l,h,18)^q.rotrBH(l,h,41),S=q.rotrSL(l,h,14)^q.rotrSL(l,h,18)^q.rotrBL(l,h,41),_=l&g^~l&p,L=h&y^~h&m,b=q.add5L(I,S,L,Bg[v],br[v]),C=q.add5H(b,w,U,_,Ag[v],wr[v]),O=b|0,T=q.rotrSH(n,o,28)^q.rotrBH(n,o,34)^q.rotrBH(n,o,39),V=q.rotrSL(n,o,28)^q.rotrBL(n,o,34)^q.rotrBL(n,o,39),H=n&s^n&a^s&a,X=o&i^o&c^i&c;w=p|0,I=m|0,p=g|0,m=y|0,g=l|0,y=h|0,{h:l,l:h}=q.add(f|0,u|0,C|0,O|0),f=a|0,u=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let E=q.add3L(O,V,X);n=q.add3H(E,C,T,H),o=E|0}({h:n,l:o}=q.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=q.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=q.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:u}=q.add(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:h}=q.add(this.Eh|0,this.El|0,l|0,h|0),{h:g,l:y}=q.add(this.Fh|0,this.Fl|0,g|0,y|0),{h:p,l:m}=q.add(this.Gh|0,this.Gl|0,p|0,m|0),{h:w,l:I}=q.add(this.Hh|0,this.Hl|0,w|0,I|0),this.set(n,o,s,i,a,c,f,u,l,h,g,y,p,m,w,I)}roundClean(){wr.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 Nn=Ss(()=>new kc);var _s={};xe(_s,{abytes:()=>Cn,bitGet:()=>Ng,bitLen:()=>Tg,bitMask:()=>mo,bitSet:()=>Cg,bytesToHex:()=>Kt,bytesToNumberBE:()=>qt,bytesToNumberLE:()=>Er,concatBytes:()=>zt,createHmacDrbg:()=>Rc,ensureBytes:()=>pe,equalBytes:()=>Rg,hexToBytes:()=>Hr,hexToNumber:()=>Ic,isBytes:()=>xr,numberToBytesBE:()=>vr,numberToBytesLE:()=>Kr,numberToHexUnpadded:()=>Df,numberToVarBytesBE:()=>Ig,utf8ToBytes:()=>_g,validateObject:()=>It});var Uf=BigInt(0),Rs=BigInt(1),kg=BigInt(2);function xr(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Cn(r){if(!xr(r))throw new Error("Uint8Array expected")}var Sg=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function Kt(r){Cn(r);let e="";for(let t=0;t<r.length;t++)e+=Sg[r[t]];return e}function Df(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function Ic(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Ht={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Cf(r){if(r>=Ht._0&&r<=Ht._9)return r-Ht._0;if(r>=Ht._A&&r<=Ht._F)return r-(Ht._A-10);if(r>=Ht._a&&r<=Ht._f)return r-(Ht._a-10)}function Hr(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let e=r.length,t=e/2;if(e%2)throw new Error("padded hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let o=0,s=0;o<t;o++,s+=2){let i=Cf(r.charCodeAt(s)),a=Cf(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 qt(r){return Ic(Kt(r))}function Er(r){return Cn(r),Ic(Kt(Uint8Array.from(r).reverse()))}function vr(r,e){return Hr(r.toString(16).padStart(e*2,"0"))}function Kr(r,e){return vr(r,e).reverse()}function Ig(r){return Hr(Df(r))}function pe(r,e,t){let n;if(typeof e=="string")try{n=Hr(e)}catch(s){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${s}`)}else if(xr(e))n=Uint8Array.from(e);else throw new Error(`${r} must be hex string or Uint8Array`);let o=n.length;if(typeof t=="number"&&o!==t)throw new Error(`${r} expected ${t} bytes, got ${o}`);return n}function zt(...r){let e=0;for(let n=0;n<r.length;n++){let o=r[n];Cn(o),e+=o.length}let t=new Uint8Array(e);for(let n=0,o=0;n<r.length;n++){let s=r[n];t.set(s,o),o+=s.length}return t}function Rg(r,e){if(r.length!==e.length)return!1;let t=0;for(let n=0;n<r.length;n++)t|=r[n]^e[n];return t===0}function _g(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Tg(r){let e;for(e=0;r>Uf;r>>=Rs,e+=1);return e}function Ng(r,e){return r>>BigInt(e)&Rs}function Cg(r,e,t){return r|(t?Rs:Uf)<<BigInt(e)}var mo=r=>(kg<<BigInt(r-1))-Rs,Sc=r=>new Uint8Array(r),Lf=r=>Uint8Array.from(r);function Rc(r,e,t){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof e!="number"||e<2)throw new Error("qByteLen must be a number");if(typeof t!="function")throw new Error("hmacFn must be a function");let n=Sc(r),o=Sc(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>t(o,n,...l),c=(l=Sc())=>{o=a(Lf([0]),l),n=a(),l.length!==0&&(o=a(Lf([1]),l),n=a())},f=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,h=[];for(;l<e;){n=a();let g=n.slice();h.push(g),l+=n.length}return zt(...h)};return(l,h)=>{i(),c(l);let g;for(;!(g=h(f()));)c();return i(),g}}var Lg={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"||xr(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,e)=>e.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function It(r,e,t={}){let n=(o,s,i)=>{let a=Lg[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(e))n(o,s,!1);for(let[o,s]of Object.entries(t))n(o,s,!0);return r}var ve=BigInt(0),ue=BigInt(1),qr=BigInt(2),Ug=BigInt(3),_c=BigInt(4),Pf=BigInt(5),Of=BigInt(8),Dg=BigInt(9),Pg=BigInt(16);function ae(r,e){let t=r%e;return t>=ve?t:e+t}function Og(r,e,t){if(t<=ve||e<ve)throw new Error("Expected power/modulo > 0");if(t===ue)return ve;let n=ue;for(;e>ve;)e&ue&&(n=n*r%t),r=r*r%t,e>>=ue;return n}function le(r,e,t){let n=r;for(;e-- >ve;)n*=n,n%=t;return n}function Ts(r,e){if(r===ve||e<=ve)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=ae(r,e),n=e,o=ve,s=ue,i=ue,a=ve;for(;t!==ve;){let f=n/t,u=n%t,l=o-i*f,h=s-a*f;n=t,t=u,o=i,s=a,i=l,a=h}if(n!==ue)throw new Error("invert: does not exist");return ae(o,e)}function Fg(r){let e=(r-ue)/qr,t,n,o;for(t=r-ue,n=0;t%qr===ve;t/=qr,n++);for(o=qr;o<r&&Og(o,e,r)!==r-ue;o++);if(n===1){let i=(r+ue)/_c;return function(c,f){let u=c.pow(f,i);if(!c.eql(c.sqr(u),f))throw new Error("Cannot find square root");return u}}let s=(t+ue)/qr;return function(a,c){if(a.pow(c,e)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,u=a.pow(a.mul(a.ONE,o),t),l=a.pow(c,s),h=a.pow(c,t);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let g=1;for(let p=a.sqr(h);g<f&&!a.eql(p,a.ONE);g++)p=a.sqr(p);let y=a.pow(u,ue<<BigInt(f-g-1));u=a.sqr(y),l=a.mul(l,y),h=a.mul(h,u),f=g}return l}}function Vg(r){if(r%_c===Ug){let e=(r+ue)/_c;return function(n,o){let s=n.pow(o,e);if(!n.eql(n.sqr(s),o))throw new Error("Cannot find square root");return s}}if(r%Of===Pf){let e=(r-Pf)/Of;return function(n,o){let s=n.mul(o,qr),i=n.pow(s,e),a=n.mul(o,i),c=n.mul(n.mul(a,qr),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),o))throw new Error("Cannot find square root");return f}}return r%Pg,Fg(r)}var Ff=(r,e)=>(ae(r,e)&ue)===ue,Mg=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Tc(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=Mg.reduce((n,o)=>(n[o]="function",n),e);return It(r,t)}function $g(r,e,t){if(t<ve)throw new Error("Expected power > 0");if(t===ve)return r.ONE;if(t===ue)return e;let n=r.ONE,o=e;for(;t>ve;)t&ue&&(n=r.mul(n,o)),o=r.sqr(o),t>>=ue;return n}function Hg(r,e){let t=new Array(e.length),n=e.reduce((s,i,a)=>r.is0(i)?s:(t[a]=s,r.mul(s,i)),r.ONE),o=r.inv(n);return e.reduceRight((s,i,a)=>r.is0(i)?s:(t[a]=r.mul(s,t[a]),r.mul(s,i)),o),t}function Nc(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function Ns(r,e,t=!1,n={}){if(r<=ve)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:o,nByteLength:s}=Nc(r,e);if(s>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Vg(r),a=Object.freeze({ORDER:r,BITS:o,BYTES:s,MASK:mo(o),ZERO:ve,ONE:ue,create:c=>ae(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return ve<=c&&c<r},is0:c=>c===ve,isOdd:c=>(c&ue)===ue,neg:c=>ae(-c,r),eql:(c,f)=>c===f,sqr:c=>ae(c*c,r),add:(c,f)=>ae(c+f,r),sub:(c,f)=>ae(c-f,r),mul:(c,f)=>ae(c*f,r),pow:(c,f)=>$g(a,c,f),div:(c,f)=>ae(c*Ts(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>Ts(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Hg(a,c),cmov:(c,f,u)=>u?f:c,toBytes:c=>t?Kr(c,s):vr(c,s),fromBytes:c=>{if(c.length!==s)throw new Error(`Fp.fromBytes: expected ${s}, got ${c.length}`);return t?Er(c):qt(c)}});return Object.freeze(a)}function Vf(r,e){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let t=r.sqrt(e);return r.isOdd(t)?r.neg(t):t}function Mf(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let e=r.toString(2).length;return Math.ceil(e/8)}function Cc(r){let e=Mf(r);return e+Math.ceil(e/2)}function $f(r,e,t=!1){let n=r.length,o=Mf(e),s=Cc(e);if(n<16||n<s||n>1024)throw new Error(`expected ${s}-1024 bytes of input, got ${n}`);let i=t?qt(r):Er(r),a=ae(i,e-ue)+ue;return t?Kr(a,o):vr(a,o)}var qg=BigInt(0),Lc=BigInt(1);function Cs(r,e){let t=(o,s)=>{let i=s.negate();return o?i:s},n=o=>{let s=Math.ceil(e/o)+1,i=2**(o-1);return{windows:s,windowSize:i}};return{constTimeNegate:t,unsafeLadder(o,s){let i=r.ZERO,a=o;for(;s>qg;)s&Lc&&(i=i.add(a)),a=a.double(),s>>=Lc;return i},precomputeWindow(o,s){let{windows:i,windowSize:a}=n(s),c=[],f=o,u=f;for(let l=0;l<i;l++){u=f,c.push(u);for(let h=1;h<a;h++)u=u.add(f),c.push(u);f=u.double()}return c},wNAF(o,s,i){let{windows:a,windowSize:c}=n(o),f=r.ZERO,u=r.BASE,l=BigInt(2**o-1),h=2**o,g=BigInt(o);for(let y=0;y<a;y++){let p=y*c,m=Number(i&l);i>>=g,m>c&&(m-=h,i+=Lc);let w=p,I=p+Math.abs(m)-1,v=y%2!==0,U=m<0;m===0?u=u.add(t(v,s[w])):f=f.add(t(U,s[I]))}return{p:f,f:u}},wNAFCached(o,s,i,a){let c=o._WINDOW_SIZE||1,f=s.get(o);return f||(f=this.precomputeWindow(o,c),c!==1&&s.set(o,a(f))),this.wNAF(c,f,i)}}}function yo(r){return Tc(r.Fp),It(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Nc(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var yt=BigInt(0),Xe=BigInt(1),Ls=BigInt(2),zg=BigInt(8),Gg={zip215:!0};function jg(r){let e=yo(r);return It(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function Us(r){let e=jg(r),{Fp:t,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=e,f=Ls<<BigInt(a*8)-Xe,u=t.create,l=e.uvRatio||((B,x)=>{try{return{isValid:!0,value:t.sqrt(B*t.inv(x))}}catch{return{isValid:!1,value:yt}}}),h=e.adjustScalarBytes||(B=>B),g=e.domain||((B,x,P)=>{if(x.length||P)throw new Error("Contexts/pre-hash are not supported");return B}),y=B=>typeof B=="bigint"&&yt<B,p=(B,x)=>y(B)&&y(x)&&B<x,m=B=>B===yt||p(B,f);function w(B,x){if(p(B,x))return B;throw new Error(`Expected valid scalar < ${x}, got ${typeof B} ${B}`)}function I(B){return B===yt?B:w(B,n)}let v=new Map;function U(B){if(!(B instanceof S))throw new Error("ExtendedPoint expected")}class S{constructor(x,P,M,K){if(this.ex=x,this.ey=P,this.ez=M,this.et=K,!m(x))throw new Error("x required");if(!m(P))throw new Error("y required");if(!m(M))throw new Error("z required");if(!m(K))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(x){if(x instanceof S)throw new Error("extended point not allowed");let{x:P,y:M}=x||{};if(!m(P)||!m(M))throw new Error("invalid affine point");return new S(P,M,Xe,u(P*M))}static normalizeZ(x){let P=t.invertBatch(x.map(M=>M.ez));return x.map((M,K)=>M.toAffine(P[K])).map(S.fromAffine)}_setWindowSize(x){this._WINDOW_SIZE=x,v.delete(this)}assertValidity(){let{a:x,d:P}=e;if(this.is0())throw new Error("bad point: ZERO");let{ex:M,ey:K,ez:j,et:W}=this,te=u(M*M),J=u(K*K),Q=u(j*j),ge=u(Q*Q),he=u(te*x),ke=u(Q*u(he+J)),Se=u(ge+u(P*u(te*J)));if(ke!==Se)throw new Error("bad point: equation left != right (1)");let be=u(M*K),Le=u(j*W);if(be!==Le)throw new Error("bad point: equation left != right (2)")}equals(x){U(x);let{ex:P,ey:M,ez:K}=this,{ex:j,ey:W,ez:te}=x,J=u(P*te),Q=u(j*K),ge=u(M*te),he=u(W*K);return J===Q&&ge===he}is0(){return this.equals(S.ZERO)}negate(){return new S(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:x}=e,{ex:P,ey:M,ez:K}=this,j=u(P*P),W=u(M*M),te=u(Ls*u(K*K)),J=u(x*j),Q=P+M,ge=u(u(Q*Q)-j-W),he=J+W,ke=he-te,Se=J-W,be=u(ge*ke),Le=u(he*Se),Pt=u(ge*Se),Ur=u(ke*he);return new S(be,Le,Ur,Pt)}add(x){U(x);let{a:P,d:M}=e,{ex:K,ey:j,ez:W,et:te}=this,{ex:J,ey:Q,ez:ge,et:he}=x;if(P===BigInt(-1)){let $u=u((j-K)*(Q+J)),Hu=u((j+K)*(Q-J)),ua=u(Hu-$u);if(ua===yt)return this.double();let Ku=u(W*Ls*he),qu=u(te*Ls*ge),zu=qu+Ku,Gu=Hu+$u,ju=qu-Ku,w0=u(zu*ua),b0=u(Gu*ju),x0=u(zu*ju),E0=u(ua*Gu);return new S(w0,b0,E0,x0)}let ke=u(K*J),Se=u(j*Q),be=u(te*M*he),Le=u(W*ge),Pt=u((K+j)*(J+Q)-ke-Se),Ur=Le-be,Qn=Le+be,Mu=u(Se-P*ke),p0=u(Pt*Ur),m0=u(Qn*Mu),y0=u(Pt*Mu),g0=u(Ur*Qn);return new S(p0,m0,g0,y0)}subtract(x){return this.add(x.negate())}wNAF(x){return b.wNAFCached(this,v,x,S.normalizeZ)}multiply(x){let{p:P,f:M}=this.wNAF(w(x,n));return S.normalizeZ([P,M])[0]}multiplyUnsafe(x){let P=I(x);return P===yt?L:this.equals(L)||P===Xe?this:this.equals(_)?this.wNAF(P).p:b.unsafeLadder(this,P)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return b.unsafeLadder(this,n).is0()}toAffine(x){let{ex:P,ey:M,ez:K}=this,j=this.is0();x==null&&(x=j?zg:t.inv(K));let W=u(P*x),te=u(M*x),J=u(K*x);if(j)return{x:yt,y:Xe};if(J!==Xe)throw new Error("invZ was invalid");return{x:W,y:te}}clearCofactor(){let{h:x}=e;return x===Xe?this:this.multiplyUnsafe(x)}static fromHex(x,P=!1){let{d:M,a:K}=e,j=t.BYTES;x=pe("pointHex",x,j);let W=x.slice(),te=x[j-1];W[j-1]=te&-129;let J=Er(W);J===yt||(P?w(J,f):w(J,t.ORDER));let Q=u(J*J),ge=u(Q-Xe),he=u(M*Q-K),{isValid:ke,value:Se}=l(ge,he);if(!ke)throw new Error("Point.fromHex: invalid y coordinate");let be=(Se&Xe)===Xe,Le=(te&128)!==0;if(!P&&Se===yt&&Le)throw new Error("Point.fromHex: x=0 and x_0=1");return Le!==be&&(Se=u(-Se)),S.fromAffine({x:Se,y:J})}static fromPrivateKey(x){return T(x).point}toRawBytes(){let{x,y:P}=this.toAffine(),M=Kr(P,t.BYTES);return M[M.length-1]|=x&Xe?128:0,M}toHex(){return Kt(this.toRawBytes())}}S.BASE=new S(e.Gx,e.Gy,Xe,u(e.Gx*e.Gy)),S.ZERO=new S(yt,Xe,Xe,yt);let{BASE:_,ZERO:L}=S,b=Cs(S,a*8);function C(B){return ae(B,n)}function O(B){return C(Er(B))}function T(B){let x=a;B=pe("private key",B,x);let P=pe("hashed private key",s(B),2*x),M=h(P.slice(0,x)),K=P.slice(x,2*x),j=O(M),W=_.multiply(j),te=W.toRawBytes();return{head:M,prefix:K,scalar:j,point:W,pointBytes:te}}function V(B){return T(B).pointBytes}function H(B=new Uint8Array,...x){let P=zt(...x);return O(s(g(P,pe("context",B),!!o)))}function X(B,x,P={}){B=pe("message",B),o&&(B=o(B));let{prefix:M,scalar:K,pointBytes:j}=T(x),W=H(P.context,M,B),te=_.multiply(W).toRawBytes(),J=H(P.context,te,j,B),Q=C(W+J*K);I(Q);let ge=zt(te,Kr(Q,t.BYTES));return pe("result",ge,a*2)}let E=Gg;function k(B,x,P,M=E){let{context:K,zip215:j}=M,W=t.BYTES;B=pe("signature",B,2*W),x=pe("message",x),o&&(x=o(x));let te=Er(B.slice(W,2*W)),J,Q,ge;try{J=S.fromHex(P,j),Q=S.fromHex(B.slice(0,W),j),ge=_.multiplyUnsafe(te)}catch{return!1}if(!j&&J.isSmallOrder())return!1;let he=H(K,Q.toRawBytes(),J.toRawBytes(),x);return Q.add(J.multiplyUnsafe(he)).subtract(ge).clearCofactor().equals(S.ZERO)}return _._setWindowSize(8),{CURVE:e,getPublicKey:V,sign:X,verify:k,ExtendedPoint:S,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>i(t.BYTES),precompute(B=8,x=S.BASE){return x._setWindowSize(B),x.multiply(BigInt(3)),x}}}}var Dc=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Hf=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),GA=BigInt(0),Wg=BigInt(1),Uc=BigInt(2),Yg=BigInt(5),Kf=BigInt(10),Zg=BigInt(20),Jg=BigInt(40),qf=BigInt(80);function Xg(r){let e=Dc,n=r*r%e*r%e,o=le(n,Uc,e)*n%e,s=le(o,Wg,e)*r%e,i=le(s,Yg,e)*s%e,a=le(i,Kf,e)*i%e,c=le(a,Zg,e)*a%e,f=le(c,Jg,e)*c%e,u=le(f,qf,e)*f%e,l=le(u,qf,e)*f%e,h=le(l,Kf,e)*i%e;return{pow_p_5_8:le(h,Uc,e)*r%e,b2:n}}function Qg(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function ew(r,e){let t=Dc,n=ae(e*e*e,t),o=ae(n*n*e,t),s=Xg(r*o).pow_p_5_8,i=ae(r*n*s,t),a=ae(e*i*i,t),c=i,f=ae(i*Hf,t),u=a===r,l=a===ae(-r,t),h=a===ae(-r*Hf,t);return u&&(i=c),(l||h)&&(i=f),Ff(i,t)&&(i=ae(-i,t)),{isValid:u||l,value:i}}var Gt=Ns(Dc,void 0,!0),Pc={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Gt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Nn,randomBytes:_n,adjustScalarBytes:Qg,uvRatio:ew},Ln=Us(Pc);function zf(r,e,t){if(e.length>255)throw new Error("Context is too big");return ks(Ac("SigEd25519 no Ed25519 collisions"),new Uint8Array([t?1:0,e.length]),e,r)}var jA=Us({...Pc,domain:zf}),WA=Us({...Pc,domain:zf,prehash:Nn});var tw=(Gt.ORDER+BigInt(3))/BigInt(8),YA=Gt.pow(Uc,tw),ZA=Gt.sqrt(Gt.neg(Gt.ONE)),JA=(Gt.ORDER-BigInt(5))/BigInt(8),XA=BigInt(486662);var QA=Vf(Gt,Gt.neg(BigInt(486664)));var eB=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),tB=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),rB=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),nB=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var oB=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var Un=32,jt=64,Ds=32;function Gf(){let r=Ln.utils.randomPrivateKey(),e=Ln.getPublicKey(r);return{privateKey:Zf(r,e),publicKey:e}}function jf(r){if(r.length!==Ds)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 e=r,t=Ln.getPublicKey(e);return{privateKey:Zf(e,t),publicKey:t}}function Wf(r,e){let t=r.subarray(0,Ds);return Ln.sign(e instanceof Uint8Array?e:e.subarray(),t)}function Yf(r,e,t){return Ln.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function Zf(r,e){let t=new Uint8Array(jt);for(let n=0;n<Ds;n++)t[n]=r[n],t[Ds+n]=e[n];return t}var Me={get(r=globalThis){let e=r.crypto;if(e==null||e.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 e}};var Oc={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Jf(r){let e=r?.algorithm??"AES-GCM",t=r?.keyLength??16,n=r?.nonceLength??12,o=r?.digest??"SHA-256",s=r?.saltLength??16,i=r?.iterations??32767,a=Me.get();t*=8;async function c(l,h){let g=a.getRandomValues(new Uint8Array(s)),y=a.getRandomValues(new Uint8Array(n)),p={name:e,iv:y};typeof h=="string"&&(h=Y(h));let m;if(h.length===0){m=await a.subtle.importKey("jwk",Oc,{name:"AES-GCM"},!0,["encrypt"]);try{let I={name:"PBKDF2",salt:g,iterations:i,hash:{name:o}},v=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(I,v,{name:e,length:t},!0,["encrypt"])}catch{m=await a.subtle.importKey("jwk",Oc,{name:"AES-GCM"},!0,["encrypt"])}}else{let I={name:"PBKDF2",salt:g,iterations:i,hash:{name:o}},v=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(I,v,{name:e,length:t},!0,["encrypt"])}let w=await a.subtle.encrypt(p,m,l);return Fe([g,p.iv,new Uint8Array(w)])}async function f(l,h){let g=l.subarray(0,s),y=l.subarray(s,s+n),p=l.subarray(s+n),m={name:e,iv:y};typeof h=="string"&&(h=Y(h));let w;if(h.length===0)try{let v={name:"PBKDF2",salt:g,iterations:i,hash:{name:o}},U=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(v,U,{name:e,length:t},!0,["decrypt"])}catch{w=await a.subtle.importKey("jwk",Oc,{name:"AES-GCM"},!0,["decrypt"])}else{let v={name:"PBKDF2",salt:g,iterations:i,hash:{name:o}},U=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(v,U,{name:e,length:t},!0,["decrypt"])}let I=await a.subtle.decrypt(m,w,p);return new Uint8Array(I)}return{encrypt:c,decrypt:f}}async function Dn(r,e){let n=await Jf().encrypt(r,e);return dr.encode(n)}var ye;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(ye||(ye={}));var Fc;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Fc||(Fc={}));(function(r){r.codec=()=>uo(Fc)})(ye||(ye={}));var Rt;(function(r){let e;r.codec=()=>(e==null&&(e=xn((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),ye.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),o.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let o={},s=n==null?t.len:t.pos+n;for(;t.pos<s;){let i=t.uint32();switch(i>>>3){case 1:o.Type=ye.codec().decode(t);break;case 2:o.Data=t.bytes();break;default:t.skipType(i&7);break}}return o})),e),r.encode=t=>wn(t,r.codec()),r.decode=t=>gn(t,r.codec())})(Rt||(Rt={}));var Wt;(function(r){let e;r.codec=()=>(e==null&&(e=xn((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),ye.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),o.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let o={},s=n==null?t.len:t.pos+n;for(;t.pos<s;){let i=t.uint32();switch(i>>>3){case 1:o.Type=ye.codec().decode(t);break;case 2:o.Data=t.bytes();break;default:t.skipType(i&7);break}}return o})),e),r.encode=t=>wn(t,r.codec()),r.decode=t=>gn(t,r.codec())})(Wt||(Wt={}));var go=class{_key;constructor(e){this._key=Pn(e,Un)}verify(e,t){return Yf(this._key,t,e)}marshal(){return this._key}get bytes(){return Rt.encode({Type:ye.Ed25519,Data:this.marshal()}).subarray()}equals(e){return ce(this.bytes,e.bytes)}hash(){let e=Ee.digest(this.bytes);return at(e)?e.then(({bytes:t})=>t):e.bytes}},zr=class{_key;_publicKey;constructor(e,t){this._key=Pn(e,jt),this._publicKey=Pn(t,Un)}sign(e){return Wf(this._key,e)}get public(){return new go(this._publicKey)}marshal(){return this._key}get bytes(){return Wt.encode({Type:ye.Ed25519,Data:this.marshal()}).subarray()}equals(e){return ce(this.bytes,e.bytes)}async hash(){let e=Ee.digest(this.bytes),t;return at(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=st.digest(this.public.bytes);return fe.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return Dn(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function ow(r){if(r.length>jt){r=Pn(r,jt+Un);let n=r.subarray(0,jt),o=r.subarray(jt,r.length);return new zr(n,o)}r=Pn(r,jt);let e=r.subarray(0,jt),t=r.subarray(Un);return new zr(e,t)}function sw(r){return r=Pn(r,Un),new go(r)}async function iw(){let{privateKey:r,publicKey:e}=Gf();return new zr(r,e)}async function Xf(r){let{privateKey:e,publicKey:t}=jf(r);return new zr(e,t)}function Pn(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new N(`Key must be a Uint8Array of length ${e}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}var Yc={};xe(Yc,{MAX_RSA_KEY_SIZE:()=>_o,RsaPrivateKey:()=>$n,RsaPublicKey:()=>Ro,fromJwk:()=>Lw,generateKeyPair:()=>Uw,unmarshalRsaPrivateKey:()=>jc,unmarshalRsaPublicKey:()=>Cw});function Gr(r){if(isNaN(r)||r<=0)throw new N("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return _n(r)}var Sr={};xe(Sr,{exportToPem:()=>Iw,importFromPem:()=>Rw,jwkToPkcs1:()=>Aw,jwkToPkix:()=>kw,pkcs1ToJwk:()=>vw,pkixToJwk:()=>Bw});var Os=class extends In{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,As(e);let n=gr(t);if(this.iHash=e.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?e.create().update(n).digest():n);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=e.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),s.fill(0)}update(e){return Sn(this),this.iHash.update(e),this}digestInto(e){Sn(this),kn(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));let{oHash:t,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return e=e,e.finished=o,e.destroyed=s,e.blockLen=i,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},wo=(r,e,t)=>new Os(r,e).update(t).digest();wo.create=(r,e)=>new Os(r,e);function aw(r,e,t,n){As(r);let o=Rf({dkLen:32,asyncTick:10},n),{c:s,dkLen:i,asyncTick:a}=o;if(Bn(s),Bn(i),Bn(a),s<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=gr(e),f=gr(t),u=new Uint8Array(i),l=wo.create(r,c),h=l._cloneInto().update(f);return{c:s,dkLen:i,asyncTick:a,DK:u,PRF:l,PRFSalt:h}}function cw(r,e,t,n,o){return r.destroy(),e.destroy(),n&&n.destroy(),o.fill(0),t}async function Mc(r,e,t,n){let{c:o,dkLen:s,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=aw(r,e,t,n),u,l=new Uint8Array(4),h=Rn(l),g=new Uint8Array(c.outputLen);for(let y=1,p=0;p<s;y++,p+=c.outputLen){let m=a.subarray(p,p+c.outputLen);h.setInt32(0,y,!1),(u=f._cloneInto(u)).update(l).digestInto(g),m.set(g.subarray(0,m.length)),await If(o-1,i,()=>{c._cloneInto(u).update(g).digestInto(g);for(let w=0;w<m.length;w++)m[w]^=g[w]})}return cw(c,f,a,u,g)}var Z=ot(Qf());function jr(r,e){let t=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)t+=r[r.length-1-n]*Math.pow(2,e*n);return t}function Ar(r,e,t=-1){let n=t,o=r,s=0,i=Math.pow(2,e);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 f=new Uint8Array(c);for(let u=a-1;u>=0;u--){let l=Math.pow(2,u*e);f[s-u-1]=Math.floor(o/l),o-=f[s-u-1]*l}return c}i*=Math.pow(2,e)}return new ArrayBuffer(0)}function Ms(...r){let e=0,t=0;for(let s of r)e+=s.length;let n=new ArrayBuffer(e),o=new Uint8Array(n);for(let s of r)o.set(s,t),t+=s.length;return o}function Hc(){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 e=new ArrayBuffer(this.valueHex.byteLength),t=new Uint8Array(e);for(let a=0;a<this.valueHex.byteLength;a++)t[a]=0;t[0]=r[0]&128;let n=jr(t,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,jr(s,8)-n}function eh(r){let e=r<0?r*-1:r,t=128;for(let n=1;n<8;n++){if(e<=t){if(r<0){let i=t-e,a=Ar(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=Ar(e,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}t*=Math.pow(2,8)}return new ArrayBuffer(0)}function th(r,e){if(r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let o=0;o<t.length;o++)if(t[o]!==n[o])return!1;return!0}function qe(r,e){let t=r.toString(10);if(e<t.length)return"";let n=e-t.length,o=new Array(n);for(let i=0;i<n;i++)o[i]="0";return o.join("").concat(t)}var CB=Math.log(2);function $s(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Kc(r){let e=0,t=0;for(let o=0;o<r.length;o++){let s=r[o];e+=s.byteLength}let n=new Uint8Array(e);for(let o=0;o<r.length;o++){let s=r[o];n.set(new Uint8Array(s),t),t+=s.byteLength}return n.buffer}function Qt(r,e,t,n){return e instanceof Uint8Array?e.byteLength?t<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):e.byteLength-t-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 xo=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return Kc(this.items)}},bo=[new Uint8Array([1])],rh="0123456789";var Vn="",wt=new ArrayBuffer(0),qc=new Uint8Array(0),Eo="EndOfContent",oh="OCTET STRING",sh="BIT STRING";function er(r){var e;return e=class extends r{constructor(...n){var o;super(...n);let s=n[0]||{};this.isHexOnly=(o=s.isHexOnly)!==null&&o!==void 0?o:!1,this.valueHexView=s.valueHex?Z.BufferSourceConverter.toUint8Array(s.valueHex):qc}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,o,s){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Qt(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",wt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Z.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var Zt=class{constructor({blockLength:e=0,error:t=Vn,warnings:n=[],valueBeforeDecode:o=qc}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=Z.BufferSourceConverter.toUint8Array(o)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(e){this.valueBeforeDecodeView=new Uint8Array(e)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:Z.Convert.ToHex(this.valueBeforeDecodeView)}}};Zt.NAME="baseBlock";var Pe=class extends Zt{fromBER(e,t,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(e,t){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};Pe.NAME="valueBlock";var Hs=class extends er(Zt){constructor({idBlock:e={}}={}){var t,n,o,s;super(),e?(this.isHexOnly=(t=e.isHexOnly)!==null&&t!==void 0?t:!1,this.valueHexView=e.valueHex?Z.BufferSourceConverter.toUint8Array(e.valueHex):qc,this.tagClass=(n=e.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(o=e.tagNumber)!==null&&o!==void 0?o:-1,this.isConstructed=(s=e.isConstructed)!==null&&s!==void 0?s:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(e=!1){let t=0;switch(this.tagClass){case 1:t|=0;break;case 2:t|=64;break;case 3:t|=128;break;case 4:t|=192;break;default:return this.error="Unknown tag class",wt}if(this.isConstructed&&(t|=32),this.tagNumber<31&&!this.isHexOnly){let o=new Uint8Array(1);if(!e){let s=this.tagNumber;s&=31,t|=s,o[0]=t}return o.buffer}if(!this.isHexOnly){let o=Ar(this.tagNumber,7),s=new Uint8Array(o),i=o.byteLength,a=new Uint8Array(i+1);if(a[0]=t|31,!e){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]=t|31,!e){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(e,t,n){let o=Z.BufferSourceConverter.toUint8Array(e);if(!Qt(this,o,t,n))return-1;let s=o.subarray(t,t+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,f=this.valueHexView=new Uint8Array(255),u=255;for(;s[c]&128;){if(f[c-1]=s[c]&127,c++,c>=s.length)return this.error="End of input reached before message was fully decoded",-1;if(c===u){u+=255;let h=new Uint8Array(u);for(let g=0;g<f.length;g++)h[g]=f[g];f=this.valueHexView=new Uint8Array(u)}}this.blockLength=c+1,f[c-1]=s[c]&127;let l=new Uint8Array(c);for(let h=0;h<c;h++)l[h]=f[h];f=this.valueHexView=new Uint8Array(c),f.set(l),this.blockLength<=9?this.tagNumber=jr(f,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 t+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};Hs.NAME="identificationBlock";var Ks=class extends Zt{constructor({lenBlock:e={}}={}){var t,n,o;super(),this.isIndefiniteForm=(t=e.isIndefiniteForm)!==null&&t!==void 0?t:!1,this.longFormUsed=(n=e.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(o=e.length)!==null&&o!==void 0?o:0}fromBER(e,t,n){let o=Z.BufferSourceConverter.toUint8Array(e);if(!Qt(this,o,t,n))return-1;let s=o.subarray(t,t+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,t+this.blockLength;if(this.longFormUsed=!!(s[0]&128),this.longFormUsed===!1)return this.length=s[0],this.blockLength=1,t+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=t+1,c=o.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=jr(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,t+this.blockLength}toBER(e=!1){let t,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=128),t;if(this.longFormUsed){let o=Ar(this.length,8);if(o.byteLength>127)return this.error="Too big length",wt;if(t=new ArrayBuffer(o.byteLength+1),e)return t;let s=new Uint8Array(o);n=new Uint8Array(t),n[0]=o.byteLength|128;for(let i=0;i<o.byteLength;i++)n[i+1]=s[i];return t}return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=this.length),t}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Ks.NAME="lengthBlock";var D={},Te=class extends Zt{constructor({name:e=Vn,optional:t=!1,primitiveSchema:n,...o}={},s){super(o),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new Hs(o),this.lenBlock=new Ks(o),this.valueBlock=s?new s(o):new Pe(o)}fromBER(e,t,n){let o=this.valueBlock.fromBER(e,t,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(e,t){let n=t||new xo;t||ih(this);let o=this.idBlock.toBER(e);if(n.write(o),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(e,n),n.write(new ArrayBuffer(2));else{let s=this.valueBlock.toBER(e);this.lenBlock.length=s.byteLength;let i=this.lenBlock.toBER(e);n.write(i),n.write(s)}return t?wt:n.final()}toJSON(){let e={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(e.primitiveSchema=this.primitiveSchema.toJSON()),e}toString(e="ascii"){return e==="ascii"?this.onAsciiEncoding():Z.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${Z.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(e){if(this===e)return!0;if(!(e instanceof this.constructor))return!1;let t=this.toBER(),n=e.toBER();return th(t,n)}};Te.NAME="BaseBlock";function ih(r){if(r instanceof D.Constructed)for(let e of r.valueBlock.value)ih(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var qs=class extends Te{constructor({value:e=Vn,...t}={},n){super(t,n),e&&this.fromString(e)}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}fromBER(e,t,n){let o=this.valueBlock.fromBER(e,t,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}'`}};qs.NAME="BaseStringBlock";var zs=class extends er(Pe){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};zs.NAME="PrimitiveValueBlock";var ah,Gs=class extends Te{constructor(e={}){super(e,zs),this.idBlock.isConstructed=!1}};ah=Gs;D.Primitive=ah;Gs.NAME="PRIMITIVE";function gw(r,e){if(r instanceof e)return r;let t=new e;return t.idBlock=r.idBlock,t.lenBlock=r.lenBlock,t.warnings=r.warnings,t.valueBeforeDecodeView=r.valueBeforeDecodeView,t}function ki(r,e=0,t=r.length){let n=e,o=new Te({},Pe),s=new Zt;if(!Qt(s,r,e,t))return o.error=s.error,{offset:-1,result:o};if(!r.subarray(e,e+t).length)return o.error="Zero buffer length",{offset:-1,result:o};let a=o.idBlock.fromBER(r,e,t);if(o.idBlock.warnings.length&&o.warnings.concat(o.idBlock.warnings),a===-1)return o.error=o.idBlock.error,{offset:-1,result:o};if(e=a,t-=o.idBlock.blockLength,a=o.lenBlock.fromBER(r,e,t),o.lenBlock.warnings.length&&o.warnings.concat(o.lenBlock.warnings),a===-1)return o.error=o.lenBlock.error,{offset:-1,result:o};if(e=a,t-=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=Te;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=D.EndOfContent;break;case 1:c=D.Boolean;break;case 2:c=D.Integer;break;case 3:c=D.BitString;break;case 4:c=D.OctetString;break;case 5:c=D.Null;break;case 6:c=D.ObjectIdentifier;break;case 10:c=D.Enumerated;break;case 12:c=D.Utf8String;break;case 13:c=D.RelativeObjectIdentifier;break;case 14:c=D.TIME;break;case 15:return o.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:o};case 16:c=D.Sequence;break;case 17:c=D.Set;break;case 18:c=D.NumericString;break;case 19:c=D.PrintableString;break;case 20:c=D.TeletexString;break;case 21:c=D.VideotexString;break;case 22:c=D.IA5String;break;case 23:c=D.UTCTime;break;case 24:c=D.GeneralizedTime;break;case 25:c=D.GraphicString;break;case 26:c=D.VisibleString;break;case 27:c=D.GeneralString;break;case 28:c=D.UniversalString;break;case 29:c=D.CharacterString;break;case 30:c=D.BmpString;break;case 31:c=D.DATE;break;case 32:c=D.TimeOfDay;break;case 33:c=D.DateTime;break;case 34:c=D.Duration;break;default:{let f=o.idBlock.isConstructed?new D.Constructed:new D.Primitive;f.idBlock=o.idBlock,f.lenBlock=o.lenBlock,f.warnings=o.warnings,o=f}}break;case 2:case 3:case 4:default:c=o.idBlock.isConstructed?D.Constructed:D.Primitive}return o=gw(o,c),a=o.fromBER(r,e,o.lenBlock.isIndefiniteForm?t:o.lenBlock.length),o.valueBeforeDecodeView=r.subarray(n,n+o.blockLength),{offset:a,result:o}}function Mn(r){if(!r.byteLength){let e=new Te({},Pe);return e.error="Input buffer has zero length",{offset:-1,result:e}}return ki(Z.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function ww(r,e){return r?1:e}var _t=class extends Pe{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n){let o=Z.BufferSourceConverter.toUint8Array(e);if(!Qt(this,o,t,n))return-1;if(this.valueBeforeDecodeView=o.subarray(t,t+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),t;let s=t;for(;ww(this.isIndefiniteForm,n)>0;){let i=ki(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===Eo)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Eo?this.value.pop():this.warnings.push("No EndOfContent block encoded")),s}toBER(e,t){let n=t||new xo;for(let o=0;o<this.value.length;o++)this.value[o].toBER(e,n);return t?wt:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};_t.NAME="ConstructedValueBlock";var ch,Br=class extends Te{constructor(e={}){super(e,_t),this.idBlock.isConstructed=!0}fromBER(e,t,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let o=this.valueBlock.fromBER(e,t,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 e=[];for(let n of this.valueBlock.value)e.push(n.toString("ascii").split(`
4
4
  `).map(o=>` ${o}`).join(`
5
5
  `));let t=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return e.length?`${t} :
6
6
  ${e.join(`
7
- `)}`:`${t} :`}};ch=Ar;D.Constructed=ch;Ar.NAME="CONSTRUCTED";var js=class extends Pe{fromBER(e,t,n){return t}toBER(e){return wt}};js.override="EndOfContentValueBlock";var uh,Ws=class extends Te{constructor(e={}){super(e,js),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};uh=Ws;D.EndOfContent=uh;Ws.NAME=Eo;var lh,Br=class extends Te{constructor(e={}){super(e,Pe),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(e,t,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,t+n>e.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):t+n}toBER(e,t){let n=new ArrayBuffer(2);if(!e){let o=new Uint8Array(n);o[0]=5,o[1]=0}return t&&t.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};lh=Br;D.Null=lh;Br.NAME="NULL";var Ys=class extends Qt(Pe){constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=Z.BufferSourceConverter.toUint8Array(t.valueHex):this.valueHexView=new Uint8Array(1),e&&(this.value=e)}get value(){for(let e of this.valueHexView)if(e>0)return!0;return!1}set value(e){this.valueHexView[0]=e?255:0}fromBER(e,t,n){let o=Z.BufferSourceConverter.toUint8Array(e);return Xt(this,o,t,n)?(this.valueHexView=o.subarray(t,t+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,Gc.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Ys.NAME="BooleanValueBlock";var fh,Zs=class extends Te{constructor(e={}){super(e,Ys),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};fh=Zs;D.Boolean=fh;Zs.NAME="BOOLEAN";var Js=class extends Qt(Rt){constructor({isConstructed:e=!1,...t}={}){super(t),this.isConstructed=e}fromBER(e,t,n){let o=0;if(this.isConstructed){if(this.isHexOnly=!1,o=Rt.prototype.fromBER.call(this,e,t,n),o===-1)return o;for(let s=0;s<this.value.length;s++){let i=this.value[s].constructor.NAME;if(i===Eo){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==oh)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,o=super.fromBER(e,t,n),this.blockLength=n;return o}toBER(e,t){return this.isConstructed?Rt.prototype.toBER.call(this,e,t):e?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Js.NAME="OctetStringValueBlock";var hh,Zt=class r extends Te{constructor({idBlock:e={},lenBlock:t={},...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,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},Js),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(e,t,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),t;if(!this.valueBlock.isConstructed){let s=(e instanceof ArrayBuffer?new Uint8Array(e):e).subarray(t,t+n);try{if(s.byteLength){let i=ki(s,0,s.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(e,t,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?Ar.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 e=[];for(let t of this.valueBlock.value)t instanceof r&&e.push(t.valueBlock.valueHexView);return Z.BufferSourceConverter.concat(e)}};hh=Zt;D.OctetString=hh;Zt.NAME=oh;var Xs=class extends Qt(Rt){constructor({unusedBits:e=0,isConstructed:t=!1,...n}={}){super(n),this.unusedBits=e,this.isConstructed=t,this.blockLength=this.valueHexView.byteLength}fromBER(e,t,n){if(!n)return t;let o=-1;if(this.isConstructed){if(o=Rt.prototype.fromBER.call(this,e,t,n),o===-1)return o;for(let a of this.value){let c=a.constructor.NAME;if(c===Eo){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==sh)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return o}let s=Z.BufferSourceConverter.toUint8Array(e);if(!Xt(this,s,t,n))return-1;let i=s.subarray(t,t+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=ki(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,t+n}toBER(e,t){if(this.isConstructed)return Rt.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return wt;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}}};Xs.NAME="BitStringValueBlock";var dh,Fn=class extends Te{constructor({idBlock:e={},lenBlock:t={},...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,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},Xs),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(e,t,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(e,t,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Ar.prototype.onAsciiEncoding.call(this);{let e=[],t=this.valueBlock.valueHexView;for(let o of t)e.push(o.toString(2).padStart(8,"0"));let n=e.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};dh=Fn;D.BitString=dh;Fn.NAME=sh;var ph;function bw(r,e){let t=new Uint8Array([0]),n=new Uint8Array(r),o=new Uint8Array(e),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,f=0,u=c<i?i:c,l=0;for(let h=u;h>=0;h--,l++){switch(!0){case l<a.length:f=s[i-l]+a[c-l]+t[0];break;default:f=s[i-l]+t[0]}switch(t[0]=f/10,!0){case l>=s.length:s=Ms(new Uint8Array([f%10]),s);break;default:s[i-l]=f%10}}return t[0]>0&&(s=Ms(t,s)),s}function nh(r){if(r>=bo.length)for(let e=bo.length;e<=r;e++){let t=new Uint8Array([0]),n=bo[e-1].slice(0);for(let o=n.length-1;o>=0;o--){let s=new Uint8Array([(n[o]<<1)+t[0]]);t[0]=s[0]/10,n[o]=s[0]%10}t[0]>0&&(n=Ms(t,n)),bo.push(n)}return bo[r]}function xw(r,e){let t=0,n=new Uint8Array(r),o=new Uint8Array(e),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,f,u=0;for(let l=c;l>=0;l--,u++)switch(f=s[i-u]-a[c-u]-t,!0){case f<0:t=1,s[i-u]=f+10;break;default:t=0,s[i-u]=f}if(t>0)for(let l=i-c+1;l>=0;l--,u++)if(f=s[i-u]-t,f<0)t=1,s[i-u]=f+10;else{t=0,s[i-u]=f;break}return s.slice()}var vo=class extends Qt(Pe){constructor({value:e,...t}={}){super(t),this._valueDec=0,t.valueHex&&this.setValueHex(),e!==void 0&&(this.valueDec=e)}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=Gc.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(eh(e))}get valueDec(){return this._valueDec}fromDER(e,t,n,o=0){let s=this.fromBER(e,t,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(e=!1){let t=this.valueHexView;switch(!0){case(t[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(t,1),this.valueHexView=n}break;case(t[0]===0&&(t[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(e)}fromBER(e,t,n){let o=super.fromBER(e,t,n);return o===-1||this.setValueHex(),o}toBER(e){return e?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let e=this.valueHexView.length*8-1,t=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 f=0;f<8;f++){if((o&1)===1)switch(n){case e:t=xw(nh(n),t),i="-";break;default:t=bw(t,nh(n))}n++,o>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(i+=rh.charAt(t[c]));return a===!1&&(i+=rh.charAt(0)),i}};ph=vo;vo.NAME="IntegerValueBlock";Object.defineProperty(ph.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var mh,we=class r extends Te{constructor(e={}){super(e,vo),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return $s(),BigInt(this.valueBlock.toString())}static fromBigInt(e){$s();let t=BigInt(e),n=new xo,o=t.toString(16).replace(/^-/,""),s=new Uint8Array(Z.Convert.FromHex(o));if(t<0){let a=new Uint8Array(s.length+(s[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${Z.Convert.ToHex(a)}`)+t,u=Z.BufferSourceConverter.toUint8Array(Z.Convert.FromHex(f.toString(16)));u[0]|=128,n.write(u)}else s[0]&128&&n.write(new Uint8Array([0])),n.write(s);return new r({valueHex:n.final()})}convertToDER(){let e=new r({valueHex:this.valueBlock.valueHexView});return e.valueBlock.toDER(),e}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()}`}};mh=we;D.Integer=mh;we.NAME="INTEGER";var yh,Qs=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};yh=Qs;D.Enumerated=yh;Qs.NAME="ENUMERATED";var Ao=class extends Qt(Pe){constructor({valueDec:e=-1,isFirstSid:t=!1,...n}={}){super(n),this.valueDec=e,this.isFirstSid=t}fromBER(e,t,n){if(!n)return t;let o=Z.BufferSourceConverter.toUint8Array(e);if(!Xt(this,o,t,n))return-1;let s=o.subarray(t,t+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=s[a]&127,this.blockLength++,!!(s[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,s[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Gr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){$s();let t=BigInt(e).toString(2);for(;t.length%7;)t="0"+t;let n=new Uint8Array(t.length/7);for(let o=0;o<n.length;o++)n[o]=parseInt(t.slice(o*7,o*7+7),2)+(o+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(e){if(this.isHexOnly){if(e)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 t=vr(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",wt;let n=new Uint8Array(t.byteLength);if(!e){let o=new Uint8Array(t),s=t.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n}toString(){let e="";if(this.isHexOnly)e=Z.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let t=this.valueDec;this.valueDec<=39?e="0.":this.valueDec<=79?(e="1.",t-=40):(e="2.",t-=80),e+=t.toString()}else e=this.valueDec.toString();return e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Ao.NAME="sidBlock";var ei=class extends Pe{constructor({value:e=Vn,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let s=new Ao;if(o=s.fromBER(e,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(e){let t=[];for(let n=0;n<this.value.length;n++){let o=this.value[n].toBER(e);if(o.byteLength===0)return this.error=this.value[n].error,wt;t.push(o)}return jc(t)}fromString(e){this.value=[];let t=0,n=0,o="",s=!1;do if(n=e.indexOf(".",t),n===-1?o=e.substring(t):o=e.substring(t,n),t=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 Ao;if(o>Number.MAX_SAFE_INTEGER){$s();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 e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let o=this.value[n].toString();n!==0&&(e=`${e}.`),t?(o=`{${o}}`,this.value[n].isFirstSid?e=`2.{${o} - 80}`:e+=o):e+=o}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};ei.NAME="ObjectIdentifierValueBlock";var gh,gt=class extends Te{constructor(e={}){super(e,ei),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};gh=gt;D.ObjectIdentifier=gh;gt.NAME="OBJECT IDENTIFIER";var Bo=class extends Qt(Yt){constructor({valueDec:e=0,...t}={}){super(t),this.valueDec=e}fromBER(e,t,n){if(n===0)return t;let o=Z.BufferSourceConverter.toUint8Array(e);if(!Xt(this,o,t,n))return-1;let s=o.subarray(t,t+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=s[a]&127,this.blockLength++,!!(s[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,s[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Gr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}toBER(e){if(this.isHexOnly){if(e)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 t=vr(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",wt;let n=new Uint8Array(t.byteLength);if(!e){let o=new Uint8Array(t),s=t.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n.buffer}toString(){let e="";return this.isHexOnly?e=Z.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Bo.NAME="relativeSidBlock";var ti=class extends Pe{constructor({value:e=Vn,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let s=new Bo;if(o=s.fromBER(e,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(e,t){let n=[];for(let o=0;o<this.value.length;o++){let s=this.value[o].toBER(e);if(s.byteLength===0)return this.error=this.value[o].error,wt;n.push(s)}return jc(n)}fromString(e){this.value=[];let t=0,n=0,o="";do{n=e.indexOf(".",t),n===-1?o=e.substring(t):o=e.substring(t,n),t=n+1;let s=new Bo;if(s.valueDec=parseInt(o,10),isNaN(s.valueDec))return!0;this.value.push(s)}while(n!==-1);return!0}toString(){let e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let o=this.value[n].toString();n!==0&&(e=`${e}.`),t&&(o=`{${o}}`),e+=o}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};ti.NAME="RelativeObjectIdentifierValueBlock";var wh,ri=class extends Te{constructor(e={}){super(e,ti),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};wh=ri;D.RelativeObjectIdentifier=wh;ri.NAME="RelativeObjectIdentifier";var bh,Ae=class extends Ar{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};bh=Ae;D.Sequence=bh;Ae.NAME="SEQUENCE";var xh,ni=class extends Ar{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};xh=ni;D.Set=xh;ni.NAME="SET";var oi=class extends Qt(Pe){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=Vn}toJSON(){return{...super.toJSON(),value:this.value}}};oi.NAME="StringValueBlock";var si=class extends oi{};si.NAME="SimpleStringValueBlock";var $e=class extends qs{constructor({...e}={}){super(e,si)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,Z.BufferSourceConverter.toUint8Array(e))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t);for(let o=0;o<t;o++)n[o]=e.charCodeAt(o);this.valueBlock.value=e}};$e.NAME="SIMPLE STRING";var ii=class extends $e{fromBuffer(e){this.valueBlock.valueHexView=Z.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=Z.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=Z.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(Z.Convert.FromUtf8String(e)),this.valueBlock.value=e}};ii.NAME="Utf8StringValueBlock";var Eh,Jt=class extends ii{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Eh=Jt;D.Utf8String=Eh;Jt.NAME="UTF8String";var ai=class extends $e{fromBuffer(e){this.valueBlock.value=Z.Convert.ToUtf16String(e),this.valueBlock.valueHexView=Z.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(Z.Convert.FromUtf16String(e))}};ai.NAME="BmpStringValueBlock";var vh,ci=class extends ai{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};vh=ci;D.BmpString=vh;ci.NAME="BMPString";var ui=class extends $e{fromBuffer(e){let t=ArrayBuffer.isView(e)?e.slice().buffer:e.slice(0),n=new Uint8Array(t);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(t))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t*4);for(let o=0;o<t;o++){let s=vr(e.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=e}};ui.NAME="UniversalStringValueBlock";var Ah,li=class extends ui{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Ah=li;D.UniversalString=Ah;li.NAME="UniversalString";var Bh,fi=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Bh=fi;D.NumericString=Bh;fi.NAME="NumericString";var kh,hi=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};kh=hi;D.PrintableString=kh;hi.NAME="PrintableString";var Sh,di=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Sh=di;D.TeletexString=Sh;di.NAME="TeletexString";var Ih,pi=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ih=pi;D.VideotexString=Ih;pi.NAME="VideotexString";var Rh,mi=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Rh=mi;D.IA5String=Rh;mi.NAME="IA5String";var _h,yi=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};_h=yi;D.GraphicString=_h;yi.NAME="GraphicString";var Th,ko=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Th=ko;D.VisibleString=Th;ko.NAME="VisibleString";var Nh,gi=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Nh=gi;D.GeneralString=Nh;gi.NAME="GeneralString";var Ch,wi=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Ch=wi;D.CharacterString=Ch;wi.NAME="CharacterString";var Lh,So=class extends ko{constructor({value:e,valueDate:t,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,e){this.fromString(e),this.valueBlock.valueHexView=new Uint8Array(e.length);for(let o=0;o<e.length;o++)this.valueBlock.valueHexView[o]=e.charCodeAt(o)}t&&(this.fromDate(t),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(e){this.fromString(String.fromCharCode.apply(null,Z.BufferSourceConverter.toUint8Array(e)))}toBuffer(){let e=this.toString(),t=new ArrayBuffer(e.length),n=new Uint8Array(t);for(let o=0;o<e.length;o++)n[o]=e.charCodeAt(o);return t}fromDate(e){this.year=e.getUTCFullYear(),this.month=e.getUTCMonth()+1,this.day=e.getUTCDate(),this.hour=e.getUTCHours(),this.minute=e.getUTCMinutes(),this.second=e.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(e){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(e);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(e="iso"){if(e==="iso"){let t=new Array(7);return t[0]=qe(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=qe(this.month,2),t[2]=qe(this.day,2),t[3]=qe(this.hour,2),t[4]=qe(this.minute,2),t[5]=qe(this.second,2),t[6]="Z",t.join("")}return super.toString(e)}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}}};Lh=So;D.UTCTime=Lh;So.NAME="UTCTime";var Uh,bi=class extends So{constructor(e={}){var t;super(e),(t=this.millisecond)!==null&&t!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(e){super.fromDate(e),this.millisecond=e.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(e){let t=!1,n="",o="",s=0,i,a=0,c=0;if(e[e.length-1]==="Z")n=e.substring(0,e.length-1),t=!0;else{let l=new Number(e[e.length-1]);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");n=e}if(t){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,h=n.indexOf("+"),g="";if(h===-1&&(h=n.indexOf("-"),l=-1),h!==-1){if(g=n.substring(h+1),n=n.substring(0,h),g.length!==2&&g.length!==4)throw new Error("Wrong input string for conversion");let y=parseInt(g.substring(0,2),10);if(isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*y,g.length===4){if(y=parseInt(g.substring(2,4),10),isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");c=l*y}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let l=new Number(`0${n.substring(f)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");s=l.valueOf(),o=n.substring(0,f)}else o=n;switch(!0){case o.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-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,f!==-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,f!==-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,f!==-1){let l=1e3*s;this.millisecond=Math.floor(l)}break;default:throw new Error("Wrong input string for conversion")}let u=i.exec(o);if(u===null)throw new Error("Wrong input string for conversion");for(let l=1;l<u.length;l++)switch(l){case 1:this.year=parseInt(u[l],10);break;case 2:this.month=parseInt(u[l],10);break;case 3:this.day=parseInt(u[l],10);break;case 4:this.hour=parseInt(u[l],10)+a;break;case 5:this.minute=parseInt(u[l],10)+c;break;case 6:this.second=parseInt(u[l],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!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(e="iso"){if(e==="iso"){let t=[];return t.push(qe(this.year,4)),t.push(qe(this.month,2)),t.push(qe(this.day,2)),t.push(qe(this.hour,2)),t.push(qe(this.minute,2)),t.push(qe(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(qe(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Uh=bi;D.GeneralizedTime=Uh;bi.NAME="GeneralizedTime";var Dh,xi=class extends Jt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Dh=xi;D.DATE=Dh;xi.NAME="DATE";var Ph,Ei=class extends Jt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ph=Ei;D.TimeOfDay=Ph;Ei.NAME="TimeOfDay";var Oh,vi=class extends Jt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Oh=vi;D.DateTime=Oh;vi.NAME="DateTime";var Fh,Ai=class extends Jt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Fh=Ai;D.Duration=Fh;Ai.NAME="Duration";var Vh,Bi=class extends Jt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Vh=Bi;D.TIME=Vh;Bi.NAME="TIME";function vw(r){let{result:e}=Mn(r),t=e.valueBlock.value;return{n:z(_t(t[1].toBigInt()),"base64url"),e:z(_t(t[2].toBigInt()),"base64url"),d:z(_t(t[3].toBigInt()),"base64url"),p:z(_t(t[4].toBigInt()),"base64url"),q:z(_t(t[5].toBigInt()),"base64url"),dp:z(_t(t[6].toBigInt()),"base64url"),dq:z(_t(t[7].toBigInt()),"base64url"),qi:z(_t(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Aw(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 N("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new Ae({value:[new we({value:0}),we.fromBigInt(Tt(Y(r.n,"base64url"))),we.fromBigInt(Tt(Y(r.e,"base64url"))),we.fromBigInt(Tt(Y(r.d,"base64url"))),we.fromBigInt(Tt(Y(r.p,"base64url"))),we.fromBigInt(Tt(Y(r.q,"base64url"))),we.fromBigInt(Tt(Y(r.dp,"base64url"))),we.fromBigInt(Tt(Y(r.dq,"base64url"))),we.fromBigInt(Tt(Y(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function Bw(r){let{result:e}=Mn(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:z(_t(t[0].toBigInt()),"base64url"),e:z(_t(t[1].toBigInt()),"base64url")}}function kw(r){if(r.n==null||r.e==null)throw new N("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new Ae({value:[new Ae({value:[new gt({value:"1.2.840.113549.1.1.1"}),new Br]}),new Fn({valueHex:new Ae({value:[we.fromBigInt(Tt(Y(r.n,"base64url"))),we.fromBigInt(Tt(Y(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function _t(r){let e=r.toString(16);e.length%2>0&&(e=`0${e}`);let t=e.length/2,n=new Uint8Array(t),o=0,s=0;for(;o<t;)n[o]=parseInt(e.slice(s,s+2),16),o+=1,s+=2;return n}function Tt(r){let e=[];return r.forEach(function(t){let n=t.toString(16);n.length%2>0&&(n=`0${n}`),e.push(n)}),BigInt("0x"+e.join(""))}var Sw=16,Yc=32,Zc=1e4;async function Iw(r,e){let t=Me.get(),o=new Ae({value:[new we({value:0}),new Ae({value:[new gt({value:"1.2.840.113549.1.1.1"}),new Br]}),new Zt({valueHex:r.marshal()})]}).toBER(),s=new Uint8Array(o,0,o.byteLength),i=zr(Sw),a=await qc(Nn,e,i,{c:Zc,dkLen:Yc}),c=zr(16),f=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),u=await t.subtle.encrypt({name:"AES-CBC",iv:c},f,s),l=new Ae({value:[new Zt({valueHex:i}),new we({value:Zc}),new we({value:Yc}),new Ae({value:[new gt({value:"1.2.840.113549.2.11"}),new Br]})]}),h=new Ae({value:[new gt({value:"1.2.840.113549.1.5.13"}),new Ae({value:[new Ae({value:[new gt({value:"1.2.840.113549.1.5.12"}),l]}),new Ae({value:[new gt({value:"2.16.840.1.101.3.4.1.42"}),new Zt({valueHex:c})]})]})]}),y=new Ae({value:[h,new Zt({valueHex:u})]}).toBER(),p=new Uint8Array(y,0,y.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...z(p,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
8
- `)}async function Rw(r,e){let t=Me.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=Y(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Mn(o),{iv:i,salt:a,iterations:c,keySize:f,cipherText:u}=_w(s),l=await qc(Nn,e,a,{c,dkLen:f}),h=await t.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),g=Io(await t.subtle.decrypt({name:"AES-CBC",iv:i},h,u)),{result:y}=Mn(g);n=Mh(y)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=Y(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Mn(o);n=Mh(s)}else throw new N("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Jc(n)}function _w(r){let e=r.valueBlock.value[0];if(e.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new N("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=e.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new N("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let s=n.valueBlock.value[1],i=Io(s.valueBlock.value[0].getValue()),a=Zc,c=Yc;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 N("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let f=e.valueBlock.value[1].valueBlock.value[1],u=f.valueBlock.value[0].toString();if(u!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(u!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new N("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=Io(f.valueBlock.value[1].getValue());return{cipherText:Io(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:l}}function Mh(r){return Io(r.valueBlock.value[2].getValue())}function Io(r){return new Uint8Array(r,0,r.byteLength)}async function $h(r){let e=await Me.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),t=await qh(e);return{privateKey:t[0],publicKey:t[1]}}async function Xc(r){let t=[await Me.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Tw(r)],n=await qh({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Hh(r,e){let t=await Me.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Me.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function Kh(r,e,t){let n=await Me.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Me.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray())}async function qh(r){if(r.privateKey==null||r.publicKey==null)throw new N("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Me.get().subtle.exportKey("jwk",r.privateKey),Me.get().subtle.exportKey("jwk",r.publicKey)])}async function Tw(r){return Me.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 Si(r){if(r.kty!=="RSA")throw new N("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new N("invalid key modulus","ERR_INVALID_KEY_MODULUS");return Y(r.n,"base64url").length*8}var _o=8192,Ro=class{_key;constructor(e){this._key=e}verify(e,t){return Kh(this._key,t,e)}marshal(){return kr.jwkToPkix(this._key)}get bytes(){return It.encode({Type:ye.RSA,Data:this.marshal()}).subarray()}equals(e){return ce(this.bytes,e.bytes)}hash(){let e=Ee.digest(this.bytes);return at(e)?e.then(({bytes:t})=>t):e.bytes}},$n=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return zr(16)}sign(e){return Hh(this._key,e)}get public(){if(this._publicKey==null)throw new N("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Ro(this._publicKey)}marshal(){return kr.jwkToPkcs1(this._key)}get bytes(){return jt.encode({Type:ye.RSA,Data:this.marshal()}).subarray()}equals(e){return ce(this.bytes,e.bytes)}hash(){let e=Ee.digest(this.bytes);return at(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return z(e,"base58btc")}async export(e,t="pkcs-8"){if(t==="pkcs-8")return kr.exportToPem(this,e);if(t==="libp2p-key")return Dn(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Jc(r){let e=kr.pkcs1ToJwk(r);if(Si(e)>_o)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Xc(e);return new $n(t.privateKey,t.publicKey)}function Cw(r){let e=kr.pkixToJwk(r);if(Si(e)>_o)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Ro(e)}async function Lw(r){if(Si(r)>_o)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Xc(r);return new $n(e.privateKey,e.publicKey)}async function Uw(r){if(r>_o)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await $h(r);return new $n(e.privateKey,e.publicKey)}var ou={};xe(ou,{Secp256k1PrivateKey:()=>No,Secp256k1PublicKey:()=>To,generateKeyPair:()=>jw,unmarshalSecp256k1PrivateKey:()=>zw,unmarshalSecp256k1PublicKey:()=>Gw});var Dw=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]),Sr=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Ir=new Uint32Array(64),eu=class extends Tn{constructor(){super(64,32,8,!1),this.A=Sr[0]|0,this.B=Sr[1]|0,this.C=Sr[2]|0,this.D=Sr[3]|0,this.E=Sr[4]|0,this.F=Sr[5]|0,this.G=Sr[6]|0,this.H=Sr[7]|0}get(){let{A:e,B:t,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[e,t,n,o,s,i,a,c]}set(e,t,n,o,s,i,a,c){this.A=e|0,this.B=t|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(e,t){for(let l=0;l<16;l++,t+=4)Ir[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let h=Ir[l-15],g=Ir[l-2],y=mt(h,7)^mt(h,18)^h>>>3,p=mt(g,17)^mt(g,19)^g>>>10;Ir[l]=p+Ir[l-7]+y+Ir[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let h=mt(a,6)^mt(a,11)^mt(a,25),g=u+h+_f(a,c,f)+Dw[l]+Ir[l]|0,p=(mt(n,2)^mt(n,13)^mt(n,22))+Tf(n,o,s)|0;u=f,f=c,c=a,a=i+g|0,i=s,s=o,o=n,n=g+p|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,u=u+this.H|0,this.set(n,o,s,i,a,c,f,u)}roundClean(){Ir.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var zh=Ss(()=>new eu);function Pw(r){let e=yo(r);St(e,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:t,Fp:n,a:o}=e;if(t){if(!n.eql(o,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof t!="object"||typeof t.beta!="bigint"||typeof t.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...e})}var{bytesToNumberBE:Ow,hexToBytes:Fw}=_s,jr={Err:class extends Error{constructor(e=""){super(e)}},_parseInt(r){let{Err:e}=jr;if(r.length<2||r[0]!==2)throw new e("Invalid signature integer tag");let t=r[1],n=r.subarray(2,t+2);if(!t||n.length!==t)throw new e("Invalid signature integer: wrong length");if(n[0]&128)throw new e("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new e("Invalid signature integer: unnecessary leading zero");return{d:Ow(n),l:r.subarray(t+2)}},toSig(r){let{Err:e}=jr,t=typeof r=="string"?Fw(r):r;Cn(t);let n=t.length;if(n<2||t[0]!=48)throw new e("Invalid signature tag");if(t[1]!==n-2)throw new e("Invalid signature: incorrect length");let{d:o,l:s}=jr._parseInt(t.subarray(2)),{d:i,l:a}=jr._parseInt(s);if(a.length)throw new e("Invalid signature: left bytes after parsing");return{r:o,s:i}},hexFromSig(r){let e=f=>Number.parseInt(f[0],16)&8?"00"+f:f,t=f=>{let u=f.toString(16);return u.length&1?`0${u}`:u},n=e(t(r.s)),o=e(t(r.r)),s=n.length/2,i=o.length/2,a=t(s),c=t(i);return`30${t(i+s+4)}02${c}${o}02${a}${n}`}},er=BigInt(0),ut=BigInt(1),uk=BigInt(2),Gh=BigInt(3),lk=BigInt(4);function Vw(r){let e=Pw(r),{Fp:t}=e,n=e.toBytes||((y,p,m)=>{let w=p.toAffine();return qt(Uint8Array.from([4]),t.toBytes(w.x),t.toBytes(w.y))}),o=e.fromBytes||(y=>{let p=y.subarray(1),m=t.fromBytes(p.subarray(0,t.BYTES)),w=t.fromBytes(p.subarray(t.BYTES,2*t.BYTES));return{x:m,y:w}});function s(y){let{a:p,b:m}=e,w=t.sqr(y),I=t.mul(w,y);return t.add(t.add(I,t.mul(y,p)),m)}if(!t.eql(t.sqr(e.Gy),s(e.Gx)))throw new Error("bad generator point: equation left != right");function i(y){return typeof y=="bigint"&&er<y&&y<e.n}function a(y){if(!i(y))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(y){let{allowedPrivateKeyLengths:p,nByteLength:m,wrapPrivateKey:w,n:I}=e;if(p&&typeof y!="bigint"){if(br(y)&&(y=Ht(y)),typeof y!="string"||!p.includes(y.length))throw new Error("Invalid key");y=y.padStart(m*2,"0")}let v;try{v=typeof y=="bigint"?y:Kt(pe("private key",y,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof y}`)}return w&&(v=ae(v,I)),a(v),v}let f=new Map;function u(y){if(!(y instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(p,m,w){if(this.px=p,this.py=m,this.pz=w,p==null||!t.isValid(p))throw new Error("x required");if(m==null||!t.isValid(m))throw new Error("y required");if(w==null||!t.isValid(w))throw new Error("z required")}static fromAffine(p){let{x:m,y:w}=p||{};if(!p||!t.isValid(m)||!t.isValid(w))throw new Error("invalid affine point");if(p instanceof l)throw new Error("projective point not allowed");let I=v=>t.eql(v,t.ZERO);return I(m)&&I(w)?l.ZERO:new l(m,w,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(p){let m=t.invertBatch(p.map(w=>w.pz));return p.map((w,I)=>w.toAffine(m[I])).map(l.fromAffine)}static fromHex(p){let m=l.fromAffine(o(pe("pointHex",p)));return m.assertValidity(),m}static fromPrivateKey(p){return l.BASE.multiply(c(p))}_setWindowSize(p){this._WINDOW_SIZE=p,f.delete(this)}assertValidity(){if(this.is0()){if(e.allowInfinityPoint&&!t.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:p,y:m}=this.toAffine();if(!t.isValid(p)||!t.isValid(m))throw new Error("bad point: x or y not FE");let w=t.sqr(m),I=s(p);if(!t.eql(w,I))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:p}=this.toAffine();if(t.isOdd)return!t.isOdd(p);throw new Error("Field doesn't support isOdd")}equals(p){u(p);let{px:m,py:w,pz:I}=this,{px:v,py:U,pz:S}=p,_=t.eql(t.mul(m,S),t.mul(v,I)),L=t.eql(t.mul(w,S),t.mul(U,I));return _&&L}negate(){return new l(this.px,t.neg(this.py),this.pz)}double(){let{a:p,b:m}=e,w=t.mul(m,Gh),{px:I,py:v,pz:U}=this,S=t.ZERO,_=t.ZERO,L=t.ZERO,b=t.mul(I,I),C=t.mul(v,v),O=t.mul(U,U),T=t.mul(I,v);return T=t.add(T,T),L=t.mul(I,U),L=t.add(L,L),S=t.mul(p,L),_=t.mul(w,O),_=t.add(S,_),S=t.sub(C,_),_=t.add(C,_),_=t.mul(S,_),S=t.mul(T,S),L=t.mul(w,L),O=t.mul(p,O),T=t.sub(b,O),T=t.mul(p,T),T=t.add(T,L),L=t.add(b,b),b=t.add(L,b),b=t.add(b,O),b=t.mul(b,T),_=t.add(_,b),O=t.mul(v,U),O=t.add(O,O),b=t.mul(O,T),S=t.sub(S,b),L=t.mul(O,C),L=t.add(L,L),L=t.add(L,L),new l(S,_,L)}add(p){u(p);let{px:m,py:w,pz:I}=this,{px:v,py:U,pz:S}=p,_=t.ZERO,L=t.ZERO,b=t.ZERO,C=e.a,O=t.mul(e.b,Gh),T=t.mul(m,v),V=t.mul(w,U),H=t.mul(I,S),X=t.add(m,w),E=t.add(v,U);X=t.mul(X,E),E=t.add(T,V),X=t.sub(X,E),E=t.add(m,I);let k=t.add(v,S);return E=t.mul(E,k),k=t.add(T,H),E=t.sub(E,k),k=t.add(w,I),_=t.add(U,S),k=t.mul(k,_),_=t.add(V,H),k=t.sub(k,_),b=t.mul(C,E),_=t.mul(O,H),b=t.add(_,b),_=t.sub(V,b),b=t.add(V,b),L=t.mul(_,b),V=t.add(T,T),V=t.add(V,T),H=t.mul(C,H),E=t.mul(O,E),V=t.add(V,H),H=t.sub(T,H),H=t.mul(C,H),E=t.add(E,H),T=t.mul(V,E),L=t.add(L,T),T=t.mul(k,E),_=t.mul(X,_),_=t.sub(_,T),T=t.mul(X,V),b=t.mul(k,b),b=t.add(b,T),new l(_,L,b)}subtract(p){return this.add(p.negate())}is0(){return this.equals(l.ZERO)}wNAF(p){return g.wNAFCached(this,f,p,m=>{let w=t.invertBatch(m.map(I=>I.pz));return m.map((I,v)=>I.toAffine(w[v])).map(l.fromAffine)})}multiplyUnsafe(p){let m=l.ZERO;if(p===er)return m;if(a(p),p===ut)return this;let{endo:w}=e;if(!w)return g.unsafeLadder(this,p);let{k1neg:I,k1:v,k2neg:U,k2:S}=w.splitScalar(p),_=m,L=m,b=this;for(;v>er||S>er;)v&ut&&(_=_.add(b)),S&ut&&(L=L.add(b)),b=b.double(),v>>=ut,S>>=ut;return I&&(_=_.negate()),U&&(L=L.negate()),L=new l(t.mul(L.px,w.beta),L.py,L.pz),_.add(L)}multiply(p){a(p);let m=p,w,I,{endo:v}=e;if(v){let{k1neg:U,k1:S,k2neg:_,k2:L}=v.splitScalar(m),{p:b,f:C}=this.wNAF(S),{p:O,f:T}=this.wNAF(L);b=g.constTimeNegate(U,b),O=g.constTimeNegate(_,O),O=new l(t.mul(O.px,v.beta),O.py,O.pz),w=b.add(O),I=C.add(T)}else{let{p:U,f:S}=this.wNAF(m);w=U,I=S}return l.normalizeZ([w,I])[0]}multiplyAndAddUnsafe(p,m,w){let I=l.BASE,v=(S,_)=>_===er||_===ut||!S.equals(I)?S.multiplyUnsafe(_):S.multiply(_),U=v(this,m).add(v(p,w));return U.is0()?void 0:U}toAffine(p){let{px:m,py:w,pz:I}=this,v=this.is0();p==null&&(p=v?t.ONE:t.inv(I));let U=t.mul(m,p),S=t.mul(w,p),_=t.mul(I,p);if(v)return{x:t.ZERO,y:t.ZERO};if(!t.eql(_,t.ONE))throw new Error("invZ was invalid");return{x:U,y:S}}isTorsionFree(){let{h:p,isTorsionFree:m}=e;if(p===ut)return!0;if(m)return m(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:p,clearCofactor:m}=e;return p===ut?this:m?m(l,this):this.multiplyUnsafe(e.h)}toRawBytes(p=!0){return this.assertValidity(),n(l,this,p)}toHex(p=!0){return Ht(this.toRawBytes(p))}}l.BASE=new l(e.Gx,e.Gy,t.ONE),l.ZERO=new l(t.ZERO,t.ONE,t.ZERO);let h=e.nBitLength,g=Cs(l,e.endo?Math.ceil(h/2):h);return{CURVE:e,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:s,isWithinCurveOrder:i}}function Mw(r){let e=yo(r);return St(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function jh(r){let e=Mw(r),{Fp:t,n}=e,o=t.BYTES+1,s=2*t.BYTES+1;function i(E){return er<E&&E<t.ORDER}function a(E){return ae(E,n)}function c(E){return Ts(E,n)}let{ProjectivePoint:f,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:h}=Vw({...e,toBytes(E,k,$){let B=k.toAffine(),x=t.toBytes(B.x),P=qt;return $?P(Uint8Array.from([k.hasEvenY()?2:3]),x):P(Uint8Array.from([4]),x,t.toBytes(B.y))},fromBytes(E){let k=E.length,$=E[0],B=E.subarray(1);if(k===o&&($===2||$===3)){let x=Kt(B);if(!i(x))throw new Error("Point is not on curve");let P=l(x),M;try{M=t.sqrt(P)}catch(W){let te=W instanceof Error?": "+W.message:"";throw new Error("Point is not on curve"+te)}let K=(M&ut)===ut;return($&1)===1!==K&&(M=t.neg(M)),{x,y:M}}else if(k===s&&$===4){let x=t.fromBytes(B.subarray(0,t.BYTES)),P=t.fromBytes(B.subarray(t.BYTES,2*t.BYTES));return{x,y:P}}else throw new Error(`Point of length ${k} was invalid. Expected ${o} compressed bytes or ${s} uncompressed bytes`)}}),g=E=>Ht(Er(E,e.nByteLength));function y(E){let k=n>>ut;return E>k}function p(E){return y(E)?a(-E):E}let m=(E,k,$)=>Kt(E.slice(k,$));class w{constructor(k,$,B){this.r=k,this.s=$,this.recovery=B,this.assertValidity()}static fromCompact(k){let $=e.nByteLength;return k=pe("compactSignature",k,$*2),new w(m(k,0,$),m(k,$,2*$))}static fromDER(k){let{r:$,s:B}=jr.toSig(pe("DER",k));return new w($,B)}assertValidity(){if(!h(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!h(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(k){return new w(this.r,this.s,k)}recoverPublicKey(k){let{r:$,s:B,recovery:x}=this,P=L(pe("msgHash",k));if(x==null||![0,1,2,3].includes(x))throw new Error("recovery id invalid");let M=x===2||x===3?$+e.n:$;if(M>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let K=x&1?"03":"02",j=f.fromHex(K+g(M)),W=c(M),te=a(-P*W),J=a(B*W),Q=f.BASE.multiplyAndAddUnsafe(j,te,J);if(!Q)throw new Error("point at infinify");return Q.assertValidity(),Q}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new w(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return $r(this.toDERHex())}toDERHex(){return jr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return $r(this.toCompactHex())}toCompactHex(){return g(this.r)+g(this.s)}}let I={isValidPrivateKey(E){try{return u(E),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let E=Pc(e.n);return $f(e.randomBytes(E),e.n)},precompute(E=8,k=f.BASE){return k._setWindowSize(E),k.multiply(BigInt(3)),k}};function v(E,k=!0){return f.fromPrivateKey(E).toRawBytes(k)}function U(E){let k=br(E),$=typeof E=="string",B=(k||$)&&E.length;return k?B===o||B===s:$?B===2*o||B===2*s:E instanceof f}function S(E,k,$=!0){if(U(E))throw new Error("first arg must be private key");if(!U(k))throw new Error("second arg must be public key");return f.fromHex(k).multiply(u(E)).toRawBytes($)}let _=e.bits2int||function(E){let k=Kt(E),$=E.length*8-e.nBitLength;return $>0?k>>BigInt($):k},L=e.bits2int_modN||function(E){return a(_(E))},b=mo(e.nBitLength);function C(E){if(typeof E!="bigint")throw new Error("bigint expected");if(!(er<=E&&E<b))throw new Error(`bigint expected < 2^${e.nBitLength}`);return Er(E,e.nByteLength)}function O(E,k,$=T){if(["recovered","canonical"].some(he=>he in $))throw new Error("sign() legacy options not supported");let{hash:B,randomBytes:x}=e,{lowS:P,prehash:M,extraEntropy:K}=$;P==null&&(P=!0),E=pe("msgHash",E),M&&(E=pe("prehashed msgHash",B(E)));let j=L(E),W=u(k),te=[C(W),C(j)];if(K!=null&&K!==!1){let he=K===!0?x(t.BYTES):K;te.push(pe("extraEntropy",he))}let J=qt(...te),Q=j;function ge(he){let ke=_(he);if(!h(ke))return;let Se=c(ke),be=f.BASE.multiply(ke).toAffine(),Le=a(be.x);if(Le===er)return;let Dt=a(Se*a(Q+Le*W));if(Dt===er)return;let Lr=(be.x===Le?0:2)|Number(be.y&ut),Qn=Dt;return P&&y(Dt)&&(Qn=p(Dt),Lr^=1),new w(Le,Qn,Lr)}return{seed:J,k2sig:ge}}let T={lowS:e.lowS,prehash:!1},V={lowS:e.lowS,prehash:!1};function H(E,k,$=T){let{seed:B,k2sig:x}=O(E,k,$),P=e;return Cc(P.hash.outputLen,P.nByteLength,P.hmac)(B,x)}f.BASE._setWindowSize(8);function X(E,k,$,B=V){let x=E;if(k=pe("msgHash",k),$=pe("publicKey",$),"strict"in B)throw new Error("options.strict was renamed to lowS");let{lowS:P,prehash:M}=B,K,j;try{if(typeof x=="string"||br(x))try{K=w.fromDER(x)}catch(be){if(!(be instanceof jr.Err))throw be;K=w.fromCompact(x)}else if(typeof x=="object"&&typeof x.r=="bigint"&&typeof x.s=="bigint"){let{r:be,s:Le}=x;K=new w(be,Le)}else throw new Error("PARSE");j=f.fromHex($)}catch(be){if(be.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(P&&K.hasHighS())return!1;M&&(k=e.hash(k));let{r:W,s:te}=K,J=L(k),Q=c(te),ge=a(J*Q),he=a(W*Q),ke=f.BASE.multiplyAndAddUnsafe(j,ge,he)?.toAffine();return ke?a(ke.x)===W:!1}return{CURVE:e,getPublicKey:v,getSharedSecret:S,sign:H,verify:X,ProjectivePoint:f,Signature:w,utils:I}}function $w(r){return{hash:r,hmac:(e,...t)=>wo(r,e,ks(...t)),randomBytes:_n}}function Wh(r,e){let t=n=>jh({...r,...$w(n)});return Object.freeze({...t(e),create:t})}var Jh=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Yh=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Hw=BigInt(1),tu=BigInt(2),Zh=(r,e)=>(r+e/tu)/e;function Kw(r){let e=Jh,t=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%e,u=f*f*r%e,l=le(u,t,e)*u%e,h=le(l,t,e)*u%e,g=le(h,tu,e)*f%e,y=le(g,o,e)*g%e,p=le(y,s,e)*y%e,m=le(p,a,e)*p%e,w=le(m,c,e)*m%e,I=le(w,a,e)*p%e,v=le(I,t,e)*u%e,U=le(v,i,e)*y%e,S=le(U,n,e)*f%e,_=le(S,tu,e);if(!ru.eql(ru.sqr(_),r))throw new Error("Cannot find square root");return _}var ru=Ns(Jh,void 0,void 0,{sqrt:Kw}),bt=Wh({a:BigInt(0),b:BigInt(7),Fp:ru,n:Yh,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=Yh,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Hw*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=t,i=BigInt("0x100000000000000000000000000000000"),a=Zh(s*r,e),c=Zh(-n*r,e),f=ae(r-a*t-c*o,e),u=ae(-a*n-c*s,e),l=f>i,h=u>i;if(l&&(f=e-f),h&&(u=e-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:h,k2:u}}}},zh),bk=BigInt(0);var xk=bt.ProjectivePoint;function Xh(){return bt.utils.randomPrivateKey()}function Qh(r,e){let t=Ee.digest(e instanceof Uint8Array?e:e.subarray());if(at(t))return t.then(({digest:n})=>bt.sign(n,r).toDERRawBytes()).catch(n=>{throw new N(String(n),"ERR_INVALID_INPUT")});try{return bt.sign(t.digest,r).toDERRawBytes()}catch(n){throw new N(String(n),"ERR_INVALID_INPUT")}}function ed(r,e,t){let n=Ee.digest(t instanceof Uint8Array?t:t.subarray());if(at(n))return n.then(({digest:o})=>bt.verify(e,o,r)).catch(o=>{throw new N(String(o),"ERR_INVALID_INPUT")});try{return bt.verify(e,n.digest,r)}catch(o){throw new N(String(o),"ERR_INVALID_INPUT")}}function td(r){return bt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function rd(r){try{bt.getPublicKey(r,!0)}catch(e){throw new N(String(e),"ERR_INVALID_PRIVATE_KEY")}}function nu(r){try{bt.ProjectivePoint.fromHex(r)}catch(e){throw new N(String(e),"ERR_INVALID_PUBLIC_KEY")}}function nd(r){try{return bt.getPublicKey(r,!0)}catch(e){throw new N(String(e),"ERR_INVALID_PRIVATE_KEY")}}var To=class{_key;constructor(e){nu(e),this._key=e}verify(e,t){return ed(this._key,t,e)}marshal(){return td(this._key)}get bytes(){return It.encode({Type:ye.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return ce(this.bytes,e.bytes)}async hash(){let e=Ee.digest(this.bytes),t;return at(e)?{bytes:t}=await e:t=e.bytes,t}},No=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??nd(e),rd(this._key),nu(this._publicKey)}sign(e){return Qh(this._key,e)}get public(){return new To(this._publicKey)}marshal(){return this._key}get bytes(){return jt.encode({Type:ye.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return ce(this.bytes,e.bytes)}hash(){let e=Ee.digest(this.bytes);return at(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return z(e,"base58btc")}async export(e,t="libp2p-key"){if(t==="libp2p-key")return Dn(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function zw(r){return new No(r)}function Gw(r){return new To(r)}async function jw(){let r=Xh();return new No(r)}var Ii={rsa:Qc,ed25519:Kc,secp256k1:ou};function Ww(r){let e=Object.keys(Ii).join(" / ");return new N(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function su(r){let e=It.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case ye.RSA:return Ii.rsa.unmarshalRsaPublicKey(t);case ye.Ed25519:return Ii.ed25519.unmarshalEd25519PublicKey(t);case ye.Secp256k1:return Ii.secp256k1.unmarshalSecp256k1PublicKey(t);default:throw Ww(e.Type??"unknown")}}var Rb=ot(pn(),1);var tr="/",od=new TextEncoder().encode(tr),Ri=od[0],Ne=class r{_buf;constructor(e,t){if(typeof e=="string")this._buf=Y(e);else if(e instanceof Uint8Array)this._buf=e;else throw new Error("Invalid key, should be String of Uint8Array");if(t==null&&(t=!0),t&&this.clean(),this._buf.byteLength===0||this._buf[0]!==Ri)throw new Error("Invalid key")}toString(e="utf8"){return z(this._buf,e)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(e){return new r(e.join(tr))}static random(){return new r(Math.random().toString().substring(2))}static asKey(e){return e instanceof Uint8Array||typeof e=="string"?new r(e):typeof e.uint8Array=="function"?new r(e.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=od),this._buf[0]!==Ri){let e=new Uint8Array(this._buf.byteLength+1);e.fill(Ri,0,1),e.set(this._buf,1),this._buf=e}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Ri;)this._buf=this._buf.subarray(0,-1)}less(e){let t=this.list(),n=e.list();for(let o=0;o<t.length;o++){if(n.length<o+1)return!1;let s=t[o],i=n[o];if(s<i)return!0;if(s>i)return!1}return t.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let e=this.namespaces();return e[e.length-1]}list(){return this.toString().split(tr).slice(1)}type(){return Yw(this.baseNamespace())}name(){return Zw(this.baseNamespace())}instance(e){return new r(this.toString()+":"+e)}path(){let e=this.parent().toString();return e.endsWith(tr)||(e+=tr),e+=this.type(),new r(e)}parent(){let e=this.list();return e.length===1?new r(tr):new r(e.slice(0,-1).join(tr))}child(e){return this.toString()===tr?e:e.toString()===tr?this:new r(this.toString()+e.toString(),!1)}isAncestorOf(e){return e.toString()===this.toString()?!1:e.toString().startsWith(this.toString())}isDecendantOf(e){return e.toString()===this.toString()?!1:this.toString().startsWith(e.toString())}isTopLevel(){return this.list().length===1}concat(...e){return r.withNamespaces([...this.namespaces(),...Jw(e.map(t=>t.namespaces()))])}};function Yw(r){let e=r.split(":");return e.length<2?"":e.slice(0,-1).join(":")}function Zw(r){let e=r.split(":");return e[e.length-1]}function Jw(r){return[].concat(...r)}var _b=ot(au(),1);var sd="ERR_IPNS_EXPIRED_RECORD",_i="ERR_UNRECOGNIZED_VALIDITY";var rr="ERR_SIGNATURE_VERIFICATION";var cu="ERR_UNDEFINED_PARAMETER",id="ERR_INVALID_RECORD_DATA",ad="ERR_INVALID_VALUE",cd="ERR_INVALID_EMBEDDED_KEY";var ud="ERR_RECORD_TOO_LARGE";var xt;(function(r){let e;(function(o){o.EOL="EOL"})(e=r.ValidityType||(r.ValidityType={}));let t;(function(o){o[o.EOL=0]="EOL"})(t||(t={})),function(o){o.codec=()=>uo(t)}(e=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=xn((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=>wn(o,r.codec()),r.decode=o=>gn(o,r.codec())})(xt||(xt={}));var Xw=["string","number","bigint","symbol"],Qw=["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 fd(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let e=typeof r;if(Xw.includes(e))return e;if(e==="function")return"Function";if(Array.isArray(r))return"Array";if(eb(r))return"Buffer";let t=tb(r);return t||"Object"}function eb(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function tb(r){let e=Object.prototype.toString.call(r).slice(8,-1);if(Qw.includes(e))return e}var d=class{constructor(e,t,n){this.major=e,this.majorEncoded=e<<5,this.name=t,this.terminal=n}toString(){return`Type[${this.major}].${this.name}`}compare(e){return this.major<e.major?-1:this.major>e.major?1:0}};d.uint=new d(0,"uint",!0);d.negint=new d(1,"negint",!0);d.bytes=new d(2,"bytes",!0);d.string=new d(3,"string",!0);d.array=new d(4,"array",!1);d.map=new d(5,"map",!1);d.tag=new d(6,"tag",!1);d.float=new d(7,"float",!0);d.false=new d(7,"false",!0);d.true=new d(7,"true",!0);d.null=new d(7,"null",!0);d.undefined=new d(7,"undefined",!0);d.break=new d(7,"break",!0);var A=class{constructor(e,t,n){this.type=e,this.value=t,this.encodedLength=n,this.encodedBytes=void 0,this.byteValue=void 0}toString(){return`Token[${this.type}].${this.value}`}};var Hn=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",rb=new TextDecoder,nb=new TextEncoder;function Ti(r){return Hn&&globalThis.Buffer.isBuffer(r)}function Co(r){return r instanceof Uint8Array?Ti(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var md=Hn?(r,e,t)=>t-e>64?globalThis.Buffer.from(r.subarray(e,t)).toString("utf8"):dd(r,e,t):(r,e,t)=>t-e>64?rb.decode(r.subarray(e,t)):dd(r,e,t),Ni=Hn?r=>r.length>64?globalThis.Buffer.from(r):hd(r):r=>r.length>64?nb.encode(r):hd(r),Nt=r=>Uint8Array.from(r),Kn=Hn?(r,e,t)=>Ti(r)?new Uint8Array(r.subarray(e,t)):r.slice(e,t):(r,e,t)=>r.slice(e,t),yd=Hn?(r,e)=>(r=r.map(t=>t instanceof Uint8Array?t:globalThis.Buffer.from(t)),Co(globalThis.Buffer.concat(r,e))):(r,e)=>{let t=new Uint8Array(e),n=0;for(let o of r)n+o.length>t.length&&(o=o.subarray(0,t.length-n)),t.set(o,n),n+=o.length;return t},gd=Hn?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function wd(r,e){if(Ti(r)&&Ti(e))return r.compare(e);for(let t=0;t<r.length;t++)if(r[t]!==e[t])return r[t]<e[t]?-1:1;return 0}function hd(r){let e=[],t=0;for(let n=0;n<r.length;n++){let o=r.charCodeAt(n);o<128?e[t++]=o:o<2048?(e[t++]=o>>6|192,e[t++]=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),e[t++]=o>>18|240,e[t++]=o>>12&63|128,e[t++]=o>>6&63|128,e[t++]=o&63|128):(e[t++]=o>>12|224,e[t++]=o>>6&63|128,e[t++]=o&63|128)}return e}function dd(r,e,t){let n=[];for(;e<t;){let o=r[e],s=null,i=o>239?4:o>223?3:o>191?2:1;if(e+i<=t){let a,c,f,u;switch(i){case 1:o<128&&(s=o);break;case 2:a=r[e+1],(a&192)===128&&(u=(o&31)<<6|a&63,u>127&&(s=u));break;case 3:a=r[e+1],c=r[e+2],(a&192)===128&&(c&192)===128&&(u=(o&15)<<12|(a&63)<<6|c&63,u>2047&&(u<55296||u>57343)&&(s=u));break;case 4:a=r[e+1],c=r[e+2],f=r[e+3],(a&192)===128&&(c&192)===128&&(f&192)===128&&(u=(o&15)<<18|(a&63)<<12|(c&63)<<6|f&63,u>65535&&u<1114112&&(s=u))}}s===null?(s=65533,i=1):s>65535&&(s-=65536,n.push(s>>>10&1023|55296),s=56320|s&1023),n.push(s),e+=i}return uu(n)}var pd=4096;function uu(r){let e=r.length;if(e<=pd)return String.fromCharCode.apply(String,r);let t="",n=0;for(;n<e;)t+=String.fromCharCode.apply(String,r.slice(n,n+=pd));return t}var ob=256,Lo=class{constructor(e=ob){this.chunkSize=e,this.cursor=0,this.maxCursor=-1,this.chunks=[],this._initReuseChunk=null}reset(){this.cursor=0,this.maxCursor=-1,this.chunks.length&&(this.chunks=[]),this._initReuseChunk!==null&&(this.chunks.push(this._initReuseChunk),this.maxCursor=this._initReuseChunk.length-1)}push(e){let t=this.chunks[this.chunks.length-1];if(this.cursor+e.length<=this.maxCursor+1){let o=t.length-(this.maxCursor-this.cursor)-1;t.set(e,o)}else{if(t){let o=t.length-(this.maxCursor-this.cursor)-1;o<t.length&&(this.chunks[this.chunks.length-1]=t.subarray(0,o),this.maxCursor=this.cursor-1)}e.length<64&&e.length<this.chunkSize?(t=gd(this.chunkSize),this.chunks.push(t),this.maxCursor+=t.length,this._initReuseChunk===null&&(this._initReuseChunk=t),t.set(e,0)):(this.chunks.push(e),this.maxCursor+=e.length)}this.cursor+=e.length}toBytes(e=!1){let t;if(this.chunks.length===1){let n=this.chunks[0];e&&this.cursor>n.length/2?(t=this.cursor===n.length?n:n.subarray(0,this.cursor),this._initReuseChunk=null,this.chunks=[]):t=Kn(n,0,this.cursor)}else t=yd(this.chunks,this.cursor);return e&&this.reset(),t}};var F="CBOR decode error:",qn="CBOR encode error:",Uo=[];Uo[23]=1;Uo[24]=2;Uo[25]=3;Uo[26]=5;Uo[27]=9;function nr(r,e,t){if(r.length-e<t)throw new Error(`${F} not enough data for type`)}var Be=[24,256,65536,4294967296,BigInt("18446744073709551616")];function Qe(r,e,t){nr(r,e,1);let n=r[e];if(t.strict===!0&&n<Be[0])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);return n}function et(r,e,t){nr(r,e,2);let n=r[e]<<8|r[e+1];if(t.strict===!0&&n<Be[1])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);return n}function tt(r,e,t){nr(r,e,4);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3];if(t.strict===!0&&n<Be[2])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);return n}function rt(r,e,t){nr(r,e,8);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3],o=r[e+4]*16777216+(r[e+5]<<16)+(r[e+6]<<8)+r[e+7],s=(BigInt(n)<<BigInt(32))+BigInt(o);if(t.strict===!0&&s<Be[3])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);if(s<=Number.MAX_SAFE_INTEGER)return Number(s);if(t.allowBigInt===!0)return s;throw new Error(`${F} integers outside of the safe integer range are not supported`)}function bd(r,e,t,n){return new A(d.uint,Qe(r,e+1,n),2)}function xd(r,e,t,n){return new A(d.uint,et(r,e+1,n),3)}function Ed(r,e,t,n){return new A(d.uint,tt(r,e+1,n),5)}function vd(r,e,t,n){return new A(d.uint,rt(r,e+1,n),9)}function lt(r,e){return Ce(r,0,e.value)}function Ce(r,e,t){if(t<Be[0]){let n=Number(t);r.push([e|n])}else if(t<Be[1]){let n=Number(t);r.push([e|24,n])}else if(t<Be[2]){let n=Number(t);r.push([e|25,n>>>8,n&255])}else if(t<Be[3]){let n=Number(t);r.push([e|26,n>>>24&255,n>>>16&255,n>>>8&255,n&255])}else{let n=BigInt(t);if(n<Be[4]){let o=[e|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(`${F} encountered BigInt larger than allowable range`)}}lt.encodedSize=function(e){return Ce.encodedSize(e.value)};Ce.encodedSize=function(e){return e<Be[0]?1:e<Be[1]?2:e<Be[2]?3:e<Be[3]?5:9};lt.compareTokens=function(e,t){return e.value<t.value?-1:e.value>t.value?1:0};function Ad(r,e,t,n){return new A(d.negint,-1-Qe(r,e+1,n),2)}function Bd(r,e,t,n){return new A(d.negint,-1-et(r,e+1,n),3)}function kd(r,e,t,n){return new A(d.negint,-1-tt(r,e+1,n),5)}var lu=BigInt(-1),Sd=BigInt(1);function Id(r,e,t,n){let o=rt(r,e+1,n);if(typeof o!="bigint"){let s=-1-o;if(s>=Number.MIN_SAFE_INTEGER)return new A(d.negint,s,9)}if(n.allowBigInt!==!0)throw new Error(`${F} integers outside of the safe integer range are not supported`);return new A(d.negint,lu-BigInt(o),9)}function Ci(r,e){let t=e.value,n=typeof t=="bigint"?t*lu-Sd:t*-1-1;Ce(r,e.type.majorEncoded,n)}Ci.encodedSize=function(e){let t=e.value,n=typeof t=="bigint"?t*lu-Sd:t*-1-1;return n<Be[0]?1:n<Be[1]?2:n<Be[2]?3:n<Be[3]?5:9};Ci.compareTokens=function(e,t){return e.value<t.value?1:e.value>t.value?-1:0};function Do(r,e,t,n){nr(r,e,t+n);let o=Kn(r,e+t,e+t+n);return new A(d.bytes,o,t+n)}function Rd(r,e,t,n){return Do(r,e,1,t)}function _d(r,e,t,n){return Do(r,e,2,Qe(r,e+1,n))}function Td(r,e,t,n){return Do(r,e,3,et(r,e+1,n))}function Nd(r,e,t,n){return Do(r,e,5,tt(r,e+1,n))}function Cd(r,e,t,n){let o=rt(r,e+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer bytes lengths not supported`);return Do(r,e,9,o)}function Li(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===d.string?Ni(r.value):r.value),r.encodedBytes}function zn(r,e){let t=Li(e);Ce(r,e.type.majorEncoded,t.length),r.push(t)}zn.encodedSize=function(e){let t=Li(e);return Ce.encodedSize(t.length)+t.length};zn.compareTokens=function(e,t){return ib(Li(e),Li(t))};function ib(r,e){return r.length<e.length?-1:r.length>e.length?1:wd(r,e)}function Po(r,e,t,n,o){let s=t+n;nr(r,e,s);let i=new A(d.string,md(r,e+t,e+s),s);return o.retainStringBytes===!0&&(i.byteValue=Kn(r,e+t,e+s)),i}function Ld(r,e,t,n){return Po(r,e,1,t,n)}function Ud(r,e,t,n){return Po(r,e,2,Qe(r,e+1,n),n)}function Dd(r,e,t,n){return Po(r,e,3,et(r,e+1,n),n)}function Pd(r,e,t,n){return Po(r,e,5,tt(r,e+1,n),n)}function Od(r,e,t,n){let o=rt(r,e+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer string lengths not supported`);return Po(r,e,9,o,n)}var Fd=zn;function Gn(r,e,t,n){return new A(d.array,n,t)}function Vd(r,e,t,n){return Gn(r,e,1,t)}function Md(r,e,t,n){return Gn(r,e,2,Qe(r,e+1,n))}function $d(r,e,t,n){return Gn(r,e,3,et(r,e+1,n))}function Hd(r,e,t,n){return Gn(r,e,5,tt(r,e+1,n))}function Kd(r,e,t,n){let o=rt(r,e+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer array lengths not supported`);return Gn(r,e,9,o)}function qd(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${F} indefinite length items not allowed`);return Gn(r,e,1,1/0)}function Ui(r,e){Ce(r,d.array.majorEncoded,e.value)}Ui.compareTokens=lt.compareTokens;Ui.encodedSize=function(e){return Ce.encodedSize(e.value)};function jn(r,e,t,n){return new A(d.map,n,t)}function zd(r,e,t,n){return jn(r,e,1,t)}function Gd(r,e,t,n){return jn(r,e,2,Qe(r,e+1,n))}function jd(r,e,t,n){return jn(r,e,3,et(r,e+1,n))}function Wd(r,e,t,n){return jn(r,e,5,tt(r,e+1,n))}function Yd(r,e,t,n){let o=rt(r,e+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer map lengths not supported`);return jn(r,e,9,o)}function Zd(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${F} indefinite length items not allowed`);return jn(r,e,1,1/0)}function Di(r,e){Ce(r,d.map.majorEncoded,e.value)}Di.compareTokens=lt.compareTokens;Di.encodedSize=function(e){return Ce.encodedSize(e.value)};function Jd(r,e,t,n){return new A(d.tag,t,1)}function Xd(r,e,t,n){return new A(d.tag,Qe(r,e+1,n),2)}function Qd(r,e,t,n){return new A(d.tag,et(r,e+1,n),3)}function ep(r,e,t,n){return new A(d.tag,tt(r,e+1,n),5)}function tp(r,e,t,n){return new A(d.tag,rt(r,e+1,n),9)}function Pi(r,e){Ce(r,d.tag.majorEncoded,e.value)}Pi.compareTokens=lt.compareTokens;Pi.encodedSize=function(e){return Ce.encodedSize(e.value)};var hb=20,db=21,pb=22,mb=23;function rp(r,e,t,n){if(n.allowUndefined===!1)throw new Error(`${F} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new A(d.null,null,1):new A(d.undefined,void 0,1)}function np(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${F} indefinite length items not allowed`);return new A(d.break,void 0,1)}function fu(r,e,t){if(t){if(t.allowNaN===!1&&Number.isNaN(r))throw new Error(`${F} NaN values are not supported`);if(t.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${F} Infinity values are not supported`)}return new A(d.float,r,e)}function op(r,e,t,n){return fu(hu(r,e+1),3,n)}function sp(r,e,t,n){return fu(du(r,e+1),5,n)}function ip(r,e,t,n){return fu(lp(r,e+1),9,n)}function Oi(r,e,t){let n=e.value;if(n===!1)r.push([d.float.majorEncoded|hb]);else if(n===!0)r.push([d.float.majorEncoded|db]);else if(n===null)r.push([d.float.majorEncoded|pb]);else if(n===void 0)r.push([d.float.majorEncoded|mb]);else{let o,s=!1;(!t||t.float64!==!0)&&(cp(n),o=hu(Et,1),n===o||Number.isNaN(n)?(Et[0]=249,r.push(Et.slice(0,3)),s=!0):(up(n),o=du(Et,1),n===o&&(Et[0]=250,r.push(Et.slice(0,5)),s=!0))),s||(yb(n),o=lp(Et,1),Et[0]=251,r.push(Et.slice(0,9)))}}Oi.encodedSize=function(e,t){let n=e.value;if(n===!1||n===!0||n===null||n===void 0)return 1;if(!t||t.float64!==!0){cp(n);let o=hu(Et,1);if(n===o||Number.isNaN(n))return 3;if(up(n),o=du(Et,1),n===o)return 5}return 9};var ap=new ArrayBuffer(9),ft=new DataView(ap,1),Et=new Uint8Array(ap,0);function cp(r){if(r===1/0)ft.setUint16(0,31744,!1);else if(r===-1/0)ft.setUint16(0,64512,!1);else if(Number.isNaN(r))ft.setUint16(0,32256,!1);else{ft.setFloat32(0,r);let e=ft.getUint32(0),t=(e&2139095040)>>23,n=e&8388607;if(t===255)ft.setUint16(0,31744,!1);else if(t===0)ft.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let o=t-127;o<-24?ft.setUint16(0,0):o<-14?ft.setUint16(0,(e&2147483648)>>16|1<<24+o,!1):ft.setUint16(0,(e&2147483648)>>16|o+15<<10|n>>13,!1)}}}function hu(r,e){if(r.length-e<2)throw new Error(`${F} not enough data for float16`);let t=(r[e]<<8)+r[e+1];if(t===31744)return 1/0;if(t===64512)return-1/0;if(t===32256)return NaN;let n=t>>10&31,o=t&1023,s;return n===0?s=o*2**-24:n!==31?s=(o+1024)*2**(n-25):s=o===0?1/0:NaN,t&32768?-s:s}function up(r){ft.setFloat32(0,r,!1)}function du(r,e){if(r.length-e<4)throw new Error(`${F} not enough data for float32`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,4).getFloat32(0,!1)}function yb(r){ft.setFloat64(0,r,!1)}function lp(r,e){if(r.length-e<8)throw new Error(`${F} not enough data for float64`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,8).getFloat64(0,!1)}Oi.compareTokens=lt.compareTokens;function ee(r,e,t){throw new Error(`${F} encountered invalid minor (${t}) for major ${r[e]>>>5}`)}function Fi(r){return()=>{throw new Error(`${F} ${r}`)}}var R=[];for(let r=0;r<=23;r++)R[r]=ee;R[24]=bd;R[25]=xd;R[26]=Ed;R[27]=vd;R[28]=ee;R[29]=ee;R[30]=ee;R[31]=ee;for(let r=32;r<=55;r++)R[r]=ee;R[56]=Ad;R[57]=Bd;R[58]=kd;R[59]=Id;R[60]=ee;R[61]=ee;R[62]=ee;R[63]=ee;for(let r=64;r<=87;r++)R[r]=Rd;R[88]=_d;R[89]=Td;R[90]=Nd;R[91]=Cd;R[92]=ee;R[93]=ee;R[94]=ee;R[95]=Fi("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)R[r]=Ld;R[120]=Ud;R[121]=Dd;R[122]=Pd;R[123]=Od;R[124]=ee;R[125]=ee;R[126]=ee;R[127]=Fi("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)R[r]=Vd;R[152]=Md;R[153]=$d;R[154]=Hd;R[155]=Kd;R[156]=ee;R[157]=ee;R[158]=ee;R[159]=qd;for(let r=160;r<=183;r++)R[r]=zd;R[184]=Gd;R[185]=jd;R[186]=Wd;R[187]=Yd;R[188]=ee;R[189]=ee;R[190]=ee;R[191]=Zd;for(let r=192;r<=215;r++)R[r]=Jd;R[216]=Xd;R[217]=Qd;R[218]=ep;R[219]=tp;R[220]=ee;R[221]=ee;R[222]=ee;R[223]=ee;for(let r=224;r<=243;r++)R[r]=Fi("simple values are not supported");R[244]=ee;R[245]=ee;R[246]=ee;R[247]=rp;R[248]=Fi("simple values are not supported");R[249]=op;R[250]=sp;R[251]=ip;R[252]=ee;R[253]=ee;R[254]=ee;R[255]=np;var vt=[];for(let r=0;r<24;r++)vt[r]=new A(d.uint,r,1);for(let r=-1;r>=-24;r--)vt[31-r]=new A(d.negint,r,1);vt[64]=new A(d.bytes,new Uint8Array(0),1);vt[96]=new A(d.string,"",1);vt[128]=new A(d.array,0,1);vt[160]=new A(d.map,0,1);vt[244]=new A(d.false,!1,1);vt[245]=new A(d.true,!0,1);vt[246]=new A(d.null,null,1);function fp(r){switch(r.type){case d.false:return Nt([244]);case d.true:return Nt([245]);case d.null:return Nt([246]);case d.bytes:return r.value.length?void 0:Nt([64]);case d.string:return r.value===""?Nt([96]):void 0;case d.array:return r.value===0?Nt([128]):void 0;case d.map:return r.value===0?Nt([160]):void 0;case d.uint:return r.value<24?Nt([Number(r.value)]):void 0;case d.negint:if(r.value>=-24)return Nt([31-Number(r.value)])}}var wb={float64:!1,mapSorter:Eb,quickEncodeToken:fp};function bb(){let r=[];return r[d.uint.major]=lt,r[d.negint.major]=Ci,r[d.bytes.major]=zn,r[d.string.major]=Fd,r[d.array.major]=Ui,r[d.map.major]=Di,r[d.tag.major]=Pi,r[d.float.major]=Oi,r}var hp=bb(),pu=new Lo,Mi=class r{constructor(e,t){this.obj=e,this.parent=t}includes(e){let t=this;do if(t.obj===e)return!0;while(t=t.parent);return!1}static createCheck(e,t){if(e&&e.includes(t))throw new Error(`${qn} object contains circular references`);return new r(t,e)}},Rr={null:new A(d.null,null),undefined:new A(d.undefined,void 0),true:new A(d.true,!0),false:new A(d.false,!1),emptyArray:new A(d.array,0),emptyMap:new A(d.map,0)},_r={number(r,e,t,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new A(d.float,r):r>=0?new A(d.uint,r):new A(d.negint,r)},bigint(r,e,t,n){return r>=BigInt(0)?new A(d.uint,r):new A(d.negint,r)},Uint8Array(r,e,t,n){return new A(d.bytes,r)},string(r,e,t,n){return new A(d.string,r)},boolean(r,e,t,n){return r?Rr.true:Rr.false},null(r,e,t,n){return Rr.null},undefined(r,e,t,n){return Rr.undefined},ArrayBuffer(r,e,t,n){return new A(d.bytes,new Uint8Array(r))},DataView(r,e,t,n){return new A(d.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,e,t,n){if(!r.length)return t.addBreakTokens===!0?[Rr.emptyArray,new A(d.break)]:Rr.emptyArray;n=Mi.createCheck(n,r);let o=[],s=0;for(let i of r)o[s++]=Vi(i,t,n);return t.addBreakTokens?[new A(d.array,r.length),o,new A(d.break)]:[new A(d.array,r.length),o]},Object(r,e,t,n){let o=e!=="Object",s=o?r.keys():Object.keys(r),i=o?r.size:s.length;if(!i)return t.addBreakTokens===!0?[Rr.emptyMap,new A(d.break)]:Rr.emptyMap;n=Mi.createCheck(n,r);let a=[],c=0;for(let f of s)a[c++]=[Vi(f,t,n),Vi(o?r.get(f):r[f],t,n)];return xb(a,t),t.addBreakTokens?[new A(d.map,i),a,new A(d.break)]:[new A(d.map,i),a]}};_r.Map=_r.Object;_r.Buffer=_r.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))_r[`${r}Array`]=_r.DataView;function Vi(r,e={},t){let n=fd(r),o=e&&e.typeEncoders&&e.typeEncoders[n]||_r[n];if(typeof o=="function"){let i=o(r,n,e,t);if(i!=null)return i}let s=_r[n];if(!s)throw new Error(`${qn} unsupported type: ${n}`);return s(r,n,e,t)}function xb(r,e){e.mapSorter&&r.sort(e.mapSorter)}function Eb(r,e){let t=Array.isArray(r[0])?r[0][0]:r[0],n=Array.isArray(e[0])?e[0][0]:e[0];if(t.type!==n.type)return t.type.compare(n.type);let o=t.type.major,s=hp[o].compareTokens(t,n);return s===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),s}function dp(r,e,t,n){if(Array.isArray(e))for(let o of e)dp(r,o,t,n);else t[e.type.major](r,e,n)}function pp(r,e,t){let n=Vi(r,t);if(!Array.isArray(n)&&t.quickEncodeToken){let o=t.quickEncodeToken(n);if(o)return o;let s=e[n.type.major];if(s.encodedSize){let i=s.encodedSize(n,t),a=new Lo(i);if(s(a,n,t),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return Co(a.chunks[0])}}return pu.reset(),dp(pu,n,e,t),pu.toBytes(!0)}function Wn(r,e){return e=Object.assign({},wb,e),pp(r,hp,e)}var vb={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},$i=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t}pos(){return this._pos}done(){return this._pos>=this.data.length}next(){let e=this.data[this._pos],t=vt[e];if(t===void 0){let n=R[e];if(!n)throw new Error(`${F} no decoder for major type ${e>>>5} (byte 0x${e.toString(16).padStart(2,"0")})`);let o=e&31;t=n(this.data,this._pos,o,this.options)}return this._pos+=t.encodedLength,t}},Oo=Symbol.for("DONE"),Hi=Symbol.for("BREAK");function Ab(r,e,t){let n=[];for(let o=0;o<r.value;o++){let s=Yn(e,t);if(s===Hi){if(r.value===1/0)break;throw new Error(`${F} got unexpected break to lengthed array`)}if(s===Oo)throw new Error(`${F} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=s}return n}function Bb(r,e,t){let n=t.useMaps===!0,o=n?void 0:{},s=n?new Map:void 0;for(let i=0;i<r.value;i++){let a=Yn(e,t);if(a===Hi){if(r.value===1/0)break;throw new Error(`${F} got unexpected break to lengthed map`)}if(a===Oo)throw new Error(`${F} found map but not enough entries (got ${i} [no key], expected ${r.value})`);if(n!==!0&&typeof a!="string")throw new Error(`${F} non-string keys not supported (got ${typeof a})`);if(t.rejectDuplicateMapKeys===!0&&(n&&s.has(a)||!n&&a in o))throw new Error(`${F} found repeat map key "${a}"`);let c=Yn(e,t);if(c===Oo)throw new Error(`${F} 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 Yn(r,e){if(r.done())return Oo;let t=r.next();if(t.type===d.break)return Hi;if(t.type.terminal)return t.value;if(t.type===d.array)return Ab(t,r,e);if(t.type===d.map)return Bb(t,r,e);if(t.type===d.tag){if(e.tags&&typeof e.tags[t.value]=="function"){let n=Yn(r,e);return e.tags[t.value](n)}throw new Error(`${F} tag not supported (${t.value})`)}throw new Error("unsupported")}function mu(r,e){if(!(r instanceof Uint8Array))throw new Error(`${F} data to decode must be a Uint8Array`);e=Object.assign({},vb,e);let t=e.tokenizer||new $i(r,e),n=Yn(t,e);if(n===Oo)throw new Error(`${F} did not find any content to decode`);if(n===Hi)throw new Error(`${F} got unexpected break`);return[n,r.subarray(t.pos())]}function ht(r,e){let[t,n]=mu(r,e);if(n.length>0)throw new Error(`${F} too many terminals, data makes no sense`);return t}var nt=ot(pn(),1);var mp=Je("ipns:utils"),yp=Y("/ipns/"),kb=114,gp=async(r,e)=>{if(e==null||r==null){let n=new Error("one or more of the provided parameters are not defined");throw mp.error(n),(0,nt.default)(n,cu)}let t;if(e.pubKey!=null){try{t=su(e.pubKey)}catch(o){throw mp.error(o),o}if(!(await yf(e.pubKey)).equals(r))throw(0,nt.default)(new Error("Embedded public key did not match PeerID"),cd)}else r.publicKey!=null&&(t=su(r.publicKey));if(t!=null)return t;throw(0,nt.default)(new Error("no public key is available"),cu)};var wp=r=>{let e=Y("ipns-signature:");return Fe([e,r])},Yr=r=>"signatureV1"in r?xt.encode({value:Y(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:Y(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):xt.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data});function Ct(r){let e=xt.decode(r);if(e.sequence!=null&&(e.sequence=BigInt(e.sequence)),e.ttl!=null&&(e.ttl=BigInt(e.ttl)),e.signatureV2==null||e.data==null)throw(0,nt.default)(new Error("missing data or signatureV2"),rr);let t=bp(e.data),n=Sb(t.Value),o=z(t.Validity);if(e.value!=null&&e.signatureV1!=null)return Ib(e),{value:n,validityType:xt.ValidityType.EOL,validity:o,sequence:t.Sequence,ttl:t.TTL,pubKey:e.pubKey,signatureV1:e.signatureV1,signatureV2:e.signatureV2,data:e.data};if(e.signatureV2!=null)return{value:n,validityType:xt.ValidityType.EOL,validity:o,sequence:t.Sequence,ttl:t.TTL,pubKey:e.pubKey,signatureV2:e.signatureV2,data:e.data};throw new Error("invalid record: does not include signatureV1 or signatureV2")}var yu=r=>Fe([yp,r.toBytes()]),Zn=r=>fo(r.slice(yp.length));var bp=r=>{let e=ht(r);if(e.ValidityType===0)e.ValidityType=xt.ValidityType.EOL;else throw(0,nt.default)(new Error("Unknown validity type"),_i);return Number.isInteger(e.Sequence)&&(e.Sequence=BigInt(e.Sequence)),Number.isInteger(e.TTL)&&(e.TTL=BigInt(e.TTL)),e},Sb=r=>{if(r!=null){if(Qu(r))return`/ipns/${r.toCID().toString(fr)}`;if(r instanceof Uint8Array){let n=z(r);n.startsWith("/")&&(r=n)}let e=r.toString().trim();if(e.startsWith("/")&&e.length>1)return e;let t=oe.asCID(r);if(t!=null)return t.code===kb?`/ipns/${t.toString(fr)}`:`/ipfs/${t.toV1().toString()}`;try{return r instanceof Uint8Array?`/ipfs/${oe.decode(r).toV1().toString()}`:`/ipfs/${oe.parse(e).toV1().toString()}`}catch{}}throw(0,nt.default)(new Error("Value must be a valid content path starting with /"),ad)},Ib=r=>{if(r.data==null)throw(0,nt.default)(new Error("Record data is missing"),id);let e=bp(r.data);if(!ce(e.Value,r.value??new Uint8Array(0)))throw(0,nt.default)(new Error('Field "value" did not match between protobuf and CBOR'),rr);if(!ce(e.Validity,r.validity??new Uint8Array(0)))throw(0,nt.default)(new Error('Field "validity" did not match between protobuf and CBOR'),rr);if(e.ValidityType!==r.validityType)throw(0,nt.default)(new Error('Field "validityType" did not match between protobuf and CBOR'),rr);if(e.Sequence!==r.sequence)throw(0,nt.default)(new Error('Field "sequence" did not match between protobuf and CBOR'),rr);if(e.TTL!==r.ttl)throw(0,nt.default)(new Error('Field "ttl" did not match between protobuf and CBOR'),rr)};var rS=Je("ipns"),nS=st.code,oS=60*60*1e9,Tb="/ipns/",sS=Tb.length;var Fo=ot(pn(),1),xp=ot(au(),1);var qi=Je("ipns:validator"),Nb=1024*10,Cb=async(r,e)=>{let t=Ct(e),n;try{let o=wp(t.data);n=await r.verify(o,t.signatureV2)}catch{n=!1}if(!n)throw qi.error("record signature verification failed"),(0,Fo.default)(new Error("record signature verification failed"),rr);if(t.validityType===xt.ValidityType.EOL){if(xp.default.fromString(t.validity).toDate().getTime()<Date.now())throw qi.error("record has expired"),(0,Fo.default)(new Error("record has expired"),sd)}else if(t.validityType!=null)throw qi.error("unrecognized validity type"),(0,Fo.default)(new Error("unrecognized validity type"),_i);qi("ipns record for %s is valid",t.value)};async function Ep(r,e){if(e.byteLength>Nb)throw(0,Fo.default)(new Error("record too large"),ud);let t=Zn(r),n=Ct(e),o=await gp(t,n);await Cb(o,e)}async function*Vo(r){let e=/\r?\n/,t=new TextDecoder("utf8"),n="";for await(let o of r){typeof o=="string"&&(o=new TextEncoder().encode(o)),n+=t.decode(o,{stream:!0});let s=n.split(e);n=s.pop()??"";for(let i=0;i<s.length;i++)yield JSON.parse(s[i])}n+=t.decode(),n!==""&&(yield JSON.parse(n))}var wu=ot(Ap(),1);var $o=class extends Error{constructor(e){super(e),this.name="TimeoutError"}},bu=class extends Error{constructor(e){super(),this.name="AbortError",this.message=e}},Bp=r=>globalThis.DOMException===void 0?new bu(r):new DOMException(r),kp=r=>{let e=r.reason===void 0?Bp("This operation was aborted."):r.reason;return e instanceof Error?e:Bp(e)};function Ho(r,e){let{milliseconds:t,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout}}=e,i,c=new Promise((f,u)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(e.signal){let{signal:h}=e;h.aborted&&u(kp(h)),h.addEventListener("abort",()=>{u(kp(h))})}if(t===Number.POSITIVE_INFINITY){r.then(f,u);return}let l=new $o;i=s.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(h){u(h)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?f():o instanceof Error?u(o):(l.message=o??`Promise timed out after ${t} milliseconds`,u(l))},t),(async()=>{try{f(await r)}catch(h){u(h)}})()}).finally(()=>{c.clear()});return c.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},c}function xu(r,e,t){let n=0,o=r.length;for(;o>0;){let s=Math.trunc(o/2),i=n+s;t(r[i],e)<=0?(n=++i,o-=s+1):o=s}return n}var Ko=class{#e=[];enqueue(e,t){t={priority:0,...t};let n={priority:t.priority,run:e};if(this.size&&this.#e[this.size-1].priority>=t.priority){this.#e.push(n);return}let o=xu(this.#e,n,(s,i)=>i.priority-s.priority);this.#e.splice(o,0,n)}dequeue(){return this.#e.shift()?.run}filter(e){return this.#e.filter(t=>t.priority===e.priority).map(t=>t.run)}get size(){return this.#e.length}};var Lt=class extends wu.default{#e;#t;#r=0;#i;#c;#p=0;#o;#u;#n;#m;#s=0;#l;#a;#y;timeout;constructor(e){if(super(),e={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:Ko,...e},!(typeof e.intervalCap=="number"&&e.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${e.intervalCap?.toString()??""}\` (${typeof e.intervalCap})`);if(e.interval===void 0||!(Number.isFinite(e.interval)&&e.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${e.interval?.toString()??""}\` (${typeof e.interval})`);this.#e=e.carryoverConcurrencyCount,this.#t=e.intervalCap===Number.POSITIVE_INFINITY||e.interval===0,this.#i=e.intervalCap,this.#c=e.interval,this.#n=new e.queueClass,this.#m=e.queueClass,this.concurrency=e.concurrency,this.timeout=e.timeout,this.#y=e.throwOnTimeout===!0,this.#a=e.autoStart===!1}get#b(){return this.#t||this.#r<this.#i}get#x(){return this.#s<this.#l}#E(){this.#s--,this.#f(),this.emit("next")}#v(){this.#w(),this.#g(),this.#u=void 0}get#A(){let e=Date.now();if(this.#o===void 0){let t=this.#p-e;if(t<0)this.#r=this.#e?this.#s:0;else return this.#u===void 0&&(this.#u=setTimeout(()=>{this.#v()},t)),!0}return!1}#f(){if(this.#n.size===0)return this.#o&&clearInterval(this.#o),this.#o=void 0,this.emit("empty"),this.#s===0&&this.emit("idle"),!1;if(!this.#a){let e=!this.#A;if(this.#b&&this.#x){let t=this.#n.dequeue();return t?(this.emit("active"),t(),e&&this.#g(),!0):!1}}return!1}#g(){this.#t||this.#o!==void 0||(this.#o=setInterval(()=>{this.#w()},this.#c),this.#p=Date.now()+this.#c)}#w(){this.#r===0&&this.#s===0&&this.#o&&(clearInterval(this.#o),this.#o=void 0),this.#r=this.#e?this.#s:0,this.#h()}#h(){for(;this.#f(););}get concurrency(){return this.#l}set concurrency(e){if(!(typeof e=="number"&&e>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${e}\` (${typeof e})`);this.#l=e,this.#h()}async#B(e){return new Promise((t,n)=>{e.addEventListener("abort",()=>{n(e.reason)},{once:!0})})}async add(e,t={}){return t={timeout:this.timeout,throwOnTimeout:this.#y,...t},new Promise((n,o)=>{this.#n.enqueue(async()=>{this.#s++,this.#r++;try{t.signal?.throwIfAborted();let s=e({signal:t.signal});t.timeout&&(s=Ho(Promise.resolve(s),{milliseconds:t.timeout})),t.signal&&(s=Promise.race([s,this.#B(t.signal)]));let i=await s;n(i),this.emit("completed",i)}catch(s){if(s instanceof $o&&!t.throwOnTimeout){n();return}o(s),this.emit("error",s)}finally{this.#E()}},t),this.emit("add"),this.#f()})}async addAll(e,t){return Promise.all(e.map(async n=>this.add(n,t)))}start(){return this.#a?(this.#a=!1,this.#h(),this):this}pause(){this.#a=!0}clear(){this.#n=new this.#m}async onEmpty(){this.#n.size!==0&&await this.#d("empty")}async onSizeLessThan(e){this.#n.size<e||await this.#d("next",()=>this.#n.size<e)}async onIdle(){this.#s===0&&this.#n.size===0||await this.#d("idle")}async#d(e,t){return new Promise(n=>{let o=()=>{t&&!t()||(this.off(e,o),n())};this.on(e,o)})}get size(){return this.#n.size}sizeBy(e){return this.#n.filter(e).length}get pending(){return this.#s}get isPaused(){return this.#a}};function Db(r){return r[Symbol.asyncIterator]!=null}function Pb(r){if(Db(r))return(async()=>{for await(let e of r)return e})();for(let e of r)return e}var Gi=Pb;var Eu=Y("/ipns/");function Sp(r){return ce(r.subarray(0,Eu.byteLength),Eu)}var Ip=r=>fo(r.slice(Eu.length)),ji=class{client;constructor(e){this.client=e}async*findProviders(e,t={}){yield*yn(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async put(e,t,n){if(!Sp(e))return;let o=Ip(e),s=Ct(t);await this.client.putIPNS(o,s,n)}async get(e,t){if(!Sp(e))throw new N("Not found","ERR_NOT_FOUND");let n=Ip(e);try{let o=await this.client.getIPNS(n,t);return Yr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new N("Not found","ERR_NOT_FOUND"):o}}},Wi=class{client;constructor(e){this.client=e}async findPeer(e,t={}){let n=await Gi(this.client.getPeers(e,t));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new N("Not found","ERR_NOT_FOUND")}async*getClosestPeers(e,t={}){}};var ze=Je("delegated-routing-v1-http-api-client"),Rp={concurrentRequests:4,timeout:3e4},Yi=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;constructor(e,t={}){this.started=!1,this.shutDownController=new AbortController,Qr(1/0,this.shutDownController.signal),this.httpQueue=new Lt({concurrency:t.concurrentRequests??Rp.concurrentRequests}),this.clientUrl=e instanceof URL?e:new URL(e),this.timeout=t.timeout??Rp.timeout,this.contentRouting=new ji(this),this.peerRouting=new Wi(this)}get[eo](){return this.contentRouting}get[to](){return this.peerRouting}isStarted(){return this.started}start(){this.started=!0}stop(){this.httpQueue.clear(),this.shutDownController.abort(),this.started=!1}async*getProviders(e,t={}){ze("getProviders starts: %c",e);let n=Ur([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=Ie(),s=Ie();this.httpQueue.add(async()=>(o.resolve(),s.promise));try{await o.promise;let i=`${this.clientUrl}routing/v1/providers/${e.toString()}`,c=await fetch(i,{headers:{Accept:"application/x-ndjson"},signal:n});if(c.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new N("Routing response had no body","ERR_BAD_RESPONSE");if(c.headers.get("Content-Type")==="application/json"){let u=await c.json();for(let l of u.Providers){let h=this.#e(l);h!=null&&(yield h)}}else for await(let u of Vo(vs(c.body))){let l=this.#e(u);l!=null&&(yield l)}}catch(i){ze.error("getProviders errored:",i)}finally{n.clear(),s.resolve(),ze("getProviders finished: %c",e)}}async*getPeers(e,t={}){ze("getPeers starts: %c",e);let n=Ur([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=Ie(),s=Ie();this.httpQueue.add(async()=>(o.resolve(),s.promise));try{await o.promise;let i=`${this.clientUrl}routing/v1/peers/${e.toCID().toString()}`,c=await fetch(i,{headers:{Accept:"application/x-ndjson"},signal:n});if(c.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new N("Routing response had no body","ERR_BAD_RESPONSE");if(c.headers.get("Content-Type")==="application/json"){let u=await c.json();for(let l of u.Peers){let h=this.#e(l);h!=null&&(yield h)}}else for await(let u of Vo(vs(c.body))){let l=this.#e(u);l!=null&&(yield l)}}catch(i){ze.error("getPeers errored:",i)}finally{n.clear(),s.resolve(),ze("getPeers finished: %c",e)}}async getIPNS(e,t={}){ze("getIPNS starts: %c",e);let n=Ur([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=Ie(),s=Ie();this.httpQueue.add(async()=>(o.resolve(),s.promise));let i=`${this.clientUrl}routing/v1/ipns/${e.toCID().toString()}`;try{await o.promise;let c=await fetch(i,{headers:{Accept:"application/vnd.ipfs.ipns-record"},signal:n});if(ze("getIPNS GET %s %d",i,c.status),c.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new N("GET ipns response had no body","ERR_BAD_RESPONSE");let f=await c.arrayBuffer(),u=new Uint8Array(f,0,f.byteLength);return t.validate!==!1&&await Ep(yu(e),u),Ct(u)}catch(a){throw ze.error("getIPNS GET %s error:",i,a),a}finally{n.clear(),s.resolve(),ze("getIPNS finished: %c",e)}}async putIPNS(e,t,n={}){ze("putIPNS starts: %c",e);let o=Ur([this.shutDownController.signal,n.signal,AbortSignal.timeout(this.timeout)]),s=Ie(),i=Ie();this.httpQueue.add(async()=>(s.resolve(),i.promise));let a=`${this.clientUrl}routing/v1/ipns/${e.toCID().toString()}`;try{await s.promise;let c=Yr(t),u=await fetch(a,{method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:c,signal:o});if(ze("putIPNS PUT %s %d",a,u.status),u.status!==200)throw new N("PUT ipns response had status other than 200","ERR_BAD_RESPONSE")}catch(c){throw ze.error("putIPNS PUT %s error:",a,c.stack),c}finally{o.clear(),i.resolve(),ze("putIPNS finished: %c",e)}}#e(e){let t=[],n=e.Addrs?.map(Or)??[];return e.Protocols!=null&&t.push(...e.Protocols),e.Protocol!=null&&(t.push(e.Protocol),delete e.Protocol),{...e,Schema:"peer",ID:Bc(e.ID),Addrs:n,Protocols:t}}};function _p(r,e={}){return new Yi(new URL(r),e)}var Tp=Y("/ipns/");function Np(r){return ce(r.subarray(0,Tp.byteLength),Tp)}var vu=class{client;constructor(e){this.client=_p(e)}async provide(e,t){}async*findProviders(e,t){yield*yn(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs,protocols:n.Protocols}))}async put(e,t,n){if(!Np(e))return;let o=Zn(e),s=Ct(t);await this.client.putIPNS(o,s,n)}async get(e,t){if(!Np(e))throw new N("Not found","ERR_NOT_FOUND");let n=Zn(e);try{let o=await this.client.getIPNS(n,t);return Yr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new N("Not found","ERR_NOT_FOUND"):o}}async findPeer(e,t){let n=await Gi(this.client.getPeers(e,t));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new N("Not found","ERR_NOT_FOUND")}async*getClosestPeers(e,t){}};function Au(r){return new vu(new URL(r))}function Zi(r){let e=[or.A];return r==null?e:Array.isArray(r)?r.length===0?e:r:[r]}var Bu=60;function Ji(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(e=>({name:e.name,type:or[e.type]})),Answer:(r.Answer??r.answers??[]).map(e=>({name:e.name,type:or[e.type],TTL:e.TTL??e.ttl??Bu,data:e.data instanceof Uint8Array?z(e.data):e.data}))}}var Ob=4;function ku(r,e={}){let t=new Lt({concurrency:e.queryConcurrency??Ob});return async(n,o={})=>{let s=new URLSearchParams;s.set("name",n),Zi(o.types).forEach(a=>{s.append("type",a.toString())}),o.onProgress?.(new ne("dns:query",{detail:n}));let i=await t.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=Ji(await a.json());return o.onProgress?.(new ne("dns:response",{detail:c})),c},{signal:o.signal});if(i==null)throw new Error("No DNS response received");return i}}function Cp(){return[ku("https://cloudflare-dns.com/dns-query"),ku("https://dns.google/resolve")]}var Dp=ot(Up(),1);var Su=class{lru;constructor(e){this.lru=(0,Dp.default)(e)}get(e,t){let n=!0,o=[];for(let s of t){let i=this.getAnswers(e,s);if(i.length===0){n=!1;break}o.push(...i)}if(n)return Ji({answers:o})}getAnswers(e,t){let n=`${e.toLowerCase()}-${t}`,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:or[a.type]}));return s.length===0&&this.lru.remove(n),s}return[]}add(e,t){let n=`${e.toLowerCase()}-${t.type}`,o=this.lru.get(n)??[];o.push({expires:Date.now()+(t.TTL??Bu)*1e3,value:t}),this.lru.set(n,o)}remove(e,t){let n=`${e.toLowerCase()}-${t}`;this.lru.remove(n)}clear(){this.lru.clear()}};function Pp(r){return new Su(r)}var Fb=1e3,Xi=class{resolvers;cache;constructor(e){this.resolvers={},this.cache=Pp(e.cacheSize??Fb),Object.entries(e.resolvers??{}).forEach(([t,n])=>{Array.isArray(n)||(n=[n]),t.endsWith(".")||(t=`${t}.`),this.resolvers[t]=n}),this.resolvers["."]==null&&(this.resolvers["."]=Cp())}async query(e,t={}){let n=Zi(t.types),o=t.cached!==!1?this.cache.get(e,n):void 0;if(o!=null)return t.onProgress?.(new ne("dns:cache",{detail:o})),o;let s=`${e.split(".").pop()}.`,i=(this.resolvers[s]??this.resolvers["."]).sort(()=>Math.random()>.5?-1:1),a=[];for(let c of i){if(t.signal?.aborted===!0)break;try{let f=await c(e,{...t,types:n});for(let u of f.Answer)this.cache.add(e,u);return f}catch(f){a.push(f),t.onProgress?.(new ne("dns:error",{detail:f}))}}throw a.length===1?a[0]:new AggregateError(a,`DNS lookup of ${e} ${n} failed`)}};var or;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(or||(or={}));function Op(r={}){return new Xi(r)}var $p="/pin/",Fp="/pinned-block/",Iu=fr,Vp=1;function Mp(r){return r.version===0&&(r=r.toV1()),new Ne(`${$p}${r.toString(Iu)}`)}var Qi=class{datastore;blockstore;dagWalkers;constructor(e,t,n){this.datastore=e,this.blockstore=t,this.dagWalkers=n}async*add(e,t={}){let n=Mp(e);if(await this.datastore.has(n))throw new Error("Already pinned");let o=Math.round(t.depth??1/0);if(o<0)throw new Error("Depth must be greater than or equal to 0");let s=new Dr({concurrency:Vp});for await(let a of this.#e(e,s,{...t,depth:o}))await this.#t(a,c=>c.pinnedBy.find(f=>ce(f,e.bytes))!=null?!1:(c.pinCount++,c.pinnedBy.push(e.bytes),!0),t),yield a;let i={depth:o,metadata:t.metadata??{}};await this.datastore.put(n,Wn(i),t)}async*#e(e,t,n){if(n.depth===-1)return;let o=this.dagWalkers[e.code];if(o==null)throw new Error(`No dag walker found for cid codec ${e.code}`);let s=await this.blockstore.get(e,n);yield e;for await(let i of o.walk(s))yield*await t.add(async()=>this.#e(i,t,{...n,depth:n.depth-1}))}async#t(e,t,n){let o=new Ne(`${Fp}${Iu.encode(e.multihash.bytes)}`),s={pinCount:0,pinnedBy:[]};try{s=ht(await this.datastore.get(o,n))}catch(a){if(a.code!=="ERR_NOT_FOUND")throw a}if(t(s)){if(s.pinCount===0&&await this.datastore.has(o)){await this.datastore.delete(o);return}await this.datastore.put(o,Wn(s),n),n.onProgress?.(new ne("helia:pin:add",e))}}async*rm(e,t={}){let n=Mp(e),o=await this.datastore.get(n,t),s=ht(o);await this.datastore.delete(n,t);let i=new Dr({concurrency:Vp});for await(let a of this.#e(e,i,{...t,depth:s.depth}))await this.#t(a,c=>(c.pinCount--,c.pinnedBy=c.pinnedBy.filter(f=>ce(f,e.bytes)),!0),{...t,depth:s.depth}),yield a}async*ls(e={}){for await(let{key:t,value:n}of this.datastore.query({prefix:$p+(e.cid!=null?`${e.cid.toString(fr)}`:"")},e)){let o=oe.parse(t.toString().substring(5),fr),s=ht(n);yield{cid:o,...s}}}async isPinned(e,t={}){let n=new Ne(`${Fp}${Iu.encode(e.multihash.bytes)}`);return this.datastore.has(n,t)}};var ea=class{log;routers;constructor(e,t){this.log=e.logger.forComponent("helia:routing"),this.routers=t.routers??[]}async start(){await cr(...this.routers)}async stop(){await ur(...this.routers)}async*findProviders(e,t={}){if(this.routers.length===0)throw new N("No content routers available","ERR_NO_ROUTERS_AVAILABLE");for await(let n of pr(...Jn(this.routers,"findProviders").map(o=>o.findProviders(e,t))))n!=null&&(yield n)}async provide(e,t={}){if(this.routers.length===0)throw new N("No content routers available","ERR_NO_ROUTERS_AVAILABLE");await Promise.all(Jn(this.routers,"provide").map(async n=>{await n.provide(e,t)}))}async put(e,t,n){await Promise.all(Jn(this.routers,"put").map(async o=>{await o.put(e,t,n)}))}async get(e,t){return Promise.any(Jn(this.routers,"get").map(async n=>n.get(e,t)))}async findPeer(e,t){if(this.routers.length===0)throw new N("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");let n=this,o=pr(...Jn(this.routers,"findPeer").map(s=>async function*(){try{yield await s.findPeer(e,t)}catch(i){n.log.error(i)}}()));for await(let s of o)if(s!=null)return s;throw new N("Could not find peer in routing","ERR_NOT_FOUND")}async*getClosestPeers(e,t={}){if(this.routers.length===0)throw new N("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");for await(let n of pr(...Jn(this.routers,"getClosestPeers").map(o=>o.getClosestPeers(e,t))))n!=null&&(yield n)}};function Jn(r,e){return r.filter(t=>t[e]!=null)}var Tr={},Xn=r=>{r.addEventListener("message",e=>{Xn.dispatchEvent("message",r,e)}),r.port!=null&&r.port.addEventListener("message",e=>{Xn.dispatchEvent("message",r,e)})};Xn.addEventListener=(r,e)=>{Tr[r]==null&&(Tr[r]=[]),Tr[r].push(e)};Xn.removeEventListener=(r,e)=>{Tr[r]!=null&&(Tr[r]=Tr[r].filter(t=>t===e))};Xn.dispatchEvent=function(r,e,t){Tr[r]!=null&&Tr[r].forEach(n=>n(e,t))};var Ru=Xn;var _u="lock:worker:request-read",Tu="lock:worker:release-read",Nu="lock:master:grant-read",Cu="lock:worker:request-write",Lu="lock:worker:release-write",Uu="lock:master:grant-write";var Hp=(r=21)=>Math.random().toString().substring(2);var Kp=(r,e,t,n,o)=>(s,i)=>{if(i.data.type!==t)return;let a={type:i.data.type,name:i.data.name,identifier:i.data.identifier};r.dispatchEvent(new MessageEvent(e,{data:{name:a.name,handler:async()=>{s.postMessage({type:o,name:a.name,identifier:a.identifier}),await new Promise(c=>{let f=u=>{if(u==null||u.data==null)return;let l={type:u.data.type,name:u.data.name,identifier:u.data.identifier};l.type===n&&l.identifier===a.identifier&&(s.removeEventListener("message",f),c())};s.addEventListener("message",f)})}}}))},qp=(r,e,t,n)=>async()=>{let o=Hp();return globalThis.postMessage({type:e,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===t&&c.identifier===o&&(globalThis.removeEventListener("message",i),s(()=>{globalThis.postMessage({type:n,identifier:o,name:r})}))};globalThis.addEventListener("message",i)})},Vb={singleProcess:!1},zp=r=>{if(r=Object.assign({},Vb,r),!!globalThis.document||r.singleProcess){let t=new EventTarget;return Ru.addEventListener("message",Kp(t,"requestReadLock",_u,Tu,Nu)),Ru.addEventListener("message",Kp(t,"requestWriteLock",Cu,Lu,Uu)),t}return{isWorker:!0,readLock:t=>qp(t,_u,Nu,Tu),writeLock:t=>qp(t,Cu,Uu,Lu)}};var Zr={},Nr;async function Du(r,e){let t,n=new Promise(o=>{t=o});return r.add(async()=>Ho((async()=>{await new Promise(o=>{t(()=>{o()})})})(),{milliseconds:e.timeout})),n}var Mb=(r,e)=>{if(Nr.isWorker===!0)return{readLock:Nr.readLock(r,e),writeLock:Nr.writeLock(r,e)};let t=new Lt({concurrency:1}),n;return{async readLock(){if(n!=null)return Du(n,e);n=new Lt({concurrency:e.concurrency,autoStart:!1});let o=n,s=Du(n,e);return t.add(async()=>{o.start(),await o.onIdle().then(()=>{n===o&&(n=null)})}),s},async writeLock(){return n=null,Du(t,e)}}},$b={name:"lock",concurrency:1/0,timeout:846e5,singleProcess:!1};function Pu(r){let e=Object.assign({},$b,r);return Nr==null&&(Nr=zp(e),Nr.isWorker!==!0&&(Nr.addEventListener("requestReadLock",t=>{Zr[t.data.name]!=null&&Zr[t.data.name].readLock().then(async n=>t.data.handler().finally(()=>{n()}))}),Nr.addEventListener("requestWriteLock",async t=>{Zr[t.data.name]!=null&&Zr[t.data.name].writeLock().then(async n=>t.data.handler().finally(()=>{n()}))}))),Zr[e.name]==null&&(Zr[e.name]=Mb(e.name,e)),Zr[e.name]}var ta=class{lock;child;pins;started;constructor(e,t,n={}){this.child=e,this.pins=t,this.lock=Pu({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await cr(this.child),this.started=!0}async stop(){await ur(this.child),this.started=!1}unwrap(){return this.child}async put(e,t,n={}){let o=await this.lock.readLock();try{return await this.child.put(e,t,n)}finally{o()}}async*putMany(e,t={}){let n=await this.lock.readLock();try{yield*this.child.putMany(e,t)}finally{n()}}async get(e,t={}){let n=await this.lock.readLock();try{return await this.child.get(e,t)}finally{n()}}async*getMany(e,t={}){let n=await this.lock.readLock();try{yield*this.child.getMany(e,t)}finally{n()}}async delete(e,t={}){let n=await this.lock.writeLock();try{if(await this.pins.isPinned(e))throw new Error("CID was pinned");await this.child.delete(e,t)}finally{n()}}async*deleteMany(e,t={}){let n=await this.lock.writeLock();try{let o=this;yield*this.child.deleteMany(async function*(){for await(let s of e){if(await o.pins.isPinned(s))throw new Error("CID was pinned");yield s}}(),t)}finally{n()}}async has(e,t={}){let n=await this.lock.readLock();try{return await this.child.has(e,t)}finally{n()}}async*getAll(e={}){let t=await this.lock.readLock();try{yield*this.child.getAll(e)}finally{t()}}async createSession(e,t){let n=await this.lock.readLock();try{let o=await this.child.createSession(e,t);if(o==null)throw new N("Sessions not supported","ERR_UNSUPPORTED");return o}finally{n()}}};var jp=42;function Hb(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let e=oe.asCID(r);if(!e)return null;let t=new Uint8Array(e.bytes.byteLength+1);return t.set(e.bytes,1),[new A(d.tag,jp),new A(d.bytes,t)]}function Kb(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function qb(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 Gp={float64:!0,typeEncoders:{Object:Hb,undefined:Kb,number:qb}},a6={...Gp,typeEncoders:{...Gp.typeEncoders}};function zb(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return oe.decode(r.subarray(1))}var Ou={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Ou.tags[jp]=zb;var c6={...Ou,tags:Ou.tags.slice()};var Wp=113;var Yp=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(e){let t=this.inRecursive[this.inRecursive.length-1];t&&(t.type===d.array&&(t.elements++,t.elements!==1&&e.push([44])),t.type===d.map&&(t.elements++,t.elements!==1&&(t.elements%2===1?e.push([44]):e.push([58]))))}[d.uint.major](e,t){this.prefix(e);let n=String(t.value),o=[];for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);e.push(o)}[d.negint.major](e,t){this[d.uint.major](e,t)}[d.bytes.major](e,t){throw new Error(`${qn} unsupported type: Uint8Array`)}[d.string.major](e,t){this.prefix(e);let n=Ni(JSON.stringify(t.value));e.push(n.length>32?Co(n):n)}[d.array.major](e,t){this.prefix(e),this.inRecursive.push({type:d.array,elements:0}),e.push([91])}[d.map.major](e,t){this.prefix(e),this.inRecursive.push({type:d.map,elements:0}),e.push([123])}[d.tag.major](e,t){}[d.float.major](e,t){if(t.type.name==="break"){let i=this.inRecursive.pop();if(i){if(i.type===d.array)e.push([93]);else if(i.type===d.map)e.push([125]);else throw new Error("Unexpected recursive type; this should not happen!");return}throw new Error("Unexpected break; this should not happen!")}if(t.value===void 0)throw new Error(`${qn} unsupported type: undefined`);if(this.prefix(e),t.type.name==="true"){e.push([116,114,117,101]);return}else if(t.type.name==="false"){e.push([102,97,108,115,101]);return}else if(t.type.name==="null"){e.push([110,117,108,108]);return}let n=String(t.value),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)),e.push(o)}};var Jr=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t,this.modeStack=["value"],this.lastToken=""}pos(){return this._pos}done(){return this._pos>=this.data.length}ch(){return this.data[this._pos]}currentMode(){return this.modeStack[this.modeStack.length-1]}skipWhitespace(){let e=this.ch();for(;e===32||e===9||e===13||e===10;)e=this.data[++this._pos]}expect(e){if(this.data.length-this._pos<e.length)throw new Error(`${F} unexpected end of input at position ${this._pos}`);for(let t=0;t<e.length;t++)if(this.data[this._pos++]!==e[t])throw new Error(`${F} unexpected token at position ${this._pos}, expected to find '${String.fromCharCode(...e)}'`)}parseNumber(){let e=this._pos,t=!1,n=!1,o=a=>{for(;!this.done();){let c=this.ch();if(a.includes(c))this._pos++;else break}};if(this.ch()===45&&(t=!0,this._pos++),this.ch()===48)if(this._pos++,this.ch()===46)this._pos++,n=!0;else return new A(d.uint,0,this._pos-e);if(o([48,49,50,51,52,53,54,55,56,57]),t&&this._pos===e+1)throw new Error(`${F} unexpected token at position ${this._pos}`);if(!this.done()&&this.ch()===46){if(n)throw new Error(`${F} 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(e,this._pos)),i=parseFloat(s);return n?new A(d.float,i,this._pos-e):this.options.allowBigInt!==!0||Number.isSafeInteger(i)?new A(i>=0?d.uint:d.negint,i,this._pos-e):new A(i>=0?d.uint:d.negint,BigInt(s),this._pos-e)}parseString(){if(this.ch()!==34)throw new Error(`${F} 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 A(d.string,c,i)}}let e=this._pos,t=[],n=()=>{if(this._pos+4>=this.data.length)throw new Error(`${F} 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(`${F} 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(`${F} unexpected unicode sequence at position ${this._pos}`);let c,f,u,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],f=this.data[this._pos+2],(c&192)===128&&(f&192)===128&&(l=(s&15)<<12|(c&63)<<6|f&63,l>2047&&(l<55296||l>57343)&&(i=l));break;case 4:c=this.data[this._pos+1],f=this.data[this._pos+2],u=this.data[this._pos+3],(c&192)===128&&(f&192)===128&&(u&192)===128&&(l=(s&15)<<18|(c&63)<<12|(f&63)<<6|u&63,l>65535&&l<1114112&&(i=l))}i===null?(i=65533,a=1):i>65535&&(i-=65536,t.push(i>>>10&1023|55296),i=56320|i&1023),t.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(`${F} unexpected string termination at position ${this._pos}`);switch(i=this.ch(),this._pos++,i){case 34:case 39:case 92:case 47:t.push(i);break;case 98:t.push(8);break;case 116:t.push(9);break;case 110:t.push(10);break;case 102:t.push(12);break;case 114:t.push(13);break;case 117:t.push(n());break;default:throw new Error(`${F} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new A(d.string,uu(t),this._pos-e);default:if(s<32)throw new Error(`${F} invalid control character at position ${this._pos}`);s<128?(t.push(s),this._pos++):o()}}throw new Error(`${F} unexpected end of string at position ${this._pos}`)}parseValue(){switch(this.ch()){case 123:return this.modeStack.push("obj-start"),this._pos++,new A(d.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new A(d.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new A(d.null,null,4);case 102:return this.expect([102,97,108,115,101]),new A(d.false,!1,5);case 116:return this.expect([116,114,117,101]),new A(d.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(`${F} 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 A(d.break,void 0,1);if(this.ch()!==44)throw new Error(`${F} 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 A(d.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 A(d.break,void 0,1);if(this.ch()!==44)throw new Error(`${F} 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 A(d.break,void 0,1);let e=this.parseString();if(this.skipWhitespace(),this.ch()!==58)throw new Error(`${F} unexpected character at position ${this._pos}, was expecting key/value delimiter ':' but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("obj-value"),e}case"obj-value":return this.modeStack.pop(),this.modeStack.push("obj-key"),this.skipWhitespace(),this.parseValue();default:throw new Error(`${F} unexpected parse state at position ${this._pos}; this shouldn't happen`)}}};function ra(r,e){return e=Object.assign({tokenizer:new Jr(r,e)},e),ht(r,e)}var Wb={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Wb.tags[42]=oe.parse;var Jp=297;var k6=new TextDecoder;var S6=new TextEncoder;var Zb=new TextDecoder;function Fu(r,e){let t=0;for(let n=0;;n+=7){if(n>=64)throw new Error("protobuf: varint overflow");if(e>=r.length)throw new Error("protobuf: unexpected end of data");let o=r[e++];if(t+=n<28?(o&127)<<n:(o&127)*2**n,o<128)break}return[t,e]}function na(r,e){let t;[t,e]=Fu(r,e);let n=e+t;if(t<0||n<0)throw new Error("protobuf: invalid length");if(n>r.length)throw new Error("protobuf: unexpected end of data");return[r.subarray(e,n),n]}function Xp(r,e){let t;return[t,e]=Fu(r,e),[t&7,t>>3,e]}function Jb(r){let e={},t=r.length,n=0;for(;n<t;){let o,s;if([o,s,n]=Xp(r,n),s===1){if(e.Hash)throw new Error("protobuf: (PBLink) duplicate Hash section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Hash`);if(e.Name!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Name before Hash");if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Hash");[e.Hash,n]=na(r,n)}else if(s===2){if(e.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(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Name");let i;[i,n]=na(r,n),e.Name=Zb.decode(i)}else if(s===3){if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) duplicate Tsize section");if(o!==0)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Tsize`);[e.Tsize,n]=Fu(r,n)}else throw new Error(`protobuf: (PBLink) invalid fieldNumber, expected 1, 2 or 3, got ${s}`)}if(n>t)throw new Error("protobuf: (PBLink) unexpected end of data");return e}function Qp(r){let e=r.length,t=0,n,o=!1,s;for(;t<e;){let a,c;if([a,c,t]=Xp(r,t),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,t]=na(r,t),n&&(o=!0)}else if(c===2){if(o)throw new Error("protobuf: (PBNode) duplicate Links section");n||(n=[]);let f;[f,t]=na(r,t),n.push(Jb(f))}else throw new Error(`protobuf: (PBNode) invalid fieldNumber, expected 1 or 2, got ${c}`)}if(t>e)throw new Error("protobuf: (PBNode) unexpected end of data");let i={};return s&&(i.Data=s),i.Links=n||[],i}var R6=new TextEncoder,_6=2**32,T6=2**31;var L6=new TextEncoder;function e0(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var t0=112;function r0(r){let e=e0(r),t=Qp(e),n={};return t.Data&&(n.Data=t.Data),t.Links&&(n.Links=t.Links.map(o=>{let s={};try{s.Hash=oe.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 Qb={codec:t0,*walk(r){yield*r0(r).Links.map(t=>t.Hash)}},ex={codec:is,*walk(){}},n0=42,tx={codec:Wp,*walk(r){let e=[],t=[];t[n0]=n=>{if(n[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");let o=oe.decode(n.subarray(1));return e.push(o),o},ht(r,{tags:t}),yield*e}},Vu=class extends Jr{tokenBuffer;constructor(e,t){super(e,t),this.tokenBuffer=[]}done(){return this.tokenBuffer.length===0&&super.done()}_next(){return this.tokenBuffer.length>0?this.tokenBuffer.pop():super.next()}next(){let e=this._next();if(e.type===d.map){let t=this._next();if(t.type===d.string&&t.value==="/"){let n=this._next();if(n.type===d.string){if(this._next().type!==d.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new A(d.tag,42,0)}if(n.type===d.map){let o=this._next();if(o.type===d.string&&o.value==="bytes"){let s=this._next();if(s.type===d.string){for(let a=0;a<2;a++)if(this._next().type!==d.break)throw new Error("Invalid encoded Bytes form");let i=hr.decode(`m${s.value}`);return new A(d.bytes,i,s.value.length)}this.tokenBuffer.push(s)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(t)}return e}},rx={codec:Jp,*walk(r){let e=[],t=[];t[n0]=n=>{let o=oe.parse(n);return e.push(o),o},ra(r,{tags:t,tokenizer:new Vu(r,{tags:t,allowIndefinite:!0,allowUndefined:!0,allowNaN:!0,allowInfinity:!0,allowBigInt:!0,strict:!1,rejectDuplicateMapKeys:!1})}),yield*e}},nx={codec:wl,*walk(){}};function o0(r=[]){let e={};return[Qb,ex,tx,rx,nx,...r].forEach(t=>{e[t.codec]=t}),e}var Mu=new Ne("/version"),s0=1;async function i0(r){if(!await r.has(Mu)){await r.put(Mu,Y(`${s0}`));return}let e=await r.get(Mu),t=z(e);if(parseInt(t,10)!==s0)throw new Error("Unknown datastore version, a datastore migration may be required")}function a0(r=[]){let e={};return[Ee,$a,st,...r].forEach(t=>{e[t.code]=t}),e}var Ut=class{has(e,t){return Promise.reject(new Error(".has is not implemented"))}put(e,t,n){return Promise.reject(new Error(".put is not implemented"))}async*putMany(e,t){for await(let{cid:n,block:o}of e)await this.put(n,o,t),yield n}get(e,t){return Promise.reject(new Error(".get is not implemented"))}async*getMany(e,t){for await(let n of e)yield{cid:n,block:await this.get(n,t)}}delete(e,t){return Promise.reject(new Error(".delete is not implemented"))}async*deleteMany(e,t){for await(let n of e)await this.delete(n,t),yield n}async*getAll(e){throw new Error(".getAll is not implemented")}};var Xr={};xe(Xr,{abortedError:()=>cx,closeFailedError:()=>sx,deleteFailedError:()=>Hu,getFailedError:()=>ix,hasFailedError:()=>ax,notFoundError:()=>Cr,openFailedError:()=>ox,putFailedError:()=>$u});var sr=ot(pn(),1);function ox(r){return r=r??new Error("Open failed"),(0,sr.default)(r,"ERR_OPEN_FAILED")}function sx(r){return r=r??new Error("Close failed"),(0,sr.default)(r,"ERR_CLOSE_FAILED")}function $u(r){return r=r??new Error("Put failed"),(0,sr.default)(r,"ERR_PUT_FAILED")}function ix(r){return r=r??new Error("Get failed"),(0,sr.default)(r,"ERR_GET_FAILED")}function Hu(r){return r=r??new Error("Delete failed"),(0,sr.default)(r,"ERR_DELETE_FAILED")}function ax(r){return r=r??new Error("Has failed"),(0,sr.default)(r,"ERR_HAS_FAILED")}function Cr(r){return r=r??new Error("Not Found"),(0,sr.default)(r,"ERR_NOT_FOUND")}function cx(r){return r=r??new Error("Aborted"),(0,sr.default)(r,"ERR_ABORTED")}var c0=0,oa=class extends Ut{put(e){return e}get(e){if(e.code===c0)return e.multihash.digest;throw Cr()}has(e){return e.code===c0}delete(){}*getAll(){}};var ux=Je("blockstore:core:tiered"),qo=class extends Ut{stores;constructor(e){super(),this.stores=e.slice()}async put(e,t,n){try{return await Promise.all(this.stores.map(async o=>{await o.put(e,t,n)})),e}catch(o){throw $u(o)}}async get(e,t){for(let n of this.stores)try{let o=await n.get(e,t);if(o!=null)return o}catch(o){ux.error(o)}throw Cr()}async has(e,t){for(let n of this.stores)if(await n.has(e,t))return!0;return!1}async delete(e,t){try{await Promise.all(this.stores.map(async n=>{await n.delete(e,t)}))}catch(n){throw Hu(n)}}async*putMany(e,t={}){let n,o=this.stores.map(s=>{let i=Ot({objectMode:!0});return Mt(s.putMany(i,t)).catch(a=>{n=a}),i});try{for await(let s of e){if(n!=null)throw n;o.forEach(i=>i.push(s)),yield s.cid}}finally{o.forEach(s=>s.end())}}async*deleteMany(e,t={}){let n,o=this.stores.map(s=>{let i=Ot({objectMode:!0});return Mt(s.deleteMany(i,t)).catch(a=>{n=a}),i});try{for await(let s of e){if(n!=null)throw n;o.forEach(i=>i.push(s)),yield s}}finally{o.forEach(s=>s.end())}}async*getAll(e){let t=new Set;yield*it(pr(...this.stores.map(n=>n.getAll(e))),n=>{let o=n.cid.toString();return t.has(o)?!1:(t.add(o),!0)})}};function lx(r){return r[Symbol.asyncIterator]!=null}function u0(r){return r?.then!=null}function fx(r,e){if(lx(r))return async function*(){for await(let a of r){let c=e(a);u0(c)&&await c,yield a}}();let t=mn(r),{value:n,done:o}=t.next();if(o===!0)return function*(){}();if(typeof e(n)?.then=="function")return async function*(){yield n;for await(let a of t){let c=e(a);u0(c)&&await c,yield a}}();let i=e;return function*(){yield n;for(let a of t)i(a),yield a}()}var Ku=fx;var sa=class r{child;hashers;started;log;logger;components;constructor(e,t={}){this.log=e.logger.forComponent(`helia:networked-storage${t.root==null?"":`:${t.root}`}`),this.logger=e.logger,this.components=e,this.child=new qo([new oa,e.blockstore]),this.hashers=e.hashers??{},this.started=!1}isStarted(){return this.started}async start(){await cr(this.child,...this.components.blockBrokers),this.started=!0}async stop(){await ur(this.child,...this.components.blockBrokers),this.started=!1}unwrap(){return this.child}async put(e,t,n={}){return await this.child.has(e)?(n.onProgress?.(new ne("blocks:put:duplicate",e)),e):(n.onProgress?.(new ne("blocks:put:providers:notify",e)),await Promise.all(this.components.blockBrokers.map(async o=>o.announce?.(e,t,n))),n.onProgress?.(new ne("blocks:put:blockstore:put",e)),this.child.put(e,t,n))}async*putMany(e,t={}){let n=it(e,async({cid:s})=>{let i=await this.child.has(s);return i&&t.onProgress?.(new ne("blocks:put-many:duplicate",s)),!i}),o=Ku(n,async({cid:s,block:i})=>{t.onProgress?.(new ne("blocks:put-many:providers:notify",s)),await Promise.all(this.components.blockBrokers.map(async a=>a.announce?.(s,i,t)))});t.onProgress?.(new ne("blocks:put-many:blockstore:put-many")),yield*this.child.putMany(o,t)}async get(e,t={}){if(t.offline!==!0&&!await this.child.has(e)){t.onProgress?.(new ne("blocks:get:providers:get",e));let n=await l0(e,this.components.blockBrokers,this.hashers[e.multihash.code],{...t,log:this.log});return t.onProgress?.(new ne("blocks:get:blockstore:put",e)),await this.child.put(e,n,t),t.onProgress?.(new ne("blocks:get:providers:notify",e)),await Promise.all(this.components.blockBrokers.map(async o=>o.announce?.(e,n,t))),n}return t.onProgress?.(new ne("blocks:get:blockstore:get",e)),this.child.get(e,t)}async*getMany(e,t={}){t.onProgress?.(new ne("blocks:get-many:blockstore:get-many")),yield*this.child.getMany(Ku(e,async n=>{if(t.offline!==!0&&!await this.child.has(n)){t.onProgress?.(new ne("blocks:get-many:providers:get",n));let o=await l0(n,this.components.blockBrokers,this.hashers[n.multihash.code],{...t,log:this.log});t.onProgress?.(new ne("blocks:get-many:blockstore:put",n)),await this.child.put(n,o,t),t.onProgress?.(new ne("blocks:get-many:providers:notify",n)),await Promise.all(this.components.blockBrokers.map(async s=>s.announce?.(n,o,t)))}}))}async delete(e,t={}){t.onProgress?.(new ne("blocks:delete:blockstore:delete",e)),await this.child.delete(e,t)}async*deleteMany(e,t={}){t.onProgress?.(new ne("blocks:delete-many:blockstore:delete-many")),yield*this.child.deleteMany(async function*(){for await(let n of e)yield n}(),t)}async has(e,t={}){return this.child.has(e,t)}async*getAll(e={}){e.onProgress?.(new ne("blocks:get-all:blockstore:get-many")),yield*this.child.getAll(e)}async createSession(e,t){let n=await Promise.all(this.components.blockBrokers.map(async o=>o.createSession==null?o:o.createSession(e,t)));return new r({blockstore:this.child,blockBrokers:n,hashers:this.hashers,logger:this.logger},{root:e})}};function hx(r){return typeof r.retrieve=="function"}var dx=(r,e)=>{if(e==null)throw new N(`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 t=>{let n=await e.digest(t);if(!ce(n.digest,r.multihash.digest))throw new N("Hash of downloaded block did not match multihash from passed CID","ERR_HASH_MISMATCH")}};async function l0(r,e,t,n){let o=dx(r,t),s=new AbortController,i=Ur([s.signal,n.signal]),a=[];for(let c of e)hx(c)&&a.push(c);try{return await Promise.any(a.map(async c=>{try{let f=!1,u=await c.retrieve(r,{...n,signal:i,validateFn:async l=>{await o(l),f=!0}});return f||await o(u),u}catch(f){throw n.log.error("could not retrieve verified block for %c",r,f),f}}))}finally{i.clear()}}var ia=class{blockstore;datastore;pins;logger;routing;dagWalkers;hashers;dns;log;constructor(e){this.logger=e.logger??kf(),this.log=this.logger.forComponent("helia"),this.hashers=a0(e.hashers),this.dagWalkers=o0(e.dagWalkers),this.dns=e.dns??Op();let t={blockstore:e.blockstore,datastore:e.datastore,hashers:this.hashers,dagWalkers:this.dagWalkers,logger:this.logger,blockBrokers:[],dns:this.dns,...e.components??{}};this.routing=t.routing=new ea(t,{routers:(e.routers??[]).flatMap(o=>{let s=[o];return o[eo]!=null&&s.push(o[eo]),o[to]!=null&&s.push(o[to]),s})});let n=new sa(t);this.pins=new Qi(e.datastore,n,this.dagWalkers),this.blockstore=new ta(n,this.pins,{holdGcLock:e.holdGcLock??!0}),this.datastore=e.datastore,t.blockBrokers=e.blockBrokers.map(o=>o(t))}async start(){await i0(this.datastore),await cr(this.blockstore,this.datastore,this.routing)}async stop(){await ur(this.blockstore,this.datastore,this.routing)}async gc(e={}){let t=await this.blockstore.lock.writeLock();try{let n=this,o=this.blockstore.unwrap();this.log("gc start"),await Mt(o.deleteMany(async function*(){for await(let{cid:s}of o.getAll())try{if(await n.pins.isPinned(s,e))continue;yield s,e.onProgress?.(new ne("helia:gc:deleted",s))}catch(i){n.log.error("Error during gc",i),e.onProgress?.(new ne("helia:gc:error",i))}}()))}finally{t()}this.log("gc finished")}};var zo=class extends Ut{data;constructor(){super(),this.data=new Map}put(e,t){return this.data.set(Re.encode(e.multihash.bytes),t),e}get(e){let t=this.data.get(Re.encode(e.multihash.bytes));if(t==null)throw Cr();return t}has(e){return this.data.has(Re.encode(e.multihash.bytes))}async delete(e){this.data.delete(Re.encode(e.multihash.bytes))}async*getAll(){for(let[e,t]of this.data.entries())yield{cid:oe.createV1(is,Bt(Re.decode(e))),block:t}}};var H4={...Xr};var f0=ot(pn(),1);function aa(r){return r=r??new Error("Not Found"),(0,f0.default)(r,"ERR_NOT_FOUND")}var h0="SHARDING";function mx(r){return r[Symbol.asyncIterator]!=null}function yx(r,e){return mx(r)?async function*(){yield*(await kc(r)).sort(e)}():function*(){yield*kc(r).sort(e)}()}var ca=yx;var ir=class{put(e,t,n){return Promise.reject(new Error(".put is not implemented"))}get(e,t){return Promise.reject(new Error(".get is not implemented"))}has(e,t){return Promise.reject(new Error(".has is not implemented"))}delete(e,t){return Promise.reject(new Error(".delete is not implemented"))}async*putMany(e,t={}){for await(let{key:n,value:o}of e)await this.put(n,o,t),yield n}async*getMany(e,t={}){for await(let n of e)yield{key:n,value:await this.get(n,t)}}async*deleteMany(e,t={}){for await(let n of e)await this.delete(n,t),yield n}batch(){let e=[],t=[];return{put(n,o){e.push({key:n,value:o})},delete(n){t.push(n)},commit:async n=>{await Mt(this.putMany(e,n)),e=[],await Mt(this.deleteMany(t,n)),t=[]}}}async*_all(e,t){throw new Error("._all is not implemented")}async*_allKeys(e,t){throw new Error("._allKeys is not implemented")}query(e,t){let n=this._all(e,t);if(e.prefix!=null){let o=e.prefix;n=it(n,s=>s.key.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,s)=>it(o,s),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,s)=>ca(o,s),n)),e.offset!=null){let o=0,s=e.offset;n=it(n,()=>o++>=s)}return e.limit!=null&&(n=gs(n,e.limit)),n}queryKeys(e,t){let n=this._allKeys(e,t);if(e.prefix!=null){let o=e.prefix;n=it(n,s=>s.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,s)=>it(o,s),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,s)=>ca(o,s),n)),e.offset!=null){let o=e.offset,s=0;n=it(n,()=>s++>=o)}return e.limit!=null&&(n=gs(n,e.limit)),n}};var jo=class extends ir{data;constructor(){super(),this.data=new Map}put(e,t){return this.data.set(e.toString(),t),e}get(e){let t=this.data.get(e.toString());if(t==null)throw aa();return t}has(e){return this.data.has(e.toString())}delete(e){this.data.delete(e.toString())}*_all(){for(let[e,t]of this.data.entries())yield{key:new Ne(e),value:t}}*_allKeys(){for(let e of this.data.keys())yield new Ne(e)}};var yR=new Ne(h0);var RR=Je("datastore:core:tiered");async function bx(r={}){let e=r.datastore??new jo,t=r.blockstore??new zo,n=new ia({...r,datastore:e,blockstore:t,blockBrokers:r.blockBrokers??[Sc()],routers:r.routers??[Au("https://delegated-ipfs.dev")]});return r.start!==!1&&await n.start(),n}return I0(xx);})();
7
+ `)}`:`${t} :`}};ch=Br;D.Constructed=ch;Br.NAME="CONSTRUCTED";var js=class extends Pe{fromBER(e,t,n){return t}toBER(e){return wt}};js.override="EndOfContentValueBlock";var uh,Ws=class extends Te{constructor(e={}){super(e,js),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};uh=Ws;D.EndOfContent=uh;Ws.NAME=Eo;var lh,kr=class extends Te{constructor(e={}){super(e,Pe),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(e,t,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,t+n>e.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):t+n}toBER(e,t){let n=new ArrayBuffer(2);if(!e){let o=new Uint8Array(n);o[0]=5,o[1]=0}return t&&t.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};lh=kr;D.Null=lh;kr.NAME="NULL";var Ys=class extends er(Pe){constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=Z.BufferSourceConverter.toUint8Array(t.valueHex):this.valueHexView=new Uint8Array(1),e&&(this.value=e)}get value(){for(let e of this.valueHexView)if(e>0)return!0;return!1}set value(e){this.valueHexView[0]=e?255:0}fromBER(e,t,n){let o=Z.BufferSourceConverter.toUint8Array(e);return Qt(this,o,t,n)?(this.valueHexView=o.subarray(t,t+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,Hc.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Ys.NAME="BooleanValueBlock";var fh,Zs=class extends Te{constructor(e={}){super(e,Ys),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};fh=Zs;D.Boolean=fh;Zs.NAME="BOOLEAN";var Js=class extends er(_t){constructor({isConstructed:e=!1,...t}={}){super(t),this.isConstructed=e}fromBER(e,t,n){let o=0;if(this.isConstructed){if(this.isHexOnly=!1,o=_t.prototype.fromBER.call(this,e,t,n),o===-1)return o;for(let s=0;s<this.value.length;s++){let i=this.value[s].constructor.NAME;if(i===Eo){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==oh)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,o=super.fromBER(e,t,n),this.blockLength=n;return o}toBER(e,t){return this.isConstructed?_t.prototype.toBER.call(this,e,t):e?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Js.NAME="OctetStringValueBlock";var hh,Jt=class r extends Te{constructor({idBlock:e={},lenBlock:t={},...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,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},Js),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(e,t,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),t;if(!this.valueBlock.isConstructed){let s=(e instanceof ArrayBuffer?new Uint8Array(e):e).subarray(t,t+n);try{if(s.byteLength){let i=ki(s,0,s.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(e,t,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?Br.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${Z.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let e=[];for(let t of this.valueBlock.value)t instanceof r&&e.push(t.valueBlock.valueHexView);return Z.BufferSourceConverter.concat(e)}};hh=Jt;D.OctetString=hh;Jt.NAME=oh;var Xs=class extends er(_t){constructor({unusedBits:e=0,isConstructed:t=!1,...n}={}){super(n),this.unusedBits=e,this.isConstructed=t,this.blockLength=this.valueHexView.byteLength}fromBER(e,t,n){if(!n)return t;let o=-1;if(this.isConstructed){if(o=_t.prototype.fromBER.call(this,e,t,n),o===-1)return o;for(let a of this.value){let c=a.constructor.NAME;if(c===Eo){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==sh)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return o}let s=Z.BufferSourceConverter.toUint8Array(e);if(!Qt(this,s,t,n))return-1;let i=s.subarray(t,t+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=ki(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,t+n}toBER(e,t){if(this.isConstructed)return _t.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return wt;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}}};Xs.NAME="BitStringValueBlock";var dh,Fn=class extends Te{constructor({idBlock:e={},lenBlock:t={},...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,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},Xs),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(e,t,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(e,t,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Br.prototype.onAsciiEncoding.call(this);{let e=[],t=this.valueBlock.valueHexView;for(let o of t)e.push(o.toString(2).padStart(8,"0"));let n=e.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};dh=Fn;D.BitString=dh;Fn.NAME=sh;var ph;function bw(r,e){let t=new Uint8Array([0]),n=new Uint8Array(r),o=new Uint8Array(e),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,f=0,u=c<i?i:c,l=0;for(let h=u;h>=0;h--,l++){switch(!0){case l<a.length:f=s[i-l]+a[c-l]+t[0];break;default:f=s[i-l]+t[0]}switch(t[0]=f/10,!0){case l>=s.length:s=Ms(new Uint8Array([f%10]),s);break;default:s[i-l]=f%10}}return t[0]>0&&(s=Ms(t,s)),s}function nh(r){if(r>=bo.length)for(let e=bo.length;e<=r;e++){let t=new Uint8Array([0]),n=bo[e-1].slice(0);for(let o=n.length-1;o>=0;o--){let s=new Uint8Array([(n[o]<<1)+t[0]]);t[0]=s[0]/10,n[o]=s[0]%10}t[0]>0&&(n=Ms(t,n)),bo.push(n)}return bo[r]}function xw(r,e){let t=0,n=new Uint8Array(r),o=new Uint8Array(e),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,f,u=0;for(let l=c;l>=0;l--,u++)switch(f=s[i-u]-a[c-u]-t,!0){case f<0:t=1,s[i-u]=f+10;break;default:t=0,s[i-u]=f}if(t>0)for(let l=i-c+1;l>=0;l--,u++)if(f=s[i-u]-t,f<0)t=1,s[i-u]=f+10;else{t=0,s[i-u]=f;break}return s.slice()}var vo=class extends er(Pe){constructor({value:e,...t}={}){super(t),this._valueDec=0,t.valueHex&&this.setValueHex(),e!==void 0&&(this.valueDec=e)}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=Hc.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(eh(e))}get valueDec(){return this._valueDec}fromDER(e,t,n,o=0){let s=this.fromBER(e,t,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(e=!1){let t=this.valueHexView;switch(!0){case(t[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(t,1),this.valueHexView=n}break;case(t[0]===0&&(t[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(e)}fromBER(e,t,n){let o=super.fromBER(e,t,n);return o===-1||this.setValueHex(),o}toBER(e){return e?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let e=this.valueHexView.length*8-1,t=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 f=0;f<8;f++){if((o&1)===1)switch(n){case e:t=xw(nh(n),t),i="-";break;default:t=bw(t,nh(n))}n++,o>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(i+=rh.charAt(t[c]));return a===!1&&(i+=rh.charAt(0)),i}};ph=vo;vo.NAME="IntegerValueBlock";Object.defineProperty(ph.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var mh,we=class r extends Te{constructor(e={}){super(e,vo),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return $s(),BigInt(this.valueBlock.toString())}static fromBigInt(e){$s();let t=BigInt(e),n=new xo,o=t.toString(16).replace(/^-/,""),s=new Uint8Array(Z.Convert.FromHex(o));if(t<0){let a=new Uint8Array(s.length+(s[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${Z.Convert.ToHex(a)}`)+t,u=Z.BufferSourceConverter.toUint8Array(Z.Convert.FromHex(f.toString(16)));u[0]|=128,n.write(u)}else s[0]&128&&n.write(new Uint8Array([0])),n.write(s);return new r({valueHex:n.final()})}convertToDER(){let e=new r({valueHex:this.valueBlock.valueHexView});return e.valueBlock.toDER(),e}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()}`}};mh=we;D.Integer=mh;we.NAME="INTEGER";var yh,Qs=class extends we{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};yh=Qs;D.Enumerated=yh;Qs.NAME="ENUMERATED";var Ao=class extends er(Pe){constructor({valueDec:e=-1,isFirstSid:t=!1,...n}={}){super(n),this.valueDec=e,this.isFirstSid=t}fromBER(e,t,n){if(!n)return t;let o=Z.BufferSourceConverter.toUint8Array(e);if(!Qt(this,o,t,n))return-1;let s=o.subarray(t,t+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=jr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){$s();let t=BigInt(e).toString(2);for(;t.length%7;)t="0"+t;let n=new Uint8Array(t.length/7);for(let o=0;o<n.length;o++)n[o]=parseInt(t.slice(o*7,o*7+7),2)+(o+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(e){if(this.isHexOnly){if(e)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 t=Ar(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",wt;let n=new Uint8Array(t.byteLength);if(!e){let o=new Uint8Array(t),s=t.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n}toString(){let e="";if(this.isHexOnly)e=Z.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let t=this.valueDec;this.valueDec<=39?e="0.":this.valueDec<=79?(e="1.",t-=40):(e="2.",t-=80),e+=t.toString()}else e=this.valueDec.toString();return e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};Ao.NAME="sidBlock";var ei=class extends Pe{constructor({value:e=Vn,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let s=new Ao;if(o=s.fromBER(e,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(e){let t=[];for(let n=0;n<this.value.length;n++){let o=this.value[n].toBER(e);if(o.byteLength===0)return this.error=this.value[n].error,wt;t.push(o)}return Kc(t)}fromString(e){this.value=[];let t=0,n=0,o="",s=!1;do if(n=e.indexOf(".",t),n===-1?o=e.substring(t):o=e.substring(t,n),t=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 Ao;if(o>Number.MAX_SAFE_INTEGER){$s();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 e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let o=this.value[n].toString();n!==0&&(e=`${e}.`),t?(o=`{${o}}`,this.value[n].isFirstSid?e=`2.{${o} - 80}`:e+=o):e+=o}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};ei.NAME="ObjectIdentifierValueBlock";var gh,gt=class extends Te{constructor(e={}){super(e,ei),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};gh=gt;D.ObjectIdentifier=gh;gt.NAME="OBJECT IDENTIFIER";var Bo=class extends er(Zt){constructor({valueDec:e=0,...t}={}){super(t),this.valueDec=e}fromBER(e,t,n){if(n===0)return t;let o=Z.BufferSourceConverter.toUint8Array(e);if(!Qt(this,o,t,n))return-1;let s=o.subarray(t,t+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=jr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}toBER(e){if(this.isHexOnly){if(e)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 t=Ar(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",wt;let n=new Uint8Array(t.byteLength);if(!e){let o=new Uint8Array(t),s=t.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n.buffer}toString(){let e="";return this.isHexOnly?e=Z.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Bo.NAME="relativeSidBlock";var ti=class extends Pe{constructor({value:e=Vn,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let s=new Bo;if(o=s.fromBER(e,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(e,t){let n=[];for(let o=0;o<this.value.length;o++){let s=this.value[o].toBER(e);if(s.byteLength===0)return this.error=this.value[o].error,wt;n.push(s)}return Kc(n)}fromString(e){this.value=[];let t=0,n=0,o="";do{n=e.indexOf(".",t),n===-1?o=e.substring(t):o=e.substring(t,n),t=n+1;let s=new Bo;if(s.valueDec=parseInt(o,10),isNaN(s.valueDec))return!0;this.value.push(s)}while(n!==-1);return!0}toString(){let e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let o=this.value[n].toString();n!==0&&(e=`${e}.`),t&&(o=`{${o}}`),e+=o}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};ti.NAME="RelativeObjectIdentifierValueBlock";var wh,ri=class extends Te{constructor(e={}){super(e,ti),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};wh=ri;D.RelativeObjectIdentifier=wh;ri.NAME="RelativeObjectIdentifier";var bh,Ae=class extends Br{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};bh=Ae;D.Sequence=bh;Ae.NAME="SEQUENCE";var xh,ni=class extends Br{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};xh=ni;D.Set=xh;ni.NAME="SET";var oi=class extends er(Pe){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=Vn}toJSON(){return{...super.toJSON(),value:this.value}}};oi.NAME="StringValueBlock";var si=class extends oi{};si.NAME="SimpleStringValueBlock";var $e=class extends qs{constructor({...e}={}){super(e,si)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,Z.BufferSourceConverter.toUint8Array(e))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t);for(let o=0;o<t;o++)n[o]=e.charCodeAt(o);this.valueBlock.value=e}};$e.NAME="SIMPLE STRING";var ii=class extends $e{fromBuffer(e){this.valueBlock.valueHexView=Z.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=Z.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=Z.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(Z.Convert.FromUtf8String(e)),this.valueBlock.value=e}};ii.NAME="Utf8StringValueBlock";var Eh,Xt=class extends ii{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Eh=Xt;D.Utf8String=Eh;Xt.NAME="UTF8String";var ai=class extends $e{fromBuffer(e){this.valueBlock.value=Z.Convert.ToUtf16String(e),this.valueBlock.valueHexView=Z.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(Z.Convert.FromUtf16String(e))}};ai.NAME="BmpStringValueBlock";var vh,ci=class extends ai{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};vh=ci;D.BmpString=vh;ci.NAME="BMPString";var ui=class extends $e{fromBuffer(e){let t=ArrayBuffer.isView(e)?e.slice().buffer:e.slice(0),n=new Uint8Array(t);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(t))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t*4);for(let o=0;o<t;o++){let s=Ar(e.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=e}};ui.NAME="UniversalStringValueBlock";var Ah,li=class extends ui{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Ah=li;D.UniversalString=Ah;li.NAME="UniversalString";var Bh,fi=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Bh=fi;D.NumericString=Bh;fi.NAME="NumericString";var kh,hi=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};kh=hi;D.PrintableString=kh;hi.NAME="PrintableString";var Sh,di=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Sh=di;D.TeletexString=Sh;di.NAME="TeletexString";var Ih,pi=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Ih=pi;D.VideotexString=Ih;pi.NAME="VideotexString";var Rh,mi=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Rh=mi;D.IA5String=Rh;mi.NAME="IA5String";var _h,yi=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};_h=yi;D.GraphicString=_h;yi.NAME="GraphicString";var Th,ko=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Th=ko;D.VisibleString=Th;ko.NAME="VisibleString";var Nh,gi=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Nh=gi;D.GeneralString=Nh;gi.NAME="GeneralString";var Ch,wi=class extends $e{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Ch=wi;D.CharacterString=Ch;wi.NAME="CharacterString";var Lh,So=class extends ko{constructor({value:e,valueDate:t,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,e){this.fromString(e),this.valueBlock.valueHexView=new Uint8Array(e.length);for(let o=0;o<e.length;o++)this.valueBlock.valueHexView[o]=e.charCodeAt(o)}t&&(this.fromDate(t),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(e){this.fromString(String.fromCharCode.apply(null,Z.BufferSourceConverter.toUint8Array(e)))}toBuffer(){let e=this.toString(),t=new ArrayBuffer(e.length),n=new Uint8Array(t);for(let o=0;o<e.length;o++)n[o]=e.charCodeAt(o);return t}fromDate(e){this.year=e.getUTCFullYear(),this.month=e.getUTCMonth()+1,this.day=e.getUTCDate(),this.hour=e.getUTCHours(),this.minute=e.getUTCMinutes(),this.second=e.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(e){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(e);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(e="iso"){if(e==="iso"){let t=new Array(7);return t[0]=qe(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=qe(this.month,2),t[2]=qe(this.day,2),t[3]=qe(this.hour,2),t[4]=qe(this.minute,2),t[5]=qe(this.second,2),t[6]="Z",t.join("")}return super.toString(e)}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}}};Lh=So;D.UTCTime=Lh;So.NAME="UTCTime";var Uh,bi=class extends So{constructor(e={}){var t;super(e),(t=this.millisecond)!==null&&t!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(e){super.fromDate(e),this.millisecond=e.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(e){let t=!1,n="",o="",s=0,i,a=0,c=0;if(e[e.length-1]==="Z")n=e.substring(0,e.length-1),t=!0;else{let l=new Number(e[e.length-1]);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");n=e}if(t){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,h=n.indexOf("+"),g="";if(h===-1&&(h=n.indexOf("-"),l=-1),h!==-1){if(g=n.substring(h+1),n=n.substring(0,h),g.length!==2&&g.length!==4)throw new Error("Wrong input string for conversion");let y=parseInt(g.substring(0,2),10);if(isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*y,g.length===4){if(y=parseInt(g.substring(2,4),10),isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");c=l*y}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let l=new Number(`0${n.substring(f)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");s=l.valueOf(),o=n.substring(0,f)}else o=n;switch(!0){case o.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-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,f!==-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,f!==-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,f!==-1){let l=1e3*s;this.millisecond=Math.floor(l)}break;default:throw new Error("Wrong input string for conversion")}let u=i.exec(o);if(u===null)throw new Error("Wrong input string for conversion");for(let l=1;l<u.length;l++)switch(l){case 1:this.year=parseInt(u[l],10);break;case 2:this.month=parseInt(u[l],10);break;case 3:this.day=parseInt(u[l],10);break;case 4:this.hour=parseInt(u[l],10)+a;break;case 5:this.minute=parseInt(u[l],10)+c;break;case 6:this.second=parseInt(u[l],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!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(e="iso"){if(e==="iso"){let t=[];return t.push(qe(this.year,4)),t.push(qe(this.month,2)),t.push(qe(this.day,2)),t.push(qe(this.hour,2)),t.push(qe(this.minute,2)),t.push(qe(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(qe(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Uh=bi;D.GeneralizedTime=Uh;bi.NAME="GeneralizedTime";var Dh,xi=class extends Xt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Dh=xi;D.DATE=Dh;xi.NAME="DATE";var Ph,Ei=class extends Xt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ph=Ei;D.TimeOfDay=Ph;Ei.NAME="TimeOfDay";var Oh,vi=class extends Xt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Oh=vi;D.DateTime=Oh;vi.NAME="DateTime";var Fh,Ai=class extends Xt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Fh=Ai;D.Duration=Fh;Ai.NAME="Duration";var Vh,Bi=class extends Xt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Vh=Bi;D.TIME=Vh;Bi.NAME="TIME";function vw(r){let{result:e}=Mn(r),t=e.valueBlock.value;return{n:z(Tt(t[1].toBigInt()),"base64url"),e:z(Tt(t[2].toBigInt()),"base64url"),d:z(Tt(t[3].toBigInt()),"base64url"),p:z(Tt(t[4].toBigInt()),"base64url"),q:z(Tt(t[5].toBigInt()),"base64url"),dp:z(Tt(t[6].toBigInt()),"base64url"),dq:z(Tt(t[7].toBigInt()),"base64url"),qi:z(Tt(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Aw(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 N("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new Ae({value:[new we({value:0}),we.fromBigInt(Nt(Y(r.n,"base64url"))),we.fromBigInt(Nt(Y(r.e,"base64url"))),we.fromBigInt(Nt(Y(r.d,"base64url"))),we.fromBigInt(Nt(Y(r.p,"base64url"))),we.fromBigInt(Nt(Y(r.q,"base64url"))),we.fromBigInt(Nt(Y(r.dp,"base64url"))),we.fromBigInt(Nt(Y(r.dq,"base64url"))),we.fromBigInt(Nt(Y(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function Bw(r){let{result:e}=Mn(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:z(Tt(t[0].toBigInt()),"base64url"),e:z(Tt(t[1].toBigInt()),"base64url")}}function kw(r){if(r.n==null||r.e==null)throw new N("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new Ae({value:[new Ae({value:[new gt({value:"1.2.840.113549.1.1.1"}),new kr]}),new Fn({valueHex:new Ae({value:[we.fromBigInt(Nt(Y(r.n,"base64url"))),we.fromBigInt(Nt(Y(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function Tt(r){let e=r.toString(16);e.length%2>0&&(e=`0${e}`);let t=e.length/2,n=new Uint8Array(t),o=0,s=0;for(;o<t;)n[o]=parseInt(e.slice(s,s+2),16),o+=1,s+=2;return n}function Nt(r){let e=[];return r.forEach(function(t){let n=t.toString(16);n.length%2>0&&(n=`0${n}`),e.push(n)}),BigInt("0x"+e.join(""))}var Sw=16,zc=32,Gc=1e4;async function Iw(r,e){let t=Me.get(),o=new Ae({value:[new we({value:0}),new Ae({value:[new gt({value:"1.2.840.113549.1.1.1"}),new kr]}),new Jt({valueHex:r.marshal()})]}).toBER(),s=new Uint8Array(o,0,o.byteLength),i=Gr(Sw),a=await Mc(Nn,e,i,{c:Gc,dkLen:zc}),c=Gr(16),f=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),u=await t.subtle.encrypt({name:"AES-CBC",iv:c},f,s),l=new Ae({value:[new Jt({valueHex:i}),new we({value:Gc}),new we({value:zc}),new Ae({value:[new gt({value:"1.2.840.113549.2.11"}),new kr]})]}),h=new Ae({value:[new gt({value:"1.2.840.113549.1.5.13"}),new Ae({value:[new Ae({value:[new gt({value:"1.2.840.113549.1.5.12"}),l]}),new Ae({value:[new gt({value:"2.16.840.1.101.3.4.1.42"}),new Jt({valueHex:c})]})]})]}),y=new Ae({value:[h,new Jt({valueHex:u})]}).toBER(),p=new Uint8Array(y,0,y.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...z(p,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
8
+ `)}async function Rw(r,e){let t=Me.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=Y(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Mn(o),{iv:i,salt:a,iterations:c,keySize:f,cipherText:u}=_w(s),l=await Mc(Nn,e,a,{c,dkLen:f}),h=await t.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),g=Io(await t.subtle.decrypt({name:"AES-CBC",iv:i},h,u)),{result:y}=Mn(g);n=Mh(y)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=Y(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Mn(o);n=Mh(s)}else throw new N("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return jc(n)}function _w(r){let e=r.valueBlock.value[0];if(e.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new N("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=e.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new N("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let s=n.valueBlock.value[1],i=Io(s.valueBlock.value[0].getValue()),a=Gc,c=zc;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 N("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let f=e.valueBlock.value[1].valueBlock.value[1],u=f.valueBlock.value[0].toString();if(u!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(u!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new N("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=Io(f.valueBlock.value[1].getValue());return{cipherText:Io(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:l}}function Mh(r){return Io(r.valueBlock.value[2].getValue())}function Io(r){return new Uint8Array(r,0,r.byteLength)}async function $h(r){let e=await Me.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),t=await qh(e);return{privateKey:t[0],publicKey:t[1]}}async function Wc(r){let t=[await Me.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Tw(r)],n=await qh({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Hh(r,e){let t=await Me.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Me.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function Kh(r,e,t){let n=await Me.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Me.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray())}async function qh(r){if(r.privateKey==null||r.publicKey==null)throw new N("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Me.get().subtle.exportKey("jwk",r.privateKey),Me.get().subtle.exportKey("jwk",r.publicKey)])}async function Tw(r){return Me.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 Si(r){if(r.kty!=="RSA")throw new N("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new N("invalid key modulus","ERR_INVALID_KEY_MODULUS");return Y(r.n,"base64url").length*8}var _o=8192,Ro=class{_key;constructor(e){this._key=e}verify(e,t){return Kh(this._key,t,e)}marshal(){return Sr.jwkToPkix(this._key)}get bytes(){return Rt.encode({Type:ye.RSA,Data:this.marshal()}).subarray()}equals(e){return ce(this.bytes,e.bytes)}hash(){let e=Ee.digest(this.bytes);return at(e)?e.then(({bytes:t})=>t):e.bytes}},$n=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return Gr(16)}sign(e){return Hh(this._key,e)}get public(){if(this._publicKey==null)throw new N("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Ro(this._publicKey)}marshal(){return Sr.jwkToPkcs1(this._key)}get bytes(){return Wt.encode({Type:ye.RSA,Data:this.marshal()}).subarray()}equals(e){return ce(this.bytes,e.bytes)}hash(){let e=Ee.digest(this.bytes);return at(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return z(e,"base58btc")}async export(e,t="pkcs-8"){if(t==="pkcs-8")return Sr.exportToPem(this,e);if(t==="libp2p-key")return Dn(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function jc(r){let e=Sr.pkcs1ToJwk(r);if(Si(e)>_o)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Wc(e);return new $n(t.privateKey,t.publicKey)}function Cw(r){let e=Sr.pkixToJwk(r);if(Si(e)>_o)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Ro(e)}async function Lw(r){if(Si(r)>_o)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Wc(r);return new $n(e.privateKey,e.publicKey)}async function Uw(r){if(r>_o)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await $h(r);return new $n(e.privateKey,e.publicKey)}var eu={};xe(eu,{Secp256k1PrivateKey:()=>No,Secp256k1PublicKey:()=>To,generateKeyPair:()=>jw,unmarshalSecp256k1PrivateKey:()=>zw,unmarshalSecp256k1PublicKey:()=>Gw});var Dw=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Ir=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Rr=new Uint32Array(64),Zc=class extends Tn{constructor(){super(64,32,8,!1),this.A=Ir[0]|0,this.B=Ir[1]|0,this.C=Ir[2]|0,this.D=Ir[3]|0,this.E=Ir[4]|0,this.F=Ir[5]|0,this.G=Ir[6]|0,this.H=Ir[7]|0}get(){let{A:e,B:t,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[e,t,n,o,s,i,a,c]}set(e,t,n,o,s,i,a,c){this.A=e|0,this.B=t|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(e,t){for(let l=0;l<16;l++,t+=4)Rr[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let h=Rr[l-15],g=Rr[l-2],y=mt(h,7)^mt(h,18)^h>>>3,p=mt(g,17)^mt(g,19)^g>>>10;Rr[l]=p+Rr[l-7]+y+Rr[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let h=mt(a,6)^mt(a,11)^mt(a,25),g=u+h+_f(a,c,f)+Dw[l]+Rr[l]|0,p=(mt(n,2)^mt(n,13)^mt(n,22))+Tf(n,o,s)|0;u=f,f=c,c=a,a=i+g|0,i=s,s=o,o=n,n=g+p|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,u=u+this.H|0,this.set(n,o,s,i,a,c,f,u)}roundClean(){Rr.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var zh=Ss(()=>new Zc);function Pw(r){let e=yo(r);It(e,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:t,Fp:n,a:o}=e;if(t){if(!n.eql(o,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof t!="object"||typeof t.beta!="bigint"||typeof t.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...e})}var{bytesToNumberBE:Ow,hexToBytes:Fw}=_s,Wr={Err:class extends Error{constructor(e=""){super(e)}},_parseInt(r){let{Err:e}=Wr;if(r.length<2||r[0]!==2)throw new e("Invalid signature integer tag");let t=r[1],n=r.subarray(2,t+2);if(!t||n.length!==t)throw new e("Invalid signature integer: wrong length");if(n[0]&128)throw new e("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new e("Invalid signature integer: unnecessary leading zero");return{d:Ow(n),l:r.subarray(t+2)}},toSig(r){let{Err:e}=Wr,t=typeof r=="string"?Fw(r):r;Cn(t);let n=t.length;if(n<2||t[0]!=48)throw new e("Invalid signature tag");if(t[1]!==n-2)throw new e("Invalid signature: incorrect length");let{d:o,l:s}=Wr._parseInt(t.subarray(2)),{d:i,l:a}=Wr._parseInt(s);if(a.length)throw new e("Invalid signature: left bytes after parsing");return{r:o,s:i}},hexFromSig(r){let e=f=>Number.parseInt(f[0],16)&8?"00"+f:f,t=f=>{let u=f.toString(16);return u.length&1?`0${u}`:u},n=e(t(r.s)),o=e(t(r.r)),s=n.length/2,i=o.length/2,a=t(s),c=t(i);return`30${t(i+s+4)}02${c}${o}02${a}${n}`}},tr=BigInt(0),ut=BigInt(1),ok=BigInt(2),Gh=BigInt(3),sk=BigInt(4);function Vw(r){let e=Pw(r),{Fp:t}=e,n=e.toBytes||((y,p,m)=>{let w=p.toAffine();return zt(Uint8Array.from([4]),t.toBytes(w.x),t.toBytes(w.y))}),o=e.fromBytes||(y=>{let p=y.subarray(1),m=t.fromBytes(p.subarray(0,t.BYTES)),w=t.fromBytes(p.subarray(t.BYTES,2*t.BYTES));return{x:m,y:w}});function s(y){let{a:p,b:m}=e,w=t.sqr(y),I=t.mul(w,y);return t.add(t.add(I,t.mul(y,p)),m)}if(!t.eql(t.sqr(e.Gy),s(e.Gx)))throw new Error("bad generator point: equation left != right");function i(y){return typeof y=="bigint"&&tr<y&&y<e.n}function a(y){if(!i(y))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(y){let{allowedPrivateKeyLengths:p,nByteLength:m,wrapPrivateKey:w,n:I}=e;if(p&&typeof y!="bigint"){if(xr(y)&&(y=Kt(y)),typeof y!="string"||!p.includes(y.length))throw new Error("Invalid key");y=y.padStart(m*2,"0")}let v;try{v=typeof y=="bigint"?y:qt(pe("private key",y,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof y}`)}return w&&(v=ae(v,I)),a(v),v}let f=new Map;function u(y){if(!(y instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(p,m,w){if(this.px=p,this.py=m,this.pz=w,p==null||!t.isValid(p))throw new Error("x required");if(m==null||!t.isValid(m))throw new Error("y required");if(w==null||!t.isValid(w))throw new Error("z required")}static fromAffine(p){let{x:m,y:w}=p||{};if(!p||!t.isValid(m)||!t.isValid(w))throw new Error("invalid affine point");if(p instanceof l)throw new Error("projective point not allowed");let I=v=>t.eql(v,t.ZERO);return I(m)&&I(w)?l.ZERO:new l(m,w,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(p){let m=t.invertBatch(p.map(w=>w.pz));return p.map((w,I)=>w.toAffine(m[I])).map(l.fromAffine)}static fromHex(p){let m=l.fromAffine(o(pe("pointHex",p)));return m.assertValidity(),m}static fromPrivateKey(p){return l.BASE.multiply(c(p))}_setWindowSize(p){this._WINDOW_SIZE=p,f.delete(this)}assertValidity(){if(this.is0()){if(e.allowInfinityPoint&&!t.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:p,y:m}=this.toAffine();if(!t.isValid(p)||!t.isValid(m))throw new Error("bad point: x or y not FE");let w=t.sqr(m),I=s(p);if(!t.eql(w,I))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:p}=this.toAffine();if(t.isOdd)return!t.isOdd(p);throw new Error("Field doesn't support isOdd")}equals(p){u(p);let{px:m,py:w,pz:I}=this,{px:v,py:U,pz:S}=p,_=t.eql(t.mul(m,S),t.mul(v,I)),L=t.eql(t.mul(w,S),t.mul(U,I));return _&&L}negate(){return new l(this.px,t.neg(this.py),this.pz)}double(){let{a:p,b:m}=e,w=t.mul(m,Gh),{px:I,py:v,pz:U}=this,S=t.ZERO,_=t.ZERO,L=t.ZERO,b=t.mul(I,I),C=t.mul(v,v),O=t.mul(U,U),T=t.mul(I,v);return T=t.add(T,T),L=t.mul(I,U),L=t.add(L,L),S=t.mul(p,L),_=t.mul(w,O),_=t.add(S,_),S=t.sub(C,_),_=t.add(C,_),_=t.mul(S,_),S=t.mul(T,S),L=t.mul(w,L),O=t.mul(p,O),T=t.sub(b,O),T=t.mul(p,T),T=t.add(T,L),L=t.add(b,b),b=t.add(L,b),b=t.add(b,O),b=t.mul(b,T),_=t.add(_,b),O=t.mul(v,U),O=t.add(O,O),b=t.mul(O,T),S=t.sub(S,b),L=t.mul(O,C),L=t.add(L,L),L=t.add(L,L),new l(S,_,L)}add(p){u(p);let{px:m,py:w,pz:I}=this,{px:v,py:U,pz:S}=p,_=t.ZERO,L=t.ZERO,b=t.ZERO,C=e.a,O=t.mul(e.b,Gh),T=t.mul(m,v),V=t.mul(w,U),H=t.mul(I,S),X=t.add(m,w),E=t.add(v,U);X=t.mul(X,E),E=t.add(T,V),X=t.sub(X,E),E=t.add(m,I);let k=t.add(v,S);return E=t.mul(E,k),k=t.add(T,H),E=t.sub(E,k),k=t.add(w,I),_=t.add(U,S),k=t.mul(k,_),_=t.add(V,H),k=t.sub(k,_),b=t.mul(C,E),_=t.mul(O,H),b=t.add(_,b),_=t.sub(V,b),b=t.add(V,b),L=t.mul(_,b),V=t.add(T,T),V=t.add(V,T),H=t.mul(C,H),E=t.mul(O,E),V=t.add(V,H),H=t.sub(T,H),H=t.mul(C,H),E=t.add(E,H),T=t.mul(V,E),L=t.add(L,T),T=t.mul(k,E),_=t.mul(X,_),_=t.sub(_,T),T=t.mul(X,V),b=t.mul(k,b),b=t.add(b,T),new l(_,L,b)}subtract(p){return this.add(p.negate())}is0(){return this.equals(l.ZERO)}wNAF(p){return g.wNAFCached(this,f,p,m=>{let w=t.invertBatch(m.map(I=>I.pz));return m.map((I,v)=>I.toAffine(w[v])).map(l.fromAffine)})}multiplyUnsafe(p){let m=l.ZERO;if(p===tr)return m;if(a(p),p===ut)return this;let{endo:w}=e;if(!w)return g.unsafeLadder(this,p);let{k1neg:I,k1:v,k2neg:U,k2:S}=w.splitScalar(p),_=m,L=m,b=this;for(;v>tr||S>tr;)v&ut&&(_=_.add(b)),S&ut&&(L=L.add(b)),b=b.double(),v>>=ut,S>>=ut;return I&&(_=_.negate()),U&&(L=L.negate()),L=new l(t.mul(L.px,w.beta),L.py,L.pz),_.add(L)}multiply(p){a(p);let m=p,w,I,{endo:v}=e;if(v){let{k1neg:U,k1:S,k2neg:_,k2:L}=v.splitScalar(m),{p:b,f:C}=this.wNAF(S),{p:O,f:T}=this.wNAF(L);b=g.constTimeNegate(U,b),O=g.constTimeNegate(_,O),O=new l(t.mul(O.px,v.beta),O.py,O.pz),w=b.add(O),I=C.add(T)}else{let{p:U,f:S}=this.wNAF(m);w=U,I=S}return l.normalizeZ([w,I])[0]}multiplyAndAddUnsafe(p,m,w){let I=l.BASE,v=(S,_)=>_===tr||_===ut||!S.equals(I)?S.multiplyUnsafe(_):S.multiply(_),U=v(this,m).add(v(p,w));return U.is0()?void 0:U}toAffine(p){let{px:m,py:w,pz:I}=this,v=this.is0();p==null&&(p=v?t.ONE:t.inv(I));let U=t.mul(m,p),S=t.mul(w,p),_=t.mul(I,p);if(v)return{x:t.ZERO,y:t.ZERO};if(!t.eql(_,t.ONE))throw new Error("invZ was invalid");return{x:U,y:S}}isTorsionFree(){let{h:p,isTorsionFree:m}=e;if(p===ut)return!0;if(m)return m(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:p,clearCofactor:m}=e;return p===ut?this:m?m(l,this):this.multiplyUnsafe(e.h)}toRawBytes(p=!0){return this.assertValidity(),n(l,this,p)}toHex(p=!0){return Kt(this.toRawBytes(p))}}l.BASE=new l(e.Gx,e.Gy,t.ONE),l.ZERO=new l(t.ZERO,t.ONE,t.ZERO);let h=e.nBitLength,g=Cs(l,e.endo?Math.ceil(h/2):h);return{CURVE:e,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:s,isWithinCurveOrder:i}}function Mw(r){let e=yo(r);return It(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function jh(r){let e=Mw(r),{Fp:t,n}=e,o=t.BYTES+1,s=2*t.BYTES+1;function i(E){return tr<E&&E<t.ORDER}function a(E){return ae(E,n)}function c(E){return Ts(E,n)}let{ProjectivePoint:f,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:h}=Vw({...e,toBytes(E,k,$){let B=k.toAffine(),x=t.toBytes(B.x),P=zt;return $?P(Uint8Array.from([k.hasEvenY()?2:3]),x):P(Uint8Array.from([4]),x,t.toBytes(B.y))},fromBytes(E){let k=E.length,$=E[0],B=E.subarray(1);if(k===o&&($===2||$===3)){let x=qt(B);if(!i(x))throw new Error("Point is not on curve");let P=l(x),M;try{M=t.sqrt(P)}catch(W){let te=W instanceof Error?": "+W.message:"";throw new Error("Point is not on curve"+te)}let K=(M&ut)===ut;return($&1)===1!==K&&(M=t.neg(M)),{x,y:M}}else if(k===s&&$===4){let x=t.fromBytes(B.subarray(0,t.BYTES)),P=t.fromBytes(B.subarray(t.BYTES,2*t.BYTES));return{x,y:P}}else throw new Error(`Point of length ${k} was invalid. Expected ${o} compressed bytes or ${s} uncompressed bytes`)}}),g=E=>Kt(vr(E,e.nByteLength));function y(E){let k=n>>ut;return E>k}function p(E){return y(E)?a(-E):E}let m=(E,k,$)=>qt(E.slice(k,$));class w{constructor(k,$,B){this.r=k,this.s=$,this.recovery=B,this.assertValidity()}static fromCompact(k){let $=e.nByteLength;return k=pe("compactSignature",k,$*2),new w(m(k,0,$),m(k,$,2*$))}static fromDER(k){let{r:$,s:B}=Wr.toSig(pe("DER",k));return new w($,B)}assertValidity(){if(!h(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!h(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(k){return new w(this.r,this.s,k)}recoverPublicKey(k){let{r:$,s:B,recovery:x}=this,P=L(pe("msgHash",k));if(x==null||![0,1,2,3].includes(x))throw new Error("recovery id invalid");let M=x===2||x===3?$+e.n:$;if(M>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let K=x&1?"03":"02",j=f.fromHex(K+g(M)),W=c(M),te=a(-P*W),J=a(B*W),Q=f.BASE.multiplyAndAddUnsafe(j,te,J);if(!Q)throw new Error("point at infinify");return Q.assertValidity(),Q}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new w(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Hr(this.toDERHex())}toDERHex(){return Wr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Hr(this.toCompactHex())}toCompactHex(){return g(this.r)+g(this.s)}}let I={isValidPrivateKey(E){try{return u(E),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let E=Cc(e.n);return $f(e.randomBytes(E),e.n)},precompute(E=8,k=f.BASE){return k._setWindowSize(E),k.multiply(BigInt(3)),k}};function v(E,k=!0){return f.fromPrivateKey(E).toRawBytes(k)}function U(E){let k=xr(E),$=typeof E=="string",B=(k||$)&&E.length;return k?B===o||B===s:$?B===2*o||B===2*s:E instanceof f}function S(E,k,$=!0){if(U(E))throw new Error("first arg must be private key");if(!U(k))throw new Error("second arg must be public key");return f.fromHex(k).multiply(u(E)).toRawBytes($)}let _=e.bits2int||function(E){let k=qt(E),$=E.length*8-e.nBitLength;return $>0?k>>BigInt($):k},L=e.bits2int_modN||function(E){return a(_(E))},b=mo(e.nBitLength);function C(E){if(typeof E!="bigint")throw new Error("bigint expected");if(!(tr<=E&&E<b))throw new Error(`bigint expected < 2^${e.nBitLength}`);return vr(E,e.nByteLength)}function O(E,k,$=T){if(["recovered","canonical"].some(he=>he in $))throw new Error("sign() legacy options not supported");let{hash:B,randomBytes:x}=e,{lowS:P,prehash:M,extraEntropy:K}=$;P==null&&(P=!0),E=pe("msgHash",E),M&&(E=pe("prehashed msgHash",B(E)));let j=L(E),W=u(k),te=[C(W),C(j)];if(K!=null&&K!==!1){let he=K===!0?x(t.BYTES):K;te.push(pe("extraEntropy",he))}let J=zt(...te),Q=j;function ge(he){let ke=_(he);if(!h(ke))return;let Se=c(ke),be=f.BASE.multiply(ke).toAffine(),Le=a(be.x);if(Le===tr)return;let Pt=a(Se*a(Q+Le*W));if(Pt===tr)return;let Ur=(be.x===Le?0:2)|Number(be.y&ut),Qn=Pt;return P&&y(Pt)&&(Qn=p(Pt),Ur^=1),new w(Le,Qn,Ur)}return{seed:J,k2sig:ge}}let T={lowS:e.lowS,prehash:!1},V={lowS:e.lowS,prehash:!1};function H(E,k,$=T){let{seed:B,k2sig:x}=O(E,k,$),P=e;return Rc(P.hash.outputLen,P.nByteLength,P.hmac)(B,x)}f.BASE._setWindowSize(8);function X(E,k,$,B=V){let x=E;if(k=pe("msgHash",k),$=pe("publicKey",$),"strict"in B)throw new Error("options.strict was renamed to lowS");let{lowS:P,prehash:M}=B,K,j;try{if(typeof x=="string"||xr(x))try{K=w.fromDER(x)}catch(be){if(!(be instanceof Wr.Err))throw be;K=w.fromCompact(x)}else if(typeof x=="object"&&typeof x.r=="bigint"&&typeof x.s=="bigint"){let{r:be,s:Le}=x;K=new w(be,Le)}else throw new Error("PARSE");j=f.fromHex($)}catch(be){if(be.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(P&&K.hasHighS())return!1;M&&(k=e.hash(k));let{r:W,s:te}=K,J=L(k),Q=c(te),ge=a(J*Q),he=a(W*Q),ke=f.BASE.multiplyAndAddUnsafe(j,ge,he)?.toAffine();return ke?a(ke.x)===W:!1}return{CURVE:e,getPublicKey:v,getSharedSecret:S,sign:H,verify:X,ProjectivePoint:f,Signature:w,utils:I}}function $w(r){return{hash:r,hmac:(e,...t)=>wo(r,e,ks(...t)),randomBytes:_n}}function Wh(r,e){let t=n=>jh({...r,...$w(n)});return Object.freeze({...t(e),create:t})}var Jh=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Yh=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Hw=BigInt(1),Jc=BigInt(2),Zh=(r,e)=>(r+e/Jc)/e;function Kw(r){let e=Jh,t=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%e,u=f*f*r%e,l=le(u,t,e)*u%e,h=le(l,t,e)*u%e,g=le(h,Jc,e)*f%e,y=le(g,o,e)*g%e,p=le(y,s,e)*y%e,m=le(p,a,e)*p%e,w=le(m,c,e)*m%e,I=le(w,a,e)*p%e,v=le(I,t,e)*u%e,U=le(v,i,e)*y%e,S=le(U,n,e)*f%e,_=le(S,Jc,e);if(!Xc.eql(Xc.sqr(_),r))throw new Error("Cannot find square root");return _}var Xc=Ns(Jh,void 0,void 0,{sqrt:Kw}),bt=Wh({a:BigInt(0),b:BigInt(7),Fp:Xc,n:Yh,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=Yh,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Hw*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=t,i=BigInt("0x100000000000000000000000000000000"),a=Zh(s*r,e),c=Zh(-n*r,e),f=ae(r-a*t-c*o,e),u=ae(-a*n-c*s,e),l=f>i,h=u>i;if(l&&(f=e-f),h&&(u=e-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:h,k2:u}}}},zh),pk=BigInt(0);var mk=bt.ProjectivePoint;function Xh(){return bt.utils.randomPrivateKey()}function Qh(r,e){let t=Ee.digest(e instanceof Uint8Array?e:e.subarray());if(at(t))return t.then(({digest:n})=>bt.sign(n,r).toDERRawBytes()).catch(n=>{throw new N(String(n),"ERR_INVALID_INPUT")});try{return bt.sign(t.digest,r).toDERRawBytes()}catch(n){throw new N(String(n),"ERR_INVALID_INPUT")}}function ed(r,e,t){let n=Ee.digest(t instanceof Uint8Array?t:t.subarray());if(at(n))return n.then(({digest:o})=>bt.verify(e,o,r)).catch(o=>{throw new N(String(o),"ERR_INVALID_INPUT")});try{return bt.verify(e,n.digest,r)}catch(o){throw new N(String(o),"ERR_INVALID_INPUT")}}function td(r){return bt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function rd(r){try{bt.getPublicKey(r,!0)}catch(e){throw new N(String(e),"ERR_INVALID_PRIVATE_KEY")}}function Qc(r){try{bt.ProjectivePoint.fromHex(r)}catch(e){throw new N(String(e),"ERR_INVALID_PUBLIC_KEY")}}function nd(r){try{return bt.getPublicKey(r,!0)}catch(e){throw new N(String(e),"ERR_INVALID_PRIVATE_KEY")}}var To=class{_key;constructor(e){Qc(e),this._key=e}verify(e,t){return ed(this._key,t,e)}marshal(){return td(this._key)}get bytes(){return Rt.encode({Type:ye.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return ce(this.bytes,e.bytes)}async hash(){let e=Ee.digest(this.bytes),t;return at(e)?{bytes:t}=await e:t=e.bytes,t}},No=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??nd(e),rd(this._key),Qc(this._publicKey)}sign(e){return Qh(this._key,e)}get public(){return new To(this._publicKey)}marshal(){return this._key}get bytes(){return Wt.encode({Type:ye.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return ce(this.bytes,e.bytes)}hash(){let e=Ee.digest(this.bytes);return at(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return z(e,"base58btc")}async export(e,t="libp2p-key"){if(t==="libp2p-key")return Dn(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function zw(r){return new No(r)}function Gw(r){return new To(r)}async function jw(){let r=Xh();return new No(r)}var Ii={rsa:Yc,ed25519:Vc,secp256k1:eu};function Ww(r){let e=Object.keys(Ii).join(" / ");return new N(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function tu(r){let e=Rt.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case ye.RSA:return Ii.rsa.unmarshalRsaPublicKey(t);case ye.Ed25519:return Ii.ed25519.unmarshalEd25519PublicKey(t);case ye.Secp256k1:return Ii.secp256k1.unmarshalSecp256k1PublicKey(t);default:throw Ww(e.Type??"unknown")}}var Rb=ot(pn(),1);var rr="/",od=new TextEncoder().encode(rr),Ri=od[0],Ne=class r{_buf;constructor(e,t){if(typeof e=="string")this._buf=Y(e);else if(e instanceof Uint8Array)this._buf=e;else throw new Error("Invalid key, should be String of Uint8Array");if(t==null&&(t=!0),t&&this.clean(),this._buf.byteLength===0||this._buf[0]!==Ri)throw new Error("Invalid key")}toString(e="utf8"){return z(this._buf,e)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(e){return new r(e.join(rr))}static random(){return new r(Math.random().toString().substring(2))}static asKey(e){return e instanceof Uint8Array||typeof e=="string"?new r(e):typeof e.uint8Array=="function"?new r(e.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=od),this._buf[0]!==Ri){let e=new Uint8Array(this._buf.byteLength+1);e.fill(Ri,0,1),e.set(this._buf,1),this._buf=e}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Ri;)this._buf=this._buf.subarray(0,-1)}less(e){let t=this.list(),n=e.list();for(let o=0;o<t.length;o++){if(n.length<o+1)return!1;let s=t[o],i=n[o];if(s<i)return!0;if(s>i)return!1}return t.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let e=this.namespaces();return e[e.length-1]}list(){return this.toString().split(rr).slice(1)}type(){return Yw(this.baseNamespace())}name(){return Zw(this.baseNamespace())}instance(e){return new r(this.toString()+":"+e)}path(){let e=this.parent().toString();return e.endsWith(rr)||(e+=rr),e+=this.type(),new r(e)}parent(){let e=this.list();return e.length===1?new r(rr):new r(e.slice(0,-1).join(rr))}child(e){return this.toString()===rr?e:e.toString()===rr?this:new r(this.toString()+e.toString(),!1)}isAncestorOf(e){return e.toString()===this.toString()?!1:e.toString().startsWith(this.toString())}isDecendantOf(e){return e.toString()===this.toString()?!1:this.toString().startsWith(e.toString())}isTopLevel(){return this.list().length===1}concat(...e){return r.withNamespaces([...this.namespaces(),...Jw(e.map(t=>t.namespaces()))])}};function Yw(r){let e=r.split(":");return e.length<2?"":e.slice(0,-1).join(":")}function Zw(r){let e=r.split(":");return e[e.length-1]}function Jw(r){return[].concat(...r)}var _b=ot(nu(),1);var sd="ERR_IPNS_EXPIRED_RECORD",_i="ERR_UNRECOGNIZED_VALIDITY";var nr="ERR_SIGNATURE_VERIFICATION";var ou="ERR_UNDEFINED_PARAMETER",id="ERR_INVALID_RECORD_DATA",ad="ERR_INVALID_VALUE",cd="ERR_INVALID_EMBEDDED_KEY";var ud="ERR_RECORD_TOO_LARGE";var xt;(function(r){let e;(function(o){o.EOL="EOL"})(e=r.ValidityType||(r.ValidityType={}));let t;(function(o){o[o.EOL=0]="EOL"})(t||(t={})),function(o){o.codec=()=>uo(t)}(e=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=xn((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=>wn(o,r.codec()),r.decode=o=>gn(o,r.codec())})(xt||(xt={}));var Xw=["string","number","bigint","symbol"],Qw=["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 fd(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let e=typeof r;if(Xw.includes(e))return e;if(e==="function")return"Function";if(Array.isArray(r))return"Array";if(eb(r))return"Buffer";let t=tb(r);return t||"Object"}function eb(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function tb(r){let e=Object.prototype.toString.call(r).slice(8,-1);if(Qw.includes(e))return e}var d=class{constructor(e,t,n){this.major=e,this.majorEncoded=e<<5,this.name=t,this.terminal=n}toString(){return`Type[${this.major}].${this.name}`}compare(e){return this.major<e.major?-1:this.major>e.major?1:0}};d.uint=new d(0,"uint",!0);d.negint=new d(1,"negint",!0);d.bytes=new d(2,"bytes",!0);d.string=new d(3,"string",!0);d.array=new d(4,"array",!1);d.map=new d(5,"map",!1);d.tag=new d(6,"tag",!1);d.float=new d(7,"float",!0);d.false=new d(7,"false",!0);d.true=new d(7,"true",!0);d.null=new d(7,"null",!0);d.undefined=new d(7,"undefined",!0);d.break=new d(7,"break",!0);var A=class{constructor(e,t,n){this.type=e,this.value=t,this.encodedLength=n,this.encodedBytes=void 0,this.byteValue=void 0}toString(){return`Token[${this.type}].${this.value}`}};var Hn=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",rb=new TextDecoder,nb=new TextEncoder;function Ti(r){return Hn&&globalThis.Buffer.isBuffer(r)}function Co(r){return r instanceof Uint8Array?Ti(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var md=Hn?(r,e,t)=>t-e>64?globalThis.Buffer.from(r.subarray(e,t)).toString("utf8"):dd(r,e,t):(r,e,t)=>t-e>64?rb.decode(r.subarray(e,t)):dd(r,e,t),Ni=Hn?r=>r.length>64?globalThis.Buffer.from(r):hd(r):r=>r.length>64?nb.encode(r):hd(r),Ct=r=>Uint8Array.from(r),Kn=Hn?(r,e,t)=>Ti(r)?new Uint8Array(r.subarray(e,t)):r.slice(e,t):(r,e,t)=>r.slice(e,t),yd=Hn?(r,e)=>(r=r.map(t=>t instanceof Uint8Array?t:globalThis.Buffer.from(t)),Co(globalThis.Buffer.concat(r,e))):(r,e)=>{let t=new Uint8Array(e),n=0;for(let o of r)n+o.length>t.length&&(o=o.subarray(0,t.length-n)),t.set(o,n),n+=o.length;return t},gd=Hn?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function wd(r,e){if(Ti(r)&&Ti(e))return r.compare(e);for(let t=0;t<r.length;t++)if(r[t]!==e[t])return r[t]<e[t]?-1:1;return 0}function hd(r){let e=[],t=0;for(let n=0;n<r.length;n++){let o=r.charCodeAt(n);o<128?e[t++]=o:o<2048?(e[t++]=o>>6|192,e[t++]=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),e[t++]=o>>18|240,e[t++]=o>>12&63|128,e[t++]=o>>6&63|128,e[t++]=o&63|128):(e[t++]=o>>12|224,e[t++]=o>>6&63|128,e[t++]=o&63|128)}return e}function dd(r,e,t){let n=[];for(;e<t;){let o=r[e],s=null,i=o>239?4:o>223?3:o>191?2:1;if(e+i<=t){let a,c,f,u;switch(i){case 1:o<128&&(s=o);break;case 2:a=r[e+1],(a&192)===128&&(u=(o&31)<<6|a&63,u>127&&(s=u));break;case 3:a=r[e+1],c=r[e+2],(a&192)===128&&(c&192)===128&&(u=(o&15)<<12|(a&63)<<6|c&63,u>2047&&(u<55296||u>57343)&&(s=u));break;case 4:a=r[e+1],c=r[e+2],f=r[e+3],(a&192)===128&&(c&192)===128&&(f&192)===128&&(u=(o&15)<<18|(a&63)<<12|(c&63)<<6|f&63,u>65535&&u<1114112&&(s=u))}}s===null?(s=65533,i=1):s>65535&&(s-=65536,n.push(s>>>10&1023|55296),s=56320|s&1023),n.push(s),e+=i}return su(n)}var pd=4096;function su(r){let e=r.length;if(e<=pd)return String.fromCharCode.apply(String,r);let t="",n=0;for(;n<e;)t+=String.fromCharCode.apply(String,r.slice(n,n+=pd));return t}var ob=256,Lo=class{constructor(e=ob){this.chunkSize=e,this.cursor=0,this.maxCursor=-1,this.chunks=[],this._initReuseChunk=null}reset(){this.cursor=0,this.maxCursor=-1,this.chunks.length&&(this.chunks=[]),this._initReuseChunk!==null&&(this.chunks.push(this._initReuseChunk),this.maxCursor=this._initReuseChunk.length-1)}push(e){let t=this.chunks[this.chunks.length-1];if(this.cursor+e.length<=this.maxCursor+1){let o=t.length-(this.maxCursor-this.cursor)-1;t.set(e,o)}else{if(t){let o=t.length-(this.maxCursor-this.cursor)-1;o<t.length&&(this.chunks[this.chunks.length-1]=t.subarray(0,o),this.maxCursor=this.cursor-1)}e.length<64&&e.length<this.chunkSize?(t=gd(this.chunkSize),this.chunks.push(t),this.maxCursor+=t.length,this._initReuseChunk===null&&(this._initReuseChunk=t),t.set(e,0)):(this.chunks.push(e),this.maxCursor+=e.length)}this.cursor+=e.length}toBytes(e=!1){let t;if(this.chunks.length===1){let n=this.chunks[0];e&&this.cursor>n.length/2?(t=this.cursor===n.length?n:n.subarray(0,this.cursor),this._initReuseChunk=null,this.chunks=[]):t=Kn(n,0,this.cursor)}else t=yd(this.chunks,this.cursor);return e&&this.reset(),t}};var F="CBOR decode error:",qn="CBOR encode error:",Uo=[];Uo[23]=1;Uo[24]=2;Uo[25]=3;Uo[26]=5;Uo[27]=9;function or(r,e,t){if(r.length-e<t)throw new Error(`${F} not enough data for type`)}var Be=[24,256,65536,4294967296,BigInt("18446744073709551616")];function Qe(r,e,t){or(r,e,1);let n=r[e];if(t.strict===!0&&n<Be[0])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);return n}function et(r,e,t){or(r,e,2);let n=r[e]<<8|r[e+1];if(t.strict===!0&&n<Be[1])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);return n}function tt(r,e,t){or(r,e,4);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3];if(t.strict===!0&&n<Be[2])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);return n}function rt(r,e,t){or(r,e,8);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3],o=r[e+4]*16777216+(r[e+5]<<16)+(r[e+6]<<8)+r[e+7],s=(BigInt(n)<<BigInt(32))+BigInt(o);if(t.strict===!0&&s<Be[3])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);if(s<=Number.MAX_SAFE_INTEGER)return Number(s);if(t.allowBigInt===!0)return s;throw new Error(`${F} integers outside of the safe integer range are not supported`)}function bd(r,e,t,n){return new A(d.uint,Qe(r,e+1,n),2)}function xd(r,e,t,n){return new A(d.uint,et(r,e+1,n),3)}function Ed(r,e,t,n){return new A(d.uint,tt(r,e+1,n),5)}function vd(r,e,t,n){return new A(d.uint,rt(r,e+1,n),9)}function lt(r,e){return Ce(r,0,e.value)}function Ce(r,e,t){if(t<Be[0]){let n=Number(t);r.push([e|n])}else if(t<Be[1]){let n=Number(t);r.push([e|24,n])}else if(t<Be[2]){let n=Number(t);r.push([e|25,n>>>8,n&255])}else if(t<Be[3]){let n=Number(t);r.push([e|26,n>>>24&255,n>>>16&255,n>>>8&255,n&255])}else{let n=BigInt(t);if(n<Be[4]){let o=[e|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(`${F} encountered BigInt larger than allowable range`)}}lt.encodedSize=function(e){return Ce.encodedSize(e.value)};Ce.encodedSize=function(e){return e<Be[0]?1:e<Be[1]?2:e<Be[2]?3:e<Be[3]?5:9};lt.compareTokens=function(e,t){return e.value<t.value?-1:e.value>t.value?1:0};function Ad(r,e,t,n){return new A(d.negint,-1-Qe(r,e+1,n),2)}function Bd(r,e,t,n){return new A(d.negint,-1-et(r,e+1,n),3)}function kd(r,e,t,n){return new A(d.negint,-1-tt(r,e+1,n),5)}var iu=BigInt(-1),Sd=BigInt(1);function Id(r,e,t,n){let o=rt(r,e+1,n);if(typeof o!="bigint"){let s=-1-o;if(s>=Number.MIN_SAFE_INTEGER)return new A(d.negint,s,9)}if(n.allowBigInt!==!0)throw new Error(`${F} integers outside of the safe integer range are not supported`);return new A(d.negint,iu-BigInt(o),9)}function Ci(r,e){let t=e.value,n=typeof t=="bigint"?t*iu-Sd:t*-1-1;Ce(r,e.type.majorEncoded,n)}Ci.encodedSize=function(e){let t=e.value,n=typeof t=="bigint"?t*iu-Sd:t*-1-1;return n<Be[0]?1:n<Be[1]?2:n<Be[2]?3:n<Be[3]?5:9};Ci.compareTokens=function(e,t){return e.value<t.value?1:e.value>t.value?-1:0};function Do(r,e,t,n){or(r,e,t+n);let o=Kn(r,e+t,e+t+n);return new A(d.bytes,o,t+n)}function Rd(r,e,t,n){return Do(r,e,1,t)}function _d(r,e,t,n){return Do(r,e,2,Qe(r,e+1,n))}function Td(r,e,t,n){return Do(r,e,3,et(r,e+1,n))}function Nd(r,e,t,n){return Do(r,e,5,tt(r,e+1,n))}function Cd(r,e,t,n){let o=rt(r,e+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer bytes lengths not supported`);return Do(r,e,9,o)}function Li(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===d.string?Ni(r.value):r.value),r.encodedBytes}function zn(r,e){let t=Li(e);Ce(r,e.type.majorEncoded,t.length),r.push(t)}zn.encodedSize=function(e){let t=Li(e);return Ce.encodedSize(t.length)+t.length};zn.compareTokens=function(e,t){return ib(Li(e),Li(t))};function ib(r,e){return r.length<e.length?-1:r.length>e.length?1:wd(r,e)}function Po(r,e,t,n,o){let s=t+n;or(r,e,s);let i=new A(d.string,md(r,e+t,e+s),s);return o.retainStringBytes===!0&&(i.byteValue=Kn(r,e+t,e+s)),i}function Ld(r,e,t,n){return Po(r,e,1,t,n)}function Ud(r,e,t,n){return Po(r,e,2,Qe(r,e+1,n),n)}function Dd(r,e,t,n){return Po(r,e,3,et(r,e+1,n),n)}function Pd(r,e,t,n){return Po(r,e,5,tt(r,e+1,n),n)}function Od(r,e,t,n){let o=rt(r,e+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer string lengths not supported`);return Po(r,e,9,o,n)}var Fd=zn;function Gn(r,e,t,n){return new A(d.array,n,t)}function Vd(r,e,t,n){return Gn(r,e,1,t)}function Md(r,e,t,n){return Gn(r,e,2,Qe(r,e+1,n))}function $d(r,e,t,n){return Gn(r,e,3,et(r,e+1,n))}function Hd(r,e,t,n){return Gn(r,e,5,tt(r,e+1,n))}function Kd(r,e,t,n){let o=rt(r,e+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer array lengths not supported`);return Gn(r,e,9,o)}function qd(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${F} indefinite length items not allowed`);return Gn(r,e,1,1/0)}function Ui(r,e){Ce(r,d.array.majorEncoded,e.value)}Ui.compareTokens=lt.compareTokens;Ui.encodedSize=function(e){return Ce.encodedSize(e.value)};function jn(r,e,t,n){return new A(d.map,n,t)}function zd(r,e,t,n){return jn(r,e,1,t)}function Gd(r,e,t,n){return jn(r,e,2,Qe(r,e+1,n))}function jd(r,e,t,n){return jn(r,e,3,et(r,e+1,n))}function Wd(r,e,t,n){return jn(r,e,5,tt(r,e+1,n))}function Yd(r,e,t,n){let o=rt(r,e+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer map lengths not supported`);return jn(r,e,9,o)}function Zd(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${F} indefinite length items not allowed`);return jn(r,e,1,1/0)}function Di(r,e){Ce(r,d.map.majorEncoded,e.value)}Di.compareTokens=lt.compareTokens;Di.encodedSize=function(e){return Ce.encodedSize(e.value)};function Jd(r,e,t,n){return new A(d.tag,t,1)}function Xd(r,e,t,n){return new A(d.tag,Qe(r,e+1,n),2)}function Qd(r,e,t,n){return new A(d.tag,et(r,e+1,n),3)}function ep(r,e,t,n){return new A(d.tag,tt(r,e+1,n),5)}function tp(r,e,t,n){return new A(d.tag,rt(r,e+1,n),9)}function Pi(r,e){Ce(r,d.tag.majorEncoded,e.value)}Pi.compareTokens=lt.compareTokens;Pi.encodedSize=function(e){return Ce.encodedSize(e.value)};var hb=20,db=21,pb=22,mb=23;function rp(r,e,t,n){if(n.allowUndefined===!1)throw new Error(`${F} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new A(d.null,null,1):new A(d.undefined,void 0,1)}function np(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${F} indefinite length items not allowed`);return new A(d.break,void 0,1)}function au(r,e,t){if(t){if(t.allowNaN===!1&&Number.isNaN(r))throw new Error(`${F} NaN values are not supported`);if(t.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${F} Infinity values are not supported`)}return new A(d.float,r,e)}function op(r,e,t,n){return au(cu(r,e+1),3,n)}function sp(r,e,t,n){return au(uu(r,e+1),5,n)}function ip(r,e,t,n){return au(lp(r,e+1),9,n)}function Oi(r,e,t){let n=e.value;if(n===!1)r.push([d.float.majorEncoded|hb]);else if(n===!0)r.push([d.float.majorEncoded|db]);else if(n===null)r.push([d.float.majorEncoded|pb]);else if(n===void 0)r.push([d.float.majorEncoded|mb]);else{let o,s=!1;(!t||t.float64!==!0)&&(cp(n),o=cu(Et,1),n===o||Number.isNaN(n)?(Et[0]=249,r.push(Et.slice(0,3)),s=!0):(up(n),o=uu(Et,1),n===o&&(Et[0]=250,r.push(Et.slice(0,5)),s=!0))),s||(yb(n),o=lp(Et,1),Et[0]=251,r.push(Et.slice(0,9)))}}Oi.encodedSize=function(e,t){let n=e.value;if(n===!1||n===!0||n===null||n===void 0)return 1;if(!t||t.float64!==!0){cp(n);let o=cu(Et,1);if(n===o||Number.isNaN(n))return 3;if(up(n),o=uu(Et,1),n===o)return 5}return 9};var ap=new ArrayBuffer(9),ft=new DataView(ap,1),Et=new Uint8Array(ap,0);function cp(r){if(r===1/0)ft.setUint16(0,31744,!1);else if(r===-1/0)ft.setUint16(0,64512,!1);else if(Number.isNaN(r))ft.setUint16(0,32256,!1);else{ft.setFloat32(0,r);let e=ft.getUint32(0),t=(e&2139095040)>>23,n=e&8388607;if(t===255)ft.setUint16(0,31744,!1);else if(t===0)ft.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let o=t-127;o<-24?ft.setUint16(0,0):o<-14?ft.setUint16(0,(e&2147483648)>>16|1<<24+o,!1):ft.setUint16(0,(e&2147483648)>>16|o+15<<10|n>>13,!1)}}}function cu(r,e){if(r.length-e<2)throw new Error(`${F} not enough data for float16`);let t=(r[e]<<8)+r[e+1];if(t===31744)return 1/0;if(t===64512)return-1/0;if(t===32256)return NaN;let n=t>>10&31,o=t&1023,s;return n===0?s=o*2**-24:n!==31?s=(o+1024)*2**(n-25):s=o===0?1/0:NaN,t&32768?-s:s}function up(r){ft.setFloat32(0,r,!1)}function uu(r,e){if(r.length-e<4)throw new Error(`${F} not enough data for float32`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,4).getFloat32(0,!1)}function yb(r){ft.setFloat64(0,r,!1)}function lp(r,e){if(r.length-e<8)throw new Error(`${F} not enough data for float64`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,8).getFloat64(0,!1)}Oi.compareTokens=lt.compareTokens;function ee(r,e,t){throw new Error(`${F} encountered invalid minor (${t}) for major ${r[e]>>>5}`)}function Fi(r){return()=>{throw new Error(`${F} ${r}`)}}var R=[];for(let r=0;r<=23;r++)R[r]=ee;R[24]=bd;R[25]=xd;R[26]=Ed;R[27]=vd;R[28]=ee;R[29]=ee;R[30]=ee;R[31]=ee;for(let r=32;r<=55;r++)R[r]=ee;R[56]=Ad;R[57]=Bd;R[58]=kd;R[59]=Id;R[60]=ee;R[61]=ee;R[62]=ee;R[63]=ee;for(let r=64;r<=87;r++)R[r]=Rd;R[88]=_d;R[89]=Td;R[90]=Nd;R[91]=Cd;R[92]=ee;R[93]=ee;R[94]=ee;R[95]=Fi("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)R[r]=Ld;R[120]=Ud;R[121]=Dd;R[122]=Pd;R[123]=Od;R[124]=ee;R[125]=ee;R[126]=ee;R[127]=Fi("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)R[r]=Vd;R[152]=Md;R[153]=$d;R[154]=Hd;R[155]=Kd;R[156]=ee;R[157]=ee;R[158]=ee;R[159]=qd;for(let r=160;r<=183;r++)R[r]=zd;R[184]=Gd;R[185]=jd;R[186]=Wd;R[187]=Yd;R[188]=ee;R[189]=ee;R[190]=ee;R[191]=Zd;for(let r=192;r<=215;r++)R[r]=Jd;R[216]=Xd;R[217]=Qd;R[218]=ep;R[219]=tp;R[220]=ee;R[221]=ee;R[222]=ee;R[223]=ee;for(let r=224;r<=243;r++)R[r]=Fi("simple values are not supported");R[244]=ee;R[245]=ee;R[246]=ee;R[247]=rp;R[248]=Fi("simple values are not supported");R[249]=op;R[250]=sp;R[251]=ip;R[252]=ee;R[253]=ee;R[254]=ee;R[255]=np;var vt=[];for(let r=0;r<24;r++)vt[r]=new A(d.uint,r,1);for(let r=-1;r>=-24;r--)vt[31-r]=new A(d.negint,r,1);vt[64]=new A(d.bytes,new Uint8Array(0),1);vt[96]=new A(d.string,"",1);vt[128]=new A(d.array,0,1);vt[160]=new A(d.map,0,1);vt[244]=new A(d.false,!1,1);vt[245]=new A(d.true,!0,1);vt[246]=new A(d.null,null,1);function fp(r){switch(r.type){case d.false:return Ct([244]);case d.true:return Ct([245]);case d.null:return Ct([246]);case d.bytes:return r.value.length?void 0:Ct([64]);case d.string:return r.value===""?Ct([96]):void 0;case d.array:return r.value===0?Ct([128]):void 0;case d.map:return r.value===0?Ct([160]):void 0;case d.uint:return r.value<24?Ct([Number(r.value)]):void 0;case d.negint:if(r.value>=-24)return Ct([31-Number(r.value)])}}var wb={float64:!1,mapSorter:Eb,quickEncodeToken:fp};function bb(){let r=[];return r[d.uint.major]=lt,r[d.negint.major]=Ci,r[d.bytes.major]=zn,r[d.string.major]=Fd,r[d.array.major]=Ui,r[d.map.major]=Di,r[d.tag.major]=Pi,r[d.float.major]=Oi,r}var hp=bb(),lu=new Lo,Mi=class r{constructor(e,t){this.obj=e,this.parent=t}includes(e){let t=this;do if(t.obj===e)return!0;while(t=t.parent);return!1}static createCheck(e,t){if(e&&e.includes(t))throw new Error(`${qn} object contains circular references`);return new r(t,e)}},_r={null:new A(d.null,null),undefined:new A(d.undefined,void 0),true:new A(d.true,!0),false:new A(d.false,!1),emptyArray:new A(d.array,0),emptyMap:new A(d.map,0)},Tr={number(r,e,t,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new A(d.float,r):r>=0?new A(d.uint,r):new A(d.negint,r)},bigint(r,e,t,n){return r>=BigInt(0)?new A(d.uint,r):new A(d.negint,r)},Uint8Array(r,e,t,n){return new A(d.bytes,r)},string(r,e,t,n){return new A(d.string,r)},boolean(r,e,t,n){return r?_r.true:_r.false},null(r,e,t,n){return _r.null},undefined(r,e,t,n){return _r.undefined},ArrayBuffer(r,e,t,n){return new A(d.bytes,new Uint8Array(r))},DataView(r,e,t,n){return new A(d.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,e,t,n){if(!r.length)return t.addBreakTokens===!0?[_r.emptyArray,new A(d.break)]:_r.emptyArray;n=Mi.createCheck(n,r);let o=[],s=0;for(let i of r)o[s++]=Vi(i,t,n);return t.addBreakTokens?[new A(d.array,r.length),o,new A(d.break)]:[new A(d.array,r.length),o]},Object(r,e,t,n){let o=e!=="Object",s=o?r.keys():Object.keys(r),i=o?r.size:s.length;if(!i)return t.addBreakTokens===!0?[_r.emptyMap,new A(d.break)]:_r.emptyMap;n=Mi.createCheck(n,r);let a=[],c=0;for(let f of s)a[c++]=[Vi(f,t,n),Vi(o?r.get(f):r[f],t,n)];return xb(a,t),t.addBreakTokens?[new A(d.map,i),a,new A(d.break)]:[new A(d.map,i),a]}};Tr.Map=Tr.Object;Tr.Buffer=Tr.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))Tr[`${r}Array`]=Tr.DataView;function Vi(r,e={},t){let n=fd(r),o=e&&e.typeEncoders&&e.typeEncoders[n]||Tr[n];if(typeof o=="function"){let i=o(r,n,e,t);if(i!=null)return i}let s=Tr[n];if(!s)throw new Error(`${qn} unsupported type: ${n}`);return s(r,n,e,t)}function xb(r,e){e.mapSorter&&r.sort(e.mapSorter)}function Eb(r,e){let t=Array.isArray(r[0])?r[0][0]:r[0],n=Array.isArray(e[0])?e[0][0]:e[0];if(t.type!==n.type)return t.type.compare(n.type);let o=t.type.major,s=hp[o].compareTokens(t,n);return s===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),s}function dp(r,e,t,n){if(Array.isArray(e))for(let o of e)dp(r,o,t,n);else t[e.type.major](r,e,n)}function pp(r,e,t){let n=Vi(r,t);if(!Array.isArray(n)&&t.quickEncodeToken){let o=t.quickEncodeToken(n);if(o)return o;let s=e[n.type.major];if(s.encodedSize){let i=s.encodedSize(n,t),a=new Lo(i);if(s(a,n,t),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return Co(a.chunks[0])}}return lu.reset(),dp(lu,n,e,t),lu.toBytes(!0)}function Wn(r,e){return e=Object.assign({},wb,e),pp(r,hp,e)}var vb={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},$i=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t}pos(){return this._pos}done(){return this._pos>=this.data.length}next(){let e=this.data[this._pos],t=vt[e];if(t===void 0){let n=R[e];if(!n)throw new Error(`${F} no decoder for major type ${e>>>5} (byte 0x${e.toString(16).padStart(2,"0")})`);let o=e&31;t=n(this.data,this._pos,o,this.options)}return this._pos+=t.encodedLength,t}},Oo=Symbol.for("DONE"),Hi=Symbol.for("BREAK");function Ab(r,e,t){let n=[];for(let o=0;o<r.value;o++){let s=Yn(e,t);if(s===Hi){if(r.value===1/0)break;throw new Error(`${F} got unexpected break to lengthed array`)}if(s===Oo)throw new Error(`${F} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=s}return n}function Bb(r,e,t){let n=t.useMaps===!0,o=n?void 0:{},s=n?new Map:void 0;for(let i=0;i<r.value;i++){let a=Yn(e,t);if(a===Hi){if(r.value===1/0)break;throw new Error(`${F} got unexpected break to lengthed map`)}if(a===Oo)throw new Error(`${F} found map but not enough entries (got ${i} [no key], expected ${r.value})`);if(n!==!0&&typeof a!="string")throw new Error(`${F} non-string keys not supported (got ${typeof a})`);if(t.rejectDuplicateMapKeys===!0&&(n&&s.has(a)||!n&&a in o))throw new Error(`${F} found repeat map key "${a}"`);let c=Yn(e,t);if(c===Oo)throw new Error(`${F} 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 Yn(r,e){if(r.done())return Oo;let t=r.next();if(t.type===d.break)return Hi;if(t.type.terminal)return t.value;if(t.type===d.array)return Ab(t,r,e);if(t.type===d.map)return Bb(t,r,e);if(t.type===d.tag){if(e.tags&&typeof e.tags[t.value]=="function"){let n=Yn(r,e);return e.tags[t.value](n)}throw new Error(`${F} tag not supported (${t.value})`)}throw new Error("unsupported")}function fu(r,e){if(!(r instanceof Uint8Array))throw new Error(`${F} data to decode must be a Uint8Array`);e=Object.assign({},vb,e);let t=e.tokenizer||new $i(r,e),n=Yn(t,e);if(n===Oo)throw new Error(`${F} did not find any content to decode`);if(n===Hi)throw new Error(`${F} got unexpected break`);return[n,r.subarray(t.pos())]}function ht(r,e){let[t,n]=fu(r,e);if(n.length>0)throw new Error(`${F} too many terminals, data makes no sense`);return t}var nt=ot(pn(),1);var mp=Je("ipns:utils"),yp=Y("/ipns/"),kb=114,gp=async(r,e)=>{if(e==null||r==null){let n=new Error("one or more of the provided parameters are not defined");throw mp.error(n),(0,nt.default)(n,ou)}let t;if(e.pubKey!=null){try{t=tu(e.pubKey)}catch(o){throw mp.error(o),o}if(!(await yf(e.pubKey)).equals(r))throw(0,nt.default)(new Error("Embedded public key did not match PeerID"),cd)}else r.publicKey!=null&&(t=tu(r.publicKey));if(t!=null)return t;throw(0,nt.default)(new Error("no public key is available"),ou)};var wp=r=>{let e=Y("ipns-signature:");return Fe([e,r])},Zr=r=>"signatureV1"in r?xt.encode({value:Y(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:Y(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):xt.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data});function Lt(r){let e=xt.decode(r);if(e.sequence!=null&&(e.sequence=BigInt(e.sequence)),e.ttl!=null&&(e.ttl=BigInt(e.ttl)),e.signatureV2==null||e.data==null)throw(0,nt.default)(new Error("missing data or signatureV2"),nr);let t=bp(e.data),n=Sb(t.Value),o=z(t.Validity);if(e.value!=null&&e.signatureV1!=null)return Ib(e),{value:n,validityType:xt.ValidityType.EOL,validity:o,sequence:t.Sequence,ttl:t.TTL,pubKey:e.pubKey,signatureV1:e.signatureV1,signatureV2:e.signatureV2,data:e.data};if(e.signatureV2!=null)return{value:n,validityType:xt.ValidityType.EOL,validity:o,sequence:t.Sequence,ttl:t.TTL,pubKey:e.pubKey,signatureV2:e.signatureV2,data:e.data};throw new Error("invalid record: does not include signatureV1 or signatureV2")}var hu=r=>Fe([yp,r.toBytes()]),Zn=r=>fo(r.slice(yp.length));var bp=r=>{let e=ht(r);if(e.ValidityType===0)e.ValidityType=xt.ValidityType.EOL;else throw(0,nt.default)(new Error("Unknown validity type"),_i);return Number.isInteger(e.Sequence)&&(e.Sequence=BigInt(e.Sequence)),Number.isInteger(e.TTL)&&(e.TTL=BigInt(e.TTL)),e},Sb=r=>{if(r!=null){if(Qu(r))return`/ipns/${r.toCID().toString(hr)}`;if(r instanceof Uint8Array){let n=z(r);n.startsWith("/")&&(r=n)}let e=r.toString().trim();if(e.startsWith("/")&&e.length>1)return e;let t=oe.asCID(r);if(t!=null)return t.code===kb?`/ipns/${t.toString(hr)}`:`/ipfs/${t.toV1().toString()}`;try{return r instanceof Uint8Array?`/ipfs/${oe.decode(r).toV1().toString()}`:`/ipfs/${oe.parse(e).toV1().toString()}`}catch{}}throw(0,nt.default)(new Error("Value must be a valid content path starting with /"),ad)},Ib=r=>{if(r.data==null)throw(0,nt.default)(new Error("Record data is missing"),id);let e=bp(r.data);if(!ce(e.Value,r.value??new Uint8Array(0)))throw(0,nt.default)(new Error('Field "value" did not match between protobuf and CBOR'),nr);if(!ce(e.Validity,r.validity??new Uint8Array(0)))throw(0,nt.default)(new Error('Field "validity" did not match between protobuf and CBOR'),nr);if(e.ValidityType!==r.validityType)throw(0,nt.default)(new Error('Field "validityType" did not match between protobuf and CBOR'),nr);if(e.Sequence!==r.sequence)throw(0,nt.default)(new Error('Field "sequence" did not match between protobuf and CBOR'),nr);if(e.TTL!==r.ttl)throw(0,nt.default)(new Error('Field "ttl" did not match between protobuf and CBOR'),nr)};var J8=Je("ipns"),X8=st.code,Q8=60*60*1e9,Tb="/ipns/",eS=Tb.length;var Fo=ot(pn(),1),xp=ot(nu(),1);var qi=Je("ipns:validator"),Nb=1024*10,Cb=async(r,e)=>{let t=Lt(e),n;try{let o=wp(t.data);n=await r.verify(o,t.signatureV2)}catch{n=!1}if(!n)throw qi.error("record signature verification failed"),(0,Fo.default)(new Error("record signature verification failed"),nr);if(t.validityType===xt.ValidityType.EOL){if(xp.default.fromString(t.validity).toDate().getTime()<Date.now())throw qi.error("record has expired"),(0,Fo.default)(new Error("record has expired"),sd)}else if(t.validityType!=null)throw qi.error("unrecognized validity type"),(0,Fo.default)(new Error("unrecognized validity type"),_i);qi("ipns record for %s is valid",t.value)};async function Ep(r,e){if(e.byteLength>Nb)throw(0,Fo.default)(new Error("record too large"),ud);let t=Zn(r),n=Lt(e),o=await gp(t,n);await Cb(o,e)}async function*Vo(r){let e=/\r?\n/,t=new TextDecoder("utf8"),n="";for await(let o of r){typeof o=="string"&&(o=new TextEncoder().encode(o)),n+=t.decode(o,{stream:!0});let s=n.split(e);n=s.pop()??"";for(let i=0;i<s.length;i++)yield JSON.parse(s[i])}n+=t.decode(),n!==""&&(yield JSON.parse(n))}var pu=ot(Ap(),1);var $o=class extends Error{constructor(e){super(e),this.name="TimeoutError"}},mu=class extends Error{constructor(e){super(),this.name="AbortError",this.message=e}},Bp=r=>globalThis.DOMException===void 0?new mu(r):new DOMException(r),kp=r=>{let e=r.reason===void 0?Bp("This operation was aborted."):r.reason;return e instanceof Error?e:Bp(e)};function Ho(r,e){let{milliseconds:t,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout}}=e,i,c=new Promise((f,u)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(e.signal){let{signal:h}=e;h.aborted&&u(kp(h)),h.addEventListener("abort",()=>{u(kp(h))})}if(t===Number.POSITIVE_INFINITY){r.then(f,u);return}let l=new $o;i=s.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(h){u(h)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?f():o instanceof Error?u(o):(l.message=o??`Promise timed out after ${t} milliseconds`,u(l))},t),(async()=>{try{f(await r)}catch(h){u(h)}})()}).finally(()=>{c.clear()});return c.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},c}function yu(r,e,t){let n=0,o=r.length;for(;o>0;){let s=Math.trunc(o/2),i=n+s;t(r[i],e)<=0?(n=++i,o-=s+1):o=s}return n}var Ko=class{#e=[];enqueue(e,t){t={priority:0,...t};let n={priority:t.priority,run:e};if(this.size&&this.#e[this.size-1].priority>=t.priority){this.#e.push(n);return}let o=yu(this.#e,n,(s,i)=>i.priority-s.priority);this.#e.splice(o,0,n)}dequeue(){return this.#e.shift()?.run}filter(e){return this.#e.filter(t=>t.priority===e.priority).map(t=>t.run)}get size(){return this.#e.length}};var Ut=class extends pu.default{#e;#t;#r=0;#i;#c;#p=0;#o;#u;#n;#m;#s=0;#l;#a;#y;timeout;constructor(e){if(super(),e={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:Ko,...e},!(typeof e.intervalCap=="number"&&e.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${e.intervalCap?.toString()??""}\` (${typeof e.intervalCap})`);if(e.interval===void 0||!(Number.isFinite(e.interval)&&e.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${e.interval?.toString()??""}\` (${typeof e.interval})`);this.#e=e.carryoverConcurrencyCount,this.#t=e.intervalCap===Number.POSITIVE_INFINITY||e.interval===0,this.#i=e.intervalCap,this.#c=e.interval,this.#n=new e.queueClass,this.#m=e.queueClass,this.concurrency=e.concurrency,this.timeout=e.timeout,this.#y=e.throwOnTimeout===!0,this.#a=e.autoStart===!1}get#b(){return this.#t||this.#r<this.#i}get#x(){return this.#s<this.#l}#E(){this.#s--,this.#f(),this.emit("next")}#v(){this.#w(),this.#g(),this.#u=void 0}get#A(){let e=Date.now();if(this.#o===void 0){let t=this.#p-e;if(t<0)this.#r=this.#e?this.#s:0;else return this.#u===void 0&&(this.#u=setTimeout(()=>{this.#v()},t)),!0}return!1}#f(){if(this.#n.size===0)return this.#o&&clearInterval(this.#o),this.#o=void 0,this.emit("empty"),this.#s===0&&this.emit("idle"),!1;if(!this.#a){let e=!this.#A;if(this.#b&&this.#x){let t=this.#n.dequeue();return t?(this.emit("active"),t(),e&&this.#g(),!0):!1}}return!1}#g(){this.#t||this.#o!==void 0||(this.#o=setInterval(()=>{this.#w()},this.#c),this.#p=Date.now()+this.#c)}#w(){this.#r===0&&this.#s===0&&this.#o&&(clearInterval(this.#o),this.#o=void 0),this.#r=this.#e?this.#s:0,this.#h()}#h(){for(;this.#f(););}get concurrency(){return this.#l}set concurrency(e){if(!(typeof e=="number"&&e>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${e}\` (${typeof e})`);this.#l=e,this.#h()}async#B(e){return new Promise((t,n)=>{e.addEventListener("abort",()=>{n(e.reason)},{once:!0})})}async add(e,t={}){return t={timeout:this.timeout,throwOnTimeout:this.#y,...t},new Promise((n,o)=>{this.#n.enqueue(async()=>{this.#s++,this.#r++;try{t.signal?.throwIfAborted();let s=e({signal:t.signal});t.timeout&&(s=Ho(Promise.resolve(s),{milliseconds:t.timeout})),t.signal&&(s=Promise.race([s,this.#B(t.signal)]));let i=await s;n(i),this.emit("completed",i)}catch(s){if(s instanceof $o&&!t.throwOnTimeout){n();return}o(s),this.emit("error",s)}finally{this.#E()}},t),this.emit("add"),this.#f()})}async addAll(e,t){return Promise.all(e.map(async n=>this.add(n,t)))}start(){return this.#a?(this.#a=!1,this.#h(),this):this}pause(){this.#a=!0}clear(){this.#n=new this.#m}async onEmpty(){this.#n.size!==0&&await this.#d("empty")}async onSizeLessThan(e){this.#n.size<e||await this.#d("next",()=>this.#n.size<e)}async onIdle(){this.#s===0&&this.#n.size===0||await this.#d("idle")}async#d(e,t){return new Promise(n=>{let o=()=>{t&&!t()||(this.off(e,o),n())};this.on(e,o)})}get size(){return this.#n.size}sizeBy(e){return this.#n.filter(e).length}get pending(){return this.#s}get isPaused(){return this.#a}};function Db(r){return r[Symbol.asyncIterator]!=null}function Pb(r){if(Db(r))return(async()=>{for await(let e of r)return e})();for(let e of r)return e}var Gi=Pb;var gu=Y("/ipns/");function Sp(r){return ce(r.subarray(0,gu.byteLength),gu)}var Ip=r=>fo(r.slice(gu.length)),ji=class{client;constructor(e){this.client=e}async*findProviders(e,t={}){yield*yn(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async put(e,t,n){if(!Sp(e))return;let o=Ip(e),s=Lt(t);await this.client.putIPNS(o,s,n)}async get(e,t){if(!Sp(e))throw new N("Not found","ERR_NOT_FOUND");let n=Ip(e);try{let o=await this.client.getIPNS(n,t);return Zr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new N("Not found","ERR_NOT_FOUND"):o}}},Wi=class{client;constructor(e){this.client=e}async findPeer(e,t={}){let n=await Gi(this.client.getPeers(e,t));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new N("Not found","ERR_NOT_FOUND")}async*getClosestPeers(e,t={}){}};var ze=Je("delegated-routing-v1-http-api-client"),Rp={concurrentRequests:4,timeout:3e4},Yi=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;constructor(e,t={}){this.started=!1,this.shutDownController=new AbortController,cr(1/0,this.shutDownController.signal),this.httpQueue=new Ut({concurrency:t.concurrentRequests??Rp.concurrentRequests}),this.clientUrl=e instanceof URL?e:new URL(e),this.timeout=t.timeout??Rp.timeout,this.contentRouting=new ji(this),this.peerRouting=new Wi(this)}get[eo](){return this.contentRouting}get[to](){return this.peerRouting}isStarted(){return this.started}start(){this.started=!0}stop(){this.httpQueue.clear(),this.shutDownController.abort(),this.started=!1}async*getProviders(e,t={}){ze("getProviders starts: %c",e);let n=Dr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=Ie(),s=Ie();this.httpQueue.add(async()=>(o.resolve(),s.promise));try{await o.promise;let i=`${this.clientUrl}routing/v1/providers/${e.toString()}`,c=await fetch(i,{headers:{Accept:"application/x-ndjson"},signal:n});if(c.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new N("Routing response had no body","ERR_BAD_RESPONSE");if(c.headers.get("Content-Type")==="application/json"){let u=await c.json();for(let l of u.Providers){let h=this.#e(l);h!=null&&(yield h)}}else for await(let u of Vo(vs(c.body))){let l=this.#e(u);l!=null&&(yield l)}}catch(i){ze.error("getProviders errored:",i)}finally{n.clear(),s.resolve(),ze("getProviders finished: %c",e)}}async*getPeers(e,t={}){ze("getPeers starts: %c",e);let n=Dr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=Ie(),s=Ie();this.httpQueue.add(async()=>(o.resolve(),s.promise));try{await o.promise;let i=`${this.clientUrl}routing/v1/peers/${e.toCID().toString()}`,c=await fetch(i,{headers:{Accept:"application/x-ndjson"},signal:n});if(c.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new N("Routing response had no body","ERR_BAD_RESPONSE");if(c.headers.get("Content-Type")==="application/json"){let u=await c.json();for(let l of u.Peers){let h=this.#e(l);h!=null&&(yield h)}}else for await(let u of Vo(vs(c.body))){let l=this.#e(u);l!=null&&(yield l)}}catch(i){ze.error("getPeers errored:",i)}finally{n.clear(),s.resolve(),ze("getPeers finished: %c",e)}}async getIPNS(e,t={}){ze("getIPNS starts: %c",e);let n=Dr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=Ie(),s=Ie();this.httpQueue.add(async()=>(o.resolve(),s.promise));let i=`${this.clientUrl}routing/v1/ipns/${e.toCID().toString()}`;try{await o.promise;let c=await fetch(i,{headers:{Accept:"application/vnd.ipfs.ipns-record"},signal:n});if(ze("getIPNS GET %s %d",i,c.status),c.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new N("GET ipns response had no body","ERR_BAD_RESPONSE");let f=await c.arrayBuffer(),u=new Uint8Array(f,0,f.byteLength);return t.validate!==!1&&await Ep(hu(e),u),Lt(u)}catch(a){throw ze.error("getIPNS GET %s error:",i,a),a}finally{n.clear(),s.resolve(),ze("getIPNS finished: %c",e)}}async putIPNS(e,t,n={}){ze("putIPNS starts: %c",e);let o=Dr([this.shutDownController.signal,n.signal,AbortSignal.timeout(this.timeout)]),s=Ie(),i=Ie();this.httpQueue.add(async()=>(s.resolve(),i.promise));let a=`${this.clientUrl}routing/v1/ipns/${e.toCID().toString()}`;try{await s.promise;let c=Zr(t),u=await fetch(a,{method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:c,signal:o});if(ze("putIPNS PUT %s %d",a,u.status),u.status!==200)throw new N("PUT ipns response had status other than 200","ERR_BAD_RESPONSE")}catch(c){throw ze.error("putIPNS PUT %s error:",a,c.stack),c}finally{o.clear(),i.resolve(),ze("putIPNS finished: %c",e)}}#e(e){let t=[],n=e.Addrs?.map(Fr)??[];return e.Protocols!=null&&t.push(...e.Protocols),e.Protocol!=null&&(t.push(e.Protocol),delete e.Protocol),{...e,Schema:"peer",ID:xc(e.ID),Addrs:n,Protocols:t}}};function _p(r,e={}){return new Yi(new URL(r),e)}var Tp=Y("/ipns/");function Np(r){return ce(r.subarray(0,Tp.byteLength),Tp)}var wu=class{client;constructor(e){this.client=_p(e)}async provide(e,t){}async*findProviders(e,t){yield*yn(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs,protocols:n.Protocols}))}async put(e,t,n){if(!Np(e))return;let o=Zn(e),s=Lt(t);await this.client.putIPNS(o,s,n)}async get(e,t){if(!Np(e))throw new N("Not found","ERR_NOT_FOUND");let n=Zn(e);try{let o=await this.client.getIPNS(n,t);return Zr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new N("Not found","ERR_NOT_FOUND"):o}}async findPeer(e,t){let n=await Gi(this.client.getPeers(e,t));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new N("Not found","ERR_NOT_FOUND")}async*getClosestPeers(e,t){}};function bu(r){return new wu(new URL(r))}function Zi(r){let e=[At.A];return r==null?e:Array.isArray(r)?r.length===0?e:r:[r]}var xu=60;function Ji(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(e=>({name:e.name,type:At[e.type]})),Answer:(r.Answer??r.answers??[]).map(e=>({name:e.name,type:At[e.type],TTL:e.TTL??e.ttl??xu,data:e.data instanceof Uint8Array?z(e.data):e.data}))}}var Ob=4;function Eu(r,e={}){let t=new Ut({concurrency:e.queryConcurrency??Ob});return async(n,o={})=>{let s=new URLSearchParams;s.set("name",n),Zi(o.types).forEach(a=>{s.append("type",At[a])}),o.onProgress?.(new ne("dns:query",{detail:n}));let i=await t.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=Ji(await a.json());return o.onProgress?.(new ne("dns:response",{detail:c})),c},{signal:o.signal});if(i==null)throw new Error("No DNS response received");return i}}function Cp(){return[Eu("https://cloudflare-dns.com/dns-query"),Eu("https://dns.google/resolve")]}var Dp=ot(Up(),1);var vu=class{lru;constructor(e){this.lru=(0,Dp.default)(e)}get(e,t){let n=!0,o=[];for(let s of t){let i=this.getAnswers(e,s);if(i.length===0){n=!1;break}o.push(...i)}if(n)return Ji({answers:o})}getAnswers(e,t){let n=`${e.toLowerCase()}-${t}`,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:At[a.type]}));return s.length===0&&this.lru.remove(n),s}return[]}add(e,t){let n=`${e.toLowerCase()}-${t.type}`,o=this.lru.get(n)??[];o.push({expires:Date.now()+(t.TTL??xu)*1e3,value:t}),this.lru.set(n,o)}remove(e,t){let n=`${e.toLowerCase()}-${t}`;this.lru.remove(n)}clear(){this.lru.clear()}};function Pp(r){return new vu(r)}var Fb=1e3,Xi=class{resolvers;cache;constructor(e){this.resolvers={},this.cache=Pp(e.cacheSize??Fb),Object.entries(e.resolvers??{}).forEach(([t,n])=>{Array.isArray(n)||(n=[n]),t.endsWith(".")||(t=`${t}.`),this.resolvers[t]=n}),this.resolvers["."]==null&&(this.resolvers["."]=Cp())}async query(e,t={}){let n=Zi(t.types),o=t.cached!==!1?this.cache.get(e,n):void 0;if(o!=null)return t.onProgress?.(new ne("dns:cache",{detail:o})),o;let s=`${e.split(".").pop()}.`,i=(this.resolvers[s]??this.resolvers["."]).sort(()=>Math.random()>.5?-1:1),a=[];for(let c of i){if(t.signal?.aborted===!0)break;try{let f=await c(e,{...t,types:n});for(let u of f.Answer)this.cache.add(e,u);return f}catch(f){a.push(f),t.onProgress?.(new ne("dns:error",{detail:f}))}}throw a.length===1?a[0]:new AggregateError(a,`DNS lookup of ${e} ${n} failed`)}};var At;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(At||(At={}));function Op(r={}){return new Xi(r)}var $p="/pin/",Fp="/pinned-block/",Au=hr,Vp=1;function Mp(r){return r.version===0&&(r=r.toV1()),new Ne(`${$p}${r.toString(Au)}`)}var Qi=class{datastore;blockstore;dagWalkers;constructor(e,t,n){this.datastore=e,this.blockstore=t,this.dagWalkers=n}async*add(e,t={}){let n=Mp(e);if(await this.datastore.has(n))throw new Error("Already pinned");let o=Math.round(t.depth??1/0);if(o<0)throw new Error("Depth must be greater than or equal to 0");let s=new Pr({concurrency:Vp});for await(let a of this.#e(e,s,{...t,depth:o}))await this.#t(a,c=>c.pinnedBy.find(f=>ce(f,e.bytes))!=null?!1:(c.pinCount++,c.pinnedBy.push(e.bytes),!0),t),yield a;let i={depth:o,metadata:t.metadata??{}};await this.datastore.put(n,Wn(i),t)}async*#e(e,t,n){if(n.depth===-1)return;let o=this.dagWalkers[e.code];if(o==null)throw new Error(`No dag walker found for cid codec ${e.code}`);let s=await this.blockstore.get(e,n);yield e;for await(let i of o.walk(s))yield*await t.add(async()=>this.#e(i,t,{...n,depth:n.depth-1}))}async#t(e,t,n){let o=new Ne(`${Fp}${Au.encode(e.multihash.bytes)}`),s={pinCount:0,pinnedBy:[]};try{s=ht(await this.datastore.get(o,n))}catch(a){if(a.code!=="ERR_NOT_FOUND")throw a}if(t(s)){if(s.pinCount===0&&await this.datastore.has(o)){await this.datastore.delete(o);return}await this.datastore.put(o,Wn(s),n),n.onProgress?.(new ne("helia:pin:add",e))}}async*rm(e,t={}){let n=Mp(e),o=await this.datastore.get(n,t),s=ht(o);await this.datastore.delete(n,t);let i=new Pr({concurrency:Vp});for await(let a of this.#e(e,i,{...t,depth:s.depth}))await this.#t(a,c=>(c.pinCount--,c.pinnedBy=c.pinnedBy.filter(f=>ce(f,e.bytes)),!0),{...t,depth:s.depth}),yield a}async*ls(e={}){for await(let{key:t,value:n}of this.datastore.query({prefix:$p+(e.cid!=null?`${e.cid.toString(hr)}`:"")},e)){let o=oe.parse(t.toString().substring(5),hr),s=ht(n);yield{cid:o,...s}}}async isPinned(e,t={}){let n=new Ne(`${Fp}${Au.encode(e.multihash.bytes)}`);return this.datastore.has(n,t)}};var ea=class{log;routers;constructor(e,t){this.log=e.logger.forComponent("helia:routing"),this.routers=t.routers??[]}async start(){await ur(...this.routers)}async stop(){await lr(...this.routers)}async*findProviders(e,t={}){if(this.routers.length===0)throw new N("No content routers available","ERR_NO_ROUTERS_AVAILABLE");for await(let n of mr(...Jn(this.routers,"findProviders").map(o=>o.findProviders(e,t))))n!=null&&(yield n)}async provide(e,t={}){if(this.routers.length===0)throw new N("No content routers available","ERR_NO_ROUTERS_AVAILABLE");await Promise.all(Jn(this.routers,"provide").map(async n=>{await n.provide(e,t)}))}async put(e,t,n){await Promise.all(Jn(this.routers,"put").map(async o=>{await o.put(e,t,n)}))}async get(e,t){return Promise.any(Jn(this.routers,"get").map(async n=>n.get(e,t)))}async findPeer(e,t){if(this.routers.length===0)throw new N("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");let n=this,o=mr(...Jn(this.routers,"findPeer").map(s=>async function*(){try{yield await s.findPeer(e,t)}catch(i){n.log.error(i)}}()));for await(let s of o)if(s!=null)return s;throw new N("Could not find peer in routing","ERR_NOT_FOUND")}async*getClosestPeers(e,t={}){if(this.routers.length===0)throw new N("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");for await(let n of mr(...Jn(this.routers,"getClosestPeers").map(o=>o.getClosestPeers(e,t))))n!=null&&(yield n)}};function Jn(r,e){return r.filter(t=>t[e]!=null)}var Nr={},Xn=r=>{r.addEventListener("message",e=>{Xn.dispatchEvent("message",r,e)}),r.port!=null&&r.port.addEventListener("message",e=>{Xn.dispatchEvent("message",r,e)})};Xn.addEventListener=(r,e)=>{Nr[r]==null&&(Nr[r]=[]),Nr[r].push(e)};Xn.removeEventListener=(r,e)=>{Nr[r]!=null&&(Nr[r]=Nr[r].filter(t=>t===e))};Xn.dispatchEvent=function(r,e,t){Nr[r]!=null&&Nr[r].forEach(n=>n(e,t))};var Bu=Xn;var ku="lock:worker:request-read",Su="lock:worker:release-read",Iu="lock:master:grant-read",Ru="lock:worker:request-write",_u="lock:worker:release-write",Tu="lock:master:grant-write";var Hp=(r=21)=>Math.random().toString().substring(2);var Kp=(r,e,t,n,o)=>(s,i)=>{if(i.data.type!==t)return;let a={type:i.data.type,name:i.data.name,identifier:i.data.identifier};r.dispatchEvent(new MessageEvent(e,{data:{name:a.name,handler:async()=>{s.postMessage({type:o,name:a.name,identifier:a.identifier}),await new Promise(c=>{let f=u=>{if(u==null||u.data==null)return;let l={type:u.data.type,name:u.data.name,identifier:u.data.identifier};l.type===n&&l.identifier===a.identifier&&(s.removeEventListener("message",f),c())};s.addEventListener("message",f)})}}}))},qp=(r,e,t,n)=>async()=>{let o=Hp();return globalThis.postMessage({type:e,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===t&&c.identifier===o&&(globalThis.removeEventListener("message",i),s(()=>{globalThis.postMessage({type:n,identifier:o,name:r})}))};globalThis.addEventListener("message",i)})},Vb={singleProcess:!1},zp=r=>{if(r=Object.assign({},Vb,r),!!globalThis.document||r.singleProcess){let t=new EventTarget;return Bu.addEventListener("message",Kp(t,"requestReadLock",ku,Su,Iu)),Bu.addEventListener("message",Kp(t,"requestWriteLock",Ru,_u,Tu)),t}return{isWorker:!0,readLock:t=>qp(t,ku,Iu,Su),writeLock:t=>qp(t,Ru,Tu,_u)}};var Jr={},Cr;async function Nu(r,e){let t,n=new Promise(o=>{t=o});return r.add(async()=>Ho((async()=>{await new Promise(o=>{t(()=>{o()})})})(),{milliseconds:e.timeout})),n}var Mb=(r,e)=>{if(Cr.isWorker===!0)return{readLock:Cr.readLock(r,e),writeLock:Cr.writeLock(r,e)};let t=new Ut({concurrency:1}),n;return{async readLock(){if(n!=null)return Nu(n,e);n=new Ut({concurrency:e.concurrency,autoStart:!1});let o=n,s=Nu(n,e);return t.add(async()=>{o.start(),await o.onIdle().then(()=>{n===o&&(n=null)})}),s},async writeLock(){return n=null,Nu(t,e)}}},$b={name:"lock",concurrency:1/0,timeout:846e5,singleProcess:!1};function Cu(r){let e=Object.assign({},$b,r);return Cr==null&&(Cr=zp(e),Cr.isWorker!==!0&&(Cr.addEventListener("requestReadLock",t=>{Jr[t.data.name]!=null&&Jr[t.data.name].readLock().then(async n=>t.data.handler().finally(()=>{n()}))}),Cr.addEventListener("requestWriteLock",async t=>{Jr[t.data.name]!=null&&Jr[t.data.name].writeLock().then(async n=>t.data.handler().finally(()=>{n()}))}))),Jr[e.name]==null&&(Jr[e.name]=Mb(e.name,e)),Jr[e.name]}var ta=class{lock;child;pins;started;constructor(e,t,n={}){this.child=e,this.pins=t,this.lock=Cu({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await ur(this.child),this.started=!0}async stop(){await lr(this.child),this.started=!1}unwrap(){return this.child}async put(e,t,n={}){let o=await this.lock.readLock();try{return await this.child.put(e,t,n)}finally{o()}}async*putMany(e,t={}){let n=await this.lock.readLock();try{yield*this.child.putMany(e,t)}finally{n()}}async get(e,t={}){let n=await this.lock.readLock();try{return await this.child.get(e,t)}finally{n()}}async*getMany(e,t={}){let n=await this.lock.readLock();try{yield*this.child.getMany(e,t)}finally{n()}}async delete(e,t={}){let n=await this.lock.writeLock();try{if(await this.pins.isPinned(e))throw new Error("CID was pinned");await this.child.delete(e,t)}finally{n()}}async*deleteMany(e,t={}){let n=await this.lock.writeLock();try{let o=this;yield*this.child.deleteMany(async function*(){for await(let s of e){if(await o.pins.isPinned(s))throw new Error("CID was pinned");yield s}}(),t)}finally{n()}}async has(e,t={}){let n=await this.lock.readLock();try{return await this.child.has(e,t)}finally{n()}}async*getAll(e={}){let t=await this.lock.readLock();try{yield*this.child.getAll(e)}finally{t()}}async createSession(e,t){let n=await this.lock.readLock();try{let o=await this.child.createSession(e,t);if(o==null)throw new N("Sessions not supported","ERR_UNSUPPORTED");return o}finally{n()}}};var jp=42;function Hb(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let e=oe.asCID(r);if(!e)return null;let t=new Uint8Array(e.bytes.byteLength+1);return t.set(e.bytes,1),[new A(d.tag,jp),new A(d.bytes,t)]}function Kb(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function qb(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 Gp={float64:!0,typeEncoders:{Object:Hb,undefined:Kb,number:qb}},n6={...Gp,typeEncoders:{...Gp.typeEncoders}};function zb(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return oe.decode(r.subarray(1))}var Lu={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Lu.tags[jp]=zb;var o6={...Lu,tags:Lu.tags.slice()};var Wp=113;var Yp=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(e){let t=this.inRecursive[this.inRecursive.length-1];t&&(t.type===d.array&&(t.elements++,t.elements!==1&&e.push([44])),t.type===d.map&&(t.elements++,t.elements!==1&&(t.elements%2===1?e.push([44]):e.push([58]))))}[d.uint.major](e,t){this.prefix(e);let n=String(t.value),o=[];for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);e.push(o)}[d.negint.major](e,t){this[d.uint.major](e,t)}[d.bytes.major](e,t){throw new Error(`${qn} unsupported type: Uint8Array`)}[d.string.major](e,t){this.prefix(e);let n=Ni(JSON.stringify(t.value));e.push(n.length>32?Co(n):n)}[d.array.major](e,t){this.prefix(e),this.inRecursive.push({type:d.array,elements:0}),e.push([91])}[d.map.major](e,t){this.prefix(e),this.inRecursive.push({type:d.map,elements:0}),e.push([123])}[d.tag.major](e,t){}[d.float.major](e,t){if(t.type.name==="break"){let i=this.inRecursive.pop();if(i){if(i.type===d.array)e.push([93]);else if(i.type===d.map)e.push([125]);else throw new Error("Unexpected recursive type; this should not happen!");return}throw new Error("Unexpected break; this should not happen!")}if(t.value===void 0)throw new Error(`${qn} unsupported type: undefined`);if(this.prefix(e),t.type.name==="true"){e.push([116,114,117,101]);return}else if(t.type.name==="false"){e.push([102,97,108,115,101]);return}else if(t.type.name==="null"){e.push([110,117,108,108]);return}let n=String(t.value),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)),e.push(o)}};var Xr=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t,this.modeStack=["value"],this.lastToken=""}pos(){return this._pos}done(){return this._pos>=this.data.length}ch(){return this.data[this._pos]}currentMode(){return this.modeStack[this.modeStack.length-1]}skipWhitespace(){let e=this.ch();for(;e===32||e===9||e===13||e===10;)e=this.data[++this._pos]}expect(e){if(this.data.length-this._pos<e.length)throw new Error(`${F} unexpected end of input at position ${this._pos}`);for(let t=0;t<e.length;t++)if(this.data[this._pos++]!==e[t])throw new Error(`${F} unexpected token at position ${this._pos}, expected to find '${String.fromCharCode(...e)}'`)}parseNumber(){let e=this._pos,t=!1,n=!1,o=a=>{for(;!this.done();){let c=this.ch();if(a.includes(c))this._pos++;else break}};if(this.ch()===45&&(t=!0,this._pos++),this.ch()===48)if(this._pos++,this.ch()===46)this._pos++,n=!0;else return new A(d.uint,0,this._pos-e);if(o([48,49,50,51,52,53,54,55,56,57]),t&&this._pos===e+1)throw new Error(`${F} unexpected token at position ${this._pos}`);if(!this.done()&&this.ch()===46){if(n)throw new Error(`${F} 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(e,this._pos)),i=parseFloat(s);return n?new A(d.float,i,this._pos-e):this.options.allowBigInt!==!0||Number.isSafeInteger(i)?new A(i>=0?d.uint:d.negint,i,this._pos-e):new A(i>=0?d.uint:d.negint,BigInt(s),this._pos-e)}parseString(){if(this.ch()!==34)throw new Error(`${F} 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 A(d.string,c,i)}}let e=this._pos,t=[],n=()=>{if(this._pos+4>=this.data.length)throw new Error(`${F} 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(`${F} 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(`${F} unexpected unicode sequence at position ${this._pos}`);let c,f,u,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],f=this.data[this._pos+2],(c&192)===128&&(f&192)===128&&(l=(s&15)<<12|(c&63)<<6|f&63,l>2047&&(l<55296||l>57343)&&(i=l));break;case 4:c=this.data[this._pos+1],f=this.data[this._pos+2],u=this.data[this._pos+3],(c&192)===128&&(f&192)===128&&(u&192)===128&&(l=(s&15)<<18|(c&63)<<12|(f&63)<<6|u&63,l>65535&&l<1114112&&(i=l))}i===null?(i=65533,a=1):i>65535&&(i-=65536,t.push(i>>>10&1023|55296),i=56320|i&1023),t.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(`${F} unexpected string termination at position ${this._pos}`);switch(i=this.ch(),this._pos++,i){case 34:case 39:case 92:case 47:t.push(i);break;case 98:t.push(8);break;case 116:t.push(9);break;case 110:t.push(10);break;case 102:t.push(12);break;case 114:t.push(13);break;case 117:t.push(n());break;default:throw new Error(`${F} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new A(d.string,su(t),this._pos-e);default:if(s<32)throw new Error(`${F} invalid control character at position ${this._pos}`);s<128?(t.push(s),this._pos++):o()}}throw new Error(`${F} unexpected end of string at position ${this._pos}`)}parseValue(){switch(this.ch()){case 123:return this.modeStack.push("obj-start"),this._pos++,new A(d.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new A(d.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new A(d.null,null,4);case 102:return this.expect([102,97,108,115,101]),new A(d.false,!1,5);case 116:return this.expect([116,114,117,101]),new A(d.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(`${F} 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 A(d.break,void 0,1);if(this.ch()!==44)throw new Error(`${F} 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 A(d.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 A(d.break,void 0,1);if(this.ch()!==44)throw new Error(`${F} 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 A(d.break,void 0,1);let e=this.parseString();if(this.skipWhitespace(),this.ch()!==58)throw new Error(`${F} unexpected character at position ${this._pos}, was expecting key/value delimiter ':' but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("obj-value"),e}case"obj-value":return this.modeStack.pop(),this.modeStack.push("obj-key"),this.skipWhitespace(),this.parseValue();default:throw new Error(`${F} unexpected parse state at position ${this._pos}; this shouldn't happen`)}}};function ra(r,e){return e=Object.assign({tokenizer:new Xr(r,e)},e),ht(r,e)}var Wb={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Wb.tags[42]=oe.parse;var Jp=297;var E6=new TextDecoder;var v6=new TextEncoder;var Zb=new TextDecoder;function Uu(r,e){let t=0;for(let n=0;;n+=7){if(n>=64)throw new Error("protobuf: varint overflow");if(e>=r.length)throw new Error("protobuf: unexpected end of data");let o=r[e++];if(t+=n<28?(o&127)<<n:(o&127)*2**n,o<128)break}return[t,e]}function na(r,e){let t;[t,e]=Uu(r,e);let n=e+t;if(t<0||n<0)throw new Error("protobuf: invalid length");if(n>r.length)throw new Error("protobuf: unexpected end of data");return[r.subarray(e,n),n]}function Xp(r,e){let t;return[t,e]=Uu(r,e),[t&7,t>>3,e]}function Jb(r){let e={},t=r.length,n=0;for(;n<t;){let o,s;if([o,s,n]=Xp(r,n),s===1){if(e.Hash)throw new Error("protobuf: (PBLink) duplicate Hash section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Hash`);if(e.Name!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Name before Hash");if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Hash");[e.Hash,n]=na(r,n)}else if(s===2){if(e.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(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Name");let i;[i,n]=na(r,n),e.Name=Zb.decode(i)}else if(s===3){if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) duplicate Tsize section");if(o!==0)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Tsize`);[e.Tsize,n]=Uu(r,n)}else throw new Error(`protobuf: (PBLink) invalid fieldNumber, expected 1, 2 or 3, got ${s}`)}if(n>t)throw new Error("protobuf: (PBLink) unexpected end of data");return e}function Qp(r){let e=r.length,t=0,n,o=!1,s;for(;t<e;){let a,c;if([a,c,t]=Xp(r,t),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,t]=na(r,t),n&&(o=!0)}else if(c===2){if(o)throw new Error("protobuf: (PBNode) duplicate Links section");n||(n=[]);let f;[f,t]=na(r,t),n.push(Jb(f))}else throw new Error(`protobuf: (PBNode) invalid fieldNumber, expected 1 or 2, got ${c}`)}if(t>e)throw new Error("protobuf: (PBNode) unexpected end of data");let i={};return s&&(i.Data=s),i.Links=n||[],i}var B6=new TextEncoder,k6=2**32,S6=2**31;var _6=new TextEncoder;function e0(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var t0=112;function r0(r){let e=e0(r),t=Qp(e),n={};return t.Data&&(n.Data=t.Data),t.Links&&(n.Links=t.Links.map(o=>{let s={};try{s.Hash=oe.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 Qb={codec:t0,*walk(r){yield*r0(r).Links.map(t=>t.Hash)}},ex={codec:is,*walk(){}},n0=42,tx={codec:Wp,*walk(r){let e=[],t=[];t[n0]=n=>{if(n[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");let o=oe.decode(n.subarray(1));return e.push(o),o},ht(r,{tags:t}),yield*e}},Du=class extends Xr{tokenBuffer;constructor(e,t){super(e,t),this.tokenBuffer=[]}done(){return this.tokenBuffer.length===0&&super.done()}_next(){return this.tokenBuffer.length>0?this.tokenBuffer.pop():super.next()}next(){let e=this._next();if(e.type===d.map){let t=this._next();if(t.type===d.string&&t.value==="/"){let n=this._next();if(n.type===d.string){if(this._next().type!==d.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new A(d.tag,42,0)}if(n.type===d.map){let o=this._next();if(o.type===d.string&&o.value==="bytes"){let s=this._next();if(s.type===d.string){for(let a=0;a<2;a++)if(this._next().type!==d.break)throw new Error("Invalid encoded Bytes form");let i=dr.decode(`m${s.value}`);return new A(d.bytes,i,s.value.length)}this.tokenBuffer.push(s)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(t)}return e}},rx={codec:Jp,*walk(r){let e=[],t=[];t[n0]=n=>{let o=oe.parse(n);return e.push(o),o},ra(r,{tags:t,tokenizer:new Du(r,{tags:t,allowIndefinite:!0,allowUndefined:!0,allowNaN:!0,allowInfinity:!0,allowBigInt:!0,strict:!1,rejectDuplicateMapKeys:!1})}),yield*e}},nx={codec:wl,*walk(){}};function o0(r=[]){let e={};return[Qb,ex,tx,rx,nx,...r].forEach(t=>{e[t.codec]=t}),e}var Pu=new Ne("/version"),s0=1;async function i0(r){if(!await r.has(Pu)){await r.put(Pu,Y(`${s0}`));return}let e=await r.get(Pu),t=z(e);if(parseInt(t,10)!==s0)throw new Error("Unknown datastore version, a datastore migration may be required")}function a0(r=[]){let e={};return[Ee,Oa,st,...r].forEach(t=>{e[t.code]=t}),e}var Dt=class{has(e,t){return Promise.reject(new Error(".has is not implemented"))}put(e,t,n){return Promise.reject(new Error(".put is not implemented"))}async*putMany(e,t){for await(let{cid:n,block:o}of e)await this.put(n,o,t),yield n}get(e,t){return Promise.reject(new Error(".get is not implemented"))}async*getMany(e,t){for await(let n of e)yield{cid:n,block:await this.get(n,t)}}delete(e,t){return Promise.reject(new Error(".delete is not implemented"))}async*deleteMany(e,t){for await(let n of e)await this.delete(n,t),yield n}async*getAll(e){throw new Error(".getAll is not implemented")}};var Qr={};xe(Qr,{abortedError:()=>cx,closeFailedError:()=>sx,deleteFailedError:()=>Fu,getFailedError:()=>ix,hasFailedError:()=>ax,notFoundError:()=>Lr,openFailedError:()=>ox,putFailedError:()=>Ou});var sr=ot(pn(),1);function ox(r){return r=r??new Error("Open failed"),(0,sr.default)(r,"ERR_OPEN_FAILED")}function sx(r){return r=r??new Error("Close failed"),(0,sr.default)(r,"ERR_CLOSE_FAILED")}function Ou(r){return r=r??new Error("Put failed"),(0,sr.default)(r,"ERR_PUT_FAILED")}function ix(r){return r=r??new Error("Get failed"),(0,sr.default)(r,"ERR_GET_FAILED")}function Fu(r){return r=r??new Error("Delete failed"),(0,sr.default)(r,"ERR_DELETE_FAILED")}function ax(r){return r=r??new Error("Has failed"),(0,sr.default)(r,"ERR_HAS_FAILED")}function Lr(r){return r=r??new Error("Not Found"),(0,sr.default)(r,"ERR_NOT_FOUND")}function cx(r){return r=r??new Error("Aborted"),(0,sr.default)(r,"ERR_ABORTED")}var c0=0,oa=class extends Dt{put(e){return e}get(e){if(e.code===c0)return e.multihash.digest;throw Lr()}has(e){return e.code===c0}delete(){}*getAll(){}};var ux=Je("blockstore:core:tiered"),qo=class extends Dt{stores;constructor(e){super(),this.stores=e.slice()}async put(e,t,n){try{return await Promise.all(this.stores.map(async o=>{await o.put(e,t,n)})),e}catch(o){throw Ou(o)}}async get(e,t){for(let n of this.stores)try{let o=await n.get(e,t);if(o!=null)return o}catch(o){ux.error(o)}throw Lr()}async has(e,t){for(let n of this.stores)if(await n.has(e,t))return!0;return!1}async delete(e,t){try{await Promise.all(this.stores.map(async n=>{await n.delete(e,t)}))}catch(n){throw Fu(n)}}async*putMany(e,t={}){let n,o=this.stores.map(s=>{let i=Ft({objectMode:!0});return $t(s.putMany(i,t)).catch(a=>{n=a}),i});try{for await(let s of e){if(n!=null)throw n;o.forEach(i=>i.push(s)),yield s.cid}}finally{o.forEach(s=>s.end())}}async*deleteMany(e,t={}){let n,o=this.stores.map(s=>{let i=Ft({objectMode:!0});return $t(s.deleteMany(i,t)).catch(a=>{n=a}),i});try{for await(let s of e){if(n!=null)throw n;o.forEach(i=>i.push(s)),yield s}}finally{o.forEach(s=>s.end())}}async*getAll(e){let t=new Set;yield*it(mr(...this.stores.map(n=>n.getAll(e))),n=>{let o=n.cid.toString();return t.has(o)?!1:(t.add(o),!0)})}};function lx(r){return r[Symbol.asyncIterator]!=null}function u0(r){return r?.then!=null}function fx(r,e){if(lx(r))return async function*(){for await(let a of r){let c=e(a);u0(c)&&await c,yield a}}();let t=mn(r),{value:n,done:o}=t.next();if(o===!0)return function*(){}();if(typeof e(n)?.then=="function")return async function*(){yield n;for await(let a of t){let c=e(a);u0(c)&&await c,yield a}}();let i=e;return function*(){yield n;for(let a of t)i(a),yield a}()}var Vu=fx;var sa=class r{child;hashers;started;log;logger;components;constructor(e,t={}){this.log=e.logger.forComponent(`helia:networked-storage${t.root==null?"":`:${t.root}`}`),this.logger=e.logger,this.components=e,this.child=new qo([new oa,e.blockstore]),this.hashers=e.hashers??{},this.started=!1}isStarted(){return this.started}async start(){await ur(this.child,...this.components.blockBrokers),this.started=!0}async stop(){await lr(this.child,...this.components.blockBrokers),this.started=!1}unwrap(){return this.child}async put(e,t,n={}){return await this.child.has(e)?(n.onProgress?.(new ne("blocks:put:duplicate",e)),e):(n.onProgress?.(new ne("blocks:put:providers:notify",e)),await Promise.all(this.components.blockBrokers.map(async o=>o.announce?.(e,t,n))),n.onProgress?.(new ne("blocks:put:blockstore:put",e)),this.child.put(e,t,n))}async*putMany(e,t={}){let n=it(e,async({cid:s})=>{let i=await this.child.has(s);return i&&t.onProgress?.(new ne("blocks:put-many:duplicate",s)),!i}),o=Vu(n,async({cid:s,block:i})=>{t.onProgress?.(new ne("blocks:put-many:providers:notify",s)),await Promise.all(this.components.blockBrokers.map(async a=>a.announce?.(s,i,t)))});t.onProgress?.(new ne("blocks:put-many:blockstore:put-many")),yield*this.child.putMany(o,t)}async get(e,t={}){if(t.offline!==!0&&!await this.child.has(e)){t.onProgress?.(new ne("blocks:get:providers:get",e));let n=await l0(e,this.components.blockBrokers,this.hashers[e.multihash.code],{...t,log:this.log});return t.onProgress?.(new ne("blocks:get:blockstore:put",e)),await this.child.put(e,n,t),t.onProgress?.(new ne("blocks:get:providers:notify",e)),await Promise.all(this.components.blockBrokers.map(async o=>o.announce?.(e,n,t))),n}return t.onProgress?.(new ne("blocks:get:blockstore:get",e)),this.child.get(e,t)}async*getMany(e,t={}){t.onProgress?.(new ne("blocks:get-many:blockstore:get-many")),yield*this.child.getMany(Vu(e,async n=>{if(t.offline!==!0&&!await this.child.has(n)){t.onProgress?.(new ne("blocks:get-many:providers:get",n));let o=await l0(n,this.components.blockBrokers,this.hashers[n.multihash.code],{...t,log:this.log});t.onProgress?.(new ne("blocks:get-many:blockstore:put",n)),await this.child.put(n,o,t),t.onProgress?.(new ne("blocks:get-many:providers:notify",n)),await Promise.all(this.components.blockBrokers.map(async s=>s.announce?.(n,o,t)))}}))}async delete(e,t={}){t.onProgress?.(new ne("blocks:delete:blockstore:delete",e)),await this.child.delete(e,t)}async*deleteMany(e,t={}){t.onProgress?.(new ne("blocks:delete-many:blockstore:delete-many")),yield*this.child.deleteMany(async function*(){for await(let n of e)yield n}(),t)}async has(e,t={}){return this.child.has(e,t)}async*getAll(e={}){e.onProgress?.(new ne("blocks:get-all:blockstore:get-many")),yield*this.child.getAll(e)}async createSession(e,t){let n=await Promise.all(this.components.blockBrokers.map(async o=>o.createSession==null?o:o.createSession(e,t)));return new r({blockstore:this.child,blockBrokers:n,hashers:this.hashers,logger:this.logger},{root:e})}};function hx(r){return typeof r.retrieve=="function"}var dx=(r,e)=>{if(e==null)throw new N(`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 t=>{let n=await e.digest(t);if(!ce(n.digest,r.multihash.digest))throw new N("Hash of downloaded block did not match multihash from passed CID","ERR_HASH_MISMATCH")}};async function l0(r,e,t,n){let o=dx(r,t),s=new AbortController,i=Dr([s.signal,n.signal]);cr(1/0,s.signal,i);let a=[];for(let c of e)hx(c)&&a.push(c);try{return await Promise.any(a.map(async c=>{try{let f=!1,u=await c.retrieve(r,{...n,signal:i,validateFn:async l=>{await o(l),f=!0}});return f||await o(u),u}catch(f){throw n.log.error("could not retrieve verified block for %c",r,f),f}}))}finally{s.abort(),i.clear()}}var ia=class{blockstore;datastore;pins;logger;routing;dagWalkers;hashers;dns;log;constructor(e){this.logger=e.logger??kf(),this.log=this.logger.forComponent("helia"),this.hashers=a0(e.hashers),this.dagWalkers=o0(e.dagWalkers),this.dns=e.dns??Op();let t={blockstore:e.blockstore,datastore:e.datastore,hashers:this.hashers,dagWalkers:this.dagWalkers,logger:this.logger,blockBrokers:[],dns:this.dns,...e.components??{}};this.routing=t.routing=new ea(t,{routers:(e.routers??[]).flatMap(o=>{let s=[o];return o[eo]!=null&&s.push(o[eo]),o[to]!=null&&s.push(o[to]),s})});let n=new sa(t);this.pins=new Qi(e.datastore,n,this.dagWalkers),this.blockstore=new ta(n,this.pins,{holdGcLock:e.holdGcLock??!0}),this.datastore=e.datastore,t.blockBrokers=e.blockBrokers.map(o=>o(t))}async start(){await i0(this.datastore),await ur(this.blockstore,this.datastore,this.routing)}async stop(){await lr(this.blockstore,this.datastore,this.routing)}async gc(e={}){let t=await this.blockstore.lock.writeLock();try{let n=this,o=this.blockstore.unwrap();this.log("gc start"),await $t(o.deleteMany(async function*(){for await(let{cid:s}of o.getAll())try{if(await n.pins.isPinned(s,e))continue;yield s,e.onProgress?.(new ne("helia:gc:deleted",s))}catch(i){n.log.error("Error during gc",i),e.onProgress?.(new ne("helia:gc:error",i))}}()))}finally{t()}this.log("gc finished")}};var zo=class extends Dt{data;constructor(){super(),this.data=new Map}put(e,t){return this.data.set(Re.encode(e.multihash.bytes),t),e}get(e){let t=this.data.get(Re.encode(e.multihash.bytes));if(t==null)throw Lr();return t}has(e){return this.data.has(Re.encode(e.multihash.bytes))}async delete(e){this.data.delete(Re.encode(e.multihash.bytes))}async*getAll(){for(let[e,t]of this.data.entries())yield{cid:oe.createV1(is,kt(Re.decode(e))),block:t}}};var F4={...Qr};var f0=ot(pn(),1);function aa(r){return r=r??new Error("Not Found"),(0,f0.default)(r,"ERR_NOT_FOUND")}var h0="SHARDING";function mx(r){return r[Symbol.asyncIterator]!=null}function yx(r,e){return mx(r)?async function*(){yield*(await Ec(r)).sort(e)}():function*(){yield*Ec(r).sort(e)}()}var ca=yx;var ir=class{put(e,t,n){return Promise.reject(new Error(".put is not implemented"))}get(e,t){return Promise.reject(new Error(".get is not implemented"))}has(e,t){return Promise.reject(new Error(".has is not implemented"))}delete(e,t){return Promise.reject(new Error(".delete is not implemented"))}async*putMany(e,t={}){for await(let{key:n,value:o}of e)await this.put(n,o,t),yield n}async*getMany(e,t={}){for await(let n of e)yield{key:n,value:await this.get(n,t)}}async*deleteMany(e,t={}){for await(let n of e)await this.delete(n,t),yield n}batch(){let e=[],t=[];return{put(n,o){e.push({key:n,value:o})},delete(n){t.push(n)},commit:async n=>{await $t(this.putMany(e,n)),e=[],await $t(this.deleteMany(t,n)),t=[]}}}async*_all(e,t){throw new Error("._all is not implemented")}async*_allKeys(e,t){throw new Error("._allKeys is not implemented")}query(e,t){let n=this._all(e,t);if(e.prefix!=null){let o=e.prefix;n=it(n,s=>s.key.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,s)=>it(o,s),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,s)=>ca(o,s),n)),e.offset!=null){let o=0,s=e.offset;n=it(n,()=>o++>=s)}return e.limit!=null&&(n=gs(n,e.limit)),n}queryKeys(e,t){let n=this._allKeys(e,t);if(e.prefix!=null){let o=e.prefix;n=it(n,s=>s.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,s)=>it(o,s),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,s)=>ca(o,s),n)),e.offset!=null){let o=e.offset,s=0;n=it(n,()=>s++>=o)}return e.limit!=null&&(n=gs(n,e.limit)),n}};var jo=class extends ir{data;constructor(){super(),this.data=new Map}put(e,t){return this.data.set(e.toString(),t),e}get(e){let t=this.data.get(e.toString());if(t==null)throw aa();return t}has(e){return this.data.has(e.toString())}delete(e){this.data.delete(e.toString())}*_all(){for(let[e,t]of this.data.entries())yield{key:new Ne(e),value:t}}*_allKeys(){for(let e of this.data.keys())yield new Ne(e)}};var hR=new Ne(h0);var BR=Je("datastore:core:tiered");async function bx(r={}){let e=r.datastore??new jo,t=r.blockstore??new zo,n=new ia({...r,datastore:e,blockstore:t,blockBrokers:r.blockBrokers??[vc()],routers:r.routers??[bu("https://delegated-ipfs.dev")]});return r.start!==!1&&await n.start(),n}return I0(xx);})();
9
9
  /*! Bundled license information:
10
10
 
11
11
  pvtsutils/build/index.js: