@helia/http 1.0.1 → 1.0.2-2c71b6e

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 pp=Object.create;var No=Object.defineProperty;var mp=Object.getOwnPropertyDescriptor;var yp=Object.getOwnPropertyNames;var gp=Object.getPrototypeOf,wp=Object.prototype.hasOwnProperty;var br=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),ge=(r,e)=>{for(var t in e)No(r,t,{get:e[t],enumerable:!0})},du=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of yp(e))!wp.call(r,o)&&o!==t&&No(r,o,{get:()=>e[o],enumerable:!(n=mp(e,o))||n.enumerable});return r};var yt=(r,e,t)=>(t=r!=null?pp(gp(r)):{},du(e||!r||!r.__esModule?No(t,"default",{value:r,enumerable:!0}):t,r)),bp=r=>du(No({},"__esModule",{value:!0}),r);var Uu=br((Nb,Lu)=>{var jr=1e3,Wr=jr*60,Yr=Wr*60,Er=Yr*24,sm=Er*7,am=Er*365.25;Lu.exports=function(r,e){e=e||{};var t=typeof r;if(t==="string"&&r.length>0)return cm(r);if(t==="number"&&isFinite(r))return e.long?lm(r):um(r);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(r))};function cm(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*am;case"weeks":case"week":case"w":return t*sm;case"days":case"day":case"d":return t*Er;case"hours":case"hour":case"hrs":case"hr":case"h":return t*Yr;case"minutes":case"minute":case"mins":case"min":case"m":return t*Wr;case"seconds":case"second":case"secs":case"sec":case"s":return t*jr;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return t;default:return}}}}function um(r){var e=Math.abs(r);return e>=Er?Math.round(r/Er)+"d":e>=Yr?Math.round(r/Yr)+"h":e>=Wr?Math.round(r/Wr)+"m":e>=jr?Math.round(r/jr)+"s":r+"ms"}function lm(r){var e=Math.abs(r);return e>=Er?Do(r,e,Er,"day"):e>=Yr?Do(r,e,Yr,"hour"):e>=Wr?Do(r,e,Wr,"minute"):e>=jr?Do(r,e,jr,"second"):r+" ms"}function Do(r,e,t,n){var o=e>=t*1.5;return Math.round(r/t)+" "+n+(o?"s":"")}});var Pu=br((Cb,Du)=>{function fm(r){t.debug=t,t.default=t,t.coerce=c,t.disable=i,t.enable=o,t.enabled=s,t.humanize=Uu(),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 p=0;p<u.length;p++)l=(l<<5)-l+u.charCodeAt(p),l|=0;return t.colors[Math.abs(l)%t.colors.length]}t.selectColor=e;function t(u){let l,p=null,E,y;function d(...m){if(!d.enabled)return;let g=d,I=Number(new Date),v=I-(l||I);g.diff=v,g.prev=l,g.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 w=t.formatters[L];if(typeof w=="function"){let N=m[U];_=w.call(g,N),m.splice(U,1),U--}return _}),t.formatArgs.call(g,m),(g.log||t.log).apply(g,m)}return d.namespace=u,d.useColors=t.useColors(),d.color=t.selectColor(u),d.extend=n,d.destroy=t.destroy,Object.defineProperty(d,"enabled",{enumerable:!0,configurable:!1,get:()=>p!==null?p:(E!==t.namespaces&&(E=t.namespaces,y=t.enabled(u)),y),set:m=>{p=m}}),typeof t.init=="function"&&t.init(d),d}function n(u,l){let p=t(this.namespace+(typeof l>"u"?":":l)+u);return p.log=this.log,p}function o(u){t.save(u),t.namespaces=u,t.names=[],t.skips=[];let l,p=(typeof u=="string"?u:"").split(/[\s,]+/),E=p.length;for(l=0;l<E;l++)p[l]&&(u=p[l].replace(/\*/g,".*?"),u[0]==="-"?t.skips.push(new RegExp("^"+u.slice(1)+"$")):t.names.push(new RegExp("^"+u+"$")))}function i(){let u=[...t.names.map(a),...t.skips.map(a).map(l=>"-"+l)].join(",");return t.enable(""),u}function s(u){if(u[u.length-1]==="*")return!0;let l,p;for(l=0,p=t.skips.length;l<p;l++)if(t.skips[l].test(u))return!1;for(l=0,p=t.names.length;l<p;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}Du.exports=fm});var Ou=br((He,Po)=>{He.formatArgs=dm;He.save=pm;He.load=mm;He.useColors=hm;He.storage=ym();He.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`."))}})();He.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 hm(){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 dm(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+Po.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)}He.log=console.debug||console.log||(()=>{});function pm(r){try{r?He.storage.setItem("debug",r):He.storage.removeItem("debug")}catch{}}function mm(){let r;try{r=He.storage.getItem("debug")}catch{}return!r&&typeof process<"u"&&"env"in process&&(r=process.env.DEBUG),r}function ym(){try{return localStorage}catch{}}Po.exports=Pu()(He);var{formatters:gm}=Po.exports;gm.j=function(r){try{return JSON.stringify(r)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}});var tn=br((Qx,rl)=>{"use strict";function tl(r,e){for(let t in e)Object.defineProperty(r,t,{value:e[t],enumerable:!0,configurable:!0});return r}function Xm(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 tl(r,t)}catch{t.message=r.message,t.stack=r.stack;let o=function(){};return o.prototype=Object.create(Object.getPrototypeOf(r)),tl(new o,t)}}rl.exports=Xm});var Zl=br(xn=>{"use strict";var Hy="[object ArrayBuffer]",Pt=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===Hy}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 i=0;i<n.length;i++)if(n[i]!==o[i])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 s of t)n+=s.byteLength;let o=new Uint8Array(n),i=0;for(let s of t){let a=this.toUint8Array(s);o.set(a,i),i+=a.length}return e[e.length-1]instanceof Function?this.toView(o,e[e.length-1]):o.buffer}},cc="string",$y=/^[0-9a-f]+$/i,Ky=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,qy=/^[a-zA-Z0-9-_]+$/,hi=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=Pt.toUint8Array(e),n="";for(let i=0;i<t.length;i++)n+=String.fromCharCode(t[i]);return decodeURIComponent(escape(n))}},Qe=class{static toString(e,t=!1){let n=Pt.toArrayBuffer(e),o=new DataView(n),i="";for(let s=0;s<n.byteLength;s+=2){let a=o.getUint16(s,t);i+=String.fromCharCode(a)}return i}static fromString(e,t=!1){let n=new ArrayBuffer(e.length*2),o=new DataView(n);for(let i=0;i<e.length;i++)o.setUint16(i*2,e.charCodeAt(i),t);return n}},di=class r{static isHex(e){return typeof e===cc&&$y.test(e)}static isBase64(e){return typeof e===cc&&Ky.test(e)}static isBase64Url(e){return typeof e===cc&&qy.test(e)}static ToString(e,t="utf8"){let n=Pt.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 Qe.toString(n,!0);case"utf16":case"utf16be":return Qe.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 Qe.fromString(e,!0);case"utf16":case"utf16be":return Qe.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=Pt.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 hi.fromString(e);case"utf16":case"utf16be":return Qe.fromString(e);case"utf16le":case"usc2":return Qe.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 hi.toString(e);case"utf16":case"utf16be":return Qe.toString(e);case"utf16le":case"usc2":return Qe.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=Pt.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return n}static ToHex(e){let t=Pt.toUint8Array(e),n="",o=t.length;for(let i=0;i<o;i++){let s=t[i];s<16&&(n+="0"),n+=s.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 i=t.slice(o,o+2);n[o/2]=parseInt(i,16)}return n.buffer}static ToUtf16String(e,t=!1){return Qe.toString(e,t)}static FromUtf16String(e,t=!1){return Qe.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,"")||""}};di.DEFAULT_UTF8_ENCODING="utf8";function zy(r,...e){let t=arguments[0];for(let n=1;n<arguments.length;n++){let o=arguments[n];for(let i in o)t[i]=o[i]}return t}function Gy(...r){let e=r.map(o=>o.byteLength).reduce((o,i)=>o+i),t=new Uint8Array(e),n=0;return r.map(o=>new Uint8Array(o)).forEach(o=>{for(let i of o)t[n++]=i}),t.buffer}function jy(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}xn.BufferSourceConverter=Pt;xn.Convert=di;xn.assign=zy;xn.combine=Gy;xn.isEqual=jy});var Ac=br((yB,Bc)=>{var mB=function(){typeof Bc<"u"&&(Bc.exports=d);var r=86400,e=3200,t=146097*e/400,n=r*t,o=1e3*n,i=864e13,s=4294967296,a=1e6,c="000000000",f=Math.trunc||function(w){var N=w-w%1;return N==0&&(w<0||w===0&&1/w!=1/0)?-0:N},u=d.prototype,l=(d.fromDate=function(w){return new d(+w)},d.fromInt64BE=U(0,1,2,3,0,4),d.fromInt64LE=U(3,2,1,0,4,0),d.fromString=function(T){var N,O=new d,T=(T+="").replace(/^\s*[+\-]?\d+/,function($){var $=+$,J=1970+($-1970)%400;return O.year=$-J,J}).replace(/(?:Z|([+\-]\d{2}):?(\d{2}))$/,function(F,$,J){return $<0&&(J*=-1),N=6e4*(60*+$+ +J),""}).replace(/\.\d+$/,function(F){return O.nano=+(F+c).substr(1,9),""}).split(/\D+/);if(1<T.length?T[1]--:T[1]=0,O.time=N=Date.UTC.apply(Date,T)-(N||0),isNaN(N))throw new TypeError("Invalid Date");return m(O)},d.fromTimeT=function(w){return I(w,0)},u.year=0,u.time=0,u.nano=0,u.addNano=function(w){return this.nano+=+w||0,this},u.getNano=function(){var w=m(this);return(w.time%1e3*a+ +w.nano+1e9)%1e9},u.getTimeT=function(){var N=m(this),w=Math.floor(N.time/1e3),N=N.year;return N&&(w+=N*t*r/e),w},u.getYear=function(){return this.toDate().getUTCFullYear()+this.year},u.toDate=function(){return g(m(this).time)},u.toJSON=function(){return this.toString().replace(/0{1,6}Z$/,"Z")},u.toString=function(w){var N=this,O=N.toDate(),T={H:function(){return _(O.getUTCHours())},L:function(){return L(O.getUTCMilliseconds(),3)},M:function(){return _(O.getUTCMinutes())},N:function(){return L(N.getNano(),9)},S:function(){return _(O.getUTCSeconds())},Y:function(){var F=N.getYear();return 999999<F?"+"+F:9999<F?"+"+L(F,6):0<=F?L(F,4):-999999<=F?"-"+L(-F,6):F},a:function(){return E[O.getUTCDay()]},b:function(){return p[O.getUTCMonth()]},d:function(){return _(O.getUTCDate())},e:function(){return function(F){return(9<F?"":" ")+(0|F)}(O.getUTCDate())},m:function(){return _(O.getUTCMonth()+1)}};return function F($){return $.replace(/%./g,function(J){var k=J[1],x=y[k],k=T[k];return x?F(x):k?k():J})}(w||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"),p=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],E=["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 d;function d(w,N,O){var T=this;if(!(T instanceof d))return new d(w,N,O);T.time=+w||0,T.nano=+N||0,T.year=+O||0,m(T)}function m(w){var N,O,T,F=w.year,$=w.time,J=w.nano,x=((J<0||a<=J)&&(J-=(O=Math.floor(J/a))*a,$+=O,O=1),F%e);return($<-i||i<$||x)&&((N=f($/o))&&(F+=N*e,$-=N*o),(T=g($)).setUTCFullYear(x+T.getUTCFullYear()),T=($=+T)+(N=f((F-=x)/e))*o,N&&-i<=T&&T<=i&&(F-=N*e,$=T),O=1),O&&(w.year=F,w.time=$,w.nano=J),w}function g(w){var N=new Date(0);return N.setTime(w),N}function I(F,T){F=+F||0;var O=f((T=(T|0)*s)/n)+f(F/n),T=T%n+F%n,F=f(T/n);return F&&(O+=F,T-=F*n),new d(1e3*T,0,O*e)}function v(w,N,O,T,F,$){return function(x,k){var A=m(this);x=x||new Array(8),S(x,k|=0);var b=Math.floor(A.time/1e3),A=A.year*(t*r/e),H=f(A/s)+f(b/s),A=A%s+b%s,b=Math.floor(A/s);return b&&(H+=b,A-=b*s),J(x,k+F,H),J(x,k+$,A),x};function J(x,k,H){x[k+w]=H>>24&255,x[k+N]=H>>16&255,x[k+O]=H>>8&255,x[k+T]=255&H}}function U(w,N,O,T,F,$){return function(x,k){S(x,k|=0);var H=J(x,k+F);return I(J(x,k+$),H)};function J(x,k){return 16777216*x[k+w]+(x[k+N]<<16|x[k+O]<<8|x[k+T])}}function S(w,N){if(w=w&&w.length,w==null)throw new TypeError("Invalid Buffer");if(w<N+8)throw new RangeError("Out of range")}function _(w){return(9<w?"":"0")+(0|w)}function L(w,N){return(c+(0|w)).substr(-N)}}()});var Ed=br((XA,Dc)=>{"use strict";var dw=Object.prototype.hasOwnProperty,Oe="~";function vo(){}Object.create&&(vo.prototype=Object.create(null),new vo().__proto__||(Oe=!1));function pw(r,e,t){this.fn=r,this.context=e,this.once=t||!1}function xd(r,e,t,n,o){if(typeof t!="function")throw new TypeError("The listener must be a function");var i=new pw(t,n||r,o),s=Oe?Oe+e:e;return r._events[s]?r._events[s].fn?r._events[s]=[r._events[s],i]:r._events[s].push(i):(r._events[s]=i,r._eventsCount++),r}function ws(r,e){--r._eventsCount===0?r._events=new vo:delete r._events[e]}function Ce(){this._events=new vo,this._eventsCount=0}Ce.prototype.eventNames=function(){var e=[],t,n;if(this._eventsCount===0)return e;for(n in t=this._events)dw.call(t,n)&&e.push(Oe?n.slice(1):n);return Object.getOwnPropertySymbols?e.concat(Object.getOwnPropertySymbols(t)):e};Ce.prototype.listeners=function(e){var t=Oe?Oe+e:e,n=this._events[t];if(!n)return[];if(n.fn)return[n.fn];for(var o=0,i=n.length,s=new Array(i);o<i;o++)s[o]=n[o].fn;return s};Ce.prototype.listenerCount=function(e){var t=Oe?Oe+e:e,n=this._events[t];return n?n.fn?1:n.length:0};Ce.prototype.emit=function(e,t,n,o,i,s){var a=Oe?Oe+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,i),!0;case 6:return c.fn.call(c.context,t,n,o,i,s),!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 p=c.length,E;for(l=0;l<p;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(E=1,u=new Array(f-1);E<f;E++)u[E-1]=arguments[E];c[l].fn.apply(c[l].context,u)}}return!0};Ce.prototype.on=function(e,t,n){return xd(this,e,t,n,!1)};Ce.prototype.once=function(e,t,n){return xd(this,e,t,n,!0)};Ce.prototype.removeListener=function(e,t,n,o){var i=Oe?Oe+e:e;if(!this._events[i])return this;if(!t)return ws(this,i),this;var s=this._events[i];if(s.fn)s.fn===t&&(!o||s.once)&&(!n||s.context===n)&&ws(this,i);else{for(var a=0,c=[],f=s.length;a<f;a++)(s[a].fn!==t||o&&!s[a].once||n&&s[a].context!==n)&&c.push(s[a]);c.length?this._events[i]=c.length===1?c[0]:c:ws(this,i)}return this};Ce.prototype.removeAllListeners=function(e){var t;return e?(t=Oe?Oe+e:e,this._events[t]&&ws(this,t)):(this._events=new vo,this._eventsCount=0),this};Ce.prototype.off=Ce.prototype.removeListener;Ce.prototype.addListener=Ce.prototype.on;Ce.prefixed=Oe;Ce.EventEmitter=Ce;typeof Dc<"u"&&(Dc.exports=Ce)});var rb={};ge(rb,{createHeliaHTTP:()=>tb});function xr(r){let e=new globalThis.AbortController;function t(){e.abort();for(let i of r)i?.removeEventListener!=null&&i.removeEventListener("abort",t)}for(let i of r){if(i?.aborted===!0){t();break}i?.addEventListener!=null&&i.addEventListener("abort",t)}function n(){for(let i of r)i?.removeEventListener!=null&&i.removeEventListener("abort",t)}let o=e.signal;return o.clear=n,o}function xp(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 $r=xp;function Ep(r){return r[Symbol.asyncIterator]!=null}function pu(r){return r?.then!=null}function vp(r,e){if(Ep(r))return async function*(){for await(let a of r){let c=e(a);pu(c)&&await c,yield a}}();let t=$r(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);pu(c)&&await c,yield a}}();let s=e;return function*(){yield n;for(let a of t)s(a),yield a}()}var Os=vp;var $s={};ge($s,{base32:()=>Ae,base32hex:()=>Tp,base32hexpad:()=>Cp,base32hexpadupper:()=>Lp,base32hexupper:()=>Np,base32pad:()=>Rp,base32padupper:()=>_p,base32upper:()=>Eu,base32z:()=>Up});var cb=new Uint8Array(0);function mu(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 It(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function yu(r){return new TextEncoder().encode(r)}function gu(r){return new TextDecoder().decode(r)}function Bp(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 i=r.charAt(o),s=i.charCodeAt(0);if(t[s]!==255)throw new TypeError(i+" is ambiguous");t[s]=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 d=0,m=0,g=0,I=y.length;g!==I&&y[g]===0;)g++,d++;for(var v=(I-g)*u+1>>>0,U=new Uint8Array(v);g!==I;){for(var S=y[g],_=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=_,g++}for(var w=v-m;w!==v&&U[w]===0;)w++;for(var N=c.repeat(d);w<v;++w)N+=r.charAt(U[w]);return N}function p(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var d=0;if(y[d]!==" "){for(var m=0,g=0;y[d]===c;)m++,d++;for(var I=(y.length-d)*f+1>>>0,v=new Uint8Array(I);y[d];){var U=t[y.charCodeAt(d)];if(U===255)return;for(var S=0,_=I-1;(U!==0||S<g)&&_!==-1;_--,S++)U+=a*v[_]>>>0,v[_]=U%256>>>0,U=U/256>>>0;if(U!==0)throw new Error("Non-zero carry");g=S,d++}if(y[d]!==" "){for(var L=I-g;L!==I&&v[L]===0;)L++;for(var w=new Uint8Array(m+(I-L)),N=m;L!==I;)w[N++]=v[L++];return w}}}function E(y){var d=p(y);if(d)return d;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:p,decode:E}}var Ap=Bp,kp=Ap,bu=kp;var Vs=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")}},Fs=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 xu(this,e)}},Ms=class{decoders;constructor(e){this.decoders=e}or(e){return xu(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 xu(r,e){return new Ms({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var Hs=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 Vs(e,t,n),this.decoder=new Fs(e,t,o)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function Kr({name:r,prefix:e,encode:t,decode:n}){return new Hs(r,e,t,n)}function Wt({name:r,prefix:e,alphabet:t}){let{encode:n,decode:o}=bu(t,r);return Kr({prefix:e,name:r,encode:n,decode:i=>It(o(i))})}function Sp(r,e,t,n){let o={};for(let u=0;u<e.length;++u)o[e[u]]=u;let i=r.length;for(;r[i-1]==="=";)--i;let s=new Uint8Array(i*t/8|0),a=0,c=0,f=0;for(let u=0;u<i;++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,s[f++]=255&c>>a)}if(a>=t||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return s}function Ip(r,e,t){let n=e[e.length-1]==="=",o=(1<<t)-1,i="",s=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],s+=8;s>t;)s-=t,i+=e[o&a>>s];if(s!==0&&(i+=e[o&a<<t-s]),n)for(;i.length*t&7;)i+="=";return i}function le({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return Kr({prefix:e,name:r,encode(o){return Ip(o,n,t)},decode(o){return Sp(o,n,t,r)}})}var Ae=le({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Eu=le({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Rp=le({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),_p=le({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Tp=le({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Np=le({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Cp=le({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Lp=le({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Up=le({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ks={};ge(Ks,{base58btc:()=>he,base58flickr:()=>Dp});var he=Wt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Dp=Wt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Pp=Au,vu=128,Op=127,Vp=~Op,Fp=Math.pow(2,31);function Au(r,e,t){e=e||[],t=t||0;for(var n=t;r>=Fp;)e[t++]=r&255|vu,r/=128;for(;r&Vp;)e[t++]=r&255|vu,r>>>=7;return e[t]=r|0,Au.bytes=t-n+1,e}var Mp=qs,Hp=128,Bu=127;function qs(r,n){var t=0,n=n||0,o=0,i=n,s,a=r.length;do{if(i>=a)throw qs.bytes=0,new RangeError("Could not decode varint");s=r[i++],t+=o<28?(s&Bu)<<o:(s&Bu)*Math.pow(2,o),o+=7}while(s>=Hp);return qs.bytes=i-n,t}var $p=Math.pow(2,7),Kp=Math.pow(2,14),qp=Math.pow(2,21),zp=Math.pow(2,28),Gp=Math.pow(2,35),jp=Math.pow(2,42),Wp=Math.pow(2,49),Yp=Math.pow(2,56),Zp=Math.pow(2,63),Jp=function(r){return r<$p?1:r<Kp?2:r<qp?3:r<zp?4:r<Gp?5:r<jp?6:r<Wp?7:r<Yp?8:r<Zp?9:10},Xp={encode:Pp,decode:Mp,encodingLength:Jp},Qp=Xp,Vn=Qp;function Fn(r,e=0){return[Vn.decode(r,e),Vn.decode.bytes]}function qr(r,e,t=0){return Vn.encode(r,e,t),e}function zr(r){return Vn.encodingLength(r)}function gt(r,e){let t=e.byteLength,n=zr(r),o=n+zr(t),i=new Uint8Array(o+t);return qr(r,i,0),qr(t,i,n),i.set(e,o),new Gr(r,t,e,i)}function wt(r){let e=It(r),[t,n]=Fn(e),[o,i]=Fn(e.subarray(n)),s=e.subarray(n+i);if(s.byteLength!==o)throw new Error("Incorrect length");return new Gr(t,o,s,e)}function ku(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&mu(r.bytes,t.bytes)}}var Gr=class{code;size;digest;bytes;constructor(e,t,n,o){this.code=e,this.size=t,this.digest=n,this.bytes=o}};function Su(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return tm(t,zs(r),e??he.encoder);default:return rm(t,zs(r),e??Ae.encoder)}}var Iu=new WeakMap;function zs(r){let e=Iu.get(r);if(e==null){let t=new Map;return Iu.set(r,t),t}return e}var ee=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!==Mn)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==nm)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=gt(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&&ku(e.multihash,n.multihash)}toString(e){return Su(this,e)}toJSON(){return{"/":Su(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:i,bytes:s}=t;return new r(n,o,i,s??Ru(n,o,i.bytes))}else if(t[om]===!0){let{version:n,multihash:o,code:i}=t,s=wt(o);return r.create(n,i,s)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==Mn)throw new Error(`Version 0 CID must use dag-pb (code: ${Mn}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let o=Ru(e,t,n.bytes);return new r(e,t,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Mn,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=It(e.subarray(n,n+t.multihashSize));if(o.byteLength!==t.multihashSize)throw new Error("Incorrect length");let i=o.subarray(t.multihashSize-t.digestSize),s=new Gr(t.multihashCode,t.digestSize,i,o);return[t.version===0?r.createV0(s):r.createV1(t.codec,s),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[l,p]=Fn(e.subarray(t));return t+=p,l},o=n(),i=Mn;if(o===18?(o=0,t=0):i=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let s=t,a=n(),c=n(),f=t+c,u=f-s;return{version:o,codec:i,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(e,t){let[n,o]=em(e,t),i=r.decode(o);if(i.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return zs(i).set(n,e),i}};function em(r,e){switch(r[0]){case"Q":{let t=e??he;return[he.prefix,t.decode(`${he.prefix}${r}`)]}case he.prefix:{let t=e??he;return[he.prefix,t.decode(r)]}case Ae.prefix:{let t=e??Ae;return[Ae.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 tm(r,e,t){let{prefix:n}=t;if(n!==he.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let o=e.get(n);if(o==null){let i=t.encode(r).slice(1);return e.set(n,i),i}else return o}function rm(r,e,t){let{prefix:n}=t,o=e.get(n);if(o==null){let i=t.encode(r);return e.set(n,i),i}else return o}var Mn=112,nm=18;function Ru(r,e,t){let n=zr(r),o=n+zr(e),i=new Uint8Array(o+t.byteLength);return qr(r,i,0),qr(e,i,n),i.set(t,o),i}var om=Symbol.for("@ipld/js-cid/CID");var Hn=Symbol.for("@libp2p/content-routing");var Gs=Symbol.for("@libp2p/peer-id");function _u(r){return r!=null&&!!r[Gs]}var $n=Symbol.for("@libp2p/peer-routing");var Yt=class r extends Error{code;type;constructor(e="The operation was aborted"){super(e),this.code=r.code,this.type=r.type}static code="ABORT_ERR";static type="aborted"},C=class extends Error{code;props;constructor(e,t,n){super(e),this.code=t,this.name=n?.name??"CodeError",this.props=n??{}}};var Lo=class extends EventTarget{#e=new Map;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:i})=>i!==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 im(e,t))}},js=class extends Event{detail;constructor(e,t){super(e,t),this.detail=t?.detail}},im=globalThis.CustomEvent??js;var Uo=(r,...e)=>{try{[...e]}catch{}};function Tu(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function Zt(...r){let e=[];for(let t of r)Tu(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 Jt(...r){let e=[];for(let t of r)Tu(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()}))}var Js={};ge(Js,{sha256:()=>we,sha512:()=>Zs});function Ys({name:r,code:e,encode:t}){return new Ws(r,e,t)}var Ws=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?gt(this.code,t):t.then(n=>gt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Cu(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var we=Ys({name:"sha2-256",code:18,encode:Cu("SHA-256")}),Zs=Ys({name:"sha2-512",code:19,encode:Cu("SHA-512")});var $e=yt(Ou(),1);var Xs={};ge(Xs,{base64:()=>Xt,base64pad:()=>wm,base64url:()=>bm,base64urlpad:()=>xm});var Xt=le({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),wm=le({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),bm=le({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),xm=le({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});$e.default.formatters.b=r=>r==null?"undefined":he.baseEncode(r);$e.default.formatters.t=r=>r==null?"undefined":Ae.baseEncode(r);$e.default.formatters.m=r=>r==null?"undefined":Xt.baseEncode(r);$e.default.formatters.p=r=>r==null?"undefined":r.toString();$e.default.formatters.c=r=>r==null?"undefined":r.toString();$e.default.formatters.k=r=>r==null?"undefined":r.toString();$e.default.formatters.a=r=>r==null?"undefined":r.toString();function Em(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 Vu(){return{forComponent(r){return Ke(r)}}}function Ke(r){let e=Em(`${r}:trace`);return $e.default.enabled(`${r}:trace`)&&$e.default.names.map(t=>t.toString()).find(t=>t.includes(":trace"))!=null&&(e=(0,$e.default)(`${r}:trace`)),Object.assign((0,$e.default)(r),{error:(0,$e.default)(`${r}:error`),trace:e})}function oe(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 vr(r){return globalThis.Buffer!=null?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r}function ot(r=0){return globalThis.Buffer?.allocUnsafe!=null?vr(globalThis.Buffer.allocUnsafe(r)):new Uint8Array(r)}var vm=Math.pow(2,7),Bm=Math.pow(2,14),Am=Math.pow(2,21),Qs=Math.pow(2,28),ea=Math.pow(2,35),ta=Math.pow(2,42),ra=Math.pow(2,49),te=128,_e=127;function Ve(r){if(r<vm)return 1;if(r<Bm)return 2;if(r<Am)return 3;if(r<Qs)return 4;if(r<ea)return 5;if(r<ta)return 6;if(r<ra)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function na(r,e,t=0){switch(Ve(r)){case 8:e[t++]=r&255|te,r/=128;case 7:e[t++]=r&255|te,r/=128;case 6:e[t++]=r&255|te,r/=128;case 5:e[t++]=r&255|te,r/=128;case 4:e[t++]=r&255|te,r>>>=7;case 3:e[t++]=r&255|te,r>>>=7;case 2:e[t++]=r&255|te,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function km(r,e,t=0){switch(Ve(r)){case 8:e.set(t++,r&255|te),r/=128;case 7:e.set(t++,r&255|te),r/=128;case 6:e.set(t++,r&255|te),r/=128;case 5:e.set(t++,r&255|te),r/=128;case 4:e.set(t++,r&255|te),r>>>=7;case 3:e.set(t++,r&255|te),r>>>=7;case 2:e.set(t++,r&255|te),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function oa(r,e){let t=r[e],n=0;if(n+=t&_e,t<te||(t=r[e+1],n+=(t&_e)<<7,t<te)||(t=r[e+2],n+=(t&_e)<<14,t<te)||(t=r[e+3],n+=(t&_e)<<21,t<te)||(t=r[e+4],n+=(t&_e)*Qs,t<te)||(t=r[e+5],n+=(t&_e)*ea,t<te)||(t=r[e+6],n+=(t&_e)*ta,t<te)||(t=r[e+7],n+=(t&_e)*ra,t<te))return n;throw new RangeError("Could not decode varint")}function Sm(r,e){let t=r.get(e),n=0;if(n+=t&_e,t<te||(t=r.get(e+1),n+=(t&_e)<<7,t<te)||(t=r.get(e+2),n+=(t&_e)<<14,t<te)||(t=r.get(e+3),n+=(t&_e)<<21,t<te)||(t=r.get(e+4),n+=(t&_e)*Qs,t<te)||(t=r.get(e+5),n+=(t&_e)*ea,t<te)||(t=r.get(e+6),n+=(t&_e)*ta,t<te)||(t=r.get(e+7),n+=(t&_e)*ra,t<te))return n;throw new RangeError("Could not decode varint")}function Zr(r,e,t=0){return e==null&&(e=ot(Ve(r))),e instanceof Uint8Array?na(r,e,t):km(r,e,t)}function Br(r,e=0){return r instanceof Uint8Array?oa(r,e):Sm(r,e)}var ia=new Float32Array([-0]),Qt=new Uint8Array(ia.buffer);function Mu(r,e,t){ia[0]=r,e[t]=Qt[0],e[t+1]=Qt[1],e[t+2]=Qt[2],e[t+3]=Qt[3]}function Hu(r,e){return Qt[0]=r[e],Qt[1]=r[e+1],Qt[2]=r[e+2],Qt[3]=r[e+3],ia[0]}var sa=new Float64Array([-0]),Te=new Uint8Array(sa.buffer);function $u(r,e,t){sa[0]=r,e[t]=Te[0],e[t+1]=Te[1],e[t+2]=Te[2],e[t+3]=Te[3],e[t+4]=Te[4],e[t+5]=Te[5],e[t+6]=Te[6],e[t+7]=Te[7]}function Ku(r,e){return Te[0]=r[e],Te[1]=r[e+1],Te[2]=r[e+2],Te[3]=r[e+3],Te[4]=r[e+4],Te[5]=r[e+5],Te[6]=r[e+6],Te[7]=r[e+7],sa[0]}var Im=BigInt(Number.MAX_SAFE_INTEGER),Rm=BigInt(Number.MIN_SAFE_INTEGER),qe=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 Ar;if(e<Im&&e>Rm)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>qu&&(o=0n,++n>qu&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(e){if(e===0)return Ar;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):Ar}},Ar=new qe(0,0);Ar.toBigInt=function(){return 0n};Ar.zzEncode=Ar.zzDecode=function(){return this};Ar.length=function(){return 1};var qu=4294967296n;function zu(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 Gu(r,e,t){if(t-e<1)return"";let o,i=[],s=0,a;for(;e<t;)a=r[e++],a<128?i[s++]=a:a>191&&a<224?i[s++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,i[s++]=55296+(a>>10),i[s++]=56320+(a&1023)):i[s++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&63,s>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,i)),s=0);return o!=null?(s>0&&o.push(String.fromCharCode.apply(String,i.slice(0,s))),o.join("")):String.fromCharCode.apply(String,i.slice(0,s))}function aa(r,e,t){let n=t,o,i;for(let s=0;s<r.length;++s)o=r.charCodeAt(s),o<128?e[t++]=o:o<2048?(e[t++]=o>>6|192,e[t++]=o&63|128):(o&64512)===55296&&((i=r.charCodeAt(s+1))&64512)===56320?(o=65536+((o&1023)<<10)+(i&1023),++s,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 it(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function Oo(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var ca=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,it(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 it(this,4);return Oo(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw it(this,4);return Oo(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw it(this,4);let e=Hu(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw it(this,4);let e=Ku(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 it(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return Gu(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw it(this,e);this.pos+=e}else do if(this.pos>=this.len)throw it(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 qe(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 it(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 it(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 it(this,8);let e=Oo(this.buf,this.pos+=4),t=Oo(this.buf,this.pos+=4);return new qe(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=oa(this.buf,this.pos);return this.pos+=Ve(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 ua(r){return new ca(r instanceof Uint8Array?r:r.subarray())}function Jr(r,e,t){let n=ua(r);return e.decode(n,void 0,t)}var la={};ge(la,{base10:()=>_m});var _m=Wt({prefix:"9",name:"base10",alphabet:"0123456789"});var fa={};ge(fa,{base16:()=>Tm,base16upper:()=>Nm});var Tm=le({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Nm=le({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var ha={};ge(ha,{base2:()=>Cm});var Cm=le({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var da={};ge(da,{base256emoji:()=>Om});var Wu=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}"),Lm=Wu.reduce((r,e,t)=>(r[t]=e,r),[]),Um=Wu.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function Dm(r){return r.reduce((e,t)=>(e+=Lm[t],e),"")}function Pm(r){let e=[];for(let t of r){let n=Um[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var Om=Kr({prefix:"\u{1F680}",name:"base256emoji",encode:Dm,decode:Pm});var pa={};ge(pa,{base36:()=>er,base36upper:()=>Vm});var er=Wt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Vm=Wt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ma={};ge(ma,{base8:()=>Fm});var Fm=le({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ya={};ge(ya,{identity:()=>Mm});var Mm=Kr({prefix:"\0",name:"identity",encode:r=>gu(r),decode:r=>yu(r)});var ix=new TextEncoder,sx=new TextDecoder;var Yu=512;var Vo=85;var wa={};ge(wa,{identity:()=>Je});var Ju=0,Hm="identity",Xu=It;function $m(r){return gt(Ju,Xu(r))}var Je={code:Ju,name:Hm,encode:Xu,digest:$m};var tr={...ya,...ha,...ma,...la,...fa,...$s,...pa,...Ks,...Xs,...da},wx={...Js,...wa};function el(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var Qu=el("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),ba=el("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=ot(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),Km={utf8:Qu,"utf-8":Qu,hex:tr.base16,latin1:ba,ascii:ba,binary:ba,...tr},Fo=Km;function G(r,e="utf8"){let t=Fo[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?vr(globalThis.Buffer.from(r,"utf-8")):t.decoder.decode(`${t.prefix}${r}`)}function xa(r){let e=r??8192,t=e>>>1,n,o=e;return function(s){if(s<1||s>t)return ot(s);o+s>e&&(n=ot(e),o=0);let a=n.subarray(o,o+=s);return o&7&&(o=(o|7)+1),a}}var kr=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function Ea(){}var Ba=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},qm=xa();function zm(r){return globalThis.Buffer!=null?ot(r):qm(r)}var qn=class{len;head;tail;states;constructor(){this.len=0,this.head=new kr(Ea,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new kr(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new Aa((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(Mo,10,qe.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=qe.fromBigInt(e);return this._push(Mo,t.length(),t)}uint64Number(e){return this._push(na,Ve(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=qe.fromBigInt(e).zzEncode();return this._push(Mo,t.length(),t)}sint64Number(e){let t=qe.fromNumber(e).zzEncode();return this._push(Mo,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(va,1,e?1:0)}fixed32(e){return this._push(Kn,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=qe.fromBigInt(e);return this._push(Kn,4,t.lo)._push(Kn,4,t.hi)}fixed64Number(e){let t=qe.fromNumber(e);return this._push(Kn,4,t.lo)._push(Kn,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(Mu,4,e)}double(e){return this._push($u,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(va,1,0):this.uint32(t)._push(jm,t,e)}string(e){let t=zu(e);return t!==0?this.uint32(t)._push(aa,t,e):this._push(va,1,0)}fork(){return this.states=new Ba(this),this.head=this.tail=new kr(Ea,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 kr(Ea,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=zm(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function va(r,e,t){e[t]=r&255}function Gm(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var Aa=class extends kr{next;constructor(e,t){super(Gm,e,t),this.next=void 0}};function Mo(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 Kn(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 jm(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(qn.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(Wm,e,r),this},qn.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(Ym,e,r),this});function Wm(r,e,t){e.set(r,t)}function Ym(r,e,t){r.length<40?aa(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(G(r),t)}function ka(){return new qn}function Xr(r,e){let t=ka();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var Qr;(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"})(Qr||(Qr={}));function Ho(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function zn(r){function e(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let t=function(i,s){let a=e(i);s.int32(a)},n=function(i){let s=i.int32();return e(s)};return Ho("enum",Qr.VARINT,t,n)}function en(r,e){return Ho("message",Qr.LENGTH_DELIMITED,r,e)}function Zm(r){return r[Symbol.asyncIterator]!=null}function Jm(r){if(Zm(r))return(async()=>{for await(let e of r);})();for(let e of r);}var Sr=Jm;function Le(r,e){if(globalThis.Buffer!=null)return vr(globalThis.Buffer.concat(r,e));e==null&&(e=r.reduce((o,i)=>o+i.length,0));let t=ot(e),n=0;for(let o of r)t.set(o,n),n+=o.length;return vr(t)}function Qm(r){return r[Symbol.asyncIterator]!=null}function e0(r,e){if(Qm(r))return async function*(){for await(let a of r)yield e(a)}();let t=$r(r),{value:n,done:o}=t.next();if(o===!0)return function*(){}();let i=e(n);if(typeof i.then=="function")return async function*(){yield await i;for await(let a of t)yield e(a)}();let s=e;return function*(){yield i;for(let a of t)yield s(a)}()}var Gn=e0;function Ue(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var $o=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}},rn=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new $o(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 $o(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 Sa=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function Ir(r={}){return t0(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 t0(r,e){e=e??{};let t=e.onEnd,n=new rn,o,i,s,a=Ue(),c=async()=>{try{return n.isEmpty()?s?{done:!0}:await new Promise((m,g)=>{i=I=>{i=null,n.push(I);try{m(r(n))}catch(v){g(v)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ue()})}},f=m=>i!=null?i(m):(n.push(m),o),u=m=>(n=new rn,i!=null?i({error:m}):(n.push({error:m}),o)),l=m=>{if(s)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})},p=m=>s?o:(s=!0,m!=null?u(m):f({done:!0})),E=()=>(n=new rn,p(),{done:!0}),y=m=>(p(m),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:E,throw:y,push:l,end:p,get readableLength(){return n.size},onEmpty:async m=>{let g=m?.signal;if(g?.throwIfAborted(),n.isEmpty())return;let I,v;g!=null&&(I=new Promise((U,S)=>{v=()=>{S(new Sa)},g.addEventListener("abort",v)}));try{await Promise.race([a.promise,I])}finally{v!=null&&g!=null&&g?.removeEventListener("abort",v)}}},t==null)return o;let d=o;return o={[Symbol.asyncIterator](){return this},next(){return d.next()},throw(m){return d.throw(m),t!=null&&(t(m),t=void 0),{done:!0}},return(){return d.return(),t!=null&&(t(),t=void 0),{done:!0}},push:l,end(m){return d.end(m),t!=null&&(t(m),t=void 0),o},get readableLength(){return d.readableLength},onEmpty:m=>d.onEmpty(m)},o}function r0(r){return r[Symbol.asyncIterator]!=null}function n0(...r){let e=[];for(let t of r)r0(t)||e.push(t);return e.length===r.length?function*(){for(let t of e)yield*t}():async function*(){let t=Ir({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 Rr=n0;function o0(r){return r[Symbol.asyncIterator]!=null}function i0(r,e){return o0(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 Ko=i0;var se=class extends Event{constructor(e,t){super(e),this.detail=t}};function j(r,e="utf8"){let t=Fo[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?globalThis.Buffer.from(r.buffer,r.byteOffset,r.byteLength).toString("utf8"):t.encoder.encode(r).substring(1)}var qo=class{url;#e=0;#t=0;#r=0;#s=0;constructor(e){this.url=e instanceof URL?e:new URL(e)}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(!o.ok)throw this.#t++,new Error(`unable to fetch raw block for CID ${e} from gateway ${this.url}`);return this.#s++,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.#s/(this.#e+this.#t*3)}incrementInvalidBlocks(){this.#r++}};var zo=class{gateways;log;constructor(e,t={}){this.log=e.logger.forComponent("helia:trustless-gateway-block-broker"),this.gateways=(t.gateways??nl).map(n=>new qo(n))}async retrieve(e,t={}){let n=this.gateways.sort((i,s)=>s.reliability()-i.reliability()),o=[];for(let i of n){this.log("getting block for %c from %s",e,i.url);try{let s=await i.getRawBlock(e,t.signal);this.log.trace("got block for %c from %s",e,i.url);try{await t.validateFn?.(s)}catch(a){throw this.log.error("failed to validate block for %c from %s",e,i.url,a),i.incrementInvalidBlocks(),new Error(`unable to validate block for CID ${e} from gateway ${i.url}`)}return s}catch(s){if(this.log.error("failed to get block for %c from %s",e,i.url,s),s instanceof Error?o.push(s):o.push(new Error(`unable to fetch raw block for CID ${e} from gateway ${i.url}`)),t.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",e,i.url);break}}}throw new AggregateError(o,`unable to fetch raw block for CID ${e} from any gateway`)}};var nl=["https://trustless-gateway.link","https://cloudflare-ipfs.com","https://4everland.io"];function Ia(r={}){return e=>new zo(e,r)}var s0=Symbol.for("nodejs.util.inspect.custom"),ol=Object.values(tr).map(r=>r.decoder).reduce((r,e)=>r.or(e),tr.identity.decoder),il=114,Ra=36,_a=37,jn=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()})`}[Gs]=!0;toString(){return this.string==null&&(this.string=he.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return ee.createV1(il,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return oe(this.multihash.bytes,e);if(typeof e=="string")return _r(e).equals(this);if(e?.multihash?.bytes!=null)return oe(this.multihash.bytes,e.multihash.bytes);throw new Error("not valid Id")}[s0](){return`PeerId(${this.toString()})`}},nn=class extends jn{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},on=class extends jn{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.multihash.digest}},sn=class extends jn{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.multihash.digest}};function _r(r,e){if(e=e??ol,r.charAt(0)==="1"||r.charAt(0)==="Q"){let t=wt(he.decode(`z${r}`));return r.startsWith("12D")?new on({multihash:t}):r.startsWith("16U")?new sn({multihash:t}):new nn({multihash:t})}return Wn(ol.decode(r))}function Wn(r){try{let e=wt(r);if(e.code===Je.code){if(e.digest.length===Ra)return new on({multihash:e});if(e.digest.length===_a)return new sn({multihash:e})}if(e.code===we.code)return new nn({multihash:e})}catch{return a0(ee.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function a0(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==il)throw new Error("Supplied PeerID CID is invalid");let e=r.multihash;if(e.code===we.code)return new nn({multihash:r.multihash});if(e.code===Je.code){if(e.digest.length===Ra)return new on({multihash:r.multihash});if(e.digest.length===_a)return new sn({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function sl(r,e){return r.length===Ra?new on({multihash:gt(Je.code,r),privateKey:e}):r.length===_a?new sn({multihash:gt(Je.code,r),privateKey:e}):new nn({multihash:await we.digest(r),publicKey:r,privateKey:e})}var Go=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 i=0,s=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 p=Number.parseInt(l,e);if(!Number.isNaN(p))return p});if(u===void 0)break;if(i*=e,i+=u,i>f||(s+=1,t!==void 0&&s>t))return}if(s!==0)return!n&&c&&s>1?void 0:i})}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 s=this.readSeparator(":",n,()=>this.readIPv4Addr());if(s!==void 0)return t[o]=s[0],t[o+1]=s[1],t[o+2]=s[2],t[o+3]=s[3],[o+4,!0]}let i=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(i===void 0)return[o,!1];t[o]=i>>8,t[o+1]=i&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 i=new Uint8Array(14),s=16-(n+2),[a]=e(i.subarray(0,s));return t.set(i.subarray(0,a),16-a),t})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var al=45,c0=15,an=new Go;function Ta(r){if(!(r.length>c0))return an.new(r).parseWith(()=>an.readIPv4Addr())}function Na(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>al))return an.new(r).parseWith(()=>an.readIPv6Addr())}function jo(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>al))return an.new(r).parseWith(()=>an.readIPAddr())}var q1=parseInt("0xFFFF",16),z1=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function ll(r){return!!Ta(r)}function fl(r){return!!Na(r)}function Wo(r){return!!jo(r)}var hl=ll,d0=fl,Ca=function(r){let e=0;if(r=r.toString().trim(),hl(r)){let t=new Uint8Array(e+4);return r.split(/\./g).forEach(n=>{t[e++]=parseInt(n,10)&255}),t}if(d0(r)){let t=r.split(":",8),n;for(n=0;n<t.length;n++){let i=hl(t[n]),s;i&&(s=Ca(t[n]),t[n]=j(s.slice(0,2),"base16")),s!=null&&++n<8&&t.splice(n,0,j(s.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 i=[n,1];for(n=9-t.length;n>0;n--)i.push("0");t.splice.apply(t,i)}let o=new Uint8Array(e+16);for(n=0;n<t.length;n++){let i=parseInt(t[n],16);o[e++]=i>>8&255,o[e++]=i&255}return o}throw new Error("invalid ip address")},dl=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 i=0;i<t;i++)o.push(r[e+i]);return o.join(".")}if(t===16){let o=[];for(let i=0;i<t;i+=2)o.push(n.getUint16(e+i).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var cn={},La={},m0=[[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"]];m0.forEach(r=>{let e=y0(...r);La[e.code]=e,cn[e.name]=e});function y0(r,e,t,n,o){return{code:r,size:e,name:t,resolvable:!!n,path:!!o}}function ie(r){if(typeof r=="number"){if(La[r]!=null)return La[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(cn[r]!=null)return cn[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var RE=ie("ip4"),_E=ie("ip6"),TE=ie("ipcidr");function Da(r,e){switch(ie(r).code){case 4:case 41:return w0(e);case 42:return yl(e);case 6:case 273:case 33:case 132:return wl(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return yl(e);case 421:return v0(e);case 444:return gl(e);case 445:return gl(e);case 466:return E0(e);default:return j(e,"base16")}}function Pa(r,e){switch(ie(r).code){case 4:return pl(e);case 41:return pl(e);case 42:return ml(e);case 6:case 273:case 33:case 132:return Oa(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return ml(e);case 421:return b0(e);case 444:return B0(e);case 445:return A0(e);case 466:return x0(e);default:return G(e,"base16")}}var Ua=Object.values(tr).map(r=>r.decoder),g0=function(){let r=Ua[0].or(Ua[1]);return Ua.slice(2).forEach(e=>r=r.or(e)),r}();function pl(r){if(!Wo(r))throw new Error("invalid ip address");return Ca(r)}function w0(r){let e=dl(r,0,r.length);if(e==null)throw new Error("ipBuff is required");if(!Wo(e))throw new Error("invalid ip address");return e}function Oa(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,r),new Uint8Array(e)}function wl(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function ml(r){let e=G(r),t=Uint8Array.from(Zr(e.length));return Le([t,e],t.length+e.length)}function yl(r){let e=Br(r);if(r=r.slice(Ve(e)),r.length!==e)throw new Error("inconsistent lengths");return j(r)}function b0(r){let e;r[0]==="Q"||r[0]==="1"?e=wt(he.decode(`z${r}`)).bytes:e=ee.parse(r).multihash.bytes;let t=Uint8Array.from(Zr(e.length));return Le([t,e],t.length+e.length)}function x0(r){let e=g0.decode(r),t=Uint8Array.from(Zr(e.length));return Le([t,e],t.length+e.length)}function E0(r){let e=Br(r),t=r.slice(Ve(e));if(t.length!==e)throw new Error("inconsistent lengths");return"u"+j(t,"base64url")}function v0(r){let e=Br(r),t=r.slice(Ve(e));if(t.length!==e)throw new Error("inconsistent lengths");return j(t,"base58btc")}function B0(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=Ae.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=Oa(n);return Le([t,o],t.length+o.length)}function A0(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=Ae.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=Oa(n);return Le([t,o],t.length+o.length)}function gl(r){let e=r.slice(0,r.length-2),t=r.slice(r.length-2),n=j(e,"base32"),o=wl(t);return`${n}:${o}`}function bl(r){r=Va(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 i=0;i<o.length;i++){let s=o[i],a=ie(s);if(a.size===0){e.push([a.code]),t.push([a.code]);continue}if(i++,i>=o.length)throw El("invalid address: "+r);if(a.path===!0){n=Va(o.slice(i).join("/")),e.push([a.code,Pa(a.code,n)]),t.push([a.code,n]);break}let c=Pa(a.code,o[i]);e.push([a.code,c]),t.push([a.code,Da(a.code,c)])}return{string:xl(t),bytes:Ma(e),tuples:e,stringTuples:t,path:n}}function Fa(r){let e=[],t=[],n=null,o=0;for(;o<r.length;){let i=Br(r,o),s=Ve(i),a=ie(i),c=k0(a,r.slice(o+s));if(c===0){e.push([i]),t.push([i]),o+=s;continue}let f=r.slice(o+s,o+s+c);if(o+=c+s,o>r.length)throw El("Invalid address Uint8Array: "+j(r,"base16"));e.push([i,f]);let u=Da(i,f);if(t.push([i,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:xl(t),tuples:e,stringTuples:t,path:n}}function xl(r){let e=[];return r.map(t=>{let n=ie(t[0]);return e.push(n.name),t.length>1&&t[1]!=null&&e.push(t[1]),null}),Va(e.join("/"))}function Ma(r){return Le(r.map(e=>{let t=ie(e[0]),n=Uint8Array.from(Zr(t.code));return e.length>1&&e[1]!=null&&(n=Le([n,e[1]])),n}))}function k0(r,e){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let t=Br(e instanceof Uint8Array?e:Uint8Array.from(e));return t+Ve(t)}}function Va(r){return"/"+r.trim().split("/").filter(e=>e).join("/")}function El(r){return new Error("Error parsing address: "+r)}var S0=Symbol.for("nodejs.util.inspect.custom"),Ha=Symbol.for("@multiformats/js-multiaddr/multiaddr"),I0=[ie("dns").code,ie("dns4").code,ie("dns6").code,ie("dnsaddr").code],Yo=class r{bytes;#e;#t;#r;#s;[Ha]=!0;constructor(e){e==null&&(e="");let t;if(e instanceof Uint8Array)t=Fa(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);t=bl(e)}else if(Bl(e))t=Fa(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.#s=t.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let e,t,n,o,i="",s=ie("tcp"),a=ie("udp"),c=ie("ip4"),f=ie("ip6"),u=ie("dns6"),l=ie("ip6zone");for(let[E,y]of this.stringTuples())E===l.code&&(i=`%${y??""}`),I0.includes(E)&&(t=s.name,o=443,n=`${y??""}${i}`,e=E===u.code?6:4),(E===s.code||E===a.code)&&(t=ie(E).name,o=parseInt(y??"")),(E===c.code||E===f.code)&&(t=ie(E).name,n=`${y??""}${i}`,e=E===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({},ie(e)))}protoCodes(){return this.#t.map(([e])=>e)}protoNames(){return this.#t.map(([e])=>ie(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(Ma(t.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,o])=>{n===cn.p2p.code&&e.push([n,o]),n===cn["p2p-circuit"].code&&(e=[])});let t=e.pop();if(t?.[1]!=null){let n=t[1];return n[0]==="Q"||n[0]==="1"?j(he.decode(`z${n}`),"base58btc"):j(ee.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#s}equals(e){return oe(this.bytes,e.bytes)}async resolve(e){let t=this.protos().find(i=>i.resolvable);if(t==null)return[this];let n=vl.get(t.name);if(n==null)throw new C(`no available resolver for ${t.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,e)).map(i=>new r(i))}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)}[S0](){return`Multiaddr(${this.#e})`}};var vl=new Map;function Bl(r){return!!r?.[Ha]}function $a(r){return new Yo(r)}async function*Zo(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 sc={};ge(sc,{Ed25519PrivateKey:()=>Lr,Ed25519PublicKey:()=>Jn,generateKeyPair:()=>Vy,generateKeyPairFromSeed:()=>Yl,unmarshalEd25519PrivateKey:()=>Py,unmarshalEd25519PublicKey:()=>Oy});function Xe(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function un(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`Wrong positive integer: ${r}`)}function R0(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Ka(r,...e){if(!R0(r))throw new Error("Expected Uint8Array");if(e.length>0&&!e.includes(r.length))throw new Error(`Expected Uint8Array of length ${e}, not of length=${r.length}`)}function Jo(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");un(r.outputLen),un(r.blockLen)}function ln(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 Al(r,e){Ka(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var Xo=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function kl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var hn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),st=(r,e)=>r<<32-e|r>>>e,_0=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!_0)throw new Error("Non little-endian hardware is not supported");var T0=async()=>{};async function Sl(r,e,t){let n=Date.now();for(let o=0;o<r;o++){t(o);let i=Date.now()-n;i>=0&&i<e||(await T0(),n+=i)}}function qa(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function rr(r){if(typeof r=="string"&&(r=qa(r)),!kl(r))throw new Error(`expected Uint8Array, got ${typeof r}`);return r}function Qo(...r){let e=0;for(let n=0;n<r.length;n++){let o=r[n];if(!kl(o))throw new Error("Uint8Array expected");e+=o.length}let t=new Uint8Array(e);for(let n=0,o=0;n<r.length;n++){let i=r[n];t.set(i,o),o+=i.length}return t}var fn=class{clone(){return this._cloneInto()}},N0={}.toString;function Il(r,e){if(e!==void 0&&N0.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function ei(r){let e=n=>r().update(rr(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function dn(r=32){if(Xo&&typeof Xo.getRandomValues=="function")return Xo.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function C0(r,e,t,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(e,t,n);let o=BigInt(32),i=BigInt(4294967295),s=Number(t>>o&i),a=Number(t&i),c=n?4:0,f=n?0:4;r.setUint32(e+c,s,n),r.setUint32(e+f,a,n)}var pn=class extends fn{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=hn(this.buffer)}update(e){ln(this);let{view:t,buffer:n,blockLen:o}=this;e=rr(e);let i=e.length;for(let s=0;s<i;){let a=Math.min(o-this.pos,i-s);if(a===o){let c=hn(e);for(;o<=i-s;s+=o)this.process(c,s);continue}n.set(e.subarray(s,s+a),this.pos),this.pos+=a,s+=a,this.pos===o&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){ln(this),Al(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:o,isLE:i}=this,{pos:s}=this;t[s++]=128,this.buffer.subarray(s).fill(0),this.padOffset>o-s&&(this.process(n,0),s=0);for(let l=s;l<o;l++)t[l]=0;C0(n,o-8,BigInt(this.length*8),i),this.process(n,0);let a=hn(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],i)}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:i,destroyed:s,pos:a}=this;return e.length=o,e.pos=a,e.finished=i,e.destroyed=s,o%t&&e.buffer.set(n),e}};var ti=BigInt(4294967295),za=BigInt(32);function Rl(r,e=!1){return e?{h:Number(r&ti),l:Number(r>>za&ti)}:{h:Number(r>>za&ti)|0,l:Number(r&ti)|0}}function L0(r,e=!1){let t=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let o=0;o<r.length;o++){let{h:i,l:s}=Rl(r[o],e);[t[o],n[o]]=[i,s]}return[t,n]}var U0=(r,e)=>BigInt(r>>>0)<<za|BigInt(e>>>0),D0=(r,e,t)=>r>>>t,P0=(r,e,t)=>r<<32-t|e>>>t,O0=(r,e,t)=>r>>>t|e<<32-t,V0=(r,e,t)=>r<<32-t|e>>>t,F0=(r,e,t)=>r<<64-t|e>>>t-32,M0=(r,e,t)=>r>>>t-32|e<<64-t,H0=(r,e)=>e,$0=(r,e)=>r,K0=(r,e,t)=>r<<t|e>>>32-t,q0=(r,e,t)=>e<<t|r>>>32-t,z0=(r,e,t)=>e<<t-32|r>>>64-t,G0=(r,e,t)=>r<<t-32|e>>>64-t;function j0(r,e,t,n){let o=(e>>>0)+(n>>>0);return{h:r+t+(o/2**32|0)|0,l:o|0}}var W0=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),Y0=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,Z0=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),J0=(r,e,t,n,o)=>e+t+n+o+(r/2**32|0)|0,X0=(r,e,t,n,o)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(o>>>0),Q0=(r,e,t,n,o,i)=>e+t+n+o+i+(r/2**32|0)|0;var ey={fromBig:Rl,split:L0,toBig:U0,shrSH:D0,shrSL:P0,rotrSH:O0,rotrSL:V0,rotrBH:F0,rotrBL:M0,rotr32H:H0,rotr32L:$0,rotlSH:K0,rotlSL:q0,rotlBH:z0,rotlBL:G0,add:j0,add3L:W0,add3H:Y0,add4L:Z0,add4H:J0,add5H:Q0,add5L:X0},q=ey;var[ty,ry]=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))),nr=new Uint32Array(80),or=new Uint32Array(80),Ga=class extends pn{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:i,Cl:s,Dh:a,Dl:c,Eh:f,El:u,Fh:l,Fl:p,Gh:E,Gl:y,Hh:d,Hl:m}=this;return[e,t,n,o,i,s,a,c,f,u,l,p,E,y,d,m]}set(e,t,n,o,i,s,a,c,f,u,l,p,E,y,d,m){this.Ah=e|0,this.Al=t|0,this.Bh=n|0,this.Bl=o|0,this.Ch=i|0,this.Cl=s|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=u|0,this.Fh=l|0,this.Fl=p|0,this.Gh=E|0,this.Gl=y|0,this.Hh=d|0,this.Hl=m|0}process(e,t){for(let v=0;v<16;v++,t+=4)nr[v]=e.getUint32(t),or[v]=e.getUint32(t+=4);for(let v=16;v<80;v++){let U=nr[v-15]|0,S=or[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),w=nr[v-2]|0,N=or[v-2]|0,O=q.rotrSH(w,N,19)^q.rotrBH(w,N,61)^q.shrSH(w,N,6),T=q.rotrSL(w,N,19)^q.rotrBL(w,N,61)^q.shrSL(w,N,6),F=q.add4L(L,T,or[v-7],or[v-16]),$=q.add4H(F,_,O,nr[v-7],nr[v-16]);nr[v]=$|0,or[v]=F|0}let{Ah:n,Al:o,Bh:i,Bl:s,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:p,Fh:E,Fl:y,Gh:d,Gl:m,Hh:g,Hl:I}=this;for(let v=0;v<80;v++){let U=q.rotrSH(l,p,14)^q.rotrSH(l,p,18)^q.rotrBH(l,p,41),S=q.rotrSL(l,p,14)^q.rotrSL(l,p,18)^q.rotrBL(l,p,41),_=l&E^~l&d,L=p&y^~p&m,w=q.add5L(I,S,L,ry[v],or[v]),N=q.add5H(w,g,U,_,ty[v],nr[v]),O=w|0,T=q.rotrSH(n,o,28)^q.rotrBH(n,o,34)^q.rotrBH(n,o,39),F=q.rotrSL(n,o,28)^q.rotrBL(n,o,34)^q.rotrBL(n,o,39),$=n&i^n&a^i&a,J=o&s^o&c^s&c;g=d|0,I=m|0,d=E|0,m=y|0,E=l|0,y=p|0,{h:l,l:p}=q.add(f|0,u|0,N|0,O|0),f=a|0,u=c|0,a=i|0,c=s|0,i=n|0,s=o|0;let x=q.add3L(O,F,J);n=q.add3H(x,N,T,$),o=x|0}({h:n,l:o}=q.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:i,l:s}=q.add(this.Bh|0,this.Bl|0,i|0,s|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:p}=q.add(this.Eh|0,this.El|0,l|0,p|0),{h:E,l:y}=q.add(this.Fh|0,this.Fl|0,E|0,y|0),{h:d,l:m}=q.add(this.Gh|0,this.Gl|0,d|0,m|0),{h:g,l:I}=q.add(this.Hh|0,this.Hl|0,g|0,I|0),this.set(n,o,i,s,a,c,f,u,l,p,E,y,d,m,g,I)}roundClean(){nr.fill(0),or.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 mn=ei(()=>new Ga);var ni={};ge(ni,{bitGet:()=>uy,bitLen:()=>cy,bitMask:()=>Yn,bitSet:()=>ly,bytesToHex:()=>Tt,bytesToNumberBE:()=>Nt,bytesToNumberLE:()=>ir,concatBytes:()=>Ct,createHmacDrbg:()=>Ya,ensureBytes:()=>fe,equalBytes:()=>sy,hexToBytes:()=>Tr,hexToNumber:()=>Wa,isBytes:()=>at,numberToBytesBE:()=>sr,numberToBytesLE:()=>Nr,numberToHexUnpadded:()=>Cl,numberToVarBytesBE:()=>iy,utf8ToBytes:()=>ay,validateObject:()=>bt});var Nl=BigInt(0),ri=BigInt(1),ny=BigInt(2);function at(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var oy=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function Tt(r){if(!at(r))throw new Error("Uint8Array expected");let e="";for(let t=0;t<r.length;t++)e+=oy[r[t]];return e}function Cl(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function Wa(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 _l(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 Tr(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,i=0;o<t;o++,i+=2){let s=_l(r.charCodeAt(i)),a=_l(r.charCodeAt(i+1));if(s===void 0||a===void 0){let c=r[i]+r[i+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+i)}n[o]=s*16+a}return n}function Nt(r){return Wa(Tt(r))}function ir(r){if(!at(r))throw new Error("Uint8Array expected");return Wa(Tt(Uint8Array.from(r).reverse()))}function sr(r,e){return Tr(r.toString(16).padStart(e*2,"0"))}function Nr(r,e){return sr(r,e).reverse()}function iy(r){return Tr(Cl(r))}function fe(r,e,t){let n;if(typeof e=="string")try{n=Tr(e)}catch(i){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${i}`)}else if(at(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 Ct(...r){let e=0;for(let o=0;o<r.length;o++){let i=r[o];if(!at(i))throw new Error("Uint8Array expected");e+=i.length}let t=new Uint8Array(e),n=0;for(let o=0;o<r.length;o++){let i=r[o];t.set(i,n),n+=i.length}return t}function sy(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 ay(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function cy(r){let e;for(e=0;r>Nl;r>>=ri,e+=1);return e}function uy(r,e){return r>>BigInt(e)&ri}var ly=(r,e,t)=>r|(t?ri:Nl)<<BigInt(e),Yn=r=>(ny<<BigInt(r-1))-ri,ja=r=>new Uint8Array(r),Tl=r=>Uint8Array.from(r);function Ya(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=ja(r),o=ja(r),i=0,s=()=>{n.fill(1),o.fill(0),i=0},a=(...l)=>t(o,n,...l),c=(l=ja())=>{o=a(Tl([0]),l),n=a(),l.length!==0&&(o=a(Tl([1]),l),n=a())},f=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,p=[];for(;l<e;){n=a();let E=n.slice();p.push(E),l+=n.length}return Ct(...p)};return(l,p)=>{s(),c(l);let E;for(;!(E=p(f()));)c();return s(),E}}var fy={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"||at(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 bt(r,e,t={}){let n=(o,i,s)=>{let a=fy[i];if(typeof a!="function")throw new Error(`Invalid validator "${i}", expected function`);let c=r[o];if(!(s&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(o)}=${c} (${typeof c}), expected ${i}`)};for(let[o,i]of Object.entries(e))n(o,i,!1);for(let[o,i]of Object.entries(t))n(o,i,!0);return r}var be=BigInt(0),ae=BigInt(1),Cr=BigInt(2),hy=BigInt(3),Za=BigInt(4),Ll=BigInt(5),Ul=BigInt(8),dy=BigInt(9),py=BigInt(16);function ne(r,e){let t=r%e;return t>=be?t:e+t}function my(r,e,t){if(t<=be||e<be)throw new Error("Expected power/modulo > 0");if(t===ae)return be;let n=ae;for(;e>be;)e&ae&&(n=n*r%t),r=r*r%t,e>>=ae;return n}function ce(r,e,t){let n=r;for(;e-- >be;)n*=n,n%=t;return n}function oi(r,e){if(r===be||e<=be)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=ne(r,e),n=e,o=be,i=ae,s=ae,a=be;for(;t!==be;){let f=n/t,u=n%t,l=o-s*f,p=i-a*f;n=t,t=u,o=s,i=a,s=l,a=p}if(n!==ae)throw new Error("invert: does not exist");return ne(o,e)}function yy(r){let e=(r-ae)/Cr,t,n,o;for(t=r-ae,n=0;t%Cr===be;t/=Cr,n++);for(o=Cr;o<r&&my(o,e,r)!==r-ae;o++);if(n===1){let s=(r+ae)/Za;return function(c,f){let u=c.pow(f,s);if(!c.eql(c.sqr(u),f))throw new Error("Cannot find square root");return u}}let i=(t+ae)/Cr;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,i),p=a.pow(c,t);for(;!a.eql(p,a.ONE);){if(a.eql(p,a.ZERO))return a.ZERO;let E=1;for(let d=a.sqr(p);E<f&&!a.eql(d,a.ONE);E++)d=a.sqr(d);let y=a.pow(u,ae<<BigInt(f-E-1));u=a.sqr(y),l=a.mul(l,y),p=a.mul(p,u),f=E}return l}}function gy(r){if(r%Za===hy){let e=(r+ae)/Za;return function(n,o){let i=n.pow(o,e);if(!n.eql(n.sqr(i),o))throw new Error("Cannot find square root");return i}}if(r%Ul===Ll){let e=(r-Ll)/Ul;return function(n,o){let i=n.mul(o,Cr),s=n.pow(i,e),a=n.mul(o,s),c=n.mul(n.mul(a,Cr),s),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%py,yy(r)}var Dl=(r,e)=>(ne(r,e)&ae)===ae,wy=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Ja(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=wy.reduce((n,o)=>(n[o]="function",n),e);return bt(r,t)}function by(r,e,t){if(t<be)throw new Error("Expected power > 0");if(t===be)return r.ONE;if(t===ae)return e;let n=r.ONE,o=e;for(;t>be;)t&ae&&(n=r.mul(n,o)),o=r.sqr(o),t>>=ae;return n}function xy(r,e){let t=new Array(e.length),n=e.reduce((i,s,a)=>r.is0(s)?i:(t[a]=i,r.mul(i,s)),r.ONE),o=r.inv(n);return e.reduceRight((i,s,a)=>r.is0(s)?i:(t[a]=r.mul(i,t[a]),r.mul(i,s)),o),t}function Xa(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function ii(r,e,t=!1,n={}){if(r<=be)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:o,nByteLength:i}=Xa(r,e);if(i>2048)throw new Error("Field lengths over 2048 bytes are not supported");let s=gy(r),a=Object.freeze({ORDER:r,BITS:o,BYTES:i,MASK:Yn(o),ZERO:be,ONE:ae,create:c=>ne(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return be<=c&&c<r},is0:c=>c===be,isOdd:c=>(c&ae)===ae,neg:c=>ne(-c,r),eql:(c,f)=>c===f,sqr:c=>ne(c*c,r),add:(c,f)=>ne(c+f,r),sub:(c,f)=>ne(c-f,r),mul:(c,f)=>ne(c*f,r),pow:(c,f)=>by(a,c,f),div:(c,f)=>ne(c*oi(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>oi(c,r),sqrt:n.sqrt||(c=>s(a,c)),invertBatch:c=>xy(a,c),cmov:(c,f,u)=>u?f:c,toBytes:c=>t?Nr(c,i):sr(c,i),fromBytes:c=>{if(c.length!==i)throw new Error(`Fp.fromBytes: expected ${i}, got ${c.length}`);return t?ir(c):Nt(c)}});return Object.freeze(a)}function Pl(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 Ol(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 Qa(r){let e=Ol(r);return e+Math.ceil(e/2)}function Vl(r,e,t=!1){let n=r.length,o=Ol(e),i=Qa(e);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let s=t?Nt(r):ir(r),a=ne(s,e-ae)+ae;return t?Nr(a,o):sr(a,o)}var vy=BigInt(0),ec=BigInt(1);function si(r,e){let t=(o,i)=>{let s=i.negate();return o?s:i},n=o=>{let i=Math.ceil(e/o)+1,s=2**(o-1);return{windows:i,windowSize:s}};return{constTimeNegate:t,unsafeLadder(o,i){let s=r.ZERO,a=o;for(;i>vy;)i&ec&&(s=s.add(a)),a=a.double(),i>>=ec;return s},precomputeWindow(o,i){let{windows:s,windowSize:a}=n(i),c=[],f=o,u=f;for(let l=0;l<s;l++){u=f,c.push(u);for(let p=1;p<a;p++)u=u.add(f),c.push(u);f=u.double()}return c},wNAF(o,i,s){let{windows:a,windowSize:c}=n(o),f=r.ZERO,u=r.BASE,l=BigInt(2**o-1),p=2**o,E=BigInt(o);for(let y=0;y<a;y++){let d=y*c,m=Number(s&l);s>>=E,m>c&&(m-=p,s+=ec);let g=d,I=d+Math.abs(m)-1,v=y%2!==0,U=m<0;m===0?u=u.add(t(v,i[g])):f=f.add(t(U,i[I]))}return{p:f,f:u}},wNAFCached(o,i,s,a){let c=o._WINDOW_SIZE||1,f=i.get(o);return f||(f=this.precomputeWindow(o,c),c!==1&&i.set(o,a(f))),this.wNAF(c,f,s)}}}function Zn(r){return Ja(r.Fp),bt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Xa(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var ct=BigInt(0),ze=BigInt(1),ai=BigInt(2),By=BigInt(8),Ay={zip215:!0};function ky(r){let e=Zn(r);return bt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function ci(r){let e=ky(r),{Fp:t,n,prehash:o,hash:i,randomBytes:s,nByteLength:a,h:c}=e,f=ai<<BigInt(a*8)-ze,u=t.create,l=e.uvRatio||((A,b)=>{try{return{isValid:!0,value:t.sqrt(A*t.inv(b))}}catch{return{isValid:!1,value:ct}}}),p=e.adjustScalarBytes||(A=>A),E=e.domain||((A,b,P)=>{if(b.length||P)throw new Error("Contexts/pre-hash are not supported");return A}),y=A=>typeof A=="bigint"&&ct<A,d=(A,b)=>y(A)&&y(b)&&A<b,m=A=>A===ct||d(A,f);function g(A,b){if(d(A,b))return A;throw new Error(`Expected valid scalar < ${b}, got ${typeof A} ${A}`)}function I(A){return A===ct?A:g(A,n)}let v=new Map;function U(A){if(!(A instanceof S))throw new Error("ExtendedPoint expected")}class S{constructor(b,P,M,K){if(this.ex=b,this.ey=P,this.ez=M,this.et=K,!m(b))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(b){if(b instanceof S)throw new Error("extended point not allowed");let{x:P,y:M}=b||{};if(!m(P)||!m(M))throw new Error("invalid affine point");return new S(P,M,ze,u(P*M))}static normalizeZ(b){let P=t.invertBatch(b.map(M=>M.ez));return b.map((M,K)=>M.toAffine(P[K])).map(S.fromAffine)}_setWindowSize(b){this._WINDOW_SIZE=b,v.delete(this)}assertValidity(){let{a:b,d:P}=e;if(this.is0())throw new Error("bad point: ZERO");let{ex:M,ey:K,ez:z,et:W}=this,re=u(M*M),Z=u(K*K),X=u(z*z),pe=u(X*X),ue=u(re*b),ve=u(X*u(ue+Z)),Be=u(pe+u(P*u(re*Z)));if(ve!==Be)throw new Error("bad point: equation left != right (1)");let ye=u(M*K),Re=u(z*W);if(ye!==Re)throw new Error("bad point: equation left != right (2)")}equals(b){U(b);let{ex:P,ey:M,ez:K}=this,{ex:z,ey:W,ez:re}=b,Z=u(P*re),X=u(z*K),pe=u(M*re),ue=u(W*K);return Z===X&&pe===ue}is0(){return this.equals(S.ZERO)}negate(){return new S(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:b}=e,{ex:P,ey:M,ez:K}=this,z=u(P*P),W=u(M*M),re=u(ai*u(K*K)),Z=u(b*z),X=P+M,pe=u(u(X*X)-z-W),ue=Z+W,ve=ue-re,Be=Z-W,ye=u(pe*ve),Re=u(ue*Be),St=u(pe*Be),wr=u(ve*ue);return new S(ye,Re,wr,St)}add(b){U(b);let{a:P,d:M}=e,{ex:K,ey:z,ez:W,et:re}=this,{ex:Z,ey:X,ez:pe,et:ue}=b;if(P===BigInt(-1)){let su=u((z-K)*(X+Z)),au=u((z+K)*(X-Z)),Ps=u(au-su);if(Ps===ct)return this.double();let cu=u(W*ai*ue),uu=u(re*ai*pe),lu=uu+cu,fu=au+su,hu=uu-cu,lp=u(lu*Ps),fp=u(fu*hu),hp=u(lu*hu),dp=u(Ps*fu);return new S(lp,fp,dp,hp)}let ve=u(K*Z),Be=u(z*X),ye=u(re*M*ue),Re=u(W*pe),St=u((K+z)*(Z+X)-ve-Be),wr=Re-ye,On=Re+ye,iu=u(Be-P*ve),sp=u(St*wr),ap=u(On*iu),cp=u(St*iu),up=u(wr*On);return new S(sp,ap,up,cp)}subtract(b){return this.add(b.negate())}wNAF(b){return w.wNAFCached(this,v,b,S.normalizeZ)}multiply(b){let{p:P,f:M}=this.wNAF(g(b,n));return S.normalizeZ([P,M])[0]}multiplyUnsafe(b){let P=I(b);return P===ct?L:this.equals(L)||P===ze?this:this.equals(_)?this.wNAF(P).p:w.unsafeLadder(this,P)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return w.unsafeLadder(this,n).is0()}toAffine(b){let{ex:P,ey:M,ez:K}=this,z=this.is0();b==null&&(b=z?By:t.inv(K));let W=u(P*b),re=u(M*b),Z=u(K*b);if(z)return{x:ct,y:ze};if(Z!==ze)throw new Error("invZ was invalid");return{x:W,y:re}}clearCofactor(){let{h:b}=e;return b===ze?this:this.multiplyUnsafe(b)}static fromHex(b,P=!1){let{d:M,a:K}=e,z=t.BYTES;b=fe("pointHex",b,z);let W=b.slice(),re=b[z-1];W[z-1]=re&-129;let Z=ir(W);Z===ct||(P?g(Z,f):g(Z,t.ORDER));let X=u(Z*Z),pe=u(X-ze),ue=u(M*X-K),{isValid:ve,value:Be}=l(pe,ue);if(!ve)throw new Error("Point.fromHex: invalid y coordinate");let ye=(Be&ze)===ze,Re=(re&128)!==0;if(!P&&Be===ct&&Re)throw new Error("Point.fromHex: x=0 and x_0=1");return Re!==ye&&(Be=u(-Be)),S.fromAffine({x:Be,y:Z})}static fromPrivateKey(b){return T(b).point}toRawBytes(){let{x:b,y:P}=this.toAffine(),M=Nr(P,t.BYTES);return M[M.length-1]|=b&ze?128:0,M}toHex(){return Tt(this.toRawBytes())}}S.BASE=new S(e.Gx,e.Gy,ze,u(e.Gx*e.Gy)),S.ZERO=new S(ct,ze,ze,ct);let{BASE:_,ZERO:L}=S,w=si(S,a*8);function N(A){return ne(A,n)}function O(A){return N(ir(A))}function T(A){let b=a;A=fe("private key",A,b);let P=fe("hashed private key",i(A),2*b),M=p(P.slice(0,b)),K=P.slice(b,2*b),z=O(M),W=_.multiply(z),re=W.toRawBytes();return{head:M,prefix:K,scalar:z,point:W,pointBytes:re}}function F(A){return T(A).pointBytes}function $(A=new Uint8Array,...b){let P=Ct(...b);return O(i(E(P,fe("context",A),!!o)))}function J(A,b,P={}){A=fe("message",A),o&&(A=o(A));let{prefix:M,scalar:K,pointBytes:z}=T(b),W=$(P.context,M,A),re=_.multiply(W).toRawBytes(),Z=$(P.context,re,z,A),X=N(W+Z*K);I(X);let pe=Ct(re,Nr(X,t.BYTES));return fe("result",pe,a*2)}let x=Ay;function k(A,b,P,M=x){let{context:K,zip215:z}=M,W=t.BYTES;A=fe("signature",A,2*W),b=fe("message",b),o&&(b=o(b));let re=ir(A.slice(W,2*W)),Z,X,pe;try{Z=S.fromHex(P,z),X=S.fromHex(A.slice(0,W),z),pe=_.multiplyUnsafe(re)}catch{return!1}if(!z&&Z.isSmallOrder())return!1;let ue=$(K,X.toRawBytes(),Z.toRawBytes(),b);return X.add(Z.multiplyUnsafe(ue)).subtract(pe).clearCofactor().equals(S.ZERO)}return _._setWindowSize(8),{CURVE:e,getPublicKey:F,sign:J,verify:k,ExtendedPoint:S,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>s(t.BYTES),precompute(A=8,b=S.BASE){return b._setWindowSize(A),b.multiply(BigInt(3)),b}}}}var rc=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Fl=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),_v=BigInt(0),Sy=BigInt(1),tc=BigInt(2),Iy=BigInt(5),Ml=BigInt(10),Ry=BigInt(20),_y=BigInt(40),Hl=BigInt(80);function Ty(r){let e=rc,n=r*r%e*r%e,o=ce(n,tc,e)*n%e,i=ce(o,Sy,e)*r%e,s=ce(i,Iy,e)*i%e,a=ce(s,Ml,e)*s%e,c=ce(a,Ry,e)*a%e,f=ce(c,_y,e)*c%e,u=ce(f,Hl,e)*f%e,l=ce(u,Hl,e)*f%e,p=ce(l,Ml,e)*s%e;return{pow_p_5_8:ce(p,tc,e)*r%e,b2:n}}function Ny(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Cy(r,e){let t=rc,n=ne(e*e*e,t),o=ne(n*n*e,t),i=Ty(r*o).pow_p_5_8,s=ne(r*n*i,t),a=ne(e*s*s,t),c=s,f=ne(s*Fl,t),u=a===r,l=a===ne(-r,t),p=a===ne(-r*Fl,t);return u&&(s=c),(l||p)&&(s=f),Dl(s,t)&&(s=ne(-s,t)),{isValid:u||l,value:s}}var Lt=ii(rc,void 0,!0),nc={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Lt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:mn,randomBytes:dn,adjustScalarBytes:Ny,uvRatio:Cy},yn=ci(nc);function $l(r,e,t){if(e.length>255)throw new Error("Context is too big");return Qo(qa("SigEd25519 no Ed25519 collisions"),new Uint8Array([t?1:0,e.length]),e,r)}var Tv=ci({...nc,domain:$l}),Nv=ci({...nc,domain:$l,prehash:mn});var Ly=(Lt.ORDER+BigInt(3))/BigInt(8),Cv=Lt.pow(tc,Ly),Lv=Lt.sqrt(Lt.neg(Lt.ONE)),Uv=(Lt.ORDER-BigInt(5))/BigInt(8),Dv=BigInt(486662);var Pv=Pl(Lt,Lt.neg(BigInt(486664)));var Ov=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),Vv=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),Fv=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),Mv=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var Hv=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var gn=32,Ut=64,ui=32;function Kl(){let r=yn.utils.randomPrivateKey(),e=yn.getPublicKey(r);return{privateKey:jl(r,e),publicKey:e}}function ql(r){if(r.length!==ui)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=yn.getPublicKey(e);return{privateKey:jl(e,t),publicKey:t}}function zl(r,e){let t=r.subarray(0,ui);return yn.sign(e instanceof Uint8Array?e:e.subarray(),t)}function Gl(r,e,t){return yn.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function jl(r,e){let t=new Uint8Array(Ut);for(let n=0;n<ui;n++)t[n]=r[n],t[ui+n]=e[n];return t}var De={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 Wl(r){let e=r?.algorithm??"AES-GCM",t=r?.keyLength??16,n=r?.nonceLength??12,o=r?.digest??"SHA-256",i=r?.saltLength??16,s=r?.iterations??32767,a=De.get();t*=8;async function c(l,p){let E=a.getRandomValues(new Uint8Array(i)),y=a.getRandomValues(new Uint8Array(n)),d={name:e,iv:y};typeof p=="string"&&(p=G(p));let m;if(p.length===0){m=await a.subtle.importKey("jwk",oc,{name:"AES-GCM"},!0,["encrypt"]);try{let I={name:"PBKDF2",salt:E,iterations:s,hash:{name:o}},v=await a.subtle.importKey("raw",p,{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:E,iterations:s,hash:{name:o}},v=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(I,v,{name:e,length:t},!0,["encrypt"])}let g=await a.subtle.encrypt(d,m,l);return Le([E,d.iv,new Uint8Array(g)])}async function f(l,p){let E=l.subarray(0,i),y=l.subarray(i,i+n),d=l.subarray(i+n),m={name:e,iv:y};typeof p=="string"&&(p=G(p));let g;if(p.length===0)try{let v={name:"PBKDF2",salt:E,iterations:s,hash:{name:o}},U=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(v,U,{name:e,length:t},!0,["decrypt"])}catch{g=await a.subtle.importKey("jwk",oc,{name:"AES-GCM"},!0,["decrypt"])}else{let v={name:"PBKDF2",salt:E,iterations:s,hash:{name:o}},U=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(v,U,{name:e,length:t},!0,["decrypt"])}let I=await a.subtle.decrypt(m,g,d);return new Uint8Array(I)}return{encrypt:c,decrypt:f}}async function wn(r,e){let n=await Wl().encrypt(r,e);return Xt.encode(n)}var de;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(de||(de={}));var ic;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(ic||(ic={}));(function(r){r.codec=()=>zn(ic)})(de||(de={}));var xt;(function(r){let e;r.codec=()=>(e==null&&(e=en((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),de.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),o.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let o={},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let s=t.uint32();switch(s>>>3){case 1:o.Type=de.codec().decode(t);break;case 2:o.Data=t.bytes();break;default:t.skipType(s&7);break}}return o})),e),r.encode=t=>Xr(t,r.codec()),r.decode=t=>Jr(t,r.codec())})(xt||(xt={}));var Dt;(function(r){let e;r.codec=()=>(e==null&&(e=en((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),de.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),o.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let o={},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let s=t.uint32();switch(s>>>3){case 1:o.Type=de.codec().decode(t);break;case 2:o.Data=t.bytes();break;default:t.skipType(s&7);break}}return o})),e),r.encode=t=>Xr(t,r.codec()),r.decode=t=>Jr(t,r.codec())})(Dt||(Dt={}));var Jn=class{_key;constructor(e){this._key=bn(e,gn)}verify(e,t){return Gl(this._key,t,e)}marshal(){return this._key}get bytes(){return xt.encode({Type:de.Ed25519,Data:this.marshal()}).subarray()}equals(e){return oe(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(e)?e.then(({bytes:t})=>t):e.bytes}},Lr=class{_key;_publicKey;constructor(e,t){this._key=bn(e,Ut),this._publicKey=bn(t,gn)}sign(e){return zl(this._key,e)}get public(){return new Jn(this._publicKey)}marshal(){return this._key}get bytes(){return Dt.encode({Type:de.Ed25519,Data:this.marshal()}).subarray()}equals(e){return oe(this.bytes,e.bytes)}async hash(){let e=we.digest(this.bytes),t;return Xe(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=Je.digest(this.public.bytes);return he.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return wn(this.bytes,e);throw new C(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Py(r){if(r.length>Ut){r=bn(r,Ut+gn);let n=r.subarray(0,Ut),o=r.subarray(Ut,r.length);return new Lr(n,o)}r=bn(r,Ut);let e=r.subarray(0,Ut),t=r.subarray(gn);return new Lr(e,t)}function Oy(r){return r=bn(r,gn),new Jn(r)}async function Vy(){let{privateKey:r,publicKey:e}=Kl();return new Lr(r,e)}async function Yl(r){let{privateKey:e,publicKey:t}=ql(r);return new Lr(e,t)}function bn(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new C(`Key must be a Uint8Array of length ${e}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}var yc={};ge(yc,{MAX_RSA_KEY_SIZE:()=>uo,RsaPrivateKey:()=>An,RsaPublicKey:()=>co,fromJwk:()=>fg,generateKeyPair:()=>hg,unmarshalRsaPrivateKey:()=>pc,unmarshalRsaPublicKey:()=>lg});function Ur(r){if(isNaN(r)||r<=0)throw new C("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return dn(r)}var lr={};ge(lr,{exportToPem:()=>ig,importFromPem:()=>sg,jwkToPkcs1:()=>tg,jwkToPkix:()=>ng,pkcs1ToJwk:()=>eg,pkixToJwk:()=>rg});var fi=class extends fn{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,Jo(e);let n=rr(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,i=new Uint8Array(o);i.set(n.length>o?e.create().update(n).digest():n);for(let s=0;s<i.length;s++)i[s]^=54;this.iHash.update(i),this.oHash=e.create();for(let s=0;s<i.length;s++)i[s]^=106;this.oHash.update(i),i.fill(0)}update(e){return ln(this),this.iHash.update(e),this}digestInto(e){ln(this),Ka(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:i,blockLen:s,outputLen:a}=this;return e=e,e.finished=o,e.destroyed=i,e.blockLen=s,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()}},Xn=(r,e,t)=>new fi(r,e).update(t).digest();Xn.create=(r,e)=>new fi(r,e);function Fy(r,e,t,n){Jo(r);let o=Il({dkLen:32,asyncTick:10},n),{c:i,dkLen:s,asyncTick:a}=o;if(un(i),un(s),un(a),i<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=rr(e),f=rr(t),u=new Uint8Array(s),l=Xn.create(r,c),p=l._cloneInto().update(f);return{c:i,dkLen:s,asyncTick:a,DK:u,PRF:l,PRFSalt:p}}function My(r,e,t,n,o){return r.destroy(),e.destroy(),n&&n.destroy(),o.fill(0),t}async function ac(r,e,t,n){let{c:o,dkLen:i,asyncTick:s,DK:a,PRF:c,PRFSalt:f}=Fy(r,e,t,n),u,l=new Uint8Array(4),p=hn(l),E=new Uint8Array(c.outputLen);for(let y=1,d=0;d<i;y++,d+=c.outputLen){let m=a.subarray(d,d+c.outputLen);p.setInt32(0,y,!1),(u=f._cloneInto(u)).update(l).digestInto(E),m.set(E.subarray(0,m.length)),await Sl(o-1,s,()=>{c._cloneInto(u).update(E).digestInto(E);for(let g=0;g<m.length;g++)m[g]^=E[g]})}return My(c,f,a,u,E)}var Y=yt(Zl());function Dr(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,i=0,s=Math.pow(2,e);for(let a=1;a<8;a++){if(r<s){let c;if(n<0)c=new ArrayBuffer(a),i=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),i=n}let f=new Uint8Array(c);for(let u=a-1;u>=0;u--){let l=Math.pow(2,u*e);f[i-u-1]=Math.floor(o/l),o-=f[i-u-1]*l}return c}s*=Math.pow(2,e)}return new ArrayBuffer(0)}function pi(...r){let e=0,t=0;for(let i of r)e+=i.length;let n=new ArrayBuffer(e),o=new Uint8Array(n);for(let i of r)o.set(i,t),t+=i.length;return o}function uc(){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=Dr(t,8),o=new ArrayBuffer(this.valueHex.byteLength),i=new Uint8Array(o);for(let a=0;a<this.valueHex.byteLength;a++)i[a]=r[a];return i[0]&=127,Dr(i,8)-n}function Jl(r){let e=r<0?r*-1:r,t=128;for(let n=1;n<8;n++){if(e<=t){if(r<0){let s=t-e,a=ar(s,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=ar(e,8,n),i=new Uint8Array(o);if(i[0]&128){let s=o.slice(0),a=new Uint8Array(s);o=new ArrayBuffer(o.byteLength+1),i=new Uint8Array(o);for(let c=0;c<s.byteLength;c++)i[c+1]=a[c];i[0]=0}return o}t*=Math.pow(2,8)}return new ArrayBuffer(0)}function Xl(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 Fe(r,e){let t=r.toString(10);if(e<t.length)return"";let n=e-t.length,o=new Array(n);for(let s=0;s<n;s++)o[s]="0";return o.join("").concat(t)}var m2=Math.log(2);function mi(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function lc(r){let e=0,t=0;for(let o=0;o<r.length;o++){let i=r[o];e+=i.byteLength}let n=new Uint8Array(e);for(let o=0;o<r.length;o++){let i=r[o];n.set(new Uint8Array(i),t),t+=i.byteLength}return n.buffer}function Mt(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 eo=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return lc(this.items)}},Qn=[new Uint8Array([1])],Ql="0123456789";var vn="",lt=new ArrayBuffer(0),fc=new Uint8Array(0),to="EndOfContent",tf="OCTET STRING",rf="BIT STRING";function Ht(r){var e;return e=class extends r{constructor(...n){var o;super(...n);let i=n[0]||{};this.isHexOnly=(o=i.isHexOnly)!==null&&o!==void 0?o:!1,this.valueHexView=i.valueHex?Y.BufferSourceConverter.toUint8Array(i.valueHex):fc}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,o,i){let s=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Mt(this,s,o,i))return-1;let a=o+i;return this.valueHexView=s.subarray(o,a),this.valueHexView.length?(this.blockLength=i,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",lt)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Y.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var Ot=class{constructor({blockLength:e=0,error:t=vn,warnings:n=[],valueBeforeDecode:o=fc}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=Y.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:Y.Convert.ToHex(this.valueBeforeDecodeView)}}};Ot.NAME="baseBlock";var Ne=class extends Ot{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'")}};Ne.NAME="valueBlock";var yi=class extends Ht(Ot){constructor({idBlock:e={}}={}){var t,n,o,i;super(),e?(this.isHexOnly=(t=e.isHexOnly)!==null&&t!==void 0?t:!1,this.valueHexView=e.valueHex?Y.BufferSourceConverter.toUint8Array(e.valueHex):fc,this.tagClass=(n=e.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(o=e.tagNumber)!==null&&o!==void 0?o:-1,this.isConstructed=(i=e.isConstructed)!==null&&i!==void 0?i:!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",lt}if(this.isConstructed&&(t|=32),this.tagNumber<31&&!this.isHexOnly){let o=new Uint8Array(1);if(!e){let i=this.tagNumber;i&=31,t|=i,o[0]=t}return o.buffer}if(!this.isHexOnly){let o=ar(this.tagNumber,7),i=new Uint8Array(o),s=o.byteLength,a=new Uint8Array(s+1);if(a[0]=t|31,!e){for(let c=0;c<s-1;c++)a[c+1]=i[c]|128;a[s]=i[s-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=t|31,!e){let o=this.valueHexView;for(let i=0;i<o.length-1;i++)n[i+1]=o[i]|128;n[this.valueHexView.byteLength]=o[o.length-1]}return n.buffer}fromBER(e,t,n){let o=Y.BufferSourceConverter.toUint8Array(e);if(!Mt(this,o,t,n))return-1;let i=o.subarray(t,t+n);if(i.length===0)return this.error="Zero buffer length",-1;switch(i[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=(i[0]&32)===32,this.isHexOnly=!1;let a=i[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),u=255;for(;i[c]&128;){if(f[c-1]=i[c]&127,c++,c>=i.length)return this.error="End of input reached before message was fully decoded",-1;if(c===u){u+=255;let p=new Uint8Array(u);for(let E=0;E<f.length;E++)p[E]=f[E];f=this.valueHexView=new Uint8Array(u)}}this.blockLength=c+1,f[c-1]=i[c]&127;let l=new Uint8Array(c);for(let p=0;p<c;p++)l[p]=f[p];f=this.valueHexView=new Uint8Array(c),f.set(l),this.blockLength<=9?this.tagNumber=Dr(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}}};yi.NAME="identificationBlock";var gi=class extends Ot{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=Y.BufferSourceConverter.toUint8Array(e);if(!Mt(this,o,t,n))return-1;let i=o.subarray(t,t+n);if(i.length===0)return this.error="Zero buffer length",-1;if(i[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=i[0]===128,this.isIndefiniteForm)return this.blockLength=1,t+this.blockLength;if(this.longFormUsed=!!(i[0]&128),this.longFormUsed===!1)return this.length=i[0],this.blockLength=1,t+this.blockLength;let s=i[0]&127;if(s>8)return this.error="Too big integer",-1;if(s+1>i.length)return this.error="End of input reached before message was fully decoded",-1;let a=t+1,c=o.subarray(a,a+s);return c[s-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Dr(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=s+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",lt;if(t=new ArrayBuffer(o.byteLength+1),e)return t;let i=new Uint8Array(o);n=new Uint8Array(t),n[0]=o.byteLength|128;for(let s=0;s<o.byteLength;s++)n[s+1]=i[s];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}}};gi.NAME="lengthBlock";var D={},ke=class extends Ot{constructor({name:e=vn,optional:t=!1,primitiveSchema:n,...o}={},i){super(o),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new yi(o),this.lenBlock=new gi(o),this.valueBlock=i?new i(o):new Ne(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 eo;t||nf(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 i=this.valueBlock.toBER(e);this.lenBlock.length=i.byteLength;let s=this.lenBlock.toBER(e);n.write(s),n.write(i)}return t?lt: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():Y.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${Y.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 Xl(t,n)}};ke.NAME="BaseBlock";function nf(r){if(r instanceof D.Constructed)for(let e of r.valueBlock.value)nf(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var wi=class extends ke{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}'`}};wi.NAME="BaseStringBlock";var bi=class extends Ht(Ne){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};bi.NAME="PrimitiveValueBlock";var of,xi=class extends ke{constructor(e={}){super(e,bi),this.idBlock.isConstructed=!1}};of=xi;D.Primitive=of;xi.NAME="PRIMITIVE";function Yy(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 Qi(r,e=0,t=r.length){let n=e,o=new ke({},Ne),i=new Ot;if(!Mt(i,r,e,t))return o.error=i.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=ke;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=Yy(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 Bn(r){if(!r.byteLength){let e=new ke({},Ne);return e.error="Input buffer has zero length",{offset:-1,result:e}}return Qi(Y.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Zy(r,e){return r?1:e}var Et=class extends Ne{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n){let o=Y.BufferSourceConverter.toUint8Array(e);if(!Mt(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 i=t;for(;Zy(this.isIndefiniteForm,n)>0;){let s=Qi(o,i,n);if(s.offset===-1)return this.error=s.result.error,this.warnings.concat(s.result.warnings),-1;if(i=s.offset,this.blockLength+=s.result.blockLength,n-=s.result.blockLength,this.value.push(s.result),this.isIndefiniteForm&&s.result.constructor.NAME===to)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===to?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(e,t){let n=t||new eo;for(let o=0;o<this.value.length;o++)this.value[o].toBER(e,n);return t?lt:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};Et.NAME="ConstructedValueBlock";var sf,cr=class extends ke{constructor(e={}){super(e,Et),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 Np=Object.create;var Po=Object.defineProperty;var Lp=Object.getOwnPropertyDescriptor;var Dp=Object.getOwnPropertyNames;var Up=Object.getPrototypeOf,Pp=Object.prototype.hasOwnProperty;var Xt=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),ge=(r,e)=>{for(var t in e)Po(r,t,{get:e[t],enumerable:!0})},ku=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Dp(e))!Pp.call(r,o)&&o!==t&&Po(r,o,{get:()=>e[o],enumerable:!(n=Lp(e,o))||n.enumerable});return r};var st=(r,e,t)=>(t=r!=null?Np(Up(r)):{},ku(e||!r||!r.__esModule?Po(t,"default",{value:r,enumerable:!0}):t,r)),Op=r=>ku(Po({},"__esModule",{value:!0}),r);var Gu=Xt((Yb,zu)=>{var Zr=1e3,Jr=Zr*60,Xr=Jr*60,Ir=Xr*24,Bm=Ir*7,km=Ir*365.25;zu.exports=function(r,e){e=e||{};var t=typeof r;if(t==="string"&&r.length>0)return Sm(r);if(t==="number"&&isFinite(r))return e.long?Rm(r):Im(r);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(r))};function Sm(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*km;case"weeks":case"week":case"w":return t*Bm;case"days":case"day":case"d":return t*Ir;case"hours":case"hour":case"hrs":case"hr":case"h":return t*Xr;case"minutes":case"minute":case"mins":case"min":case"m":return t*Jr;case"seconds":case"second":case"secs":case"sec":case"s":return t*Zr;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return t;default:return}}}}function Im(r){var e=Math.abs(r);return e>=Ir?Math.round(r/Ir)+"d":e>=Xr?Math.round(r/Xr)+"h":e>=Jr?Math.round(r/Jr)+"m":e>=Zr?Math.round(r/Zr)+"s":r+"ms"}function Rm(r){var e=Math.abs(r);return e>=Ir?Fo(r,e,Ir,"day"):e>=Xr?Fo(r,e,Xr,"hour"):e>=Jr?Fo(r,e,Jr,"minute"):e>=Zr?Fo(r,e,Zr,"second"):r+" ms"}function Fo(r,e,t,n){var o=e>=t*1.5;return Math.round(r/t)+" "+n+(o?"s":"")}});var Wu=Xt((Zb,ju)=>{function _m(r){t.debug=t,t.default=t,t.coerce=c,t.disable=s,t.enable=o,t.enabled=i,t.humanize=Gu(),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 p=0;p<u.length;p++)l=(l<<5)-l+u.charCodeAt(p),l|=0;return t.colors[Math.abs(l)%t.colors.length]}t.selectColor=e;function t(u){let l,p=null,E,y;function d(...m){if(!d.enabled)return;let g=d,I=Number(new Date),v=I-(l||I);g.diff=v,g.prev=l,g.curr=I,l=I,m[0]=t.coerce(m[0]),typeof m[0]!="string"&&m.unshift("%O");let D=0;m[0]=m[0].replace(/%([a-zA-Z%])/g,(_,L)=>{if(_==="%%")return"%";D++;let w=t.formatters[L];if(typeof w=="function"){let C=m[D];_=w.call(g,C),m.splice(D,1),D--}return _}),t.formatArgs.call(g,m),(g.log||t.log).apply(g,m)}return d.namespace=u,d.useColors=t.useColors(),d.color=t.selectColor(u),d.extend=n,d.destroy=t.destroy,Object.defineProperty(d,"enabled",{enumerable:!0,configurable:!1,get:()=>p!==null?p:(E!==t.namespaces&&(E=t.namespaces,y=t.enabled(u)),y),set:m=>{p=m}}),typeof t.init=="function"&&t.init(d),d}function n(u,l){let p=t(this.namespace+(typeof l>"u"?":":l)+u);return p.log=this.log,p}function o(u){t.save(u),t.namespaces=u,t.names=[],t.skips=[];let l,p=(typeof u=="string"?u:"").split(/[\s,]+/),E=p.length;for(l=0;l<E;l++)p[l]&&(u=p[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,p;for(l=0,p=t.skips.length;l<p;l++)if(t.skips[l].test(u))return!1;for(l=0,p=t.names.length;l<p;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}ju.exports=_m});var Yu=Xt((He,Mo)=>{He.formatArgs=Cm;He.save=Nm;He.load=Lm;He.useColors=Tm;He.storage=Dm();He.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`."))}})();He.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 Tm(){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 Cm(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+Mo.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)}He.log=console.debug||console.log||(()=>{});function Nm(r){try{r?He.storage.setItem("debug",r):He.storage.removeItem("debug")}catch{}}function Lm(){let r;try{r=He.storage.getItem("debug")}catch{}return!r&&typeof process<"u"&&"env"in process&&(r=process.env.DEBUG),r}function Dm(){try{return localStorage}catch{}}Mo.exports=Wu()(He);var{formatters:Um}=Mo.exports;Um.j=function(r){try{return JSON.stringify(r)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}});var on=Xt((y1,pl)=>{"use strict";function dl(r,e){for(let t in e)Object.defineProperty(r,t,{value:e[t],enumerable:!0,configurable:!0});return r}function y0(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 dl(r,t)}catch{t.message=r.message,t.stack=r.stack;let o=function(){};return o.prototype=Object.create(Object.getPrototypeOf(r)),dl(new o,t)}}pl.exports=y0});var lf=Xt(Sn=>{"use strict";var og="[object ArrayBuffer]",Ft=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===og}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}},mc="string",sg=/^[0-9a-f]+$/i,ig=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,ag=/^[a-zA-Z0-9-_]+$/,ys=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=Ft.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return decodeURIComponent(escape(n))}},Qe=class{static toString(e,t=!1){let n=Ft.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}},gs=class r{static isHex(e){return typeof e===mc&&sg.test(e)}static isBase64(e){return typeof e===mc&&ig.test(e)}static isBase64Url(e){return typeof e===mc&&ag.test(e)}static ToString(e,t="utf8"){let n=Ft.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 Qe.toString(n,!0);case"utf16":case"utf16be":return Qe.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 Qe.fromString(e,!0);case"utf16":case"utf16be":return Qe.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=Ft.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 ys.fromString(e);case"utf16":case"utf16be":return Qe.fromString(e);case"utf16le":case"usc2":return Qe.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 ys.toString(e);case"utf16":case"utf16be":return Qe.toString(e);case"utf16le":case"usc2":return Qe.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=Ft.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return n}static ToHex(e){let t=Ft.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 Qe.toString(e,t)}static FromUtf16String(e,t=!1){return Qe.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,"")||""}};gs.DEFAULT_UTF8_ENCODING="utf8";function cg(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 ug(...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 lg(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}Sn.BufferSourceConverter=Ft;Sn.Convert=gs;Sn.assign=cg;Sn.combine=ug;Sn.isEqual=lg});var Cc=Xt((UA,Tc)=>{var DA=function(){typeof Tc<"u"&&(Tc.exports=d);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(w){var C=w-w%1;return C==0&&(w<0||w===0&&1/w!=1/0)?-0:C},u=d.prototype,l=(d.fromDate=function(w){return new d(+w)},d.fromInt64BE=D(0,1,2,3,0,4),d.fromInt64LE=D(3,2,1,0,4,0),d.fromString=function(T){var C,O=new d,T=(T+="").replace(/^\s*[+\-]?\d+/,function($){var $=+$,J=1970+($-1970)%400;return O.year=$-J,J}).replace(/(?:Z|([+\-]\d{2}):?(\d{2}))$/,function(F,$,J){return $<0&&(J*=-1),C=6e4*(60*+$+ +J),""}).replace(/\.\d+$/,function(F){return O.nano=+(F+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)},d.fromTimeT=function(w){return I(w,0)},u.year=0,u.time=0,u.nano=0,u.addNano=function(w){return this.nano+=+w||0,this},u.getNano=function(){var w=m(this);return(w.time%1e3*a+ +w.nano+1e9)%1e9},u.getTimeT=function(){var C=m(this),w=Math.floor(C.time/1e3),C=C.year;return C&&(w+=C*t*r/e),w},u.getYear=function(){return this.toDate().getUTCFullYear()+this.year},u.toDate=function(){return g(m(this).time)},u.toJSON=function(){return this.toString().replace(/0{1,6}Z$/,"Z")},u.toString=function(w){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 F=C.getYear();return 999999<F?"+"+F:9999<F?"+"+L(F,6):0<=F?L(F,4):-999999<=F?"-"+L(-F,6):F},a:function(){return E[O.getUTCDay()]},b:function(){return p[O.getUTCMonth()]},d:function(){return _(O.getUTCDate())},e:function(){return function(F){return(9<F?"":" ")+(0|F)}(O.getUTCDate())},m:function(){return _(O.getUTCMonth()+1)}};return function F($){return $.replace(/%./g,function(J){var k=J[1],x=y[k],k=T[k];return x?F(x):k?k():J})}(w||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"),p=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],E=["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 d;function d(w,C,O){var T=this;if(!(T instanceof d))return new d(w,C,O);T.time=+w||0,T.nano=+C||0,T.year=+O||0,m(T)}function m(w){var C,O,T,F=w.year,$=w.time,J=w.nano,x=((J<0||a<=J)&&(J-=(O=Math.floor(J/a))*a,$+=O,O=1),F%e);return($<-s||s<$||x)&&((C=f($/o))&&(F+=C*e,$-=C*o),(T=g($)).setUTCFullYear(x+T.getUTCFullYear()),T=($=+T)+(C=f((F-=x)/e))*o,C&&-s<=T&&T<=s&&(F-=C*e,$=T),O=1),O&&(w.year=F,w.time=$,w.nano=J),w}function g(w){var C=new Date(0);return C.setTime(w),C}function I(F,T){F=+F||0;var O=f((T=(T|0)*i)/n)+f(F/n),T=T%n+F%n,F=f(T/n);return F&&(O+=F,T-=F*n),new d(1e3*T,0,O*e)}function v(w,C,O,T,F,$){return function(x,k){var B=m(this);x=x||new Array(8),S(x,k|=0);var b=Math.floor(B.time/1e3),B=B.year*(t*r/e),H=f(B/i)+f(b/i),B=B%i+b%i,b=Math.floor(B/i);return b&&(H+=b,B-=b*i),J(x,k+F,H),J(x,k+$,B),x};function J(x,k,H){x[k+w]=H>>24&255,x[k+C]=H>>16&255,x[k+O]=H>>8&255,x[k+T]=255&H}}function D(w,C,O,T,F,$){return function(x,k){S(x,k|=0);var H=J(x,k+F);return I(J(x,k+$),H)};function J(x,k){return 16777216*x[k+w]+(x[k+C]<<16|x[k+O]<<8|x[k+T])}}function S(w,C){if(w=w&&w.length,w==null)throw new TypeError("Invalid Buffer");if(w<C+8)throw new RangeError("Out of range")}function _(w){return(9<w?"":"0")+(0|w)}function L(w,C){return(c+(0|w)).substr(-C)}}()});var Dd=Xt((g8,Hc)=>{"use strict";var Rw=Object.prototype.hasOwnProperty,Oe="~";function Io(){}Object.create&&(Io.prototype=Object.create(null),new Io().__proto__||(Oe=!1));function _w(r,e,t){this.fn=r,this.context=e,this.once=t||!1}function Ld(r,e,t,n,o){if(typeof t!="function")throw new TypeError("The listener must be a function");var s=new _w(t,n||r,o),i=Oe?Oe+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 Ai(r,e){--r._eventsCount===0?r._events=new Io:delete r._events[e]}function Ne(){this._events=new Io,this._eventsCount=0}Ne.prototype.eventNames=function(){var e=[],t,n;if(this._eventsCount===0)return e;for(n in t=this._events)Rw.call(t,n)&&e.push(Oe?n.slice(1):n);return Object.getOwnPropertySymbols?e.concat(Object.getOwnPropertySymbols(t)):e};Ne.prototype.listeners=function(e){var t=Oe?Oe+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};Ne.prototype.listenerCount=function(e){var t=Oe?Oe+e:e,n=this._events[t];return n?n.fn?1:n.length:0};Ne.prototype.emit=function(e,t,n,o,s,i){var a=Oe?Oe+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 p=c.length,E;for(l=0;l<p;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(E=1,u=new Array(f-1);E<f;E++)u[E-1]=arguments[E];c[l].fn.apply(c[l].context,u)}}return!0};Ne.prototype.on=function(e,t,n){return Ld(this,e,t,n,!1)};Ne.prototype.once=function(e,t,n){return Ld(this,e,t,n,!0)};Ne.prototype.removeListener=function(e,t,n,o){var s=Oe?Oe+e:e;if(!this._events[s])return this;if(!t)return Ai(this,s),this;var i=this._events[s];if(i.fn)i.fn===t&&(!o||i.once)&&(!n||i.context===n)&&Ai(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:Ai(this,s)}return this};Ne.prototype.removeAllListeners=function(e){var t;return e?(t=Oe?Oe+e:e,this._events[t]&&Ai(this,t)):(this._events=new Io,this._eventsCount=0),this};Ne.prototype.off=Ne.prototype.removeListener;Ne.prototype.addListener=Ne.prototype.on;Ne.prefixed=Oe;Ne.EventEmitter=Ne;typeof Hc<"u"&&(Hc.exports=Ne)});var zd=Xt((bk,qd)=>{qd.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 bb={};ge(bb,{createHeliaHTTP:()=>wb});function Sr(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 Vp(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 qr=Vp;function Fp(r){return r[Symbol.asyncIterator]!=null}function Su(r){return r?.then!=null}function Mp(r,e){if(Fp(r))return async function*(){for await(let a of r){let c=e(a);Su(c)&&await c,yield a}}();let t=qr(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);Su(c)&&await c,yield a}}();let i=e;return function*(){yield n;for(let a of t)i(a),yield a}()}var Gi=Mp;var Ji={};ge(Ji,{base32:()=>Be,base32hex:()=>Wp,base32hexpad:()=>Zp,base32hexpadupper:()=>Jp,base32hexupper:()=>Yp,base32pad:()=>Gp,base32padupper:()=>jp,base32upper:()=>Lu,base32z:()=>Xp});var kb=new Uint8Array(0);function Iu(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 Rt(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 Ru(r){return new TextEncoder().encode(r)}function _u(r){return new TextDecoder().decode(r)}function Hp(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 d=0,m=0,g=0,I=y.length;g!==I&&y[g]===0;)g++,d++;for(var v=(I-g)*u+1>>>0,D=new Uint8Array(v);g!==I;){for(var S=y[g],_=0,L=v-1;(S!==0||_<m)&&L!==-1;L--,_++)S+=256*D[L]>>>0,D[L]=S%a>>>0,S=S/a>>>0;if(S!==0)throw new Error("Non-zero carry");m=_,g++}for(var w=v-m;w!==v&&D[w]===0;)w++;for(var C=c.repeat(d);w<v;++w)C+=r.charAt(D[w]);return C}function p(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var d=0;if(y[d]!==" "){for(var m=0,g=0;y[d]===c;)m++,d++;for(var I=(y.length-d)*f+1>>>0,v=new Uint8Array(I);y[d];){var D=t[y.charCodeAt(d)];if(D===255)return;for(var S=0,_=I-1;(D!==0||S<g)&&_!==-1;_--,S++)D+=a*v[_]>>>0,v[_]=D%256>>>0,D=D/256>>>0;if(D!==0)throw new Error("Non-zero carry");g=S,d++}if(y[d]!==" "){for(var L=I-g;L!==I&&v[L]===0;)L++;for(var w=new Uint8Array(m+(I-L)),C=m;L!==I;)w[C++]=v[L++];return w}}}function E(y){var d=p(y);if(d)return d;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:p,decode:E}}var $p=Hp,Kp=$p,Cu=Kp;var ji=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")}},Wi=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 Nu(this,e)}},Yi=class{decoders;constructor(e){this.decoders=e}or(e){return Nu(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 Nu(r,e){return new Yi({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var Zi=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 ji(e,t,n),this.decoder=new Wi(e,t,o)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function zr({name:r,prefix:e,encode:t,decode:n}){return new Zi(r,e,t,n)}function Qt({name:r,prefix:e,alphabet:t}){let{encode:n,decode:o}=Cu(t,r);return zr({prefix:e,name:r,encode:n,decode:s=>Rt(o(s))})}function qp(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 zp(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 le({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return zr({prefix:e,name:r,encode(o){return zp(o,n,t)},decode(o){return qp(o,n,t,r)}})}var Be=le({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Lu=le({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Gp=le({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),jp=le({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Wp=le({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Yp=le({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Zp=le({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Jp=le({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Xp=le({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Xi={};ge(Xi,{base58btc:()=>he,base58flickr:()=>Qp});var he=Qt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Qp=Qt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var em=Pu,Du=128,tm=127,rm=~tm,nm=Math.pow(2,31);function Pu(r,e,t){e=e||[],t=t||0;for(var n=t;r>=nm;)e[t++]=r&255|Du,r/=128;for(;r&rm;)e[t++]=r&255|Du,r>>>=7;return e[t]=r|0,Pu.bytes=t-n+1,e}var om=Qi,sm=128,Uu=127;function Qi(r,n){var t=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw Qi.bytes=0,new RangeError("Could not decode varint");i=r[s++],t+=o<28?(i&Uu)<<o:(i&Uu)*Math.pow(2,o),o+=7}while(i>=sm);return Qi.bytes=s-n,t}var im=Math.pow(2,7),am=Math.pow(2,14),cm=Math.pow(2,21),um=Math.pow(2,28),lm=Math.pow(2,35),fm=Math.pow(2,42),hm=Math.pow(2,49),dm=Math.pow(2,56),pm=Math.pow(2,63),mm=function(r){return r<im?1:r<am?2:r<cm?3:r<um?4:r<lm?5:r<fm?6:r<hm?7:r<dm?8:r<pm?9:10},ym={encode:em,decode:om,encodingLength:mm},gm=ym,qn=gm;function zn(r,e=0){return[qn.decode(r,e),qn.decode.bytes]}function Gr(r,e,t=0){return qn.encode(r,e,t),e}function jr(r){return qn.encodingLength(r)}function yt(r,e){let t=e.byteLength,n=jr(r),o=n+jr(t),s=new Uint8Array(o+t);return Gr(r,s,0),Gr(t,s,n),s.set(e,o),new Wr(r,t,e,s)}function gt(r){let e=Rt(r),[t,n]=zn(e),[o,s]=zn(e.subarray(n)),i=e.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Wr(t,o,i,e)}function Ou(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&Iu(r.bytes,t.bytes)}}var Wr=class{code;size;digest;bytes;constructor(e,t,n,o){this.code=e,this.size=t,this.digest=n,this.bytes=o}};function Vu(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return bm(t,ea(r),e??he.encoder);default:return xm(t,ea(r),e??Be.encoder)}}var Fu=new WeakMap;function ea(r){let e=Fu.get(r);if(e==null){let t=new Map;return Fu.set(r,t),t}return e}var re=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!==Gn)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==Em)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=yt(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&&Ou(e.multihash,n.multihash)}toString(e){return Vu(this,e)}toJSON(){return{"/":Vu(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??Mu(n,o,s.bytes))}else if(t[vm]===!0){let{version:n,multihash:o,code:s}=t,i=gt(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!==Gn)throw new Error(`Version 0 CID must use dag-pb (code: ${Gn}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let o=Mu(e,t,n.bytes);return new r(e,t,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Gn,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=Rt(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 Wr(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,p]=zn(e.subarray(t));return t+=p,l},o=n(),s=Gn;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]=wm(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 ea(s).set(n,e),s}};function wm(r,e){switch(r[0]){case"Q":{let t=e??he;return[he.prefix,t.decode(`${he.prefix}${r}`)]}case he.prefix:{let t=e??he;return[he.prefix,t.decode(r)]}case Be.prefix:{let t=e??Be;return[Be.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 bm(r,e,t){let{prefix:n}=t;if(n!==he.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 xm(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 Gn=112,Em=18;function Mu(r,e,t){let n=jr(r),o=n+jr(e),s=new Uint8Array(o+t.byteLength);return Gr(r,s,0),Gr(e,s,n),s.set(t,o),s}var vm=Symbol.for("@ipld/js-cid/CID");var jn=Symbol.for("@libp2p/content-routing");var ta=Symbol.for("@libp2p/peer-id");function Hu(r){return r!=null&&!!r[ta]}var Wn=Symbol.for("@libp2p/peer-routing");var er=class r extends Error{code;type;constructor(e="The operation was aborted"){super(e),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 Yr=(r,...e)=>{try{[...e]}catch{}};var Vo=class extends EventTarget{#e=new Map;constructor(){super(),Yr(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 Am(e,t))}},ra=class extends Event{detail;constructor(e,t){super(e,t),this.detail=t?.detail}},Am=globalThis.CustomEvent??ra;function $u(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function tr(...r){let e=[];for(let t of r)$u(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 rr(...r){let e=[];for(let t of r)$u(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()}))}var ia={};ge(ia,{sha256:()=>we,sha512:()=>sa});function oa({name:r,code:e,encode:t}){return new na(r,e,t)}var na=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?yt(this.code,t):t.then(n=>yt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function qu(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var we=oa({name:"sha2-256",code:18,encode:qu("SHA-256")}),sa=oa({name:"sha2-512",code:19,encode:qu("SHA-512")});var $e=st(Yu(),1);var aa={};ge(aa,{base64:()=>nr,base64pad:()=>Pm,base64url:()=>Om,base64urlpad:()=>Vm});var nr=le({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Pm=le({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Om=le({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Vm=le({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});$e.default.formatters.b=r=>r==null?"undefined":he.baseEncode(r);$e.default.formatters.t=r=>r==null?"undefined":Be.baseEncode(r);$e.default.formatters.m=r=>r==null?"undefined":nr.baseEncode(r);$e.default.formatters.p=r=>r==null?"undefined":r.toString();$e.default.formatters.c=r=>r==null?"undefined":r.toString();$e.default.formatters.k=r=>r==null?"undefined":r.toString();$e.default.formatters.a=r=>r==null?"undefined":r.toString();function Fm(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 Zu(){return{forComponent(r){return Ke(r)}}}function Ke(r){let e=Fm(`${r}:trace`);return $e.default.enabled(`${r}:trace`)&&$e.default.names.map(t=>t.toString()).find(t=>t.includes(":trace"))!=null&&(e=(0,$e.default)(`${r}:trace`)),Object.assign((0,$e.default)(r),{error:(0,$e.default)(`${r}:error`),trace:e})}function se(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 it(r=0){return new Uint8Array(r)}var Mm=Math.pow(2,7),Hm=Math.pow(2,14),$m=Math.pow(2,21),ca=Math.pow(2,28),ua=Math.pow(2,35),la=Math.pow(2,42),fa=Math.pow(2,49),ne=128,_e=127;function Ve(r){if(r<Mm)return 1;if(r<Hm)return 2;if(r<$m)return 3;if(r<ca)return 4;if(r<ua)return 5;if(r<la)return 6;if(r<fa)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ha(r,e,t=0){switch(Ve(r)){case 8:e[t++]=r&255|ne,r/=128;case 7:e[t++]=r&255|ne,r/=128;case 6:e[t++]=r&255|ne,r/=128;case 5:e[t++]=r&255|ne,r/=128;case 4:e[t++]=r&255|ne,r>>>=7;case 3:e[t++]=r&255|ne,r>>>=7;case 2:e[t++]=r&255|ne,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function Km(r,e,t=0){switch(Ve(r)){case 8:e.set(t++,r&255|ne),r/=128;case 7:e.set(t++,r&255|ne),r/=128;case 6:e.set(t++,r&255|ne),r/=128;case 5:e.set(t++,r&255|ne),r/=128;case 4:e.set(t++,r&255|ne),r>>>=7;case 3:e.set(t++,r&255|ne),r>>>=7;case 2:e.set(t++,r&255|ne),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function da(r,e){let t=r[e],n=0;if(n+=t&_e,t<ne||(t=r[e+1],n+=(t&_e)<<7,t<ne)||(t=r[e+2],n+=(t&_e)<<14,t<ne)||(t=r[e+3],n+=(t&_e)<<21,t<ne)||(t=r[e+4],n+=(t&_e)*ca,t<ne)||(t=r[e+5],n+=(t&_e)*ua,t<ne)||(t=r[e+6],n+=(t&_e)*la,t<ne)||(t=r[e+7],n+=(t&_e)*fa,t<ne))return n;throw new RangeError("Could not decode varint")}function qm(r,e){let t=r.get(e),n=0;if(n+=t&_e,t<ne||(t=r.get(e+1),n+=(t&_e)<<7,t<ne)||(t=r.get(e+2),n+=(t&_e)<<14,t<ne)||(t=r.get(e+3),n+=(t&_e)<<21,t<ne)||(t=r.get(e+4),n+=(t&_e)*ca,t<ne)||(t=r.get(e+5),n+=(t&_e)*ua,t<ne)||(t=r.get(e+6),n+=(t&_e)*la,t<ne)||(t=r.get(e+7),n+=(t&_e)*fa,t<ne))return n;throw new RangeError("Could not decode varint")}function Qr(r,e,t=0){return e==null&&(e=it(Ve(r))),e instanceof Uint8Array?ha(r,e,t):Km(r,e,t)}function Rr(r,e=0){return r instanceof Uint8Array?da(r,e):qm(r,e)}var pa=new Float32Array([-0]),or=new Uint8Array(pa.buffer);function Xu(r,e,t){pa[0]=r,e[t]=or[0],e[t+1]=or[1],e[t+2]=or[2],e[t+3]=or[3]}function Qu(r,e){return or[0]=r[e],or[1]=r[e+1],or[2]=r[e+2],or[3]=r[e+3],pa[0]}var ma=new Float64Array([-0]),Te=new Uint8Array(ma.buffer);function el(r,e,t){ma[0]=r,e[t]=Te[0],e[t+1]=Te[1],e[t+2]=Te[2],e[t+3]=Te[3],e[t+4]=Te[4],e[t+5]=Te[5],e[t+6]=Te[6],e[t+7]=Te[7]}function tl(r,e){return Te[0]=r[e],Te[1]=r[e+1],Te[2]=r[e+2],Te[3]=r[e+3],Te[4]=r[e+4],Te[5]=r[e+5],Te[6]=r[e+6],Te[7]=r[e+7],ma[0]}var zm=BigInt(Number.MAX_SAFE_INTEGER),Gm=BigInt(Number.MIN_SAFE_INTEGER),qe=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 _r;if(e<zm&&e>Gm)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>rl&&(o=0n,++n>rl&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(e){if(e===0)return _r;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):_r}},_r=new qe(0,0);_r.toBigInt=function(){return 0n};_r.zzEncode=_r.zzDecode=function(){return this};_r.length=function(){return 1};var rl=4294967296n;function nl(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 ol(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 ya(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 at(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function Ho(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var ga=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,at(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 at(this,4);return Ho(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw at(this,4);return Ho(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw at(this,4);let e=Qu(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw at(this,4);let e=tl(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 at(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return ol(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw at(this,e);this.pos+=e}else do if(this.pos>=this.len)throw at(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 qe(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 at(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 at(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 at(this,8);let e=Ho(this.buf,this.pos+=4),t=Ho(this.buf,this.pos+=4);return new qe(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=da(this.buf,this.pos);return this.pos+=Ve(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 wa(r){return new ga(r instanceof Uint8Array?r:r.subarray())}function en(r,e,t){let n=wa(r);return e.decode(n,void 0,t)}var ba={};ge(ba,{base10:()=>jm});var jm=Qt({prefix:"9",name:"base10",alphabet:"0123456789"});var xa={};ge(xa,{base16:()=>Wm,base16upper:()=>Ym});var Wm=le({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Ym=le({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ea={};ge(Ea,{base2:()=>Zm});var Zm=le({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var va={};ge(va,{base256emoji:()=>t0});var il=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}"),Jm=il.reduce((r,e,t)=>(r[t]=e,r),[]),Xm=il.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function Qm(r){return r.reduce((e,t)=>(e+=Jm[t],e),"")}function e0(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 t0=zr({prefix:"\u{1F680}",name:"base256emoji",encode:Qm,decode:e0});var Aa={};ge(Aa,{base36:()=>sr,base36upper:()=>r0});var sr=Qt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),r0=Qt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ba={};ge(Ba,{base8:()=>n0});var n0=le({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ka={};ge(ka,{identity:()=>o0});var o0=zr({prefix:"\0",name:"identity",encode:r=>_u(r),decode:r=>Ru(r)});var Ex=new TextEncoder,vx=new TextDecoder;var al=512;var $o=85;var Ia={};ge(Ia,{identity:()=>Je});var ul=0,s0="identity",ll=Rt;function i0(r){return yt(ul,ll(r))}var Je={code:ul,name:s0,encode:ll,digest:i0};var ir={...ka,...Ea,...Ba,...ba,...xa,...Ji,...Aa,...Xi,...aa,...va},Dx={...ia,...Ia};function hl(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var fl=hl("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Ra=hl("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=it(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),a0={utf8:fl,"utf-8":fl,hex:ir.base16,latin1:Ra,ascii:Ra,binary:Ra,...ir},Ko=a0;function W(r,e="utf8"){let t=Ko[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function _a(r){let e=r??8192,t=e>>>1,n,o=e;return function(i){if(i<1||i>t)return it(i);o+i>e&&(n=it(e),o=0);let a=n.subarray(o,o+=i);return o&7&&(o=(o|7)+1),a}}var Tr=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function Ta(){}var Na=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},c0=_a();function u0(r){return globalThis.Buffer!=null?it(r):c0(r)}var Zn=class{len;head;tail;states;constructor(){this.len=0,this.head=new Tr(Ta,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new Tr(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new La((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(qo,10,qe.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=qe.fromBigInt(e);return this._push(qo,t.length(),t)}uint64Number(e){return this._push(ha,Ve(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=qe.fromBigInt(e).zzEncode();return this._push(qo,t.length(),t)}sint64Number(e){let t=qe.fromNumber(e).zzEncode();return this._push(qo,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(Ca,1,e?1:0)}fixed32(e){return this._push(Yn,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=qe.fromBigInt(e);return this._push(Yn,4,t.lo)._push(Yn,4,t.hi)}fixed64Number(e){let t=qe.fromNumber(e);return this._push(Yn,4,t.lo)._push(Yn,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(Xu,4,e)}double(e){return this._push(el,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(Ca,1,0):this.uint32(t)._push(f0,t,e)}string(e){let t=nl(e);return t!==0?this.uint32(t)._push(ya,t,e):this._push(Ca,1,0)}fork(){return this.states=new Na(this),this.head=this.tail=new Tr(Ta,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 Tr(Ta,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=u0(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function Ca(r,e,t){e[t]=r&255}function l0(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var La=class extends Tr{next;constructor(e,t){super(l0,e,t),this.next=void 0}};function qo(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 Yn(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 f0(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(Zn.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(h0,e,r),this},Zn.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(d0,e,r),this});function h0(r,e,t){e.set(r,t)}function d0(r,e,t){r.length<40?ya(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(W(r),t)}function Da(){return new Zn}function tn(r,e){let t=Da();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var rn;(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"})(rn||(rn={}));function zo(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function Jn(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 zo("enum",rn.VARINT,t,n)}function nn(r,e){return zo("message",rn.LENGTH_DELIMITED,r,e)}function p0(r){return r[Symbol.asyncIterator]!=null}function m0(r){if(p0(r))return(async()=>{for await(let e of r);})();for(let e of r);}var Tt=m0;function Le(r,e){e==null&&(e=r.reduce((o,s)=>o+s.length,0));let t=it(e),n=0;for(let o of r)t.set(o,n),n+=o.length;return t}function g0(r){return r[Symbol.asyncIterator]!=null}function w0(r,e){if(g0(r))return async function*(){for await(let a of r)yield e(a)}();let t=qr(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 sn=w0;function De(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var Go=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}},an=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new Go(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 Go(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 Ua=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function Ct(r={}){return b0(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 b0(r,e){e=e??{};let t=e.onEnd,n=new an,o,s,i,a=De(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((m,g)=>{s=I=>{s=null,n.push(I);try{m(r(n))}catch(v){g(v)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=De()})}},f=m=>s!=null?s(m):(n.push(m),o),u=m=>(n=new an,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})},p=m=>i?o:(i=!0,m!=null?u(m):f({done:!0})),E=()=>(n=new an,p(),{done:!0}),y=m=>(p(m),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:E,throw:y,push:l,end:p,get readableLength(){return n.size},onEmpty:async m=>{let g=m?.signal;if(g?.throwIfAborted(),n.isEmpty())return;let I,v;g!=null&&(I=new Promise((D,S)=>{v=()=>{S(new Ua)},g.addEventListener("abort",v)}));try{await Promise.race([a.promise,I])}finally{v!=null&&g!=null&&g?.removeEventListener("abort",v)}}},t==null)return o;let d=o;return o={[Symbol.asyncIterator](){return this},next(){return d.next()},throw(m){return d.throw(m),t!=null&&(t(m),t=void 0),{done:!0}},return(){return d.return(),t!=null&&(t(),t=void 0),{done:!0}},push:l,end(m){return d.end(m),t!=null&&(t(m),t=void 0),o},get readableLength(){return d.readableLength},onEmpty:m=>d.onEmpty(m)},o}function x0(r){return r[Symbol.asyncIterator]!=null}function E0(...r){let e=[];for(let t of r)x0(t)||e.push(t);return e.length===r.length?function*(){for(let t of e)yield*t}():async function*(){let t=Ct({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 ar=E0;function v0(r){return r[Symbol.asyncIterator]!=null}function A0(r,e){return v0(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 jo=A0;var te=class extends Event{constructor(e,t){super(e),this.detail=t}};function z(r,e="utf8"){let t=Ko[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var Wo=class{url;#e=0;#t=0;#r=0;#i=0;constructor(e){this.url=e instanceof URL?e:new URL(e)}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(!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 Yo=class{gateways;log;constructor(e,t={}){this.log=e.logger.forComponent("helia:trustless-gateway-block-broker"),this.gateways=(t.gateways??ml).map(n=>new Wo(n))}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(`unable to validate block for CID ${e} from gateway ${s.url}`)}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 new AggregateError(o,`unable to fetch raw block for CID ${e} from any gateway`)}};var ml=["https://trustless-gateway.link","https://cloudflare-ipfs.com","https://4everland.io"];function Pa(r={}){return e=>new Yo(e,r)}var B0=Symbol.for("nodejs.util.inspect.custom"),yl=Object.values(ir).map(r=>r.decoder).reduce((r,e)=>r.or(e),ir.identity.decoder),gl=114,Oa=36,Va=37,Xn=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()})`}[ta]=!0;toString(){return this.string==null&&(this.string=he.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return re.createV1(gl,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return se(this.multihash.bytes,e);if(typeof e=="string")return Cr(e).equals(this);if(e?.multihash?.bytes!=null)return se(this.multihash.bytes,e.multihash.bytes);throw new Error("not valid Id")}[B0](){return`PeerId(${this.toString()})`}},cn=class extends Xn{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},un=class extends Xn{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.multihash.digest}},ln=class extends Xn{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.multihash.digest}};function Cr(r,e){if(e=e??yl,r.charAt(0)==="1"||r.charAt(0)==="Q"){let t=gt(he.decode(`z${r}`));return r.startsWith("12D")?new un({multihash:t}):r.startsWith("16U")?new ln({multihash:t}):new cn({multihash:t})}return Qn(yl.decode(r))}function Qn(r){try{let e=gt(r);if(e.code===Je.code){if(e.digest.length===Oa)return new un({multihash:e});if(e.digest.length===Va)return new ln({multihash:e})}if(e.code===we.code)return new cn({multihash:e})}catch{return k0(re.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function k0(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==gl)throw new Error("Supplied PeerID CID is invalid");let e=r.multihash;if(e.code===we.code)return new cn({multihash:r.multihash});if(e.code===Je.code){if(e.digest.length===Oa)return new un({multihash:r.multihash});if(e.digest.length===Va)return new ln({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function wl(r,e){return r.length===Oa?new un({multihash:yt(Je.code,r),privateKey:e}):r.length===Va?new ln({multihash:yt(Je.code,r),privateKey:e}):new cn({multihash:await we.digest(r),publicKey:r,privateKey:e})}var Zo=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 p=Number.parseInt(l,e);if(!Number.isNaN(p))return p});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 bl=45,S0=15,fn=new Zo;function Fa(r){if(!(r.length>S0))return fn.new(r).parseWith(()=>fn.readIPv4Addr())}function Ma(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>bl))return fn.new(r).parseWith(()=>fn.readIPv6Addr())}function Jo(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>bl))return fn.new(r).parseWith(()=>fn.readIPAddr())}var aE=parseInt("0xFFFF",16),cE=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function vl(r){return!!Fa(r)}function Al(r){return!!Ma(r)}function Xo(r){return!!Jo(r)}var Bl=vl,C0=Al,Ha=function(r){let e=0;if(r=r.toString().trim(),Bl(r)){let t=new Uint8Array(e+4);return r.split(/\./g).forEach(n=>{t[e++]=parseInt(n,10)&255}),t}if(C0(r)){let t=r.split(":",8),n;for(n=0;n<t.length;n++){let s=Bl(t[n]),i;s&&(i=Ha(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")},kl=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 hn={},$a={},L0=[[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"]];L0.forEach(r=>{let e=D0(...r);$a[e.code]=e,hn[e.name]=e});function D0(r,e,t,n,o){return{code:r,size:e,name:t,resolvable:!!n,path:!!o}}function ie(r){if(typeof r=="number"){if($a[r]!=null)return $a[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(hn[r]!=null)return hn[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var zE=ie("ip4"),GE=ie("ip6"),jE=ie("ipcidr");function qa(r,e){switch(ie(r).code){case 4:case 41:return P0(e);case 42:return Rl(e);case 6:case 273:case 33:case 132:return Tl(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Rl(e);case 421:return M0(e);case 444:return _l(e);case 445:return _l(e);case 466:return F0(e);default:return z(e,"base16")}}function za(r,e){switch(ie(r).code){case 4:return Sl(e);case 41:return Sl(e);case 42:return Il(e);case 6:case 273:case 33:case 132:return Ga(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Il(e);case 421:return O0(e);case 444:return H0(e);case 445:return $0(e);case 466:return V0(e);default:return W(e,"base16")}}var Ka=Object.values(ir).map(r=>r.decoder),U0=function(){let r=Ka[0].or(Ka[1]);return Ka.slice(2).forEach(e=>r=r.or(e)),r}();function Sl(r){if(!Xo(r))throw new Error("invalid ip address");return Ha(r)}function P0(r){let e=kl(r,0,r.length);if(e==null)throw new Error("ipBuff is required");if(!Xo(e))throw new Error("invalid ip address");return e}function Ga(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,r),new Uint8Array(e)}function Tl(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Il(r){let e=W(r),t=Uint8Array.from(Qr(e.length));return Le([t,e],t.length+e.length)}function Rl(r){let e=Rr(r);if(r=r.slice(Ve(e)),r.length!==e)throw new Error("inconsistent lengths");return z(r)}function O0(r){let e;r[0]==="Q"||r[0]==="1"?e=gt(he.decode(`z${r}`)).bytes:e=re.parse(r).multihash.bytes;let t=Uint8Array.from(Qr(e.length));return Le([t,e],t.length+e.length)}function V0(r){let e=U0.decode(r),t=Uint8Array.from(Qr(e.length));return Le([t,e],t.length+e.length)}function F0(r){let e=Rr(r),t=r.slice(Ve(e));if(t.length!==e)throw new Error("inconsistent lengths");return"u"+z(t,"base64url")}function M0(r){let e=Rr(r),t=r.slice(Ve(e));if(t.length!==e)throw new Error("inconsistent lengths");return z(t,"base58btc")}function H0(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=Be.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=Ga(n);return Le([t,o],t.length+o.length)}function $0(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=Be.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=Ga(n);return Le([t,o],t.length+o.length)}function _l(r){let e=r.slice(0,r.length-2),t=r.slice(r.length-2),n=z(e,"base32"),o=Tl(t);return`${n}:${o}`}function Cl(r){r=ja(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=ie(i);if(a.size===0){e.push([a.code]),t.push([a.code]);continue}if(s++,s>=o.length)throw Ll("invalid address: "+r);if(a.path===!0){n=ja(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,qa(a.code,c)])}return{string:Nl(t),bytes:Ya(e),tuples:e,stringTuples:t,path:n}}function Wa(r){let e=[],t=[],n=null,o=0;for(;o<r.length;){let s=Rr(r,o),i=Ve(s),a=ie(s),c=K0(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 Ll("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:Nl(t),tuples:e,stringTuples:t,path:n}}function Nl(r){let e=[];return r.map(t=>{let n=ie(t[0]);return e.push(n.name),t.length>1&&t[1]!=null&&e.push(t[1]),null}),ja(e.join("/"))}function Ya(r){return Le(r.map(e=>{let t=ie(e[0]),n=Uint8Array.from(Qr(t.code));return e.length>1&&e[1]!=null&&(n=Le([n,e[1]])),n}))}function K0(r,e){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let t=Rr(e instanceof Uint8Array?e:Uint8Array.from(e));return t+Ve(t)}}function ja(r){return"/"+r.trim().split("/").filter(e=>e).join("/")}function Ll(r){return new Error("Error parsing address: "+r)}var q0=Symbol.for("nodejs.util.inspect.custom"),Za=Symbol.for("@multiformats/js-multiaddr/multiaddr"),z0=[ie("dns").code,ie("dns4").code,ie("dns6").code,ie("dnsaddr").code],Qo=class r{bytes;#e;#t;#r;#i;[Za]=!0;constructor(e){e==null&&(e="");let t;if(e instanceof Uint8Array)t=Wa(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);t=Cl(e)}else if(Ul(e))t=Wa(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=ie("tcp"),a=ie("udp"),c=ie("ip4"),f=ie("ip6"),u=ie("dns6"),l=ie("ip6zone");for(let[E,y]of this.stringTuples())E===l.code&&(s=`%${y??""}`),z0.includes(E)&&(t=i.name,o=443,n=`${y??""}${s}`,e=E===u.code?6:4),(E===i.code||E===a.code)&&(t=ie(E).name,o=parseInt(y??"")),(E===c.code||E===f.code)&&(t=ie(E).name,n=`${y??""}${s}`,e=E===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({},ie(e)))}protoCodes(){return this.#t.map(([e])=>e)}protoNames(){return this.#t.map(([e])=>ie(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(Ya(t.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,o])=>{n===hn.p2p.code&&e.push([n,o]),n===hn["p2p-circuit"].code&&(e=[])});let t=e.pop();if(t?.[1]!=null){let n=t[1];return n[0]==="Q"||n[0]==="1"?z(he.decode(`z${n}`),"base58btc"):z(re.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#i}equals(e){return se(this.bytes,e.bytes)}async resolve(e){let t=this.protos().find(s=>s.resolvable);if(t==null)return[this];let n=Dl.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=>eo(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)}[q0](){return`Multiaddr(${this.#e})`}};var Dl=new Map;function Ul(r){return!!r?.[Za]}function eo(r){return new Qo(r)}async function*es(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 dc={};ge(dc,{Ed25519PrivateKey:()=>Ur,Ed25519PublicKey:()=>no,generateKeyPair:()=>tg,generateKeyPairFromSeed:()=>uf,unmarshalEd25519PrivateKey:()=>Qy,unmarshalEd25519PublicKey:()=>eg});function Xe(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function dn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function G0(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function pn(r,...e){if(!G0(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 ts(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");dn(r.outputLen),dn(r.blockLen)}function mn(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 Pl(r,e){pn(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var rs=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var gn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),ct=(r,e)=>r<<32-e|r>>>e;var Sv=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var j0=async()=>{};async function Ol(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 j0(),n+=s)}}function Ja(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function cr(r){return typeof r=="string"&&(r=Ja(r)),pn(r),r}function ns(...r){let e=0;for(let n=0;n<r.length;n++){let o=r[n];pn(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 yn=class{clone(){return this._cloneInto()}},W0={}.toString;function Vl(r,e){if(e!==void 0&&W0.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function os(r){let e=n=>r().update(cr(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function wn(r=32){if(rs&&typeof rs.getRandomValues=="function")return rs.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Y0(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 Fl=(r,e,t)=>r&e^~r&t,Ml=(r,e,t)=>r&e^r&t^e&t,bn=class extends yn{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=gn(this.buffer)}update(e){mn(this);let{view:t,buffer:n,blockLen:o}=this;e=cr(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=gn(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){mn(this),Pl(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;Y0(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=gn(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 ss=BigInt(4294967295),Xa=BigInt(32);function Hl(r,e=!1){return e?{h:Number(r&ss),l:Number(r>>Xa&ss)}:{h:Number(r>>Xa&ss)|0,l:Number(r&ss)|0}}function Z0(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}=Hl(r[o],e);[t[o],n[o]]=[s,i]}return[t,n]}var J0=(r,e)=>BigInt(r>>>0)<<Xa|BigInt(e>>>0),X0=(r,e,t)=>r>>>t,Q0=(r,e,t)=>r<<32-t|e>>>t,ey=(r,e,t)=>r>>>t|e<<32-t,ty=(r,e,t)=>r<<32-t|e>>>t,ry=(r,e,t)=>r<<64-t|e>>>t-32,ny=(r,e,t)=>r>>>t-32|e<<64-t,oy=(r,e)=>e,sy=(r,e)=>r,iy=(r,e,t)=>r<<t|e>>>32-t,ay=(r,e,t)=>e<<t|r>>>32-t,cy=(r,e,t)=>e<<t-32|r>>>64-t,uy=(r,e,t)=>r<<t-32|e>>>64-t;function ly(r,e,t,n){let o=(e>>>0)+(n>>>0);return{h:r+t+(o/2**32|0)|0,l:o|0}}var fy=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),hy=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,dy=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),py=(r,e,t,n,o)=>e+t+n+o+(r/2**32|0)|0,my=(r,e,t,n,o)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(o>>>0),yy=(r,e,t,n,o,s)=>e+t+n+o+s+(r/2**32|0)|0;var gy={fromBig:Hl,split:Z0,toBig:J0,shrSH:X0,shrSL:Q0,rotrSH:ey,rotrSL:ty,rotrBH:ry,rotrBL:ny,rotr32H:oy,rotr32L:sy,rotlSH:iy,rotlSL:ay,rotlBH:cy,rotlBL:uy,add:ly,add3L:fy,add3H:hy,add4L:dy,add4H:py,add5H:yy,add5L:my},q=gy;var[wy,by]=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))),ur=new Uint32Array(80),lr=new Uint32Array(80),Qa=class extends bn{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:e,Al:t,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:f,El:u,Fh:l,Fl:p,Gh:E,Gl:y,Hh:d,Hl:m}=this;return[e,t,n,o,s,i,a,c,f,u,l,p,E,y,d,m]}set(e,t,n,o,s,i,a,c,f,u,l,p,E,y,d,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=p|0,this.Gh=E|0,this.Gl=y|0,this.Hh=d|0,this.Hl=m|0}process(e,t){for(let v=0;v<16;v++,t+=4)ur[v]=e.getUint32(t),lr[v]=e.getUint32(t+=4);for(let v=16;v<80;v++){let D=ur[v-15]|0,S=lr[v-15]|0,_=q.rotrSH(D,S,1)^q.rotrSH(D,S,8)^q.shrSH(D,S,7),L=q.rotrSL(D,S,1)^q.rotrSL(D,S,8)^q.shrSL(D,S,7),w=ur[v-2]|0,C=lr[v-2]|0,O=q.rotrSH(w,C,19)^q.rotrBH(w,C,61)^q.shrSH(w,C,6),T=q.rotrSL(w,C,19)^q.rotrBL(w,C,61)^q.shrSL(w,C,6),F=q.add4L(L,T,lr[v-7],lr[v-16]),$=q.add4H(F,_,O,ur[v-7],ur[v-16]);ur[v]=$|0,lr[v]=F|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:p,Fh:E,Fl:y,Gh:d,Gl:m,Hh:g,Hl:I}=this;for(let v=0;v<80;v++){let D=q.rotrSH(l,p,14)^q.rotrSH(l,p,18)^q.rotrBH(l,p,41),S=q.rotrSL(l,p,14)^q.rotrSL(l,p,18)^q.rotrBL(l,p,41),_=l&E^~l&d,L=p&y^~p&m,w=q.add5L(I,S,L,by[v],lr[v]),C=q.add5H(w,g,D,_,wy[v],ur[v]),O=w|0,T=q.rotrSH(n,o,28)^q.rotrBH(n,o,34)^q.rotrBH(n,o,39),F=q.rotrSL(n,o,28)^q.rotrBL(n,o,34)^q.rotrBL(n,o,39),$=n&s^n&a^s&a,J=o&i^o&c^i&c;g=d|0,I=m|0,d=E|0,m=y|0,E=l|0,y=p|0,{h:l,l:p}=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 x=q.add3L(O,F,J);n=q.add3H(x,C,T,$),o=x|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:p}=q.add(this.Eh|0,this.El|0,l|0,p|0),{h:E,l:y}=q.add(this.Fh|0,this.Fl|0,E|0,y|0),{h:d,l:m}=q.add(this.Gh|0,this.Gl|0,d|0,m|0),{h:g,l:I}=q.add(this.Hh|0,this.Hl|0,g|0,I|0),this.set(n,o,s,i,a,c,f,u,l,p,E,y,d,m,g,I)}roundClean(){ur.fill(0),lr.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 xn=os(()=>new Qa);var as={};ge(as,{abytes:()=>En,bitGet:()=>Sy,bitLen:()=>ky,bitMask:()=>to,bitSet:()=>Iy,bytesToHex:()=>Lt,bytesToNumberBE:()=>Dt,bytesToNumberLE:()=>hr,concatBytes:()=>Ut,createHmacDrbg:()=>rc,ensureBytes:()=>fe,equalBytes:()=>Ay,hexToBytes:()=>Nr,hexToNumber:()=>tc,isBytes:()=>fr,numberToBytesBE:()=>dr,numberToBytesLE:()=>Lr,numberToHexUnpadded:()=>zl,numberToVarBytesBE:()=>vy,utf8ToBytes:()=>By,validateObject:()=>wt});var ql=BigInt(0),is=BigInt(1),xy=BigInt(2);function fr(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function En(r){if(!fr(r))throw new Error("Uint8Array expected")}var Ey=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function Lt(r){En(r);let e="";for(let t=0;t<r.length;t++)e+=Ey[r[t]];return e}function zl(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function tc(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Nt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function $l(r){if(r>=Nt._0&&r<=Nt._9)return r-Nt._0;if(r>=Nt._A&&r<=Nt._F)return r-(Nt._A-10);if(r>=Nt._a&&r<=Nt._f)return r-(Nt._a-10)}function Nr(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=$l(r.charCodeAt(s)),a=$l(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 Dt(r){return tc(Lt(r))}function hr(r){return En(r),tc(Lt(Uint8Array.from(r).reverse()))}function dr(r,e){return Nr(r.toString(16).padStart(e*2,"0"))}function Lr(r,e){return dr(r,e).reverse()}function vy(r){return Nr(zl(r))}function fe(r,e,t){let n;if(typeof e=="string")try{n=Nr(e)}catch(s){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${s}`)}else if(fr(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 Ut(...r){let e=0;for(let n=0;n<r.length;n++){let o=r[n];En(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 Ay(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 By(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function ky(r){let e;for(e=0;r>ql;r>>=is,e+=1);return e}function Sy(r,e){return r>>BigInt(e)&is}function Iy(r,e,t){return r|(t?is:ql)<<BigInt(e)}var to=r=>(xy<<BigInt(r-1))-is,ec=r=>new Uint8Array(r),Kl=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=ec(r),o=ec(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>t(o,n,...l),c=(l=ec())=>{o=a(Kl([0]),l),n=a(),l.length!==0&&(o=a(Kl([1]),l),n=a())},f=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,p=[];for(;l<e;){n=a();let E=n.slice();p.push(E),l+=n.length}return Ut(...p)};return(l,p)=>{i(),c(l);let E;for(;!(E=p(f()));)c();return i(),E}}var Ry={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"||fr(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 wt(r,e,t={}){let n=(o,s,i)=>{let a=Ry[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 be=BigInt(0),ae=BigInt(1),Dr=BigInt(2),_y=BigInt(3),nc=BigInt(4),Gl=BigInt(5),jl=BigInt(8),Ty=BigInt(9),Cy=BigInt(16);function oe(r,e){let t=r%e;return t>=be?t:e+t}function Ny(r,e,t){if(t<=be||e<be)throw new Error("Expected power/modulo > 0");if(t===ae)return be;let n=ae;for(;e>be;)e&ae&&(n=n*r%t),r=r*r%t,e>>=ae;return n}function ce(r,e,t){let n=r;for(;e-- >be;)n*=n,n%=t;return n}function cs(r,e){if(r===be||e<=be)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=oe(r,e),n=e,o=be,s=ae,i=ae,a=be;for(;t!==be;){let f=n/t,u=n%t,l=o-i*f,p=s-a*f;n=t,t=u,o=i,s=a,i=l,a=p}if(n!==ae)throw new Error("invert: does not exist");return oe(o,e)}function Ly(r){let e=(r-ae)/Dr,t,n,o;for(t=r-ae,n=0;t%Dr===be;t/=Dr,n++);for(o=Dr;o<r&&Ny(o,e,r)!==r-ae;o++);if(n===1){let i=(r+ae)/nc;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+ae)/Dr;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),p=a.pow(c,t);for(;!a.eql(p,a.ONE);){if(a.eql(p,a.ZERO))return a.ZERO;let E=1;for(let d=a.sqr(p);E<f&&!a.eql(d,a.ONE);E++)d=a.sqr(d);let y=a.pow(u,ae<<BigInt(f-E-1));u=a.sqr(y),l=a.mul(l,y),p=a.mul(p,u),f=E}return l}}function Dy(r){if(r%nc===_y){let e=(r+ae)/nc;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%jl===Gl){let e=(r-Gl)/jl;return function(n,o){let s=n.mul(o,Dr),i=n.pow(s,e),a=n.mul(o,i),c=n.mul(n.mul(a,Dr),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%Cy,Ly(r)}var Wl=(r,e)=>(oe(r,e)&ae)===ae,Uy=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function oc(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=Uy.reduce((n,o)=>(n[o]="function",n),e);return wt(r,t)}function Py(r,e,t){if(t<be)throw new Error("Expected power > 0");if(t===be)return r.ONE;if(t===ae)return e;let n=r.ONE,o=e;for(;t>be;)t&ae&&(n=r.mul(n,o)),o=r.sqr(o),t>>=ae;return n}function Oy(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 sc(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function us(r,e,t=!1,n={}){if(r<=be)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:o,nByteLength:s}=sc(r,e);if(s>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Dy(r),a=Object.freeze({ORDER:r,BITS:o,BYTES:s,MASK:to(o),ZERO:be,ONE:ae,create:c=>oe(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return be<=c&&c<r},is0:c=>c===be,isOdd:c=>(c&ae)===ae,neg:c=>oe(-c,r),eql:(c,f)=>c===f,sqr:c=>oe(c*c,r),add:(c,f)=>oe(c+f,r),sub:(c,f)=>oe(c-f,r),mul:(c,f)=>oe(c*f,r),pow:(c,f)=>Py(a,c,f),div:(c,f)=>oe(c*cs(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>cs(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Oy(a,c),cmov:(c,f,u)=>u?f:c,toBytes:c=>t?Lr(c,s):dr(c,s),fromBytes:c=>{if(c.length!==s)throw new Error(`Fp.fromBytes: expected ${s}, got ${c.length}`);return t?hr(c):Dt(c)}});return Object.freeze(a)}function Yl(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 Zl(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 ic(r){let e=Zl(r);return e+Math.ceil(e/2)}function Jl(r,e,t=!1){let n=r.length,o=Zl(e),s=ic(e);if(n<16||n<s||n>1024)throw new Error(`expected ${s}-1024 bytes of input, got ${n}`);let i=t?Dt(r):hr(r),a=oe(i,e-ae)+ae;return t?Lr(a,o):dr(a,o)}var Fy=BigInt(0),ac=BigInt(1);function ls(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>Fy;)s&ac&&(i=i.add(a)),a=a.double(),s>>=ac;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 p=1;p<a;p++)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),p=2**o,E=BigInt(o);for(let y=0;y<a;y++){let d=y*c,m=Number(i&l);i>>=E,m>c&&(m-=p,i+=ac);let g=d,I=d+Math.abs(m)-1,v=y%2!==0,D=m<0;m===0?u=u.add(t(v,s[g])):f=f.add(t(D,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 ro(r){return oc(r.Fp),wt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...sc(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var ut=BigInt(0),ze=BigInt(1),fs=BigInt(2),My=BigInt(8),Hy={zip215:!0};function $y(r){let e=ro(r);return wt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function hs(r){let e=$y(r),{Fp:t,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=e,f=fs<<BigInt(a*8)-ze,u=t.create,l=e.uvRatio||((B,b)=>{try{return{isValid:!0,value:t.sqrt(B*t.inv(b))}}catch{return{isValid:!1,value:ut}}}),p=e.adjustScalarBytes||(B=>B),E=e.domain||((B,b,P)=>{if(b.length||P)throw new Error("Contexts/pre-hash are not supported");return B}),y=B=>typeof B=="bigint"&&ut<B,d=(B,b)=>y(B)&&y(b)&&B<b,m=B=>B===ut||d(B,f);function g(B,b){if(d(B,b))return B;throw new Error(`Expected valid scalar < ${b}, got ${typeof B} ${B}`)}function I(B){return B===ut?B:g(B,n)}let v=new Map;function D(B){if(!(B instanceof S))throw new Error("ExtendedPoint expected")}class S{constructor(b,P,M,K){if(this.ex=b,this.ey=P,this.ez=M,this.et=K,!m(b))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(b){if(b instanceof S)throw new Error("extended point not allowed");let{x:P,y:M}=b||{};if(!m(P)||!m(M))throw new Error("invalid affine point");return new S(P,M,ze,u(P*M))}static normalizeZ(b){let P=t.invertBatch(b.map(M=>M.ez));return b.map((M,K)=>M.toAffine(P[K])).map(S.fromAffine)}_setWindowSize(b){this._WINDOW_SIZE=b,v.delete(this)}assertValidity(){let{a:b,d:P}=e;if(this.is0())throw new Error("bad point: ZERO");let{ex:M,ey:K,ez:G,et:j}=this,ee=u(M*M),Z=u(K*K),X=u(G*G),pe=u(X*X),ue=u(ee*b),ve=u(X*u(ue+Z)),Ae=u(pe+u(P*u(ee*Z)));if(ve!==Ae)throw new Error("bad point: equation left != right (1)");let ye=u(M*K),Re=u(G*j);if(ye!==Re)throw new Error("bad point: equation left != right (2)")}equals(b){D(b);let{ex:P,ey:M,ez:K}=this,{ex:G,ey:j,ez:ee}=b,Z=u(P*ee),X=u(G*K),pe=u(M*ee),ue=u(j*K);return Z===X&&pe===ue}is0(){return this.equals(S.ZERO)}negate(){return new S(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:b}=e,{ex:P,ey:M,ez:K}=this,G=u(P*P),j=u(M*M),ee=u(fs*u(K*K)),Z=u(b*G),X=P+M,pe=u(u(X*X)-G-j),ue=Z+j,ve=ue-ee,Ae=Z-j,ye=u(pe*ve),Re=u(ue*Ae),It=u(pe*Ae),kr=u(ve*ue);return new S(ye,Re,kr,It)}add(b){D(b);let{a:P,d:M}=e,{ex:K,ey:G,ez:j,et:ee}=this,{ex:Z,ey:X,ez:pe,et:ue}=b;if(P===BigInt(-1)){let wu=u((G-K)*(X+Z)),bu=u((G+K)*(X-Z)),zi=u(bu-wu);if(zi===ut)return this.double();let xu=u(j*fs*ue),Eu=u(ee*fs*pe),vu=Eu+xu,Au=bu+wu,Bu=Eu-xu,Rp=u(vu*zi),_p=u(Au*Bu),Tp=u(vu*Bu),Cp=u(zi*Au);return new S(Rp,_p,Cp,Tp)}let ve=u(K*Z),Ae=u(G*X),ye=u(ee*M*ue),Re=u(j*pe),It=u((K+G)*(Z+X)-ve-Ae),kr=Re-ye,Kn=Re+ye,gu=u(Ae-P*ve),Bp=u(It*kr),kp=u(Kn*gu),Sp=u(It*gu),Ip=u(kr*Kn);return new S(Bp,kp,Ip,Sp)}subtract(b){return this.add(b.negate())}wNAF(b){return w.wNAFCached(this,v,b,S.normalizeZ)}multiply(b){let{p:P,f:M}=this.wNAF(g(b,n));return S.normalizeZ([P,M])[0]}multiplyUnsafe(b){let P=I(b);return P===ut?L:this.equals(L)||P===ze?this:this.equals(_)?this.wNAF(P).p:w.unsafeLadder(this,P)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return w.unsafeLadder(this,n).is0()}toAffine(b){let{ex:P,ey:M,ez:K}=this,G=this.is0();b==null&&(b=G?My:t.inv(K));let j=u(P*b),ee=u(M*b),Z=u(K*b);if(G)return{x:ut,y:ze};if(Z!==ze)throw new Error("invZ was invalid");return{x:j,y:ee}}clearCofactor(){let{h:b}=e;return b===ze?this:this.multiplyUnsafe(b)}static fromHex(b,P=!1){let{d:M,a:K}=e,G=t.BYTES;b=fe("pointHex",b,G);let j=b.slice(),ee=b[G-1];j[G-1]=ee&-129;let Z=hr(j);Z===ut||(P?g(Z,f):g(Z,t.ORDER));let X=u(Z*Z),pe=u(X-ze),ue=u(M*X-K),{isValid:ve,value:Ae}=l(pe,ue);if(!ve)throw new Error("Point.fromHex: invalid y coordinate");let ye=(Ae&ze)===ze,Re=(ee&128)!==0;if(!P&&Ae===ut&&Re)throw new Error("Point.fromHex: x=0 and x_0=1");return Re!==ye&&(Ae=u(-Ae)),S.fromAffine({x:Ae,y:Z})}static fromPrivateKey(b){return T(b).point}toRawBytes(){let{x:b,y:P}=this.toAffine(),M=Lr(P,t.BYTES);return M[M.length-1]|=b&ze?128:0,M}toHex(){return Lt(this.toRawBytes())}}S.BASE=new S(e.Gx,e.Gy,ze,u(e.Gx*e.Gy)),S.ZERO=new S(ut,ze,ze,ut);let{BASE:_,ZERO:L}=S,w=ls(S,a*8);function C(B){return oe(B,n)}function O(B){return C(hr(B))}function T(B){let b=a;B=fe("private key",B,b);let P=fe("hashed private key",s(B),2*b),M=p(P.slice(0,b)),K=P.slice(b,2*b),G=O(M),j=_.multiply(G),ee=j.toRawBytes();return{head:M,prefix:K,scalar:G,point:j,pointBytes:ee}}function F(B){return T(B).pointBytes}function $(B=new Uint8Array,...b){let P=Ut(...b);return O(s(E(P,fe("context",B),!!o)))}function J(B,b,P={}){B=fe("message",B),o&&(B=o(B));let{prefix:M,scalar:K,pointBytes:G}=T(b),j=$(P.context,M,B),ee=_.multiply(j).toRawBytes(),Z=$(P.context,ee,G,B),X=C(j+Z*K);I(X);let pe=Ut(ee,Lr(X,t.BYTES));return fe("result",pe,a*2)}let x=Hy;function k(B,b,P,M=x){let{context:K,zip215:G}=M,j=t.BYTES;B=fe("signature",B,2*j),b=fe("message",b),o&&(b=o(b));let ee=hr(B.slice(j,2*j)),Z,X,pe;try{Z=S.fromHex(P,G),X=S.fromHex(B.slice(0,j),G),pe=_.multiplyUnsafe(ee)}catch{return!1}if(!G&&Z.isSmallOrder())return!1;let ue=$(K,X.toRawBytes(),Z.toRawBytes(),b);return X.add(Z.multiplyUnsafe(ue)).subtract(pe).clearCofactor().equals(S.ZERO)}return _._setWindowSize(8),{CURVE:e,getPublicKey:F,sign:J,verify:k,ExtendedPoint:S,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>i(t.BYTES),precompute(B=8,b=S.BASE){return b._setWindowSize(B),b.multiply(BigInt(3)),b}}}}var uc=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Xl=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Wv=BigInt(0),Ky=BigInt(1),cc=BigInt(2),qy=BigInt(5),Ql=BigInt(10),zy=BigInt(20),Gy=BigInt(40),ef=BigInt(80);function jy(r){let e=uc,n=r*r%e*r%e,o=ce(n,cc,e)*n%e,s=ce(o,Ky,e)*r%e,i=ce(s,qy,e)*s%e,a=ce(i,Ql,e)*i%e,c=ce(a,zy,e)*a%e,f=ce(c,Gy,e)*c%e,u=ce(f,ef,e)*f%e,l=ce(u,ef,e)*f%e,p=ce(l,Ql,e)*i%e;return{pow_p_5_8:ce(p,cc,e)*r%e,b2:n}}function Wy(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Yy(r,e){let t=uc,n=oe(e*e*e,t),o=oe(n*n*e,t),s=jy(r*o).pow_p_5_8,i=oe(r*n*s,t),a=oe(e*i*i,t),c=i,f=oe(i*Xl,t),u=a===r,l=a===oe(-r,t),p=a===oe(-r*Xl,t);return u&&(i=c),(l||p)&&(i=f),Wl(i,t)&&(i=oe(-i,t)),{isValid:u||l,value:i}}var Pt=us(uc,void 0,!0),lc={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Pt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:xn,randomBytes:wn,adjustScalarBytes:Wy,uvRatio:Yy},vn=hs(lc);function tf(r,e,t){if(e.length>255)throw new Error("Context is too big");return ns(Ja("SigEd25519 no Ed25519 collisions"),new Uint8Array([t?1:0,e.length]),e,r)}var Yv=hs({...lc,domain:tf}),Zv=hs({...lc,domain:tf,prehash:xn});var Zy=(Pt.ORDER+BigInt(3))/BigInt(8),Jv=Pt.pow(cc,Zy),Xv=Pt.sqrt(Pt.neg(Pt.ONE)),Qv=(Pt.ORDER-BigInt(5))/BigInt(8),e2=BigInt(486662);var t2=Yl(Pt,Pt.neg(BigInt(486664)));var r2=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),n2=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),o2=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),s2=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var i2=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var An=32,Ot=64,ds=32;function rf(){let r=vn.utils.randomPrivateKey(),e=vn.getPublicKey(r);return{privateKey:af(r,e),publicKey:e}}function nf(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=vn.getPublicKey(e);return{privateKey:af(e,t),publicKey:t}}function of(r,e){let t=r.subarray(0,ds);return vn.sign(e instanceof Uint8Array?e:e.subarray(),t)}function sf(r,e,t){return vn.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function af(r,e){let t=new Uint8Array(Ot);for(let n=0;n<ds;n++)t[n]=r[n],t[ds+n]=e[n];return t}var Ue={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 fc={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function cf(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=Ue.get();t*=8;async function c(l,p){let E=a.getRandomValues(new Uint8Array(s)),y=a.getRandomValues(new Uint8Array(n)),d={name:e,iv:y};typeof p=="string"&&(p=W(p));let m;if(p.length===0){m=await a.subtle.importKey("jwk",fc,{name:"AES-GCM"},!0,["encrypt"]);try{let I={name:"PBKDF2",salt:E,iterations:i,hash:{name:o}},v=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(I,v,{name:e,length:t},!0,["encrypt"])}catch{m=await a.subtle.importKey("jwk",fc,{name:"AES-GCM"},!0,["encrypt"])}}else{let I={name:"PBKDF2",salt:E,iterations:i,hash:{name:o}},v=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(I,v,{name:e,length:t},!0,["encrypt"])}let g=await a.subtle.encrypt(d,m,l);return Le([E,d.iv,new Uint8Array(g)])}async function f(l,p){let E=l.subarray(0,s),y=l.subarray(s,s+n),d=l.subarray(s+n),m={name:e,iv:y};typeof p=="string"&&(p=W(p));let g;if(p.length===0)try{let v={name:"PBKDF2",salt:E,iterations:i,hash:{name:o}},D=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(v,D,{name:e,length:t},!0,["decrypt"])}catch{g=await a.subtle.importKey("jwk",fc,{name:"AES-GCM"},!0,["decrypt"])}else{let v={name:"PBKDF2",salt:E,iterations:i,hash:{name:o}},D=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(v,D,{name:e,length:t},!0,["decrypt"])}let I=await a.subtle.decrypt(m,g,d);return new Uint8Array(I)}return{encrypt:c,decrypt:f}}async function Bn(r,e){let n=await cf().encrypt(r,e);return nr.encode(n)}var de;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(de||(de={}));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=()=>Jn(hc)})(de||(de={}));var bt;(function(r){let e;r.codec=()=>(e==null&&(e=nn((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),de.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=de.codec().decode(t);break;case 2:o.Data=t.bytes();break;default:t.skipType(i&7);break}}return o})),e),r.encode=t=>tn(t,r.codec()),r.decode=t=>en(t,r.codec())})(bt||(bt={}));var Vt;(function(r){let e;r.codec=()=>(e==null&&(e=nn((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),de.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=de.codec().decode(t);break;case 2:o.Data=t.bytes();break;default:t.skipType(i&7);break}}return o})),e),r.encode=t=>tn(t,r.codec()),r.decode=t=>en(t,r.codec())})(Vt||(Vt={}));var no=class{_key;constructor(e){this._key=kn(e,An)}verify(e,t){return sf(this._key,t,e)}marshal(){return this._key}get bytes(){return bt.encode({Type:de.Ed25519,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(e)?e.then(({bytes:t})=>t):e.bytes}},Ur=class{_key;_publicKey;constructor(e,t){this._key=kn(e,Ot),this._publicKey=kn(t,An)}sign(e){return of(this._key,e)}get public(){return new no(this._publicKey)}marshal(){return this._key}get bytes(){return Vt.encode({Type:de.Ed25519,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}async hash(){let e=we.digest(this.bytes),t;return Xe(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=Je.digest(this.public.bytes);return he.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return Bn(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Qy(r){if(r.length>Ot){r=kn(r,Ot+An);let n=r.subarray(0,Ot),o=r.subarray(Ot,r.length);return new Ur(n,o)}r=kn(r,Ot);let e=r.subarray(0,Ot),t=r.subarray(An);return new Ur(e,t)}function eg(r){return r=kn(r,An),new no(r)}async function tg(){let{privateKey:r,publicKey:e}=rf();return new Ur(r,e)}async function uf(r){let{privateKey:e,publicKey:t}=nf(r);return new Ur(e,t)}function kn(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 Ac={};ge(Ac,{MAX_RSA_KEY_SIZE:()=>yo,RsaPrivateKey:()=>Tn,RsaPublicKey:()=>mo,fromJwk:()=>Rg,generateKeyPair:()=>_g,unmarshalRsaPrivateKey:()=>Ec,unmarshalRsaPublicKey:()=>Ig});function Pr(r){if(isNaN(r)||r<=0)throw new N("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return wn(r)}var gr={};ge(gr,{exportToPem:()=>vg,importFromPem:()=>Ag,jwkToPkcs1:()=>wg,jwkToPkix:()=>xg,pkcs1ToJwk:()=>gg,pkixToJwk:()=>bg});var ms=class extends yn{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,ts(e);let n=cr(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 mn(this),this.iHash.update(e),this}digestInto(e){mn(this),pn(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()}},oo=(r,e,t)=>new ms(r,e).update(t).digest();oo.create=(r,e)=>new ms(r,e);function rg(r,e,t,n){ts(r);let o=Vl({dkLen:32,asyncTick:10},n),{c:s,dkLen:i,asyncTick:a}=o;if(dn(s),dn(i),dn(a),s<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=cr(e),f=cr(t),u=new Uint8Array(i),l=oo.create(r,c),p=l._cloneInto().update(f);return{c:s,dkLen:i,asyncTick:a,DK:u,PRF:l,PRFSalt:p}}function ng(r,e,t,n,o){return r.destroy(),e.destroy(),n&&n.destroy(),o.fill(0),t}async function pc(r,e,t,n){let{c:o,dkLen:s,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=rg(r,e,t,n),u,l=new Uint8Array(4),p=gn(l),E=new Uint8Array(c.outputLen);for(let y=1,d=0;d<s;y++,d+=c.outputLen){let m=a.subarray(d,d+c.outputLen);p.setInt32(0,y,!1),(u=f._cloneInto(u)).update(l).digestInto(E),m.set(E.subarray(0,m.length)),await Ol(o-1,i,()=>{c._cloneInto(u).update(E).digestInto(E);for(let g=0;g<m.length;g++)m[g]^=E[g]})}return ng(c,f,a,u,E)}var Y=st(lf());function Or(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 pr(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 ws(...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 yc(){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=Or(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,Or(s,8)-n}function ff(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=pr(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=pr(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 hf(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 Fe(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 D2=Math.log(2);function bs(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function gc(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 Kt(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 io=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return gc(this.items)}},so=[new Uint8Array([1])],df="0123456789";var Rn="",ft=new ArrayBuffer(0),wc=new Uint8Array(0),ao="EndOfContent",mf="OCTET STRING",yf="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?Y.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(!Kt(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",ft)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Y.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var Mt=class{constructor({blockLength:e=0,error:t=Rn,warnings:n=[],valueBeforeDecode:o=wc}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=Y.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:Y.Convert.ToHex(this.valueBeforeDecodeView)}}};Mt.NAME="baseBlock";var Ce=class extends Mt{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'")}};Ce.NAME="valueBlock";var xs=class extends qt(Mt){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?Y.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",ft}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=pr(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=Y.BufferSourceConverter.toUint8Array(e);if(!Kt(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 p=new Uint8Array(u);for(let E=0;E<f.length;E++)p[E]=f[E];f=this.valueHexView=new Uint8Array(u)}}this.blockLength=c+1,f[c-1]=s[c]&127;let l=new Uint8Array(c);for(let p=0;p<c;p++)l[p]=f[p];f=this.valueHexView=new Uint8Array(c),f.set(l),this.blockLength<=9?this.tagNumber=Or(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}}};xs.NAME="identificationBlock";var Es=class extends Mt{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=Y.BufferSourceConverter.toUint8Array(e);if(!Kt(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=Or(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=pr(this.length,8);if(o.byteLength>127)return this.error="Too big length",ft;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}}};Es.NAME="lengthBlock";var U={},ke=class extends Mt{constructor({name:e=Rn,optional:t=!1,primitiveSchema:n,...o}={},s){super(o),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new xs(o),this.lenBlock=new Es(o),this.valueBlock=s?new s(o):new Ce(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 io;t||gf(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?ft: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():Y.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${Y.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 hf(t,n)}};ke.NAME="BaseBlock";function gf(r){if(r instanceof U.Constructed)for(let e of r.valueBlock.value)gf(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var vs=class extends ke{constructor({value:e=Rn,...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}'`}};vs.NAME="BaseStringBlock";var As=class extends qt(Ce){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};As.NAME="PrimitiveValueBlock";var wf,Bs=class extends ke{constructor(e={}){super(e,As),this.idBlock.isConstructed=!1}};wf=Bs;U.Primitive=wf;Bs.NAME="PRIMITIVE";function hg(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 ni(r,e=0,t=r.length){let n=e,o=new ke({},Ce),s=new Mt;if(!Kt(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=ke;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=U.EndOfContent;break;case 1:c=U.Boolean;break;case 2:c=U.Integer;break;case 3:c=U.BitString;break;case 4:c=U.OctetString;break;case 5:c=U.Null;break;case 6:c=U.ObjectIdentifier;break;case 10:c=U.Enumerated;break;case 12:c=U.Utf8String;break;case 13:c=U.RelativeObjectIdentifier;break;case 14:c=U.TIME;break;case 15:return o.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:o};case 16:c=U.Sequence;break;case 17:c=U.Set;break;case 18:c=U.NumericString;break;case 19:c=U.PrintableString;break;case 20:c=U.TeletexString;break;case 21:c=U.VideotexString;break;case 22:c=U.IA5String;break;case 23:c=U.UTCTime;break;case 24:c=U.GeneralizedTime;break;case 25:c=U.GraphicString;break;case 26:c=U.VisibleString;break;case 27:c=U.GeneralString;break;case 28:c=U.UniversalString;break;case 29:c=U.CharacterString;break;case 30:c=U.BmpString;break;case 31:c=U.DATE;break;case 32:c=U.TimeOfDay;break;case 33:c=U.DateTime;break;case 34:c=U.Duration;break;default:{let f=o.idBlock.isConstructed?new U.Constructed:new U.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?U.Constructed:U.Primitive}return o=hg(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 _n(r){if(!r.byteLength){let e=new ke({},Ce);return e.error="Input buffer has zero length",{offset:-1,result:e}}return ni(Y.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function dg(r,e){return r?1:e}var xt=class extends Ce{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n){let o=Y.BufferSourceConverter.toUint8Array(e);if(!Kt(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(;dg(this.isIndefiniteForm,n)>0;){let i=ni(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===ao)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===ao?this.value.pop():this.warnings.push("No EndOfContent block encoded")),s}toBER(e,t){let n=t||new io;for(let o=0;o<this.value.length;o++)this.value[o].toBER(e,n);return t?ft:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};xt.NAME="ConstructedValueBlock";var bf,mr=class extends ke{constructor(e={}){super(e,xt),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} :`}};sf=cr;D.Constructed=sf;cr.NAME="CONSTRUCTED";var Ei=class extends Ne{fromBER(e,t,n){return t}toBER(e){return lt}};Ei.override="EndOfContentValueBlock";var af,vi=class extends ke{constructor(e={}){super(e,Ei),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};af=vi;D.EndOfContent=af;vi.NAME=to;var cf,ur=class extends ke{constructor(e={}){super(e,Ne),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}`}};cf=ur;D.Null=cf;ur.NAME="NULL";var Bi=class extends Ht(Ne){constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=Y.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=Y.BufferSourceConverter.toUint8Array(e);return Mt(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,uc.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Bi.NAME="BooleanValueBlock";var uf,Ai=class extends ke{constructor(e={}){super(e,Bi),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}`}};uf=Ai;D.Boolean=uf;Ai.NAME="BOOLEAN";var ki=class extends Ht(Et){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=Et.prototype.fromBER.call(this,e,t,n),o===-1)return o;for(let i=0;i<this.value.length;i++){let s=this.value[i].constructor.NAME;if(s===to){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(s!==tf)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?Et.prototype.toBER.call(this,e,t):e?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};ki.NAME="OctetStringValueBlock";var lf,Vt=class r extends ke{constructor({idBlock:e={},lenBlock:t={},...n}={}){var o,i;(o=n.isConstructed)!==null&&o!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},ki),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 i=(e instanceof ArrayBuffer?new Uint8Array(e):e).subarray(t,t+n);try{if(i.byteLength){let s=Qi(i,0,i.byteLength);s.offset!==-1&&s.offset===n&&(this.valueBlock.value=[s.result])}}catch{}}return super.fromBER(e,t,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?cr.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${Y.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 Y.BufferSourceConverter.concat(e)}};lf=Vt;D.OctetString=lf;Vt.NAME=tf;var Si=class extends Ht(Et){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=Et.prototype.fromBER.call(this,e,t,n),o===-1)return o;for(let a of this.value){let c=a.constructor.NAME;if(c===to){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==rf)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 i=Y.BufferSourceConverter.toUint8Array(e);if(!Mt(this,i,t,n))return-1;let s=i.subarray(t,t+n);if(this.unusedBits=s[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=s.subarray(1);try{if(a.byteLength){let c=Qi(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=s.subarray(1),this.blockLength=s.length,t+n}toBER(e,t){if(this.isConstructed)return Et.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return lt;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}}};Si.NAME="BitStringValueBlock";var ff,En=class extends ke{constructor({idBlock:e={},lenBlock:t={},...n}={}){var o,i;(o=n.isConstructed)!==null&&o!==void 0||(n.isConstructed=!!(!((i=n.value)===null||i===void 0)&&i.length)),super({idBlock:{isConstructed:n.isConstructed,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},Si),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 cr.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)}`}}};ff=En;D.BitString=ff;En.NAME=rf;var hf;function Jy(r,e){let t=new Uint8Array([0]),n=new Uint8Array(r),o=new Uint8Array(e),i=n.slice(0),s=i.length-1,a=o.slice(0),c=a.length-1,f=0,u=c<s?s:c,l=0;for(let p=u;p>=0;p--,l++){switch(!0){case l<a.length:f=i[s-l]+a[c-l]+t[0];break;default:f=i[s-l]+t[0]}switch(t[0]=f/10,!0){case l>=i.length:i=pi(new Uint8Array([f%10]),i);break;default:i[s-l]=f%10}}return t[0]>0&&(i=pi(t,i)),i}function ef(r){if(r>=Qn.length)for(let e=Qn.length;e<=r;e++){let t=new Uint8Array([0]),n=Qn[e-1].slice(0);for(let o=n.length-1;o>=0;o--){let i=new Uint8Array([(n[o]<<1)+t[0]]);t[0]=i[0]/10,n[o]=i[0]%10}t[0]>0&&(n=pi(t,n)),Qn.push(n)}return Qn[r]}function Xy(r,e){let t=0,n=new Uint8Array(r),o=new Uint8Array(e),i=n.slice(0),s=i.length-1,a=o.slice(0),c=a.length-1,f,u=0;for(let l=c;l>=0;l--,u++)switch(f=i[s-u]-a[c-u]-t,!0){case f<0:t=1,i[s-u]=f+10;break;default:t=0,i[s-u]=f}if(t>0)for(let l=s-c+1;l>=0;l--,u++)if(f=i[s-u]-t,f<0)t=1,i[s-u]=f+10;else{t=0,i[s-u]=f;break}return i.slice()}var ro=class extends Ht(Ne){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=uc.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Jl(e))}get valueDec(){return this._valueDec}fromDER(e,t,n,o=0){let i=this.fromBER(e,t,n);if(i===-1)return i;let s=this.valueHexView;return s[0]===0&&s[1]&128?this.valueHexView=s.subarray(1):o!==0&&s.length<o&&(o-s.length>1&&(o=s.length+1),this.valueHexView=s.subarray(o-s.length)),i}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,i=this.valueHexView,s="",a=!1;for(let c=i.byteLength-1;c>=0;c--){o=i[c];for(let f=0;f<8;f++){if((o&1)===1)switch(n){case e:t=Xy(ef(n),t),s="-";break;default:t=Jy(t,ef(n))}n++,o>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(s+=Ql.charAt(t[c]));return a===!1&&(s+=Ql.charAt(0)),s}};hf=ro;ro.NAME="IntegerValueBlock";Object.defineProperty(hf.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var df,me=class r extends ke{constructor(e={}){super(e,ro),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return mi(),BigInt(this.valueBlock.toString())}static fromBigInt(e){mi();let t=BigInt(e),n=new eo,o=t.toString(16).replace(/^-/,""),i=new Uint8Array(Y.Convert.FromHex(o));if(t<0){let a=new Uint8Array(i.length+(i[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${Y.Convert.ToHex(a)}`)+t,u=Y.BufferSourceConverter.toUint8Array(Y.Convert.FromHex(f.toString(16)));u[0]|=128,n.write(u)}else i[0]&128&&n.write(new Uint8Array([0])),n.write(i);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()}`}};df=me;D.Integer=df;me.NAME="INTEGER";var pf,Ii=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};pf=Ii;D.Enumerated=pf;Ii.NAME="ENUMERATED";var no=class extends Ht(Ne){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=Y.BufferSourceConverter.toUint8Array(e);if(!Mt(this,o,t,n))return-1;let i=o.subarray(t,t+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let s=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)s[a]=this.valueHexView[a];return this.valueHexView=s,i[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=Dr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){mi();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,i=new Uint8Array(this.blockLength);for(let s=0;s<this.blockLength-1;s++)i[s]=o[s]|128;return i[this.blockLength-1]=o[this.blockLength-1],i.buffer}let t=ar(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",lt;let n=new Uint8Array(t.byteLength);if(!e){let o=new Uint8Array(t),i=t.byteLength-1;for(let s=0;s<i;s++)n[s]=o[s]|128;n[i]=o[i]}return n}toString(){let e="";if(this.isHexOnly)e=Y.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}}};no.NAME="sidBlock";var Ri=class extends Ne{constructor({value:e=vn,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let i=new no;if(o=i.fromBER(e,o,n),o===-1)return this.blockLength=0,this.error=i.error,o;this.value.length===0&&(i.isFirstSid=!0),this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}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,lt;t.push(o)}return lc(t)}fromString(e){this.value=[];let t=0,n=0,o="",i=!1;do if(n=e.indexOf(".",t),n===-1?o=e.substring(t):o=e.substring(t,n),t=n+1,i){let s=this.value[0],a=0;switch(s.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;s.valueDec=c+a,i=!1}else{let s=new no;if(o>Number.MAX_SAFE_INTEGER){mi();let a=BigInt(o);s.valueBigInt=a}else if(s.valueDec=parseInt(o,10),isNaN(s.valueDec))return;this.value.length||(s.isFirstSid=!0,i=!0),this.value.push(s)}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}};Ri.NAME="ObjectIdentifierValueBlock";var mf,ut=class extends ke{constructor(e={}){super(e,Ri),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()}}};mf=ut;D.ObjectIdentifier=mf;ut.NAME="OBJECT IDENTIFIER";var oo=class extends Ht(Ot){constructor({valueDec:e=0,...t}={}){super(t),this.valueDec=e}fromBER(e,t,n){if(n===0)return t;let o=Y.BufferSourceConverter.toUint8Array(e);if(!Mt(this,o,t,n))return-1;let i=o.subarray(t,t+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=i[a]&127,this.blockLength++,!!(i[a]&128));a++);let s=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)s[a]=this.valueHexView[a];return this.valueHexView=s,i[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=Dr(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,i=new Uint8Array(this.blockLength);for(let s=0;s<this.blockLength-1;s++)i[s]=o[s]|128;return i[this.blockLength-1]=o[this.blockLength-1],i.buffer}let t=ar(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",lt;let n=new Uint8Array(t.byteLength);if(!e){let o=new Uint8Array(t),i=t.byteLength-1;for(let s=0;s<i;s++)n[s]=o[s]|128;n[i]=o[i]}return n.buffer}toString(){let e="";return this.isHexOnly?e=Y.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};oo.NAME="relativeSidBlock";var _i=class extends Ne{constructor({value:e=vn,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let i=new oo;if(o=i.fromBER(e,o,n),o===-1)return this.blockLength=0,this.error=i.error,o;this.blockLength+=i.blockLength,n-=i.blockLength,this.value.push(i)}return o}toBER(e,t){let n=[];for(let o=0;o<this.value.length;o++){let i=this.value[o].toBER(e);if(i.byteLength===0)return this.error=this.value[o].error,lt;n.push(i)}return lc(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 i=new oo;if(i.valueDec=parseInt(o,10),isNaN(i.valueDec))return!0;this.value.push(i)}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}};_i.NAME="RelativeObjectIdentifierValueBlock";var yf,Ti=class extends ke{constructor(e={}){super(e,_i),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()}}};yf=Ti;D.RelativeObjectIdentifier=yf;Ti.NAME="RelativeObjectIdentifier";var gf,xe=class extends cr{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};gf=xe;D.Sequence=gf;xe.NAME="SEQUENCE";var wf,Ni=class extends cr{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};wf=Ni;D.Set=wf;Ni.NAME="SET";var Ci=class extends Ht(Ne){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=vn}toJSON(){return{...super.toJSON(),value:this.value}}};Ci.NAME="StringValueBlock";var Li=class extends Ci{};Li.NAME="SimpleStringValueBlock";var Pe=class extends wi{constructor({...e}={}){super(e,Li)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,Y.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}};Pe.NAME="SIMPLE STRING";var Ui=class extends Pe{fromBuffer(e){this.valueBlock.valueHexView=Y.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=Y.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=Y.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(Y.Convert.FromUtf8String(e)),this.valueBlock.value=e}};Ui.NAME="Utf8StringValueBlock";var bf,Ft=class extends Ui{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};bf=Ft;D.Utf8String=bf;Ft.NAME="UTF8String";var Di=class extends Pe{fromBuffer(e){this.valueBlock.value=Y.Convert.ToUtf16String(e),this.valueBlock.valueHexView=Y.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(Y.Convert.FromUtf16String(e))}};Di.NAME="BmpStringValueBlock";var xf,Pi=class extends Di{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};xf=Pi;D.BmpString=xf;Pi.NAME="BMPString";var Oi=class extends Pe{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 i=ar(e.charCodeAt(o),8),s=new Uint8Array(i);if(s.length>4)continue;let a=4-s.length;for(let c=s.length-1;c>=0;c--)n[o*4+c+a]=s[c]}this.valueBlock.value=e}};Oi.NAME="UniversalStringValueBlock";var Ef,Vi=class extends Oi{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Ef=Vi;D.UniversalString=Ef;Vi.NAME="UniversalString";var vf,Fi=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};vf=Fi;D.NumericString=vf;Fi.NAME="NumericString";var Bf,Mi=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Bf=Mi;D.PrintableString=Bf;Mi.NAME="PrintableString";var Af,Hi=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Af=Hi;D.TeletexString=Af;Hi.NAME="TeletexString";var kf,$i=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};kf=$i;D.VideotexString=kf;$i.NAME="VideotexString";var Sf,Ki=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Sf=Ki;D.IA5String=Sf;Ki.NAME="IA5String";var If,qi=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};If=qi;D.GraphicString=If;qi.NAME="GraphicString";var Rf,io=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Rf=io;D.VisibleString=Rf;io.NAME="VisibleString";var _f,zi=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};_f=zi;D.GeneralString=_f;zi.NAME="GeneralString";var Tf,Gi=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Tf=Gi;D.CharacterString=Tf;Gi.NAME="CharacterString";var Nf,so=class extends io{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,Y.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]=Fe(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=Fe(this.month,2),t[2]=Fe(this.day,2),t[3]=Fe(this.hour,2),t[4]=Fe(this.minute,2),t[5]=Fe(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}}};Nf=so;D.UTCTime=Nf;so.NAME="UTCTime";var Cf,ji=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="",i=0,s,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,p=n.indexOf("+"),E="";if(p===-1&&(p=n.indexOf("-"),l=-1),p!==-1){if(E=n.substring(p+1),n=n.substring(0,p),E.length!==2&&E.length!==4)throw new Error("Wrong input string for conversion");let y=parseInt(E.substring(0,2),10);if(isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*y,E.length===4){if(y=parseInt(E.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");i=l.valueOf(),o=n.substring(0,f)}else o=n;switch(!0){case o.length===8:if(s=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case o.length===10:if(s=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=60*i;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(s=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=60*i;this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case o.length===14:if(s=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=1e3*i;this.millisecond=Math.floor(l)}break;default:throw new Error("Wrong input string for conversion")}let u=s.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(Fe(this.year,4)),t.push(Fe(this.month,2)),t.push(Fe(this.day,2)),t.push(Fe(this.hour,2)),t.push(Fe(this.minute,2)),t.push(Fe(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(Fe(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Cf=ji;D.GeneralizedTime=Cf;ji.NAME="GeneralizedTime";var Lf,Wi=class extends Ft{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Lf=Wi;D.DATE=Lf;Wi.NAME="DATE";var Uf,Yi=class extends Ft{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Uf=Yi;D.TimeOfDay=Uf;Yi.NAME="TimeOfDay";var Df,Zi=class extends Ft{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Df=Zi;D.DateTime=Df;Zi.NAME="DateTime";var Pf,Ji=class extends Ft{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Pf=Ji;D.Duration=Pf;Ji.NAME="Duration";var Of,Xi=class extends Ft{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Of=Xi;D.TIME=Of;Xi.NAME="TIME";function eg(r){let{result:e}=Bn(r),t=e.valueBlock.value;return{n:j(vt(t[1].toBigInt()),"base64url"),e:j(vt(t[2].toBigInt()),"base64url"),d:j(vt(t[3].toBigInt()),"base64url"),p:j(vt(t[4].toBigInt()),"base64url"),q:j(vt(t[5].toBigInt()),"base64url"),dp:j(vt(t[6].toBigInt()),"base64url"),dq:j(vt(t[7].toBigInt()),"base64url"),qi:j(vt(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function tg(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 C("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new xe({value:[new me({value:0}),me.fromBigInt(Bt(G(r.n,"base64url"))),me.fromBigInt(Bt(G(r.e,"base64url"))),me.fromBigInt(Bt(G(r.d,"base64url"))),me.fromBigInt(Bt(G(r.p,"base64url"))),me.fromBigInt(Bt(G(r.q,"base64url"))),me.fromBigInt(Bt(G(r.dp,"base64url"))),me.fromBigInt(Bt(G(r.dq,"base64url"))),me.fromBigInt(Bt(G(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function rg(r){let{result:e}=Bn(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:j(vt(t[0].toBigInt()),"base64url"),e:j(vt(t[1].toBigInt()),"base64url")}}function ng(r){if(r.n==null||r.e==null)throw new C("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new xe({value:[new xe({value:[new ut({value:"1.2.840.113549.1.1.1"}),new ur]}),new En({valueHex:new xe({value:[me.fromBigInt(Bt(G(r.n,"base64url"))),me.fromBigInt(Bt(G(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function vt(r){let e=r.toString(16);e.length%2>0&&(e=`0${e}`);let t=e.length/2,n=new Uint8Array(t),o=0,i=0;for(;o<t;)n[o]=parseInt(e.slice(i,i+2),16),o+=1,i+=2;return n}function Bt(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 og=16,hc=32,dc=1e4;async function ig(r,e){let t=De.get(),o=new xe({value:[new me({value:0}),new xe({value:[new ut({value:"1.2.840.113549.1.1.1"}),new ur]}),new Vt({valueHex:r.marshal()})]}).toBER(),i=new Uint8Array(o,0,o.byteLength),s=Ur(og),a=await ac(mn,e,s,{c:dc,dkLen:hc}),c=Ur(16),f=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),u=await t.subtle.encrypt({name:"AES-CBC",iv:c},f,i),l=new xe({value:[new Vt({valueHex:s}),new me({value:dc}),new me({value:hc}),new xe({value:[new ut({value:"1.2.840.113549.2.11"}),new ur]})]}),p=new xe({value:[new ut({value:"1.2.840.113549.1.5.13"}),new xe({value:[new xe({value:[new ut({value:"1.2.840.113549.1.5.12"}),l]}),new xe({value:[new ut({value:"2.16.840.1.101.3.4.1.42"}),new Vt({valueHex:c})]})]})]}),y=new xe({value:[p,new Vt({valueHex:u})]}).toBER(),d=new Uint8Array(y,0,y.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...j(d,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
8
- `)}async function sg(r,e){let t=De.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=G(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Bn(o),{iv:s,salt:a,iterations:c,keySize:f,cipherText:u}=ag(i),l=await ac(mn,e,a,{c,dkLen:f}),p=await t.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),E=ao(await t.subtle.decrypt({name:"AES-CBC",iv:s},p,u)),{result:y}=Bn(E);n=Vf(y)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=G(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:i}=Bn(o);n=Vf(i)}else throw new C("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return pc(n)}function ag(r){let e=r.valueBlock.value[0];if(e.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new C("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 C("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let i=n.valueBlock.value[1],s=ao(i.valueBlock.value[0].getValue()),a=dc,c=hc;if(i.valueBlock.value.length===3)a=Number(i.valueBlock.value[1].toBigInt()),c=Number(i.valueBlock.value[2].toBigInt());else if(i.valueBlock.value.length===2)throw new C("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 C("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=ao(f.valueBlock.value[1].getValue());return{cipherText:ao(r.valueBlock.value[1].getValue()),salt:s,iterations:a,keySize:c,iv:l}}function Vf(r){return ao(r.valueBlock.value[2].getValue())}function ao(r){return new Uint8Array(r,0,r.byteLength)}async function Ff(r){let e=await De.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 $f(e);return{privateKey:t[0],publicKey:t[1]}}async function mc(r){let t=[await De.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await cg(r)],n=await $f({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Mf(r,e){let t=await De.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await De.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function Hf(r,e,t){let n=await De.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return De.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray())}async function $f(r){if(r.privateKey==null||r.publicKey==null)throw new C("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([De.get().subtle.exportKey("jwk",r.privateKey),De.get().subtle.exportKey("jwk",r.publicKey)])}async function cg(r){return De.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 es(r){if(r.kty!=="RSA")throw new C("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new C("invalid key modulus","ERR_INVALID_KEY_MODULUS");return G(r.n,"base64url").length*8}var uo=8192,co=class{_key;constructor(e){this._key=e}verify(e,t){return Hf(this._key,t,e)}marshal(){return lr.jwkToPkix(this._key)}get bytes(){return xt.encode({Type:de.RSA,Data:this.marshal()}).subarray()}equals(e){return oe(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(e)?e.then(({bytes:t})=>t):e.bytes}},An=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return Ur(16)}sign(e){return Mf(this._key,e)}get public(){if(this._publicKey==null)throw new C("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new co(this._publicKey)}marshal(){return lr.jwkToPkcs1(this._key)}get bytes(){return Dt.encode({Type:de.RSA,Data:this.marshal()}).subarray()}equals(e){return oe(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return j(e,"base58btc")}async export(e,t="pkcs-8"){if(t==="pkcs-8")return lr.exportToPem(this,e);if(t==="libp2p-key")return wn(this.bytes,e);throw new C(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function pc(r){let e=lr.pkcs1ToJwk(r);if(es(e)>uo)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await mc(e);return new An(t.privateKey,t.publicKey)}function lg(r){let e=lr.pkixToJwk(r);if(es(e)>uo)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new co(e)}async function fg(r){if(es(r)>uo)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await mc(r);return new An(e.privateKey,e.publicKey)}async function hg(r){if(r>uo)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Ff(r);return new An(e.privateKey,e.publicKey)}var Ec={};ge(Ec,{Secp256k1PrivateKey:()=>fo,Secp256k1PublicKey:()=>lo,generateKeyPair:()=>Ig,unmarshalSecp256k1PrivateKey:()=>kg,unmarshalSecp256k1PublicKey:()=>Sg});var dg=(r,e,t)=>r&e^~r&t,pg=(r,e,t)=>r&e^r&t^e&t,mg=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]),fr=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),hr=new Uint32Array(64),gc=class extends pn{constructor(){super(64,32,8,!1),this.A=fr[0]|0,this.B=fr[1]|0,this.C=fr[2]|0,this.D=fr[3]|0,this.E=fr[4]|0,this.F=fr[5]|0,this.G=fr[6]|0,this.H=fr[7]|0}get(){let{A:e,B:t,C:n,D:o,E:i,F:s,G:a,H:c}=this;return[e,t,n,o,i,s,a,c]}set(e,t,n,o,i,s,a,c){this.A=e|0,this.B=t|0,this.C=n|0,this.D=o|0,this.E=i|0,this.F=s|0,this.G=a|0,this.H=c|0}process(e,t){for(let l=0;l<16;l++,t+=4)hr[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let p=hr[l-15],E=hr[l-2],y=st(p,7)^st(p,18)^p>>>3,d=st(E,17)^st(E,19)^E>>>10;hr[l]=d+hr[l-7]+y+hr[l-16]|0}let{A:n,B:o,C:i,D:s,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let p=st(a,6)^st(a,11)^st(a,25),E=u+p+dg(a,c,f)+mg[l]+hr[l]|0,d=(st(n,2)^st(n,13)^st(n,22))+pg(n,o,i)|0;u=f,f=c,c=a,a=s+E|0,s=i,i=o,o=n,n=E+d|0}n=n+this.A|0,o=o+this.B|0,i=i+this.C|0,s=s+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,i,s,a,c,f,u)}roundClean(){hr.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Kf=ei(()=>new gc);function yg(r){let e=Zn(r);bt(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:gg,hexToBytes:wg}=ni,Pr={Err:class extends Error{constructor(e=""){super(e)}},_parseInt(r){let{Err:e}=Pr;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:gg(n),l:r.subarray(t+2)}},toSig(r){let{Err:e}=Pr,t=typeof r=="string"?wg(r):r;if(!at(t))throw new Error("ui8a expected");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:i}=Pr._parseInt(t.subarray(2)),{d:s,l:a}=Pr._parseInt(i);if(a.length)throw new e("Invalid signature: left bytes after parsing");return{r:o,s}},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)),i=n.length/2,s=o.length/2,a=t(i),c=t(s);return`30${t(s+i+4)}02${c}${o}02${a}${n}`}},$t=BigInt(0),et=BigInt(1),H2=BigInt(2),qf=BigInt(3),$2=BigInt(4);function bg(r){let e=yg(r),{Fp:t}=e,n=e.toBytes||((y,d,m)=>{let g=d.toAffine();return Ct(Uint8Array.from([4]),t.toBytes(g.x),t.toBytes(g.y))}),o=e.fromBytes||(y=>{let d=y.subarray(1),m=t.fromBytes(d.subarray(0,t.BYTES)),g=t.fromBytes(d.subarray(t.BYTES,2*t.BYTES));return{x:m,y:g}});function i(y){let{a:d,b:m}=e,g=t.sqr(y),I=t.mul(g,y);return t.add(t.add(I,t.mul(y,d)),m)}if(!t.eql(t.sqr(e.Gy),i(e.Gx)))throw new Error("bad generator point: equation left != right");function s(y){return typeof y=="bigint"&&$t<y&&y<e.n}function a(y){if(!s(y))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(y){let{allowedPrivateKeyLengths:d,nByteLength:m,wrapPrivateKey:g,n:I}=e;if(d&&typeof y!="bigint"){if(at(y)&&(y=Tt(y)),typeof y!="string"||!d.includes(y.length))throw new Error("Invalid key");y=y.padStart(m*2,"0")}let v;try{v=typeof y=="bigint"?y:Nt(fe("private key",y,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof y}`)}return g&&(v=ne(v,I)),a(v),v}let f=new Map;function u(y){if(!(y instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(d,m,g){if(this.px=d,this.py=m,this.pz=g,d==null||!t.isValid(d))throw new Error("x required");if(m==null||!t.isValid(m))throw new Error("y required");if(g==null||!t.isValid(g))throw new Error("z required")}static fromAffine(d){let{x:m,y:g}=d||{};if(!d||!t.isValid(m)||!t.isValid(g))throw new Error("invalid affine point");if(d instanceof l)throw new Error("projective point not allowed");let I=v=>t.eql(v,t.ZERO);return I(m)&&I(g)?l.ZERO:new l(m,g,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let m=t.invertBatch(d.map(g=>g.pz));return d.map((g,I)=>g.toAffine(m[I])).map(l.fromAffine)}static fromHex(d){let m=l.fromAffine(o(fe("pointHex",d)));return m.assertValidity(),m}static fromPrivateKey(d){return l.BASE.multiply(c(d))}_setWindowSize(d){this._WINDOW_SIZE=d,f.delete(this)}assertValidity(){if(this.is0()){if(e.allowInfinityPoint&&!t.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:d,y:m}=this.toAffine();if(!t.isValid(d)||!t.isValid(m))throw new Error("bad point: x or y not FE");let g=t.sqr(m),I=i(d);if(!t.eql(g,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:d}=this.toAffine();if(t.isOdd)return!t.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){u(d);let{px:m,py:g,pz:I}=this,{px:v,py:U,pz:S}=d,_=t.eql(t.mul(m,S),t.mul(v,I)),L=t.eql(t.mul(g,S),t.mul(U,I));return _&&L}negate(){return new l(this.px,t.neg(this.py),this.pz)}double(){let{a:d,b:m}=e,g=t.mul(m,qf),{px:I,py:v,pz:U}=this,S=t.ZERO,_=t.ZERO,L=t.ZERO,w=t.mul(I,I),N=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(d,L),_=t.mul(g,O),_=t.add(S,_),S=t.sub(N,_),_=t.add(N,_),_=t.mul(S,_),S=t.mul(T,S),L=t.mul(g,L),O=t.mul(d,O),T=t.sub(w,O),T=t.mul(d,T),T=t.add(T,L),L=t.add(w,w),w=t.add(L,w),w=t.add(w,O),w=t.mul(w,T),_=t.add(_,w),O=t.mul(v,U),O=t.add(O,O),w=t.mul(O,T),S=t.sub(S,w),L=t.mul(O,N),L=t.add(L,L),L=t.add(L,L),new l(S,_,L)}add(d){u(d);let{px:m,py:g,pz:I}=this,{px:v,py:U,pz:S}=d,_=t.ZERO,L=t.ZERO,w=t.ZERO,N=e.a,O=t.mul(e.b,qf),T=t.mul(m,v),F=t.mul(g,U),$=t.mul(I,S),J=t.add(m,g),x=t.add(v,U);J=t.mul(J,x),x=t.add(T,F),J=t.sub(J,x),x=t.add(m,I);let k=t.add(v,S);return x=t.mul(x,k),k=t.add(T,$),x=t.sub(x,k),k=t.add(g,I),_=t.add(U,S),k=t.mul(k,_),_=t.add(F,$),k=t.sub(k,_),w=t.mul(N,x),_=t.mul(O,$),w=t.add(_,w),_=t.sub(F,w),w=t.add(F,w),L=t.mul(_,w),F=t.add(T,T),F=t.add(F,T),$=t.mul(N,$),x=t.mul(O,x),F=t.add(F,$),$=t.sub(T,$),$=t.mul(N,$),x=t.add(x,$),T=t.mul(F,x),L=t.add(L,T),T=t.mul(k,x),_=t.mul(J,_),_=t.sub(_,T),T=t.mul(J,F),w=t.mul(k,w),w=t.add(w,T),new l(_,L,w)}subtract(d){return this.add(d.negate())}is0(){return this.equals(l.ZERO)}wNAF(d){return E.wNAFCached(this,f,d,m=>{let g=t.invertBatch(m.map(I=>I.pz));return m.map((I,v)=>I.toAffine(g[v])).map(l.fromAffine)})}multiplyUnsafe(d){let m=l.ZERO;if(d===$t)return m;if(a(d),d===et)return this;let{endo:g}=e;if(!g)return E.unsafeLadder(this,d);let{k1neg:I,k1:v,k2neg:U,k2:S}=g.splitScalar(d),_=m,L=m,w=this;for(;v>$t||S>$t;)v&et&&(_=_.add(w)),S&et&&(L=L.add(w)),w=w.double(),v>>=et,S>>=et;return I&&(_=_.negate()),U&&(L=L.negate()),L=new l(t.mul(L.px,g.beta),L.py,L.pz),_.add(L)}multiply(d){a(d);let m=d,g,I,{endo:v}=e;if(v){let{k1neg:U,k1:S,k2neg:_,k2:L}=v.splitScalar(m),{p:w,f:N}=this.wNAF(S),{p:O,f:T}=this.wNAF(L);w=E.constTimeNegate(U,w),O=E.constTimeNegate(_,O),O=new l(t.mul(O.px,v.beta),O.py,O.pz),g=w.add(O),I=N.add(T)}else{let{p:U,f:S}=this.wNAF(m);g=U,I=S}return l.normalizeZ([g,I])[0]}multiplyAndAddUnsafe(d,m,g){let I=l.BASE,v=(S,_)=>_===$t||_===et||!S.equals(I)?S.multiplyUnsafe(_):S.multiply(_),U=v(this,m).add(v(d,g));return U.is0()?void 0:U}toAffine(d){let{px:m,py:g,pz:I}=this,v=this.is0();d==null&&(d=v?t.ONE:t.inv(I));let U=t.mul(m,d),S=t.mul(g,d),_=t.mul(I,d);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:d,isTorsionFree:m}=e;if(d===et)return!0;if(m)return m(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:m}=e;return d===et?this:m?m(l,this):this.multiplyUnsafe(e.h)}toRawBytes(d=!0){return this.assertValidity(),n(l,this,d)}toHex(d=!0){return Tt(this.toRawBytes(d))}}l.BASE=new l(e.Gx,e.Gy,t.ONE),l.ZERO=new l(t.ZERO,t.ONE,t.ZERO);let p=e.nBitLength,E=si(l,e.endo?Math.ceil(p/2):p);return{CURVE:e,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:s}}function xg(r){let e=Zn(r);return bt(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function zf(r){let e=xg(r),{Fp:t,n}=e,o=t.BYTES+1,i=2*t.BYTES+1;function s(x){return $t<x&&x<t.ORDER}function a(x){return ne(x,n)}function c(x){return oi(x,n)}let{ProjectivePoint:f,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:p}=bg({...e,toBytes(x,k,H){let A=k.toAffine(),b=t.toBytes(A.x),P=Ct;return H?P(Uint8Array.from([k.hasEvenY()?2:3]),b):P(Uint8Array.from([4]),b,t.toBytes(A.y))},fromBytes(x){let k=x.length,H=x[0],A=x.subarray(1);if(k===o&&(H===2||H===3)){let b=Nt(A);if(!s(b))throw new Error("Point is not on curve");let P=l(b),M=t.sqrt(P),K=(M&et)===et;return(H&1)===1!==K&&(M=t.neg(M)),{x:b,y:M}}else if(k===i&&H===4){let b=t.fromBytes(A.subarray(0,t.BYTES)),P=t.fromBytes(A.subarray(t.BYTES,2*t.BYTES));return{x:b,y:P}}else throw new Error(`Point of length ${k} was invalid. Expected ${o} compressed bytes or ${i} uncompressed bytes`)}}),E=x=>Tt(sr(x,e.nByteLength));function y(x){let k=n>>et;return x>k}function d(x){return y(x)?a(-x):x}let m=(x,k,H)=>Nt(x.slice(k,H));class g{constructor(k,H,A){this.r=k,this.s=H,this.recovery=A,this.assertValidity()}static fromCompact(k){let H=e.nByteLength;return k=fe("compactSignature",k,H*2),new g(m(k,0,H),m(k,H,2*H))}static fromDER(k){let{r:H,s:A}=Pr.toSig(fe("DER",k));return new g(H,A)}assertValidity(){if(!p(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!p(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(k){return new g(this.r,this.s,k)}recoverPublicKey(k){let{r:H,s:A,recovery:b}=this,P=L(fe("msgHash",k));if(b==null||![0,1,2,3].includes(b))throw new Error("recovery id invalid");let M=b===2||b===3?H+e.n:H;if(M>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let K=b&1?"03":"02",z=f.fromHex(K+E(M)),W=c(M),re=a(-P*W),Z=a(A*W),X=f.BASE.multiplyAndAddUnsafe(z,re,Z);if(!X)throw new Error("point at infinify");return X.assertValidity(),X}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new g(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Tr(this.toDERHex())}toDERHex(){return Pr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Tr(this.toCompactHex())}toCompactHex(){return E(this.r)+E(this.s)}}let I={isValidPrivateKey(x){try{return u(x),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let x=Qa(e.n);return Vl(e.randomBytes(x),e.n)},precompute(x=8,k=f.BASE){return k._setWindowSize(x),k.multiply(BigInt(3)),k}};function v(x,k=!0){return f.fromPrivateKey(x).toRawBytes(k)}function U(x){let k=at(x),H=typeof x=="string",A=(k||H)&&x.length;return k?A===o||A===i:H?A===2*o||A===2*i:x instanceof f}function S(x,k,H=!0){if(U(x))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(x)).toRawBytes(H)}let _=e.bits2int||function(x){let k=Nt(x),H=x.length*8-e.nBitLength;return H>0?k>>BigInt(H):k},L=e.bits2int_modN||function(x){return a(_(x))},w=Yn(e.nBitLength);function N(x){if(typeof x!="bigint")throw new Error("bigint expected");if(!($t<=x&&x<w))throw new Error(`bigint expected < 2^${e.nBitLength}`);return sr(x,e.nByteLength)}function O(x,k,H=T){if(["recovered","canonical"].some(ue=>ue in H))throw new Error("sign() legacy options not supported");let{hash:A,randomBytes:b}=e,{lowS:P,prehash:M,extraEntropy:K}=H;P==null&&(P=!0),x=fe("msgHash",x),M&&(x=fe("prehashed msgHash",A(x)));let z=L(x),W=u(k),re=[N(W),N(z)];if(K!=null){let ue=K===!0?b(t.BYTES):K;re.push(fe("extraEntropy",ue))}let Z=Ct(...re),X=z;function pe(ue){let ve=_(ue);if(!p(ve))return;let Be=c(ve),ye=f.BASE.multiply(ve).toAffine(),Re=a(ye.x);if(Re===$t)return;let St=a(Be*a(X+Re*W));if(St===$t)return;let wr=(ye.x===Re?0:2)|Number(ye.y&et),On=St;return P&&y(St)&&(On=d(St),wr^=1),new g(Re,On,wr)}return{seed:Z,k2sig:pe}}let T={lowS:e.lowS,prehash:!1},F={lowS:e.lowS,prehash:!1};function $(x,k,H=T){let{seed:A,k2sig:b}=O(x,k,H),P=e;return Ya(P.hash.outputLen,P.nByteLength,P.hmac)(A,b)}f.BASE._setWindowSize(8);function J(x,k,H,A=F){let b=x;if(k=fe("msgHash",k),H=fe("publicKey",H),"strict"in A)throw new Error("options.strict was renamed to lowS");let{lowS:P,prehash:M}=A,K,z;try{if(typeof b=="string"||at(b))try{K=g.fromDER(b)}catch(ye){if(!(ye instanceof Pr.Err))throw ye;K=g.fromCompact(b)}else if(typeof b=="object"&&typeof b.r=="bigint"&&typeof b.s=="bigint"){let{r:ye,s:Re}=b;K=new g(ye,Re)}else throw new Error("PARSE");z=f.fromHex(H)}catch(ye){if(ye.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:re}=K,Z=L(k),X=c(re),pe=a(Z*X),ue=a(W*X),ve=f.BASE.multiplyAndAddUnsafe(z,pe,ue)?.toAffine();return ve?a(ve.x)===W:!1}return{CURVE:e,getPublicKey:v,getSharedSecret:S,sign:$,verify:J,ProjectivePoint:f,Signature:g,utils:I}}function Eg(r){return{hash:r,hmac:(e,...t)=>Xn(r,e,Qo(...t)),randomBytes:dn}}function Gf(r,e){let t=n=>zf({...r,...Eg(n)});return Object.freeze({...t(e),create:t})}var Yf=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),jf=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),vg=BigInt(1),wc=BigInt(2),Wf=(r,e)=>(r+e/wc)/e;function Bg(r){let e=Yf,t=BigInt(3),n=BigInt(6),o=BigInt(11),i=BigInt(22),s=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%e,u=f*f*r%e,l=ce(u,t,e)*u%e,p=ce(l,t,e)*u%e,E=ce(p,wc,e)*f%e,y=ce(E,o,e)*E%e,d=ce(y,i,e)*y%e,m=ce(d,a,e)*d%e,g=ce(m,c,e)*m%e,I=ce(g,a,e)*d%e,v=ce(I,t,e)*u%e,U=ce(v,s,e)*y%e,S=ce(U,n,e)*f%e,_=ce(S,wc,e);if(!bc.eql(bc.sqr(_),r))throw new Error("Cannot find square root");return _}var bc=ii(Yf,void 0,void 0,{sqrt:Bg}),ft=Gf({a:BigInt(0),b:BigInt(7),Fp:bc,n:jf,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=jf,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-vg*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=t,s=BigInt("0x100000000000000000000000000000000"),a=Wf(i*r,e),c=Wf(-n*r,e),f=ne(r-a*t-c*o,e),u=ne(-a*n-c*i,e),l=f>s,p=u>s;if(l&&(f=e-f),p&&(u=e-u),f>s||u>s)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:p,k2:u}}}},Kf),J2=BigInt(0);var X2=ft.ProjectivePoint;function Zf(){return ft.utils.randomPrivateKey()}function Jf(r,e){let t=we.digest(e instanceof Uint8Array?e:e.subarray());if(Xe(t))return t.then(({digest:n})=>ft.sign(n,r).toDERRawBytes()).catch(n=>{throw new C(String(n),"ERR_INVALID_INPUT")});try{return ft.sign(t.digest,r).toDERRawBytes()}catch(n){throw new C(String(n),"ERR_INVALID_INPUT")}}function Xf(r,e,t){let n=we.digest(t instanceof Uint8Array?t:t.subarray());if(Xe(n))return n.then(({digest:o})=>ft.verify(e,o,r)).catch(o=>{throw new C(String(o),"ERR_INVALID_INPUT")});try{return ft.verify(e,n.digest,r)}catch(o){throw new C(String(o),"ERR_INVALID_INPUT")}}function Qf(r){return ft.ProjectivePoint.fromHex(r).toRawBytes(!0)}function eh(r){try{ft.getPublicKey(r,!0)}catch(e){throw new C(String(e),"ERR_INVALID_PRIVATE_KEY")}}function xc(r){try{ft.ProjectivePoint.fromHex(r)}catch(e){throw new C(String(e),"ERR_INVALID_PUBLIC_KEY")}}function th(r){try{return ft.getPublicKey(r,!0)}catch(e){throw new C(String(e),"ERR_INVALID_PRIVATE_KEY")}}var lo=class{_key;constructor(e){xc(e),this._key=e}verify(e,t){return Xf(this._key,t,e)}marshal(){return Qf(this._key)}get bytes(){return xt.encode({Type:de.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return oe(this.bytes,e.bytes)}async hash(){let e=we.digest(this.bytes),t;return Xe(e)?{bytes:t}=await e:t=e.bytes,t}},fo=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??th(e),eh(this._key),xc(this._publicKey)}sign(e){return Jf(this._key,e)}get public(){return new lo(this._publicKey)}marshal(){return this._key}get bytes(){return Dt.encode({Type:de.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return oe(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return j(e,"base58btc")}async export(e,t="libp2p-key"){if(t==="libp2p-key")return wn(this.bytes,e);throw new C(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function kg(r){return new fo(r)}function Sg(r){return new lo(r)}async function Ig(){let r=Zf();return new fo(r)}var ts={rsa:yc,ed25519:sc,secp256k1:Ec};function Rg(r){let e=Object.keys(ts).join(" / ");return new C(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function vc(r){let e=xt.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case de.RSA:return ts.rsa.unmarshalRsaPublicKey(t);case de.Ed25519:return ts.ed25519.unmarshalEd25519PublicKey(t);case de.Secp256k1:return ts.secp256k1.unmarshalSecp256k1PublicKey(t);default:throw Rg(e.Type??"unknown")}}var cw=yt(tn(),1);var Kt="/",rh=new TextEncoder().encode(Kt),rs=rh[0],Se=class r{_buf;constructor(e,t){if(typeof e=="string")this._buf=G(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]!==rs)throw new Error("Invalid key")}toString(e="utf8"){return j(this._buf,e)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(e){return new r(e.join(Kt))}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=rh),this._buf[0]!==rs){let e=new Uint8Array(this._buf.byteLength+1);e.fill(rs,0,1),e.set(this._buf,1),this._buf=e}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===rs;)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 i=t[o],s=n[o];if(i<s)return!0;if(i>s)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(Kt).slice(1)}type(){return _g(this.baseNamespace())}name(){return Tg(this.baseNamespace())}instance(e){return new r(this.toString()+":"+e)}path(){let e=this.parent().toString();return e.endsWith(Kt)||(e+=Kt),e+=this.type(),new r(e)}parent(){let e=this.list();return e.length===1?new r(Kt):new r(e.slice(0,-1).join(Kt))}child(e){return this.toString()===Kt?e:e.toString()===Kt?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(),...Ng(e.map(t=>t.namespaces()))])}};function _g(r){let e=r.split(":");return e.length<2?"":e.slice(0,-1).join(":")}function Tg(r){let e=r.split(":");return e[e.length-1]}function Ng(r){return[].concat(...r)}var uw=yt(Ac(),1);var nh="ERR_IPNS_EXPIRED_RECORD",ns="ERR_UNRECOGNIZED_VALIDITY";var qt="ERR_SIGNATURE_VERIFICATION";var kc="ERR_UNDEFINED_PARAMETER",oh="ERR_INVALID_RECORD_DATA",ih="ERR_INVALID_VALUE",sh="ERR_INVALID_EMBEDDED_KEY";var ah="ERR_RECORD_TOO_LARGE";var ht;(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=()=>zn(t)}(e=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=en((o,i,s={})=>{s.lengthDelimited!==!1&&i.fork(),o.value!=null&&(i.uint32(10),i.bytes(o.value)),o.signatureV1!=null&&(i.uint32(18),i.bytes(o.signatureV1)),o.validityType!=null&&(i.uint32(24),r.ValidityType.codec().encode(o.validityType,i)),o.validity!=null&&(i.uint32(34),i.bytes(o.validity)),o.sequence!=null&&(i.uint32(40),i.uint64(o.sequence)),o.ttl!=null&&(i.uint32(48),i.uint64(o.ttl)),o.pubKey!=null&&(i.uint32(58),i.bytes(o.pubKey)),o.signatureV2!=null&&(i.uint32(66),i.bytes(o.signatureV2)),o.data!=null&&(i.uint32(74),i.bytes(o.data)),s.lengthDelimited!==!1&&i.ldelim()},(o,i)=>{let s={},a=i==null?o.len:o.pos+i;for(;o.pos<a;){let c=o.uint32();switch(c>>>3){case 1:s.value=o.bytes();break;case 2:s.signatureV1=o.bytes();break;case 3:s.validityType=r.ValidityType.codec().decode(o);break;case 4:s.validity=o.bytes();break;case 5:s.sequence=o.uint64();break;case 6:s.ttl=o.uint64();break;case 7:s.pubKey=o.bytes();break;case 8:s.signatureV2=o.bytes();break;case 9:s.data=o.bytes();break;default:o.skipType(c&7);break}}return s})),n),r.encode=o=>Xr(o,r.codec()),r.decode=o=>Jr(o,r.codec())})(ht||(ht={}));var Cg=["string","number","bigint","symbol"],Lg=["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 uh(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let e=typeof r;if(Cg.includes(e))return e;if(e==="function")return"Function";if(Array.isArray(r))return"Array";if(Ug(r))return"Buffer";let t=Dg(r);return t||"Object"}function Ug(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function Dg(r){let e=Object.prototype.toString.call(r).slice(8,-1);if(Lg.includes(e))return e}var h=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}};h.uint=new h(0,"uint",!0);h.negint=new h(1,"negint",!0);h.bytes=new h(2,"bytes",!0);h.string=new h(3,"string",!0);h.array=new h(4,"array",!1);h.map=new h(5,"map",!1);h.tag=new h(6,"tag",!1);h.float=new h(7,"float",!0);h.false=new h(7,"false",!0);h.true=new h(7,"true",!0);h.null=new h(7,"null",!0);h.undefined=new h(7,"undefined",!0);h.break=new h(7,"break",!0);var B=class{constructor(e,t,n){this.type=e,this.value=t,this.encodedLength=n,this.encodedBytes=void 0,this.byteValue=void 0}toString(){return`Token[${this.type}].${this.value}`}};var kn=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",Pg=new TextDecoder,Og=new TextEncoder;function os(r){return kn&&globalThis.Buffer.isBuffer(r)}function ho(r){return r instanceof Uint8Array?os(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var dh=kn?(r,e,t)=>t-e>64?globalThis.Buffer.from(r.subarray(e,t)).toString("utf8"):fh(r,e,t):(r,e,t)=>t-e>64?Pg.decode(r.subarray(e,t)):fh(r,e,t),is=kn?r=>r.length>64?globalThis.Buffer.from(r):lh(r):r=>r.length>64?Og.encode(r):lh(r),At=r=>Uint8Array.from(r),Sn=kn?(r,e,t)=>os(r)?new Uint8Array(r.subarray(e,t)):r.slice(e,t):(r,e,t)=>r.slice(e,t),ph=kn?(r,e)=>(r=r.map(t=>t instanceof Uint8Array?t:globalThis.Buffer.from(t)),ho(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},mh=kn?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function yh(r,e){if(os(r)&&os(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 lh(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 fh(r,e,t){let n=[];for(;e<t;){let o=r[e],i=null,s=o>239?4:o>223?3:o>191?2:1;if(e+s<=t){let a,c,f,u;switch(s){case 1:o<128&&(i=o);break;case 2:a=r[e+1],(a&192)===128&&(u=(o&31)<<6|a&63,u>127&&(i=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)&&(i=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&&(i=u))}}i===null?(i=65533,s=1):i>65535&&(i-=65536,n.push(i>>>10&1023|55296),i=56320|i&1023),n.push(i),e+=s}return Sc(n)}var hh=4096;function Sc(r){let e=r.length;if(e<=hh)return String.fromCharCode.apply(String,r);let t="",n=0;for(;n<e;)t+=String.fromCharCode.apply(String,r.slice(n,n+=hh));return t}var Vg=256,po=class{constructor(e=Vg){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=mh(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=Sn(n,0,this.cursor)}else t=ph(this.chunks,this.cursor);return e&&this.reset(),t}};var V="CBOR decode error:",In="CBOR encode error:",mo=[];mo[23]=1;mo[24]=2;mo[25]=3;mo[26]=5;mo[27]=9;function zt(r,e,t){if(r.length-e<t)throw new Error(`${V} not enough data for type`)}var Ee=[24,256,65536,4294967296,BigInt("18446744073709551616")];function Ge(r,e,t){zt(r,e,1);let n=r[e];if(t.strict===!0&&n<Ee[0])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function je(r,e,t){zt(r,e,2);let n=r[e]<<8|r[e+1];if(t.strict===!0&&n<Ee[1])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function We(r,e,t){zt(r,e,4);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3];if(t.strict===!0&&n<Ee[2])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function Ye(r,e,t){zt(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],i=(BigInt(n)<<BigInt(32))+BigInt(o);if(t.strict===!0&&i<Ee[3])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);if(i<=Number.MAX_SAFE_INTEGER)return Number(i);if(t.allowBigInt===!0)return i;throw new Error(`${V} integers outside of the safe integer range are not supported`)}function gh(r,e,t,n){return new B(h.uint,Ge(r,e+1,n),2)}function wh(r,e,t,n){return new B(h.uint,je(r,e+1,n),3)}function bh(r,e,t,n){return new B(h.uint,We(r,e+1,n),5)}function xh(r,e,t,n){return new B(h.uint,Ye(r,e+1,n),9)}function tt(r,e){return Ie(r,0,e.value)}function Ie(r,e,t){if(t<Ee[0]){let n=Number(t);r.push([e|n])}else if(t<Ee[1]){let n=Number(t);r.push([e|24,n])}else if(t<Ee[2]){let n=Number(t);r.push([e|25,n>>>8,n&255])}else if(t<Ee[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<Ee[4]){let o=[e|27,0,0,0,0,0,0,0],i=Number(n&BigInt(4294967295)),s=Number(n>>BigInt(32)&BigInt(4294967295));o[8]=i&255,i=i>>8,o[7]=i&255,i=i>>8,o[6]=i&255,i=i>>8,o[5]=i&255,o[4]=s&255,s=s>>8,o[3]=s&255,s=s>>8,o[2]=s&255,s=s>>8,o[1]=s&255,r.push(o)}else throw new Error(`${V} encountered BigInt larger than allowable range`)}}tt.encodedSize=function(e){return Ie.encodedSize(e.value)};Ie.encodedSize=function(e){return e<Ee[0]?1:e<Ee[1]?2:e<Ee[2]?3:e<Ee[3]?5:9};tt.compareTokens=function(e,t){return e.value<t.value?-1:e.value>t.value?1:0};function Eh(r,e,t,n){return new B(h.negint,-1-Ge(r,e+1,n),2)}function vh(r,e,t,n){return new B(h.negint,-1-je(r,e+1,n),3)}function Bh(r,e,t,n){return new B(h.negint,-1-We(r,e+1,n),5)}var Ic=BigInt(-1),Ah=BigInt(1);function kh(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o!="bigint"){let i=-1-o;if(i>=Number.MIN_SAFE_INTEGER)return new B(h.negint,i,9)}if(n.allowBigInt!==!0)throw new Error(`${V} integers outside of the safe integer range are not supported`);return new B(h.negint,Ic-BigInt(o),9)}function ss(r,e){let t=e.value,n=typeof t=="bigint"?t*Ic-Ah:t*-1-1;Ie(r,e.type.majorEncoded,n)}ss.encodedSize=function(e){let t=e.value,n=typeof t=="bigint"?t*Ic-Ah:t*-1-1;return n<Ee[0]?1:n<Ee[1]?2:n<Ee[2]?3:n<Ee[3]?5:9};ss.compareTokens=function(e,t){return e.value<t.value?1:e.value>t.value?-1:0};function yo(r,e,t,n){zt(r,e,t+n);let o=Sn(r,e+t,e+t+n);return new B(h.bytes,o,t+n)}function Sh(r,e,t,n){return yo(r,e,1,t)}function Ih(r,e,t,n){return yo(r,e,2,Ge(r,e+1,n))}function Rh(r,e,t,n){return yo(r,e,3,je(r,e+1,n))}function _h(r,e,t,n){return yo(r,e,5,We(r,e+1,n))}function Th(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer bytes lengths not supported`);return yo(r,e,9,o)}function as(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===h.string?is(r.value):r.value),r.encodedBytes}function Rn(r,e){let t=as(e);Ie(r,e.type.majorEncoded,t.length),r.push(t)}Rn.encodedSize=function(e){let t=as(e);return Ie.encodedSize(t.length)+t.length};Rn.compareTokens=function(e,t){return Mg(as(e),as(t))};function Mg(r,e){return r.length<e.length?-1:r.length>e.length?1:yh(r,e)}function go(r,e,t,n,o){let i=t+n;zt(r,e,i);let s=new B(h.string,dh(r,e+t,e+i),i);return o.retainStringBytes===!0&&(s.byteValue=Sn(r,e+t,e+i)),s}function Nh(r,e,t,n){return go(r,e,1,t,n)}function Ch(r,e,t,n){return go(r,e,2,Ge(r,e+1,n),n)}function Lh(r,e,t,n){return go(r,e,3,je(r,e+1,n),n)}function Uh(r,e,t,n){return go(r,e,5,We(r,e+1,n),n)}function Dh(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer string lengths not supported`);return go(r,e,9,o,n)}var Ph=Rn;function _n(r,e,t,n){return new B(h.array,n,t)}function Oh(r,e,t,n){return _n(r,e,1,t)}function Vh(r,e,t,n){return _n(r,e,2,Ge(r,e+1,n))}function Fh(r,e,t,n){return _n(r,e,3,je(r,e+1,n))}function Mh(r,e,t,n){return _n(r,e,5,We(r,e+1,n))}function Hh(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer array lengths not supported`);return _n(r,e,9,o)}function $h(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return _n(r,e,1,1/0)}function cs(r,e){Ie(r,h.array.majorEncoded,e.value)}cs.compareTokens=tt.compareTokens;cs.encodedSize=function(e){return Ie.encodedSize(e.value)};function Tn(r,e,t,n){return new B(h.map,n,t)}function Kh(r,e,t,n){return Tn(r,e,1,t)}function qh(r,e,t,n){return Tn(r,e,2,Ge(r,e+1,n))}function zh(r,e,t,n){return Tn(r,e,3,je(r,e+1,n))}function Gh(r,e,t,n){return Tn(r,e,5,We(r,e+1,n))}function jh(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer map lengths not supported`);return Tn(r,e,9,o)}function Wh(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Tn(r,e,1,1/0)}function us(r,e){Ie(r,h.map.majorEncoded,e.value)}us.compareTokens=tt.compareTokens;us.encodedSize=function(e){return Ie.encodedSize(e.value)};function Yh(r,e,t,n){return new B(h.tag,t,1)}function Zh(r,e,t,n){return new B(h.tag,Ge(r,e+1,n),2)}function Jh(r,e,t,n){return new B(h.tag,je(r,e+1,n),3)}function Xh(r,e,t,n){return new B(h.tag,We(r,e+1,n),5)}function Qh(r,e,t,n){return new B(h.tag,Ye(r,e+1,n),9)}function ls(r,e){Ie(r,h.tag.majorEncoded,e.value)}ls.compareTokens=tt.compareTokens;ls.encodedSize=function(e){return Ie.encodedSize(e.value)};var Gg=20,jg=21,Wg=22,Yg=23;function ed(r,e,t,n){if(n.allowUndefined===!1)throw new Error(`${V} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new B(h.null,null,1):new B(h.undefined,void 0,1)}function td(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return new B(h.break,void 0,1)}function Rc(r,e,t){if(t){if(t.allowNaN===!1&&Number.isNaN(r))throw new Error(`${V} NaN values are not supported`);if(t.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${V} Infinity values are not supported`)}return new B(h.float,r,e)}function rd(r,e,t,n){return Rc(_c(r,e+1),3,n)}function nd(r,e,t,n){return Rc(Tc(r,e+1),5,n)}function od(r,e,t,n){return Rc(cd(r,e+1),9,n)}function fs(r,e,t){let n=e.value;if(n===!1)r.push([h.float.majorEncoded|Gg]);else if(n===!0)r.push([h.float.majorEncoded|jg]);else if(n===null)r.push([h.float.majorEncoded|Wg]);else if(n===void 0)r.push([h.float.majorEncoded|Yg]);else{let o,i=!1;(!t||t.float64!==!0)&&(sd(n),o=_c(dt,1),n===o||Number.isNaN(n)?(dt[0]=249,r.push(dt.slice(0,3)),i=!0):(ad(n),o=Tc(dt,1),n===o&&(dt[0]=250,r.push(dt.slice(0,5)),i=!0))),i||(Zg(n),o=cd(dt,1),dt[0]=251,r.push(dt.slice(0,9)))}}fs.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){sd(n);let o=_c(dt,1);if(n===o||Number.isNaN(n))return 3;if(ad(n),o=Tc(dt,1),n===o)return 5}return 9};var id=new ArrayBuffer(9),rt=new DataView(id,1),dt=new Uint8Array(id,0);function sd(r){if(r===1/0)rt.setUint16(0,31744,!1);else if(r===-1/0)rt.setUint16(0,64512,!1);else if(Number.isNaN(r))rt.setUint16(0,32256,!1);else{rt.setFloat32(0,r);let e=rt.getUint32(0),t=(e&2139095040)>>23,n=e&8388607;if(t===255)rt.setUint16(0,31744,!1);else if(t===0)rt.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let o=t-127;o<-24?rt.setUint16(0,0):o<-14?rt.setUint16(0,(e&2147483648)>>16|1<<24+o,!1):rt.setUint16(0,(e&2147483648)>>16|o+15<<10|n>>13,!1)}}}function _c(r,e){if(r.length-e<2)throw new Error(`${V} not enough data for float16`);let t=(r[e]<<8)+r[e+1];if(t===31744)return 1/0;if(t===64512)return-1/0;if(t===32256)return NaN;let n=t>>10&31,o=t&1023,i;return n===0?i=o*2**-24:n!==31?i=(o+1024)*2**(n-25):i=o===0?1/0:NaN,t&32768?-i:i}function ad(r){rt.setFloat32(0,r,!1)}function Tc(r,e){if(r.length-e<4)throw new Error(`${V} not enough data for float32`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,4).getFloat32(0,!1)}function Zg(r){rt.setFloat64(0,r,!1)}function cd(r,e){if(r.length-e<8)throw new Error(`${V} not enough data for float64`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,8).getFloat64(0,!1)}fs.compareTokens=tt.compareTokens;function Q(r,e,t){throw new Error(`${V} encountered invalid minor (${t}) for major ${r[e]>>>5}`)}function hs(r){return()=>{throw new Error(`${V} ${r}`)}}var R=[];for(let r=0;r<=23;r++)R[r]=Q;R[24]=gh;R[25]=wh;R[26]=bh;R[27]=xh;R[28]=Q;R[29]=Q;R[30]=Q;R[31]=Q;for(let r=32;r<=55;r++)R[r]=Q;R[56]=Eh;R[57]=vh;R[58]=Bh;R[59]=kh;R[60]=Q;R[61]=Q;R[62]=Q;R[63]=Q;for(let r=64;r<=87;r++)R[r]=Sh;R[88]=Ih;R[89]=Rh;R[90]=_h;R[91]=Th;R[92]=Q;R[93]=Q;R[94]=Q;R[95]=hs("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)R[r]=Nh;R[120]=Ch;R[121]=Lh;R[122]=Uh;R[123]=Dh;R[124]=Q;R[125]=Q;R[126]=Q;R[127]=hs("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)R[r]=Oh;R[152]=Vh;R[153]=Fh;R[154]=Mh;R[155]=Hh;R[156]=Q;R[157]=Q;R[158]=Q;R[159]=$h;for(let r=160;r<=183;r++)R[r]=Kh;R[184]=qh;R[185]=zh;R[186]=Gh;R[187]=jh;R[188]=Q;R[189]=Q;R[190]=Q;R[191]=Wh;for(let r=192;r<=215;r++)R[r]=Yh;R[216]=Zh;R[217]=Jh;R[218]=Xh;R[219]=Qh;R[220]=Q;R[221]=Q;R[222]=Q;R[223]=Q;for(let r=224;r<=243;r++)R[r]=hs("simple values are not supported");R[244]=Q;R[245]=Q;R[246]=Q;R[247]=ed;R[248]=hs("simple values are not supported");R[249]=rd;R[250]=nd;R[251]=od;R[252]=Q;R[253]=Q;R[254]=Q;R[255]=td;var pt=[];for(let r=0;r<24;r++)pt[r]=new B(h.uint,r,1);for(let r=-1;r>=-24;r--)pt[31-r]=new B(h.negint,r,1);pt[64]=new B(h.bytes,new Uint8Array(0),1);pt[96]=new B(h.string,"",1);pt[128]=new B(h.array,0,1);pt[160]=new B(h.map,0,1);pt[244]=new B(h.false,!1,1);pt[245]=new B(h.true,!0,1);pt[246]=new B(h.null,null,1);function ud(r){switch(r.type){case h.false:return At([244]);case h.true:return At([245]);case h.null:return At([246]);case h.bytes:return r.value.length?void 0:At([64]);case h.string:return r.value===""?At([96]):void 0;case h.array:return r.value===0?At([128]):void 0;case h.map:return r.value===0?At([160]):void 0;case h.uint:return r.value<24?At([Number(r.value)]):void 0;case h.negint:if(r.value>=-24)return At([31-Number(r.value)])}}var Xg={float64:!1,mapSorter:tw,quickEncodeToken:ud};function Qg(){let r=[];return r[h.uint.major]=tt,r[h.negint.major]=ss,r[h.bytes.major]=Rn,r[h.string.major]=Ph,r[h.array.major]=cs,r[h.map.major]=us,r[h.tag.major]=ls,r[h.float.major]=fs,r}var ld=Qg(),Nc=new po,ps=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(`${In} object contains circular references`);return new r(t,e)}},dr={null:new B(h.null,null),undefined:new B(h.undefined,void 0),true:new B(h.true,!0),false:new B(h.false,!1),emptyArray:new B(h.array,0),emptyMap:new B(h.map,0)},pr={number(r,e,t,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new B(h.float,r):r>=0?new B(h.uint,r):new B(h.negint,r)},bigint(r,e,t,n){return r>=BigInt(0)?new B(h.uint,r):new B(h.negint,r)},Uint8Array(r,e,t,n){return new B(h.bytes,r)},string(r,e,t,n){return new B(h.string,r)},boolean(r,e,t,n){return r?dr.true:dr.false},null(r,e,t,n){return dr.null},undefined(r,e,t,n){return dr.undefined},ArrayBuffer(r,e,t,n){return new B(h.bytes,new Uint8Array(r))},DataView(r,e,t,n){return new B(h.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,e,t,n){if(!r.length)return t.addBreakTokens===!0?[dr.emptyArray,new B(h.break)]:dr.emptyArray;n=ps.createCheck(n,r);let o=[],i=0;for(let s of r)o[i++]=ds(s,t,n);return t.addBreakTokens?[new B(h.array,r.length),o,new B(h.break)]:[new B(h.array,r.length),o]},Object(r,e,t,n){let o=e!=="Object",i=o?r.keys():Object.keys(r),s=o?r.size:i.length;if(!s)return t.addBreakTokens===!0?[dr.emptyMap,new B(h.break)]:dr.emptyMap;n=ps.createCheck(n,r);let a=[],c=0;for(let f of i)a[c++]=[ds(f,t,n),ds(o?r.get(f):r[f],t,n)];return ew(a,t),t.addBreakTokens?[new B(h.map,s),a,new B(h.break)]:[new B(h.map,s),a]}};pr.Map=pr.Object;pr.Buffer=pr.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))pr[`${r}Array`]=pr.DataView;function ds(r,e={},t){let n=uh(r),o=e&&e.typeEncoders&&e.typeEncoders[n]||pr[n];if(typeof o=="function"){let s=o(r,n,e,t);if(s!=null)return s}let i=pr[n];if(!i)throw new Error(`${In} unsupported type: ${n}`);return i(r,n,e,t)}function ew(r,e){e.mapSorter&&r.sort(e.mapSorter)}function tw(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,i=ld[o].compareTokens(t,n);return i===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),i}function fd(r,e,t,n){if(Array.isArray(e))for(let o of e)fd(r,o,t,n);else t[e.type.major](r,e,n)}function hd(r,e,t){let n=ds(r,t);if(!Array.isArray(n)&&t.quickEncodeToken){let o=t.quickEncodeToken(n);if(o)return o;let i=e[n.type.major];if(i.encodedSize){let s=i.encodedSize(n,t),a=new po(s);if(i(a,n,t),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return ho(a.chunks[0])}}return Nc.reset(),fd(Nc,n,e,t),Nc.toBytes(!0)}function Nn(r,e){return e=Object.assign({},Xg,e),hd(r,ld,e)}var rw={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},Cc=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=pt[e];if(t===void 0){let n=R[e];if(!n)throw new Error(`${V} 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}},wo=Symbol.for("DONE"),ms=Symbol.for("BREAK");function nw(r,e,t){let n=[];for(let o=0;o<r.value;o++){let i=bo(e,t);if(i===ms){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed array`)}if(i===wo)throw new Error(`${V} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=i}return n}function ow(r,e,t){let n=t.useMaps===!0,o=n?void 0:{},i=n?new Map:void 0;for(let s=0;s<r.value;s++){let a=bo(e,t);if(a===ms){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed map`)}if(a===wo)throw new Error(`${V} found map but not enough entries (got ${s} [no key], expected ${r.value})`);if(n!==!0&&typeof a!="string")throw new Error(`${V} non-string keys not supported (got ${typeof a})`);if(t.rejectDuplicateMapKeys===!0&&(n&&i.has(a)||!n&&a in o))throw new Error(`${V} found repeat map key "${a}"`);let c=bo(e,t);if(c===wo)throw new Error(`${V} found map but not enough entries (got ${s} [no value], expected ${r.value})`);n?i.set(a,c):o[a]=c}return n?i:o}function bo(r,e){if(r.done())return wo;let t=r.next();if(t.type===h.break)return ms;if(t.type.terminal)return t.value;if(t.type===h.array)return nw(t,r,e);if(t.type===h.map)return ow(t,r,e);if(t.type===h.tag){if(e.tags&&typeof e.tags[t.value]=="function"){let n=bo(r,e);return e.tags[t.value](n)}throw new Error(`${V} tag not supported (${t.value})`)}throw new Error("unsupported")}function Lc(r,e){if(!(r instanceof Uint8Array))throw new Error(`${V} data to decode must be a Uint8Array`);e=Object.assign({},rw,e);let t=e.tokenizer||new Cc(r,e),n=bo(t,e);if(n===wo)throw new Error(`${V} did not find any content to decode`);if(n===ms)throw new Error(`${V} got unexpected break`);return[n,r.subarray(t.pos())]}function nt(r,e){let[t,n]=Lc(r,e);if(n.length>0)throw new Error(`${V} too many terminals, data makes no sense`);return t}var Ze=yt(tn(),1);var dd=Ke("ipns:utils"),pd=G("/ipns/"),iw=114,md=async(r,e)=>{if(e==null||r==null){let n=new Error("one or more of the provided parameters are not defined");throw dd.error(n),(0,Ze.default)(n,kc)}let t;if(e.pubKey!=null){try{t=vc(e.pubKey)}catch(o){throw dd.error(o),o}if(!(await sl(e.pubKey)).equals(r))throw(0,Ze.default)(new Error("Embedded public key did not match PeerID"),sh)}else r.publicKey!=null&&(t=vc(r.publicKey));if(t!=null)return t;throw(0,Ze.default)(new Error("no public key is available"),kc)};var yd=r=>{let e=G("ipns-signature:");return Le([e,r])},Vr=r=>"signatureV1"in r?ht.encode({value:G(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:G(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):ht.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data});function kt(r){let e=ht.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,Ze.default)(new Error("missing data or signatureV2"),qt);let t=gd(e.data),n=sw(t.Value),o=j(t.Validity);if(e.value!=null&&e.signatureV1!=null)return aw(e),{value:n,validityType:ht.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:ht.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 Uc=r=>Le([pd,r.toBytes()]),Cn=r=>Wn(r.slice(pd.length));var gd=r=>{let e=nt(r);if(e.ValidityType===0)e.ValidityType=ht.ValidityType.EOL;else throw(0,Ze.default)(new Error("Unknown validity type"),ns);return Number.isInteger(e.Sequence)&&(e.Sequence=BigInt(e.Sequence)),Number.isInteger(e.TTL)&&(e.TTL=BigInt(e.TTL)),e},sw=r=>{if(r!=null){if(_u(r))return`/ipns/${r.toCID().toString(er)}`;if(r instanceof Uint8Array){let n=j(r);n.startsWith("/")&&(r=n)}let e=r.toString().trim();if(e.startsWith("/")&&e.length>1)return e;let t=ee.asCID(r);if(t!=null)return t.code===iw?`/ipns/${t.toString(er)}`:`/ipfs/${t.toV1().toString()}`;try{return r instanceof Uint8Array?`/ipfs/${ee.decode(r).toV1().toString()}`:`/ipfs/${ee.parse(e).toV1().toString()}`}catch{}}throw(0,Ze.default)(new Error("Value must be a valid content path starting with /"),ih)},aw=r=>{if(r.data==null)throw(0,Ze.default)(new Error("Record data is missing"),oh);let e=gd(r.data);if(!oe(e.Value,r.value??new Uint8Array(0)))throw(0,Ze.default)(new Error('Field "value" did not match between protobuf and CBOR'),qt);if(!oe(e.Validity,r.validity??new Uint8Array(0)))throw(0,Ze.default)(new Error('Field "validity" did not match between protobuf and CBOR'),qt);if(e.ValidityType!==r.validityType)throw(0,Ze.default)(new Error('Field "validityType" did not match between protobuf and CBOR'),qt);if(e.Sequence!==r.sequence)throw(0,Ze.default)(new Error('Field "sequence" did not match between protobuf and CBOR'),qt);if(e.TTL!==r.ttl)throw(0,Ze.default)(new Error('Field "ttl" did not match between protobuf and CBOR'),qt)};var UA=Ke("ipns"),DA=Je.code,lw="/ipns/",PA=lw.length;var xo=yt(tn(),1),wd=yt(Ac(),1);var gs=Ke("ipns:validator"),fw=1024*10,hw=async(r,e)=>{let t=kt(e),n;try{let o=yd(t.data);n=await r.verify(o,t.signatureV2)}catch{n=!1}if(!n)throw gs.error("record signature verification failed"),(0,xo.default)(new Error("record signature verification failed"),qt);if(t.validityType===ht.ValidityType.EOL){if(wd.default.fromString(t.validity).toDate().getTime()<Date.now())throw gs.error("record has expired"),(0,xo.default)(new Error("record has expired"),nh)}else if(t.validityType!=null)throw gs.error("unrecognized validity type"),(0,xo.default)(new Error("unrecognized validity type"),ns);gs("ipns record for %s is valid",t.value)};async function bd(r,e){if(e.byteLength>fw)throw(0,xo.default)(new Error("record too large"),ah);let t=Cn(r),n=kt(e),o=await md(t,n);await hw(o,e)}async function*Eo(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 i=n.split(e);n=i.pop()??"";for(let s=0;s<i.length;s++)yield JSON.parse(i[s])}n+=t.decode(),n!==""&&(yield JSON.parse(n))}var Pc=yt(Ed(),1);var Bo=class extends Error{constructor(e){super(e),this.name="TimeoutError"}},Oc=class extends Error{constructor(e){super(),this.name="AbortError",this.message=e}},vd=r=>globalThis.DOMException===void 0?new Oc(r):new DOMException(r),Bd=r=>{let e=r.reason===void 0?vd("This operation was aborted."):r.reason;return e instanceof Error?e:vd(e)};function Ao(r,e){let{milliseconds:t,fallback:n,message:o,customTimers:i={setTimeout,clearTimeout}}=e,s,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:p}=e;p.aborted&&u(Bd(p)),p.addEventListener("abort",()=>{u(Bd(p))})}if(t===Number.POSITIVE_INFINITY){r.then(f,u);return}let l=new Bo;s=i.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(p){u(p)}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(p){u(p)}})()}).finally(()=>{c.clear()});return c.clear=()=>{i.clearTimeout.call(void 0,s),s=void 0},c}function Vc(r,e,t){let n=0,o=r.length;for(;o>0;){let i=Math.trunc(o/2),s=n+i;t(r[s],e)<=0?(n=++s,o-=i+1):o=i}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=Vc(this.#e,n,(i,s)=>s.priority-i.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 mr=class extends Pc.default{#e;#t;#r=0;#s;#c;#p=0;#o;#u;#n;#m;#i=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.#s=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.#s}get#x(){return this.#i<this.#l}#E(){this.#i--,this.#f(),this.emit("next")}#v(){this.#w(),this.#g(),this.#u=void 0}get#B(){let e=Date.now();if(this.#o===void 0){let t=this.#p-e;if(t<0)this.#r=this.#e?this.#i: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.#i===0&&this.emit("idle"),!1;if(!this.#a){let e=!this.#B;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.#i===0&&this.#o&&(clearInterval(this.#o),this.#o=void 0),this.#r=this.#e?this.#i: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#A(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.#i++,this.#r++;try{t.signal?.throwIfAborted();let i=e({signal:t.signal});t.timeout&&(i=Ao(Promise.resolve(i),{milliseconds:t.timeout})),t.signal&&(i=Promise.race([i,this.#A(t.signal)]));let s=await i;n(s),this.emit("completed",s)}catch(i){if(i instanceof Bo&&!t.throwOnTimeout){n();return}o(i),this.emit("error",i)}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.#i===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.#i}get isPaused(){return this.#a}};function mw(r){return r[Symbol.asyncIterator]!=null}function yw(r){if(mw(r))return(async()=>{for await(let e of r)return e})();for(let e of r)return e}var bs=yw;var Fc=G("/ipns/");function Ad(r){return oe(r.subarray(0,Fc.byteLength),Fc)}var kd=r=>Wn(r.slice(Fc.length)),xs=class{client;constructor(e){this.client=e}async*findProviders(e,t={}){yield*Gn(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async put(e,t,n){if(!Ad(e))return;let o=kd(e),i=kt(t);await this.client.putIPNS(o,i,n)}async get(e,t){if(!Ad(e))throw new C("Not found","ERR_NOT_FOUND");let n=kd(e);try{let o=await this.client.getIPNS(n,t);return Vr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new C("Not found","ERR_NOT_FOUND"):o}}},Es=class{client;constructor(e){this.client=e}async findPeer(e,t={}){let n=await bs(this.client.getPeers(e,t));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new C("Not found","ERR_NOT_FOUND")}async*getClosestPeers(e,t={}){}};var Me=Ke("delegated-routing-v1-http-api-client"),Sd={concurrentRequests:4,timeout:3e4},vs=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;constructor(e,t={}){this.started=!1,this.shutDownController=new AbortController,Uo(1/0,this.shutDownController.signal),this.httpQueue=new mr({concurrency:t.concurrentRequests??Sd.concurrentRequests}),this.clientUrl=e instanceof URL?e:new URL(e),this.timeout=t.timeout??Sd.timeout,this.contentRouting=new xs(this),this.peerRouting=new Es(this)}get[Hn](){return this.contentRouting}get[$n](){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={}){Me("getProviders starts: %c",e);let n=xr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=Ue(),i=Ue();this.httpQueue.add(async()=>(o.resolve(),i.promise));try{await o.promise;let s=`${this.clientUrl}routing/v1/providers/${e.toString()}`,c=await fetch(s,{headers:{Accept:"application/x-ndjson"},signal:n});if(c.status===404)throw new C("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new C("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new C("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 p=this.#e(l);p!=null&&(yield p)}}else for await(let u of Eo(Zo(c.body))){let l=this.#e(u);l!=null&&(yield l)}}catch(s){Me.error("getProviders errored:",s)}finally{n.clear(),i.resolve(),Me("getProviders finished: %c",e)}}async*getPeers(e,t={}){Me("getPeers starts: %c",e);let n=xr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=Ue(),i=Ue();this.httpQueue.add(async()=>(o.resolve(),i.promise));try{await o.promise;let s=`${this.clientUrl}routing/v1/peers/${e.toCID().toString()}`,c=await fetch(s,{headers:{Accept:"application/x-ndjson"},signal:n});if(c.status===404)throw new C("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new C("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new C("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 p=this.#e(l);p!=null&&(yield p)}}else for await(let u of Eo(Zo(c.body))){let l=this.#e(u);l!=null&&(yield l)}}catch(s){Me.error("getPeers errored:",s)}finally{n.clear(),i.resolve(),Me("getPeers finished: %c",e)}}async getIPNS(e,t={}){Me("getIPNS starts: %c",e);let n=xr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=Ue(),i=Ue();this.httpQueue.add(async()=>(o.resolve(),i.promise));let s=`${this.clientUrl}routing/v1/ipns/${e.toCID().toString()}`;try{await o.promise;let c=await fetch(s,{headers:{Accept:"application/vnd.ipfs.ipns-record"},signal:n});if(Me("getIPNS GET %s %d",s,c.status),c.status===404)throw new C("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new C("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new C("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 bd(Uc(e),u),kt(u)}catch(a){throw Me.error("getIPNS GET %s error:",s,a),a}finally{n.clear(),i.resolve(),Me("getIPNS finished: %c",e)}}async putIPNS(e,t,n={}){Me("putIPNS starts: %c",e);let o=xr([this.shutDownController.signal,n.signal,AbortSignal.timeout(this.timeout)]),i=Ue(),s=Ue();this.httpQueue.add(async()=>(i.resolve(),s.promise));let a=`${this.clientUrl}routing/v1/ipns/${e.toCID().toString()}`;try{await i.promise;let c=Vr(t),u=await fetch(a,{method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:c,signal:o});if(Me("putIPNS PUT %s %d",a,u.status),u.status!==200)throw new C("PUT ipns response had status other than 200","ERR_BAD_RESPONSE")}catch(c){throw Me.error("putIPNS PUT %s error:",a,c.stack),c}finally{o.clear(),s.resolve(),Me("putIPNS finished: %c",e)}}#e(e){let t=[],n=e.Addrs?.map($a)??[];return e.Protocols!=null&&t.push(...e.Protocols),e.Protocol!=null&&(t.push(e.Protocol),delete e.Protocol),{...e,Schema:"peer",ID:_r(e.ID),Addrs:n,Protocols:t}}};function Id(r,e={}){return new vs(new URL(r),e)}var Rd=G("/ipns/");function _d(r){return oe(r.subarray(0,Rd.byteLength),Rd)}var Mc=class{client;constructor(e){this.client=Id(e)}async provide(e,t){}async*findProviders(e,t){yield*Gn(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs,protocols:n.Protocols}))}async put(e,t,n){if(!_d(e))return;let o=Cn(e),i=kt(t);await this.client.putIPNS(o,i,n)}async get(e,t){if(!_d(e))throw new C("Not found","ERR_NOT_FOUND");let n=Cn(e);try{let o=await this.client.getIPNS(n,t);return Vr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new C("Not found","ERR_NOT_FOUND"):o}}async findPeer(e,t){let n=await bs(this.client.getPeers(e,t));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new C("Not found","ERR_NOT_FOUND")}async*getClosestPeers(e,t){}};function Hc(r){return new Mc(new URL(r))}var $c=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 Bs(r,e,t,n){let o=new $c(n?.errorMessage,n?.errorCode);return t?.aborted===!0?Promise.reject(o):new Promise((i,s)=>{let a=f=>{n?.filter?.(f)!==!1&&(r.removeEventListener(e,a),t?.removeEventListener("abort",c),i(f))},c=()=>{r.removeEventListener(e,a),t?.removeEventListener("abort",c),s(o)};r.addEventListener(e,a),t?.addEventListener("abort",c)})}var As=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 Td(r,e,t){if(e==null)return r;if(e.aborted)return Promise.reject(new As(t?.errorMessage,t?.errorCode));let n,o=new As(t?.errorMessage,t?.errorCode);try{return await Promise.race([r,new Promise((i,s)=>{n=()=>{s(o)},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var ks=class{deferred;signal;where;constructor(e,t){this.signal=t,this.deferred=Ue(),this.where=e,this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(new Yt)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function gw(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var Ss=class{id;fn;options;priority;recipients;status;timeline;controller;constructor(e,t,n=0){this.id=gw(),this.status="queued",this.fn=e,this.priority=n,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,Uo(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 Yt)}async join(e={}){let t=new ks(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 Td(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 ww(r,e,t){let n=0,o=r.length;for(;o>0;){let i=Math.trunc(o/2),s=n+i;t(r[s],e)<=0?(n=++s,o-=i+1):o=i}return n}var So=class extends Lo{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=ww(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 Ss(e,t,t?.priority),o=n.join(t).then(i=>(this.safeDispatchEvent("completed",{detail:i}),i)).catch(i=>{throw this.safeDispatchEvent("error",{detail:i}),i});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 Yt)}),this.clear()}async onEmpty(e){this.size!==0&&await Bs(this,"empty",e?.signal)}async onSizeLessThan(e,t){this.size<e||await Bs(this,"next",t?.signal,{filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await Bs(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=Ir({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),t.end(c)},o=c=>{c.detail!=null&&t.push(c.detail)},i=c=>{n(c.detail)},s=()=>{n()},a=()=>{n(new C("Queue aborted","ERR_QUEUE_ABORTED"))};this.addEventListener("completed",o),this.addEventListener("error",i),this.addEventListener("idle",s),e?.signal?.addEventListener("abort",a);try{yield*t}finally{this.removeEventListener("completed",o),this.removeEventListener("error",i),this.removeEventListener("idle",s),e?.signal?.removeEventListener("abort",a),n()}}};var Ud="/pin/",Nd="/pinned-block/",Kc=er,Cd=1;function Ld(r){return r.version===0&&(r=r.toV1()),new Se(`${Ud}${r.toString(Kc)}`)}var Is=class{datastore;blockstore;dagWalkers;constructor(e,t,n){this.datastore=e,this.blockstore=t,this.dagWalkers=n}async*add(e,t={}){let n=Ld(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 i=new So({concurrency:Cd});for await(let a of this.#e(e,i,{...t,depth:o}))await this.#t(a,c=>c.pinnedBy.find(f=>oe(f,e.bytes))!=null?!1:(c.pinCount++,c.pinnedBy.push(e.bytes),!0),t),yield a;let s={depth:o,metadata:t.metadata??{}};await this.datastore.put(n,Nn(s),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 i=await this.blockstore.get(e,n);yield e;for await(let s of o.walk(i))yield*await t.add(async()=>this.#e(s,t,{...n,depth:n.depth-1}))}async#t(e,t,n){let o=new Se(`${Nd}${Kc.encode(e.multihash.bytes)}`),i={pinCount:0,pinnedBy:[]};try{i=nt(await this.datastore.get(o,n))}catch(a){if(a.code!=="ERR_NOT_FOUND")throw a}if(t(i)){if(i.pinCount===0&&await this.datastore.has(o)){await this.datastore.delete(o);return}await this.datastore.put(o,Nn(i),n),n.onProgress?.(new se("helia:pin:add",e))}}async*rm(e,t={}){let n=Ld(e),o=await this.datastore.get(n,t),i=nt(o);await this.datastore.delete(n,t);let s=new So({concurrency:Cd});for await(let a of this.#e(e,s,{...t,depth:i.depth}))await this.#t(a,c=>(c.pinCount--,c.pinnedBy=c.pinnedBy.filter(f=>oe(f,e.bytes)),!0),{...t,depth:i.depth}),yield a}async*ls(e={}){for await(let{key:t,value:n}of this.datastore.query({prefix:Ud+(e.cid!=null?`${e.cid.toString(er)}`:"")},e)){let o=ee.parse(t.toString().substring(5),er),i=nt(n);yield{cid:o,...i}}}async isPinned(e,t={}){let n=new Se(`${Nd}${Kc.encode(e.multihash.bytes)}`);return this.datastore.has(n,t)}};function qc(r,e){let t={[Symbol.iterator]:()=>t,next:()=>{let n=r.next(),o=n.value;return n.done===!0||o==null?{done:!0,value:void 0}:{done:!1,value:e(o)}}};return t}var Ln=class r{set;constructor(e){if(this.set=new Set,e!=null)for(let t of e)this.set.add(t.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(e){this.set.add(e.toString())}clear(){this.set.clear()}delete(e){this.set.delete(e.toString())}entries(){return qc(this.set.entries(),e=>{let t=_r(e[0]);return[t,t]})}forEach(e){this.set.forEach(t=>{let n=_r(t);e(n,n,this)})}has(e){return this.set.has(e.toString())}values(){return qc(this.set.values(),e=>_r(e))}intersection(e){let t=new r;for(let n of e)this.has(n)&&t.add(n);return t}difference(e){let t=new r;for(let n of this)e.has(n)||t.add(n);return t}union(e){let t=new r;for(let n of e)t.add(n);for(let n of this)t.add(n);return t}};var Rs=class{log;routers;constructor(e,t){this.log=e.logger.forComponent("helia:routing"),this.routers=t.routers??[]}async start(){await Zt(...this.routers)}async stop(){await Jt(...this.routers)}async*findProviders(e,t={}){if(this.routers.length===0)throw new C("No content routers available","ERR_NO_ROUTERS_AVAILABLE");let n=new Ln;for await(let o of Rr(...Un(this.routers,"findProviders").map(i=>i.findProviders(e,t))))o!=null&&(n.has(o.id)||(n.add(o.id),yield o))}async provide(e,t={}){if(this.routers.length===0)throw new C("No content routers available","ERR_NO_ROUTERS_AVAILABLE");await Promise.all(Un(this.routers,"provide").map(async n=>{await n.provide(e,t)}))}async put(e,t,n){await Promise.all(Un(this.routers,"put").map(async o=>{await o.put(e,t,n)}))}async get(e,t){return Promise.any(Un(this.routers,"get").map(async n=>n.get(e,t)))}async findPeer(e,t){if(this.routers.length===0)throw new C("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");let n=this,o=Rr(...Un(this.routers,"findPeer").map(i=>async function*(){try{yield await i.findPeer(e,t)}catch(s){n.log.error(s)}}()));for await(let i of o)if(i!=null)return i;throw new C("Could not find peer in routing","ERR_NOT_FOUND")}async*getClosestPeers(e,t={}){if(this.routers.length===0)throw new C("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");let n=new Ln;for await(let o of Rr(...Un(this.routers,"getClosestPeers").map(i=>i.getClosestPeers(e,t))))o!=null&&(n.has(o.id)||(n.add(o.id),yield o))}};function Un(r,e){return r.filter(t=>t[e]!=null)}var yr={},Dn=r=>{r.addEventListener("message",e=>{Dn.dispatchEvent("message",r,e)}),r.port!=null&&r.port.addEventListener("message",e=>{Dn.dispatchEvent("message",r,e)})};Dn.addEventListener=(r,e)=>{yr[r]==null&&(yr[r]=[]),yr[r].push(e)};Dn.removeEventListener=(r,e)=>{yr[r]!=null&&(yr[r]=yr[r].filter(t=>t===e))};Dn.dispatchEvent=function(r,e,t){yr[r]!=null&&yr[r].forEach(n=>n(e,t))};var zc=Dn;var Gc="lock:worker:request-read",jc="lock:worker:release-read",Wc="lock:master:grant-read",Yc="lock:worker:request-write",Zc="lock:worker:release-write",Jc="lock:master:grant-write";var Dd=(r=21)=>Math.random().toString().substring(2);var Pd=(r,e,t,n,o)=>(i,s)=>{if(s.data.type!==t)return;let a={type:s.data.type,name:s.data.name,identifier:s.data.identifier};r.dispatchEvent(new MessageEvent(e,{data:{name:a.name,handler:async()=>{i.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&&(i.removeEventListener("message",f),c())};i.addEventListener("message",f)})}}}))},Od=(r,e,t,n)=>async()=>{let o=Dd();return globalThis.postMessage({type:e,identifier:o,name:r}),new Promise(i=>{let s=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",s),i(()=>{globalThis.postMessage({type:n,identifier:o,name:r})}))};globalThis.addEventListener("message",s)})},bw={singleProcess:!1},Vd=r=>{if(r=Object.assign({},bw,r),!!globalThis.document||r.singleProcess){let t=new EventTarget;return zc.addEventListener("message",Pd(t,"requestReadLock",Gc,jc,Wc)),zc.addEventListener("message",Pd(t,"requestWriteLock",Yc,Zc,Jc)),t}return{isWorker:!0,readLock:t=>Od(t,Gc,Wc,jc),writeLock:t=>Od(t,Yc,Jc,Zc)}};var Fr={},gr;async function Xc(r,e){let t,n=new Promise(o=>{t=o});return r.add(async()=>Ao((async()=>{await new Promise(o=>{t(()=>{o()})})})(),{milliseconds:e.timeout})),n}var xw=(r,e)=>{if(gr.isWorker===!0)return{readLock:gr.readLock(r,e),writeLock:gr.writeLock(r,e)};let t=new mr({concurrency:1}),n;return{async readLock(){if(n!=null)return Xc(n,e);n=new mr({concurrency:e.concurrency,autoStart:!1});let o=n,i=Xc(n,e);return t.add(async()=>{o.start(),await o.onIdle().then(()=>{n===o&&(n=null)})}),i},async writeLock(){return n=null,Xc(t,e)}}},Ew={name:"lock",concurrency:1/0,timeout:846e5,singleProcess:!1};function Qc(r){let e=Object.assign({},Ew,r);return gr==null&&(gr=Vd(e),gr.isWorker!==!0&&(gr.addEventListener("requestReadLock",t=>{Fr[t.data.name]!=null&&Fr[t.data.name].readLock().then(async n=>t.data.handler().finally(()=>{n()}))}),gr.addEventListener("requestWriteLock",async t=>{Fr[t.data.name]!=null&&Fr[t.data.name].writeLock().then(async n=>t.data.handler().finally(()=>{n()}))}))),Fr[e.name]==null&&(Fr[e.name]=xw(e.name,e)),Fr[e.name]}var _s=class{lock;child;pins;started;constructor(e,t,n={}){this.child=e,this.pins=t,this.lock=Qc({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await Zt(this.child),this.started=!0}async stop(){await Jt(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 i of e){if(await o.pins.isPinned(i))throw new Error("CID was pinned");yield i}}(),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()}}};var Md=42;function vw(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let e=ee.asCID(r);if(!e)return null;let t=new Uint8Array(e.bytes.byteLength+1);return t.set(e.bytes,1),[new B(h.tag,Md),new B(h.bytes,t)]}function Bw(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function Aw(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 Fd={float64:!0,typeEncoders:{Object:vw,undefined:Bw,number:Aw}},Ok={...Fd,typeEncoders:{...Fd.typeEncoders}};function kw(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return ee.decode(r.subarray(1))}var eu={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};eu.tags[Md]=kw;var Vk={...eu,tags:eu.tags.slice()};var Hd=113;var $d=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(e){let t=this.inRecursive[this.inRecursive.length-1];t&&(t.type===h.array&&(t.elements++,t.elements!==1&&e.push([44])),t.type===h.map&&(t.elements++,t.elements!==1&&(t.elements%2===1?e.push([44]):e.push([58]))))}[h.uint.major](e,t){this.prefix(e);let n=String(t.value),o=[];for(let i=0;i<n.length;i++)o[i]=n.charCodeAt(i);e.push(o)}[h.negint.major](e,t){this[h.uint.major](e,t)}[h.bytes.major](e,t){throw new Error(`${In} unsupported type: Uint8Array`)}[h.string.major](e,t){this.prefix(e);let n=is(JSON.stringify(t.value));e.push(n.length>32?ho(n):n)}[h.array.major](e,t){this.prefix(e),this.inRecursive.push({type:h.array,elements:0}),e.push([91])}[h.map.major](e,t){this.prefix(e),this.inRecursive.push({type:h.map,elements:0}),e.push([123])}[h.tag.major](e,t){}[h.float.major](e,t){if(t.type.name==="break"){let s=this.inRecursive.pop();if(s){if(s.type===h.array)e.push([93]);else if(s.type===h.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(`${In} 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=[],i=!1;for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s),!i&&(o[s]===46||o[s]===101||o[s]===69)&&(i=!0);i||(o.push(46),o.push(48)),e.push(o)}};var Mr=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t,this.modeStack=["value"],this.lastToken=""}pos(){return this._pos}done(){return this._pos>=this.data.length}ch(){return this.data[this._pos]}currentMode(){return this.modeStack[this.modeStack.length-1]}skipWhitespace(){let e=this.ch();for(;e===32||e===9||e===13||e===10;)e=this.data[++this._pos]}expect(e){if(this.data.length-this._pos<e.length)throw new Error(`${V} unexpected end of input at position ${this._pos}`);for(let t=0;t<e.length;t++)if(this.data[this._pos++]!==e[t])throw new Error(`${V} unexpected token at position ${this._pos}, expected to find '${String.fromCharCode(...e)}'`)}parseNumber(){let e=this._pos,t=!1,n=!1,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 B(h.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(`${V} unexpected token at position ${this._pos}`);if(!this.done()&&this.ch()===46){if(n)throw new Error(`${V} unexpected token at position ${this._pos}`);n=!0,this._pos++,o([48,49,50,51,52,53,54,55,56,57])}!this.done()&&(this.ch()===101||this.ch()===69)&&(n=!0,this._pos++,!this.done()&&(this.ch()===43||this.ch()===45)&&this._pos++,o([48,49,50,51,52,53,54,55,56,57]));let i=String.fromCharCode.apply(null,this.data.subarray(e,this._pos)),s=parseFloat(i);return n?new B(h.float,s,this._pos-e):this.options.allowBigInt!==!0||Number.isSafeInteger(s)?new B(s>=0?h.uint:h.negint,s,this._pos-e):new B(s>=0?h.uint:h.negint,BigInt(i),this._pos-e)}parseString(){if(this.ch()!==34)throw new Error(`${V} unexpected character at position ${this._pos}; this shouldn't happen`);this._pos++;for(let i=this._pos,s=0;i<this.data.length&&s<65536;i++,s++){let a=this.data[i];if(a===92||a<32||a>=128)break;if(a===34){let c=String.fromCharCode.apply(null,this.data.subarray(this._pos,i));return this._pos=i+1,new B(h.string,c,s)}}let e=this._pos,t=[],n=()=>{if(this._pos+4>=this.data.length)throw new Error(`${V} unexpected end of unicode escape sequence at position ${this._pos}`);let i=0;for(let s=0;s<4;s++){let a=this.ch();if(a>=48&&a<=57)a-=48;else if(a>=97&&a<=102)a=a-97+10;else if(a>=65&&a<=70)a=a-65+10;else throw new Error(`${V} unexpected unicode escape character at position ${this._pos}`);i=i*16+a,this._pos++}return i},o=()=>{let i=this.ch(),s=null,a=i>239?4:i>223?3:i>191?2:1;if(this._pos+a>this.data.length)throw new Error(`${V} unexpected unicode sequence at position ${this._pos}`);let c,f,u,l;switch(a){case 1:i<128&&(s=i);break;case 2:c=this.data[this._pos+1],(c&192)===128&&(l=(i&31)<<6|c&63,l>127&&(s=l));break;case 3:c=this.data[this._pos+1],f=this.data[this._pos+2],(c&192)===128&&(f&192)===128&&(l=(i&15)<<12|(c&63)<<6|f&63,l>2047&&(l<55296||l>57343)&&(s=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=(i&15)<<18|(c&63)<<12|(f&63)<<6|u&63,l>65535&&l<1114112&&(s=l))}s===null?(s=65533,a=1):s>65535&&(s-=65536,t.push(s>>>10&1023|55296),s=56320|s&1023),t.push(s),this._pos+=a};for(;!this.done();){let i=this.ch(),s;switch(i){case 92:if(this._pos++,this.done())throw new Error(`${V} unexpected string termination at position ${this._pos}`);switch(s=this.ch(),this._pos++,s){case 34:case 39:case 92:case 47:t.push(s);break;case 98:t.push(8);break;case 116:t.push(9);break;case 110:t.push(10);break;case 102:t.push(12);break;case 114:t.push(13);break;case 117:t.push(n());break;default:throw new Error(`${V} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new B(h.string,Sc(t),this._pos-e);default:if(i<32)throw new Error(`${V} invalid control character at position ${this._pos}`);i<128?(t.push(i),this._pos++):o()}}throw new Error(`${V} unexpected end of string at position ${this._pos}`)}parseValue(){switch(this.ch()){case 123:return this.modeStack.push("obj-start"),this._pos++,new B(h.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new B(h.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new B(h.null,null,4);case 102:return this.expect([102,97,108,115,101]),new B(h.false,!1,5);case 116:return this.expect([116,114,117,101]),new B(h.true,!0,4);case 45:case 48:case 49:case 50:case 51:case 52:case 53:case 54:case 55:case 56:case 57:return this.parseNumber();default:throw new Error(`${V} unexpected character at position ${this._pos}`)}}next(){switch(this.skipWhitespace(),this.currentMode()){case"value":return this.modeStack.pop(),this.parseValue();case"array-value":{if(this.modeStack.pop(),this.ch()===93)return this._pos++,this.skipWhitespace(),new B(h.break,void 0,1);if(this.ch()!==44)throw new Error(`${V} unexpected character at position ${this._pos}, was expecting array delimiter but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue()}case"array-start":return this.modeStack.pop(),this.ch()===93?(this._pos++,this.skipWhitespace(),new B(h.break,void 0,1)):(this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue());case"obj-key":if(this.ch()===125)return this.modeStack.pop(),this._pos++,this.skipWhitespace(),new B(h.break,void 0,1);if(this.ch()!==44)throw new Error(`${V} unexpected character at position ${this._pos}, was expecting object delimiter but found '${String.fromCharCode(this.ch())}'`);this._pos++,this.skipWhitespace();case"obj-start":{if(this.modeStack.pop(),this.ch()===125)return this._pos++,this.skipWhitespace(),new B(h.break,void 0,1);let e=this.parseString();if(this.skipWhitespace(),this.ch()!==58)throw new Error(`${V} unexpected character at position ${this._pos}, was expecting key/value delimiter ':' but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("obj-value"),e}case"obj-value":return this.modeStack.pop(),this.modeStack.push("obj-key"),this.skipWhitespace(),this.parseValue();default:throw new Error(`${V} unexpected parse state at position ${this._pos}; this shouldn't happen`)}}};function Ts(r,e){return e=Object.assign({tokenizer:new Mr(r,e)},e),nt(r,e)}var Rw={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Rw.tags[42]=ee.parse;var qd=297;var tS=new TextDecoder;var rS=new TextEncoder;var Tw=new TextDecoder;function tu(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 Ns(r,e){let t;[t,e]=tu(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 zd(r,e){let t;return[t,e]=tu(r,e),[t&7,t>>3,e]}function Nw(r){let e={},t=r.length,n=0;for(;n<t;){let o,i;if([o,i,n]=zd(r,n),i===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]=Ns(r,n)}else if(i===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 s;[s,n]=Ns(r,n),e.Name=Tw.decode(s)}else if(i===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]=tu(r,n)}else throw new Error(`protobuf: (PBLink) invalid fieldNumber, expected 1, 2 or 3, got ${i}`)}if(n>t)throw new Error("protobuf: (PBLink) unexpected end of data");return e}function Gd(r){let e=r.length,t=0,n,o=!1,i;for(;t<e;){let a,c;if([a,c,t]=zd(r,t),a!==2)throw new Error(`protobuf: (PBNode) invalid wireType, expected 2, got ${a}`);if(c===1){if(i)throw new Error("protobuf: (PBNode) duplicate Data section");[i,t]=Ns(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]=Ns(r,t),n.push(Nw(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 s={};return i&&(s.Data=i),s.Links=n||[],s}var oS=new TextEncoder,iS=2**32,sS=2**31;var uS=new TextEncoder;var jd=112;function Wd(r){let e=Gd(r),t={};return e.Data&&(t.Data=e.Data),e.Links&&(t.Links=e.Links.map(n=>{let o={};try{o.Hash=ee.decode(n.Hash)}catch{}if(!o.Hash)throw new Error("Invalid Hash field found in link, expected CID");return n.Name!==void 0&&(o.Name=n.Name),n.Tsize!==void 0&&(o.Tsize=n.Tsize),o})),t}var Lw={codec:jd,*walk(r){yield*Wd(r).Links.map(t=>t.Hash)}},Uw={codec:Vo,*walk(){}},Yd=42,Dw={codec:Hd,*walk(r){let e=[],t=[];t[Yd]=n=>{if(n[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");let o=ee.decode(n.subarray(1));return e.push(o),o},nt(r,{tags:t}),yield*e}},ru=class extends Mr{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===h.map){let t=this._next();if(t.type===h.string&&t.value==="/"){let n=this._next();if(n.type===h.string){if(this._next().type!==h.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new B(h.tag,42,0)}if(n.type===h.map){let o=this._next();if(o.type===h.string&&o.value==="bytes"){let i=this._next();if(i.type===h.string){for(let a=0;a<2;a++)if(this._next().type!==h.break)throw new Error("Invalid encoded Bytes form");let s=Xt.decode(`m${i.value}`);return new B(h.bytes,s,i.value.length)}this.tokenBuffer.push(i)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(t)}return e}},Pw={codec:qd,*walk(r){let e=[],t=[];t[Yd]=n=>{let o=ee.parse(n);return e.push(o),o},Ts(r,{tags:t,tokenizer:new ru(r,{tags:t,allowIndefinite:!0,allowUndefined:!0,allowNaN:!0,allowInfinity:!0,allowBigInt:!0,strict:!1,rejectDuplicateMapKeys:!1})}),yield*e}},Ow={codec:Yu,*walk(){}};function Zd(r=[]){let e={};return[Lw,Uw,Dw,Pw,Ow,...r].forEach(t=>{e[t.codec]=t}),e}var nu=new Se("/version"),Jd=1;async function Xd(r){if(!await r.has(nu)){await r.put(nu,G(`${Jd}`));return}let e=await r.get(nu),t=j(e);if(parseInt(t,10)!==Jd)throw new Error("Unknown datastore version, a datastore migration may be required")}function Qd(r=[]){let e={};return[we,Zs,Je,...r].forEach(t=>{e[t.code]=t}),e}function Vw(r){return r[Symbol.asyncIterator]!=null}function Fw(r,e){if(Vw(r))return async function*(){for await(let a of r)await e(a)&&(yield a)}();let t=$r(r),{value:n,done:o}=t.next();if(o===!0)return function*(){}();let i=e(n);if(typeof i.then=="function")return async function*(){await i&&(yield n);for await(let a of t)await e(a)&&(yield a)}();let s=e;return function*(){i===!0&&(yield n);for(let a of t)s(a)&&(yield a)}()}var mt=Fw;function Mw(r){return typeof r.retrieve=="function"}function Hw(r){return typeof r.announce=="function"}var Cs=class{child;blockRetrievers;blockAnnouncers;hashers;started;log;constructor(e){this.log=e.logger.forComponent("helia:networked-storage"),this.child=e.blockstore,this.blockRetrievers=(e.blockBrokers??[]).filter(Mw),this.blockAnnouncers=(e.blockBrokers??[]).filter(Hw),this.hashers=e.hashers??{},this.started=!1}isStarted(){return this.started}async start(){await Zt(this.child,...new Set([...this.blockRetrievers,...this.blockAnnouncers])),this.started=!0}async stop(){await Jt(this.child,...new Set([...this.blockRetrievers,...this.blockAnnouncers])),this.started=!1}unwrap(){return this.child}async put(e,t,n={}){return await this.child.has(e)?(n.onProgress?.(new se("blocks:put:duplicate",e)),e):(n.onProgress?.(new se("blocks:put:providers:notify",e)),this.blockAnnouncers.forEach(o=>{o.announce(e,t,n)}),n.onProgress?.(new se("blocks:put:blockstore:put",e)),this.child.put(e,t,n))}async*putMany(e,t={}){let n=mt(e,async({cid:i})=>{let s=await this.child.has(i);return s&&t.onProgress?.(new se("blocks:put-many:duplicate",i)),!s}),o=Os(n,({cid:i,block:s})=>{t.onProgress?.(new se("blocks:put-many:providers:notify",i)),this.blockAnnouncers.forEach(a=>{a.announce(i,s,t)})});t.onProgress?.(new se("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 se("blocks:get:providers:get",e));let n=await ep(e,this.blockRetrievers,this.hashers[e.multihash.code],{...t,log:this.log});return t.onProgress?.(new se("blocks:get:blockstore:put",e)),await this.child.put(e,n,t),t.onProgress?.(new se("blocks:get:providers:notify",e)),this.blockAnnouncers.forEach(o=>{o.announce(e,n,t)}),n}return t.onProgress?.(new se("blocks:get:blockstore:get",e)),this.child.get(e,t)}async*getMany(e,t={}){t.onProgress?.(new se("blocks:get-many:blockstore:get-many")),yield*this.child.getMany(Os(e,async n=>{if(t.offline!==!0&&!await this.child.has(n)){t.onProgress?.(new se("blocks:get-many:providers:get",n));let o=await ep(n,this.blockRetrievers,this.hashers[n.multihash.code],{...t,log:this.log});t.onProgress?.(new se("blocks:get-many:blockstore:put",n)),await this.child.put(n,o,t),t.onProgress?.(new se("blocks:get-many:providers:notify",n)),this.blockAnnouncers.forEach(i=>{i.announce(n,o,t)})}}))}async delete(e,t={}){t.onProgress?.(new se("blocks:delete:blockstore:delete",e)),await this.child.delete(e,t)}async*deleteMany(e,t={}){t.onProgress?.(new se("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 se("blocks:get-all:blockstore:get-many")),yield*this.child.getAll(e)}},$w=(r,e)=>{if(e==null)throw new C(`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(!oe(n.digest,r.multihash.digest))throw new C("Hash of downloaded block did not match multihash from passed CID","ERR_HASH_MISMATCH")}};async function ep(r,e,t,n){let o=$w(r,t),i=new AbortController,s=xr([i.signal,n.signal]);try{return await Promise.any(e.map(async a=>{try{let c=!1,f=await a.retrieve(r,{...n,signal:s,validateFn:async u=>{await o(u),c=!0}});return c||await o(f),f}catch(c){throw n.log.error("could not retrieve verified block for %c",r,c),c}}))}finally{s.clear()}}var Ls=class{blockstore;datastore;pins;logger;routing;dagWalkers;hashers;log;constructor(e){this.logger=e.logger??Vu(),this.log=this.logger.forComponent("helia"),this.hashers=Qd(e.hashers),this.dagWalkers=Zd(e.dagWalkers);let t={blockstore:e.blockstore,datastore:e.datastore,hashers:this.hashers,dagWalkers:this.dagWalkers,logger:this.logger,blockBrokers:[],...e.components??{}};t.blockBrokers=e.blockBrokers.map(o=>o(t));let n=new Cs(t);this.pins=new Is(e.datastore,n,this.dagWalkers),this.blockstore=new _s(n,this.pins,{holdGcLock:e.holdGcLock??!0}),this.datastore=e.datastore,this.routing=new Rs(t,{routers:(e.routers??[]).flatMap(o=>{let i=[o];return o[Hn]!=null&&i.push(o[Hn]),o[$n]!=null&&i.push(o[$n]),i})})}async start(){await Xd(this.datastore),await Zt(this.blockstore,this.datastore,this.routing)}async stop(){await Jt(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 Sr(o.deleteMany(async function*(){for await(let{cid:i}of o.getAll())try{if(await n.pins.isPinned(i,e))continue;yield i,e.onProgress?.(new se("helia:gc:deleted",i))}catch(s){n.log.error("Error during gc",s),e.onProgress?.(new se("helia:gc:error",s))}}()))}finally{t()}this.log("gc finished")}};var Pn={};ge(Pn,{abortedError:()=>jw,closeFailedError:()=>qw,deleteFailedError:()=>rp,getFailedError:()=>zw,hasFailedError:()=>Gw,notFoundError:()=>Io,openFailedError:()=>Kw,putFailedError:()=>tp});var Gt=yt(tn(),1);function Kw(r){return r=r??new Error("Open failed"),(0,Gt.default)(r,"ERR_OPEN_FAILED")}function qw(r){return r=r??new Error("Close failed"),(0,Gt.default)(r,"ERR_CLOSE_FAILED")}function tp(r){return r=r??new Error("Put failed"),(0,Gt.default)(r,"ERR_PUT_FAILED")}function zw(r){return r=r??new Error("Get failed"),(0,Gt.default)(r,"ERR_GET_FAILED")}function rp(r){return r=r??new Error("Delete failed"),(0,Gt.default)(r,"ERR_DELETE_FAILED")}function Gw(r){return r=r??new Error("Has failed"),(0,Gt.default)(r,"ERR_HAS_FAILED")}function Io(r){return r=r??new Error("Not Found"),(0,Gt.default)(r,"ERR_NOT_FOUND")}function jw(r){return r=r??new Error("Aborted"),(0,Gt.default)(r,"ERR_ABORTED")}var Hr=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)}}async delete(e,t){await 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 Ro=class extends Hr{data;constructor(){super(),this.data=new Map}put(e,t){return this.data.set(Ae.encode(e.multihash.bytes),t),e}get(e){let t=this.data.get(Ae.encode(e.multihash.bytes));if(t==null)throw Io();return t}has(e){return this.data.has(Ae.encode(e.multihash.bytes))}async delete(e){this.data.delete(Ae.encode(e.multihash.bytes))}async*getAll(){for(let[e,t]of this.data.entries())yield{cid:ee.createV1(Vo,wt(Ae.decode(e))),block:t}}};var fI=Ke("blockstore:core:tiered");var mI={...Pn};var np=yt(tn(),1);function Us(r){return r=r??new Error("Not Found"),(0,np.default)(r,"ERR_NOT_FOUND")}var op="SHARDING";function Yw(r){return r[Symbol.asyncIterator]!=null}function Zw(r){if(Yw(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 ou=Zw;function Jw(r){return r[Symbol.asyncIterator]!=null}function Xw(r,e){return Jw(r)?async function*(){yield*(await ou(r)).sort(e)}():function*(){yield*ou(r).sort(e)}()}var Ds=Xw;var jt=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 Sr(this.putMany(e,n)),e=[],await Sr(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=mt(n,i=>i.key.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,i)=>mt(o,i),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,i)=>Ds(o,i),n)),e.offset!=null){let o=0,i=e.offset;n=mt(n,()=>o++>=i)}return e.limit!=null&&(n=Ko(n,e.limit)),n}queryKeys(e,t){let n=this._allKeys(e,t);if(e.prefix!=null){let o=e.prefix;n=mt(n,i=>i.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,i)=>mt(o,i),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,i)=>Ds(o,i),n)),e.offset!=null){let o=e.offset,i=0;n=mt(n,()=>i++>=o)}return e.limit!=null&&(n=Ko(n,e.limit)),n}};var To=class extends jt{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 Us();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 Se(e),value:t}}*_allKeys(){for(let e of this.data.keys())yield new Se(e)}};var qI=new Se(op);var r6=Ke("datastore:core:tiered");async function tb(r={}){let e=r.datastore??new To,t=r.blockstore??new Ro,n=new Ls({...r,datastore:e,blockstore:t,blockBrokers:r.blockBrokers??[Ia()],routers:r.routers??[Hc("https://delegated-ipfs.dev")]});return r.start!==!1&&await n.start(),n}return bp(rb);})();
7
+ `)}`:`${t} :`}};bf=mr;U.Constructed=bf;mr.NAME="CONSTRUCTED";var ks=class extends Ce{fromBER(e,t,n){return t}toBER(e){return ft}};ks.override="EndOfContentValueBlock";var xf,Ss=class extends ke{constructor(e={}){super(e,ks),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};xf=Ss;U.EndOfContent=xf;Ss.NAME=ao;var Ef,yr=class extends ke{constructor(e={}){super(e,Ce),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}`}};Ef=yr;U.Null=Ef;yr.NAME="NULL";var Is=class extends qt(Ce){constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=Y.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=Y.BufferSourceConverter.toUint8Array(e);return Kt(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,yc.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Is.NAME="BooleanValueBlock";var vf,Rs=class extends ke{constructor(e={}){super(e,Is),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}`}};vf=Rs;U.Boolean=vf;Rs.NAME="BOOLEAN";var _s=class extends qt(xt){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=xt.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===ao){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==mf)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?xt.prototype.toBER.call(this,e,t):e?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};_s.NAME="OctetStringValueBlock";var Af,Ht=class r extends ke{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},_s),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=ni(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?mr.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${Y.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 Y.BufferSourceConverter.concat(e)}};Af=Ht;U.OctetString=Af;Ht.NAME=mf;var Ts=class extends qt(xt){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=xt.prototype.fromBER.call(this,e,t,n),o===-1)return o;for(let a of this.value){let c=a.constructor.NAME;if(c===ao){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==yf)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=Y.BufferSourceConverter.toUint8Array(e);if(!Kt(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=ni(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 xt.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return ft;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}}};Ts.NAME="BitStringValueBlock";var Bf,In=class extends ke{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},Ts),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 mr.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)}`}}};Bf=In;U.BitString=Bf;In.NAME=yf;var kf;function pg(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 p=u;p>=0;p--,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=ws(new Uint8Array([f%10]),s);break;default:s[i-l]=f%10}}return t[0]>0&&(s=ws(t,s)),s}function pf(r){if(r>=so.length)for(let e=so.length;e<=r;e++){let t=new Uint8Array([0]),n=so[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=ws(t,n)),so.push(n)}return so[r]}function mg(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 co=class extends qt(Ce){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=yc.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(ff(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=mg(pf(n),t),i="-";break;default:t=pg(t,pf(n))}n++,o>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(i+=df.charAt(t[c]));return a===!1&&(i+=df.charAt(0)),i}};kf=co;co.NAME="IntegerValueBlock";Object.defineProperty(kf.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Sf,me=class r extends ke{constructor(e={}){super(e,co),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return bs(),BigInt(this.valueBlock.toString())}static fromBigInt(e){bs();let t=BigInt(e),n=new io,o=t.toString(16).replace(/^-/,""),s=new Uint8Array(Y.Convert.FromHex(o));if(t<0){let a=new Uint8Array(s.length+(s[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${Y.Convert.ToHex(a)}`)+t,u=Y.BufferSourceConverter.toUint8Array(Y.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()}`}};Sf=me;U.Integer=Sf;me.NAME="INTEGER";var If,Cs=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};If=Cs;U.Enumerated=If;Cs.NAME="ENUMERATED";var uo=class extends qt(Ce){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=Y.BufferSourceConverter.toUint8Array(e);if(!Kt(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=Or(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){bs();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=pr(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",ft;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=Y.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}}};uo.NAME="sidBlock";var Ns=class extends Ce{constructor({value:e=Rn,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let s=new uo;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,ft;t.push(o)}return gc(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 uo;if(o>Number.MAX_SAFE_INTEGER){bs();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}};Ns.NAME="ObjectIdentifierValueBlock";var Rf,lt=class extends ke{constructor(e={}){super(e,Ns),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()}}};Rf=lt;U.ObjectIdentifier=Rf;lt.NAME="OBJECT IDENTIFIER";var lo=class extends qt(Mt){constructor({valueDec:e=0,...t}={}){super(t),this.valueDec=e}fromBER(e,t,n){if(n===0)return t;let o=Y.BufferSourceConverter.toUint8Array(e);if(!Kt(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=Or(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=pr(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",ft;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=Y.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};lo.NAME="relativeSidBlock";var Ls=class extends Ce{constructor({value:e=Rn,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let s=new lo;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,ft;n.push(s)}return gc(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 lo;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}};Ls.NAME="RelativeObjectIdentifierValueBlock";var _f,Ds=class extends ke{constructor(e={}){super(e,Ls),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()}}};_f=Ds;U.RelativeObjectIdentifier=_f;Ds.NAME="RelativeObjectIdentifier";var Tf,xe=class extends mr{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Tf=xe;U.Sequence=Tf;xe.NAME="SEQUENCE";var Cf,Us=class extends mr{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Cf=Us;U.Set=Cf;Us.NAME="SET";var Ps=class extends qt(Ce){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=Rn}toJSON(){return{...super.toJSON(),value:this.value}}};Ps.NAME="StringValueBlock";var Os=class extends Ps{};Os.NAME="SimpleStringValueBlock";var Pe=class extends vs{constructor({...e}={}){super(e,Os)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,Y.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}};Pe.NAME="SIMPLE STRING";var Vs=class extends Pe{fromBuffer(e){this.valueBlock.valueHexView=Y.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=Y.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=Y.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(Y.Convert.FromUtf8String(e)),this.valueBlock.value=e}};Vs.NAME="Utf8StringValueBlock";var Nf,$t=class extends Vs{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Nf=$t;U.Utf8String=Nf;$t.NAME="UTF8String";var Fs=class extends Pe{fromBuffer(e){this.valueBlock.value=Y.Convert.ToUtf16String(e),this.valueBlock.valueHexView=Y.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(Y.Convert.FromUtf16String(e))}};Fs.NAME="BmpStringValueBlock";var Lf,Ms=class extends Fs{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Lf=Ms;U.BmpString=Lf;Ms.NAME="BMPString";var Hs=class extends Pe{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=pr(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}};Hs.NAME="UniversalStringValueBlock";var Df,$s=class extends Hs{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Df=$s;U.UniversalString=Df;$s.NAME="UniversalString";var Uf,Ks=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Uf=Ks;U.NumericString=Uf;Ks.NAME="NumericString";var Pf,qs=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Pf=qs;U.PrintableString=Pf;qs.NAME="PrintableString";var Of,zs=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Of=zs;U.TeletexString=Of;zs.NAME="TeletexString";var Vf,Gs=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Vf=Gs;U.VideotexString=Vf;Gs.NAME="VideotexString";var Ff,js=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Ff=js;U.IA5String=Ff;js.NAME="IA5String";var Mf,Ws=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Mf=Ws;U.GraphicString=Mf;Ws.NAME="GraphicString";var Hf,fo=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Hf=fo;U.VisibleString=Hf;fo.NAME="VisibleString";var $f,Ys=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};$f=Ys;U.GeneralString=$f;Ys.NAME="GeneralString";var Kf,Zs=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Kf=Zs;U.CharacterString=Kf;Zs.NAME="CharacterString";var qf,ho=class extends fo{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,Y.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]=Fe(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=Fe(this.month,2),t[2]=Fe(this.day,2),t[3]=Fe(this.hour,2),t[4]=Fe(this.minute,2),t[5]=Fe(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}}};qf=ho;U.UTCTime=qf;ho.NAME="UTCTime";var zf,Js=class extends ho{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,p=n.indexOf("+"),E="";if(p===-1&&(p=n.indexOf("-"),l=-1),p!==-1){if(E=n.substring(p+1),n=n.substring(0,p),E.length!==2&&E.length!==4)throw new Error("Wrong input string for conversion");let y=parseInt(E.substring(0,2),10);if(isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*y,E.length===4){if(y=parseInt(E.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(Fe(this.year,4)),t.push(Fe(this.month,2)),t.push(Fe(this.day,2)),t.push(Fe(this.hour,2)),t.push(Fe(this.minute,2)),t.push(Fe(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(Fe(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};zf=Js;U.GeneralizedTime=zf;Js.NAME="GeneralizedTime";var Gf,Xs=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Gf=Xs;U.DATE=Gf;Xs.NAME="DATE";var jf,Qs=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};jf=Qs;U.TimeOfDay=jf;Qs.NAME="TimeOfDay";var Wf,ei=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Wf=ei;U.DateTime=Wf;ei.NAME="DateTime";var Yf,ti=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Yf=ti;U.Duration=Yf;ti.NAME="Duration";var Zf,ri=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Zf=ri;U.TIME=Zf;ri.NAME="TIME";function gg(r){let{result:e}=_n(r),t=e.valueBlock.value;return{n:z(Et(t[1].toBigInt()),"base64url"),e:z(Et(t[2].toBigInt()),"base64url"),d:z(Et(t[3].toBigInt()),"base64url"),p:z(Et(t[4].toBigInt()),"base64url"),q:z(Et(t[5].toBigInt()),"base64url"),dp:z(Et(t[6].toBigInt()),"base64url"),dq:z(Et(t[7].toBigInt()),"base64url"),qi:z(Et(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function wg(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 xe({value:[new me({value:0}),me.fromBigInt(vt(W(r.n,"base64url"))),me.fromBigInt(vt(W(r.e,"base64url"))),me.fromBigInt(vt(W(r.d,"base64url"))),me.fromBigInt(vt(W(r.p,"base64url"))),me.fromBigInt(vt(W(r.q,"base64url"))),me.fromBigInt(vt(W(r.dp,"base64url"))),me.fromBigInt(vt(W(r.dq,"base64url"))),me.fromBigInt(vt(W(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function bg(r){let{result:e}=_n(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:z(Et(t[0].toBigInt()),"base64url"),e:z(Et(t[1].toBigInt()),"base64url")}}function xg(r){if(r.n==null||r.e==null)throw new N("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new xe({value:[new xe({value:[new lt({value:"1.2.840.113549.1.1.1"}),new yr]}),new In({valueHex:new xe({value:[me.fromBigInt(vt(W(r.n,"base64url"))),me.fromBigInt(vt(W(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function Et(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 vt(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 Eg=16,bc=32,xc=1e4;async function vg(r,e){let t=Ue.get(),o=new xe({value:[new me({value:0}),new xe({value:[new lt({value:"1.2.840.113549.1.1.1"}),new yr]}),new Ht({valueHex:r.marshal()})]}).toBER(),s=new Uint8Array(o,0,o.byteLength),i=Pr(Eg),a=await pc(xn,e,i,{c:xc,dkLen:bc}),c=Pr(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 xe({value:[new Ht({valueHex:i}),new me({value:xc}),new me({value:bc}),new xe({value:[new lt({value:"1.2.840.113549.2.11"}),new yr]})]}),p=new xe({value:[new lt({value:"1.2.840.113549.1.5.13"}),new xe({value:[new xe({value:[new lt({value:"1.2.840.113549.1.5.12"}),l]}),new xe({value:[new lt({value:"2.16.840.1.101.3.4.1.42"}),new Ht({valueHex:c})]})]})]}),y=new xe({value:[p,new Ht({valueHex:u})]}).toBER(),d=new Uint8Array(y,0,y.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...z(d,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
8
+ `)}async function Ag(r,e){let t=Ue.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=W(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=_n(o),{iv:i,salt:a,iterations:c,keySize:f,cipherText:u}=Bg(s),l=await pc(xn,e,a,{c,dkLen:f}),p=await t.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),E=po(await t.subtle.decrypt({name:"AES-CBC",iv:i},p,u)),{result:y}=_n(E);n=Jf(y)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=W(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=_n(o);n=Jf(s)}else throw new N("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Ec(n)}function Bg(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=po(s.valueBlock.value[0].getValue()),a=xc,c=bc;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=po(f.valueBlock.value[1].getValue());return{cipherText:po(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:l}}function Jf(r){return po(r.valueBlock.value[2].getValue())}function po(r){return new Uint8Array(r,0,r.byteLength)}async function Xf(r){let e=await Ue.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 th(e);return{privateKey:t[0],publicKey:t[1]}}async function vc(r){let t=[await Ue.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await kg(r)],n=await th({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Qf(r,e){let t=await Ue.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ue.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function eh(r,e,t){let n=await Ue.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ue.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray())}async function th(r){if(r.privateKey==null||r.publicKey==null)throw new N("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Ue.get().subtle.exportKey("jwk",r.privateKey),Ue.get().subtle.exportKey("jwk",r.publicKey)])}async function kg(r){return Ue.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 oi(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 W(r.n,"base64url").length*8}var yo=8192,mo=class{_key;constructor(e){this._key=e}verify(e,t){return eh(this._key,t,e)}marshal(){return gr.jwkToPkix(this._key)}get bytes(){return bt.encode({Type:de.RSA,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(e)?e.then(({bytes:t})=>t):e.bytes}},Tn=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return Pr(16)}sign(e){return Qf(this._key,e)}get public(){if(this._publicKey==null)throw new N("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new mo(this._publicKey)}marshal(){return gr.jwkToPkcs1(this._key)}get bytes(){return Vt.encode({Type:de.RSA,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(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 gr.exportToPem(this,e);if(t==="libp2p-key")return Bn(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Ec(r){let e=gr.pkcs1ToJwk(r);if(oi(e)>yo)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await vc(e);return new Tn(t.privateKey,t.publicKey)}function Ig(r){let e=gr.pkixToJwk(r);if(oi(e)>yo)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new mo(e)}async function Rg(r){if(oi(r)>yo)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await vc(r);return new Tn(e.privateKey,e.publicKey)}async function _g(r){if(r>yo)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Xf(r);return new Tn(e.privateKey,e.publicKey)}var Rc={};ge(Rc,{Secp256k1PrivateKey:()=>wo,Secp256k1PublicKey:()=>go,generateKeyPair:()=>$g,unmarshalSecp256k1PrivateKey:()=>Mg,unmarshalSecp256k1PublicKey:()=>Hg});var Tg=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]),wr=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),br=new Uint32Array(64),Bc=class extends bn{constructor(){super(64,32,8,!1),this.A=wr[0]|0,this.B=wr[1]|0,this.C=wr[2]|0,this.D=wr[3]|0,this.E=wr[4]|0,this.F=wr[5]|0,this.G=wr[6]|0,this.H=wr[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)br[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let p=br[l-15],E=br[l-2],y=ct(p,7)^ct(p,18)^p>>>3,d=ct(E,17)^ct(E,19)^E>>>10;br[l]=d+br[l-7]+y+br[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 p=ct(a,6)^ct(a,11)^ct(a,25),E=u+p+Fl(a,c,f)+Tg[l]+br[l]|0,d=(ct(n,2)^ct(n,13)^ct(n,22))+Ml(n,o,s)|0;u=f,f=c,c=a,a=i+E|0,i=s,s=o,o=n,n=E+d|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,u=u+this.H|0,this.set(n,o,s,i,a,c,f,u)}roundClean(){br.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var rh=os(()=>new Bc);function Cg(r){let e=ro(r);wt(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:Ng,hexToBytes:Lg}=as,Vr={Err:class extends Error{constructor(e=""){super(e)}},_parseInt(r){let{Err:e}=Vr;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:Ng(n),l:r.subarray(t+2)}},toSig(r){let{Err:e}=Vr,t=typeof r=="string"?Lg(r):r;En(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}=Vr._parseInt(t.subarray(2)),{d:i,l:a}=Vr._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}`}},zt=BigInt(0),et=BigInt(1),iA=BigInt(2),nh=BigInt(3),aA=BigInt(4);function Dg(r){let e=Cg(r),{Fp:t}=e,n=e.toBytes||((y,d,m)=>{let g=d.toAffine();return Ut(Uint8Array.from([4]),t.toBytes(g.x),t.toBytes(g.y))}),o=e.fromBytes||(y=>{let d=y.subarray(1),m=t.fromBytes(d.subarray(0,t.BYTES)),g=t.fromBytes(d.subarray(t.BYTES,2*t.BYTES));return{x:m,y:g}});function s(y){let{a:d,b:m}=e,g=t.sqr(y),I=t.mul(g,y);return t.add(t.add(I,t.mul(y,d)),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"&&zt<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:d,nByteLength:m,wrapPrivateKey:g,n:I}=e;if(d&&typeof y!="bigint"){if(fr(y)&&(y=Lt(y)),typeof y!="string"||!d.includes(y.length))throw new Error("Invalid key");y=y.padStart(m*2,"0")}let v;try{v=typeof y=="bigint"?y:Dt(fe("private key",y,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof y}`)}return g&&(v=oe(v,I)),a(v),v}let f=new Map;function u(y){if(!(y instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(d,m,g){if(this.px=d,this.py=m,this.pz=g,d==null||!t.isValid(d))throw new Error("x required");if(m==null||!t.isValid(m))throw new Error("y required");if(g==null||!t.isValid(g))throw new Error("z required")}static fromAffine(d){let{x:m,y:g}=d||{};if(!d||!t.isValid(m)||!t.isValid(g))throw new Error("invalid affine point");if(d instanceof l)throw new Error("projective point not allowed");let I=v=>t.eql(v,t.ZERO);return I(m)&&I(g)?l.ZERO:new l(m,g,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let m=t.invertBatch(d.map(g=>g.pz));return d.map((g,I)=>g.toAffine(m[I])).map(l.fromAffine)}static fromHex(d){let m=l.fromAffine(o(fe("pointHex",d)));return m.assertValidity(),m}static fromPrivateKey(d){return l.BASE.multiply(c(d))}_setWindowSize(d){this._WINDOW_SIZE=d,f.delete(this)}assertValidity(){if(this.is0()){if(e.allowInfinityPoint&&!t.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:d,y:m}=this.toAffine();if(!t.isValid(d)||!t.isValid(m))throw new Error("bad point: x or y not FE");let g=t.sqr(m),I=s(d);if(!t.eql(g,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:d}=this.toAffine();if(t.isOdd)return!t.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){u(d);let{px:m,py:g,pz:I}=this,{px:v,py:D,pz:S}=d,_=t.eql(t.mul(m,S),t.mul(v,I)),L=t.eql(t.mul(g,S),t.mul(D,I));return _&&L}negate(){return new l(this.px,t.neg(this.py),this.pz)}double(){let{a:d,b:m}=e,g=t.mul(m,nh),{px:I,py:v,pz:D}=this,S=t.ZERO,_=t.ZERO,L=t.ZERO,w=t.mul(I,I),C=t.mul(v,v),O=t.mul(D,D),T=t.mul(I,v);return T=t.add(T,T),L=t.mul(I,D),L=t.add(L,L),S=t.mul(d,L),_=t.mul(g,O),_=t.add(S,_),S=t.sub(C,_),_=t.add(C,_),_=t.mul(S,_),S=t.mul(T,S),L=t.mul(g,L),O=t.mul(d,O),T=t.sub(w,O),T=t.mul(d,T),T=t.add(T,L),L=t.add(w,w),w=t.add(L,w),w=t.add(w,O),w=t.mul(w,T),_=t.add(_,w),O=t.mul(v,D),O=t.add(O,O),w=t.mul(O,T),S=t.sub(S,w),L=t.mul(O,C),L=t.add(L,L),L=t.add(L,L),new l(S,_,L)}add(d){u(d);let{px:m,py:g,pz:I}=this,{px:v,py:D,pz:S}=d,_=t.ZERO,L=t.ZERO,w=t.ZERO,C=e.a,O=t.mul(e.b,nh),T=t.mul(m,v),F=t.mul(g,D),$=t.mul(I,S),J=t.add(m,g),x=t.add(v,D);J=t.mul(J,x),x=t.add(T,F),J=t.sub(J,x),x=t.add(m,I);let k=t.add(v,S);return x=t.mul(x,k),k=t.add(T,$),x=t.sub(x,k),k=t.add(g,I),_=t.add(D,S),k=t.mul(k,_),_=t.add(F,$),k=t.sub(k,_),w=t.mul(C,x),_=t.mul(O,$),w=t.add(_,w),_=t.sub(F,w),w=t.add(F,w),L=t.mul(_,w),F=t.add(T,T),F=t.add(F,T),$=t.mul(C,$),x=t.mul(O,x),F=t.add(F,$),$=t.sub(T,$),$=t.mul(C,$),x=t.add(x,$),T=t.mul(F,x),L=t.add(L,T),T=t.mul(k,x),_=t.mul(J,_),_=t.sub(_,T),T=t.mul(J,F),w=t.mul(k,w),w=t.add(w,T),new l(_,L,w)}subtract(d){return this.add(d.negate())}is0(){return this.equals(l.ZERO)}wNAF(d){return E.wNAFCached(this,f,d,m=>{let g=t.invertBatch(m.map(I=>I.pz));return m.map((I,v)=>I.toAffine(g[v])).map(l.fromAffine)})}multiplyUnsafe(d){let m=l.ZERO;if(d===zt)return m;if(a(d),d===et)return this;let{endo:g}=e;if(!g)return E.unsafeLadder(this,d);let{k1neg:I,k1:v,k2neg:D,k2:S}=g.splitScalar(d),_=m,L=m,w=this;for(;v>zt||S>zt;)v&et&&(_=_.add(w)),S&et&&(L=L.add(w)),w=w.double(),v>>=et,S>>=et;return I&&(_=_.negate()),D&&(L=L.negate()),L=new l(t.mul(L.px,g.beta),L.py,L.pz),_.add(L)}multiply(d){a(d);let m=d,g,I,{endo:v}=e;if(v){let{k1neg:D,k1:S,k2neg:_,k2:L}=v.splitScalar(m),{p:w,f:C}=this.wNAF(S),{p:O,f:T}=this.wNAF(L);w=E.constTimeNegate(D,w),O=E.constTimeNegate(_,O),O=new l(t.mul(O.px,v.beta),O.py,O.pz),g=w.add(O),I=C.add(T)}else{let{p:D,f:S}=this.wNAF(m);g=D,I=S}return l.normalizeZ([g,I])[0]}multiplyAndAddUnsafe(d,m,g){let I=l.BASE,v=(S,_)=>_===zt||_===et||!S.equals(I)?S.multiplyUnsafe(_):S.multiply(_),D=v(this,m).add(v(d,g));return D.is0()?void 0:D}toAffine(d){let{px:m,py:g,pz:I}=this,v=this.is0();d==null&&(d=v?t.ONE:t.inv(I));let D=t.mul(m,d),S=t.mul(g,d),_=t.mul(I,d);if(v)return{x:t.ZERO,y:t.ZERO};if(!t.eql(_,t.ONE))throw new Error("invZ was invalid");return{x:D,y:S}}isTorsionFree(){let{h:d,isTorsionFree:m}=e;if(d===et)return!0;if(m)return m(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:m}=e;return d===et?this:m?m(l,this):this.multiplyUnsafe(e.h)}toRawBytes(d=!0){return this.assertValidity(),n(l,this,d)}toHex(d=!0){return Lt(this.toRawBytes(d))}}l.BASE=new l(e.Gx,e.Gy,t.ONE),l.ZERO=new l(t.ZERO,t.ONE,t.ZERO);let p=e.nBitLength,E=ls(l,e.endo?Math.ceil(p/2):p);return{CURVE:e,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:s,isWithinCurveOrder:i}}function Ug(r){let e=ro(r);return wt(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function oh(r){let e=Ug(r),{Fp:t,n}=e,o=t.BYTES+1,s=2*t.BYTES+1;function i(x){return zt<x&&x<t.ORDER}function a(x){return oe(x,n)}function c(x){return cs(x,n)}let{ProjectivePoint:f,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:p}=Dg({...e,toBytes(x,k,H){let B=k.toAffine(),b=t.toBytes(B.x),P=Ut;return H?P(Uint8Array.from([k.hasEvenY()?2:3]),b):P(Uint8Array.from([4]),b,t.toBytes(B.y))},fromBytes(x){let k=x.length,H=x[0],B=x.subarray(1);if(k===o&&(H===2||H===3)){let b=Dt(B);if(!i(b))throw new Error("Point is not on curve");let P=l(b),M;try{M=t.sqrt(P)}catch(j){let ee=j instanceof Error?": "+j.message:"";throw new Error("Point is not on curve"+ee)}let K=(M&et)===et;return(H&1)===1!==K&&(M=t.neg(M)),{x:b,y:M}}else if(k===s&&H===4){let b=t.fromBytes(B.subarray(0,t.BYTES)),P=t.fromBytes(B.subarray(t.BYTES,2*t.BYTES));return{x:b,y:P}}else throw new Error(`Point of length ${k} was invalid. Expected ${o} compressed bytes or ${s} uncompressed bytes`)}}),E=x=>Lt(dr(x,e.nByteLength));function y(x){let k=n>>et;return x>k}function d(x){return y(x)?a(-x):x}let m=(x,k,H)=>Dt(x.slice(k,H));class g{constructor(k,H,B){this.r=k,this.s=H,this.recovery=B,this.assertValidity()}static fromCompact(k){let H=e.nByteLength;return k=fe("compactSignature",k,H*2),new g(m(k,0,H),m(k,H,2*H))}static fromDER(k){let{r:H,s:B}=Vr.toSig(fe("DER",k));return new g(H,B)}assertValidity(){if(!p(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!p(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(k){return new g(this.r,this.s,k)}recoverPublicKey(k){let{r:H,s:B,recovery:b}=this,P=L(fe("msgHash",k));if(b==null||![0,1,2,3].includes(b))throw new Error("recovery id invalid");let M=b===2||b===3?H+e.n:H;if(M>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let K=b&1?"03":"02",G=f.fromHex(K+E(M)),j=c(M),ee=a(-P*j),Z=a(B*j),X=f.BASE.multiplyAndAddUnsafe(G,ee,Z);if(!X)throw new Error("point at infinify");return X.assertValidity(),X}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new g(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Nr(this.toDERHex())}toDERHex(){return Vr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Nr(this.toCompactHex())}toCompactHex(){return E(this.r)+E(this.s)}}let I={isValidPrivateKey(x){try{return u(x),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let x=ic(e.n);return Jl(e.randomBytes(x),e.n)},precompute(x=8,k=f.BASE){return k._setWindowSize(x),k.multiply(BigInt(3)),k}};function v(x,k=!0){return f.fromPrivateKey(x).toRawBytes(k)}function D(x){let k=fr(x),H=typeof x=="string",B=(k||H)&&x.length;return k?B===o||B===s:H?B===2*o||B===2*s:x instanceof f}function S(x,k,H=!0){if(D(x))throw new Error("first arg must be private key");if(!D(k))throw new Error("second arg must be public key");return f.fromHex(k).multiply(u(x)).toRawBytes(H)}let _=e.bits2int||function(x){let k=Dt(x),H=x.length*8-e.nBitLength;return H>0?k>>BigInt(H):k},L=e.bits2int_modN||function(x){return a(_(x))},w=to(e.nBitLength);function C(x){if(typeof x!="bigint")throw new Error("bigint expected");if(!(zt<=x&&x<w))throw new Error(`bigint expected < 2^${e.nBitLength}`);return dr(x,e.nByteLength)}function O(x,k,H=T){if(["recovered","canonical"].some(ue=>ue in H))throw new Error("sign() legacy options not supported");let{hash:B,randomBytes:b}=e,{lowS:P,prehash:M,extraEntropy:K}=H;P==null&&(P=!0),x=fe("msgHash",x),M&&(x=fe("prehashed msgHash",B(x)));let G=L(x),j=u(k),ee=[C(j),C(G)];if(K!=null&&K!==!1){let ue=K===!0?b(t.BYTES):K;ee.push(fe("extraEntropy",ue))}let Z=Ut(...ee),X=G;function pe(ue){let ve=_(ue);if(!p(ve))return;let Ae=c(ve),ye=f.BASE.multiply(ve).toAffine(),Re=a(ye.x);if(Re===zt)return;let It=a(Ae*a(X+Re*j));if(It===zt)return;let kr=(ye.x===Re?0:2)|Number(ye.y&et),Kn=It;return P&&y(It)&&(Kn=d(It),kr^=1),new g(Re,Kn,kr)}return{seed:Z,k2sig:pe}}let T={lowS:e.lowS,prehash:!1},F={lowS:e.lowS,prehash:!1};function $(x,k,H=T){let{seed:B,k2sig:b}=O(x,k,H),P=e;return rc(P.hash.outputLen,P.nByteLength,P.hmac)(B,b)}f.BASE._setWindowSize(8);function J(x,k,H,B=F){let b=x;if(k=fe("msgHash",k),H=fe("publicKey",H),"strict"in B)throw new Error("options.strict was renamed to lowS");let{lowS:P,prehash:M}=B,K,G;try{if(typeof b=="string"||fr(b))try{K=g.fromDER(b)}catch(ye){if(!(ye instanceof Vr.Err))throw ye;K=g.fromCompact(b)}else if(typeof b=="object"&&typeof b.r=="bigint"&&typeof b.s=="bigint"){let{r:ye,s:Re}=b;K=new g(ye,Re)}else throw new Error("PARSE");G=f.fromHex(H)}catch(ye){if(ye.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:j,s:ee}=K,Z=L(k),X=c(ee),pe=a(Z*X),ue=a(j*X),ve=f.BASE.multiplyAndAddUnsafe(G,pe,ue)?.toAffine();return ve?a(ve.x)===j:!1}return{CURVE:e,getPublicKey:v,getSharedSecret:S,sign:$,verify:J,ProjectivePoint:f,Signature:g,utils:I}}function Pg(r){return{hash:r,hmac:(e,...t)=>oo(r,e,ns(...t)),randomBytes:wn}}function sh(r,e){let t=n=>oh({...r,...Pg(n)});return Object.freeze({...t(e),create:t})}var ch=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),ih=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Og=BigInt(1),kc=BigInt(2),ah=(r,e)=>(r+e/kc)/e;function Vg(r){let e=ch,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=ce(u,t,e)*u%e,p=ce(l,t,e)*u%e,E=ce(p,kc,e)*f%e,y=ce(E,o,e)*E%e,d=ce(y,s,e)*y%e,m=ce(d,a,e)*d%e,g=ce(m,c,e)*m%e,I=ce(g,a,e)*d%e,v=ce(I,t,e)*u%e,D=ce(v,i,e)*y%e,S=ce(D,n,e)*f%e,_=ce(S,kc,e);if(!Sc.eql(Sc.sqr(_),r))throw new Error("Cannot find square root");return _}var Sc=us(ch,void 0,void 0,{sqrt:Vg}),ht=sh({a:BigInt(0),b:BigInt(7),Fp:Sc,n:ih,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=ih,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Og*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=t,i=BigInt("0x100000000000000000000000000000000"),a=ah(s*r,e),c=ah(-n*r,e),f=oe(r-a*t-c*o,e),u=oe(-a*n-c*s,e),l=f>i,p=u>i;if(l&&(f=e-f),p&&(u=e-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:p,k2:u}}}},rh),yA=BigInt(0);var gA=ht.ProjectivePoint;function uh(){return ht.utils.randomPrivateKey()}function lh(r,e){let t=we.digest(e instanceof Uint8Array?e:e.subarray());if(Xe(t))return t.then(({digest:n})=>ht.sign(n,r).toDERRawBytes()).catch(n=>{throw new N(String(n),"ERR_INVALID_INPUT")});try{return ht.sign(t.digest,r).toDERRawBytes()}catch(n){throw new N(String(n),"ERR_INVALID_INPUT")}}function fh(r,e,t){let n=we.digest(t instanceof Uint8Array?t:t.subarray());if(Xe(n))return n.then(({digest:o})=>ht.verify(e,o,r)).catch(o=>{throw new N(String(o),"ERR_INVALID_INPUT")});try{return ht.verify(e,n.digest,r)}catch(o){throw new N(String(o),"ERR_INVALID_INPUT")}}function hh(r){return ht.ProjectivePoint.fromHex(r).toRawBytes(!0)}function dh(r){try{ht.getPublicKey(r,!0)}catch(e){throw new N(String(e),"ERR_INVALID_PRIVATE_KEY")}}function Ic(r){try{ht.ProjectivePoint.fromHex(r)}catch(e){throw new N(String(e),"ERR_INVALID_PUBLIC_KEY")}}function ph(r){try{return ht.getPublicKey(r,!0)}catch(e){throw new N(String(e),"ERR_INVALID_PRIVATE_KEY")}}var go=class{_key;constructor(e){Ic(e),this._key=e}verify(e,t){return fh(this._key,t,e)}marshal(){return hh(this._key)}get bytes(){return bt.encode({Type:de.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}async hash(){let e=we.digest(this.bytes),t;return Xe(e)?{bytes:t}=await e:t=e.bytes,t}},wo=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??ph(e),dh(this._key),Ic(this._publicKey)}sign(e){return lh(this._key,e)}get public(){return new go(this._publicKey)}marshal(){return this._key}get bytes(){return Vt.encode({Type:de.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(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 Bn(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Mg(r){return new wo(r)}function Hg(r){return new go(r)}async function $g(){let r=uh();return new wo(r)}var si={rsa:Ac,ed25519:dc,secp256k1:Rc};function Kg(r){let e=Object.keys(si).join(" / ");return new N(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function _c(r){let e=bt.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case de.RSA:return si.rsa.unmarshalRsaPublicKey(t);case de.Ed25519:return si.ed25519.unmarshalEd25519PublicKey(t);case de.Secp256k1:return si.secp256k1.unmarshalSecp256k1PublicKey(t);default:throw Kg(e.Type??"unknown")}}var Aw=st(on(),1);var Gt="/",mh=new TextEncoder().encode(Gt),ii=mh[0],Se=class r{_buf;constructor(e,t){if(typeof e=="string")this._buf=W(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]!==ii)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(Gt))}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=mh),this._buf[0]!==ii){let e=new Uint8Array(this._buf.byteLength+1);e.fill(ii,0,1),e.set(this._buf,1),this._buf=e}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===ii;)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(Gt).slice(1)}type(){return qg(this.baseNamespace())}name(){return zg(this.baseNamespace())}instance(e){return new r(this.toString()+":"+e)}path(){let e=this.parent().toString();return e.endsWith(Gt)||(e+=Gt),e+=this.type(),new r(e)}parent(){let e=this.list();return e.length===1?new r(Gt):new r(e.slice(0,-1).join(Gt))}child(e){return this.toString()===Gt?e:e.toString()===Gt?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(),...Gg(e.map(t=>t.namespaces()))])}};function qg(r){let e=r.split(":");return e.length<2?"":e.slice(0,-1).join(":")}function zg(r){let e=r.split(":");return e[e.length-1]}function Gg(r){return[].concat(...r)}var Bw=st(Cc(),1);var yh="ERR_IPNS_EXPIRED_RECORD",ai="ERR_UNRECOGNIZED_VALIDITY";var jt="ERR_SIGNATURE_VERIFICATION";var Nc="ERR_UNDEFINED_PARAMETER",gh="ERR_INVALID_RECORD_DATA",wh="ERR_INVALID_VALUE",bh="ERR_INVALID_EMBEDDED_KEY";var xh="ERR_RECORD_TOO_LARGE";var dt;(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=()=>Jn(t)}(e=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=nn((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=>tn(o,r.codec()),r.decode=o=>en(o,r.codec())})(dt||(dt={}));var jg=["string","number","bigint","symbol"],Wg=["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 vh(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let e=typeof r;if(jg.includes(e))return e;if(e==="function")return"Function";if(Array.isArray(r))return"Array";if(Yg(r))return"Buffer";let t=Zg(r);return t||"Object"}function Yg(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function Zg(r){let e=Object.prototype.toString.call(r).slice(8,-1);if(Wg.includes(e))return e}var h=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}};h.uint=new h(0,"uint",!0);h.negint=new h(1,"negint",!0);h.bytes=new h(2,"bytes",!0);h.string=new h(3,"string",!0);h.array=new h(4,"array",!1);h.map=new h(5,"map",!1);h.tag=new h(6,"tag",!1);h.float=new h(7,"float",!0);h.false=new h(7,"false",!0);h.true=new h(7,"true",!0);h.null=new h(7,"null",!0);h.undefined=new h(7,"undefined",!0);h.break=new h(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 Cn=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",Jg=new TextDecoder,Xg=new TextEncoder;function ci(r){return Cn&&globalThis.Buffer.isBuffer(r)}function bo(r){return r instanceof Uint8Array?ci(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var Sh=Cn?(r,e,t)=>t-e>64?globalThis.Buffer.from(r.subarray(e,t)).toString("utf8"):Bh(r,e,t):(r,e,t)=>t-e>64?Jg.decode(r.subarray(e,t)):Bh(r,e,t),ui=Cn?r=>r.length>64?globalThis.Buffer.from(r):Ah(r):r=>r.length>64?Xg.encode(r):Ah(r),At=r=>Uint8Array.from(r),Nn=Cn?(r,e,t)=>ci(r)?new Uint8Array(r.subarray(e,t)):r.slice(e,t):(r,e,t)=>r.slice(e,t),Ih=Cn?(r,e)=>(r=r.map(t=>t instanceof Uint8Array?t:globalThis.Buffer.from(t)),bo(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},Rh=Cn?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function _h(r,e){if(ci(r)&&ci(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 Ah(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 Bh(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 Lc(n)}var kh=4096;function Lc(r){let e=r.length;if(e<=kh)return String.fromCharCode.apply(String,r);let t="",n=0;for(;n<e;)t+=String.fromCharCode.apply(String,r.slice(n,n+=kh));return t}var Qg=256,xo=class{constructor(e=Qg){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=Rh(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=Nn(n,0,this.cursor)}else t=Ih(this.chunks,this.cursor);return e&&this.reset(),t}};var V="CBOR decode error:",Ln="CBOR encode error:",Eo=[];Eo[23]=1;Eo[24]=2;Eo[25]=3;Eo[26]=5;Eo[27]=9;function Wt(r,e,t){if(r.length-e<t)throw new Error(`${V} not enough data for type`)}var Ee=[24,256,65536,4294967296,BigInt("18446744073709551616")];function Ge(r,e,t){Wt(r,e,1);let n=r[e];if(t.strict===!0&&n<Ee[0])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function je(r,e,t){Wt(r,e,2);let n=r[e]<<8|r[e+1];if(t.strict===!0&&n<Ee[1])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function We(r,e,t){Wt(r,e,4);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3];if(t.strict===!0&&n<Ee[2])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function Ye(r,e,t){Wt(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<Ee[3])throw new Error(`${V} 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(`${V} integers outside of the safe integer range are not supported`)}function Th(r,e,t,n){return new A(h.uint,Ge(r,e+1,n),2)}function Ch(r,e,t,n){return new A(h.uint,je(r,e+1,n),3)}function Nh(r,e,t,n){return new A(h.uint,We(r,e+1,n),5)}function Lh(r,e,t,n){return new A(h.uint,Ye(r,e+1,n),9)}function tt(r,e){return Ie(r,0,e.value)}function Ie(r,e,t){if(t<Ee[0]){let n=Number(t);r.push([e|n])}else if(t<Ee[1]){let n=Number(t);r.push([e|24,n])}else if(t<Ee[2]){let n=Number(t);r.push([e|25,n>>>8,n&255])}else if(t<Ee[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<Ee[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(`${V} encountered BigInt larger than allowable range`)}}tt.encodedSize=function(e){return Ie.encodedSize(e.value)};Ie.encodedSize=function(e){return e<Ee[0]?1:e<Ee[1]?2:e<Ee[2]?3:e<Ee[3]?5:9};tt.compareTokens=function(e,t){return e.value<t.value?-1:e.value>t.value?1:0};function Dh(r,e,t,n){return new A(h.negint,-1-Ge(r,e+1,n),2)}function Uh(r,e,t,n){return new A(h.negint,-1-je(r,e+1,n),3)}function Ph(r,e,t,n){return new A(h.negint,-1-We(r,e+1,n),5)}var Dc=BigInt(-1),Oh=BigInt(1);function Vh(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o!="bigint"){let s=-1-o;if(s>=Number.MIN_SAFE_INTEGER)return new A(h.negint,s,9)}if(n.allowBigInt!==!0)throw new Error(`${V} integers outside of the safe integer range are not supported`);return new A(h.negint,Dc-BigInt(o),9)}function li(r,e){let t=e.value,n=typeof t=="bigint"?t*Dc-Oh:t*-1-1;Ie(r,e.type.majorEncoded,n)}li.encodedSize=function(e){let t=e.value,n=typeof t=="bigint"?t*Dc-Oh:t*-1-1;return n<Ee[0]?1:n<Ee[1]?2:n<Ee[2]?3:n<Ee[3]?5:9};li.compareTokens=function(e,t){return e.value<t.value?1:e.value>t.value?-1:0};function vo(r,e,t,n){Wt(r,e,t+n);let o=Nn(r,e+t,e+t+n);return new A(h.bytes,o,t+n)}function Fh(r,e,t,n){return vo(r,e,1,t)}function Mh(r,e,t,n){return vo(r,e,2,Ge(r,e+1,n))}function Hh(r,e,t,n){return vo(r,e,3,je(r,e+1,n))}function $h(r,e,t,n){return vo(r,e,5,We(r,e+1,n))}function Kh(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer bytes lengths not supported`);return vo(r,e,9,o)}function fi(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===h.string?ui(r.value):r.value),r.encodedBytes}function Dn(r,e){let t=fi(e);Ie(r,e.type.majorEncoded,t.length),r.push(t)}Dn.encodedSize=function(e){let t=fi(e);return Ie.encodedSize(t.length)+t.length};Dn.compareTokens=function(e,t){return tw(fi(e),fi(t))};function tw(r,e){return r.length<e.length?-1:r.length>e.length?1:_h(r,e)}function Ao(r,e,t,n,o){let s=t+n;Wt(r,e,s);let i=new A(h.string,Sh(r,e+t,e+s),s);return o.retainStringBytes===!0&&(i.byteValue=Nn(r,e+t,e+s)),i}function qh(r,e,t,n){return Ao(r,e,1,t,n)}function zh(r,e,t,n){return Ao(r,e,2,Ge(r,e+1,n),n)}function Gh(r,e,t,n){return Ao(r,e,3,je(r,e+1,n),n)}function jh(r,e,t,n){return Ao(r,e,5,We(r,e+1,n),n)}function Wh(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer string lengths not supported`);return Ao(r,e,9,o,n)}var Yh=Dn;function Un(r,e,t,n){return new A(h.array,n,t)}function Zh(r,e,t,n){return Un(r,e,1,t)}function Jh(r,e,t,n){return Un(r,e,2,Ge(r,e+1,n))}function Xh(r,e,t,n){return Un(r,e,3,je(r,e+1,n))}function Qh(r,e,t,n){return Un(r,e,5,We(r,e+1,n))}function ed(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer array lengths not supported`);return Un(r,e,9,o)}function td(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Un(r,e,1,1/0)}function hi(r,e){Ie(r,h.array.majorEncoded,e.value)}hi.compareTokens=tt.compareTokens;hi.encodedSize=function(e){return Ie.encodedSize(e.value)};function Pn(r,e,t,n){return new A(h.map,n,t)}function rd(r,e,t,n){return Pn(r,e,1,t)}function nd(r,e,t,n){return Pn(r,e,2,Ge(r,e+1,n))}function od(r,e,t,n){return Pn(r,e,3,je(r,e+1,n))}function sd(r,e,t,n){return Pn(r,e,5,We(r,e+1,n))}function id(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer map lengths not supported`);return Pn(r,e,9,o)}function ad(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Pn(r,e,1,1/0)}function di(r,e){Ie(r,h.map.majorEncoded,e.value)}di.compareTokens=tt.compareTokens;di.encodedSize=function(e){return Ie.encodedSize(e.value)};function cd(r,e,t,n){return new A(h.tag,t,1)}function ud(r,e,t,n){return new A(h.tag,Ge(r,e+1,n),2)}function ld(r,e,t,n){return new A(h.tag,je(r,e+1,n),3)}function fd(r,e,t,n){return new A(h.tag,We(r,e+1,n),5)}function hd(r,e,t,n){return new A(h.tag,Ye(r,e+1,n),9)}function pi(r,e){Ie(r,h.tag.majorEncoded,e.value)}pi.compareTokens=tt.compareTokens;pi.encodedSize=function(e){return Ie.encodedSize(e.value)};var aw=20,cw=21,uw=22,lw=23;function dd(r,e,t,n){if(n.allowUndefined===!1)throw new Error(`${V} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new A(h.null,null,1):new A(h.undefined,void 0,1)}function pd(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return new A(h.break,void 0,1)}function Uc(r,e,t){if(t){if(t.allowNaN===!1&&Number.isNaN(r))throw new Error(`${V} NaN values are not supported`);if(t.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${V} Infinity values are not supported`)}return new A(h.float,r,e)}function md(r,e,t,n){return Uc(Pc(r,e+1),3,n)}function yd(r,e,t,n){return Uc(Oc(r,e+1),5,n)}function gd(r,e,t,n){return Uc(Ed(r,e+1),9,n)}function mi(r,e,t){let n=e.value;if(n===!1)r.push([h.float.majorEncoded|aw]);else if(n===!0)r.push([h.float.majorEncoded|cw]);else if(n===null)r.push([h.float.majorEncoded|uw]);else if(n===void 0)r.push([h.float.majorEncoded|lw]);else{let o,s=!1;(!t||t.float64!==!0)&&(bd(n),o=Pc(pt,1),n===o||Number.isNaN(n)?(pt[0]=249,r.push(pt.slice(0,3)),s=!0):(xd(n),o=Oc(pt,1),n===o&&(pt[0]=250,r.push(pt.slice(0,5)),s=!0))),s||(fw(n),o=Ed(pt,1),pt[0]=251,r.push(pt.slice(0,9)))}}mi.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){bd(n);let o=Pc(pt,1);if(n===o||Number.isNaN(n))return 3;if(xd(n),o=Oc(pt,1),n===o)return 5}return 9};var wd=new ArrayBuffer(9),rt=new DataView(wd,1),pt=new Uint8Array(wd,0);function bd(r){if(r===1/0)rt.setUint16(0,31744,!1);else if(r===-1/0)rt.setUint16(0,64512,!1);else if(Number.isNaN(r))rt.setUint16(0,32256,!1);else{rt.setFloat32(0,r);let e=rt.getUint32(0),t=(e&2139095040)>>23,n=e&8388607;if(t===255)rt.setUint16(0,31744,!1);else if(t===0)rt.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let o=t-127;o<-24?rt.setUint16(0,0):o<-14?rt.setUint16(0,(e&2147483648)>>16|1<<24+o,!1):rt.setUint16(0,(e&2147483648)>>16|o+15<<10|n>>13,!1)}}}function Pc(r,e){if(r.length-e<2)throw new Error(`${V} not enough data for float16`);let t=(r[e]<<8)+r[e+1];if(t===31744)return 1/0;if(t===64512)return-1/0;if(t===32256)return NaN;let n=t>>10&31,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 xd(r){rt.setFloat32(0,r,!1)}function Oc(r,e){if(r.length-e<4)throw new Error(`${V} not enough data for float32`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,4).getFloat32(0,!1)}function fw(r){rt.setFloat64(0,r,!1)}function Ed(r,e){if(r.length-e<8)throw new Error(`${V} not enough data for float64`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,8).getFloat64(0,!1)}mi.compareTokens=tt.compareTokens;function Q(r,e,t){throw new Error(`${V} encountered invalid minor (${t}) for major ${r[e]>>>5}`)}function yi(r){return()=>{throw new Error(`${V} ${r}`)}}var R=[];for(let r=0;r<=23;r++)R[r]=Q;R[24]=Th;R[25]=Ch;R[26]=Nh;R[27]=Lh;R[28]=Q;R[29]=Q;R[30]=Q;R[31]=Q;for(let r=32;r<=55;r++)R[r]=Q;R[56]=Dh;R[57]=Uh;R[58]=Ph;R[59]=Vh;R[60]=Q;R[61]=Q;R[62]=Q;R[63]=Q;for(let r=64;r<=87;r++)R[r]=Fh;R[88]=Mh;R[89]=Hh;R[90]=$h;R[91]=Kh;R[92]=Q;R[93]=Q;R[94]=Q;R[95]=yi("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)R[r]=qh;R[120]=zh;R[121]=Gh;R[122]=jh;R[123]=Wh;R[124]=Q;R[125]=Q;R[126]=Q;R[127]=yi("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)R[r]=Zh;R[152]=Jh;R[153]=Xh;R[154]=Qh;R[155]=ed;R[156]=Q;R[157]=Q;R[158]=Q;R[159]=td;for(let r=160;r<=183;r++)R[r]=rd;R[184]=nd;R[185]=od;R[186]=sd;R[187]=id;R[188]=Q;R[189]=Q;R[190]=Q;R[191]=ad;for(let r=192;r<=215;r++)R[r]=cd;R[216]=ud;R[217]=ld;R[218]=fd;R[219]=hd;R[220]=Q;R[221]=Q;R[222]=Q;R[223]=Q;for(let r=224;r<=243;r++)R[r]=yi("simple values are not supported");R[244]=Q;R[245]=Q;R[246]=Q;R[247]=dd;R[248]=yi("simple values are not supported");R[249]=md;R[250]=yd;R[251]=gd;R[252]=Q;R[253]=Q;R[254]=Q;R[255]=pd;var mt=[];for(let r=0;r<24;r++)mt[r]=new A(h.uint,r,1);for(let r=-1;r>=-24;r--)mt[31-r]=new A(h.negint,r,1);mt[64]=new A(h.bytes,new Uint8Array(0),1);mt[96]=new A(h.string,"",1);mt[128]=new A(h.array,0,1);mt[160]=new A(h.map,0,1);mt[244]=new A(h.false,!1,1);mt[245]=new A(h.true,!0,1);mt[246]=new A(h.null,null,1);function vd(r){switch(r.type){case h.false:return At([244]);case h.true:return At([245]);case h.null:return At([246]);case h.bytes:return r.value.length?void 0:At([64]);case h.string:return r.value===""?At([96]):void 0;case h.array:return r.value===0?At([128]):void 0;case h.map:return r.value===0?At([160]):void 0;case h.uint:return r.value<24?At([Number(r.value)]):void 0;case h.negint:if(r.value>=-24)return At([31-Number(r.value)])}}var dw={float64:!1,mapSorter:yw,quickEncodeToken:vd};function pw(){let r=[];return r[h.uint.major]=tt,r[h.negint.major]=li,r[h.bytes.major]=Dn,r[h.string.major]=Yh,r[h.array.major]=hi,r[h.map.major]=di,r[h.tag.major]=pi,r[h.float.major]=mi,r}var Ad=pw(),Vc=new xo,wi=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(`${Ln} object contains circular references`);return new r(t,e)}},xr={null:new A(h.null,null),undefined:new A(h.undefined,void 0),true:new A(h.true,!0),false:new A(h.false,!1),emptyArray:new A(h.array,0),emptyMap:new A(h.map,0)},Er={number(r,e,t,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new A(h.float,r):r>=0?new A(h.uint,r):new A(h.negint,r)},bigint(r,e,t,n){return r>=BigInt(0)?new A(h.uint,r):new A(h.negint,r)},Uint8Array(r,e,t,n){return new A(h.bytes,r)},string(r,e,t,n){return new A(h.string,r)},boolean(r,e,t,n){return r?xr.true:xr.false},null(r,e,t,n){return xr.null},undefined(r,e,t,n){return xr.undefined},ArrayBuffer(r,e,t,n){return new A(h.bytes,new Uint8Array(r))},DataView(r,e,t,n){return new A(h.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,e,t,n){if(!r.length)return t.addBreakTokens===!0?[xr.emptyArray,new A(h.break)]:xr.emptyArray;n=wi.createCheck(n,r);let o=[],s=0;for(let i of r)o[s++]=gi(i,t,n);return t.addBreakTokens?[new A(h.array,r.length),o,new A(h.break)]:[new A(h.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?[xr.emptyMap,new A(h.break)]:xr.emptyMap;n=wi.createCheck(n,r);let a=[],c=0;for(let f of s)a[c++]=[gi(f,t,n),gi(o?r.get(f):r[f],t,n)];return mw(a,t),t.addBreakTokens?[new A(h.map,i),a,new A(h.break)]:[new A(h.map,i),a]}};Er.Map=Er.Object;Er.Buffer=Er.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))Er[`${r}Array`]=Er.DataView;function gi(r,e={},t){let n=vh(r),o=e&&e.typeEncoders&&e.typeEncoders[n]||Er[n];if(typeof o=="function"){let i=o(r,n,e,t);if(i!=null)return i}let s=Er[n];if(!s)throw new Error(`${Ln} unsupported type: ${n}`);return s(r,n,e,t)}function mw(r,e){e.mapSorter&&r.sort(e.mapSorter)}function yw(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=Ad[o].compareTokens(t,n);return s===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),s}function Bd(r,e,t,n){if(Array.isArray(e))for(let o of e)Bd(r,o,t,n);else t[e.type.major](r,e,n)}function kd(r,e,t){let n=gi(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 xo(i);if(s(a,n,t),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return bo(a.chunks[0])}}return Vc.reset(),Bd(Vc,n,e,t),Vc.toBytes(!0)}function On(r,e){return e=Object.assign({},dw,e),kd(r,Ad,e)}var gw={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},bi=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=mt[e];if(t===void 0){let n=R[e];if(!n)throw new Error(`${V} 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}},Bo=Symbol.for("DONE"),xi=Symbol.for("BREAK");function ww(r,e,t){let n=[];for(let o=0;o<r.value;o++){let s=Vn(e,t);if(s===xi){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed array`)}if(s===Bo)throw new Error(`${V} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=s}return n}function bw(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=Vn(e,t);if(a===xi){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed map`)}if(a===Bo)throw new Error(`${V} found map but not enough entries (got ${i} [no key], expected ${r.value})`);if(n!==!0&&typeof a!="string")throw new Error(`${V} non-string keys not supported (got ${typeof a})`);if(t.rejectDuplicateMapKeys===!0&&(n&&s.has(a)||!n&&a in o))throw new Error(`${V} found repeat map key "${a}"`);let c=Vn(e,t);if(c===Bo)throw new Error(`${V} found map but not enough entries (got ${i} [no value], expected ${r.value})`);n?s.set(a,c):o[a]=c}return n?s:o}function Vn(r,e){if(r.done())return Bo;let t=r.next();if(t.type===h.break)return xi;if(t.type.terminal)return t.value;if(t.type===h.array)return ww(t,r,e);if(t.type===h.map)return bw(t,r,e);if(t.type===h.tag){if(e.tags&&typeof e.tags[t.value]=="function"){let n=Vn(r,e);return e.tags[t.value](n)}throw new Error(`${V} tag not supported (${t.value})`)}throw new Error("unsupported")}function Fc(r,e){if(!(r instanceof Uint8Array))throw new Error(`${V} data to decode must be a Uint8Array`);e=Object.assign({},gw,e);let t=e.tokenizer||new bi(r,e),n=Vn(t,e);if(n===Bo)throw new Error(`${V} did not find any content to decode`);if(n===xi)throw new Error(`${V} got unexpected break`);return[n,r.subarray(t.pos())]}function nt(r,e){let[t,n]=Fc(r,e);if(n.length>0)throw new Error(`${V} too many terminals, data makes no sense`);return t}var Ze=st(on(),1);var Sd=Ke("ipns:utils"),Id=W("/ipns/"),xw=114,Rd=async(r,e)=>{if(e==null||r==null){let n=new Error("one or more of the provided parameters are not defined");throw Sd.error(n),(0,Ze.default)(n,Nc)}let t;if(e.pubKey!=null){try{t=_c(e.pubKey)}catch(o){throw Sd.error(o),o}if(!(await wl(e.pubKey)).equals(r))throw(0,Ze.default)(new Error("Embedded public key did not match PeerID"),bh)}else r.publicKey!=null&&(t=_c(r.publicKey));if(t!=null)return t;throw(0,Ze.default)(new Error("no public key is available"),Nc)};var _d=r=>{let e=W("ipns-signature:");return Le([e,r])},Mr=r=>"signatureV1"in r?dt.encode({value:W(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:W(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):dt.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data});function Bt(r){let e=dt.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,Ze.default)(new Error("missing data or signatureV2"),jt);let t=Td(e.data),n=Ew(t.Value),o=z(t.Validity);if(e.value!=null&&e.signatureV1!=null)return vw(e),{value:n,validityType:dt.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:dt.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 Mc=r=>Le([Id,r.toBytes()]),Fn=r=>Qn(r.slice(Id.length));var Td=r=>{let e=nt(r);if(e.ValidityType===0)e.ValidityType=dt.ValidityType.EOL;else throw(0,Ze.default)(new Error("Unknown validity type"),ai);return Number.isInteger(e.Sequence)&&(e.Sequence=BigInt(e.Sequence)),Number.isInteger(e.TTL)&&(e.TTL=BigInt(e.TTL)),e},Ew=r=>{if(r!=null){if(Hu(r))return`/ipns/${r.toCID().toString(sr)}`;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=re.asCID(r);if(t!=null)return t.code===xw?`/ipns/${t.toString(sr)}`:`/ipfs/${t.toV1().toString()}`;try{return r instanceof Uint8Array?`/ipfs/${re.decode(r).toV1().toString()}`:`/ipfs/${re.parse(e).toV1().toString()}`}catch{}}throw(0,Ze.default)(new Error("Value must be a valid content path starting with /"),wh)},vw=r=>{if(r.data==null)throw(0,Ze.default)(new Error("Record data is missing"),gh);let e=Td(r.data);if(!se(e.Value,r.value??new Uint8Array(0)))throw(0,Ze.default)(new Error('Field "value" did not match between protobuf and CBOR'),jt);if(!se(e.Validity,r.validity??new Uint8Array(0)))throw(0,Ze.default)(new Error('Field "validity" did not match between protobuf and CBOR'),jt);if(e.ValidityType!==r.validityType)throw(0,Ze.default)(new Error('Field "validityType" did not match between protobuf and CBOR'),jt);if(e.Sequence!==r.sequence)throw(0,Ze.default)(new Error('Field "sequence" did not match between protobuf and CBOR'),jt);if(e.TTL!==r.ttl)throw(0,Ze.default)(new Error('Field "ttl" did not match between protobuf and CBOR'),jt)};var QB=Ke("ipns"),e8=Je.code,kw="/ipns/",t8=kw.length;var ko=st(on(),1),Cd=st(Cc(),1);var vi=Ke("ipns:validator"),Sw=1024*10,Iw=async(r,e)=>{let t=Bt(e),n;try{let o=_d(t.data);n=await r.verify(o,t.signatureV2)}catch{n=!1}if(!n)throw vi.error("record signature verification failed"),(0,ko.default)(new Error("record signature verification failed"),jt);if(t.validityType===dt.ValidityType.EOL){if(Cd.default.fromString(t.validity).toDate().getTime()<Date.now())throw vi.error("record has expired"),(0,ko.default)(new Error("record has expired"),yh)}else if(t.validityType!=null)throw vi.error("unrecognized validity type"),(0,ko.default)(new Error("unrecognized validity type"),ai);vi("ipns record for %s is valid",t.value)};async function Nd(r,e){if(e.byteLength>Sw)throw(0,ko.default)(new Error("record too large"),xh);let t=Fn(r),n=Bt(e),o=await Rd(t,n);await Iw(o,e)}async function*So(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 $c=st(Dd(),1);var Ro=class extends Error{constructor(e){super(e),this.name="TimeoutError"}},Kc=class extends Error{constructor(e){super(),this.name="AbortError",this.message=e}},Ud=r=>globalThis.DOMException===void 0?new Kc(r):new DOMException(r),Pd=r=>{let e=r.reason===void 0?Ud("This operation was aborted."):r.reason;return e instanceof Error?e:Ud(e)};function _o(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:p}=e;p.aborted&&u(Pd(p)),p.addEventListener("abort",()=>{u(Pd(p))})}if(t===Number.POSITIVE_INFINITY){r.then(f,u);return}let l=new Ro;i=s.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(p){u(p)}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(p){u(p)}})()}).finally(()=>{c.clear()});return c.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},c}function qc(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 To=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=qc(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 kt=class extends $c.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:To,...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=_o(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 Ro&&!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 Tw(r){return r[Symbol.asyncIterator]!=null}function Cw(r){if(Tw(r))return(async()=>{for await(let e of r)return e})();for(let e of r)return e}var Bi=Cw;var zc=W("/ipns/");function Od(r){return se(r.subarray(0,zc.byteLength),zc)}var Vd=r=>Qn(r.slice(zc.length)),ki=class{client;constructor(e){this.client=e}async*findProviders(e,t={}){yield*sn(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async put(e,t,n){if(!Od(e))return;let o=Vd(e),s=Bt(t);await this.client.putIPNS(o,s,n)}async get(e,t){if(!Od(e))throw new N("Not found","ERR_NOT_FOUND");let n=Vd(e);try{let o=await this.client.getIPNS(n,t);return Mr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new N("Not found","ERR_NOT_FOUND"):o}}},Si=class{client;constructor(e){this.client=e}async findPeer(e,t={}){let n=await Bi(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 Me=Ke("delegated-routing-v1-http-api-client"),Fd={concurrentRequests:4,timeout:3e4},Ii=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;constructor(e,t={}){this.started=!1,this.shutDownController=new AbortController,Yr(1/0,this.shutDownController.signal),this.httpQueue=new kt({concurrency:t.concurrentRequests??Fd.concurrentRequests}),this.clientUrl=e instanceof URL?e:new URL(e),this.timeout=t.timeout??Fd.timeout,this.contentRouting=new ki(this),this.peerRouting=new Si(this)}get[jn](){return this.contentRouting}get[Wn](){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={}){Me("getProviders starts: %c",e);let n=Sr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=De(),s=De();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 p=this.#e(l);p!=null&&(yield p)}}else for await(let u of So(es(c.body))){let l=this.#e(u);l!=null&&(yield l)}}catch(i){Me.error("getProviders errored:",i)}finally{n.clear(),s.resolve(),Me("getProviders finished: %c",e)}}async*getPeers(e,t={}){Me("getPeers starts: %c",e);let n=Sr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=De(),s=De();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 p=this.#e(l);p!=null&&(yield p)}}else for await(let u of So(es(c.body))){let l=this.#e(u);l!=null&&(yield l)}}catch(i){Me.error("getPeers errored:",i)}finally{n.clear(),s.resolve(),Me("getPeers finished: %c",e)}}async getIPNS(e,t={}){Me("getIPNS starts: %c",e);let n=Sr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=De(),s=De();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(Me("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 Nd(Mc(e),u),Bt(u)}catch(a){throw Me.error("getIPNS GET %s error:",i,a),a}finally{n.clear(),s.resolve(),Me("getIPNS finished: %c",e)}}async putIPNS(e,t,n={}){Me("putIPNS starts: %c",e);let o=Sr([this.shutDownController.signal,n.signal,AbortSignal.timeout(this.timeout)]),s=De(),i=De();this.httpQueue.add(async()=>(s.resolve(),i.promise));let a=`${this.clientUrl}routing/v1/ipns/${e.toCID().toString()}`;try{await s.promise;let c=Mr(t),u=await fetch(a,{method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:c,signal:o});if(Me("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 Me.error("putIPNS PUT %s error:",a,c.stack),c}finally{o.clear(),i.resolve(),Me("putIPNS finished: %c",e)}}#e(e){let t=[],n=e.Addrs?.map(eo)??[];return e.Protocols!=null&&t.push(...e.Protocols),e.Protocol!=null&&(t.push(e.Protocol),delete e.Protocol),{...e,Schema:"peer",ID:Cr(e.ID),Addrs:n,Protocols:t}}};function Md(r,e={}){return new Ii(new URL(r),e)}var Hd=W("/ipns/");function $d(r){return se(r.subarray(0,Hd.byteLength),Hd)}var Gc=class{client;constructor(e){this.client=Md(e)}async provide(e,t){}async*findProviders(e,t){yield*sn(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs,protocols:n.Protocols}))}async put(e,t,n){if(!$d(e))return;let o=Fn(e),s=Bt(t);await this.client.putIPNS(o,s,n)}async get(e,t){if(!$d(e))throw new N("Not found","ERR_NOT_FOUND");let n=Fn(e);try{let o=await this.client.getIPNS(n,t);return Mr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new N("Not found","ERR_NOT_FOUND"):o}}async findPeer(e,t){let n=await Bi(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 jc(r){return new Gc(new URL(r))}function Ri(r){let e=[Yt.A];return r==null?e:Array.isArray(r)?r.length===0?e:r:[r]}var Wc=60;function _i(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:Yt[e.type]})),Answer:(r.Answer??r.answers??[]).map(e=>({name:e.name,type:Yt[e.type],TTL:e.TTL??e.ttl??Wc,data:e.data instanceof Uint8Array?z(e.data):e.data}))}}var Nw=4;function Yc(r,e={}){let t=new kt({concurrency:e.queryConcurrency??Nw});return async(n,o={})=>{let s=new URLSearchParams;s.set("name",n),Ri(o.types).forEach(a=>{s.append("type",a.toString())}),o.onProgress?.(new te("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=_i(await a.json());return o.onProgress?.(new te("dns:response",{detail:c})),c},{signal:o.signal});if(i==null)throw new Error("No DNS response received");return i}}function Kd(){return[Yc("https://cloudflare-dns.com/dns-query"),Yc("https://dns.google/resolve")]}var Gd=st(zd(),1);var Zc=class{lru;constructor(e){this.lru=(0,Gd.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 _i({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(({value:i})=>({...i,type:Yt[i.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??Wc)*1e3,value:t}),this.lru.set(n,o)}remove(e,t){let n=`${e.toLowerCase()}-${t}`;this.lru.remove(n)}clear(){this.lru.clear()}},Jc=new Zc(1e3);var Ti=class{resolvers;constructor(e){this.resolvers={},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["."]=Kd())}async query(e,t={}){let n=Ri(t.types),o=t.cached!==!1?Jc.get(e,n):void 0;if(o!=null)return t.onProgress?.(new te("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)Jc.add(e,u);return f}catch(f){a.push(f),t.onProgress?.(new te("dns:error",{detail:f}))}}throw a.length===1?a[0]:new AggregateError(a,`DNS lookup of ${e} ${n} failed`)}};var Yt;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(Yt||(Yt={}));function jd(r={}){return new Ti(r)}var Xc=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 Ci(r,e,t,n){let o=new Xc(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 Ni=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 Wd(r,e,t){if(e==null)return r;if(e.aborted)return Promise.reject(new Ni(t?.errorMessage,t?.errorCode));let n,o=new Ni(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 Li=class{deferred;signal;where;constructor(e,t){this.signal=t,this.deferred=De(),this.where=e,this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(new er)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function Lw(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var Di=class{id;fn;options;priority;recipients;status;timeline;controller;constructor(e,t,n=0){this.id=Lw(),this.status="queued",this.fn=e,this.priority=n,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,Yr(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 er)}async join(e={}){let t=new Li(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 Wd(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 Dw(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 Co=class extends Vo{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=Dw(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 Di(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 er)}),this.clear()}async onEmpty(e){this.size!==0&&await Ci(this,"empty",e?.signal)}async onSizeLessThan(e,t){this.size<e||await Ci(this,"next",t?.signal,{filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await Ci(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=Ct({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 Xd="/pin/",Yd="/pinned-block/",Qc=sr,Zd=1;function Jd(r){return r.version===0&&(r=r.toV1()),new Se(`${Xd}${r.toString(Qc)}`)}var Ui=class{datastore;blockstore;dagWalkers;constructor(e,t,n){this.datastore=e,this.blockstore=t,this.dagWalkers=n}async*add(e,t={}){let n=Jd(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 Co({concurrency:Zd});for await(let a of this.#e(e,s,{...t,depth:o}))await this.#t(a,c=>c.pinnedBy.find(f=>se(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,On(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 Se(`${Yd}${Qc.encode(e.multihash.bytes)}`),s={pinCount:0,pinnedBy:[]};try{s=nt(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,On(s),n),n.onProgress?.(new te("helia:pin:add",e))}}async*rm(e,t={}){let n=Jd(e),o=await this.datastore.get(n,t),s=nt(o);await this.datastore.delete(n,t);let i=new Co({concurrency:Zd});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=>se(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:Xd+(e.cid!=null?`${e.cid.toString(sr)}`:"")},e)){let o=re.parse(t.toString().substring(5),sr),s=nt(n);yield{cid:o,...s}}}async isPinned(e,t={}){let n=new Se(`${Yd}${Qc.encode(e.multihash.bytes)}`);return this.datastore.has(n,t)}};function eu(r,e){let t={[Symbol.iterator]:()=>t,next:()=>{let n=r.next(),o=n.value;return n.done===!0||o==null?{done:!0,value:void 0}:{done:!1,value:e(o)}}};return t}var Mn=class r{set;constructor(e){if(this.set=new Set,e!=null)for(let t of e)this.set.add(t.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(e){this.set.add(e.toString())}clear(){this.set.clear()}delete(e){this.set.delete(e.toString())}entries(){return eu(this.set.entries(),e=>{let t=Cr(e[0]);return[t,t]})}forEach(e){this.set.forEach(t=>{let n=Cr(t);e(n,n,this)})}has(e){return this.set.has(e.toString())}values(){return eu(this.set.values(),e=>Cr(e))}intersection(e){let t=new r;for(let n of e)this.has(n)&&t.add(n);return t}difference(e){let t=new r;for(let n of this)e.has(n)||t.add(n);return t}union(e){let t=new r;for(let n of e)t.add(n);for(let n of this)t.add(n);return t}};var Pi=class{log;routers;constructor(e,t){this.log=e.logger.forComponent("helia:routing"),this.routers=t.routers??[]}async start(){await tr(...this.routers)}async stop(){await rr(...this.routers)}async*findProviders(e,t={}){if(this.routers.length===0)throw new N("No content routers available","ERR_NO_ROUTERS_AVAILABLE");let n=new Mn;for await(let o of ar(...Hn(this.routers,"findProviders").map(s=>s.findProviders(e,t))))o!=null&&(n.has(o.id)||(n.add(o.id),yield o))}async provide(e,t={}){if(this.routers.length===0)throw new N("No content routers available","ERR_NO_ROUTERS_AVAILABLE");await Promise.all(Hn(this.routers,"provide").map(async n=>{await n.provide(e,t)}))}async put(e,t,n){await Promise.all(Hn(this.routers,"put").map(async o=>{await o.put(e,t,n)}))}async get(e,t){return Promise.any(Hn(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=ar(...Hn(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");let n=new Mn;for await(let o of ar(...Hn(this.routers,"getClosestPeers").map(s=>s.getClosestPeers(e,t))))o!=null&&(n.has(o.id)||(n.add(o.id),yield o))}};function Hn(r,e){return r.filter(t=>t[e]!=null)}var vr={},$n=r=>{r.addEventListener("message",e=>{$n.dispatchEvent("message",r,e)}),r.port!=null&&r.port.addEventListener("message",e=>{$n.dispatchEvent("message",r,e)})};$n.addEventListener=(r,e)=>{vr[r]==null&&(vr[r]=[]),vr[r].push(e)};$n.removeEventListener=(r,e)=>{vr[r]!=null&&(vr[r]=vr[r].filter(t=>t===e))};$n.dispatchEvent=function(r,e,t){vr[r]!=null&&vr[r].forEach(n=>n(e,t))};var tu=$n;var ru="lock:worker:request-read",nu="lock:worker:release-read",ou="lock:master:grant-read",su="lock:worker:request-write",iu="lock:worker:release-write",au="lock:master:grant-write";var Qd=(r=21)=>Math.random().toString().substring(2);var ep=(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)})}}}))},tp=(r,e,t,n)=>async()=>{let o=Qd();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)})},Uw={singleProcess:!1},rp=r=>{if(r=Object.assign({},Uw,r),!!globalThis.document||r.singleProcess){let t=new EventTarget;return tu.addEventListener("message",ep(t,"requestReadLock",ru,nu,ou)),tu.addEventListener("message",ep(t,"requestWriteLock",su,iu,au)),t}return{isWorker:!0,readLock:t=>tp(t,ru,ou,nu),writeLock:t=>tp(t,su,au,iu)}};var Hr={},Ar;async function cu(r,e){let t,n=new Promise(o=>{t=o});return r.add(async()=>_o((async()=>{await new Promise(o=>{t(()=>{o()})})})(),{milliseconds:e.timeout})),n}var Pw=(r,e)=>{if(Ar.isWorker===!0)return{readLock:Ar.readLock(r,e),writeLock:Ar.writeLock(r,e)};let t=new kt({concurrency:1}),n;return{async readLock(){if(n!=null)return cu(n,e);n=new kt({concurrency:e.concurrency,autoStart:!1});let o=n,s=cu(n,e);return t.add(async()=>{o.start(),await o.onIdle().then(()=>{n===o&&(n=null)})}),s},async writeLock(){return n=null,cu(t,e)}}},Ow={name:"lock",concurrency:1/0,timeout:846e5,singleProcess:!1};function uu(r){let e=Object.assign({},Ow,r);return Ar==null&&(Ar=rp(e),Ar.isWorker!==!0&&(Ar.addEventListener("requestReadLock",t=>{Hr[t.data.name]!=null&&Hr[t.data.name].readLock().then(async n=>t.data.handler().finally(()=>{n()}))}),Ar.addEventListener("requestWriteLock",async t=>{Hr[t.data.name]!=null&&Hr[t.data.name].writeLock().then(async n=>t.data.handler().finally(()=>{n()}))}))),Hr[e.name]==null&&(Hr[e.name]=Pw(e.name,e)),Hr[e.name]}var Oi=class{lock;child;pins;started;constructor(e,t,n={}){this.child=e,this.pins=t,this.lock=uu({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await tr(this.child),this.started=!0}async stop(){await rr(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()}}};var op=42;function Vw(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let e=re.asCID(r);if(!e)return null;let t=new Uint8Array(e.bytes.byteLength+1);return t.set(e.bytes,1),[new A(h.tag,op),new A(h.bytes,t)]}function Fw(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function Mw(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 np={float64:!0,typeEncoders:{Object:Vw,undefined:Fw,number:Mw}},kS={...np,typeEncoders:{...np.typeEncoders}};function Hw(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return re.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[op]=Hw;var SS={...lu,tags:lu.tags.slice()};var sp=113;var ip=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(e){let t=this.inRecursive[this.inRecursive.length-1];t&&(t.type===h.array&&(t.elements++,t.elements!==1&&e.push([44])),t.type===h.map&&(t.elements++,t.elements!==1&&(t.elements%2===1?e.push([44]):e.push([58]))))}[h.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)}[h.negint.major](e,t){this[h.uint.major](e,t)}[h.bytes.major](e,t){throw new Error(`${Ln} unsupported type: Uint8Array`)}[h.string.major](e,t){this.prefix(e);let n=ui(JSON.stringify(t.value));e.push(n.length>32?bo(n):n)}[h.array.major](e,t){this.prefix(e),this.inRecursive.push({type:h.array,elements:0}),e.push([91])}[h.map.major](e,t){this.prefix(e),this.inRecursive.push({type:h.map,elements:0}),e.push([123])}[h.tag.major](e,t){}[h.float.major](e,t){if(t.type.name==="break"){let i=this.inRecursive.pop();if(i){if(i.type===h.array)e.push([93]);else if(i.type===h.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(`${Ln} 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 $r=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t,this.modeStack=["value"],this.lastToken=""}pos(){return this._pos}done(){return this._pos>=this.data.length}ch(){return this.data[this._pos]}currentMode(){return this.modeStack[this.modeStack.length-1]}skipWhitespace(){let e=this.ch();for(;e===32||e===9||e===13||e===10;)e=this.data[++this._pos]}expect(e){if(this.data.length-this._pos<e.length)throw new Error(`${V} unexpected end of input at position ${this._pos}`);for(let t=0;t<e.length;t++)if(this.data[this._pos++]!==e[t])throw new Error(`${V} unexpected token at position ${this._pos}, expected to find '${String.fromCharCode(...e)}'`)}parseNumber(){let e=this._pos,t=!1,n=!1,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(h.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(`${V} unexpected token at position ${this._pos}`);if(!this.done()&&this.ch()===46){if(n)throw new Error(`${V} unexpected token at position ${this._pos}`);n=!0,this._pos++,o([48,49,50,51,52,53,54,55,56,57])}!this.done()&&(this.ch()===101||this.ch()===69)&&(n=!0,this._pos++,!this.done()&&(this.ch()===43||this.ch()===45)&&this._pos++,o([48,49,50,51,52,53,54,55,56,57]));let s=String.fromCharCode.apply(null,this.data.subarray(e,this._pos)),i=parseFloat(s);return n?new A(h.float,i,this._pos-e):this.options.allowBigInt!==!0||Number.isSafeInteger(i)?new A(i>=0?h.uint:h.negint,i,this._pos-e):new A(i>=0?h.uint:h.negint,BigInt(s),this._pos-e)}parseString(){if(this.ch()!==34)throw new Error(`${V} unexpected character at position ${this._pos}; this shouldn't happen`);this._pos++;for(let 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(h.string,c,i)}}let e=this._pos,t=[],n=()=>{if(this._pos+4>=this.data.length)throw new Error(`${V} unexpected end of unicode escape sequence at position ${this._pos}`);let s=0;for(let i=0;i<4;i++){let a=this.ch();if(a>=48&&a<=57)a-=48;else if(a>=97&&a<=102)a=a-97+10;else if(a>=65&&a<=70)a=a-65+10;else throw new Error(`${V} unexpected unicode escape character at position ${this._pos}`);s=s*16+a,this._pos++}return s},o=()=>{let s=this.ch(),i=null,a=s>239?4:s>223?3:s>191?2:1;if(this._pos+a>this.data.length)throw new Error(`${V} unexpected unicode sequence at position ${this._pos}`);let c,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(`${V} 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(`${V} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new A(h.string,Lc(t),this._pos-e);default:if(s<32)throw new Error(`${V} invalid control character at position ${this._pos}`);s<128?(t.push(s),this._pos++):o()}}throw new Error(`${V} unexpected end of string at position ${this._pos}`)}parseValue(){switch(this.ch()){case 123:return this.modeStack.push("obj-start"),this._pos++,new A(h.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new A(h.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new A(h.null,null,4);case 102:return this.expect([102,97,108,115,101]),new A(h.false,!1,5);case 116:return this.expect([116,114,117,101]),new A(h.true,!0,4);case 45:case 48:case 49:case 50:case 51:case 52:case 53:case 54:case 55:case 56:case 57:return this.parseNumber();default:throw new Error(`${V} unexpected character at position ${this._pos}`)}}next(){switch(this.skipWhitespace(),this.currentMode()){case"value":return this.modeStack.pop(),this.parseValue();case"array-value":{if(this.modeStack.pop(),this.ch()===93)return this._pos++,this.skipWhitespace(),new A(h.break,void 0,1);if(this.ch()!==44)throw new Error(`${V} unexpected character at position ${this._pos}, was expecting array delimiter but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue()}case"array-start":return this.modeStack.pop(),this.ch()===93?(this._pos++,this.skipWhitespace(),new A(h.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(h.break,void 0,1);if(this.ch()!==44)throw new Error(`${V} unexpected character at position ${this._pos}, was expecting object delimiter but found '${String.fromCharCode(this.ch())}'`);this._pos++,this.skipWhitespace();case"obj-start":{if(this.modeStack.pop(),this.ch()===125)return this._pos++,this.skipWhitespace(),new A(h.break,void 0,1);let e=this.parseString();if(this.skipWhitespace(),this.ch()!==58)throw new Error(`${V} unexpected character at position ${this._pos}, was expecting key/value delimiter ':' but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("obj-value"),e}case"obj-value":return this.modeStack.pop(),this.modeStack.push("obj-key"),this.skipWhitespace(),this.parseValue();default:throw new Error(`${V} unexpected parse state at position ${this._pos}; this shouldn't happen`)}}};function Vi(r,e){return e=Object.assign({tokenizer:new $r(r,e)},e),nt(r,e)}var qw={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};qw.tags[42]=re.parse;var cp=297;var KS=new TextDecoder;var qS=new TextEncoder;var Gw=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 Fi(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 up(r,e){let t;return[t,e]=fu(r,e),[t&7,t>>3,e]}function jw(r){let e={},t=r.length,n=0;for(;n<t;){let o,s;if([o,s,n]=up(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]=Fi(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]=Fi(r,n),e.Name=Gw.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 lp(r){let e=r.length,t=0,n,o=!1,s;for(;t<e;){let a,c;if([a,c,t]=up(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]=Fi(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]=Fi(r,t),n.push(jw(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 GS=new TextEncoder,jS=2**32,WS=2**31;var JS=new TextEncoder;function fp(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var hp=112;function dp(r){let e=fp(r),t=lp(e),n={};return t.Data&&(n.Data=t.Data),t.Links&&(n.Links=t.Links.map(o=>{let s={};try{s.Hash=re.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 Yw={codec:hp,*walk(r){yield*dp(r).Links.map(t=>t.Hash)}},Zw={codec:$o,*walk(){}},pp=42,Jw={codec:sp,*walk(r){let e=[],t=[];t[pp]=n=>{if(n[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");let o=re.decode(n.subarray(1));return e.push(o),o},nt(r,{tags:t}),yield*e}},hu=class extends $r{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===h.map){let t=this._next();if(t.type===h.string&&t.value==="/"){let n=this._next();if(n.type===h.string){if(this._next().type!==h.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new A(h.tag,42,0)}if(n.type===h.map){let o=this._next();if(o.type===h.string&&o.value==="bytes"){let s=this._next();if(s.type===h.string){for(let a=0;a<2;a++)if(this._next().type!==h.break)throw new Error("Invalid encoded Bytes form");let i=nr.decode(`m${s.value}`);return new A(h.bytes,i,s.value.length)}this.tokenBuffer.push(s)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(t)}return e}},Xw={codec:cp,*walk(r){let e=[],t=[];t[pp]=n=>{let o=re.parse(n);return e.push(o),o},Vi(r,{tags:t,tokenizer:new hu(r,{tags:t,allowIndefinite:!0,allowUndefined:!0,allowNaN:!0,allowInfinity:!0,allowBigInt:!0,strict:!1,rejectDuplicateMapKeys:!1})}),yield*e}},Qw={codec:al,*walk(){}};function mp(r=[]){let e={};return[Yw,Zw,Jw,Xw,Qw,...r].forEach(t=>{e[t.codec]=t}),e}var du=new Se("/version"),yp=1;async function gp(r){if(!await r.has(du)){await r.put(du,W(`${yp}`));return}let e=await r.get(du),t=z(e);if(parseInt(t,10)!==yp)throw new Error("Unknown datastore version, a datastore migration may be required")}function wp(r=[]){let e={};return[we,sa,Je,...r].forEach(t=>{e[t.code]=t}),e}var St=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 Kr={};ge(Kr,{abortedError:()=>ob,closeFailedError:()=>tb,deleteFailedError:()=>mu,getFailedError:()=>rb,hasFailedError:()=>nb,notFoundError:()=>Br,openFailedError:()=>eb,putFailedError:()=>pu});var Zt=st(on(),1);function eb(r){return r=r??new Error("Open failed"),(0,Zt.default)(r,"ERR_OPEN_FAILED")}function tb(r){return r=r??new Error("Close failed"),(0,Zt.default)(r,"ERR_CLOSE_FAILED")}function pu(r){return r=r??new Error("Put failed"),(0,Zt.default)(r,"ERR_PUT_FAILED")}function rb(r){return r=r??new Error("Get failed"),(0,Zt.default)(r,"ERR_GET_FAILED")}function mu(r){return r=r??new Error("Delete failed"),(0,Zt.default)(r,"ERR_DELETE_FAILED")}function nb(r){return r=r??new Error("Has failed"),(0,Zt.default)(r,"ERR_HAS_FAILED")}function Br(r){return r=r??new Error("Not Found"),(0,Zt.default)(r,"ERR_NOT_FOUND")}function ob(r){return r=r??new Error("Aborted"),(0,Zt.default)(r,"ERR_ABORTED")}var bp=0,Mi=class extends St{put(e){return e}get(e){if(e.code===bp)return e.multihash.digest;throw Br()}has(e){return e.code===bp}delete(){}*getAll(){}};function sb(r){return r[Symbol.asyncIterator]!=null}function ib(r,e){if(sb(r))return async function*(){for await(let a of r)await e(a)&&(yield a)}();let t=qr(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 ot=ib;var ab=Ke("blockstore:core:tiered"),No=class extends St{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 pu(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){ab.error(o)}throw Br()}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 mu(n)}}async*putMany(e,t={}){let n,o=this.stores.map(s=>{let i=Ct({objectMode:!0});return Tt(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=Ct({objectMode:!0});return Tt(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*ot(ar(...this.stores.map(n=>n.getAll(e))),n=>{let o=n.cid.toString();return t.has(o)?!1:(t.add(o),!0)})}};function cb(r){return typeof r.retrieve=="function"}function ub(r){return typeof r.announce=="function"}var Hi=class{child;blockRetrievers;blockAnnouncers;hashers;started;log;constructor(e){this.log=e.logger.forComponent("helia:networked-storage"),this.child=new No([new Mi,e.blockstore]),this.blockRetrievers=(e.blockBrokers??[]).filter(cb),this.blockAnnouncers=(e.blockBrokers??[]).filter(ub),this.hashers=e.hashers??{},this.started=!1}isStarted(){return this.started}async start(){await tr(this.child,...new Set([...this.blockRetrievers,...this.blockAnnouncers])),this.started=!0}async stop(){await rr(this.child,...new Set([...this.blockRetrievers,...this.blockAnnouncers])),this.started=!1}unwrap(){return this.child}async put(e,t,n={}){return await this.child.has(e)?(n.onProgress?.(new te("blocks:put:duplicate",e)),e):(n.onProgress?.(new te("blocks:put:providers:notify",e)),this.blockAnnouncers.forEach(o=>{o.announce(e,t,n)}),n.onProgress?.(new te("blocks:put:blockstore:put",e)),this.child.put(e,t,n))}async*putMany(e,t={}){let n=ot(e,async({cid:s})=>{let i=await this.child.has(s);return i&&t.onProgress?.(new te("blocks:put-many:duplicate",s)),!i}),o=Gi(n,({cid:s,block:i})=>{t.onProgress?.(new te("blocks:put-many:providers:notify",s)),this.blockAnnouncers.forEach(a=>{a.announce(s,i,t)})});t.onProgress?.(new te("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 te("blocks:get:providers:get",e));let n=await xp(e,this.blockRetrievers,this.hashers[e.multihash.code],{...t,log:this.log});return t.onProgress?.(new te("blocks:get:blockstore:put",e)),await this.child.put(e,n,t),t.onProgress?.(new te("blocks:get:providers:notify",e)),this.blockAnnouncers.forEach(o=>{o.announce(e,n,t)}),n}return t.onProgress?.(new te("blocks:get:blockstore:get",e)),this.child.get(e,t)}async*getMany(e,t={}){t.onProgress?.(new te("blocks:get-many:blockstore:get-many")),yield*this.child.getMany(Gi(e,async n=>{if(t.offline!==!0&&!await this.child.has(n)){t.onProgress?.(new te("blocks:get-many:providers:get",n));let o=await xp(n,this.blockRetrievers,this.hashers[n.multihash.code],{...t,log:this.log});t.onProgress?.(new te("blocks:get-many:blockstore:put",n)),await this.child.put(n,o,t),t.onProgress?.(new te("blocks:get-many:providers:notify",n)),this.blockAnnouncers.forEach(s=>{s.announce(n,o,t)})}}))}async delete(e,t={}){t.onProgress?.(new te("blocks:delete:blockstore:delete",e)),await this.child.delete(e,t)}async*deleteMany(e,t={}){t.onProgress?.(new te("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 te("blocks:get-all:blockstore:get-many")),yield*this.child.getAll(e)}},lb=(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(!se(n.digest,r.multihash.digest))throw new N("Hash of downloaded block did not match multihash from passed CID","ERR_HASH_MISMATCH")}};async function xp(r,e,t,n){let o=lb(r,t),s=new AbortController,i=Sr([s.signal,n.signal]);try{return await Promise.any(e.map(async a=>{try{let c=!1,f=await a.retrieve(r,{...n,signal:i,validateFn:async u=>{await o(u),c=!0}});return c||await o(f),f}catch(c){throw n.log.error("could not retrieve verified block for %c",r,c),c}}))}finally{i.clear()}}var $i=class{blockstore;datastore;pins;logger;routing;dagWalkers;hashers;dns;log;constructor(e){this.logger=e.logger??Zu(),this.log=this.logger.forComponent("helia"),this.hashers=wp(e.hashers),this.dagWalkers=mp(e.dagWalkers),this.dns=e.dns??jd();let t={blockstore:e.blockstore,datastore:e.datastore,hashers:this.hashers,dagWalkers:this.dagWalkers,logger:this.logger,blockBrokers:[],dns:this.dns,...e.components??{}};t.blockBrokers=e.blockBrokers.map(o=>o(t));let n=new Hi(t);this.pins=new Ui(e.datastore,n,this.dagWalkers),this.blockstore=new Oi(n,this.pins,{holdGcLock:e.holdGcLock??!0}),this.datastore=e.datastore,this.routing=new Pi(t,{routers:(e.routers??[]).flatMap(o=>{let s=[o];return o[jn]!=null&&s.push(o[jn]),o[Wn]!=null&&s.push(o[Wn]),s})})}async start(){await gp(this.datastore),await tr(this.blockstore,this.datastore,this.routing)}async stop(){await rr(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 Tt(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 te("helia:gc:deleted",s))}catch(i){n.log.error("Error during gc",i),e.onProgress?.(new te("helia:gc:error",i))}}()))}finally{t()}this.log("gc finished")}};var Lo=class extends St{data;constructor(){super(),this.data=new Map}put(e,t){return this.data.set(Be.encode(e.multihash.bytes),t),e}get(e){let t=this.data.get(Be.encode(e.multihash.bytes));if(t==null)throw Br();return t}has(e){return this.data.has(Be.encode(e.multihash.bytes))}async delete(e){this.data.delete(Be.encode(e.multihash.bytes))}async*getAll(){for(let[e,t]of this.data.entries())yield{cid:re.createV1($o,gt(Be.decode(e))),block:t}}};var i6={...Kr};var Ep=st(on(),1);function Ki(r){return r=r??new Error("Not Found"),(0,Ep.default)(r,"ERR_NOT_FOUND")}var vp="SHARDING";function hb(r){return r[Symbol.asyncIterator]!=null}function db(r){if(hb(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 yu=db;function pb(r){return r[Symbol.asyncIterator]!=null}function mb(r,e){return pb(r)?async function*(){yield*(await yu(r)).sort(e)}():function*(){yield*yu(r).sort(e)}()}var qi=mb;var Jt=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 Tt(this.putMany(e,n)),e=[],await Tt(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=ot(n,s=>s.key.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,s)=>ot(o,s),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,s)=>qi(o,s),n)),e.offset!=null){let o=0,s=e.offset;n=ot(n,()=>o++>=s)}return e.limit!=null&&(n=jo(n,e.limit)),n}queryKeys(e,t){let n=this._allKeys(e,t);if(e.prefix!=null){let o=e.prefix;n=ot(n,s=>s.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,s)=>ot(o,s),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,s)=>qi(o,s),n)),e.offset!=null){let o=e.offset,s=0;n=ot(n,()=>s++>=o)}return e.limit!=null&&(n=jo(n,e.limit)),n}};var Uo=class extends Jt{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 Ki();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 Se(e),value:t}}*_allKeys(){for(let e of this.data.keys())yield new Se(e)}};var U6=new Se(vp);var j6=Ke("datastore:core:tiered");async function wb(r={}){let e=r.datastore??new Uo,t=r.blockstore??new Lo,n=new $i({...r,datastore:e,blockstore:t,blockBrokers:r.blockBrokers??[Pa()],routers:r.routers??[jc("https://delegated-ipfs.dev")]});return r.start!==!1&&await n.start(),n}return Op(bb);})();
9
9
  /*! Bundled license information:
10
10
 
11
11
  pvtsutils/build/index.js: