@helia/http 1.0.1-6c88ee1 → 1.0.1-7a7c0c1

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 gp=Object.create;var Co=Object.defineProperty;var wp=Object.getOwnPropertyDescriptor;var bp=Object.getOwnPropertyNames;var xp=Object.getPrototypeOf,Ep=Object.prototype.hasOwnProperty;var Ar=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),ge=(r,e)=>{for(var t in e)Co(r,t,{get:e[t],enumerable:!0})},gu=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of bp(e))!Ep.call(r,o)&&o!==t&&Co(r,o,{get:()=>e[o],enumerable:!(n=wp(e,o))||n.enumerable});return r};var yt=(r,e,t)=>(t=r!=null?gp(xp(r)):{},gu(e||!r||!r.__esModule?Co(t,"default",{value:r,enumerable:!0}):t,r)),vp=r=>gu(Co({},"__esModule",{value:!0}),r);var Vu=Ar((Db,Ou)=>{var Yr=1e3,Zr=Yr*60,Jr=Zr*60,Sr=Jr*24,um=Sr*7,lm=Sr*365.25;Ou.exports=function(r,e){e=e||{};var t=typeof r;if(t==="string"&&r.length>0)return fm(r);if(t==="number"&&isFinite(r))return e.long?dm(r):hm(r);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(r))};function fm(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*lm;case"weeks":case"week":case"w":return t*um;case"days":case"day":case"d":return t*Sr;case"hours":case"hour":case"hrs":case"hr":case"h":return t*Jr;case"minutes":case"minute":case"mins":case"min":case"m":return t*Zr;case"seconds":case"second":case"secs":case"sec":case"s":return t*Yr;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return t;default:return}}}}function hm(r){var e=Math.abs(r);return e>=Sr?Math.round(r/Sr)+"d":e>=Jr?Math.round(r/Jr)+"h":e>=Zr?Math.round(r/Zr)+"m":e>=Yr?Math.round(r/Yr)+"s":r+"ms"}function dm(r){var e=Math.abs(r);return e>=Sr?Po(r,e,Sr,"day"):e>=Jr?Po(r,e,Jr,"hour"):e>=Zr?Po(r,e,Zr,"minute"):e>=Yr?Po(r,e,Yr,"second"):r+" ms"}function Po(r,e,t,n){var o=e>=t*1.5;return Math.round(r/t)+" "+n+(o?"s":"")}});var Mu=Ar((Pb,Fu)=>{function pm(r){t.debug=t,t.default=t,t.coerce=c,t.disable=i,t.enable=o,t.enabled=s,t.humanize=Vu(),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}Fu.exports=pm});var Hu=Ar((He,Oo)=>{He.formatArgs=ym;He.save=gm;He.load=wm;He.useColors=mm;He.storage=bm();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 mm(){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 ym(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+Oo.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 gm(r){try{r?He.storage.setItem("debug",r):He.storage.removeItem("debug")}catch{}}function wm(){let r;try{r=He.storage.getItem("debug")}catch{}return!r&&typeof process<"u"&&"env"in process&&(r=process.env.DEBUG),r}function bm(){try{return localStorage}catch{}}Oo.exports=Mu()(He);var{formatters:xm}=Oo.exports;xm.j=function(r){try{return JSON.stringify(r)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}});var nn=Ar((n1,sl)=>{"use strict";function il(r,e){for(let t in e)Object.defineProperty(r,t,{value:e[t],enumerable:!0,configurable:!0});return r}function t0(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 il(r,t)}catch{t.message=r.message,t.stack=r.stack;let o=function(){};return o.prototype=Object.create(Object.getPrototypeOf(r)),il(new o,t)}}sl.exports=t0});var ef=Ar(vn=>{"use strict";var qy="[object ArrayBuffer]",Ft=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===qy}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}},lc="string",zy=/^[0-9a-f]+$/i,Gy=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,jy=/^[a-zA-Z0-9-_]+$/,di=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 i=0;i<t.length;i++)n+=String.fromCharCode(t[i]);return decodeURIComponent(escape(n))}},Qe=class{static toString(e,t=!1){let n=Ft.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}},pi=class r{static isHex(e){return typeof e===lc&&zy.test(e)}static isBase64(e){return typeof e===lc&&Gy.test(e)}static isBase64Url(e){return typeof e===lc&&jy.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 di.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 di.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 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,"")||""}};pi.DEFAULT_UTF8_ENCODING="utf8";function Wy(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 Yy(...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 Zy(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}vn.BufferSourceConverter=Ft;vn.Convert=pi;vn.assign=Wy;vn.combine=Yy;vn.isEqual=Zy});var Sc=Ar((xB,kc)=>{var bB=function(){typeof kc<"u"&&(kc.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 kd=Ar((r8,Oc)=>{"use strict";var yw=Object.prototype.hasOwnProperty,Oe="~";function Bo(){}Object.create&&(Bo.prototype=Object.create(null),new Bo().__proto__||(Oe=!1));function gw(r,e,t){this.fn=r,this.context=e,this.once=t||!1}function Ad(r,e,t,n,o){if(typeof t!="function")throw new TypeError("The listener must be a function");var i=new gw(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 bs(r,e){--r._eventsCount===0?r._events=new Bo:delete r._events[e]}function Ce(){this._events=new Bo,this._eventsCount=0}Ce.prototype.eventNames=function(){var e=[],t,n;if(this._eventsCount===0)return e;for(n in t=this._events)yw.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 Ad(this,e,t,n,!1)};Ce.prototype.once=function(e,t,n){return Ad(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 bs(this,i),this;var s=this._events[i];if(s.fn)s.fn===t&&(!o||s.once)&&(!n||s.context===n)&&bs(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:bs(this,i)}return this};Ce.prototype.removeAllListeners=function(e){var t;return e?(t=Oe?Oe+e:e,this._events[t]&&bs(this,t)):(this._events=new Bo,this._eventsCount=0),this};Ce.prototype.off=Ce.prototype.removeListener;Ce.prototype.addListener=Ce.prototype.on;Ce.prefixed=Oe;Ce.EventEmitter=Ce;typeof Oc<"u"&&(Oc.exports=Ce)});var sb={};ge(sb,{createHeliaHTTP:()=>ib});function kr(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 Bp(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=Bp;function Ap(r){return r[Symbol.asyncIterator]!=null}function wu(r){return r?.then!=null}function kp(r,e){if(Ap(r))return async function*(){for await(let a of r){let c=e(a);wu(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);wu(c)&&await c,yield a}}();let s=e;return function*(){yield n;for(let a of t)s(a),yield a}()}var Fs=kp;var qs={};ge(qs,{base32:()=>Ae,base32hex:()=>Lp,base32hexpad:()=>Dp,base32hexpadupper:()=>Pp,base32hexupper:()=>Up,base32pad:()=>Np,base32padupper:()=>Cp,base32upper:()=>ku,base32z:()=>Op});var hb=new Uint8Array(0);function bu(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 xu(r){return new TextEncoder().encode(r)}function Eu(r){return new TextDecoder().decode(r)}function Sp(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 Ip=Sp,Rp=Ip,Bu=Rp;var Ms=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")}},Hs=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 Au(this,e)}},$s=class{decoders;constructor(e){this.decoders=e}or(e){return Au(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 Au(r,e){return new $s({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var Ks=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 Ms(e,t,n),this.decoder=new Hs(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 Ks(r,e,t,n)}function Jt({name:r,prefix:e,alphabet:t}){let{encode:n,decode:o}=Bu(t,r);return zr({prefix:e,name:r,encode:n,decode:i=>Rt(o(i))})}function _p(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 Tp(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 zr({prefix:e,name:r,encode(o){return Tp(o,n,t)},decode(o){return _p(o,n,t,r)}})}var Ae=le({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),ku=le({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Np=le({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Cp=le({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Lp=le({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Up=le({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Dp=le({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Pp=le({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Op=le({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var zs={};ge(zs,{base58btc:()=>he,base58flickr:()=>Vp});var he=Jt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Vp=Jt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Fp=Ru,Su=128,Mp=127,Hp=~Mp,$p=Math.pow(2,31);function Ru(r,e,t){e=e||[],t=t||0;for(var n=t;r>=$p;)e[t++]=r&255|Su,r/=128;for(;r&Hp;)e[t++]=r&255|Su,r>>>=7;return e[t]=r|0,Ru.bytes=t-n+1,e}var Kp=Gs,qp=128,Iu=127;function Gs(r,n){var t=0,n=n||0,o=0,i=n,s,a=r.length;do{if(i>=a)throw Gs.bytes=0,new RangeError("Could not decode varint");s=r[i++],t+=o<28?(s&Iu)<<o:(s&Iu)*Math.pow(2,o),o+=7}while(s>=qp);return Gs.bytes=i-n,t}var zp=Math.pow(2,7),Gp=Math.pow(2,14),jp=Math.pow(2,21),Wp=Math.pow(2,28),Yp=Math.pow(2,35),Zp=Math.pow(2,42),Jp=Math.pow(2,49),Xp=Math.pow(2,56),Qp=Math.pow(2,63),em=function(r){return r<zp?1:r<Gp?2:r<jp?3:r<Wp?4:r<Yp?5:r<Zp?6:r<Jp?7:r<Xp?8:r<Qp?9:10},tm={encode:Fp,decode:Kp,encodingLength:em},rm=tm,Fn=rm;function Mn(r,e=0){return[Fn.decode(r,e),Fn.decode.bytes]}function Gr(r,e,t=0){return Fn.encode(r,e,t),e}function jr(r){return Fn.encodingLength(r)}function gt(r,e){let t=e.byteLength,n=jr(r),o=n+jr(t),i=new Uint8Array(o+t);return Gr(r,i,0),Gr(t,i,n),i.set(e,o),new Wr(r,t,e,i)}function wt(r){let e=Rt(r),[t,n]=Mn(e),[o,i]=Mn(e.subarray(n)),s=e.subarray(n+i);if(s.byteLength!==o)throw new Error("Incorrect length");return new Wr(t,o,s,e)}function _u(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&bu(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 Tu(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return om(t,js(r),e??he.encoder);default:return im(t,js(r),e??Ae.encoder)}}var Nu=new WeakMap;function js(r){let e=Nu.get(r);if(e==null){let t=new Map;return Nu.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!==Hn)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==sm)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&&_u(e.multihash,n.multihash)}toString(e){return Tu(this,e)}toJSON(){return{"/":Tu(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??Cu(n,o,i.bytes))}else if(t[am]===!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!==Hn)throw new Error(`Version 0 CID must use dag-pb (code: ${Hn}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let o=Cu(e,t,n.bytes);return new r(e,t,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Hn,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 i=o.subarray(t.multihashSize-t.digestSize),s=new Wr(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]=Mn(e.subarray(t));return t+=p,l},o=n(),i=Hn;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]=nm(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 js(i).set(n,e),i}};function nm(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 om(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 im(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 Hn=112,sm=18;function Cu(r,e,t){let n=jr(r),o=n+jr(e),i=new Uint8Array(o+t.byteLength);return Gr(r,i,0),Gr(e,i,n),i.set(t,o),i}var am=Symbol.for("@ipld/js-cid/CID");var $n=Symbol.for("@libp2p/content-routing");var Ws=Symbol.for("@libp2p/peer-id");function Lu(r){return r!=null&&!!r[Ws]}var Kn=Symbol.for("@libp2p/peer-routing");var Xt=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 Uo=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 cm(e,t))}},Ys=class extends Event{detail;constructor(e,t){super(e,t),this.detail=t?.detail}},cm=globalThis.CustomEvent??Ys;var Do=(r,...e)=>{try{[...e]}catch{}};function Uu(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function Qt(...r){let e=[];for(let t of r)Uu(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 er(...r){let e=[];for(let t of r)Uu(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 Qs={};ge(Qs,{sha256:()=>we,sha512:()=>Xs});function Js({name:r,code:e,encode:t}){return new Zs(r,e,t)}var Zs=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 Pu(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var we=Js({name:"sha2-256",code:18,encode:Pu("SHA-256")}),Xs=Js({name:"sha2-512",code:19,encode:Pu("SHA-512")});var $e=yt(Hu(),1);var ea={};ge(ea,{base64:()=>tr,base64pad:()=>Em,base64url:()=>vm,base64urlpad:()=>Bm});var tr=le({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Em=le({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),vm=le({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Bm=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":tr.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 Am(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 $u(){return{forComponent(r){return Ke(r)}}}function Ke(r){let e=Am(`${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 Ir(r){return globalThis.Buffer!=null?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r}function it(r=0){return globalThis.Buffer?.allocUnsafe!=null?Ir(globalThis.Buffer.allocUnsafe(r)):new Uint8Array(r)}var km=Math.pow(2,7),Sm=Math.pow(2,14),Im=Math.pow(2,21),ta=Math.pow(2,28),ra=Math.pow(2,35),na=Math.pow(2,42),oa=Math.pow(2,49),te=128,_e=127;function Ve(r){if(r<km)return 1;if(r<Sm)return 2;if(r<Im)return 3;if(r<ta)return 4;if(r<ra)return 5;if(r<na)return 6;if(r<oa)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ia(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 Rm(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 sa(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)*ta,t<te)||(t=r[e+5],n+=(t&_e)*ra,t<te)||(t=r[e+6],n+=(t&_e)*na,t<te)||(t=r[e+7],n+=(t&_e)*oa,t<te))return n;throw new RangeError("Could not decode varint")}function _m(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)*ta,t<te)||(t=r.get(e+5),n+=(t&_e)*ra,t<te)||(t=r.get(e+6),n+=(t&_e)*na,t<te)||(t=r.get(e+7),n+=(t&_e)*oa,t<te))return n;throw new RangeError("Could not decode varint")}function Xr(r,e,t=0){return e==null&&(e=it(Ve(r))),e instanceof Uint8Array?ia(r,e,t):Rm(r,e,t)}function Rr(r,e=0){return r instanceof Uint8Array?sa(r,e):_m(r,e)}var aa=new Float32Array([-0]),rr=new Uint8Array(aa.buffer);function qu(r,e,t){aa[0]=r,e[t]=rr[0],e[t+1]=rr[1],e[t+2]=rr[2],e[t+3]=rr[3]}function zu(r,e){return rr[0]=r[e],rr[1]=r[e+1],rr[2]=r[e+2],rr[3]=r[e+3],aa[0]}var ca=new Float64Array([-0]),Te=new Uint8Array(ca.buffer);function Gu(r,e,t){ca[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 ju(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],ca[0]}var Tm=BigInt(Number.MAX_SAFE_INTEGER),Nm=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<Tm&&e>Nm)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>Wu&&(o=0n,++n>Wu&&(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 Wu=4294967296n;function Yu(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 Zu(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 ua(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 st(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function Vo(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var la=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,st(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 st(this,4);return Vo(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw st(this,4);return Vo(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw st(this,4);let e=zu(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw st(this,4);let e=ju(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 st(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return Zu(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw st(this,e);this.pos+=e}else do if(this.pos>=this.len)throw st(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 st(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 st(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 st(this,8);let e=Vo(this.buf,this.pos+=4),t=Vo(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=sa(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 fa(r){return new la(r instanceof Uint8Array?r:r.subarray())}function Qr(r,e,t){let n=fa(r);return e.decode(n,void 0,t)}var ha={};ge(ha,{base10:()=>Cm});var Cm=Jt({prefix:"9",name:"base10",alphabet:"0123456789"});var da={};ge(da,{base16:()=>Lm,base16upper:()=>Um});var Lm=le({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Um=le({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var pa={};ge(pa,{base2:()=>Dm});var Dm=le({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ma={};ge(ma,{base256emoji:()=>Mm});var Xu=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}"),Pm=Xu.reduce((r,e,t)=>(r[t]=e,r),[]),Om=Xu.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function Vm(r){return r.reduce((e,t)=>(e+=Pm[t],e),"")}function Fm(r){let e=[];for(let t of r){let n=Om[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var Mm=zr({prefix:"\u{1F680}",name:"base256emoji",encode:Vm,decode:Fm});var ya={};ge(ya,{base36:()=>nr,base36upper:()=>Hm});var nr=Jt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Hm=Jt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ga={};ge(ga,{base8:()=>$m});var $m=le({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var wa={};ge(wa,{identity:()=>Km});var Km=zr({prefix:"\0",name:"identity",encode:r=>Eu(r),decode:r=>xu(r)});var ux=new TextEncoder,lx=new TextDecoder;var Qu=512;var Fo=85;var xa={};ge(xa,{identity:()=>Je});var tl=0,qm="identity",rl=Rt;function zm(r){return gt(tl,rl(r))}var Je={code:tl,name:qm,encode:rl,digest:zm};var or={...wa,...pa,...ga,...ha,...da,...qs,...ya,...zs,...ea,...ma},vx={...Qs,...xa};function ol(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var nl=ol("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Ea=ol("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}),Gm={utf8:nl,"utf-8":nl,hex:or.base16,latin1:Ea,ascii:Ea,binary:Ea,...or},Mo=Gm;function G(r,e="utf8"){let t=Mo[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?Ir(globalThis.Buffer.from(r,"utf-8")):t.decoder.decode(`${t.prefix}${r}`)}function va(r){let e=r??8192,t=e>>>1,n,o=e;return function(s){if(s<1||s>t)return it(s);o+s>e&&(n=it(e),o=0);let a=n.subarray(o,o+=s);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 Ba(){}var ka=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},jm=va();function Wm(r){return globalThis.Buffer!=null?it(r):jm(r)}var zn=class{len;head;tail;states;constructor(){this.len=0,this.head=new Tr(Ba,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 Sa((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(Ho,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(Ho,t.length(),t)}uint64Number(e){return this._push(ia,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(Ho,t.length(),t)}sint64Number(e){let t=qe.fromNumber(e).zzEncode();return this._push(Ho,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(Aa,1,e?1:0)}fixed32(e){return this._push(qn,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=qe.fromBigInt(e);return this._push(qn,4,t.lo)._push(qn,4,t.hi)}fixed64Number(e){let t=qe.fromNumber(e);return this._push(qn,4,t.lo)._push(qn,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(qu,4,e)}double(e){return this._push(Gu,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(Aa,1,0):this.uint32(t)._push(Zm,t,e)}string(e){let t=Yu(e);return t!==0?this.uint32(t)._push(ua,t,e):this._push(Aa,1,0)}fork(){return this.states=new ka(this),this.head=this.tail=new Tr(Ba,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(Ba,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=Wm(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function Aa(r,e,t){e[t]=r&255}function Ym(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var Sa=class extends Tr{next;constructor(e,t){super(Ym,e,t),this.next=void 0}};function Ho(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 qn(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 Zm(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(Jm,e,r),this},zn.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(Xm,e,r),this});function Jm(r,e,t){e.set(r,t)}function Xm(r,e,t){r.length<40?ua(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(G(r),t)}function Ia(){return new zn}function en(r,e){let t=Ia();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var tn;(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"})(tn||(tn={}));function $o(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function Gn(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 $o("enum",tn.VARINT,t,n)}function rn(r,e){return $o("message",tn.LENGTH_DELIMITED,r,e)}function Qm(r){return r[Symbol.asyncIterator]!=null}function e0(r){if(Qm(r))return(async()=>{for await(let e of r);})();for(let e of r);}var Tt=e0;function Le(r,e){if(globalThis.Buffer!=null)return Ir(globalThis.Buffer.concat(r,e));e==null&&(e=r.reduce((o,i)=>o+i.length,0));let t=it(e),n=0;for(let o of r)t.set(o,n),n+=o.length;return Ir(t)}function r0(r){return r[Symbol.asyncIterator]!=null}function n0(r,e){if(r0(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 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 jn=n0;function Ue(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var Ko=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}},on=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new Ko(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 Ko(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 Ra=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function Nt(r={}){return o0(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 o0(r,e){e=e??{};let t=e.onEnd,n=new on,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 on,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 on,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 Ra)},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 i0(r){return r[Symbol.asyncIterator]!=null}function s0(...r){let e=[];for(let t of r)i0(t)||e.push(t);return e.length===r.length?function*(){for(let t of e)yield*t}():async function*(){let t=Nt({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 ir=s0;function a0(r){return r[Symbol.asyncIterator]!=null}function c0(r,e){return a0(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 qo=c0;var se=class extends Event{constructor(e,t){super(e),this.detail=t}};function j(r,e="utf8"){let t=Mo[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 zo=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 Go=class{gateways;log;constructor(e,t={}){this.log=e.logger.forComponent("helia:trustless-gateway-block-broker"),this.gateways=(t.gateways??al).map(n=>new zo(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 al=["https://trustless-gateway.link","https://cloudflare-ipfs.com","https://4everland.io"];function _a(r={}){return e=>new Go(e,r)}var u0=Symbol.for("nodejs.util.inspect.custom"),cl=Object.values(or).map(r=>r.decoder).reduce((r,e)=>r.or(e),or.identity.decoder),ul=114,Ta=36,Na=37,Wn=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()})`}[Ws]=!0;toString(){return this.string==null&&(this.string=he.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return ee.createV1(ul,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 Nr(e).equals(this);if(e?.multihash?.bytes!=null)return oe(this.multihash.bytes,e.multihash.bytes);throw new Error("not valid Id")}[u0](){return`PeerId(${this.toString()})`}},sn=class extends Wn{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},an=class extends Wn{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.multihash.digest}},cn=class extends Wn{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.multihash.digest}};function Nr(r,e){if(e=e??cl,r.charAt(0)==="1"||r.charAt(0)==="Q"){let t=wt(he.decode(`z${r}`));return r.startsWith("12D")?new an({multihash:t}):r.startsWith("16U")?new cn({multihash:t}):new sn({multihash:t})}return Yn(cl.decode(r))}function Yn(r){try{let e=wt(r);if(e.code===Je.code){if(e.digest.length===Ta)return new an({multihash:e});if(e.digest.length===Na)return new cn({multihash:e})}if(e.code===we.code)return new sn({multihash:e})}catch{return l0(ee.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function l0(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==ul)throw new Error("Supplied PeerID CID is invalid");let e=r.multihash;if(e.code===we.code)return new sn({multihash:r.multihash});if(e.code===Je.code){if(e.digest.length===Ta)return new an({multihash:r.multihash});if(e.digest.length===Na)return new cn({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function ll(r,e){return r.length===Ta?new an({multihash:gt(Je.code,r),privateKey:e}):r.length===Na?new cn({multihash:gt(Je.code,r),privateKey:e}):new sn({multihash:await we.digest(r),publicKey:r,privateKey:e})}var jo=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 fl=45,f0=15,un=new jo;function Ca(r){if(!(r.length>f0))return un.new(r).parseWith(()=>un.readIPv4Addr())}function La(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>fl))return un.new(r).parseWith(()=>un.readIPv6Addr())}function Wo(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>fl))return un.new(r).parseWith(()=>un.readIPAddr())}var W1=parseInt("0xFFFF",16),Y1=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function pl(r){return!!Ca(r)}function ml(r){return!!La(r)}function Yo(r){return!!Wo(r)}var yl=pl,y0=ml,Ua=function(r){let e=0;if(r=r.toString().trim(),yl(r)){let t=new Uint8Array(e+4);return r.split(/\./g).forEach(n=>{t[e++]=parseInt(n,10)&255}),t}if(y0(r)){let t=r.split(":",8),n;for(n=0;n<t.length;n++){let i=yl(t[n]),s;i&&(s=Ua(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")},gl=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 ln={},Da={},w0=[[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"]];w0.forEach(r=>{let e=b0(...r);Da[e.code]=e,ln[e.name]=e});function b0(r,e,t,n,o){return{code:r,size:e,name:t,resolvable:!!n,path:!!o}}function ie(r){if(typeof r=="number"){if(Da[r]!=null)return Da[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(ln[r]!=null)return ln[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var CE=ie("ip4"),LE=ie("ip6"),UE=ie("ipcidr");function Oa(r,e){switch(ie(r).code){case 4:case 41:return E0(e);case 42:return xl(e);case 6:case 273:case 33:case 132:return vl(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return xl(e);case 421:return k0(e);case 444:return El(e);case 445:return El(e);case 466:return A0(e);default:return j(e,"base16")}}function Va(r,e){switch(ie(r).code){case 4:return wl(e);case 41:return wl(e);case 42:return bl(e);case 6:case 273:case 33:case 132:return Fa(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return bl(e);case 421:return v0(e);case 444:return S0(e);case 445:return I0(e);case 466:return B0(e);default:return G(e,"base16")}}var Pa=Object.values(or).map(r=>r.decoder),x0=function(){let r=Pa[0].or(Pa[1]);return Pa.slice(2).forEach(e=>r=r.or(e)),r}();function wl(r){if(!Yo(r))throw new Error("invalid ip address");return Ua(r)}function E0(r){let e=gl(r,0,r.length);if(e==null)throw new Error("ipBuff is required");if(!Yo(e))throw new Error("invalid ip address");return e}function Fa(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,r),new Uint8Array(e)}function vl(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function bl(r){let e=G(r),t=Uint8Array.from(Xr(e.length));return Le([t,e],t.length+e.length)}function xl(r){let e=Rr(r);if(r=r.slice(Ve(e)),r.length!==e)throw new Error("inconsistent lengths");return j(r)}function v0(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(Xr(e.length));return Le([t,e],t.length+e.length)}function B0(r){let e=x0.decode(r),t=Uint8Array.from(Xr(e.length));return Le([t,e],t.length+e.length)}function A0(r){let e=Rr(r),t=r.slice(Ve(e));if(t.length!==e)throw new Error("inconsistent lengths");return"u"+j(t,"base64url")}function k0(r){let e=Rr(r),t=r.slice(Ve(e));if(t.length!==e)throw new Error("inconsistent lengths");return j(t,"base58btc")}function S0(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=Fa(n);return Le([t,o],t.length+o.length)}function I0(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=Fa(n);return Le([t,o],t.length+o.length)}function El(r){let e=r.slice(0,r.length-2),t=r.slice(r.length-2),n=j(e,"base32"),o=vl(t);return`${n}:${o}`}function Bl(r){r=Ma(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 kl("invalid address: "+r);if(a.path===!0){n=Ma(o.slice(i).join("/")),e.push([a.code,Va(a.code,n)]),t.push([a.code,n]);break}let c=Va(a.code,o[i]);e.push([a.code,c]),t.push([a.code,Oa(a.code,c)])}return{string:Al(t),bytes:$a(e),tuples:e,stringTuples:t,path:n}}function Ha(r){let e=[],t=[],n=null,o=0;for(;o<r.length;){let i=Rr(r,o),s=Ve(i),a=ie(i),c=R0(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 kl("Invalid address Uint8Array: "+j(r,"base16"));e.push([i,f]);let u=Oa(i,f);if(t.push([i,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:Al(t),tuples:e,stringTuples:t,path:n}}function Al(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}),Ma(e.join("/"))}function $a(r){return Le(r.map(e=>{let t=ie(e[0]),n=Uint8Array.from(Xr(t.code));return e.length>1&&e[1]!=null&&(n=Le([n,e[1]])),n}))}function R0(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 Ma(r){return"/"+r.trim().split("/").filter(e=>e).join("/")}function kl(r){return new Error("Error parsing address: "+r)}var _0=Symbol.for("nodejs.util.inspect.custom"),Ka=Symbol.for("@multiformats/js-multiaddr/multiaddr"),T0=[ie("dns").code,ie("dns4").code,ie("dns6").code,ie("dnsaddr").code],Zo=class r{bytes;#e;#t;#r;#s;[Ka]=!0;constructor(e){e==null&&(e="");let t;if(e instanceof Uint8Array)t=Ha(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(Il(e))t=Ha(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??""}`),T0.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($a(t.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,o])=>{n===ln.p2p.code&&e.push([n,o]),n===ln["p2p-circuit"].code&&(e=[])});let t=e.pop();if(t?.[1]!=null){let n=t[1];return n[0]==="Q"||n[0]==="1"?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=Sl.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)}[_0](){return`Multiaddr(${this.#e})`}};var Sl=new Map;function Il(r){return!!r?.[Ka]}function qa(r){return new Zo(r)}async function*Jo(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 cc={};ge(cc,{Ed25519PrivateKey:()=>Dr,Ed25519PublicKey:()=>Xn,generateKeyPair:()=>Hy,generateKeyPairFromSeed:()=>Ql,unmarshalEd25519PrivateKey:()=>Fy,unmarshalEd25519PublicKey:()=>My});function Xe(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function fn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`Wrong positive integer: ${r}`)}function N0(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function za(r,...e){if(!N0(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 Xo(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");fn(r.outputLen),fn(r.blockLen)}function hn(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 Rl(r,e){za(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var Qo=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function _l(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var pn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),at=(r,e)=>r<<32-e|r>>>e,C0=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!C0)throw new Error("Non little-endian hardware is not supported");var L0=async()=>{};async function Tl(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 L0(),n+=i)}}function Ga(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function sr(r){if(typeof r=="string"&&(r=Ga(r)),!_l(r))throw new Error(`expected Uint8Array, got ${typeof r}`);return r}function ei(...r){let e=0;for(let n=0;n<r.length;n++){let o=r[n];if(!_l(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 dn=class{clone(){return this._cloneInto()}},U0={}.toString;function Nl(r,e){if(e!==void 0&&U0.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function ti(r){let e=n=>r().update(sr(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function mn(r=32){if(Qo&&typeof Qo.getRandomValues=="function")return Qo.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function D0(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 yn=class extends dn{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=pn(this.buffer)}update(e){hn(this);let{view:t,buffer:n,blockLen:o}=this;e=sr(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=pn(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){hn(this),Rl(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;D0(n,o-8,BigInt(this.length*8),i),this.process(n,0);let a=pn(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 ri=BigInt(4294967295),ja=BigInt(32);function Cl(r,e=!1){return e?{h:Number(r&ri),l:Number(r>>ja&ri)}:{h:Number(r>>ja&ri)|0,l:Number(r&ri)|0}}function P0(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}=Cl(r[o],e);[t[o],n[o]]=[i,s]}return[t,n]}var O0=(r,e)=>BigInt(r>>>0)<<ja|BigInt(e>>>0),V0=(r,e,t)=>r>>>t,F0=(r,e,t)=>r<<32-t|e>>>t,M0=(r,e,t)=>r>>>t|e<<32-t,H0=(r,e,t)=>r<<32-t|e>>>t,$0=(r,e,t)=>r<<64-t|e>>>t-32,K0=(r,e,t)=>r>>>t-32|e<<64-t,q0=(r,e)=>e,z0=(r,e)=>r,G0=(r,e,t)=>r<<t|e>>>32-t,j0=(r,e,t)=>e<<t|r>>>32-t,W0=(r,e,t)=>e<<t-32|r>>>64-t,Y0=(r,e,t)=>r<<t-32|e>>>64-t;function Z0(r,e,t,n){let o=(e>>>0)+(n>>>0);return{h:r+t+(o/2**32|0)|0,l:o|0}}var J0=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),X0=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,Q0=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),ey=(r,e,t,n,o)=>e+t+n+o+(r/2**32|0)|0,ty=(r,e,t,n,o)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(o>>>0),ry=(r,e,t,n,o,i)=>e+t+n+o+i+(r/2**32|0)|0;var ny={fromBig:Cl,split:P0,toBig:O0,shrSH:V0,shrSL:F0,rotrSH:M0,rotrSL:H0,rotrBH:$0,rotrBL:K0,rotr32H:q0,rotr32L:z0,rotlSH:G0,rotlSL:j0,rotlBH:W0,rotlBL:Y0,add:Z0,add3L:J0,add3H:X0,add4L:Q0,add4H:ey,add5H:ry,add5L:ty},q=ny;var[oy,iy]=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))),ar=new Uint32Array(80),cr=new Uint32Array(80),Wa=class extends yn{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)ar[v]=e.getUint32(t),cr[v]=e.getUint32(t+=4);for(let v=16;v<80;v++){let U=ar[v-15]|0,S=cr[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=ar[v-2]|0,N=cr[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,cr[v-7],cr[v-16]),$=q.add4H(F,_,O,ar[v-7],ar[v-16]);ar[v]=$|0,cr[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,iy[v],cr[v]),N=q.add5H(w,g,U,_,oy[v],ar[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(){ar.fill(0),cr.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 gn=ti(()=>new Wa);var oi={};ge(oi,{bitGet:()=>hy,bitLen:()=>fy,bitMask:()=>Zn,bitSet:()=>dy,bytesToHex:()=>Lt,bytesToNumberBE:()=>Ut,bytesToNumberLE:()=>ur,concatBytes:()=>Dt,createHmacDrbg:()=>Ja,ensureBytes:()=>fe,equalBytes:()=>uy,hexToBytes:()=>Cr,hexToNumber:()=>Za,isBytes:()=>ct,numberToBytesBE:()=>lr,numberToBytesLE:()=>Lr,numberToHexUnpadded:()=>Pl,numberToVarBytesBE:()=>cy,utf8ToBytes:()=>ly,validateObject:()=>bt});var Dl=BigInt(0),ni=BigInt(1),sy=BigInt(2);function ct(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var ay=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function Lt(r){if(!ct(r))throw new Error("Uint8Array expected");let e="";for(let t=0;t<r.length;t++)e+=ay[r[t]];return e}function Pl(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function Za(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Ct={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Ll(r){if(r>=Ct._0&&r<=Ct._9)return r-Ct._0;if(r>=Ct._A&&r<=Ct._F)return r-(Ct._A-10);if(r>=Ct._a&&r<=Ct._f)return r-(Ct._a-10)}function Cr(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=Ll(r.charCodeAt(i)),a=Ll(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 Ut(r){return Za(Lt(r))}function ur(r){if(!ct(r))throw new Error("Uint8Array expected");return Za(Lt(Uint8Array.from(r).reverse()))}function lr(r,e){return Cr(r.toString(16).padStart(e*2,"0"))}function Lr(r,e){return lr(r,e).reverse()}function cy(r){return Cr(Pl(r))}function fe(r,e,t){let n;if(typeof e=="string")try{n=Cr(e)}catch(i){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${i}`)}else if(ct(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 Dt(...r){let e=0;for(let o=0;o<r.length;o++){let i=r[o];if(!ct(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 uy(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 ly(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function fy(r){let e;for(e=0;r>Dl;r>>=ni,e+=1);return e}function hy(r,e){return r>>BigInt(e)&ni}var dy=(r,e,t)=>r|(t?ni:Dl)<<BigInt(e),Zn=r=>(sy<<BigInt(r-1))-ni,Ya=r=>new Uint8Array(r),Ul=r=>Uint8Array.from(r);function Ja(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=Ya(r),o=Ya(r),i=0,s=()=>{n.fill(1),o.fill(0),i=0},a=(...l)=>t(o,n,...l),c=(l=Ya())=>{o=a(Ul([0]),l),n=a(),l.length!==0&&(o=a(Ul([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 Dt(...p)};return(l,p)=>{s(),c(l);let E;for(;!(E=p(f()));)c();return s(),E}}var py={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"||ct(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=py[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),Ur=BigInt(2),my=BigInt(3),Xa=BigInt(4),Ol=BigInt(5),Vl=BigInt(8),yy=BigInt(9),gy=BigInt(16);function ne(r,e){let t=r%e;return t>=be?t:e+t}function wy(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 ii(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 by(r){let e=(r-ae)/Ur,t,n,o;for(t=r-ae,n=0;t%Ur===be;t/=Ur,n++);for(o=Ur;o<r&&wy(o,e,r)!==r-ae;o++);if(n===1){let s=(r+ae)/Xa;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)/Ur;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 xy(r){if(r%Xa===my){let e=(r+ae)/Xa;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%Vl===Ol){let e=(r-Ol)/Vl;return function(n,o){let i=n.mul(o,Ur),s=n.pow(i,e),a=n.mul(o,s),c=n.mul(n.mul(a,Ur),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%gy,by(r)}var Fl=(r,e)=>(ne(r,e)&ae)===ae,Ey=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Qa(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=Ey.reduce((n,o)=>(n[o]="function",n),e);return bt(r,t)}function vy(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 By(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 ec(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function si(r,e,t=!1,n={}){if(r<=be)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:o,nByteLength:i}=ec(r,e);if(i>2048)throw new Error("Field lengths over 2048 bytes are not supported");let s=xy(r),a=Object.freeze({ORDER:r,BITS:o,BYTES:i,MASK:Zn(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)=>vy(a,c,f),div:(c,f)=>ne(c*ii(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>ii(c,r),sqrt:n.sqrt||(c=>s(a,c)),invertBatch:c=>By(a,c),cmov:(c,f,u)=>u?f:c,toBytes:c=>t?Lr(c,i):lr(c,i),fromBytes:c=>{if(c.length!==i)throw new Error(`Fp.fromBytes: expected ${i}, got ${c.length}`);return t?ur(c):Ut(c)}});return Object.freeze(a)}function Ml(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 Hl(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 tc(r){let e=Hl(r);return e+Math.ceil(e/2)}function $l(r,e,t=!1){let n=r.length,o=Hl(e),i=tc(e);if(n<16||n<i||n>1024)throw new Error(`expected ${i}-1024 bytes of input, got ${n}`);let s=t?Ut(r):ur(r),a=ne(s,e-ae)+ae;return t?Lr(a,o):lr(a,o)}var ky=BigInt(0),rc=BigInt(1);function ai(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>ky;)i&rc&&(s=s.add(a)),a=a.double(),i>>=rc;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+=rc);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 Jn(r){return Qa(r.Fp),bt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...ec(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var ut=BigInt(0),ze=BigInt(1),ci=BigInt(2),Sy=BigInt(8),Iy={zip215:!0};function Ry(r){let e=Jn(r);return bt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function ui(r){let e=Ry(r),{Fp:t,n,prehash:o,hash:i,randomBytes:s,nByteLength:a,h:c}=e,f=ci<<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:ut}}}),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"&&ut<A,d=(A,b)=>y(A)&&y(b)&&A<b,m=A=>A===ut||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===ut?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(ci*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),It=u(pe*Be),Br=u(ve*ue);return new S(ye,Re,Br,It)}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 lu=u((z-K)*(X+Z)),fu=u((z+K)*(X-Z)),Vs=u(fu-lu);if(Vs===ut)return this.double();let hu=u(W*ci*ue),du=u(re*ci*pe),pu=du+hu,mu=fu+lu,yu=du-hu,dp=u(pu*Vs),pp=u(mu*yu),mp=u(pu*yu),yp=u(Vs*mu);return new S(dp,pp,yp,mp)}let ve=u(K*Z),Be=u(z*X),ye=u(re*M*ue),Re=u(W*pe),It=u((K+z)*(Z+X)-ve-Be),Br=Re-ye,Vn=Re+ye,uu=u(Be-P*ve),up=u(It*Br),lp=u(Vn*uu),fp=u(It*uu),hp=u(Br*Vn);return new S(up,lp,hp,fp)}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,z=this.is0();b==null&&(b=z?Sy:t.inv(K));let W=u(P*b),re=u(M*b),Z=u(K*b);if(z)return{x:ut,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=ur(W);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: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===ut&&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=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=ai(S,a*8);function N(A){return ne(A,n)}function O(A){return N(ur(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=Dt(...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=Dt(re,Lr(X,t.BYTES));return fe("result",pe,a*2)}let x=Iy;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=ur(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 oc=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Kl=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Lv=BigInt(0),_y=BigInt(1),nc=BigInt(2),Ty=BigInt(5),ql=BigInt(10),Ny=BigInt(20),Cy=BigInt(40),zl=BigInt(80);function Ly(r){let e=oc,n=r*r%e*r%e,o=ce(n,nc,e)*n%e,i=ce(o,_y,e)*r%e,s=ce(i,Ty,e)*i%e,a=ce(s,ql,e)*s%e,c=ce(a,Ny,e)*a%e,f=ce(c,Cy,e)*c%e,u=ce(f,zl,e)*f%e,l=ce(u,zl,e)*f%e,p=ce(l,ql,e)*s%e;return{pow_p_5_8:ce(p,nc,e)*r%e,b2:n}}function Uy(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Dy(r,e){let t=oc,n=ne(e*e*e,t),o=ne(n*n*e,t),i=Ly(r*o).pow_p_5_8,s=ne(r*n*i,t),a=ne(e*s*s,t),c=s,f=ne(s*Kl,t),u=a===r,l=a===ne(-r,t),p=a===ne(-r*Kl,t);return u&&(s=c),(l||p)&&(s=f),Fl(s,t)&&(s=ne(-s,t)),{isValid:u||l,value:s}}var Pt=si(oc,void 0,!0),ic={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Pt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:gn,randomBytes:mn,adjustScalarBytes:Uy,uvRatio:Dy},wn=ui(ic);function Gl(r,e,t){if(e.length>255)throw new Error("Context is too big");return ei(Ga("SigEd25519 no Ed25519 collisions"),new Uint8Array([t?1:0,e.length]),e,r)}var Uv=ui({...ic,domain:Gl}),Dv=ui({...ic,domain:Gl,prehash:gn});var Py=(Pt.ORDER+BigInt(3))/BigInt(8),Pv=Pt.pow(nc,Py),Ov=Pt.sqrt(Pt.neg(Pt.ONE)),Vv=(Pt.ORDER-BigInt(5))/BigInt(8),Fv=BigInt(486662);var Mv=Ml(Pt,Pt.neg(BigInt(486664)));var Hv=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),$v=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),Kv=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),qv=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var zv=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var bn=32,Ot=64,li=32;function jl(){let r=wn.utils.randomPrivateKey(),e=wn.getPublicKey(r);return{privateKey:Jl(r,e),publicKey:e}}function Wl(r){if(r.length!==li)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=wn.getPublicKey(e);return{privateKey:Jl(e,t),publicKey:t}}function Yl(r,e){let t=r.subarray(0,li);return wn.sign(e instanceof Uint8Array?e:e.subarray(),t)}function Zl(r,e,t){return wn.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function Jl(r,e){let t=new Uint8Array(Ot);for(let n=0;n<li;n++)t[n]=r[n],t[li+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 sc={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Xl(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",sc,{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",sc,{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",sc,{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 xn(r,e){let n=await Xl().encrypt(r,e);return tr.encode(n)}var de;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(de||(de={}));var ac;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(ac||(ac={}));(function(r){r.codec=()=>Gn(ac)})(de||(de={}));var xt;(function(r){let e;r.codec=()=>(e==null&&(e=rn((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=>en(t,r.codec()),r.decode=t=>Qr(t,r.codec())})(xt||(xt={}));var Vt;(function(r){let e;r.codec=()=>(e==null&&(e=rn((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=>en(t,r.codec()),r.decode=t=>Qr(t,r.codec())})(Vt||(Vt={}));var Xn=class{_key;constructor(e){this._key=En(e,bn)}verify(e,t){return Zl(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}},Dr=class{_key;_publicKey;constructor(e,t){this._key=En(e,Ot),this._publicKey=En(t,bn)}sign(e){return Yl(this._key,e)}get public(){return new Xn(this._publicKey)}marshal(){return this._key}get bytes(){return Vt.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 xn(this.bytes,e);throw new C(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Fy(r){if(r.length>Ot){r=En(r,Ot+bn);let n=r.subarray(0,Ot),o=r.subarray(Ot,r.length);return new Dr(n,o)}r=En(r,Ot);let e=r.subarray(0,Ot),t=r.subarray(bn);return new Dr(e,t)}function My(r){return r=En(r,bn),new Xn(r)}async function Hy(){let{privateKey:r,publicKey:e}=jl();return new Dr(r,e)}async function Ql(r){let{privateKey:e,publicKey:t}=Wl(r);return new Dr(e,t)}function En(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 wc={};ge(wc,{MAX_RSA_KEY_SIZE:()=>lo,RsaPrivateKey:()=>Sn,RsaPublicKey:()=>uo,fromJwk:()=>pg,generateKeyPair:()=>mg,unmarshalRsaPrivateKey:()=>yc,unmarshalRsaPublicKey:()=>dg});function Pr(r){if(isNaN(r)||r<=0)throw new C("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return mn(r)}var pr={};ge(pr,{exportToPem:()=>cg,importFromPem:()=>ug,jwkToPkcs1:()=>og,jwkToPkix:()=>sg,pkcs1ToJwk:()=>ng,pkixToJwk:()=>ig});var hi=class extends dn{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,Xo(e);let n=sr(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 hn(this),this.iHash.update(e),this}digestInto(e){hn(this),za(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()}},Qn=(r,e,t)=>new hi(r,e).update(t).digest();Qn.create=(r,e)=>new hi(r,e);function $y(r,e,t,n){Xo(r);let o=Nl({dkLen:32,asyncTick:10},n),{c:i,dkLen:s,asyncTick:a}=o;if(fn(i),fn(s),fn(a),i<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=sr(e),f=sr(t),u=new Uint8Array(s),l=Qn.create(r,c),p=l._cloneInto().update(f);return{c:i,dkLen:s,asyncTick:a,DK:u,PRF:l,PRFSalt:p}}function Ky(r,e,t,n,o){return r.destroy(),e.destroy(),n&&n.destroy(),o.fill(0),t}async function uc(r,e,t,n){let{c:o,dkLen:i,asyncTick:s,DK:a,PRF:c,PRFSalt:f}=$y(r,e,t,n),u,l=new Uint8Array(4),p=pn(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 Tl(o-1,s,()=>{c._cloneInto(u).update(E).digestInto(E);for(let g=0;g<m.length;g++)m[g]^=E[g]})}return Ky(c,f,a,u,E)}var Y=yt(ef());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 fr(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 mi(...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 fc(){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),i=new Uint8Array(o);for(let a=0;a<this.valueHex.byteLength;a++)i[a]=r[a];return i[0]&=127,Or(i,8)-n}function tf(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=fr(s,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=fr(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 rf(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 b2=Math.log(2);function yi(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function hc(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 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 to=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return hc(this.items)}},eo=[new Uint8Array([1])],nf="0123456789";var An="",ft=new ArrayBuffer(0),dc=new Uint8Array(0),ro="EndOfContent",sf="OCTET STRING",af="BIT STRING";function qt(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):dc}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(!Kt(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",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=An,warnings:n=[],valueBeforeDecode:o=dc}={}){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 Ne=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'")}};Ne.NAME="valueBlock";var gi=class extends qt(Mt){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):dc,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",ft}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=fr(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(!Kt(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=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}}};gi.NAME="identificationBlock";var wi=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 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=Or(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=fr(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 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}}};wi.NAME="lengthBlock";var D={},ke=class extends Mt{constructor({name:e=An,optional:t=!1,primitiveSchema:n,...o}={},i){super(o),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new gi(o),this.lenBlock=new wi(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 to;t||cf(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?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 rf(t,n)}};ke.NAME="BaseBlock";function cf(r){if(r instanceof D.Constructed)for(let e of r.valueBlock.value)cf(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var bi=class extends ke{constructor({value:e=An,...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}'`}};bi.NAME="BaseStringBlock";var xi=class extends qt(Ne){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};xi.NAME="PrimitiveValueBlock";var uf,Ei=class extends ke{constructor(e={}){super(e,xi),this.idBlock.isConstructed=!1}};uf=Ei;D.Primitive=uf;Ei.NAME="PRIMITIVE";function Xy(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 es(r,e=0,t=r.length){let n=e,o=new ke({},Ne),i=new Mt;if(!Kt(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=Xy(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 kn(r){if(!r.byteLength){let e=new ke({},Ne);return e.error="Input buffer has zero length",{offset:-1,result:e}}return es(Y.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function Qy(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(!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 i=t;for(;Qy(this.isIndefiniteForm,n)>0;){let s=es(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===ro)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===ro?this.value.pop():this.warnings.push("No EndOfContent block encoded")),i}toBER(e,t){let n=t||new to;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}};Et.NAME="ConstructedValueBlock";var lf,hr=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(`
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} :`}};lf=hr;D.Constructed=lf;hr.NAME="CONSTRUCTED";var vi=class extends Ne{fromBER(e,t,n){return t}toBER(e){return ft}};vi.override="EndOfContentValueBlock";var ff,Bi=class extends ke{constructor(e={}){super(e,vi),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ff=Bi;D.EndOfContent=ff;Bi.NAME=ro;var hf,dr=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}`}};hf=dr;D.Null=hf;dr.NAME="NULL";var Ai=class extends qt(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 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,fc.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Ai.NAME="BooleanValueBlock";var df,ki=class extends ke{constructor(e={}){super(e,Ai),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}`}};df=ki;D.Boolean=df;ki.NAME="BOOLEAN";var Si=class extends qt(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===ro){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(s!==sf)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}}};Si.NAME="OctetStringValueBlock";var pf,Ht=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},Si),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=es(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?hr.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)}};pf=Ht;D.OctetString=pf;Ht.NAME=sf;var Ii=class extends qt(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===ro){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==af)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(!Kt(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=es(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 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}}};Ii.NAME="BitStringValueBlock";var mf,Bn=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},Ii),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 hr.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)}`}}};mf=Bn;D.BitString=mf;Bn.NAME=af;var yf;function eg(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=mi(new Uint8Array([f%10]),i);break;default:i[s-l]=f%10}}return t[0]>0&&(i=mi(t,i)),i}function of(r){if(r>=eo.length)for(let e=eo.length;e<=r;e++){let t=new Uint8Array([0]),n=eo[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=mi(t,n)),eo.push(n)}return eo[r]}function tg(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 no=class extends qt(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=fc.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(tf(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=tg(of(n),t),s="-";break;default:t=eg(t,of(n))}n++,o>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(s+=nf.charAt(t[c]));return a===!1&&(s+=nf.charAt(0)),s}};yf=no;no.NAME="IntegerValueBlock";Object.defineProperty(yf.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var gf,me=class r extends ke{constructor(e={}){super(e,no),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return yi(),BigInt(this.valueBlock.toString())}static fromBigInt(e){yi();let t=BigInt(e),n=new to,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()}`}};gf=me;D.Integer=gf;me.NAME="INTEGER";var wf,Ri=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};wf=Ri;D.Enumerated=wf;Ri.NAME="ENUMERATED";var oo=class extends qt(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(!Kt(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=Or(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){yi();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=fr(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),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}}};oo.NAME="sidBlock";var _i=class extends Ne{constructor({value:e=An,...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.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,ft;t.push(o)}return hc(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 oo;if(o>Number.MAX_SAFE_INTEGER){yi();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}};_i.NAME="ObjectIdentifierValueBlock";var bf,lt=class extends ke{constructor(e={}){super(e,_i),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()}}};bf=lt;D.ObjectIdentifier=bf;lt.NAME="OBJECT IDENTIFIER";var io=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 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=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,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=fr(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),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}}};io.NAME="relativeSidBlock";var Ti=class extends Ne{constructor({value:e=An,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let i=new io;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,ft;n.push(i)}return hc(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 io;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}};Ti.NAME="RelativeObjectIdentifierValueBlock";var xf,Ni=class extends ke{constructor(e={}){super(e,Ti),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};xf=Ni;D.RelativeObjectIdentifier=xf;Ni.NAME="RelativeObjectIdentifier";var Ef,xe=class extends hr{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Ef=xe;D.Sequence=Ef;xe.NAME="SEQUENCE";var vf,Ci=class extends hr{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};vf=Ci;D.Set=vf;Ci.NAME="SET";var Li=class extends qt(Ne){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=An}toJSON(){return{...super.toJSON(),value:this.value}}};Li.NAME="StringValueBlock";var Ui=class extends Li{};Ui.NAME="SimpleStringValueBlock";var Pe=class extends bi{constructor({...e}={}){super(e,Ui)}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 Di=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}};Di.NAME="Utf8StringValueBlock";var Bf,$t=class extends Di{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Bf=$t;D.Utf8String=Bf;$t.NAME="UTF8String";var Pi=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))}};Pi.NAME="BmpStringValueBlock";var Af,Oi=class extends Pi{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Af=Oi;D.BmpString=Af;Oi.NAME="BMPString";var Vi=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=fr(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}};Vi.NAME="UniversalStringValueBlock";var kf,Fi=class extends Vi{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};kf=Fi;D.UniversalString=kf;Fi.NAME="UniversalString";var Sf,Mi=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Sf=Mi;D.NumericString=Sf;Mi.NAME="NumericString";var If,Hi=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};If=Hi;D.PrintableString=If;Hi.NAME="PrintableString";var Rf,$i=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Rf=$i;D.TeletexString=Rf;$i.NAME="TeletexString";var _f,Ki=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};_f=Ki;D.VideotexString=_f;Ki.NAME="VideotexString";var Tf,qi=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Tf=qi;D.IA5String=Tf;qi.NAME="IA5String";var Nf,zi=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Nf=zi;D.GraphicString=Nf;zi.NAME="GraphicString";var Cf,so=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Cf=so;D.VisibleString=Cf;so.NAME="VisibleString";var Lf,Gi=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Lf=Gi;D.GeneralString=Lf;Gi.NAME="GeneralString";var Uf,ji=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Uf=ji;D.CharacterString=Uf;ji.NAME="CharacterString";var Df,ao=class extends so{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}}};Df=ao;D.UTCTime=Df;ao.NAME="UTCTime";var Pf,Wi=class extends ao{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}}};Pf=Wi;D.GeneralizedTime=Pf;Wi.NAME="GeneralizedTime";var Of,Yi=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Of=Yi;D.DATE=Of;Yi.NAME="DATE";var Vf,Zi=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Vf=Zi;D.TimeOfDay=Vf;Zi.NAME="TimeOfDay";var Ff,Ji=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Ff=Ji;D.DateTime=Ff;Ji.NAME="DateTime";var Mf,Xi=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Mf=Xi;D.Duration=Mf;Xi.NAME="Duration";var Hf,Qi=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Hf=Qi;D.TIME=Hf;Qi.NAME="TIME";function ng(r){let{result:e}=kn(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 og(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 ig(r){let{result:e}=kn(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 sg(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 lt({value:"1.2.840.113549.1.1.1"}),new dr]}),new Bn({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 ag=16,pc=32,mc=1e4;async function cg(r,e){let t=De.get(),o=new xe({value:[new me({value:0}),new xe({value:[new lt({value:"1.2.840.113549.1.1.1"}),new dr]}),new Ht({valueHex:r.marshal()})]}).toBER(),i=new Uint8Array(o,0,o.byteLength),s=Pr(ag),a=await uc(gn,e,s,{c:mc,dkLen:pc}),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,i),l=new xe({value:[new Ht({valueHex:s}),new me({value:mc}),new me({value:pc}),new xe({value:[new lt({value:"1.2.840.113549.2.11"}),new dr]})]}),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-----",...j(d,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
8
+ `)}async function ug(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}=kn(o),{iv:s,salt:a,iterations:c,keySize:f,cipherText:u}=lg(i),l=await uc(gn,e,a,{c,dkLen:f}),p=await t.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),E=co(await t.subtle.decrypt({name:"AES-CBC",iv:s},p,u)),{result:y}=kn(E);n=$f(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}=kn(o);n=$f(i)}else throw new C("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return yc(n)}function lg(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=co(i.valueBlock.value[0].getValue()),a=mc,c=pc;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=co(f.valueBlock.value[1].getValue());return{cipherText:co(r.valueBlock.value[1].getValue()),salt:s,iterations:a,keySize:c,iv:l}}function $f(r){return co(r.valueBlock.value[2].getValue())}function co(r){return new Uint8Array(r,0,r.byteLength)}async function Kf(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 Gf(e);return{privateKey:t[0],publicKey:t[1]}}async function gc(r){let t=[await De.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await fg(r)],n=await Gf({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function qf(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 zf(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 Gf(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 fg(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 ts(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 lo=8192,uo=class{_key;constructor(e){this._key=e}verify(e,t){return zf(this._key,t,e)}marshal(){return pr.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}},Sn=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 C("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new uo(this._publicKey)}marshal(){return pr.jwkToPkcs1(this._key)}get bytes(){return Vt.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 pr.exportToPem(this,e);if(t==="libp2p-key")return xn(this.bytes,e);throw new C(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function yc(r){let e=pr.pkcs1ToJwk(r);if(ts(e)>lo)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await gc(e);return new Sn(t.privateKey,t.publicKey)}function dg(r){let e=pr.pkixToJwk(r);if(ts(e)>lo)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new uo(e)}async function pg(r){if(ts(r)>lo)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await gc(r);return new Sn(e.privateKey,e.publicKey)}async function mg(r){if(r>lo)throw new C("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Kf(r);return new Sn(e.privateKey,e.publicKey)}var Bc={};ge(Bc,{Secp256k1PrivateKey:()=>ho,Secp256k1PublicKey:()=>fo,generateKeyPair:()=>Tg,unmarshalSecp256k1PrivateKey:()=>Rg,unmarshalSecp256k1PublicKey:()=>_g});var yg=(r,e,t)=>r&e^~r&t,gg=(r,e,t)=>r&e^r&t^e&t,wg=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]),mr=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),yr=new Uint32Array(64),bc=class extends yn{constructor(){super(64,32,8,!1),this.A=mr[0]|0,this.B=mr[1]|0,this.C=mr[2]|0,this.D=mr[3]|0,this.E=mr[4]|0,this.F=mr[5]|0,this.G=mr[6]|0,this.H=mr[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)yr[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let p=yr[l-15],E=yr[l-2],y=at(p,7)^at(p,18)^p>>>3,d=at(E,17)^at(E,19)^E>>>10;yr[l]=d+yr[l-7]+y+yr[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=at(a,6)^at(a,11)^at(a,25),E=u+p+yg(a,c,f)+wg[l]+yr[l]|0,d=(at(n,2)^at(n,13)^at(n,22))+gg(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(){yr.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var jf=ti(()=>new bc);function bg(r){let e=Jn(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:xg,hexToBytes:Eg}=oi,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:xg(n),l:r.subarray(t+2)}},toSig(r){let{Err:e}=Vr,t=typeof r=="string"?Eg(r):r;if(!ct(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}=Vr._parseInt(t.subarray(2)),{d:s,l:a}=Vr._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}`}},zt=BigInt(0),et=BigInt(1),z2=BigInt(2),Wf=BigInt(3),G2=BigInt(4);function vg(r){let e=bg(r),{Fp:t}=e,n=e.toBytes||((y,d,m)=>{let g=d.toAffine();return Dt(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"&&zt<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(ct(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:Ut(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,Wf),{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,Wf),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===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:U,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()),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,_)=>_===zt||_===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 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=ai(l,e.endo?Math.ceil(p/2):p);return{CURVE:e,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:s}}function Bg(r){let e=Jn(r);return bt(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function Yf(r){let e=Bg(r),{Fp:t,n}=e,o=t.BYTES+1,i=2*t.BYTES+1;function s(x){return zt<x&&x<t.ORDER}function a(x){return ne(x,n)}function c(x){return ii(x,n)}let{ProjectivePoint:f,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:p}=vg({...e,toBytes(x,k,H){let A=k.toAffine(),b=t.toBytes(A.x),P=Dt;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=Ut(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=>Lt(lr(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)=>Ut(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}=Vr.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 Cr(this.toDERHex())}toDERHex(){return Vr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Cr(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=tc(e.n);return $l(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=ct(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=Ut(x),H=x.length*8-e.nBitLength;return H>0?k>>BigInt(H):k},L=e.bits2int_modN||function(x){return a(_(x))},w=Zn(e.nBitLength);function N(x){if(typeof x!="bigint")throw new Error("bigint expected");if(!(zt<=x&&x<w))throw new Error(`bigint expected < 2^${e.nBitLength}`);return lr(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=Dt(...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===zt)return;let It=a(Be*a(X+Re*W));if(It===zt)return;let Br=(ye.x===Re?0:2)|Number(ye.y&et),Vn=It;return P&&y(It)&&(Vn=d(It),Br^=1),new g(Re,Vn,Br)}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 Ja(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"||ct(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");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 Ag(r){return{hash:r,hmac:(e,...t)=>Qn(r,e,ei(...t)),randomBytes:mn}}function Zf(r,e){let t=n=>Yf({...r,...Ag(n)});return Object.freeze({...t(e),create:t})}var Qf=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Jf=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),kg=BigInt(1),xc=BigInt(2),Xf=(r,e)=>(r+e/xc)/e;function Sg(r){let e=Qf,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,xc,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,xc,e);if(!Ec.eql(Ec.sqr(_),r))throw new Error("Cannot find square root");return _}var Ec=si(Qf,void 0,void 0,{sqrt:Sg}),ht=Zf({a:BigInt(0),b:BigInt(7),Fp:Ec,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=-kg*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=t,s=BigInt("0x100000000000000000000000000000000"),a=Xf(i*r,e),c=Xf(-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}}}},jf),tB=BigInt(0);var rB=ht.ProjectivePoint;function eh(){return ht.utils.randomPrivateKey()}function th(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 C(String(n),"ERR_INVALID_INPUT")});try{return ht.sign(t.digest,r).toDERRawBytes()}catch(n){throw new C(String(n),"ERR_INVALID_INPUT")}}function rh(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 C(String(o),"ERR_INVALID_INPUT")});try{return ht.verify(e,n.digest,r)}catch(o){throw new C(String(o),"ERR_INVALID_INPUT")}}function nh(r){return ht.ProjectivePoint.fromHex(r).toRawBytes(!0)}function oh(r){try{ht.getPublicKey(r,!0)}catch(e){throw new C(String(e),"ERR_INVALID_PRIVATE_KEY")}}function vc(r){try{ht.ProjectivePoint.fromHex(r)}catch(e){throw new C(String(e),"ERR_INVALID_PUBLIC_KEY")}}function ih(r){try{return ht.getPublicKey(r,!0)}catch(e){throw new C(String(e),"ERR_INVALID_PRIVATE_KEY")}}var fo=class{_key;constructor(e){vc(e),this._key=e}verify(e,t){return rh(this._key,t,e)}marshal(){return nh(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}},ho=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??ih(e),oh(this._key),vc(this._publicKey)}sign(e){return th(this._key,e)}get public(){return new fo(this._publicKey)}marshal(){return this._key}get bytes(){return Vt.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 xn(this.bytes,e);throw new C(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Rg(r){return new ho(r)}function _g(r){return new fo(r)}async function Tg(){let r=eh();return new ho(r)}var rs={rsa:wc,ed25519:cc,secp256k1:Bc};function Ng(r){let e=Object.keys(rs).join(" / ");return new C(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function Ac(r){let e=xt.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case de.RSA:return rs.rsa.unmarshalRsaPublicKey(t);case de.Ed25519:return rs.ed25519.unmarshalEd25519PublicKey(t);case de.Secp256k1:return rs.secp256k1.unmarshalSecp256k1PublicKey(t);default:throw Ng(e.Type??"unknown")}}var fw=yt(nn(),1);var Gt="/",sh=new TextEncoder().encode(Gt),ns=sh[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]!==ns)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(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=sh),this._buf[0]!==ns){let e=new Uint8Array(this._buf.byteLength+1);e.fill(ns,0,1),e.set(this._buf,1),this._buf=e}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===ns;)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(Gt).slice(1)}type(){return Cg(this.baseNamespace())}name(){return Lg(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(),...Ug(e.map(t=>t.namespaces()))])}};function Cg(r){let e=r.split(":");return e.length<2?"":e.slice(0,-1).join(":")}function Lg(r){let e=r.split(":");return e[e.length-1]}function Ug(r){return[].concat(...r)}var hw=yt(Sc(),1);var ah="ERR_IPNS_EXPIRED_RECORD",os="ERR_UNRECOGNIZED_VALIDITY";var jt="ERR_SIGNATURE_VERIFICATION";var Ic="ERR_UNDEFINED_PARAMETER",ch="ERR_INVALID_RECORD_DATA",uh="ERR_INVALID_VALUE",lh="ERR_INVALID_EMBEDDED_KEY";var fh="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=()=>Gn(t)}(e=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=rn((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=>en(o,r.codec()),r.decode=o=>Qr(o,r.codec())})(dt||(dt={}));var Dg=["string","number","bigint","symbol"],Pg=["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 dh(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let e=typeof r;if(Dg.includes(e))return e;if(e==="function")return"Function";if(Array.isArray(r))return"Array";if(Og(r))return"Buffer";let t=Vg(r);return t||"Object"}function Og(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function Vg(r){let e=Object.prototype.toString.call(r).slice(8,-1);if(Pg.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 In=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",Fg=new TextDecoder,Mg=new TextEncoder;function is(r){return In&&globalThis.Buffer.isBuffer(r)}function po(r){return r instanceof Uint8Array?is(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var gh=In?(r,e,t)=>t-e>64?globalThis.Buffer.from(r.subarray(e,t)).toString("utf8"):mh(r,e,t):(r,e,t)=>t-e>64?Fg.decode(r.subarray(e,t)):mh(r,e,t),ss=In?r=>r.length>64?globalThis.Buffer.from(r):ph(r):r=>r.length>64?Mg.encode(r):ph(r),At=r=>Uint8Array.from(r),Rn=In?(r,e,t)=>is(r)?new Uint8Array(r.subarray(e,t)):r.slice(e,t):(r,e,t)=>r.slice(e,t),wh=In?(r,e)=>(r=r.map(t=>t instanceof Uint8Array?t:globalThis.Buffer.from(t)),po(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},bh=In?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function xh(r,e){if(is(r)&&is(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 ph(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 mh(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 Rc(n)}var yh=4096;function Rc(r){let e=r.length;if(e<=yh)return String.fromCharCode.apply(String,r);let t="",n=0;for(;n<e;)t+=String.fromCharCode.apply(String,r.slice(n,n+=yh));return t}var Hg=256,mo=class{constructor(e=Hg){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=bh(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=Rn(n,0,this.cursor)}else t=wh(this.chunks,this.cursor);return e&&this.reset(),t}};var V="CBOR decode error:",_n="CBOR encode error:",yo=[];yo[23]=1;yo[24]=2;yo[25]=3;yo[26]=5;yo[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],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 Eh(r,e,t,n){return new B(h.uint,Ge(r,e+1,n),2)}function vh(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 Ah(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 kh(r,e,t,n){return new B(h.negint,-1-Ge(r,e+1,n),2)}function Sh(r,e,t,n){return new B(h.negint,-1-je(r,e+1,n),3)}function Ih(r,e,t,n){return new B(h.negint,-1-We(r,e+1,n),5)}var _c=BigInt(-1),Rh=BigInt(1);function _h(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,_c-BigInt(o),9)}function as(r,e){let t=e.value,n=typeof t=="bigint"?t*_c-Rh:t*-1-1;Ie(r,e.type.majorEncoded,n)}as.encodedSize=function(e){let t=e.value,n=typeof t=="bigint"?t*_c-Rh:t*-1-1;return n<Ee[0]?1:n<Ee[1]?2:n<Ee[2]?3:n<Ee[3]?5:9};as.compareTokens=function(e,t){return e.value<t.value?1:e.value>t.value?-1:0};function go(r,e,t,n){Wt(r,e,t+n);let o=Rn(r,e+t,e+t+n);return new B(h.bytes,o,t+n)}function Th(r,e,t,n){return go(r,e,1,t)}function Nh(r,e,t,n){return go(r,e,2,Ge(r,e+1,n))}function Ch(r,e,t,n){return go(r,e,3,je(r,e+1,n))}function Lh(r,e,t,n){return go(r,e,5,We(r,e+1,n))}function Uh(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 go(r,e,9,o)}function cs(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===h.string?ss(r.value):r.value),r.encodedBytes}function Tn(r,e){let t=cs(e);Ie(r,e.type.majorEncoded,t.length),r.push(t)}Tn.encodedSize=function(e){let t=cs(e);return Ie.encodedSize(t.length)+t.length};Tn.compareTokens=function(e,t){return Kg(cs(e),cs(t))};function Kg(r,e){return r.length<e.length?-1:r.length>e.length?1:xh(r,e)}function wo(r,e,t,n,o){let i=t+n;Wt(r,e,i);let s=new B(h.string,gh(r,e+t,e+i),i);return o.retainStringBytes===!0&&(s.byteValue=Rn(r,e+t,e+i)),s}function Dh(r,e,t,n){return wo(r,e,1,t,n)}function Ph(r,e,t,n){return wo(r,e,2,Ge(r,e+1,n),n)}function Oh(r,e,t,n){return wo(r,e,3,je(r,e+1,n),n)}function Vh(r,e,t,n){return wo(r,e,5,We(r,e+1,n),n)}function Fh(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 wo(r,e,9,o,n)}var Mh=Tn;function Nn(r,e,t,n){return new B(h.array,n,t)}function Hh(r,e,t,n){return Nn(r,e,1,t)}function $h(r,e,t,n){return Nn(r,e,2,Ge(r,e+1,n))}function Kh(r,e,t,n){return Nn(r,e,3,je(r,e+1,n))}function qh(r,e,t,n){return Nn(r,e,5,We(r,e+1,n))}function zh(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 Nn(r,e,9,o)}function Gh(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Nn(r,e,1,1/0)}function us(r,e){Ie(r,h.array.majorEncoded,e.value)}us.compareTokens=tt.compareTokens;us.encodedSize=function(e){return Ie.encodedSize(e.value)};function Cn(r,e,t,n){return new B(h.map,n,t)}function jh(r,e,t,n){return Cn(r,e,1,t)}function Wh(r,e,t,n){return Cn(r,e,2,Ge(r,e+1,n))}function Yh(r,e,t,n){return Cn(r,e,3,je(r,e+1,n))}function Zh(r,e,t,n){return Cn(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 Cn(r,e,9,o)}function Xh(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Cn(r,e,1,1/0)}function ls(r,e){Ie(r,h.map.majorEncoded,e.value)}ls.compareTokens=tt.compareTokens;ls.encodedSize=function(e){return Ie.encodedSize(e.value)};function Qh(r,e,t,n){return new B(h.tag,t,1)}function ed(r,e,t,n){return new B(h.tag,Ge(r,e+1,n),2)}function td(r,e,t,n){return new B(h.tag,je(r,e+1,n),3)}function rd(r,e,t,n){return new B(h.tag,We(r,e+1,n),5)}function nd(r,e,t,n){return new B(h.tag,Ye(r,e+1,n),9)}function fs(r,e){Ie(r,h.tag.majorEncoded,e.value)}fs.compareTokens=tt.compareTokens;fs.encodedSize=function(e){return Ie.encodedSize(e.value)};var Yg=20,Zg=21,Jg=22,Xg=23;function od(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 id(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 Tc(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 sd(r,e,t,n){return Tc(Nc(r,e+1),3,n)}function ad(r,e,t,n){return Tc(Cc(r,e+1),5,n)}function cd(r,e,t,n){return Tc(hd(r,e+1),9,n)}function hs(r,e,t){let n=e.value;if(n===!1)r.push([h.float.majorEncoded|Yg]);else if(n===!0)r.push([h.float.majorEncoded|Zg]);else if(n===null)r.push([h.float.majorEncoded|Jg]);else if(n===void 0)r.push([h.float.majorEncoded|Xg]);else{let o,i=!1;(!t||t.float64!==!0)&&(ld(n),o=Nc(pt,1),n===o||Number.isNaN(n)?(pt[0]=249,r.push(pt.slice(0,3)),i=!0):(fd(n),o=Cc(pt,1),n===o&&(pt[0]=250,r.push(pt.slice(0,5)),i=!0))),i||(Qg(n),o=hd(pt,1),pt[0]=251,r.push(pt.slice(0,9)))}}hs.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){ld(n);let o=Nc(pt,1);if(n===o||Number.isNaN(n))return 3;if(fd(n),o=Cc(pt,1),n===o)return 5}return 9};var ud=new ArrayBuffer(9),rt=new DataView(ud,1),pt=new Uint8Array(ud,0);function ld(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 Nc(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 fd(r){rt.setFloat32(0,r,!1)}function Cc(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 Qg(r){rt.setFloat64(0,r,!1)}function hd(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)}hs.compareTokens=tt.compareTokens;function Q(r,e,t){throw new Error(`${V} encountered invalid minor (${t}) for major ${r[e]>>>5}`)}function ds(r){return()=>{throw new Error(`${V} ${r}`)}}var R=[];for(let r=0;r<=23;r++)R[r]=Q;R[24]=Eh;R[25]=vh;R[26]=Bh;R[27]=Ah;R[28]=Q;R[29]=Q;R[30]=Q;R[31]=Q;for(let r=32;r<=55;r++)R[r]=Q;R[56]=kh;R[57]=Sh;R[58]=Ih;R[59]=_h;R[60]=Q;R[61]=Q;R[62]=Q;R[63]=Q;for(let r=64;r<=87;r++)R[r]=Th;R[88]=Nh;R[89]=Ch;R[90]=Lh;R[91]=Uh;R[92]=Q;R[93]=Q;R[94]=Q;R[95]=ds("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)R[r]=Dh;R[120]=Ph;R[121]=Oh;R[122]=Vh;R[123]=Fh;R[124]=Q;R[125]=Q;R[126]=Q;R[127]=ds("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)R[r]=Hh;R[152]=$h;R[153]=Kh;R[154]=qh;R[155]=zh;R[156]=Q;R[157]=Q;R[158]=Q;R[159]=Gh;for(let r=160;r<=183;r++)R[r]=jh;R[184]=Wh;R[185]=Yh;R[186]=Zh;R[187]=Jh;R[188]=Q;R[189]=Q;R[190]=Q;R[191]=Xh;for(let r=192;r<=215;r++)R[r]=Qh;R[216]=ed;R[217]=td;R[218]=rd;R[219]=nd;R[220]=Q;R[221]=Q;R[222]=Q;R[223]=Q;for(let r=224;r<=243;r++)R[r]=ds("simple values are not supported");R[244]=Q;R[245]=Q;R[246]=Q;R[247]=od;R[248]=ds("simple values are not supported");R[249]=sd;R[250]=ad;R[251]=cd;R[252]=Q;R[253]=Q;R[254]=Q;R[255]=id;var mt=[];for(let r=0;r<24;r++)mt[r]=new B(h.uint,r,1);for(let r=-1;r>=-24;r--)mt[31-r]=new B(h.negint,r,1);mt[64]=new B(h.bytes,new Uint8Array(0),1);mt[96]=new B(h.string,"",1);mt[128]=new B(h.array,0,1);mt[160]=new B(h.map,0,1);mt[244]=new B(h.false,!1,1);mt[245]=new B(h.true,!0,1);mt[246]=new B(h.null,null,1);function dd(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 tw={float64:!1,mapSorter:ow,quickEncodeToken:dd};function rw(){let r=[];return r[h.uint.major]=tt,r[h.negint.major]=as,r[h.bytes.major]=Tn,r[h.string.major]=Mh,r[h.array.major]=us,r[h.map.major]=ls,r[h.tag.major]=fs,r[h.float.major]=hs,r}var pd=rw(),Lc=new mo,ms=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(`${_n} object contains circular references`);return new r(t,e)}},gr={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)},wr={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?gr.true:gr.false},null(r,e,t,n){return gr.null},undefined(r,e,t,n){return gr.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?[gr.emptyArray,new B(h.break)]:gr.emptyArray;n=ms.createCheck(n,r);let o=[],i=0;for(let s of r)o[i++]=ps(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?[gr.emptyMap,new B(h.break)]:gr.emptyMap;n=ms.createCheck(n,r);let a=[],c=0;for(let f of i)a[c++]=[ps(f,t,n),ps(o?r.get(f):r[f],t,n)];return nw(a,t),t.addBreakTokens?[new B(h.map,s),a,new B(h.break)]:[new B(h.map,s),a]}};wr.Map=wr.Object;wr.Buffer=wr.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))wr[`${r}Array`]=wr.DataView;function ps(r,e={},t){let n=dh(r),o=e&&e.typeEncoders&&e.typeEncoders[n]||wr[n];if(typeof o=="function"){let s=o(r,n,e,t);if(s!=null)return s}let i=wr[n];if(!i)throw new Error(`${_n} unsupported type: ${n}`);return i(r,n,e,t)}function nw(r,e){e.mapSorter&&r.sort(e.mapSorter)}function ow(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=pd[o].compareTokens(t,n);return i===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),i}function md(r,e,t,n){if(Array.isArray(e))for(let o of e)md(r,o,t,n);else t[e.type.major](r,e,n)}function yd(r,e,t){let n=ps(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 mo(s);if(i(a,n,t),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return po(a.chunks[0])}}return Lc.reset(),md(Lc,n,e,t),Lc.toBytes(!0)}function Ln(r,e){return e=Object.assign({},tw,e),yd(r,pd,e)}var iw={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},Uc=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"),ys=Symbol.for("BREAK");function sw(r,e,t){let n=[];for(let o=0;o<r.value;o++){let i=xo(e,t);if(i===ys){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed array`)}if(i===bo)throw new Error(`${V} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=i}return n}function aw(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=xo(e,t);if(a===ys){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 ${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=xo(e,t);if(c===bo)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 xo(r,e){if(r.done())return bo;let t=r.next();if(t.type===h.break)return ys;if(t.type.terminal)return t.value;if(t.type===h.array)return sw(t,r,e);if(t.type===h.map)return aw(t,r,e);if(t.type===h.tag){if(e.tags&&typeof e.tags[t.value]=="function"){let n=xo(r,e);return e.tags[t.value](n)}throw new Error(`${V} tag not supported (${t.value})`)}throw new Error("unsupported")}function Dc(r,e){if(!(r instanceof Uint8Array))throw new Error(`${V} data to decode must be a Uint8Array`);e=Object.assign({},iw,e);let t=e.tokenizer||new Uc(r,e),n=xo(t,e);if(n===bo)throw new Error(`${V} did not find any content to decode`);if(n===ys)throw new Error(`${V} got unexpected break`);return[n,r.subarray(t.pos())]}function nt(r,e){let[t,n]=Dc(r,e);if(n.length>0)throw new Error(`${V} too many terminals, data makes no sense`);return t}var Ze=yt(nn(),1);var gd=Ke("ipns:utils"),wd=G("/ipns/"),cw=114,bd=async(r,e)=>{if(e==null||r==null){let n=new Error("one or more of the provided parameters are not defined");throw gd.error(n),(0,Ze.default)(n,Ic)}let t;if(e.pubKey!=null){try{t=Ac(e.pubKey)}catch(o){throw gd.error(o),o}if(!(await ll(e.pubKey)).equals(r))throw(0,Ze.default)(new Error("Embedded public key did not match PeerID"),lh)}else r.publicKey!=null&&(t=Ac(r.publicKey));if(t!=null)return t;throw(0,Ze.default)(new Error("no public key is available"),Ic)};var xd=r=>{let e=G("ipns-signature:");return Le([e,r])},Mr=r=>"signatureV1"in r?dt.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}):dt.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data});function kt(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=Ed(e.data),n=uw(t.Value),o=j(t.Validity);if(e.value!=null&&e.signatureV1!=null)return lw(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 Pc=r=>Le([wd,r.toBytes()]),Un=r=>Yn(r.slice(wd.length));var Ed=r=>{let e=nt(r);if(e.ValidityType===0)e.ValidityType=dt.ValidityType.EOL;else throw(0,Ze.default)(new Error("Unknown validity type"),os);return Number.isInteger(e.Sequence)&&(e.Sequence=BigInt(e.Sequence)),Number.isInteger(e.TTL)&&(e.TTL=BigInt(e.TTL)),e},uw=r=>{if(r!=null){if(Lu(r))return`/ipns/${r.toCID().toString(nr)}`;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===cw?`/ipns/${t.toString(nr)}`:`/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 /"),uh)},lw=r=>{if(r.data==null)throw(0,Ze.default)(new Error("Record data is missing"),ch);let e=Ed(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'),jt);if(!oe(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 VA=Ke("ipns"),FA=Je.code,dw="/ipns/",MA=dw.length;var Eo=yt(nn(),1),vd=yt(Sc(),1);var ws=Ke("ipns:validator"),pw=1024*10,mw=async(r,e)=>{let t=kt(e),n;try{let o=xd(t.data);n=await r.verify(o,t.signatureV2)}catch{n=!1}if(!n)throw ws.error("record signature verification failed"),(0,Eo.default)(new Error("record signature verification failed"),jt);if(t.validityType===dt.ValidityType.EOL){if(vd.default.fromString(t.validity).toDate().getTime()<Date.now())throw ws.error("record has expired"),(0,Eo.default)(new Error("record has expired"),ah)}else if(t.validityType!=null)throw ws.error("unrecognized validity type"),(0,Eo.default)(new Error("unrecognized validity type"),os);ws("ipns record for %s is valid",t.value)};async function Bd(r,e){if(e.byteLength>pw)throw(0,Eo.default)(new Error("record too large"),fh);let t=Un(r),n=kt(e),o=await bd(t,n);await mw(o,e)}async function*vo(r){let e=/\r?\n/,t=new TextDecoder("utf8"),n="";for await(let o of r){typeof o=="string"&&(o=new TextEncoder().encode(o)),n+=t.decode(o,{stream:!0});let 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 Vc=yt(kd(),1);var Ao=class extends Error{constructor(e){super(e),this.name="TimeoutError"}},Fc=class extends Error{constructor(e){super(),this.name="AbortError",this.message=e}},Sd=r=>globalThis.DOMException===void 0?new Fc(r):new DOMException(r),Id=r=>{let e=r.reason===void 0?Sd("This operation was aborted."):r.reason;return e instanceof Error?e:Sd(e)};function ko(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(Id(p)),p.addEventListener("abort",()=>{u(Id(p))})}if(t===Number.POSITIVE_INFINITY){r.then(f,u);return}let l=new Ao;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 Mc(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{#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=Mc(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 br=class extends Vc.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:So,...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=ko(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 Ao&&!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 ww(r){return r[Symbol.asyncIterator]!=null}function bw(r){if(ww(r))return(async()=>{for await(let e of r)return e})();for(let e of r)return e}var xs=bw;var Hc=G("/ipns/");function Rd(r){return oe(r.subarray(0,Hc.byteLength),Hc)}var _d=r=>Yn(r.slice(Hc.length)),Es=class{client;constructor(e){this.client=e}async*findProviders(e,t={}){yield*jn(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async put(e,t,n){if(!Rd(e))return;let o=_d(e),i=kt(t);await this.client.putIPNS(o,i,n)}async get(e,t){if(!Rd(e))throw new C("Not found","ERR_NOT_FOUND");let n=_d(e);try{let o=await this.client.getIPNS(n,t);return Mr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new C("Not found","ERR_NOT_FOUND"):o}}},vs=class{client;constructor(e){this.client=e}async findPeer(e,t={}){let n=await xs(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"),Td={concurrentRequests:4,timeout:3e4},Bs=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;constructor(e,t={}){this.started=!1,this.shutDownController=new AbortController,Do(1/0,this.shutDownController.signal),this.httpQueue=new br({concurrency:t.concurrentRequests??Td.concurrentRequests}),this.clientUrl=e instanceof URL?e:new URL(e),this.timeout=t.timeout??Td.timeout,this.contentRouting=new Es(this),this.peerRouting=new vs(this)}get[$n](){return this.contentRouting}get[Kn](){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=kr([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 vo(Jo(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=kr([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 vo(Jo(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=kr([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(Pc(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=kr([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=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 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(qa)??[];return e.Protocols!=null&&t.push(...e.Protocols),e.Protocol!=null&&(t.push(e.Protocol),delete e.Protocol),{...e,Schema:"peer",ID:Nr(e.ID),Addrs:n,Protocols:t}}};function Nd(r,e={}){return new Bs(new URL(r),e)}var Cd=G("/ipns/");function Ld(r){return oe(r.subarray(0,Cd.byteLength),Cd)}var $c=class{client;constructor(e){this.client=Nd(e)}async provide(e,t){}async*findProviders(e,t){yield*jn(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs,protocols:n.Protocols}))}async put(e,t,n){if(!Ld(e))return;let o=Un(e),i=kt(t);await this.client.putIPNS(o,i,n)}async get(e,t){if(!Ld(e))throw new C("Not found","ERR_NOT_FOUND");let n=Un(e);try{let o=await this.client.getIPNS(n,t);return Mr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new C("Not found","ERR_NOT_FOUND"):o}}async findPeer(e,t){let n=await xs(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 Kc(r){return new $c(new URL(r))}var qc=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 As(r,e,t,n){let o=new qc(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 ks=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 Ud(r,e,t){if(e==null)return r;if(e.aborted)return Promise.reject(new ks(t?.errorMessage,t?.errorCode));let n,o=new ks(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 Ss=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 Xt)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function xw(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var Is=class{id;fn;options;priority;recipients;status;timeline;controller;constructor(e,t,n=0){this.id=xw(),this.status="queued",this.fn=e,this.priority=n,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,Do(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 Xt)}async join(e={}){let t=new Ss(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 Ud(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 Ew(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 Io=class extends Uo{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=Ew(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 Is(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 Xt)}),this.clear()}async onEmpty(e){this.size!==0&&await As(this,"empty",e?.signal)}async onSizeLessThan(e,t){this.size<e||await As(this,"next",t?.signal,{filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await As(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=Nt({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 Vd="/pin/",Dd="/pinned-block/",zc=nr,Pd=1;function Od(r){return r.version===0&&(r=r.toV1()),new Se(`${Vd}${r.toString(zc)}`)}var Rs=class{datastore;blockstore;dagWalkers;constructor(e,t,n){this.datastore=e,this.blockstore=t,this.dagWalkers=n}async*add(e,t={}){let n=Od(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 Io({concurrency:Pd});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,Ln(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(`${Dd}${zc.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,Ln(i),n),n.onProgress?.(new se("helia:pin:add",e))}}async*rm(e,t={}){let n=Od(e),o=await this.datastore.get(n,t),i=nt(o);await this.datastore.delete(n,t);let s=new Io({concurrency:Pd});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:Vd+(e.cid!=null?`${e.cid.toString(nr)}`:"")},e)){let o=ee.parse(t.toString().substring(5),nr),i=nt(n);yield{cid:o,...i}}}async isPinned(e,t={}){let n=new Se(`${Dd}${zc.encode(e.multihash.bytes)}`);return this.datastore.has(n,t)}};function Gc(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 Dn=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 Gc(this.set.entries(),e=>{let t=Nr(e[0]);return[t,t]})}forEach(e){this.set.forEach(t=>{let n=Nr(t);e(n,n,this)})}has(e){return this.set.has(e.toString())}values(){return Gc(this.set.values(),e=>Nr(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 _s=class{log;routers;constructor(e,t){this.log=e.logger.forComponent("helia:routing"),this.routers=t.routers??[]}async start(){await Qt(...this.routers)}async stop(){await er(...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 Dn;for await(let o of ir(...Pn(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(Pn(this.routers,"provide").map(async n=>{await n.provide(e,t)}))}async put(e,t,n){await Promise.all(Pn(this.routers,"put").map(async o=>{await o.put(e,t,n)}))}async get(e,t){return Promise.any(Pn(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=ir(...Pn(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 Dn;for await(let o of ir(...Pn(this.routers,"getClosestPeers").map(i=>i.getClosestPeers(e,t))))o!=null&&(n.has(o.id)||(n.add(o.id),yield o))}};function Pn(r,e){return r.filter(t=>t[e]!=null)}var xr={},On=r=>{r.addEventListener("message",e=>{On.dispatchEvent("message",r,e)}),r.port!=null&&r.port.addEventListener("message",e=>{On.dispatchEvent("message",r,e)})};On.addEventListener=(r,e)=>{xr[r]==null&&(xr[r]=[]),xr[r].push(e)};On.removeEventListener=(r,e)=>{xr[r]!=null&&(xr[r]=xr[r].filter(t=>t===e))};On.dispatchEvent=function(r,e,t){xr[r]!=null&&xr[r].forEach(n=>n(e,t))};var jc=On;var Wc="lock:worker:request-read",Yc="lock:worker:release-read",Zc="lock:master:grant-read",Jc="lock:worker:request-write",Xc="lock:worker:release-write",Qc="lock:master:grant-write";var Fd=(r=21)=>Math.random().toString().substring(2);var Md=(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)})}}}))},Hd=(r,e,t,n)=>async()=>{let o=Fd();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)})},vw={singleProcess:!1},$d=r=>{if(r=Object.assign({},vw,r),!!globalThis.document||r.singleProcess){let t=new EventTarget;return jc.addEventListener("message",Md(t,"requestReadLock",Wc,Yc,Zc)),jc.addEventListener("message",Md(t,"requestWriteLock",Jc,Xc,Qc)),t}return{isWorker:!0,readLock:t=>Hd(t,Wc,Zc,Yc),writeLock:t=>Hd(t,Jc,Qc,Xc)}};var Hr={},Er;async function eu(r,e){let t,n=new Promise(o=>{t=o});return r.add(async()=>ko((async()=>{await new Promise(o=>{t(()=>{o()})})})(),{milliseconds:e.timeout})),n}var Bw=(r,e)=>{if(Er.isWorker===!0)return{readLock:Er.readLock(r,e),writeLock:Er.writeLock(r,e)};let t=new br({concurrency:1}),n;return{async readLock(){if(n!=null)return eu(n,e);n=new br({concurrency:e.concurrency,autoStart:!1});let o=n,i=eu(n,e);return t.add(async()=>{o.start(),await o.onIdle().then(()=>{n===o&&(n=null)})}),i},async writeLock(){return n=null,eu(t,e)}}},Aw={name:"lock",concurrency:1/0,timeout:846e5,singleProcess:!1};function tu(r){let e=Object.assign({},Aw,r);return Er==null&&(Er=$d(e),Er.isWorker!==!0&&(Er.addEventListener("requestReadLock",t=>{Hr[t.data.name]!=null&&Hr[t.data.name].readLock().then(async n=>t.data.handler().finally(()=>{n()}))}),Er.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]=Bw(e.name,e)),Hr[e.name]}var Ts=class{lock;child;pins;started;constructor(e,t,n={}){this.child=e,this.pins=t,this.lock=tu({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await Qt(this.child),this.started=!0}async stop(){await er(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 qd=42;function kw(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,qd),new B(h.bytes,t)]}function Sw(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function Iw(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 Kd={float64:!0,typeEncoders:{Object:kw,undefined:Sw,number:Iw}},Hk={...Kd,typeEncoders:{...Kd.typeEncoders}};function Rw(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return ee.decode(r.subarray(1))}var ru={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};ru.tags[qd]=Rw;var $k={...ru,tags:ru.tags.slice()};var zd=113;var Gd=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(`${_n} unsupported type: Uint8Array`)}[h.string.major](e,t){this.prefix(e);let n=ss(JSON.stringify(t.value));e.push(n.length>32?po(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(`${_n} 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 $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 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,Rc(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 Ns(r,e){return e=Object.assign({tokenizer:new $r(r,e)},e),nt(r,e)}var Nw={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Nw.tags[42]=ee.parse;var Wd=297;var iS=new TextDecoder;var sS=new TextEncoder;var Lw=new TextDecoder;function nu(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 Cs(r,e){let t;[t,e]=nu(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 Yd(r,e){let t;return[t,e]=nu(r,e),[t&7,t>>3,e]}function Uw(r){let e={},t=r.length,n=0;for(;n<t;){let o,i;if([o,i,n]=Yd(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]=Cs(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]=Cs(r,n),e.Name=Lw.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]=nu(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 Zd(r){let e=r.length,t=0,n,o=!1,i;for(;t<e;){let a,c;if([a,c,t]=Yd(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]=Cs(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]=Cs(r,t),n.push(Uw(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 cS=new TextEncoder,uS=2**32,lS=2**31;var dS=new TextEncoder;var Jd=112;function Xd(r){let e=Zd(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 Pw={codec:Jd,*walk(r){yield*Xd(r).Links.map(t=>t.Hash)}},Ow={codec:Fo,*walk(){}},Qd=42,Vw={codec:zd,*walk(r){let e=[],t=[];t[Qd]=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}},ou=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 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=tr.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}},Fw={codec:Wd,*walk(r){let e=[],t=[];t[Qd]=n=>{let o=ee.parse(n);return e.push(o),o},Ns(r,{tags:t,tokenizer:new ou(r,{tags:t,allowIndefinite:!0,allowUndefined:!0,allowNaN:!0,allowInfinity:!0,allowBigInt:!0,strict:!1,rejectDuplicateMapKeys:!1})}),yield*e}},Mw={codec:Qu,*walk(){}};function ep(r=[]){let e={};return[Pw,Ow,Vw,Fw,Mw,...r].forEach(t=>{e[t.codec]=t}),e}var iu=new Se("/version"),tp=1;async function rp(r){if(!await r.has(iu)){await r.put(iu,G(`${tp}`));return}let e=await r.get(iu),t=j(e);if(parseInt(t,10)!==tp)throw new Error("Unknown datastore version, a datastore migration may be required")}function np(r=[]){let e={};return[we,Xs,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:()=>zw,closeFailedError:()=>$w,deleteFailedError:()=>au,getFailedError:()=>Kw,hasFailedError:()=>qw,notFoundError:()=>vr,openFailedError:()=>Hw,putFailedError:()=>su});var Yt=yt(nn(),1);function Hw(r){return r=r??new Error("Open failed"),(0,Yt.default)(r,"ERR_OPEN_FAILED")}function $w(r){return r=r??new Error("Close failed"),(0,Yt.default)(r,"ERR_CLOSE_FAILED")}function su(r){return r=r??new Error("Put failed"),(0,Yt.default)(r,"ERR_PUT_FAILED")}function Kw(r){return r=r??new Error("Get failed"),(0,Yt.default)(r,"ERR_GET_FAILED")}function au(r){return r=r??new Error("Delete failed"),(0,Yt.default)(r,"ERR_DELETE_FAILED")}function qw(r){return r=r??new Error("Has failed"),(0,Yt.default)(r,"ERR_HAS_FAILED")}function vr(r){return r=r??new Error("Not Found"),(0,Yt.default)(r,"ERR_NOT_FOUND")}function zw(r){return r=r??new Error("Aborted"),(0,Yt.default)(r,"ERR_ABORTED")}var op=0,Ls=class extends St{put(e){return e}get(e){if(e.code===op)return e.multihash.digest;throw vr()}has(e){return e.code===op}delete(){}*getAll(){}};function Gw(r){return r[Symbol.asyncIterator]!=null}function jw(r,e){if(Gw(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 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 ot=jw;var Ww=Ke("blockstore:core:tiered"),Ro=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 su(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){Ww.error(o)}throw vr()}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 au(n)}}async*putMany(e,t={}){let n,o=this.stores.map(i=>{let s=Nt({objectMode:!0});return Tt(i.putMany(s,t)).catch(a=>{n=a}),s});try{for await(let i of e){if(n!=null)throw n;o.forEach(s=>s.push(i)),yield i.cid}}finally{o.forEach(i=>i.end())}}async*deleteMany(e,t={}){let n,o=this.stores.map(i=>{let s=Nt({objectMode:!0});return Tt(i.deleteMany(s,t)).catch(a=>{n=a}),s});try{for await(let i of e){if(n!=null)throw n;o.forEach(s=>s.push(i)),yield i}}finally{o.forEach(i=>i.end())}}async*getAll(e){let t=new Set;yield*ot(ir(...this.stores.map(n=>n.getAll(e))),n=>{let o=n.cid.toString();return t.has(o)?!1:(t.add(o),!0)})}};function Yw(r){return typeof r.retrieve=="function"}function Zw(r){return typeof r.announce=="function"}var Us=class{child;blockRetrievers;blockAnnouncers;hashers;started;log;constructor(e){this.log=e.logger.forComponent("helia:networked-storage"),this.child=new Ro([new Ls,e.blockstore]),this.blockRetrievers=(e.blockBrokers??[]).filter(Yw),this.blockAnnouncers=(e.blockBrokers??[]).filter(Zw),this.hashers=e.hashers??{},this.started=!1}isStarted(){return this.started}async start(){await Qt(this.child,...new Set([...this.blockRetrievers,...this.blockAnnouncers])),this.started=!0}async stop(){await er(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=ot(e,async({cid:i})=>{let s=await this.child.has(i);return s&&t.onProgress?.(new se("blocks:put-many:duplicate",i)),!s}),o=Fs(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 ip(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(Fs(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 ip(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)}},Jw=(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 ip(r,e,t,n){let o=Jw(r,t),i=new AbortController,s=kr([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 Ds=class{blockstore;datastore;pins;logger;routing;dagWalkers;hashers;log;constructor(e){this.logger=e.logger??$u(),this.log=this.logger.forComponent("helia"),this.hashers=np(e.hashers),this.dagWalkers=ep(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 Us(t);this.pins=new Rs(e.datastore,n,this.dagWalkers),this.blockstore=new Ts(n,this.pins,{holdGcLock:e.holdGcLock??!0}),this.datastore=e.datastore,this.routing=new _s(t,{routers:(e.routers??[]).flatMap(o=>{let i=[o];return o[$n]!=null&&i.push(o[$n]),o[Kn]!=null&&i.push(o[Kn]),i})})}async start(){await rp(this.datastore),await Qt(this.blockstore,this.datastore,this.routing)}async stop(){await er(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: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 _o=class extends St{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 vr();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(Fo,wt(Ae.decode(e))),block:t}}};var EI={...Kr};var sp=yt(nn(),1);function Ps(r){return r=r??new Error("Not Found"),(0,sp.default)(r,"ERR_NOT_FOUND")}var ap="SHARDING";function Qw(r){return r[Symbol.asyncIterator]!=null}function eb(r){if(Qw(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 cu=eb;function tb(r){return r[Symbol.asyncIterator]!=null}function rb(r,e){return tb(r)?async function*(){yield*(await cu(r)).sort(e)}():function*(){yield*cu(r).sort(e)}()}var Os=rb;var Zt=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,i=>i.key.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,i)=>ot(o,i),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,i)=>Os(o,i),n)),e.offset!=null){let o=0,i=e.offset;n=ot(n,()=>o++>=i)}return e.limit!=null&&(n=qo(n,e.limit)),n}queryKeys(e,t){let n=this._allKeys(e,t);if(e.prefix!=null){let o=e.prefix;n=ot(n,i=>i.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,i)=>ot(o,i),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,i)=>Os(o,i),n)),e.offset!=null){let o=e.offset,i=0;n=ot(n,()=>i++>=o)}return e.limit!=null&&(n=qo(n,e.limit)),n}};var No=class extends Zt{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 Ps();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 ZI=new Se(ap);var c6=Ke("datastore:core:tiered");async function ib(r={}){let e=r.datastore??new No,t=r.blockstore??new _o,n=new Ds({...r,datastore:e,blockstore:t,blockBrokers:r.blockBrokers??[_a()],routers:r.routers??[Kc("https://delegated-ipfs.dev")]});return r.start!==!1&&await n.start(),n}return vp(sb);})();
9
9
  /*! Bundled license information:
10
10
 
11
11
  pvtsutils/build/index.js: