@helia/http 1.0.1 → 1.0.2-8c9bb7d

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 _p=Object.create;var Do=Object.defineProperty;var Cp=Object.getOwnPropertyDescriptor;var Np=Object.getOwnPropertyNames;var Lp=Object.getPrototypeOf,Up=Object.prototype.hasOwnProperty;var Xt=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),ge=(r,e)=>{for(var t in e)Do(r,t,{get:e[t],enumerable:!0})},Bu=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Np(e))!Up.call(r,o)&&o!==t&&Do(r,o,{get:()=>e[o],enumerable:!(n=Cp(e,o))||n.enumerable});return r};var st=(r,e,t)=>(t=r!=null?_p(Lp(r)):{},Bu(e||!r||!r.__esModule?Do(t,"default",{value:r,enumerable:!0}):t,r)),Dp=r=>Bu(Do({},"__esModule",{value:!0}),r);var zu=Xt((Zb,qu)=>{var Jr=1e3,Xr=Jr*60,Qr=Xr*60,Ir=Qr*24,vm=Ir*7,Am=Ir*365.25;qu.exports=function(r,e){e=e||{};var t=typeof r;if(t==="string"&&r.length>0)return Bm(r);if(t==="number"&&isFinite(r))return e.long?Sm(r):km(r);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(r))};function Bm(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*vm;case"days":case"day":case"d":return t*Ir;case"hours":case"hour":case"hrs":case"hr":case"h":return t*Qr;case"minutes":case"minute":case"mins":case"min":case"m":return t*Xr;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 km(r){var e=Math.abs(r);return e>=Ir?Math.round(r/Ir)+"d":e>=Qr?Math.round(r/Qr)+"h":e>=Xr?Math.round(r/Xr)+"m":e>=Jr?Math.round(r/Jr)+"s":r+"ms"}function Sm(r){var e=Math.abs(r);return e>=Ir?Vo(r,e,Ir,"day"):e>=Qr?Vo(r,e,Qr,"hour"):e>=Xr?Vo(r,e,Xr,"minute"):e>=Jr?Vo(r,e,Jr,"second"):r+" ms"}function Vo(r,e,t,n){var o=e>=t*1.5;return Math.round(r/t)+" "+n+(o?"s":"")}});var ju=Xt((Jb,Gu)=>{function Im(r){t.debug=t,t.default=t,t.coerce=c,t.disable=s,t.enable=o,t.enabled=i,t.humanize=zu(),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,(T,L)=>{if(T==="%%")return"%";U++;let w=t.formatters[L];if(typeof w=="function"){let C=m[U];T=w.call(g,C),m.splice(U,1),U--}return T}),t.formatArgs.call(g,m),(g.log||t.log).apply(g,m)}return d.namespace=u,d.useColors=t.useColors(),d.color=t.selectColor(u),d.extend=n,d.destroy=t.destroy,Object.defineProperty(d,"enabled",{enumerable:!0,configurable:!1,get:()=>p!==null?p:(E!==t.namespaces&&(E=t.namespaces,y=t.enabled(u)),y),set:m=>{p=m}}),typeof t.init=="function"&&t.init(d),d}function n(u,l){let p=t(this.namespace+(typeof l>"u"?":":l)+u);return p.log=this.log,p}function o(u){t.save(u),t.namespaces=u,t.names=[],t.skips=[];let l,p=(typeof u=="string"?u:"").split(/[\s,]+/),E=p.length;for(l=0;l<E;l++)p[l]&&(u=p[l].replace(/\*/g,".*?"),u[0]==="-"?t.skips.push(new RegExp("^"+u.slice(1)+"$")):t.names.push(new RegExp("^"+u+"$")))}function s(){let u=[...t.names.map(a),...t.skips.map(a).map(l=>"-"+l)].join(",");return t.enable(""),u}function i(u){if(u[u.length-1]==="*")return!0;let l,p;for(l=0,p=t.skips.length;l<p;l++)if(t.skips[l].test(u))return!1;for(l=0,p=t.names.length;l<p;l++)if(t.names[l].test(u))return!0;return!1}function a(u){return u.toString().substring(2,u.toString().length-2).replace(/\.\*\?$/,"*")}function c(u){return u instanceof Error?u.stack||u.message:u}function f(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return t.enable(t.load()),t}Gu.exports=Im});var Wu=Xt((He,Fo)=>{He.formatArgs=Tm;He.save=_m;He.load=Cm;He.useColors=Rm;He.storage=Nm();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 Rm(){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 Tm(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+Fo.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 _m(r){try{r?He.storage.setItem("debug",r):He.storage.removeItem("debug")}catch{}}function Cm(){let r;try{r=He.storage.getItem("debug")}catch{}return!r&&typeof process<"u"&&"env"in process&&(r=process.env.DEBUG),r}function Nm(){try{return localStorage}catch{}}Fo.exports=ju()(He);var{formatters:Lm}=Fo.exports;Lm.j=function(r){try{return JSON.stringify(r)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}});var sn=Xt((w1,dl)=>{"use strict";function hl(r,e){for(let t in e)Object.defineProperty(r,t,{value:e[t],enumerable:!0,configurable:!0});return r}function p0(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 hl(r,t)}catch{t.message=r.message,t.stack=r.stack;let o=function(){};return o.prototype=Object.create(Object.getPrototypeOf(r)),hl(new o,t)}}dl.exports=p0});var cf=Xt(kn=>{"use strict";var ng="[object ArrayBuffer]",Mt=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===ng}static toArrayBuffer(e){return this.isArrayBuffer(e)?e:e.byteLength===e.buffer.byteLength||e.byteOffset===0&&e.byteLength===e.buffer.byteLength?e.buffer:this.toUint8Array(e.buffer).slice(e.byteOffset,e.byteOffset+e.byteLength).buffer}static toUint8Array(e){return this.toView(e,Uint8Array)}static toView(e,t){if(e.constructor===t)return e;if(this.isArrayBuffer(e))return new t(e);if(this.isArrayBufferView(e))return new t(e.buffer,e.byteOffset,e.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(e){return this.isArrayBufferView(e)||this.isArrayBuffer(e)}static isArrayBufferView(e){return ArrayBuffer.isView(e)||e&&this.isArrayBuffer(e.buffer)}static isEqual(e,t){let n=r.toUint8Array(e),o=r.toUint8Array(t);if(n.length!==o.byteLength)return!1;for(let s=0;s<n.length;s++)if(n[s]!==o[s])return!1;return!0}static concat(...e){let t;Array.isArray(e[0])&&!(e[1]instanceof Function)||Array.isArray(e[0])&&e[1]instanceof Function?t=e[0]:e[e.length-1]instanceof Function?t=e.slice(0,e.length-1):t=e;let n=0;for(let i of t)n+=i.byteLength;let o=new Uint8Array(n),s=0;for(let i of t){let a=this.toUint8Array(i);o.set(a,s),s+=a.length}return e[e.length-1]instanceof Function?this.toView(o,e[e.length-1]):o.buffer}},pc="string",og=/^[0-9a-f]+$/i,sg=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,ig=/^[a-zA-Z0-9-_]+$/,ms=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=Mt.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return decodeURIComponent(escape(n))}},Qe=class{static toString(e,t=!1){let n=Mt.toArrayBuffer(e),o=new DataView(n),s="";for(let i=0;i<n.byteLength;i+=2){let a=o.getUint16(i,t);s+=String.fromCharCode(a)}return s}static fromString(e,t=!1){let n=new ArrayBuffer(e.length*2),o=new DataView(n);for(let s=0;s<e.length;s++)o.setUint16(s*2,e.charCodeAt(s),t);return n}},ys=class r{static isHex(e){return typeof e===pc&&og.test(e)}static isBase64(e){return typeof e===pc&&sg.test(e)}static isBase64Url(e){return typeof e===pc&&ig.test(e)}static ToString(e,t="utf8"){let n=Mt.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=Mt.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 ms.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 ms.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=Mt.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return n}static ToHex(e){let t=Mt.toUint8Array(e),n="",o=t.length;for(let s=0;s<o;s++){let i=t[s];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isHex(t))throw new TypeError("Argument 'hexString' is not HEX encoded");t.length%2&&(t=`0${t}`);let n=new Uint8Array(t.length/2);for(let o=0;o<t.length;o=o+2){let s=t.slice(o,o+2);n[o/2]=parseInt(s,16)}return n.buffer}static ToUtf16String(e,t=!1){return Qe.toString(e,t)}static FromUtf16String(e,t=!1){return Qe.fromString(e,t)}static Base64Padding(e){let t=4-e.length%4;if(t<4)for(let n=0;n<t;n++)e+="=";return e}static formatString(e){return e?.replace(/[\n\r\t ]/g,"")||""}};ys.DEFAULT_UTF8_ENCODING="utf8";function ag(r,...e){let t=arguments[0];for(let n=1;n<arguments.length;n++){let o=arguments[n];for(let s in o)t[s]=o[s]}return t}function cg(...r){let e=r.map(o=>o.byteLength).reduce((o,s)=>o+s),t=new Uint8Array(e),n=0;return r.map(o=>new Uint8Array(o)).forEach(o=>{for(let s of o)t[n++]=s}),t.buffer}function ug(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}kn.BufferSourceConverter=Mt;kn.Convert=ys;kn.assign=ag;kn.combine=cg;kn.isEqual=ug});var _c=Xt((DA,Tc)=>{var UA=function(){typeof Tc<"u"&&(Tc.exports=d);var r=86400,e=3200,t=146097*e/400,n=r*t,o=1e3*n,s=864e13,i=4294967296,a=1e6,c="000000000",f=Math.trunc||function(w){var C=w-w%1;return C==0&&(w<0||w===0&&1/w!=1/0)?-0:C},u=d.prototype,l=(d.fromDate=function(w){return new d(+w)},d.fromInt64BE=U(0,1,2,3,0,4),d.fromInt64LE=U(3,2,1,0,4,0),d.fromString=function(_){var C,O=new d,_=(_+="").replace(/^\s*[+\-]?\d+/,function($){var $=+$,J=1970+($-1970)%400;return O.year=$-J,J}).replace(/(?:Z|([+\-]\d{2}):?(\d{2}))$/,function(F,$,J){return $<0&&(J*=-1),C=6e4*(60*+$+ +J),""}).replace(/\.\d+$/,function(F){return O.nano=+(F+c).substr(1,9),""}).split(/\D+/);if(1<_.length?_[1]--:_[1]=0,O.time=C=Date.UTC.apply(Date,_)-(C||0),isNaN(C))throw new TypeError("Invalid Date");return m(O)},d.fromTimeT=function(w){return I(w,0)},u.year=0,u.time=0,u.nano=0,u.addNano=function(w){return this.nano+=+w||0,this},u.getNano=function(){var w=m(this);return(w.time%1e3*a+ +w.nano+1e9)%1e9},u.getTimeT=function(){var C=m(this),w=Math.floor(C.time/1e3),C=C.year;return C&&(w+=C*t*r/e),w},u.getYear=function(){return this.toDate().getUTCFullYear()+this.year},u.toDate=function(){return g(m(this).time)},u.toJSON=function(){return this.toString().replace(/0{1,6}Z$/,"Z")},u.toString=function(w){var C=this,O=C.toDate(),_={H:function(){return T(O.getUTCHours())},L:function(){return L(O.getUTCMilliseconds(),3)},M:function(){return T(O.getUTCMinutes())},N:function(){return L(C.getNano(),9)},S:function(){return T(O.getUTCSeconds())},Y:function(){var F=C.getYear();return 999999<F?"+"+F:9999<F?"+"+L(F,6):0<=F?L(F,4):-999999<=F?"-"+L(-F,6):F},a:function(){return E[O.getUTCDay()]},b:function(){return p[O.getUTCMonth()]},d:function(){return T(O.getUTCDate())},e:function(){return function(F){return(9<F?"":" ")+(0|F)}(O.getUTCDate())},m:function(){return T(O.getUTCMonth()+1)}};return function F($){return $.replace(/%./g,function(J){var k=J[1],x=y[k],k=_[k];return x?F(x):k?k():J})}(w||l)},u.writeInt64BE=v(0,1,2,3,0,4),u.writeInt64LE=v(3,2,1,0,4,0),"%Y-%m-%dT%H:%M:%S.%NZ"),p=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],E=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],y={"%":"%",F:"%Y-%m-%d",n:`
3
+ `,R:"%H:%M",T:"%H:%M:%S",t:" ",X:"%T",Z:"GMT",z:"+0000"};return d;function d(w,C,O){var _=this;if(!(_ instanceof d))return new d(w,C,O);_.time=+w||0,_.nano=+C||0,_.year=+O||0,m(_)}function m(w){var C,O,_,F=w.year,$=w.time,J=w.nano,x=((J<0||a<=J)&&(J-=(O=Math.floor(J/a))*a,$+=O,O=1),F%e);return($<-s||s<$||x)&&((C=f($/o))&&(F+=C*e,$-=C*o),(_=g($)).setUTCFullYear(x+_.getUTCFullYear()),_=($=+_)+(C=f((F-=x)/e))*o,C&&-s<=_&&_<=s&&(F-=C*e,$=_),O=1),O&&(w.year=F,w.time=$,w.nano=J),w}function g(w){var C=new Date(0);return C.setTime(w),C}function I(F,_){F=+F||0;var O=f((_=(_|0)*i)/n)+f(F/n),_=_%n+F%n,F=f(_/n);return F&&(O+=F,_-=F*n),new d(1e3*_,0,O*e)}function v(w,C,O,_,F,$){return function(x,k){var B=m(this);x=x||new Array(8),S(x,k|=0);var b=Math.floor(B.time/1e3),B=B.year*(t*r/e),H=f(B/i)+f(b/i),B=B%i+b%i,b=Math.floor(B/i);return b&&(H+=b,B-=b*i),J(x,k+F,H),J(x,k+$,B),x};function J(x,k,H){x[k+w]=H>>24&255,x[k+C]=H>>16&255,x[k+O]=H>>8&255,x[k+_]=255&H}}function U(w,C,O,_,F,$){return function(x,k){S(x,k|=0);var H=J(x,k+F);return I(J(x,k+$),H)};function J(x,k){return 16777216*x[k+w]+(x[k+C]<<16|x[k+O]<<8|x[k+_])}}function S(w,C){if(w=w&&w.length,w==null)throw new TypeError("Invalid Buffer");if(w<C+8)throw new RangeError("Out of range")}function T(w){return(9<w?"":"0")+(0|w)}function L(w,C){return(c+(0|w)).substr(-C)}}()});var Nd=Xt((g8,Mc)=>{"use strict";var Tw=Object.prototype.hasOwnProperty,Oe="~";function So(){}Object.create&&(So.prototype=Object.create(null),new So().__proto__||(Oe=!1));function _w(r,e,t){this.fn=r,this.context=e,this.once=t||!1}function Cd(r,e,t,n,o){if(typeof t!="function")throw new TypeError("The listener must be a function");var s=new _w(t,n||r,o),i=Oe?Oe+e:e;return r._events[i]?r._events[i].fn?r._events[i]=[r._events[i],s]:r._events[i].push(s):(r._events[i]=s,r._eventsCount++),r}function vi(r,e){--r._eventsCount===0?r._events=new So:delete r._events[e]}function Ne(){this._events=new So,this._eventsCount=0}Ne.prototype.eventNames=function(){var e=[],t,n;if(this._eventsCount===0)return e;for(n in t=this._events)Tw.call(t,n)&&e.push(Oe?n.slice(1):n);return Object.getOwnPropertySymbols?e.concat(Object.getOwnPropertySymbols(t)):e};Ne.prototype.listeners=function(e){var t=Oe?Oe+e:e,n=this._events[t];if(!n)return[];if(n.fn)return[n.fn];for(var o=0,s=n.length,i=new Array(s);o<s;o++)i[o]=n[o].fn;return i};Ne.prototype.listenerCount=function(e){var t=Oe?Oe+e:e,n=this._events[t];return n?n.fn?1:n.length:0};Ne.prototype.emit=function(e,t,n,o,s,i){var a=Oe?Oe+e:e;if(!this._events[a])return!1;var c=this._events[a],f=arguments.length,u,l;if(c.fn){switch(c.once&&this.removeListener(e,c.fn,void 0,!0),f){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,t),!0;case 3:return c.fn.call(c.context,t,n),!0;case 4:return c.fn.call(c.context,t,n,o),!0;case 5:return c.fn.call(c.context,t,n,o,s),!0;case 6:return c.fn.call(c.context,t,n,o,s,i),!0}for(l=1,u=new Array(f-1);l<f;l++)u[l-1]=arguments[l];c.fn.apply(c.context,u)}else{var p=c.length,E;for(l=0;l<p;l++)switch(c[l].once&&this.removeListener(e,c[l].fn,void 0,!0),f){case 1:c[l].fn.call(c[l].context);break;case 2:c[l].fn.call(c[l].context,t);break;case 3:c[l].fn.call(c[l].context,t,n);break;case 4:c[l].fn.call(c[l].context,t,n,o);break;default:if(!u)for(E=1,u=new Array(f-1);E<f;E++)u[E-1]=arguments[E];c[l].fn.apply(c[l].context,u)}}return!0};Ne.prototype.on=function(e,t,n){return Cd(this,e,t,n,!1)};Ne.prototype.once=function(e,t,n){return Cd(this,e,t,n,!0)};Ne.prototype.removeListener=function(e,t,n,o){var s=Oe?Oe+e:e;if(!this._events[s])return this;if(!t)return vi(this,s),this;var i=this._events[s];if(i.fn)i.fn===t&&(!o||i.once)&&(!n||i.context===n)&&vi(this,s);else{for(var a=0,c=[],f=i.length;a<f;a++)(i[a].fn!==t||o&&!i[a].once||n&&i[a].context!==n)&&c.push(i[a]);c.length?this._events[s]=c.length===1?c[0]:c:vi(this,s)}return this};Ne.prototype.removeAllListeners=function(e){var t;return e?(t=Oe?Oe+e:e,this._events[t]&&vi(this,t)):(this._events=new So,this._eventsCount=0),this};Ne.prototype.off=Ne.prototype.removeListener;Ne.prototype.addListener=Ne.prototype.on;Ne.prefixed=Oe;Ne.EventEmitter=Ne;typeof Mc<"u"&&(Mc.exports=Ne)});var Kd=Xt((yk,$d)=>{$d.exports=function(r){if(!r)throw Error("hashlru must have a max value, of type number, greater than 0");var e=0,t=Object.create(null),n=Object.create(null);function o(s,i){t[s]=i,e++,e>=r&&(e=0,n=t,t=Object.create(null))}return{has:function(s){return t[s]!==void 0||n[s]!==void 0},remove:function(s){t[s]!==void 0&&(t[s]=void 0),n[s]!==void 0&&(n[s]=void 0)},get:function(s){var i=t[s];if(i!==void 0)return i;if((i=n[s])!==void 0)return o(s,i),i},set:function(s,i){t[s]!==void 0?t[s]=i:o(s,i)},clear:function(){t=Object.create(null),n=Object.create(null)}}}});var xb={};ge(xb,{createHeliaHTTP:()=>bb});function Sr(r){let e=new globalThis.AbortController;function t(){e.abort();for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",t)}for(let s of r){if(s?.aborted===!0){t();break}s?.addEventListener!=null&&s.addEventListener("abort",t)}function n(){for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",t)}let o=e.signal;return o.clear=n,o}function Pp(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 zr=Pp;function Op(r){return r[Symbol.asyncIterator]!=null}function ku(r){return r?.then!=null}function Vp(r,e){if(Op(r))return async function*(){for await(let a of r){let c=e(a);ku(c)&&await c,yield a}}();let t=zr(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);ku(c)&&await c,yield a}}();let i=e;return function*(){yield n;for(let a of t)i(a),yield a}()}var qi=Vp;var Yi={};ge(Yi,{base32:()=>Be,base32hex:()=>Gp,base32hexpad:()=>Wp,base32hexpadupper:()=>Yp,base32hexupper:()=>jp,base32pad:()=>qp,base32padupper:()=>zp,base32upper:()=>Nu,base32z:()=>Zp});var Sb=new Uint8Array(0);function Su(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 Tt(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 Iu(r){return new TextEncoder().encode(r)}function Ru(r){return new TextDecoder().decode(r)}function Fp(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(t[i]!==255)throw new TypeError(s+" is ambiguous");t[i]=o}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(y){if(y instanceof Uint8Array||(ArrayBuffer.isView(y)?y=new Uint8Array(y.buffer,y.byteOffset,y.byteLength):Array.isArray(y)&&(y=Uint8Array.from(y))),!(y instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(y.length===0)return"";for(var d=0,m=0,g=0,I=y.length;g!==I&&y[g]===0;)g++,d++;for(var v=(I-g)*u+1>>>0,U=new Uint8Array(v);g!==I;){for(var S=y[g],T=0,L=v-1;(S!==0||T<m)&&L!==-1;L--,T++)S+=256*U[L]>>>0,U[L]=S%a>>>0,S=S/a>>>0;if(S!==0)throw new Error("Non-zero carry");m=T,g++}for(var w=v-m;w!==v&&U[w]===0;)w++;for(var C=c.repeat(d);w<v;++w)C+=r.charAt(U[w]);return C}function p(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var d=0;if(y[d]!==" "){for(var m=0,g=0;y[d]===c;)m++,d++;for(var I=(y.length-d)*f+1>>>0,v=new Uint8Array(I);y[d];){var U=t[y.charCodeAt(d)];if(U===255)return;for(var S=0,T=I-1;(U!==0||S<g)&&T!==-1;T--,S++)U+=a*v[T]>>>0,v[T]=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)),C=m;L!==I;)w[C++]=v[L++];return w}}}function E(y){var d=p(y);if(d)return d;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:p,decode:E}}var Mp=Fp,Hp=Mp,_u=Hp;var zi=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")}},Gi=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 Cu(this,e)}},ji=class{decoders;constructor(e){this.decoders=e}or(e){return Cu(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 Cu(r,e){return new ji({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var Wi=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 zi(e,t,n),this.decoder=new Gi(e,t,o)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function Gr({name:r,prefix:e,encode:t,decode:n}){return new Wi(r,e,t,n)}function Qt({name:r,prefix:e,alphabet:t}){let{encode:n,decode:o}=_u(t,r);return Gr({prefix:e,name:r,encode:n,decode:s=>Tt(o(s))})}function $p(r,e,t,n){let o={};for(let u=0;u<e.length;++u)o[e[u]]=u;let s=r.length;for(;r[s-1]==="=";)--s;let i=new Uint8Array(s*t/8|0),a=0,c=0,f=0;for(let u=0;u<s;++u){let l=o[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<t|l,a+=t,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=t||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function Kp(r,e,t){let n=e[e.length-1]==="=",o=(1<<t)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,s+=e[o&a>>i];if(i!==0&&(s+=e[o&a<<t-i]),n)for(;s.length*t&7;)s+="=";return s}function le({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return Gr({prefix:e,name:r,encode(o){return Kp(o,n,t)},decode(o){return $p(o,n,t,r)}})}var Be=le({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Nu=le({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),qp=le({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),zp=le({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Gp=le({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),jp=le({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Wp=le({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Yp=le({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Zp=le({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Zi={};ge(Zi,{base58btc:()=>he,base58flickr:()=>Jp});var he=Qt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Jp=Qt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Xp=Du,Lu=128,Qp=127,em=~Qp,tm=Math.pow(2,31);function Du(r,e,t){e=e||[],t=t||0;for(var n=t;r>=tm;)e[t++]=r&255|Lu,r/=128;for(;r&em;)e[t++]=r&255|Lu,r>>>=7;return e[t]=r|0,Du.bytes=t-n+1,e}var rm=Ji,nm=128,Uu=127;function Ji(r,n){var t=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw Ji.bytes=0,new RangeError("Could not decode varint");i=r[s++],t+=o<28?(i&Uu)<<o:(i&Uu)*Math.pow(2,o),o+=7}while(i>=nm);return Ji.bytes=s-n,t}var om=Math.pow(2,7),sm=Math.pow(2,14),im=Math.pow(2,21),am=Math.pow(2,28),cm=Math.pow(2,35),um=Math.pow(2,42),lm=Math.pow(2,49),fm=Math.pow(2,56),hm=Math.pow(2,63),dm=function(r){return r<om?1:r<sm?2:r<im?3:r<am?4:r<cm?5:r<um?6:r<lm?7:r<fm?8:r<hm?9:10},pm={encode:Xp,decode:rm,encodingLength:dm},mm=pm,Kn=mm;function qn(r,e=0){return[Kn.decode(r,e),Kn.decode.bytes]}function jr(r,e,t=0){return Kn.encode(r,e,t),e}function Wr(r){return Kn.encodingLength(r)}function gt(r,e){let t=e.byteLength,n=Wr(r),o=n+Wr(t),s=new Uint8Array(o+t);return jr(r,s,0),jr(t,s,n),s.set(e,o),new Yr(r,t,e,s)}function wt(r){let e=Tt(r),[t,n]=qn(e),[o,s]=qn(e.subarray(n)),i=e.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Yr(t,o,i,e)}function Pu(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&Su(r.bytes,t.bytes)}}var Yr=class{code;size;digest;bytes;constructor(e,t,n,o){this.code=e,this.size=t,this.digest=n,this.bytes=o}};function Ou(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return gm(t,Xi(r),e??he.encoder);default:return wm(t,Xi(r),e??Be.encoder)}}var Vu=new WeakMap;function Xi(r){let e=Vu.get(r);if(e==null){let t=new Map;return Vu.set(r,t),t}return e}var te=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!==zn)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==bm)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&&Pu(e.multihash,n.multihash)}toString(e){return Ou(this,e)}toJSON(){return{"/":Ou(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:o,multihash:s,bytes:i}=t;return new r(n,o,s,i??Fu(n,o,s.bytes))}else if(t[xm]===!0){let{version:n,multihash:o,code:s}=t,i=wt(o);return r.create(n,s,i)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==zn)throw new Error(`Version 0 CID must use dag-pb (code: ${zn}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let o=Fu(e,t,n.bytes);return new r(e,t,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,zn,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=Tt(e.subarray(n,n+t.multihashSize));if(o.byteLength!==t.multihashSize)throw new Error("Incorrect length");let s=o.subarray(t.multihashSize-t.digestSize),i=new Yr(t.multihashCode,t.digestSize,s,o);return[t.version===0?r.createV0(i):r.createV1(t.codec,i),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[l,p]=qn(e.subarray(t));return t+=p,l},o=n(),s=zn;if(o===18?(o=0,t=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=t,a=n(),c=n(),f=t+c,u=f-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(e,t){let[n,o]=ym(e,t),s=r.decode(o);if(s.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Xi(s).set(n,e),s}};function ym(r,e){switch(r[0]){case"Q":{let t=e??he;return[he.prefix,t.decode(`${he.prefix}${r}`)]}case he.prefix:{let t=e??he;return[he.prefix,t.decode(r)]}case Be.prefix:{let t=e??Be;return[Be.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function gm(r,e,t){let{prefix:n}=t;if(n!==he.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let o=e.get(n);if(o==null){let s=t.encode(r).slice(1);return e.set(n,s),s}else return o}function wm(r,e,t){let{prefix:n}=t,o=e.get(n);if(o==null){let s=t.encode(r);return e.set(n,s),s}else return o}var zn=112,bm=18;function Fu(r,e,t){let n=Wr(r),o=n+Wr(e),s=new Uint8Array(o+t.byteLength);return jr(r,s,0),jr(e,s,n),s.set(t,o),s}var xm=Symbol.for("@ipld/js-cid/CID");var Gn=Symbol.for("@libp2p/content-routing");var Qi=Symbol.for("@libp2p/peer-id");function Mu(r){return r!=null&&!!r[Qi]}var jn=Symbol.for("@libp2p/peer-routing");var er=class r extends Error{code;type;constructor(e="The operation was aborted"){super(e),this.code=r.code,this.type=r.type}static code="ABORT_ERR";static type="aborted"},N=class extends Error{code;props;constructor(e,t,n){super(e),this.code=t,this.name=n?.name??"CodeError",this.props=n??{}}};var Zr=(r,...e)=>{try{[...e]}catch{}};var Oo=class extends EventTarget{#e=new Map;constructor(){super(),Zr(1/0,this)}listenerCount(e){let t=this.#e.get(e);return t==null?0:t.length}addEventListener(e,t,n){super.addEventListener(e,t,n);let o=this.#e.get(e);o==null&&(o=[],this.#e.set(e,o)),o.push({callback:t,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(e,t,n){super.removeEventListener(e.toString(),t??null,n);let o=this.#e.get(e);o!=null&&(o=o.filter(({callback:s})=>s!==t),this.#e.set(e,o))}dispatchEvent(e){let t=super.dispatchEvent(e),n=this.#e.get(e.type);return n==null||(n=n.filter(({once:o})=>!o),this.#e.set(e.type,n)),t}safeDispatchEvent(e,t={}){return this.dispatchEvent(new Em(e,t))}},ea=class extends Event{detail;constructor(e,t){super(e,t),this.detail=t?.detail}},Em=globalThis.CustomEvent??ea;function Hu(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function tr(...r){let e=[];for(let t of r)Hu(t)&&e.push(t);await Promise.all(e.map(async t=>{t.beforeStart!=null&&await t.beforeStart()})),await Promise.all(e.map(async t=>{await t.start()})),await Promise.all(e.map(async t=>{t.afterStart!=null&&await t.afterStart()}))}async function rr(...r){let e=[];for(let t of r)Hu(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 oa={};ge(oa,{sha256:()=>we,sha512:()=>na});function ra({name:r,code:e,encode:t}){return new ta(r,e,t)}var ta=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 Ku(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var we=ra({name:"sha2-256",code:18,encode:Ku("SHA-256")}),na=ra({name:"sha2-512",code:19,encode:Ku("SHA-512")});var $e=st(Wu(),1);var sa={};ge(sa,{base64:()=>nr,base64pad:()=>Um,base64url:()=>Dm,base64urlpad:()=>Pm});var nr=le({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Um=le({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Dm=le({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Pm=le({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});$e.default.formatters.b=r=>r==null?"undefined":he.baseEncode(r);$e.default.formatters.t=r=>r==null?"undefined":Be.baseEncode(r);$e.default.formatters.m=r=>r==null?"undefined":nr.baseEncode(r);$e.default.formatters.p=r=>r==null?"undefined":r.toString();$e.default.formatters.c=r=>r==null?"undefined":r.toString();$e.default.formatters.k=r=>r==null?"undefined":r.toString();$e.default.formatters.a=r=>r==null?"undefined":r.toString();function Om(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 Yu(){return{forComponent(r){return Ke(r)}}}function Ke(r){let e=Om(`${r}:trace`);return $e.default.enabled(`${r}:trace`)&&$e.default.names.map(t=>t.toString()).find(t=>t.includes(":trace"))!=null&&(e=(0,$e.default)(`${r}:trace`)),Object.assign((0,$e.default)(r),{error:(0,$e.default)(`${r}:error`),trace:e})}function se(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function Rr(r){return globalThis.Buffer!=null?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r}function it(r=0){return globalThis.Buffer?.allocUnsafe!=null?Rr(globalThis.Buffer.allocUnsafe(r)):new Uint8Array(r)}var Vm=Math.pow(2,7),Fm=Math.pow(2,14),Mm=Math.pow(2,21),ia=Math.pow(2,28),aa=Math.pow(2,35),ca=Math.pow(2,42),ua=Math.pow(2,49),re=128,Te=127;function Ve(r){if(r<Vm)return 1;if(r<Fm)return 2;if(r<Mm)return 3;if(r<ia)return 4;if(r<aa)return 5;if(r<ca)return 6;if(r<ua)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function la(r,e,t=0){switch(Ve(r)){case 8:e[t++]=r&255|re,r/=128;case 7:e[t++]=r&255|re,r/=128;case 6:e[t++]=r&255|re,r/=128;case 5:e[t++]=r&255|re,r/=128;case 4:e[t++]=r&255|re,r>>>=7;case 3:e[t++]=r&255|re,r>>>=7;case 2:e[t++]=r&255|re,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function Hm(r,e,t=0){switch(Ve(r)){case 8:e.set(t++,r&255|re),r/=128;case 7:e.set(t++,r&255|re),r/=128;case 6:e.set(t++,r&255|re),r/=128;case 5:e.set(t++,r&255|re),r/=128;case 4:e.set(t++,r&255|re),r>>>=7;case 3:e.set(t++,r&255|re),r>>>=7;case 2:e.set(t++,r&255|re),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function fa(r,e){let t=r[e],n=0;if(n+=t&Te,t<re||(t=r[e+1],n+=(t&Te)<<7,t<re)||(t=r[e+2],n+=(t&Te)<<14,t<re)||(t=r[e+3],n+=(t&Te)<<21,t<re)||(t=r[e+4],n+=(t&Te)*ia,t<re)||(t=r[e+5],n+=(t&Te)*aa,t<re)||(t=r[e+6],n+=(t&Te)*ca,t<re)||(t=r[e+7],n+=(t&Te)*ua,t<re))return n;throw new RangeError("Could not decode varint")}function $m(r,e){let t=r.get(e),n=0;if(n+=t&Te,t<re||(t=r.get(e+1),n+=(t&Te)<<7,t<re)||(t=r.get(e+2),n+=(t&Te)<<14,t<re)||(t=r.get(e+3),n+=(t&Te)<<21,t<re)||(t=r.get(e+4),n+=(t&Te)*ia,t<re)||(t=r.get(e+5),n+=(t&Te)*aa,t<re)||(t=r.get(e+6),n+=(t&Te)*ca,t<re)||(t=r.get(e+7),n+=(t&Te)*ua,t<re))return n;throw new RangeError("Could not decode varint")}function en(r,e,t=0){return e==null&&(e=it(Ve(r))),e instanceof Uint8Array?la(r,e,t):Hm(r,e,t)}function Tr(r,e=0){return r instanceof Uint8Array?fa(r,e):$m(r,e)}var ha=new Float32Array([-0]),or=new Uint8Array(ha.buffer);function Ju(r,e,t){ha[0]=r,e[t]=or[0],e[t+1]=or[1],e[t+2]=or[2],e[t+3]=or[3]}function Xu(r,e){return or[0]=r[e],or[1]=r[e+1],or[2]=r[e+2],or[3]=r[e+3],ha[0]}var da=new Float64Array([-0]),_e=new Uint8Array(da.buffer);function Qu(r,e,t){da[0]=r,e[t]=_e[0],e[t+1]=_e[1],e[t+2]=_e[2],e[t+3]=_e[3],e[t+4]=_e[4],e[t+5]=_e[5],e[t+6]=_e[6],e[t+7]=_e[7]}function el(r,e){return _e[0]=r[e],_e[1]=r[e+1],_e[2]=r[e+2],_e[3]=r[e+3],_e[4]=r[e+4],_e[5]=r[e+5],_e[6]=r[e+6],_e[7]=r[e+7],da[0]}var Km=BigInt(Number.MAX_SAFE_INTEGER),qm=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<Km&&e>qm)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>tl&&(o=0n,++n>tl&&(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 tl=4294967296n;function rl(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 nl(r,e,t){if(t-e<1)return"";let o,s=[],i=0,a;for(;e<t;)a=r[e++],a<128?s[i++]=a:a>191&&a<224?s[i++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&63,i>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,s)),i=0);return o!=null?(i>0&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))}function pa(r,e,t){let n=t,o,s;for(let i=0;i<r.length;++i)o=r.charCodeAt(i),o<128?e[t++]=o:o<2048?(e[t++]=o>>6|192,e[t++]=o&63|128):(o&64512)===55296&&((s=r.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,e[t++]=o>>18|240,e[t++]=o>>12&63|128,e[t++]=o>>6&63|128,e[t++]=o&63|128):(e[t++]=o>>12|224,e[t++]=o>>6&63|128,e[t++]=o&63|128);return t-n}function at(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function Mo(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var ma=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,at(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw at(this,4);return Mo(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw at(this,4);return Mo(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw at(this,4);let e=Xu(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw at(this,4);let e=el(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,n=this.pos+e;if(n>this.len)throw at(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return nl(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw at(this,e);this.pos+=e}else do if(this.pos>=this.len)throw at(this);while(this.buf[this.pos++]&128);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new qe(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw at(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw at(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw at(this,8);let e=Mo(this.buf,this.pos+=4),t=Mo(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=fa(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 ya(r){return new ma(r instanceof Uint8Array?r:r.subarray())}function tn(r,e,t){let n=ya(r);return e.decode(n,void 0,t)}var ga={};ge(ga,{base10:()=>zm});var zm=Qt({prefix:"9",name:"base10",alphabet:"0123456789"});var wa={};ge(wa,{base16:()=>Gm,base16upper:()=>jm});var Gm=le({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),jm=le({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var ba={};ge(ba,{base2:()=>Wm});var Wm=le({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var xa={};ge(xa,{base256emoji:()=>Qm});var sl=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),Ym=sl.reduce((r,e,t)=>(r[t]=e,r),[]),Zm=sl.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function Jm(r){return r.reduce((e,t)=>(e+=Ym[t],e),"")}function Xm(r){let e=[];for(let t of r){let n=Zm[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var Qm=Gr({prefix:"\u{1F680}",name:"base256emoji",encode:Jm,decode:Xm});var Ea={};ge(Ea,{base36:()=>sr,base36upper:()=>e0});var sr=Qt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),e0=Qt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var va={};ge(va,{base8:()=>t0});var t0=le({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Aa={};ge(Aa,{identity:()=>r0});var r0=Gr({prefix:"\0",name:"identity",encode:r=>Ru(r),decode:r=>Iu(r)});var Bx=new TextEncoder,kx=new TextDecoder;var il=512;var Ho=85;var ka={};ge(ka,{identity:()=>Je});var cl=0,n0="identity",ul=Tt;function o0(r){return gt(cl,ul(r))}var Je={code:cl,name:n0,encode:ul,digest:o0};var ir={...Aa,...ba,...va,...ga,...wa,...Yi,...Ea,...Zi,...sa,...xa},Ox={...oa,...ka};function fl(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var ll=fl("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Sa=fl("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}),s0={utf8:ll,"utf-8":ll,hex:ir.base16,latin1:Sa,ascii:Sa,binary:Sa,...ir},$o=s0;function j(r,e="utf8"){let t=$o[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?Rr(globalThis.Buffer.from(r,"utf-8")):t.decoder.decode(`${t.prefix}${r}`)}function Ia(r){let e=r??8192,t=e>>>1,n,o=e;return function(i){if(i<1||i>t)return it(i);o+i>e&&(n=it(e),o=0);let a=n.subarray(o,o+=i);return o&7&&(o=(o|7)+1),a}}var Cr=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function Ra(){}var _a=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},i0=Ia();function a0(r){return globalThis.Buffer!=null?it(r):i0(r)}var Yn=class{len;head;tail;states;constructor(){this.len=0,this.head=new Cr(Ra,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new Cr(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new Ca((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(Ko,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(Ko,t.length(),t)}uint64Number(e){return this._push(la,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(Ko,t.length(),t)}sint64Number(e){let t=qe.fromNumber(e).zzEncode();return this._push(Ko,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(Ta,1,e?1:0)}fixed32(e){return this._push(Wn,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=qe.fromBigInt(e);return this._push(Wn,4,t.lo)._push(Wn,4,t.hi)}fixed64Number(e){let t=qe.fromNumber(e);return this._push(Wn,4,t.lo)._push(Wn,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(Ju,4,e)}double(e){return this._push(Qu,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(Ta,1,0):this.uint32(t)._push(u0,t,e)}string(e){let t=rl(e);return t!==0?this.uint32(t)._push(pa,t,e):this._push(Ta,1,0)}fork(){return this.states=new _a(this),this.head=this.tail=new Cr(Ra,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 Cr(Ra,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=a0(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function Ta(r,e,t){e[t]=r&255}function c0(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var Ca=class extends Cr{next;constructor(e,t){super(c0,e,t),this.next=void 0}};function Ko(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 Wn(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 u0(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(Yn.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(l0,e,r),this},Yn.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(f0,e,r),this});function l0(r,e,t){e.set(r,t)}function f0(r,e,t){r.length<40?pa(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(j(r),t)}function Na(){return new Yn}function rn(r,e){let t=Na();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var nn;(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"})(nn||(nn={}));function qo(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(s,i){let a=e(s);i.int32(a)},n=function(s){let i=s.int32();return e(i)};return qo("enum",nn.VARINT,t,n)}function on(r,e){return qo("message",nn.LENGTH_DELIMITED,r,e)}function h0(r){return r[Symbol.asyncIterator]!=null}function d0(r){if(h0(r))return(async()=>{for await(let e of r);})();for(let e of r);}var Ct=d0;function Le(r,e){if(globalThis.Buffer!=null)return Rr(globalThis.Buffer.concat(r,e));e==null&&(e=r.reduce((o,s)=>o+s.length,0));let t=it(e),n=0;for(let o of r)t.set(o,n),n+=o.length;return Rr(t)}function m0(r){return r[Symbol.asyncIterator]!=null}function y0(r,e){if(m0(r))return async function*(){for await(let a of r)yield e(a)}();let t=zr(r),{value:n,done:o}=t.next();if(o===!0)return function*(){}();let s=e(n);if(typeof s.then=="function")return async function*(){yield await s;for await(let a of t)yield e(a)}();let i=e;return function*(){yield s;for(let a of t)yield i(a)}()}var an=y0;function Ue(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var zo=class{buffer;mask;top;btm;next;constructor(e){if(!(e>0)||e-1&e)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},cn=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new zo(this.hwm),this.tail=this.head,this.size=0}calculateSize(e){return e?.byteLength!=null?e.byteLength:1}push(e){if(e?.value!=null&&(this.size+=this.calculateSize(e.value)),!this.head.push(e)){let t=this.head;this.head=t.next=new zo(2*this.head.buffer.length),this.head.push(e)}}shift(){let e=this.tail.shift();if(e===void 0&&this.tail.next!=null){let t=this.tail.next;this.tail.next=null,this.tail=t,e=this.tail.shift()}return e?.value!=null&&(this.size-=this.calculateSize(e.value)),e}isEmpty(){return this.head.isEmpty()}};var La=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 g0(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 g0(r,e){e=e??{};let t=e.onEnd,n=new cn,o,s,i,a=Ue(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((m,g)=>{s=I=>{s=null,n.push(I);try{m(r(n))}catch(v){g(v)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ue()})}},f=m=>s!=null?s(m):(n.push(m),o),u=m=>(n=new cn,s!=null?s({error:m}):(n.push({error:m}),o)),l=m=>{if(i)return o;if(e?.objectMode!==!0&&m?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:m})},p=m=>i?o:(i=!0,m!=null?u(m):f({done:!0})),E=()=>(n=new cn,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 La)},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 w0(r){return r[Symbol.asyncIterator]!=null}function b0(...r){let e=[];for(let t of r)w0(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 ar=b0;function x0(r){return r[Symbol.asyncIterator]!=null}function E0(r,e){return x0(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 Go=E0;var ee=class extends Event{constructor(e,t){super(e),this.detail=t}};function z(r,e="utf8"){let t=$o[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 jo=class{url;#e=0;#t=0;#r=0;#i=0;constructor(e){this.url=e instanceof URL?e:new URL(e)}async getRawBlock(e,t){let n=this.url;if(n.pathname=`/ipfs/${e.toString()}`,n.search="?format=raw",t?.aborted===!0)throw new Error(`Signal to fetch raw block for CID ${e} from gateway ${this.url} was aborted prior to fetch`);try{this.#e++;let o=await fetch(n.toString(),{signal:t,headers:{Accept:"application/vnd.ipld.raw"},cache:"force-cache"});if(!o.ok)throw this.#t++,new Error(`unable to fetch raw block for CID ${e} from gateway ${this.url}`);return this.#i++,new Uint8Array(await o.arrayBuffer())}catch{throw t?.aborted===!0?new Error(`fetching raw block for CID ${e} from gateway ${this.url} was aborted`):(this.#t++,new Error(`unable to fetch raw block for CID ${e}`))}}reliability(){return this.#e===0?1:this.#r>0?-1/0:this.#i/(this.#e+this.#t*3)}incrementInvalidBlocks(){this.#r++}};var Wo=class{gateways;log;constructor(e,t={}){this.log=e.logger.forComponent("helia:trustless-gateway-block-broker"),this.gateways=(t.gateways??pl).map(n=>new jo(n))}async retrieve(e,t={}){let n=this.gateways.sort((s,i)=>i.reliability()-s.reliability()),o=[];for(let s of n){this.log("getting block for %c from %s",e,s.url);try{let i=await s.getRawBlock(e,t.signal);this.log.trace("got block for %c from %s",e,s.url);try{await t.validateFn?.(i)}catch(a){throw this.log.error("failed to validate block for %c from %s",e,s.url,a),s.incrementInvalidBlocks(),new Error(`unable to validate block for CID ${e} from gateway ${s.url}`)}return i}catch(i){if(this.log.error("failed to get block for %c from %s",e,s.url,i),i instanceof Error?o.push(i):o.push(new Error(`unable to fetch raw block for CID ${e} from gateway ${s.url}`)),t.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",e,s.url);break}}}throw new AggregateError(o,`unable to fetch raw block for CID ${e} from any gateway`)}};var pl=["https://trustless-gateway.link","https://cloudflare-ipfs.com","https://4everland.io"];function Ua(r={}){return e=>new Wo(e,r)}var v0=Symbol.for("nodejs.util.inspect.custom"),ml=Object.values(ir).map(r=>r.decoder).reduce((r,e)=>r.or(e),ir.identity.decoder),yl=114,Da=36,Pa=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()})`}[Qi]=!0;toString(){return this.string==null&&(this.string=he.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return te.createV1(yl,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return se(this.multihash.bytes,e);if(typeof e=="string")return Nr(e).equals(this);if(e?.multihash?.bytes!=null)return se(this.multihash.bytes,e.multihash.bytes);throw new Error("not valid Id")}[v0](){return`PeerId(${this.toString()})`}},un=class extends Jn{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},ln=class extends Jn{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.multihash.digest}},fn=class extends Jn{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.multihash.digest}};function Nr(r,e){if(e=e??ml,r.charAt(0)==="1"||r.charAt(0)==="Q"){let t=wt(he.decode(`z${r}`));return r.startsWith("12D")?new ln({multihash:t}):r.startsWith("16U")?new fn({multihash:t}):new un({multihash:t})}return Xn(ml.decode(r))}function Xn(r){try{let e=wt(r);if(e.code===Je.code){if(e.digest.length===Da)return new ln({multihash:e});if(e.digest.length===Pa)return new fn({multihash:e})}if(e.code===we.code)return new un({multihash:e})}catch{return A0(te.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!==yl)throw new Error("Supplied PeerID CID is invalid");let e=r.multihash;if(e.code===we.code)return new un({multihash:r.multihash});if(e.code===Je.code){if(e.digest.length===Da)return new ln({multihash:r.multihash});if(e.digest.length===Pa)return new fn({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function gl(r,e){return r.length===Da?new ln({multihash:gt(Je.code,r),privateKey:e}):r.length===Pa?new fn({multihash:gt(Je.code,r),privateKey:e}):new un({multihash:await we.digest(r),publicKey:r,privateKey:e})}var Yo=class{index=0;input="";new(e){return this.index=0,this.input=e,this}readAtomically(e){let t=this.index,n=e();return n===void 0&&(this.index=t),n}parseWith(e){let t=e();if(this.index===this.input.length)return t}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(e){return this.readAtomically(()=>{let t=this.readChar();if(t===e)return t})}readSeparator(e,t,n){return this.readAtomically(()=>{if(!(t>0&&this.readGivenChar(e)===void 0))return n()})}readNumber(e,t,n,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",f=2**(8*o)-1;for(;;){let u=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let p=Number.parseInt(l,e);if(!Number.isNaN(p))return p});if(u===void 0)break;if(s*=e,s+=u,s>f||(i+=1,t!==void 0&&i>t))return}if(i!==0)return!n&&c&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let e=new Uint8Array(4);for(let t=0;t<e.length;t++){let n=this.readSeparator(".",t,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;e[t]=n}return e})}readIPv6Addr(){let e=t=>{for(let n=0;n<t.length/2;n++){let o=n*2;if(n<t.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return t[o]=i[0],t[o+1]=i[1],t[o+2]=i[2],t[o+3]=i[3],[o+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[o,!1];t[o]=s>>8,t[o+1]=s&255}return[t.length,!1]};return this.readAtomically(()=>{let t=new Uint8Array(16),[n,o]=e(t);if(n===16)return t;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=e(s.subarray(0,i));return t.set(s.subarray(0,a),16-a),t})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var wl=45,B0=15,hn=new Yo;function Oa(r){if(!(r.length>B0))return hn.new(r).parseWith(()=>hn.readIPv4Addr())}function Va(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>wl))return hn.new(r).parseWith(()=>hn.readIPv6Addr())}function Zo(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>wl))return hn.new(r).parseWith(()=>hn.readIPAddr())}var uE=parseInt("0xFFFF",16),lE=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function El(r){return!!Oa(r)}function vl(r){return!!Va(r)}function Jo(r){return!!Zo(r)}var Al=El,T0=vl,Fa=function(r){let e=0;if(r=r.toString().trim(),Al(r)){let t=new Uint8Array(e+4);return r.split(/\./g).forEach(n=>{t[e++]=parseInt(n,10)&255}),t}if(T0(r)){let t=r.split(":",8),n;for(n=0;n<t.length;n++){let s=Al(t[n]),i;s&&(i=Fa(t[n]),t[n]=z(i.slice(0,2),"base16")),i!=null&&++n<8&&t.splice(n,0,z(i.slice(2,4),"base16"))}if(t[0]==="")for(;t.length<8;)t.unshift("0");else if(t[t.length-1]==="")for(;t.length<8;)t.push("0");else if(t.length<8){for(n=0;n<t.length&&t[n]!=="";n++);let s=[n,1];for(n=9-t.length;n>0;n--)s.push("0");t.splice.apply(t,s)}let o=new Uint8Array(e+16);for(n=0;n<t.length;n++){let s=parseInt(t[n],16);o[e++]=s>>8&255,o[e++]=s&255}return o}throw new Error("invalid ip address")},Bl=function(r,e=0,t){e=~~e,t=t??r.length-e;let n=new DataView(r.buffer);if(t===4){let o=[];for(let s=0;s<t;s++)o.push(r[e+s]);return o.join(".")}if(t===16){let o=[];for(let s=0;s<t;s+=2)o.push(n.getUint16(e+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var dn={},Ma={},C0=[[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"]];C0.forEach(r=>{let e=N0(...r);Ma[e.code]=e,dn[e.name]=e});function N0(r,e,t,n,o){return{code:r,size:e,name:t,resolvable:!!n,path:!!o}}function ie(r){if(typeof r=="number"){if(Ma[r]!=null)return Ma[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(dn[r]!=null)return dn[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var jE=ie("ip4"),WE=ie("ip6"),YE=ie("ipcidr");function $a(r,e){switch(ie(r).code){case 4:case 41:return U0(e);case 42:return Il(e);case 6:case 273:case 33:case 132:return Tl(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Il(e);case 421:return V0(e);case 444:return Rl(e);case 445:return Rl(e);case 466:return O0(e);default:return z(e,"base16")}}function Ka(r,e){switch(ie(r).code){case 4:return kl(e);case 41:return kl(e);case 42:return Sl(e);case 6:case 273:case 33:case 132:return qa(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Sl(e);case 421:return D0(e);case 444:return F0(e);case 445:return M0(e);case 466:return P0(e);default:return j(e,"base16")}}var Ha=Object.values(ir).map(r=>r.decoder),L0=function(){let r=Ha[0].or(Ha[1]);return Ha.slice(2).forEach(e=>r=r.or(e)),r}();function kl(r){if(!Jo(r))throw new Error("invalid ip address");return Fa(r)}function U0(r){let e=Bl(r,0,r.length);if(e==null)throw new Error("ipBuff is required");if(!Jo(e))throw new Error("invalid ip address");return e}function qa(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,r),new Uint8Array(e)}function Tl(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Sl(r){let e=j(r),t=Uint8Array.from(en(e.length));return Le([t,e],t.length+e.length)}function Il(r){let e=Tr(r);if(r=r.slice(Ve(e)),r.length!==e)throw new Error("inconsistent lengths");return z(r)}function D0(r){let e;r[0]==="Q"||r[0]==="1"?e=wt(he.decode(`z${r}`)).bytes:e=te.parse(r).multihash.bytes;let t=Uint8Array.from(en(e.length));return Le([t,e],t.length+e.length)}function P0(r){let e=L0.decode(r),t=Uint8Array.from(en(e.length));return Le([t,e],t.length+e.length)}function O0(r){let e=Tr(r),t=r.slice(Ve(e));if(t.length!==e)throw new Error("inconsistent lengths");return"u"+z(t,"base64url")}function V0(r){let e=Tr(r),t=r.slice(Ve(e));if(t.length!==e)throw new Error("inconsistent lengths");return z(t,"base58btc")}function F0(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==16)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion address.`);let t=Be.decode("b"+e[0]),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=qa(n);return Le([t,o],t.length+o.length)}function M0(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==56)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion3 address.`);let t=Be.decode(`b${e[0]}`),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=qa(n);return Le([t,o],t.length+o.length)}function Rl(r){let e=r.slice(0,r.length-2),t=r.slice(r.length-2),n=z(e,"base32"),o=Tl(t);return`${n}:${o}`}function _l(r){r=za(r);let e=[],t=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=ie(i);if(a.size===0){e.push([a.code]),t.push([a.code]);continue}if(s++,s>=o.length)throw Nl("invalid address: "+r);if(a.path===!0){n=za(o.slice(s).join("/")),e.push([a.code,Ka(a.code,n)]),t.push([a.code,n]);break}let c=Ka(a.code,o[s]);e.push([a.code,c]),t.push([a.code,$a(a.code,c)])}return{string:Cl(t),bytes:ja(e),tuples:e,stringTuples:t,path:n}}function Ga(r){let e=[],t=[],n=null,o=0;for(;o<r.length;){let s=Tr(r,o),i=Ve(s),a=ie(s),c=H0(a,r.slice(o+i));if(c===0){e.push([s]),t.push([s]),o+=i;continue}let f=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw Nl("Invalid address Uint8Array: "+z(r,"base16"));e.push([s,f]);let u=$a(s,f);if(t.push([s,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:Cl(t),tuples:e,stringTuples:t,path:n}}function Cl(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}),za(e.join("/"))}function ja(r){return Le(r.map(e=>{let t=ie(e[0]),n=Uint8Array.from(en(t.code));return e.length>1&&e[1]!=null&&(n=Le([n,e[1]])),n}))}function H0(r,e){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let t=Tr(e instanceof Uint8Array?e:Uint8Array.from(e));return t+Ve(t)}}function za(r){return"/"+r.trim().split("/").filter(e=>e).join("/")}function Nl(r){return new Error("Error parsing address: "+r)}var $0=Symbol.for("nodejs.util.inspect.custom"),Wa=Symbol.for("@multiformats/js-multiaddr/multiaddr"),K0=[ie("dns").code,ie("dns4").code,ie("dns6").code,ie("dnsaddr").code],Xo=class r{bytes;#e;#t;#r;#i;[Wa]=!0;constructor(e){e==null&&(e="");let t;if(e instanceof Uint8Array)t=Ga(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);t=_l(e)}else if(Ul(e))t=Ga(e.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=t.bytes,this.#e=t.string,this.#t=t.tuples,this.#r=t.stringTuples,this.#i=t.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let e,t,n,o,s="",i=ie("tcp"),a=ie("udp"),c=ie("ip4"),f=ie("ip6"),u=ie("dns6"),l=ie("ip6zone");for(let[E,y]of this.stringTuples())E===l.code&&(s=`%${y??""}`),K0.includes(E)&&(t=i.name,o=443,n=`${y??""}${s}`,e=E===u.code?6:4),(E===i.code||E===a.code)&&(t=ie(E).name,o=parseInt(y??"")),(E===c.code||E===f.code)&&(t=ie(E).name,n=`${y??""}${s}`,e=E===f.code?6:4);if(e==null||t==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:e,host:n,transport:t,port:o}}protos(){return this.#t.map(([e])=>Object.assign({},ie(e)))}protoCodes(){return this.#t.map(([e])=>e)}protoNames(){return this.#t.map(([e])=>ie(e).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(e){return e=new r(e),new r(this.toString()+e.toString())}decapsulate(e){let t=e.toString(),n=this.toString(),o=n.lastIndexOf(t);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${e.toString()}`);return new r(n.slice(0,o))}decapsulateCode(e){let t=this.tuples();for(let n=t.length-1;n>=0;n--)if(t[n][0]===e)return new r(ja(t.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,o])=>{n===dn.p2p.code&&e.push([n,o]),n===dn["p2p-circuit"].code&&(e=[])});let t=e.pop();if(t?.[1]!=null){let n=t[1];return n[0]==="Q"||n[0]==="1"?z(he.decode(`z${n}`),"base58btc"):z(te.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#i}equals(e){return se(this.bytes,e.bytes)}async resolve(e){let t=this.protos().find(s=>s.resolvable);if(t==null)return[this];let n=Ll.get(t.name);if(n==null)throw new N(`no available resolver for ${t.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,e)).map(s=>Qn(s))}nodeAddress(){let e=this.toOptions();if(e.transport!=="tcp"&&e.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${e.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:e.family,address:e.host,port:e.port}}isThinWaistAddress(e){let t=(e??this).protos();return!(t.length!==2||t[0].code!==4&&t[0].code!==41||t[1].code!==6&&t[1].code!==273)}[$0](){return`Multiaddr(${this.#e})`}};var Ll=new Map;function Ul(r){return!!r?.[Wa]}function Qn(r){return new Xo(r)}async function*Qo(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 hc={};ge(hc,{Ed25519PrivateKey:()=>Pr,Ed25519PublicKey:()=>ro,generateKeyPair:()=>eg,generateKeyPairFromSeed:()=>af,unmarshalEd25519PrivateKey:()=>Xy,unmarshalEd25519PublicKey:()=>Qy});function Xe(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function pn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`Wrong positive integer: ${r}`)}function q0(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Ya(r,...e){if(!q0(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 es(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");pn(r.outputLen),pn(r.blockLen)}function mn(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function Dl(r,e){Ya(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var ts=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Pl(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var gn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),ct=(r,e)=>r<<32-e|r>>>e,z0=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!z0)throw new Error("Non little-endian hardware is not supported");var G0=async()=>{};async function Ol(r,e,t){let n=Date.now();for(let o=0;o<r;o++){t(o);let s=Date.now()-n;s>=0&&s<e||(await G0(),n+=s)}}function Za(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function cr(r){if(typeof r=="string"&&(r=Za(r)),!Pl(r))throw new Error(`expected Uint8Array, got ${typeof r}`);return r}function rs(...r){let e=0;for(let n=0;n<r.length;n++){let o=r[n];if(!Pl(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 s=r[n];t.set(s,o),o+=s.length}return t}var yn=class{clone(){return this._cloneInto()}},j0={}.toString;function Vl(r,e){if(e!==void 0&&j0.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function ns(r){let e=n=>r().update(cr(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function wn(r=32){if(ts&&typeof ts.getRandomValues=="function")return ts.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function W0(r,e,t,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(e,t,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(t>>o&s),a=Number(t&s),c=n?4:0,f=n?0:4;r.setUint32(e+c,i,n),r.setUint32(e+f,a,n)}var bn=class extends yn{constructor(e,t,n,o){super(),this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=o,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=gn(this.buffer)}update(e){mn(this);let{view:t,buffer:n,blockLen:o}=this;e=cr(e);let s=e.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=gn(e);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){mn(this),Dl(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;t[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)t[l]=0;W0(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=gn(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],s)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:t,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return e.length=o,e.pos=a,e.finished=s,e.destroyed=i,o%t&&e.buffer.set(n),e}};var os=BigInt(4294967295),Ja=BigInt(32);function Fl(r,e=!1){return e?{h:Number(r&os),l:Number(r>>Ja&os)}:{h:Number(r>>Ja&os)|0,l:Number(r&os)|0}}function Y0(r,e=!1){let t=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let o=0;o<r.length;o++){let{h:s,l:i}=Fl(r[o],e);[t[o],n[o]]=[s,i]}return[t,n]}var Z0=(r,e)=>BigInt(r>>>0)<<Ja|BigInt(e>>>0),J0=(r,e,t)=>r>>>t,X0=(r,e,t)=>r<<32-t|e>>>t,Q0=(r,e,t)=>r>>>t|e<<32-t,ey=(r,e,t)=>r<<32-t|e>>>t,ty=(r,e,t)=>r<<64-t|e>>>t-32,ry=(r,e,t)=>r>>>t-32|e<<64-t,ny=(r,e)=>e,oy=(r,e)=>r,sy=(r,e,t)=>r<<t|e>>>32-t,iy=(r,e,t)=>e<<t|r>>>32-t,ay=(r,e,t)=>e<<t-32|r>>>64-t,cy=(r,e,t)=>r<<t-32|e>>>64-t;function uy(r,e,t,n){let o=(e>>>0)+(n>>>0);return{h:r+t+(o/2**32|0)|0,l:o|0}}var ly=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),fy=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,hy=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),dy=(r,e,t,n,o)=>e+t+n+o+(r/2**32|0)|0,py=(r,e,t,n,o)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(o>>>0),my=(r,e,t,n,o,s)=>e+t+n+o+s+(r/2**32|0)|0;var yy={fromBig:Fl,split:Y0,toBig:Z0,shrSH:J0,shrSL:X0,rotrSH:Q0,rotrSL:ey,rotrBH:ty,rotrBL:ry,rotr32H:ny,rotr32L:oy,rotlSH:sy,rotlSL:iy,rotlBH:ay,rotlBL:cy,add:uy,add3L:ly,add3H:fy,add4L:hy,add4H:dy,add5H:my,add5L:py},q=yy;var[gy,wy]=q.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),ur=new Uint32Array(80),lr=new Uint32Array(80),Xa=class extends bn{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:e,Al:t,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:f,El:u,Fh:l,Fl:p,Gh:E,Gl:y,Hh:d,Hl:m}=this;return[e,t,n,o,s,i,a,c,f,u,l,p,E,y,d,m]}set(e,t,n,o,s,i,a,c,f,u,l,p,E,y,d,m){this.Ah=e|0,this.Al=t|0,this.Bh=n|0,this.Bl=o|0,this.Ch=s|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=u|0,this.Fh=l|0,this.Fl=p|0,this.Gh=E|0,this.Gl=y|0,this.Hh=d|0,this.Hl=m|0}process(e,t){for(let v=0;v<16;v++,t+=4)ur[v]=e.getUint32(t),lr[v]=e.getUint32(t+=4);for(let v=16;v<80;v++){let U=ur[v-15]|0,S=lr[v-15]|0,T=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=ur[v-2]|0,C=lr[v-2]|0,O=q.rotrSH(w,C,19)^q.rotrBH(w,C,61)^q.shrSH(w,C,6),_=q.rotrSL(w,C,19)^q.rotrBL(w,C,61)^q.shrSL(w,C,6),F=q.add4L(L,_,lr[v-7],lr[v-16]),$=q.add4H(F,T,O,ur[v-7],ur[v-16]);ur[v]=$|0,lr[v]=F|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:p,Fh:E,Fl:y,Gh:d,Gl:m,Hh:g,Hl:I}=this;for(let v=0;v<80;v++){let 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),T=l&E^~l&d,L=p&y^~p&m,w=q.add5L(I,S,L,wy[v],lr[v]),C=q.add5H(w,g,U,T,gy[v],ur[v]),O=w|0,_=q.rotrSH(n,o,28)^q.rotrBH(n,o,34)^q.rotrBH(n,o,39),F=q.rotrSL(n,o,28)^q.rotrBL(n,o,34)^q.rotrBL(n,o,39),$=n&s^n&a^s&a,J=o&i^o&c^i&c;g=d|0,I=m|0,d=E|0,m=y|0,E=l|0,y=p|0,{h:l,l:p}=q.add(f|0,u|0,C|0,O|0),f=a|0,u=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let x=q.add3L(O,F,J);n=q.add3H(x,C,_,$),o=x|0}({h:n,l:o}=q.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=q.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=q.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:u}=q.add(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:p}=q.add(this.Eh|0,this.El|0,l|0,p|0),{h:E,l:y}=q.add(this.Fh|0,this.Fl|0,E|0,y|0),{h:d,l:m}=q.add(this.Gh|0,this.Gl|0,d|0,m|0),{h:g,l:I}=q.add(this.Hh|0,this.Hl|0,g|0,I|0),this.set(n,o,s,i,a,c,f,u,l,p,E,y,d,m,g,I)}roundClean(){ur.fill(0),lr.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var xn=ns(()=>new Xa);var is={};ge(is,{bitGet:()=>ky,bitLen:()=>By,bitMask:()=>eo,bitSet:()=>Sy,bytesToHex:()=>Ut,bytesToNumberBE:()=>Dt,bytesToNumberLE:()=>fr,concatBytes:()=>Pt,createHmacDrbg:()=>tc,ensureBytes:()=>fe,equalBytes:()=>vy,hexToBytes:()=>Lr,hexToNumber:()=>ec,isBytes:()=>ut,numberToBytesBE:()=>hr,numberToBytesLE:()=>Ur,numberToHexUnpadded:()=>Kl,numberToVarBytesBE:()=>Ey,utf8ToBytes:()=>Ay,validateObject:()=>bt});var $l=BigInt(0),ss=BigInt(1),by=BigInt(2);function ut(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var xy=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function Ut(r){if(!ut(r))throw new Error("Uint8Array expected");let e="";for(let t=0;t<r.length;t++)e+=xy[r[t]];return e}function Kl(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function ec(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Lt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Ml(r){if(r>=Lt._0&&r<=Lt._9)return r-Lt._0;if(r>=Lt._A&&r<=Lt._F)return r-(Lt._A-10);if(r>=Lt._a&&r<=Lt._f)return r-(Lt._a-10)}function Lr(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let e=r.length,t=e/2;if(e%2)throw new Error("padded hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let o=0,s=0;o<t;o++,s+=2){let i=Ml(r.charCodeAt(s)),a=Ml(r.charCodeAt(s+1));if(i===void 0||a===void 0){let c=r[s]+r[s+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+s)}n[o]=i*16+a}return n}function Dt(r){return ec(Ut(r))}function fr(r){if(!ut(r))throw new Error("Uint8Array expected");return ec(Ut(Uint8Array.from(r).reverse()))}function hr(r,e){return Lr(r.toString(16).padStart(e*2,"0"))}function Ur(r,e){return hr(r,e).reverse()}function Ey(r){return Lr(Kl(r))}function fe(r,e,t){let n;if(typeof e=="string")try{n=Lr(e)}catch(s){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${s}`)}else if(ut(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 Pt(...r){let e=0;for(let o=0;o<r.length;o++){let s=r[o];if(!ut(s))throw new Error("Uint8Array expected");e+=s.length}let t=new Uint8Array(e),n=0;for(let o=0;o<r.length;o++){let s=r[o];t.set(s,n),n+=s.length}return t}function vy(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 By(r){let e;for(e=0;r>$l;r>>=ss,e+=1);return e}function ky(r,e){return r>>BigInt(e)&ss}var Sy=(r,e,t)=>r|(t?ss:$l)<<BigInt(e),eo=r=>(by<<BigInt(r-1))-ss,Qa=r=>new Uint8Array(r),Hl=r=>Uint8Array.from(r);function tc(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=Qa(r),o=Qa(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>t(o,n,...l),c=(l=Qa())=>{o=a(Hl([0]),l),n=a(),l.length!==0&&(o=a(Hl([1]),l),n=a())},f=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,p=[];for(;l<e;){n=a();let E=n.slice();p.push(E),l+=n.length}return Pt(...p)};return(l,p)=>{i(),c(l);let E;for(;!(E=p(f()));)c();return i(),E}}var Iy={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"||ut(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,s,i)=>{let a=Iy[s];if(typeof a!="function")throw new Error(`Invalid validator "${s}", expected function`);let c=r[o];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(o)}=${c} (${typeof c}), expected ${s}`)};for(let[o,s]of Object.entries(e))n(o,s,!1);for(let[o,s]of Object.entries(t))n(o,s,!0);return r}var be=BigInt(0),ae=BigInt(1),Dr=BigInt(2),Ry=BigInt(3),rc=BigInt(4),ql=BigInt(5),zl=BigInt(8),Ty=BigInt(9),_y=BigInt(16);function oe(r,e){let t=r%e;return t>=be?t:e+t}function Cy(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 as(r,e){if(r===be||e<=be)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=oe(r,e),n=e,o=be,s=ae,i=ae,a=be;for(;t!==be;){let f=n/t,u=n%t,l=o-i*f,p=s-a*f;n=t,t=u,o=i,s=a,i=l,a=p}if(n!==ae)throw new Error("invert: does not exist");return oe(o,e)}function Ny(r){let e=(r-ae)/Dr,t,n,o;for(t=r-ae,n=0;t%Dr===be;t/=Dr,n++);for(o=Dr;o<r&&Cy(o,e,r)!==r-ae;o++);if(n===1){let i=(r+ae)/rc;return function(c,f){let u=c.pow(f,i);if(!c.eql(c.sqr(u),f))throw new Error("Cannot find square root");return u}}let s=(t+ae)/Dr;return function(a,c){if(a.pow(c,e)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,u=a.pow(a.mul(a.ONE,o),t),l=a.pow(c,s),p=a.pow(c,t);for(;!a.eql(p,a.ONE);){if(a.eql(p,a.ZERO))return a.ZERO;let E=1;for(let d=a.sqr(p);E<f&&!a.eql(d,a.ONE);E++)d=a.sqr(d);let y=a.pow(u,ae<<BigInt(f-E-1));u=a.sqr(y),l=a.mul(l,y),p=a.mul(p,u),f=E}return l}}function Ly(r){if(r%rc===Ry){let e=(r+ae)/rc;return function(n,o){let s=n.pow(o,e);if(!n.eql(n.sqr(s),o))throw new Error("Cannot find square root");return s}}if(r%zl===ql){let e=(r-ql)/zl;return function(n,o){let s=n.mul(o,Dr),i=n.pow(s,e),a=n.mul(o,i),c=n.mul(n.mul(a,Dr),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),o))throw new Error("Cannot find square root");return f}}return r%_y,Ny(r)}var Gl=(r,e)=>(oe(r,e)&ae)===ae,Uy=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function nc(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=Uy.reduce((n,o)=>(n[o]="function",n),e);return bt(r,t)}function Dy(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 Py(r,e){let t=new Array(e.length),n=e.reduce((s,i,a)=>r.is0(i)?s:(t[a]=s,r.mul(s,i)),r.ONE),o=r.inv(n);return e.reduceRight((s,i,a)=>r.is0(i)?s:(t[a]=r.mul(s,t[a]),r.mul(s,i)),o),t}function oc(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function cs(r,e,t=!1,n={}){if(r<=be)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:o,nByteLength:s}=oc(r,e);if(s>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Ly(r),a=Object.freeze({ORDER:r,BITS:o,BYTES:s,MASK:eo(o),ZERO:be,ONE:ae,create:c=>oe(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return be<=c&&c<r},is0:c=>c===be,isOdd:c=>(c&ae)===ae,neg:c=>oe(-c,r),eql:(c,f)=>c===f,sqr:c=>oe(c*c,r),add:(c,f)=>oe(c+f,r),sub:(c,f)=>oe(c-f,r),mul:(c,f)=>oe(c*f,r),pow:(c,f)=>Dy(a,c,f),div:(c,f)=>oe(c*as(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>as(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Py(a,c),cmov:(c,f,u)=>u?f:c,toBytes:c=>t?Ur(c,s):hr(c,s),fromBytes:c=>{if(c.length!==s)throw new Error(`Fp.fromBytes: expected ${s}, got ${c.length}`);return t?fr(c):Dt(c)}});return Object.freeze(a)}function jl(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 Wl(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 sc(r){let e=Wl(r);return e+Math.ceil(e/2)}function Yl(r,e,t=!1){let n=r.length,o=Wl(e),s=sc(e);if(n<16||n<s||n>1024)throw new Error(`expected ${s}-1024 bytes of input, got ${n}`);let i=t?Dt(r):fr(r),a=oe(i,e-ae)+ae;return t?Ur(a,o):hr(a,o)}var Vy=BigInt(0),ic=BigInt(1);function us(r,e){let t=(o,s)=>{let i=s.negate();return o?i:s},n=o=>{let s=Math.ceil(e/o)+1,i=2**(o-1);return{windows:s,windowSize:i}};return{constTimeNegate:t,unsafeLadder(o,s){let i=r.ZERO,a=o;for(;s>Vy;)s&ic&&(i=i.add(a)),a=a.double(),s>>=ic;return i},precomputeWindow(o,s){let{windows:i,windowSize:a}=n(s),c=[],f=o,u=f;for(let l=0;l<i;l++){u=f,c.push(u);for(let p=1;p<a;p++)u=u.add(f),c.push(u);f=u.double()}return c},wNAF(o,s,i){let{windows:a,windowSize:c}=n(o),f=r.ZERO,u=r.BASE,l=BigInt(2**o-1),p=2**o,E=BigInt(o);for(let y=0;y<a;y++){let d=y*c,m=Number(i&l);i>>=E,m>c&&(m-=p,i+=ic);let g=d,I=d+Math.abs(m)-1,v=y%2!==0,U=m<0;m===0?u=u.add(t(v,s[g])):f=f.add(t(U,s[I]))}return{p:f,f:u}},wNAFCached(o,s,i,a){let c=o._WINDOW_SIZE||1,f=s.get(o);return f||(f=this.precomputeWindow(o,c),c!==1&&s.set(o,a(f))),this.wNAF(c,f,i)}}}function to(r){return nc(r.Fp),bt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...oc(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var lt=BigInt(0),ze=BigInt(1),ls=BigInt(2),Fy=BigInt(8),My={zip215:!0};function Hy(r){let e=to(r);return bt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function fs(r){let e=Hy(r),{Fp:t,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=e,f=ls<<BigInt(a*8)-ze,u=t.create,l=e.uvRatio||((B,b)=>{try{return{isValid:!0,value:t.sqrt(B*t.inv(b))}}catch{return{isValid:!1,value:lt}}}),p=e.adjustScalarBytes||(B=>B),E=e.domain||((B,b,P)=>{if(b.length||P)throw new Error("Contexts/pre-hash are not supported");return B}),y=B=>typeof B=="bigint"&&lt<B,d=(B,b)=>y(B)&&y(b)&&B<b,m=B=>B===lt||d(B,f);function g(B,b){if(d(B,b))return B;throw new Error(`Expected valid scalar < ${b}, got ${typeof B} ${B}`)}function I(B){return B===lt?B:g(B,n)}let v=new Map;function U(B){if(!(B instanceof S))throw new Error("ExtendedPoint expected")}class S{constructor(b,P,M,K){if(this.ex=b,this.ey=P,this.ez=M,this.et=K,!m(b))throw new Error("x required");if(!m(P))throw new Error("y required");if(!m(M))throw new Error("z required");if(!m(K))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(b){if(b instanceof S)throw new Error("extended point not allowed");let{x:P,y:M}=b||{};if(!m(P)||!m(M))throw new Error("invalid affine point");return new S(P,M,ze,u(P*M))}static normalizeZ(b){let P=t.invertBatch(b.map(M=>M.ez));return b.map((M,K)=>M.toAffine(P[K])).map(S.fromAffine)}_setWindowSize(b){this._WINDOW_SIZE=b,v.delete(this)}assertValidity(){let{a:b,d:P}=e;if(this.is0())throw new Error("bad point: ZERO");let{ex:M,ey:K,ez:G,et:W}=this,ne=u(M*M),Z=u(K*K),X=u(G*G),pe=u(X*X),ue=u(ne*b),ve=u(X*u(ue+Z)),Ae=u(pe+u(P*u(ne*Z)));if(ve!==Ae)throw new Error("bad point: equation left != right (1)");let ye=u(M*K),Re=u(G*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:G,ey:W,ez:ne}=b,Z=u(P*ne),X=u(G*K),pe=u(M*ne),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,G=u(P*P),W=u(M*M),ne=u(ls*u(K*K)),Z=u(b*G),X=P+M,pe=u(u(X*X)-G-W),ue=Z+W,ve=ue-ne,Ae=Z-W,ye=u(pe*ve),Re=u(ue*Ae),Rt=u(pe*Ae),kr=u(ve*ue);return new S(ye,Re,kr,Rt)}add(b){U(b);let{a:P,d:M}=e,{ex:K,ey:G,ez:W,et:ne}=this,{ex:Z,ey:X,ez:pe,et:ue}=b;if(P===BigInt(-1)){let gu=u((G-K)*(X+Z)),wu=u((G+K)*(X-Z)),Ki=u(wu-gu);if(Ki===lt)return this.double();let bu=u(W*ls*ue),xu=u(ne*ls*pe),Eu=xu+bu,vu=wu+gu,Au=xu-bu,Sp=u(Eu*Ki),Ip=u(vu*Au),Rp=u(Eu*Au),Tp=u(Ki*vu);return new S(Sp,Ip,Tp,Rp)}let ve=u(K*Z),Ae=u(G*X),ye=u(ne*M*ue),Re=u(W*pe),Rt=u((K+G)*(Z+X)-ve-Ae),kr=Re-ye,$n=Re+ye,yu=u(Ae-P*ve),vp=u(Rt*kr),Ap=u($n*yu),Bp=u(Rt*yu),kp=u(kr*$n);return new S(vp,Ap,kp,Bp)}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===lt?L:this.equals(L)||P===ze?this:this.equals(T)?this.wNAF(P).p:w.unsafeLadder(this,P)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return w.unsafeLadder(this,n).is0()}toAffine(b){let{ex:P,ey:M,ez:K}=this,G=this.is0();b==null&&(b=G?Fy:t.inv(K));let W=u(P*b),ne=u(M*b),Z=u(K*b);if(G)return{x:lt,y:ze};if(Z!==ze)throw new Error("invZ was invalid");return{x:W,y:ne}}clearCofactor(){let{h:b}=e;return b===ze?this:this.multiplyUnsafe(b)}static fromHex(b,P=!1){let{d:M,a:K}=e,G=t.BYTES;b=fe("pointHex",b,G);let W=b.slice(),ne=b[G-1];W[G-1]=ne&-129;let Z=fr(W);Z===lt||(P?g(Z,f):g(Z,t.ORDER));let X=u(Z*Z),pe=u(X-ze),ue=u(M*X-K),{isValid:ve,value:Ae}=l(pe,ue);if(!ve)throw new Error("Point.fromHex: invalid y coordinate");let ye=(Ae&ze)===ze,Re=(ne&128)!==0;if(!P&&Ae===lt&&Re)throw new Error("Point.fromHex: x=0 and x_0=1");return Re!==ye&&(Ae=u(-Ae)),S.fromAffine({x:Ae,y:Z})}static fromPrivateKey(b){return _(b).point}toRawBytes(){let{x:b,y:P}=this.toAffine(),M=Ur(P,t.BYTES);return M[M.length-1]|=b&ze?128:0,M}toHex(){return Ut(this.toRawBytes())}}S.BASE=new S(e.Gx,e.Gy,ze,u(e.Gx*e.Gy)),S.ZERO=new S(lt,ze,ze,lt);let{BASE:T,ZERO:L}=S,w=us(S,a*8);function C(B){return oe(B,n)}function O(B){return C(fr(B))}function _(B){let b=a;B=fe("private key",B,b);let P=fe("hashed private key",s(B),2*b),M=p(P.slice(0,b)),K=P.slice(b,2*b),G=O(M),W=T.multiply(G),ne=W.toRawBytes();return{head:M,prefix:K,scalar:G,point:W,pointBytes:ne}}function F(B){return _(B).pointBytes}function $(B=new Uint8Array,...b){let P=Pt(...b);return O(s(E(P,fe("context",B),!!o)))}function J(B,b,P={}){B=fe("message",B),o&&(B=o(B));let{prefix:M,scalar:K,pointBytes:G}=_(b),W=$(P.context,M,B),ne=T.multiply(W).toRawBytes(),Z=$(P.context,ne,G,B),X=C(W+Z*K);I(X);let pe=Pt(ne,Ur(X,t.BYTES));return fe("result",pe,a*2)}let x=My;function k(B,b,P,M=x){let{context:K,zip215:G}=M,W=t.BYTES;B=fe("signature",B,2*W),b=fe("message",b),o&&(b=o(b));let ne=fr(B.slice(W,2*W)),Z,X,pe;try{Z=S.fromHex(P,G),X=S.fromHex(B.slice(0,W),G),pe=T.multiplyUnsafe(ne)}catch{return!1}if(!G&&Z.isSmallOrder())return!1;let ue=$(K,X.toRawBytes(),Z.toRawBytes(),b);return X.add(Z.multiplyUnsafe(ue)).subtract(pe).clearCofactor().equals(S.ZERO)}return T._setWindowSize(8),{CURVE:e,getPublicKey:F,sign:J,verify:k,ExtendedPoint:S,utils:{getExtendedPublicKey:_,randomPrivateKey:()=>i(t.BYTES),precompute(B=8,b=S.BASE){return b._setWindowSize(B),b.multiply(BigInt(3)),b}}}}var cc=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Zl=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Wv=BigInt(0),$y=BigInt(1),ac=BigInt(2),Ky=BigInt(5),Jl=BigInt(10),qy=BigInt(20),zy=BigInt(40),Xl=BigInt(80);function Gy(r){let e=cc,n=r*r%e*r%e,o=ce(n,ac,e)*n%e,s=ce(o,$y,e)*r%e,i=ce(s,Ky,e)*s%e,a=ce(i,Jl,e)*i%e,c=ce(a,qy,e)*a%e,f=ce(c,zy,e)*c%e,u=ce(f,Xl,e)*f%e,l=ce(u,Xl,e)*f%e,p=ce(l,Jl,e)*i%e;return{pow_p_5_8:ce(p,ac,e)*r%e,b2:n}}function jy(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Wy(r,e){let t=cc,n=oe(e*e*e,t),o=oe(n*n*e,t),s=Gy(r*o).pow_p_5_8,i=oe(r*n*s,t),a=oe(e*i*i,t),c=i,f=oe(i*Zl,t),u=a===r,l=a===oe(-r,t),p=a===oe(-r*Zl,t);return u&&(i=c),(l||p)&&(i=f),Gl(i,t)&&(i=oe(-i,t)),{isValid:u||l,value:i}}var Ot=cs(cc,void 0,!0),uc={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Ot,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:xn,randomBytes:wn,adjustScalarBytes:jy,uvRatio:Wy},En=fs(uc);function Ql(r,e,t){if(e.length>255)throw new Error("Context is too big");return rs(Za("SigEd25519 no Ed25519 collisions"),new Uint8Array([t?1:0,e.length]),e,r)}var Yv=fs({...uc,domain:Ql}),Zv=fs({...uc,domain:Ql,prehash:xn});var Yy=(Ot.ORDER+BigInt(3))/BigInt(8),Jv=Ot.pow(ac,Yy),Xv=Ot.sqrt(Ot.neg(Ot.ONE)),Qv=(Ot.ORDER-BigInt(5))/BigInt(8),e2=BigInt(486662);var t2=jl(Ot,Ot.neg(BigInt(486664)));var r2=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),n2=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),o2=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),s2=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var i2=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var vn=32,Vt=64,hs=32;function ef(){let r=En.utils.randomPrivateKey(),e=En.getPublicKey(r);return{privateKey:of(r,e),publicKey:e}}function tf(r){if(r.length!==hs)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=En.getPublicKey(e);return{privateKey:of(e,t),publicKey:t}}function rf(r,e){let t=r.subarray(0,hs);return En.sign(e instanceof Uint8Array?e:e.subarray(),t)}function nf(r,e,t){return En.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function of(r,e){let t=new Uint8Array(Vt);for(let n=0;n<hs;n++)t[n]=r[n],t[hs+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 lc={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function sf(r){let e=r?.algorithm??"AES-GCM",t=r?.keyLength??16,n=r?.nonceLength??12,o=r?.digest??"SHA-256",s=r?.saltLength??16,i=r?.iterations??32767,a=De.get();t*=8;async function c(l,p){let E=a.getRandomValues(new Uint8Array(s)),y=a.getRandomValues(new Uint8Array(n)),d={name:e,iv:y};typeof p=="string"&&(p=j(p));let m;if(p.length===0){m=await a.subtle.importKey("jwk",lc,{name:"AES-GCM"},!0,["encrypt"]);try{let I={name:"PBKDF2",salt:E,iterations:i,hash:{name:o}},v=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(I,v,{name:e,length:t},!0,["encrypt"])}catch{m=await a.subtle.importKey("jwk",lc,{name:"AES-GCM"},!0,["encrypt"])}}else{let I={name:"PBKDF2",salt:E,iterations:i,hash:{name:o}},v=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(I,v,{name:e,length:t},!0,["encrypt"])}let g=await a.subtle.encrypt(d,m,l);return Le([E,d.iv,new Uint8Array(g)])}async function f(l,p){let E=l.subarray(0,s),y=l.subarray(s,s+n),d=l.subarray(s+n),m={name:e,iv:y};typeof p=="string"&&(p=j(p));let g;if(p.length===0)try{let v={name:"PBKDF2",salt:E,iterations:i,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",lc,{name:"AES-GCM"},!0,["decrypt"])}else{let v={name:"PBKDF2",salt:E,iterations:i,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 An(r,e){let n=await sf().encrypt(r,e);return nr.encode(n)}var de;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(de||(de={}));var fc;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(fc||(fc={}));(function(r){r.codec=()=>Zn(fc)})(de||(de={}));var xt;(function(r){let e;r.codec=()=>(e==null&&(e=on((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),de.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),o.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let o={},s=n==null?t.len:t.pos+n;for(;t.pos<s;){let i=t.uint32();switch(i>>>3){case 1:o.Type=de.codec().decode(t);break;case 2:o.Data=t.bytes();break;default:t.skipType(i&7);break}}return o})),e),r.encode=t=>rn(t,r.codec()),r.decode=t=>tn(t,r.codec())})(xt||(xt={}));var Ft;(function(r){let e;r.codec=()=>(e==null&&(e=on((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),de.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),o.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let o={},s=n==null?t.len:t.pos+n;for(;t.pos<s;){let i=t.uint32();switch(i>>>3){case 1:o.Type=de.codec().decode(t);break;case 2:o.Data=t.bytes();break;default:t.skipType(i&7);break}}return o})),e),r.encode=t=>rn(t,r.codec()),r.decode=t=>tn(t,r.codec())})(Ft||(Ft={}));var ro=class{_key;constructor(e){this._key=Bn(e,vn)}verify(e,t){return nf(this._key,t,e)}marshal(){return this._key}get bytes(){return xt.encode({Type:de.Ed25519,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(e)?e.then(({bytes:t})=>t):e.bytes}},Pr=class{_key;_publicKey;constructor(e,t){this._key=Bn(e,Vt),this._publicKey=Bn(t,vn)}sign(e){return rf(this._key,e)}get public(){return new ro(this._publicKey)}marshal(){return this._key}get bytes(){return Ft.encode({Type:de.Ed25519,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}async hash(){let e=we.digest(this.bytes),t;return Xe(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=Je.digest(this.public.bytes);return he.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return An(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Xy(r){if(r.length>Vt){r=Bn(r,Vt+vn);let n=r.subarray(0,Vt),o=r.subarray(Vt,r.length);return new Pr(n,o)}r=Bn(r,Vt);let e=r.subarray(0,Vt),t=r.subarray(vn);return new Pr(e,t)}function Qy(r){return r=Bn(r,vn),new ro(r)}async function eg(){let{privateKey:r,publicKey:e}=ef();return new Pr(r,e)}async function af(r){let{privateKey:e,publicKey:t}=tf(r);return new Pr(e,t)}function Bn(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new N(`Key must be a Uint8Array of length ${e}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}var vc={};ge(vc,{MAX_RSA_KEY_SIZE:()=>mo,RsaPrivateKey:()=>Tn,RsaPublicKey:()=>po,fromJwk:()=>Ig,generateKeyPair:()=>Rg,unmarshalRsaPrivateKey:()=>xc,unmarshalRsaPublicKey:()=>Sg});function Or(r){if(isNaN(r)||r<=0)throw new N("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return wn(r)}var yr={};ge(yr,{exportToPem:()=>Eg,importFromPem:()=>vg,jwkToPkcs1:()=>gg,jwkToPkix:()=>bg,pkcs1ToJwk:()=>yg,pkixToJwk:()=>wg});var ps=class extends yn{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,es(e);let n=cr(t);if(this.iHash=e.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let o=this.blockLen,s=new Uint8Array(o);s.set(n.length>o?e.create().update(n).digest():n);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=e.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),s.fill(0)}update(e){return mn(this),this.iHash.update(e),this}digestInto(e){mn(this),Ya(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));let{oHash:t,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return e=e,e.finished=o,e.destroyed=s,e.blockLen=i,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},no=(r,e,t)=>new ps(r,e).update(t).digest();no.create=(r,e)=>new ps(r,e);function tg(r,e,t,n){es(r);let o=Vl({dkLen:32,asyncTick:10},n),{c:s,dkLen:i,asyncTick:a}=o;if(pn(s),pn(i),pn(a),s<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=cr(e),f=cr(t),u=new Uint8Array(i),l=no.create(r,c),p=l._cloneInto().update(f);return{c:s,dkLen:i,asyncTick:a,DK:u,PRF:l,PRFSalt:p}}function rg(r,e,t,n,o){return r.destroy(),e.destroy(),n&&n.destroy(),o.fill(0),t}async function dc(r,e,t,n){let{c:o,dkLen:s,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=tg(r,e,t,n),u,l=new Uint8Array(4),p=gn(l),E=new Uint8Array(c.outputLen);for(let y=1,d=0;d<s;y++,d+=c.outputLen){let m=a.subarray(d,d+c.outputLen);p.setInt32(0,y,!1),(u=f._cloneInto(u)).update(l).digestInto(E),m.set(E.subarray(0,m.length)),await Ol(o-1,i,()=>{c._cloneInto(u).update(E).digestInto(E);for(let g=0;g<m.length;g++)m[g]^=E[g]})}return rg(c,f,a,u,E)}var Y=st(cf());function Vr(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 dr(r,e,t=-1){let n=t,o=r,s=0,i=Math.pow(2,e);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),s=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),s=n}let f=new Uint8Array(c);for(let u=a-1;u>=0;u--){let l=Math.pow(2,u*e);f[s-u-1]=Math.floor(o/l),o-=f[s-u-1]*l}return c}i*=Math.pow(2,e)}return new ArrayBuffer(0)}function gs(...r){let e=0,t=0;for(let s of r)e+=s.length;let n=new ArrayBuffer(e),o=new Uint8Array(n);for(let s of r)o.set(s,t),t+=s.length;return o}function mc(){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=Vr(t,8),o=new ArrayBuffer(this.valueHex.byteLength),s=new Uint8Array(o);for(let a=0;a<this.valueHex.byteLength;a++)s[a]=r[a];return s[0]&=127,Vr(s,8)-n}function uf(r){let e=r<0?r*-1:r,t=128;for(let n=1;n<8;n++){if(e<=t){if(r<0){let i=t-e,a=dr(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=dr(e,8,n),s=new Uint8Array(o);if(s[0]&128){let i=o.slice(0),a=new Uint8Array(i);o=new ArrayBuffer(o.byteLength+1),s=new Uint8Array(o);for(let c=0;c<i.byteLength;c++)s[c+1]=a[c];s[0]=0}return o}t*=Math.pow(2,8)}return new ArrayBuffer(0)}function lf(r,e){if(r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let o=0;o<t.length;o++)if(t[o]!==n[o])return!1;return!0}function Fe(r,e){let t=r.toString(10);if(e<t.length)return"";let n=e-t.length,o=new Array(n);for(let i=0;i<n;i++)o[i]="0";return o.join("").concat(t)}var U2=Math.log(2);function ws(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function yc(r){let e=0,t=0;for(let o=0;o<r.length;o++){let s=r[o];e+=s.byteLength}let n=new Uint8Array(e);for(let o=0;o<r.length;o++){let s=r[o];n.set(new Uint8Array(s),t),t+=s.byteLength}return n.buffer}function qt(r,e,t,n){return e instanceof Uint8Array?e.byteLength?t<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):e.byteLength-t-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var so=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return yc(this.items)}},oo=[new Uint8Array([1])],ff="0123456789";var In="",ht=new ArrayBuffer(0),gc=new Uint8Array(0),io="EndOfContent",df="OCTET STRING",pf="BIT STRING";function zt(r){var e;return e=class extends r{constructor(...n){var o;super(...n);let s=n[0]||{};this.isHexOnly=(o=s.isHexOnly)!==null&&o!==void 0?o:!1,this.valueHexView=s.valueHex?Y.BufferSourceConverter.toUint8Array(s.valueHex):gc}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,o,s){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!qt(this,i,o,s))return-1;let a=o+s;return this.valueHexView=i.subarray(o,a),this.valueHexView.length?(this.blockLength=s,a):(this.warnings.push("Zero buffer length"),o)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",ht)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Y.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var Ht=class{constructor({blockLength:e=0,error:t=In,warnings:n=[],valueBeforeDecode:o=gc}={}){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)}}};Ht.NAME="baseBlock";var Ce=class extends Ht{fromBER(e,t,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(e,t){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};Ce.NAME="valueBlock";var bs=class extends zt(Ht){constructor({idBlock:e={}}={}){var t,n,o,s;super(),e?(this.isHexOnly=(t=e.isHexOnly)!==null&&t!==void 0?t:!1,this.valueHexView=e.valueHex?Y.BufferSourceConverter.toUint8Array(e.valueHex):gc,this.tagClass=(n=e.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(o=e.tagNumber)!==null&&o!==void 0?o:-1,this.isConstructed=(s=e.isConstructed)!==null&&s!==void 0?s:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(e=!1){let t=0;switch(this.tagClass){case 1:t|=0;break;case 2:t|=64;break;case 3:t|=128;break;case 4:t|=192;break;default:return this.error="Unknown tag class",ht}if(this.isConstructed&&(t|=32),this.tagNumber<31&&!this.isHexOnly){let o=new Uint8Array(1);if(!e){let s=this.tagNumber;s&=31,t|=s,o[0]=t}return o.buffer}if(!this.isHexOnly){let o=dr(this.tagNumber,7),s=new Uint8Array(o),i=o.byteLength,a=new Uint8Array(i+1);if(a[0]=t|31,!e){for(let c=0;c<i-1;c++)a[c+1]=s[c]|128;a[i]=s[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=t|31,!e){let o=this.valueHexView;for(let s=0;s<o.length-1;s++)n[s+1]=o[s]|128;n[this.valueHexView.byteLength]=o[o.length-1]}return n.buffer}fromBER(e,t,n){let o=Y.BufferSourceConverter.toUint8Array(e);if(!qt(this,o,t,n))return-1;let s=o.subarray(t,t+n);if(s.length===0)return this.error="Zero buffer length",-1;switch(s[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(s[0]&32)===32,this.isHexOnly=!1;let a=s[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),u=255;for(;s[c]&128;){if(f[c-1]=s[c]&127,c++,c>=s.length)return this.error="End of input reached before message was fully decoded",-1;if(c===u){u+=255;let p=new Uint8Array(u);for(let E=0;E<f.length;E++)p[E]=f[E];f=this.valueHexView=new Uint8Array(u)}}this.blockLength=c+1,f[c-1]=s[c]&127;let l=new Uint8Array(c);for(let p=0;p<c;p++)l[p]=f[p];f=this.valueHexView=new Uint8Array(c),f.set(l),this.blockLength<=9?this.tagNumber=Vr(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}}};bs.NAME="identificationBlock";var xs=class extends Ht{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(!qt(this,o,t,n))return-1;let s=o.subarray(t,t+n);if(s.length===0)return this.error="Zero buffer length",-1;if(s[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=s[0]===128,this.isIndefiniteForm)return this.blockLength=1,t+this.blockLength;if(this.longFormUsed=!!(s[0]&128),this.longFormUsed===!1)return this.length=s[0],this.blockLength=1,t+this.blockLength;let i=s[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>s.length)return this.error="End of input reached before message was fully decoded",-1;let a=t+1,c=o.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Vr(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,t+this.blockLength}toBER(e=!1){let t,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=128),t;if(this.longFormUsed){let o=dr(this.length,8);if(o.byteLength>127)return this.error="Too big length",ht;if(t=new ArrayBuffer(o.byteLength+1),e)return t;let s=new Uint8Array(o);n=new Uint8Array(t),n[0]=o.byteLength|128;for(let i=0;i<o.byteLength;i++)n[i+1]=s[i];return t}return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=this.length),t}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};xs.NAME="lengthBlock";var D={},ke=class extends Ht{constructor({name:e=In,optional:t=!1,primitiveSchema:n,...o}={},s){super(o),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new bs(o),this.lenBlock=new xs(o),this.valueBlock=s?new s(o):new Ce(o)}fromBER(e,t,n){let o=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return o===-1?(this.error=this.valueBlock.error,o):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),o)}toBER(e,t){let n=t||new so;t||mf(this);let o=this.idBlock.toBER(e);if(n.write(o),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(e,n),n.write(new ArrayBuffer(2));else{let s=this.valueBlock.toBER(e);this.lenBlock.length=s.byteLength;let i=this.lenBlock.toBER(e);n.write(i),n.write(s)}return t?ht: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 lf(t,n)}};ke.NAME="BaseBlock";function mf(r){if(r instanceof D.Constructed)for(let e of r.valueBlock.value)mf(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Es=class extends ke{constructor({value:e=In,...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}'`}};Es.NAME="BaseStringBlock";var vs=class extends zt(Ce){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};vs.NAME="PrimitiveValueBlock";var yf,As=class extends ke{constructor(e={}){super(e,vs),this.idBlock.isConstructed=!1}};yf=As;D.Primitive=yf;As.NAME="PRIMITIVE";function fg(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 ri(r,e=0,t=r.length){let n=e,o=new ke({},Ce),s=new Ht;if(!qt(s,r,e,t))return o.error=s.error,{offset:-1,result:o};if(!r.subarray(e,e+t).length)return o.error="Zero buffer length",{offset:-1,result:o};let a=o.idBlock.fromBER(r,e,t);if(o.idBlock.warnings.length&&o.warnings.concat(o.idBlock.warnings),a===-1)return o.error=o.idBlock.error,{offset:-1,result:o};if(e=a,t-=o.idBlock.blockLength,a=o.lenBlock.fromBER(r,e,t),o.lenBlock.warnings.length&&o.warnings.concat(o.lenBlock.warnings),a===-1)return o.error=o.lenBlock.error,{offset:-1,result:o};if(e=a,t-=o.lenBlock.blockLength,!o.idBlock.isConstructed&&o.lenBlock.isIndefiniteForm)return o.error="Indefinite length form used for primitive encoding form",{offset:-1,result:o};let c=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=fg(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 Rn(r){if(!r.byteLength){let e=new ke({},Ce);return e.error="Input buffer has zero length",{offset:-1,result:e}}return ri(Y.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function hg(r,e){return r?1:e}var Et=class extends Ce{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n){let o=Y.BufferSourceConverter.toUint8Array(e);if(!qt(this,o,t,n))return-1;if(this.valueBeforeDecodeView=o.subarray(t,t+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),t;let s=t;for(;hg(this.isIndefiniteForm,n)>0;){let i=ri(o,s,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(s=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===io)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===io?this.value.pop():this.warnings.push("No EndOfContent block encoded")),s}toBER(e,t){let n=t||new so;for(let o=0;o<this.value.length;o++)this.value[o].toBER(e,n);return t?ht: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 gf,pr=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} :`}};gf=pr;D.Constructed=gf;pr.NAME="CONSTRUCTED";var Bs=class extends Ce{fromBER(e,t,n){return t}toBER(e){return ht}};Bs.override="EndOfContentValueBlock";var wf,ks=class extends ke{constructor(e={}){super(e,Bs),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};wf=ks;D.EndOfContent=wf;ks.NAME=io;var bf,mr=class extends ke{constructor(e={}){super(e,Ce),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(e,t,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,t+n>e.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):t+n}toBER(e,t){let n=new ArrayBuffer(2);if(!e){let o=new Uint8Array(n);o[0]=5,o[1]=0}return t&&t.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};bf=mr;D.Null=bf;mr.NAME="NULL";var Ss=class extends zt(Ce){constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=Y.BufferSourceConverter.toUint8Array(t.valueHex):this.valueHexView=new Uint8Array(1),e&&(this.value=e)}get value(){for(let e of this.valueHexView)if(e>0)return!0;return!1}set value(e){this.valueHexView[0]=e?255:0}fromBER(e,t,n){let o=Y.BufferSourceConverter.toUint8Array(e);return qt(this,o,t,n)?(this.valueHexView=o.subarray(t,t+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,mc.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Ss.NAME="BooleanValueBlock";var xf,Is=class extends ke{constructor(e={}){super(e,Ss),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}`}};xf=Is;D.Boolean=xf;Is.NAME="BOOLEAN";var Rs=class extends zt(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 s=0;s<this.value.length;s++){let i=this.value[s].constructor.NAME;if(i===io){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==df)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}}};Rs.NAME="OctetStringValueBlock";var Ef,$t=class r extends ke{constructor({idBlock:e={},lenBlock:t={},...n}={}){var o,s;(o=n.isConstructed)!==null&&o!==void 0||(n.isConstructed=!!(!((s=n.value)===null||s===void 0)&&s.length)),super({idBlock:{isConstructed:n.isConstructed,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},Rs),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(e,t,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),t;if(!this.valueBlock.isConstructed){let s=(e instanceof ArrayBuffer?new Uint8Array(e):e).subarray(t,t+n);try{if(s.byteLength){let i=ri(s,0,s.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(e,t,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?pr.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)}};Ef=$t;D.OctetString=Ef;$t.NAME=df;var Ts=class extends zt(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===io){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==pf)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return o}let s=Y.BufferSourceConverter.toUint8Array(e);if(!qt(this,s,t,n))return-1;let i=s.subarray(t,t+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=ri(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,t+n}toBER(e,t){if(this.isConstructed)return Et.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return ht;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};Ts.NAME="BitStringValueBlock";var vf,Sn=class extends ke{constructor({idBlock:e={},lenBlock:t={},...n}={}){var o,s;(o=n.isConstructed)!==null&&o!==void 0||(n.isConstructed=!!(!((s=n.value)===null||s===void 0)&&s.length)),super({idBlock:{isConstructed:n.isConstructed,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},Ts),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(e,t,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(e,t,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return pr.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)}`}}};vf=Sn;D.BitString=vf;Sn.NAME=pf;var Af;function dg(r,e){let t=new Uint8Array([0]),n=new Uint8Array(r),o=new Uint8Array(e),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,f=0,u=c<i?i:c,l=0;for(let p=u;p>=0;p--,l++){switch(!0){case l<a.length:f=s[i-l]+a[c-l]+t[0];break;default:f=s[i-l]+t[0]}switch(t[0]=f/10,!0){case l>=s.length:s=gs(new Uint8Array([f%10]),s);break;default:s[i-l]=f%10}}return t[0]>0&&(s=gs(t,s)),s}function hf(r){if(r>=oo.length)for(let e=oo.length;e<=r;e++){let t=new Uint8Array([0]),n=oo[e-1].slice(0);for(let o=n.length-1;o>=0;o--){let s=new Uint8Array([(n[o]<<1)+t[0]]);t[0]=s[0]/10,n[o]=s[0]%10}t[0]>0&&(n=gs(t,n)),oo.push(n)}return oo[r]}function pg(r,e){let t=0,n=new Uint8Array(r),o=new Uint8Array(e),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,f,u=0;for(let l=c;l>=0;l--,u++)switch(f=s[i-u]-a[c-u]-t,!0){case f<0:t=1,s[i-u]=f+10;break;default:t=0,s[i-u]=f}if(t>0)for(let l=i-c+1;l>=0;l--,u++)if(f=s[i-u]-t,f<0)t=1,s[i-u]=f+10;else{t=0,s[i-u]=f;break}return s.slice()}var ao=class extends zt(Ce){constructor({value:e,...t}={}){super(t),this._valueDec=0,t.valueHex&&this.setValueHex(),e!==void 0&&(this.valueDec=e)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=mc.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(uf(e))}get valueDec(){return this._valueDec}fromDER(e,t,n,o=0){let s=this.fromBER(e,t,n);if(s===-1)return s;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):o!==0&&i.length<o&&(o-i.length>1&&(o=i.length+1),this.valueHexView=i.subarray(o-i.length)),s}toDER(e=!1){let t=this.valueHexView;switch(!0){case(t[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(t,1),this.valueHexView=n}break;case(t[0]===0&&(t[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(e)}fromBER(e,t,n){let o=super.fromBER(e,t,n);return o===-1||this.setValueHex(),o}toBER(e){return e?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let e=this.valueHexView.length*8-1,t=new Uint8Array(this.valueHexView.length*8/3),n=0,o,s=this.valueHexView,i="",a=!1;for(let c=s.byteLength-1;c>=0;c--){o=s[c];for(let f=0;f<8;f++){if((o&1)===1)switch(n){case e:t=pg(hf(n),t),i="-";break;default:t=dg(t,hf(n))}n++,o>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(i+=ff.charAt(t[c]));return a===!1&&(i+=ff.charAt(0)),i}};Af=ao;ao.NAME="IntegerValueBlock";Object.defineProperty(Af.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Bf,me=class r extends ke{constructor(e={}){super(e,ao),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return ws(),BigInt(this.valueBlock.toString())}static fromBigInt(e){ws();let t=BigInt(e),n=new so,o=t.toString(16).replace(/^-/,""),s=new Uint8Array(Y.Convert.FromHex(o));if(t<0){let a=new Uint8Array(s.length+(s[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${Y.Convert.ToHex(a)}`)+t,u=Y.BufferSourceConverter.toUint8Array(Y.Convert.FromHex(f.toString(16)));u[0]|=128,n.write(u)}else s[0]&128&&n.write(new Uint8Array([0])),n.write(s);return new r({valueHex:n.final()})}convertToDER(){let e=new r({valueHex:this.valueBlock.valueHexView});return e.valueBlock.toDER(),e}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};Bf=me;D.Integer=Bf;me.NAME="INTEGER";var kf,_s=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};kf=_s;D.Enumerated=kf;_s.NAME="ENUMERATED";var co=class extends zt(Ce){constructor({valueDec:e=-1,isFirstSid:t=!1,...n}={}){super(n),this.valueDec=e,this.isFirstSid=t}fromBER(e,t,n){if(!n)return t;let o=Y.BufferSourceConverter.toUint8Array(e);if(!qt(this,o,t,n))return-1;let s=o.subarray(t,t+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=s[a]&127,this.blockLength++,!!(s[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,s[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Vr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){ws();let t=BigInt(e).toString(2);for(;t.length%7;)t="0"+t;let n=new Uint8Array(t.length/7);for(let o=0;o<n.length;o++)n[o]=parseInt(t.slice(o*7,o*7+7),2)+(o+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(e){if(this.isHexOnly){if(e)return new ArrayBuffer(this.valueHexView.byteLength);let o=this.valueHexView,s=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)s[i]=o[i]|128;return s[this.blockLength-1]=o[this.blockLength-1],s.buffer}let t=dr(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",ht;let n=new Uint8Array(t.byteLength);if(!e){let o=new Uint8Array(t),s=t.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n}toString(){let e="";if(this.isHexOnly)e=Y.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let t=this.valueDec;this.valueDec<=39?e="0.":this.valueDec<=79?(e="1.",t-=40):(e="2.",t-=80),e+=t.toString()}else e=this.valueDec.toString();return e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};co.NAME="sidBlock";var Cs=class extends Ce{constructor({value:e=In,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let s=new co;if(o=s.fromBER(e,o,n),o===-1)return this.blockLength=0,this.error=s.error,o;this.value.length===0&&(s.isFirstSid=!0),this.blockLength+=s.blockLength,n-=s.blockLength,this.value.push(s)}return o}toBER(e){let t=[];for(let n=0;n<this.value.length;n++){let o=this.value[n].toBER(e);if(o.byteLength===0)return this.error=this.value[n].error,ht;t.push(o)}return yc(t)}fromString(e){this.value=[];let t=0,n=0,o="",s=!1;do if(n=e.indexOf(".",t),n===-1?o=e.substring(t):o=e.substring(t,n),t=n+1,s){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(o,10);if(isNaN(c))return;i.valueDec=c+a,s=!1}else{let i=new co;if(o>Number.MAX_SAFE_INTEGER){ws();let a=BigInt(o);i.valueBigInt=a}else if(i.valueDec=parseInt(o,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,s=!0),this.value.push(i)}while(n!==-1)}toString(){let e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let o=this.value[n].toString();n!==0&&(e=`${e}.`),t?(o=`{${o}}`,this.value[n].isFirstSid?e=`2.{${o} - 80}`:e+=o):e+=o}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};Cs.NAME="ObjectIdentifierValueBlock";var Sf,ft=class extends ke{constructor(e={}){super(e,Cs),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()}}};Sf=ft;D.ObjectIdentifier=Sf;ft.NAME="OBJECT IDENTIFIER";var uo=class extends zt(Ht){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(!qt(this,o,t,n))return-1;let s=o.subarray(t,t+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=s[a]&127,this.blockLength++,!!(s[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,s[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Vr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}toBER(e){if(this.isHexOnly){if(e)return new ArrayBuffer(this.valueHexView.byteLength);let o=this.valueHexView,s=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)s[i]=o[i]|128;return s[this.blockLength-1]=o[this.blockLength-1],s.buffer}let t=dr(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",ht;let n=new Uint8Array(t.byteLength);if(!e){let o=new Uint8Array(t),s=t.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n.buffer}toString(){let e="";return this.isHexOnly?e=Y.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};uo.NAME="relativeSidBlock";var Ns=class extends Ce{constructor({value:e=In,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let s=new uo;if(o=s.fromBER(e,o,n),o===-1)return this.blockLength=0,this.error=s.error,o;this.blockLength+=s.blockLength,n-=s.blockLength,this.value.push(s)}return o}toBER(e,t){let n=[];for(let o=0;o<this.value.length;o++){let s=this.value[o].toBER(e);if(s.byteLength===0)return this.error=this.value[o].error,ht;n.push(s)}return yc(n)}fromString(e){this.value=[];let t=0,n=0,o="";do{n=e.indexOf(".",t),n===-1?o=e.substring(t):o=e.substring(t,n),t=n+1;let s=new uo;if(s.valueDec=parseInt(o,10),isNaN(s.valueDec))return!0;this.value.push(s)}while(n!==-1);return!0}toString(){let e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let o=this.value[n].toString();n!==0&&(e=`${e}.`),t&&(o=`{${o}}`),e+=o}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};Ns.NAME="RelativeObjectIdentifierValueBlock";var If,Ls=class extends ke{constructor(e={}){super(e,Ns),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()}}};If=Ls;D.RelativeObjectIdentifier=If;Ls.NAME="RelativeObjectIdentifier";var Rf,xe=class extends pr{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Rf=xe;D.Sequence=Rf;xe.NAME="SEQUENCE";var Tf,Us=class extends pr{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Tf=Us;D.Set=Tf;Us.NAME="SET";var Ds=class extends zt(Ce){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=In}toJSON(){return{...super.toJSON(),value:this.value}}};Ds.NAME="StringValueBlock";var Ps=class extends Ds{};Ps.NAME="SimpleStringValueBlock";var Pe=class extends Es{constructor({...e}={}){super(e,Ps)}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 Os=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}};Os.NAME="Utf8StringValueBlock";var _f,Kt=class extends Os{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};_f=Kt;D.Utf8String=_f;Kt.NAME="UTF8String";var Vs=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))}};Vs.NAME="BmpStringValueBlock";var Cf,Fs=class extends Vs{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Cf=Fs;D.BmpString=Cf;Fs.NAME="BMPString";var Ms=class extends Pe{fromBuffer(e){let t=ArrayBuffer.isView(e)?e.slice().buffer:e.slice(0),n=new Uint8Array(t);for(let o=0;o<n.length;o+=4)n[o]=n[o+3],n[o+1]=n[o+2],n[o+2]=0,n[o+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(t))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t*4);for(let o=0;o<t;o++){let s=dr(e.charCodeAt(o),8),i=new Uint8Array(s);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[o*4+c+a]=i[c]}this.valueBlock.value=e}};Ms.NAME="UniversalStringValueBlock";var Nf,Hs=class extends Ms{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Nf=Hs;D.UniversalString=Nf;Hs.NAME="UniversalString";var Lf,$s=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Lf=$s;D.NumericString=Lf;$s.NAME="NumericString";var Uf,Ks=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Uf=Ks;D.PrintableString=Uf;Ks.NAME="PrintableString";var Df,qs=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Df=qs;D.TeletexString=Df;qs.NAME="TeletexString";var Pf,zs=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Pf=zs;D.VideotexString=Pf;zs.NAME="VideotexString";var Of,Gs=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Of=Gs;D.IA5String=Of;Gs.NAME="IA5String";var Vf,js=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Vf=js;D.GraphicString=Vf;js.NAME="GraphicString";var Ff,lo=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Ff=lo;D.VisibleString=Ff;lo.NAME="VisibleString";var Mf,Ws=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Mf=Ws;D.GeneralString=Mf;Ws.NAME="GeneralString";var Hf,Ys=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Hf=Ys;D.CharacterString=Hf;Ys.NAME="CharacterString";var $f,fo=class extends lo{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}}};$f=fo;D.UTCTime=$f;fo.NAME="UTCTime";var Kf,Zs=class extends fo{constructor(e={}){var t;super(e),(t=this.millisecond)!==null&&t!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(e){super.fromDate(e),this.millisecond=e.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(e){let t=!1,n="",o="",s=0,i,a=0,c=0;if(e[e.length-1]==="Z")n=e.substring(0,e.length-1),t=!0;else{let l=new Number(e[e.length-1]);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");n=e}if(t){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let l=1,p=n.indexOf("+"),E="";if(p===-1&&(p=n.indexOf("-"),l=-1),p!==-1){if(E=n.substring(p+1),n=n.substring(0,p),E.length!==2&&E.length!==4)throw new Error("Wrong input string for conversion");let y=parseInt(E.substring(0,2),10);if(isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*y,E.length===4){if(y=parseInt(E.substring(2,4),10),isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");c=l*y}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let l=new Number(`0${n.substring(f)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");s=l.valueOf(),o=n.substring(0,f)}else o=n;switch(!0){case o.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case o.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=60*s;this.minute=Math.floor(l),l=60*(l-this.minute),this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case o.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=60*s;this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case o.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=1e3*s;this.millisecond=Math.floor(l)}break;default:throw new Error("Wrong input string for conversion")}let u=i.exec(o);if(u===null)throw new Error("Wrong input string for conversion");for(let l=1;l<u.length;l++)switch(l){case 1:this.year=parseInt(u[l],10);break;case 2:this.month=parseInt(u[l],10);break;case 3:this.day=parseInt(u[l],10);break;case 4:this.hour=parseInt(u[l],10)+a;break;case 5:this.minute=parseInt(u[l],10)+c;break;case 6:this.second=parseInt(u[l],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!1){let l=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=l.getUTCFullYear(),this.month=l.getUTCMonth(),this.day=l.getUTCDay(),this.hour=l.getUTCHours(),this.minute=l.getUTCMinutes(),this.second=l.getUTCSeconds(),this.millisecond=l.getUTCMilliseconds()}}toString(e="iso"){if(e==="iso"){let t=[];return t.push(Fe(this.year,4)),t.push(Fe(this.month,2)),t.push(Fe(this.day,2)),t.push(Fe(this.hour,2)),t.push(Fe(this.minute,2)),t.push(Fe(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(Fe(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Kf=Zs;D.GeneralizedTime=Kf;Zs.NAME="GeneralizedTime";var qf,Js=class extends Kt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};qf=Js;D.DATE=qf;Js.NAME="DATE";var zf,Xs=class extends Kt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};zf=Xs;D.TimeOfDay=zf;Xs.NAME="TimeOfDay";var Gf,Qs=class extends Kt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Gf=Qs;D.DateTime=Gf;Qs.NAME="DateTime";var jf,ei=class extends Kt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};jf=ei;D.Duration=jf;ei.NAME="Duration";var Wf,ti=class extends Kt{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Wf=ti;D.TIME=Wf;ti.NAME="TIME";function yg(r){let{result:e}=Rn(r),t=e.valueBlock.value;return{n:z(vt(t[1].toBigInt()),"base64url"),e:z(vt(t[2].toBigInt()),"base64url"),d:z(vt(t[3].toBigInt()),"base64url"),p:z(vt(t[4].toBigInt()),"base64url"),q:z(vt(t[5].toBigInt()),"base64url"),dp:z(vt(t[6].toBigInt()),"base64url"),dq:z(vt(t[7].toBigInt()),"base64url"),qi:z(vt(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function gg(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new N("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new xe({value:[new me({value:0}),me.fromBigInt(At(j(r.n,"base64url"))),me.fromBigInt(At(j(r.e,"base64url"))),me.fromBigInt(At(j(r.d,"base64url"))),me.fromBigInt(At(j(r.p,"base64url"))),me.fromBigInt(At(j(r.q,"base64url"))),me.fromBigInt(At(j(r.dp,"base64url"))),me.fromBigInt(At(j(r.dq,"base64url"))),me.fromBigInt(At(j(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function wg(r){let{result:e}=Rn(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:z(vt(t[0].toBigInt()),"base64url"),e:z(vt(t[1].toBigInt()),"base64url")}}function bg(r){if(r.n==null||r.e==null)throw new N("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new xe({value:[new xe({value:[new ft({value:"1.2.840.113549.1.1.1"}),new mr]}),new Sn({valueHex:new xe({value:[me.fromBigInt(At(j(r.n,"base64url"))),me.fromBigInt(At(j(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,s=0;for(;o<t;)n[o]=parseInt(e.slice(s,s+2),16),o+=1,s+=2;return n}function At(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 xg=16,wc=32,bc=1e4;async function Eg(r,e){let t=De.get(),o=new xe({value:[new me({value:0}),new xe({value:[new ft({value:"1.2.840.113549.1.1.1"}),new mr]}),new $t({valueHex:r.marshal()})]}).toBER(),s=new Uint8Array(o,0,o.byteLength),i=Or(xg),a=await dc(xn,e,i,{c:bc,dkLen:wc}),c=Or(16),f=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),u=await t.subtle.encrypt({name:"AES-CBC",iv:c},f,s),l=new xe({value:[new $t({valueHex:i}),new me({value:bc}),new me({value:wc}),new xe({value:[new ft({value:"1.2.840.113549.2.11"}),new mr]})]}),p=new xe({value:[new ft({value:"1.2.840.113549.1.5.13"}),new xe({value:[new xe({value:[new ft({value:"1.2.840.113549.1.5.12"}),l]}),new xe({value:[new ft({value:"2.16.840.1.101.3.4.1.42"}),new $t({valueHex:c})]})]})]}),y=new xe({value:[p,new $t({valueHex:u})]}).toBER(),d=new Uint8Array(y,0,y.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...z(d,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
8
+ `)}async function vg(r,e){let t=De.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=j(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Rn(o),{iv:i,salt:a,iterations:c,keySize:f,cipherText:u}=Ag(s),l=await dc(xn,e,a,{c,dkLen:f}),p=await t.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),E=ho(await t.subtle.decrypt({name:"AES-CBC",iv:i},p,u)),{result:y}=Rn(E);n=Yf(y)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=j(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Rn(o);n=Yf(s)}else throw new N("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return xc(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 N("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=e.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new N("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let s=n.valueBlock.value[1],i=ho(s.valueBlock.value[0].getValue()),a=bc,c=wc;if(s.valueBlock.value.length===3)a=Number(s.valueBlock.value[1].toBigInt()),c=Number(s.valueBlock.value[2].toBigInt());else if(s.valueBlock.value.length===2)throw new N("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let f=e.valueBlock.value[1].valueBlock.value[1],u=f.valueBlock.value[0].toString();if(u!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(u!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new N("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=ho(f.valueBlock.value[1].getValue());return{cipherText:ho(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:l}}function Yf(r){return ho(r.valueBlock.value[2].getValue())}function ho(r){return new Uint8Array(r,0,r.byteLength)}async function Zf(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 Qf(e);return{privateKey:t[0],publicKey:t[1]}}async function Ec(r){let t=[await De.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Bg(r)],n=await Qf({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Jf(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 Xf(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 Qf(r){if(r.privateKey==null||r.publicKey==null)throw new N("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 Bg(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 ni(r){if(r.kty!=="RSA")throw new N("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new N("invalid key modulus","ERR_INVALID_KEY_MODULUS");return j(r.n,"base64url").length*8}var mo=8192,po=class{_key;constructor(e){this._key=e}verify(e,t){return Xf(this._key,t,e)}marshal(){return yr.jwkToPkix(this._key)}get bytes(){return xt.encode({Type:de.RSA,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(e)?e.then(({bytes:t})=>t):e.bytes}},Tn=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return Or(16)}sign(e){return Jf(this._key,e)}get public(){if(this._publicKey==null)throw new N("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new po(this._publicKey)}marshal(){return yr.jwkToPkcs1(this._key)}get bytes(){return Ft.encode({Type:de.RSA,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return z(e,"base58btc")}async export(e,t="pkcs-8"){if(t==="pkcs-8")return yr.exportToPem(this,e);if(t==="libp2p-key")return An(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function xc(r){let e=yr.pkcs1ToJwk(r);if(ni(e)>mo)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Ec(e);return new Tn(t.privateKey,t.publicKey)}function Sg(r){let e=yr.pkixToJwk(r);if(ni(e)>mo)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new po(e)}async function Ig(r){if(ni(r)>mo)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Ec(r);return new Tn(e.privateKey,e.publicKey)}async function Rg(r){if(r>mo)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Zf(r);return new Tn(e.privateKey,e.publicKey)}var Ic={};ge(Ic,{Secp256k1PrivateKey:()=>go,Secp256k1PublicKey:()=>yo,generateKeyPair:()=>Kg,unmarshalSecp256k1PrivateKey:()=>Hg,unmarshalSecp256k1PublicKey:()=>$g});var Tg=(r,e,t)=>r&e^~r&t,_g=(r,e,t)=>r&e^r&t^e&t,Cg=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]),gr=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),wr=new Uint32Array(64),Ac=class extends bn{constructor(){super(64,32,8,!1),this.A=gr[0]|0,this.B=gr[1]|0,this.C=gr[2]|0,this.D=gr[3]|0,this.E=gr[4]|0,this.F=gr[5]|0,this.G=gr[6]|0,this.H=gr[7]|0}get(){let{A:e,B:t,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[e,t,n,o,s,i,a,c]}set(e,t,n,o,s,i,a,c){this.A=e|0,this.B=t|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=a|0,this.H=c|0}process(e,t){for(let l=0;l<16;l++,t+=4)wr[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let p=wr[l-15],E=wr[l-2],y=ct(p,7)^ct(p,18)^p>>>3,d=ct(E,17)^ct(E,19)^E>>>10;wr[l]=d+wr[l-7]+y+wr[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let p=ct(a,6)^ct(a,11)^ct(a,25),E=u+p+Tg(a,c,f)+Cg[l]+wr[l]|0,d=(ct(n,2)^ct(n,13)^ct(n,22))+_g(n,o,s)|0;u=f,f=c,c=a,a=i+E|0,i=s,s=o,o=n,n=E+d|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,u=u+this.H|0,this.set(n,o,s,i,a,c,f,u)}roundClean(){wr.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var eh=ns(()=>new Ac);function Ng(r){let e=to(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:Lg,hexToBytes:Ug}=is,Fr={Err:class extends Error{constructor(e=""){super(e)}},_parseInt(r){let{Err:e}=Fr;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:Lg(n),l:r.subarray(t+2)}},toSig(r){let{Err:e}=Fr,t=typeof r=="string"?Ug(r):r;if(!ut(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:s}=Fr._parseInt(t.subarray(2)),{d:i,l:a}=Fr._parseInt(s);if(a.length)throw new e("Invalid signature: left bytes after parsing");return{r:o,s:i}},hexFromSig(r){let e=f=>Number.parseInt(f[0],16)&8?"00"+f:f,t=f=>{let u=f.toString(16);return u.length&1?`0${u}`:u},n=e(t(r.s)),o=e(t(r.r)),s=n.length/2,i=o.length/2,a=t(s),c=t(i);return`30${t(i+s+4)}02${c}${o}02${a}${n}`}},Gt=BigInt(0),et=BigInt(1),iA=BigInt(2),th=BigInt(3),aA=BigInt(4);function Dg(r){let e=Ng(r),{Fp:t}=e,n=e.toBytes||((y,d,m)=>{let g=d.toAffine();return Pt(Uint8Array.from([4]),t.toBytes(g.x),t.toBytes(g.y))}),o=e.fromBytes||(y=>{let d=y.subarray(1),m=t.fromBytes(d.subarray(0,t.BYTES)),g=t.fromBytes(d.subarray(t.BYTES,2*t.BYTES));return{x:m,y:g}});function s(y){let{a:d,b:m}=e,g=t.sqr(y),I=t.mul(g,y);return t.add(t.add(I,t.mul(y,d)),m)}if(!t.eql(t.sqr(e.Gy),s(e.Gx)))throw new Error("bad generator point: equation left != right");function i(y){return typeof y=="bigint"&&Gt<y&&y<e.n}function a(y){if(!i(y))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(y){let{allowedPrivateKeyLengths:d,nByteLength:m,wrapPrivateKey:g,n:I}=e;if(d&&typeof y!="bigint"){if(ut(y)&&(y=Ut(y)),typeof y!="string"||!d.includes(y.length))throw new Error("Invalid key");y=y.padStart(m*2,"0")}let v;try{v=typeof y=="bigint"?y:Dt(fe("private key",y,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof y}`)}return g&&(v=oe(v,I)),a(v),v}let f=new Map;function u(y){if(!(y instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(d,m,g){if(this.px=d,this.py=m,this.pz=g,d==null||!t.isValid(d))throw new Error("x required");if(m==null||!t.isValid(m))throw new Error("y required");if(g==null||!t.isValid(g))throw new Error("z required")}static fromAffine(d){let{x:m,y:g}=d||{};if(!d||!t.isValid(m)||!t.isValid(g))throw new Error("invalid affine point");if(d instanceof l)throw new Error("projective point not allowed");let I=v=>t.eql(v,t.ZERO);return I(m)&&I(g)?l.ZERO:new l(m,g,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let m=t.invertBatch(d.map(g=>g.pz));return d.map((g,I)=>g.toAffine(m[I])).map(l.fromAffine)}static fromHex(d){let m=l.fromAffine(o(fe("pointHex",d)));return m.assertValidity(),m}static fromPrivateKey(d){return l.BASE.multiply(c(d))}_setWindowSize(d){this._WINDOW_SIZE=d,f.delete(this)}assertValidity(){if(this.is0()){if(e.allowInfinityPoint&&!t.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:d,y:m}=this.toAffine();if(!t.isValid(d)||!t.isValid(m))throw new Error("bad point: x or y not FE");let g=t.sqr(m),I=s(d);if(!t.eql(g,I))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:d}=this.toAffine();if(t.isOdd)return!t.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){u(d);let{px:m,py:g,pz:I}=this,{px:v,py:U,pz:S}=d,T=t.eql(t.mul(m,S),t.mul(v,I)),L=t.eql(t.mul(g,S),t.mul(U,I));return T&&L}negate(){return new l(this.px,t.neg(this.py),this.pz)}double(){let{a:d,b:m}=e,g=t.mul(m,th),{px:I,py:v,pz:U}=this,S=t.ZERO,T=t.ZERO,L=t.ZERO,w=t.mul(I,I),C=t.mul(v,v),O=t.mul(U,U),_=t.mul(I,v);return _=t.add(_,_),L=t.mul(I,U),L=t.add(L,L),S=t.mul(d,L),T=t.mul(g,O),T=t.add(S,T),S=t.sub(C,T),T=t.add(C,T),T=t.mul(S,T),S=t.mul(_,S),L=t.mul(g,L),O=t.mul(d,O),_=t.sub(w,O),_=t.mul(d,_),_=t.add(_,L),L=t.add(w,w),w=t.add(L,w),w=t.add(w,O),w=t.mul(w,_),T=t.add(T,w),O=t.mul(v,U),O=t.add(O,O),w=t.mul(O,_),S=t.sub(S,w),L=t.mul(O,C),L=t.add(L,L),L=t.add(L,L),new l(S,T,L)}add(d){u(d);let{px:m,py:g,pz:I}=this,{px:v,py:U,pz:S}=d,T=t.ZERO,L=t.ZERO,w=t.ZERO,C=e.a,O=t.mul(e.b,th),_=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(_,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(_,$),x=t.sub(x,k),k=t.add(g,I),T=t.add(U,S),k=t.mul(k,T),T=t.add(F,$),k=t.sub(k,T),w=t.mul(C,x),T=t.mul(O,$),w=t.add(T,w),T=t.sub(F,w),w=t.add(F,w),L=t.mul(T,w),F=t.add(_,_),F=t.add(F,_),$=t.mul(C,$),x=t.mul(O,x),F=t.add(F,$),$=t.sub(_,$),$=t.mul(C,$),x=t.add(x,$),_=t.mul(F,x),L=t.add(L,_),_=t.mul(k,x),T=t.mul(J,T),T=t.sub(T,_),_=t.mul(J,F),w=t.mul(k,w),w=t.add(w,_),new l(T,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===Gt)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),T=m,L=m,w=this;for(;v>Gt||S>Gt;)v&et&&(T=T.add(w)),S&et&&(L=L.add(w)),w=w.double(),v>>=et,S>>=et;return I&&(T=T.negate()),U&&(L=L.negate()),L=new l(t.mul(L.px,g.beta),L.py,L.pz),T.add(L)}multiply(d){a(d);let m=d,g,I,{endo:v}=e;if(v){let{k1neg:U,k1:S,k2neg:T,k2:L}=v.splitScalar(m),{p:w,f:C}=this.wNAF(S),{p:O,f:_}=this.wNAF(L);w=E.constTimeNegate(U,w),O=E.constTimeNegate(T,O),O=new l(t.mul(O.px,v.beta),O.py,O.pz),g=w.add(O),I=C.add(_)}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)=>T===Gt||T===et||!S.equals(I)?S.multiplyUnsafe(T):S.multiply(T),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=t.mul(I,d);if(v)return{x:t.ZERO,y:t.ZERO};if(!t.eql(T,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 Ut(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=us(l,e.endo?Math.ceil(p/2):p);return{CURVE:e,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:s,isWithinCurveOrder:i}}function Pg(r){let e=to(r);return bt(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function rh(r){let e=Pg(r),{Fp:t,n}=e,o=t.BYTES+1,s=2*t.BYTES+1;function i(x){return Gt<x&&x<t.ORDER}function a(x){return oe(x,n)}function c(x){return as(x,n)}let{ProjectivePoint:f,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:p}=Dg({...e,toBytes(x,k,H){let B=k.toAffine(),b=t.toBytes(B.x),P=Pt;return H?P(Uint8Array.from([k.hasEvenY()?2:3]),b):P(Uint8Array.from([4]),b,t.toBytes(B.y))},fromBytes(x){let k=x.length,H=x[0],B=x.subarray(1);if(k===o&&(H===2||H===3)){let b=Dt(B);if(!i(b))throw new Error("Point is not on curve");let P=l(b),M=t.sqrt(P),K=(M&et)===et;return(H&1)===1!==K&&(M=t.neg(M)),{x:b,y:M}}else if(k===s&&H===4){let b=t.fromBytes(B.subarray(0,t.BYTES)),P=t.fromBytes(B.subarray(t.BYTES,2*t.BYTES));return{x:b,y:P}}else throw new Error(`Point of length ${k} was invalid. Expected ${o} compressed bytes or ${s} uncompressed bytes`)}}),E=x=>Ut(hr(x,e.nByteLength));function y(x){let k=n>>et;return x>k}function d(x){return y(x)?a(-x):x}let m=(x,k,H)=>Dt(x.slice(k,H));class g{constructor(k,H,B){this.r=k,this.s=H,this.recovery=B,this.assertValidity()}static fromCompact(k){let H=e.nByteLength;return k=fe("compactSignature",k,H*2),new g(m(k,0,H),m(k,H,2*H))}static fromDER(k){let{r:H,s:B}=Fr.toSig(fe("DER",k));return new g(H,B)}assertValidity(){if(!p(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!p(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(k){return new g(this.r,this.s,k)}recoverPublicKey(k){let{r:H,s:B,recovery:b}=this,P=L(fe("msgHash",k));if(b==null||![0,1,2,3].includes(b))throw new Error("recovery id invalid");let M=b===2||b===3?H+e.n:H;if(M>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let K=b&1?"03":"02",G=f.fromHex(K+E(M)),W=c(M),ne=a(-P*W),Z=a(B*W),X=f.BASE.multiplyAndAddUnsafe(G,ne,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 Lr(this.toDERHex())}toDERHex(){return Fr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Lr(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=sc(e.n);return Yl(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=ut(x),H=typeof x=="string",B=(k||H)&&x.length;return k?B===o||B===s:H?B===2*o||B===2*s:x instanceof f}function S(x,k,H=!0){if(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 T=e.bits2int||function(x){let k=Dt(x),H=x.length*8-e.nBitLength;return H>0?k>>BigInt(H):k},L=e.bits2int_modN||function(x){return a(T(x))},w=eo(e.nBitLength);function C(x){if(typeof x!="bigint")throw new Error("bigint expected");if(!(Gt<=x&&x<w))throw new Error(`bigint expected < 2^${e.nBitLength}`);return hr(x,e.nByteLength)}function O(x,k,H=_){if(["recovered","canonical"].some(ue=>ue in H))throw new Error("sign() legacy options not supported");let{hash:B,randomBytes:b}=e,{lowS:P,prehash:M,extraEntropy:K}=H;P==null&&(P=!0),x=fe("msgHash",x),M&&(x=fe("prehashed msgHash",B(x)));let G=L(x),W=u(k),ne=[C(W),C(G)];if(K!=null){let ue=K===!0?b(t.BYTES):K;ne.push(fe("extraEntropy",ue))}let Z=Pt(...ne),X=G;function pe(ue){let ve=T(ue);if(!p(ve))return;let Ae=c(ve),ye=f.BASE.multiply(ve).toAffine(),Re=a(ye.x);if(Re===Gt)return;let Rt=a(Ae*a(X+Re*W));if(Rt===Gt)return;let kr=(ye.x===Re?0:2)|Number(ye.y&et),$n=Rt;return P&&y(Rt)&&($n=d(Rt),kr^=1),new g(Re,$n,kr)}return{seed:Z,k2sig:pe}}let _={lowS:e.lowS,prehash:!1},F={lowS:e.lowS,prehash:!1};function $(x,k,H=_){let{seed:B,k2sig:b}=O(x,k,H),P=e;return tc(P.hash.outputLen,P.nByteLength,P.hmac)(B,b)}f.BASE._setWindowSize(8);function J(x,k,H,B=F){let b=x;if(k=fe("msgHash",k),H=fe("publicKey",H),"strict"in B)throw new Error("options.strict was renamed to lowS");let{lowS:P,prehash:M}=B,K,G;try{if(typeof b=="string"||ut(b))try{K=g.fromDER(b)}catch(ye){if(!(ye instanceof Fr.Err))throw ye;K=g.fromCompact(b)}else if(typeof b=="object"&&typeof b.r=="bigint"&&typeof b.s=="bigint"){let{r:ye,s:Re}=b;K=new g(ye,Re)}else throw new Error("PARSE");G=f.fromHex(H)}catch(ye){if(ye.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(P&&K.hasHighS())return!1;M&&(k=e.hash(k));let{r:W,s:ne}=K,Z=L(k),X=c(ne),pe=a(Z*X),ue=a(W*X),ve=f.BASE.multiplyAndAddUnsafe(G,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 Og(r){return{hash:r,hmac:(e,...t)=>no(r,e,rs(...t)),randomBytes:wn}}function nh(r,e){let t=n=>rh({...r,...Og(n)});return Object.freeze({...t(e),create:t})}var ih=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),oh=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Vg=BigInt(1),Bc=BigInt(2),sh=(r,e)=>(r+e/Bc)/e;function Fg(r){let e=ih,t=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%e,u=f*f*r%e,l=ce(u,t,e)*u%e,p=ce(l,t,e)*u%e,E=ce(p,Bc,e)*f%e,y=ce(E,o,e)*E%e,d=ce(y,s,e)*y%e,m=ce(d,a,e)*d%e,g=ce(m,c,e)*m%e,I=ce(g,a,e)*d%e,v=ce(I,t,e)*u%e,U=ce(v,i,e)*y%e,S=ce(U,n,e)*f%e,T=ce(S,Bc,e);if(!kc.eql(kc.sqr(T),r))throw new Error("Cannot find square root");return T}var kc=cs(ih,void 0,void 0,{sqrt:Fg}),dt=nh({a:BigInt(0),b:BigInt(7),Fp:kc,n:oh,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=oh,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Vg*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=t,i=BigInt("0x100000000000000000000000000000000"),a=sh(s*r,e),c=sh(-n*r,e),f=oe(r-a*t-c*o,e),u=oe(-a*n-c*s,e),l=f>i,p=u>i;if(l&&(f=e-f),p&&(u=e-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:p,k2:u}}}},eh),yA=BigInt(0);var gA=dt.ProjectivePoint;function ah(){return dt.utils.randomPrivateKey()}function ch(r,e){let t=we.digest(e instanceof Uint8Array?e:e.subarray());if(Xe(t))return t.then(({digest:n})=>dt.sign(n,r).toDERRawBytes()).catch(n=>{throw new N(String(n),"ERR_INVALID_INPUT")});try{return dt.sign(t.digest,r).toDERRawBytes()}catch(n){throw new N(String(n),"ERR_INVALID_INPUT")}}function uh(r,e,t){let n=we.digest(t instanceof Uint8Array?t:t.subarray());if(Xe(n))return n.then(({digest:o})=>dt.verify(e,o,r)).catch(o=>{throw new N(String(o),"ERR_INVALID_INPUT")});try{return dt.verify(e,n.digest,r)}catch(o){throw new N(String(o),"ERR_INVALID_INPUT")}}function lh(r){return dt.ProjectivePoint.fromHex(r).toRawBytes(!0)}function fh(r){try{dt.getPublicKey(r,!0)}catch(e){throw new N(String(e),"ERR_INVALID_PRIVATE_KEY")}}function Sc(r){try{dt.ProjectivePoint.fromHex(r)}catch(e){throw new N(String(e),"ERR_INVALID_PUBLIC_KEY")}}function hh(r){try{return dt.getPublicKey(r,!0)}catch(e){throw new N(String(e),"ERR_INVALID_PRIVATE_KEY")}}var yo=class{_key;constructor(e){Sc(e),this._key=e}verify(e,t){return uh(this._key,t,e)}marshal(){return lh(this._key)}get bytes(){return xt.encode({Type:de.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}async hash(){let e=we.digest(this.bytes),t;return Xe(e)?{bytes:t}=await e:t=e.bytes,t}},go=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??hh(e),fh(this._key),Sc(this._publicKey)}sign(e){return ch(this._key,e)}get public(){return new yo(this._publicKey)}marshal(){return this._key}get bytes(){return Ft.encode({Type:de.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return z(e,"base58btc")}async export(e,t="libp2p-key"){if(t==="libp2p-key")return An(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Hg(r){return new go(r)}function $g(r){return new yo(r)}async function Kg(){let r=ah();return new go(r)}var oi={rsa:vc,ed25519:hc,secp256k1:Ic};function qg(r){let e=Object.keys(oi).join(" / ");return new N(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function Rc(r){let e=xt.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case de.RSA:return oi.rsa.unmarshalRsaPublicKey(t);case de.Ed25519:return oi.ed25519.unmarshalEd25519PublicKey(t);case de.Secp256k1:return oi.secp256k1.unmarshalSecp256k1PublicKey(t);default:throw qg(e.Type??"unknown")}}var Bw=st(sn(),1);var jt="/",dh=new TextEncoder().encode(jt),si=dh[0],Se=class r{_buf;constructor(e,t){if(typeof e=="string")this._buf=j(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]!==si)throw new Error("Invalid key")}toString(e="utf8"){return z(this._buf,e)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(e){return new r(e.join(jt))}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=dh),this._buf[0]!==si){let e=new Uint8Array(this._buf.byteLength+1);e.fill(si,0,1),e.set(this._buf,1),this._buf=e}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===si;)this._buf=this._buf.subarray(0,-1)}less(e){let t=this.list(),n=e.list();for(let o=0;o<t.length;o++){if(n.length<o+1)return!1;let s=t[o],i=n[o];if(s<i)return!0;if(s>i)return!1}return t.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let e=this.namespaces();return e[e.length-1]}list(){return this.toString().split(jt).slice(1)}type(){return zg(this.baseNamespace())}name(){return Gg(this.baseNamespace())}instance(e){return new r(this.toString()+":"+e)}path(){let e=this.parent().toString();return e.endsWith(jt)||(e+=jt),e+=this.type(),new r(e)}parent(){let e=this.list();return e.length===1?new r(jt):new r(e.slice(0,-1).join(jt))}child(e){return this.toString()===jt?e:e.toString()===jt?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(),...jg(e.map(t=>t.namespaces()))])}};function zg(r){let e=r.split(":");return e.length<2?"":e.slice(0,-1).join(":")}function Gg(r){let e=r.split(":");return e[e.length-1]}function jg(r){return[].concat(...r)}var kw=st(_c(),1);var ph="ERR_IPNS_EXPIRED_RECORD",ii="ERR_UNRECOGNIZED_VALIDITY";var Wt="ERR_SIGNATURE_VERIFICATION";var Cc="ERR_UNDEFINED_PARAMETER",mh="ERR_INVALID_RECORD_DATA",yh="ERR_INVALID_VALUE",gh="ERR_INVALID_EMBEDDED_KEY";var wh="ERR_RECORD_TOO_LARGE";var pt;(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=on((o,s,i={})=>{i.lengthDelimited!==!1&&s.fork(),o.value!=null&&(s.uint32(10),s.bytes(o.value)),o.signatureV1!=null&&(s.uint32(18),s.bytes(o.signatureV1)),o.validityType!=null&&(s.uint32(24),r.ValidityType.codec().encode(o.validityType,s)),o.validity!=null&&(s.uint32(34),s.bytes(o.validity)),o.sequence!=null&&(s.uint32(40),s.uint64(o.sequence)),o.ttl!=null&&(s.uint32(48),s.uint64(o.ttl)),o.pubKey!=null&&(s.uint32(58),s.bytes(o.pubKey)),o.signatureV2!=null&&(s.uint32(66),s.bytes(o.signatureV2)),o.data!=null&&(s.uint32(74),s.bytes(o.data)),i.lengthDelimited!==!1&&s.ldelim()},(o,s)=>{let i={},a=s==null?o.len:o.pos+s;for(;o.pos<a;){let c=o.uint32();switch(c>>>3){case 1:i.value=o.bytes();break;case 2:i.signatureV1=o.bytes();break;case 3:i.validityType=r.ValidityType.codec().decode(o);break;case 4:i.validity=o.bytes();break;case 5:i.sequence=o.uint64();break;case 6:i.ttl=o.uint64();break;case 7:i.pubKey=o.bytes();break;case 8:i.signatureV2=o.bytes();break;case 9:i.data=o.bytes();break;default:o.skipType(c&7);break}}return i})),n),r.encode=o=>rn(o,r.codec()),r.decode=o=>tn(o,r.codec())})(pt||(pt={}));var Wg=["string","number","bigint","symbol"],Yg=["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 xh(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let e=typeof r;if(Wg.includes(e))return e;if(e==="function")return"Function";if(Array.isArray(r))return"Array";if(Zg(r))return"Buffer";let t=Jg(r);return t||"Object"}function Zg(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function Jg(r){let e=Object.prototype.toString.call(r).slice(8,-1);if(Yg.includes(e))return e}var h=class{constructor(e,t,n){this.major=e,this.majorEncoded=e<<5,this.name=t,this.terminal=n}toString(){return`Type[${this.major}].${this.name}`}compare(e){return this.major<e.major?-1:this.major>e.major?1:0}};h.uint=new h(0,"uint",!0);h.negint=new h(1,"negint",!0);h.bytes=new h(2,"bytes",!0);h.string=new h(3,"string",!0);h.array=new h(4,"array",!1);h.map=new h(5,"map",!1);h.tag=new h(6,"tag",!1);h.float=new h(7,"float",!0);h.false=new h(7,"false",!0);h.true=new h(7,"true",!0);h.null=new h(7,"null",!0);h.undefined=new h(7,"undefined",!0);h.break=new h(7,"break",!0);var A=class{constructor(e,t,n){this.type=e,this.value=t,this.encodedLength=n,this.encodedBytes=void 0,this.byteValue=void 0}toString(){return`Token[${this.type}].${this.value}`}};var _n=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",Xg=new TextDecoder,Qg=new TextEncoder;function ai(r){return _n&&globalThis.Buffer.isBuffer(r)}function wo(r){return r instanceof Uint8Array?ai(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var Bh=_n?(r,e,t)=>t-e>64?globalThis.Buffer.from(r.subarray(e,t)).toString("utf8"):vh(r,e,t):(r,e,t)=>t-e>64?Xg.decode(r.subarray(e,t)):vh(r,e,t),ci=_n?r=>r.length>64?globalThis.Buffer.from(r):Eh(r):r=>r.length>64?Qg.encode(r):Eh(r),Bt=r=>Uint8Array.from(r),Cn=_n?(r,e,t)=>ai(r)?new Uint8Array(r.subarray(e,t)):r.slice(e,t):(r,e,t)=>r.slice(e,t),kh=_n?(r,e)=>(r=r.map(t=>t instanceof Uint8Array?t:globalThis.Buffer.from(t)),wo(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},Sh=_n?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function Ih(r,e){if(ai(r)&&ai(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 Eh(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 vh(r,e,t){let n=[];for(;e<t;){let o=r[e],s=null,i=o>239?4:o>223?3:o>191?2:1;if(e+i<=t){let a,c,f,u;switch(i){case 1:o<128&&(s=o);break;case 2:a=r[e+1],(a&192)===128&&(u=(o&31)<<6|a&63,u>127&&(s=u));break;case 3:a=r[e+1],c=r[e+2],(a&192)===128&&(c&192)===128&&(u=(o&15)<<12|(a&63)<<6|c&63,u>2047&&(u<55296||u>57343)&&(s=u));break;case 4:a=r[e+1],c=r[e+2],f=r[e+3],(a&192)===128&&(c&192)===128&&(f&192)===128&&(u=(o&15)<<18|(a&63)<<12|(c&63)<<6|f&63,u>65535&&u<1114112&&(s=u))}}s===null?(s=65533,i=1):s>65535&&(s-=65536,n.push(s>>>10&1023|55296),s=56320|s&1023),n.push(s),e+=i}return Nc(n)}var Ah=4096;function Nc(r){let e=r.length;if(e<=Ah)return String.fromCharCode.apply(String,r);let t="",n=0;for(;n<e;)t+=String.fromCharCode.apply(String,r.slice(n,n+=Ah));return t}var ew=256,bo=class{constructor(e=ew){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=Sh(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=Cn(n,0,this.cursor)}else t=kh(this.chunks,this.cursor);return e&&this.reset(),t}};var V="CBOR decode error:",Nn="CBOR encode error:",xo=[];xo[23]=1;xo[24]=2;xo[25]=3;xo[26]=5;xo[27]=9;function Yt(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){Yt(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){Yt(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){Yt(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){Yt(r,e,8);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3],o=r[e+4]*16777216+(r[e+5]<<16)+(r[e+6]<<8)+r[e+7],s=(BigInt(n)<<BigInt(32))+BigInt(o);if(t.strict===!0&&s<Ee[3])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);if(s<=Number.MAX_SAFE_INTEGER)return Number(s);if(t.allowBigInt===!0)return s;throw new Error(`${V} integers outside of the safe integer range are not supported`)}function Rh(r,e,t,n){return new A(h.uint,Ge(r,e+1,n),2)}function Th(r,e,t,n){return new A(h.uint,je(r,e+1,n),3)}function _h(r,e,t,n){return new A(h.uint,We(r,e+1,n),5)}function Ch(r,e,t,n){return new A(h.uint,Ye(r,e+1,n),9)}function tt(r,e){return Ie(r,0,e.value)}function Ie(r,e,t){if(t<Ee[0]){let n=Number(t);r.push([e|n])}else if(t<Ee[1]){let n=Number(t);r.push([e|24,n])}else if(t<Ee[2]){let n=Number(t);r.push([e|25,n>>>8,n&255])}else if(t<Ee[3]){let n=Number(t);r.push([e|26,n>>>24&255,n>>>16&255,n>>>8&255,n&255])}else{let n=BigInt(t);if(n<Ee[4]){let o=[e|27,0,0,0,0,0,0,0],s=Number(n&BigInt(4294967295)),i=Number(n>>BigInt(32)&BigInt(4294967295));o[8]=s&255,s=s>>8,o[7]=s&255,s=s>>8,o[6]=s&255,s=s>>8,o[5]=s&255,o[4]=i&255,i=i>>8,o[3]=i&255,i=i>>8,o[2]=i&255,i=i>>8,o[1]=i&255,r.push(o)}else throw new Error(`${V} encountered BigInt larger than allowable range`)}}tt.encodedSize=function(e){return Ie.encodedSize(e.value)};Ie.encodedSize=function(e){return e<Ee[0]?1:e<Ee[1]?2:e<Ee[2]?3:e<Ee[3]?5:9};tt.compareTokens=function(e,t){return e.value<t.value?-1:e.value>t.value?1:0};function Nh(r,e,t,n){return new A(h.negint,-1-Ge(r,e+1,n),2)}function Lh(r,e,t,n){return new A(h.negint,-1-je(r,e+1,n),3)}function Uh(r,e,t,n){return new A(h.negint,-1-We(r,e+1,n),5)}var Lc=BigInt(-1),Dh=BigInt(1);function Ph(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o!="bigint"){let s=-1-o;if(s>=Number.MIN_SAFE_INTEGER)return new A(h.negint,s,9)}if(n.allowBigInt!==!0)throw new Error(`${V} integers outside of the safe integer range are not supported`);return new A(h.negint,Lc-BigInt(o),9)}function ui(r,e){let t=e.value,n=typeof t=="bigint"?t*Lc-Dh:t*-1-1;Ie(r,e.type.majorEncoded,n)}ui.encodedSize=function(e){let t=e.value,n=typeof t=="bigint"?t*Lc-Dh:t*-1-1;return n<Ee[0]?1:n<Ee[1]?2:n<Ee[2]?3:n<Ee[3]?5:9};ui.compareTokens=function(e,t){return e.value<t.value?1:e.value>t.value?-1:0};function Eo(r,e,t,n){Yt(r,e,t+n);let o=Cn(r,e+t,e+t+n);return new A(h.bytes,o,t+n)}function Oh(r,e,t,n){return Eo(r,e,1,t)}function Vh(r,e,t,n){return Eo(r,e,2,Ge(r,e+1,n))}function Fh(r,e,t,n){return Eo(r,e,3,je(r,e+1,n))}function Mh(r,e,t,n){return Eo(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 bytes lengths not supported`);return Eo(r,e,9,o)}function li(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===h.string?ci(r.value):r.value),r.encodedBytes}function Ln(r,e){let t=li(e);Ie(r,e.type.majorEncoded,t.length),r.push(t)}Ln.encodedSize=function(e){let t=li(e);return Ie.encodedSize(t.length)+t.length};Ln.compareTokens=function(e,t){return rw(li(e),li(t))};function rw(r,e){return r.length<e.length?-1:r.length>e.length?1:Ih(r,e)}function vo(r,e,t,n,o){let s=t+n;Yt(r,e,s);let i=new A(h.string,Bh(r,e+t,e+s),s);return o.retainStringBytes===!0&&(i.byteValue=Cn(r,e+t,e+s)),i}function $h(r,e,t,n){return vo(r,e,1,t,n)}function Kh(r,e,t,n){return vo(r,e,2,Ge(r,e+1,n),n)}function qh(r,e,t,n){return vo(r,e,3,je(r,e+1,n),n)}function zh(r,e,t,n){return vo(r,e,5,We(r,e+1,n),n)}function Gh(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 vo(r,e,9,o,n)}var jh=Ln;function Un(r,e,t,n){return new A(h.array,n,t)}function Wh(r,e,t,n){return Un(r,e,1,t)}function Yh(r,e,t,n){return Un(r,e,2,Ge(r,e+1,n))}function Zh(r,e,t,n){return Un(r,e,3,je(r,e+1,n))}function Jh(r,e,t,n){return Un(r,e,5,We(r,e+1,n))}function Xh(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer array lengths not supported`);return Un(r,e,9,o)}function Qh(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Un(r,e,1,1/0)}function fi(r,e){Ie(r,h.array.majorEncoded,e.value)}fi.compareTokens=tt.compareTokens;fi.encodedSize=function(e){return Ie.encodedSize(e.value)};function Dn(r,e,t,n){return new A(h.map,n,t)}function ed(r,e,t,n){return Dn(r,e,1,t)}function td(r,e,t,n){return Dn(r,e,2,Ge(r,e+1,n))}function rd(r,e,t,n){return Dn(r,e,3,je(r,e+1,n))}function nd(r,e,t,n){return Dn(r,e,5,We(r,e+1,n))}function od(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 Dn(r,e,9,o)}function sd(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Dn(r,e,1,1/0)}function hi(r,e){Ie(r,h.map.majorEncoded,e.value)}hi.compareTokens=tt.compareTokens;hi.encodedSize=function(e){return Ie.encodedSize(e.value)};function id(r,e,t,n){return new A(h.tag,t,1)}function ad(r,e,t,n){return new A(h.tag,Ge(r,e+1,n),2)}function cd(r,e,t,n){return new A(h.tag,je(r,e+1,n),3)}function ud(r,e,t,n){return new A(h.tag,We(r,e+1,n),5)}function ld(r,e,t,n){return new A(h.tag,Ye(r,e+1,n),9)}function di(r,e){Ie(r,h.tag.majorEncoded,e.value)}di.compareTokens=tt.compareTokens;di.encodedSize=function(e){return Ie.encodedSize(e.value)};var cw=20,uw=21,lw=22,fw=23;function fd(r,e,t,n){if(n.allowUndefined===!1)throw new Error(`${V} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new A(h.null,null,1):new A(h.undefined,void 0,1)}function hd(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return new A(h.break,void 0,1)}function Uc(r,e,t){if(t){if(t.allowNaN===!1&&Number.isNaN(r))throw new Error(`${V} NaN values are not supported`);if(t.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${V} Infinity values are not supported`)}return new A(h.float,r,e)}function dd(r,e,t,n){return Uc(Dc(r,e+1),3,n)}function pd(r,e,t,n){return Uc(Pc(r,e+1),5,n)}function md(r,e,t,n){return Uc(bd(r,e+1),9,n)}function pi(r,e,t){let n=e.value;if(n===!1)r.push([h.float.majorEncoded|cw]);else if(n===!0)r.push([h.float.majorEncoded|uw]);else if(n===null)r.push([h.float.majorEncoded|lw]);else if(n===void 0)r.push([h.float.majorEncoded|fw]);else{let o,s=!1;(!t||t.float64!==!0)&&(gd(n),o=Dc(mt,1),n===o||Number.isNaN(n)?(mt[0]=249,r.push(mt.slice(0,3)),s=!0):(wd(n),o=Pc(mt,1),n===o&&(mt[0]=250,r.push(mt.slice(0,5)),s=!0))),s||(hw(n),o=bd(mt,1),mt[0]=251,r.push(mt.slice(0,9)))}}pi.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){gd(n);let o=Dc(mt,1);if(n===o||Number.isNaN(n))return 3;if(wd(n),o=Pc(mt,1),n===o)return 5}return 9};var yd=new ArrayBuffer(9),rt=new DataView(yd,1),mt=new Uint8Array(yd,0);function gd(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 Dc(r,e){if(r.length-e<2)throw new Error(`${V} not enough data for float16`);let t=(r[e]<<8)+r[e+1];if(t===31744)return 1/0;if(t===64512)return-1/0;if(t===32256)return NaN;let n=t>>10&31,o=t&1023,s;return n===0?s=o*2**-24:n!==31?s=(o+1024)*2**(n-25):s=o===0?1/0:NaN,t&32768?-s:s}function wd(r){rt.setFloat32(0,r,!1)}function Pc(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 hw(r){rt.setFloat64(0,r,!1)}function bd(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)}pi.compareTokens=tt.compareTokens;function Q(r,e,t){throw new Error(`${V} encountered invalid minor (${t}) for major ${r[e]>>>5}`)}function mi(r){return()=>{throw new Error(`${V} ${r}`)}}var R=[];for(let r=0;r<=23;r++)R[r]=Q;R[24]=Rh;R[25]=Th;R[26]=_h;R[27]=Ch;R[28]=Q;R[29]=Q;R[30]=Q;R[31]=Q;for(let r=32;r<=55;r++)R[r]=Q;R[56]=Nh;R[57]=Lh;R[58]=Uh;R[59]=Ph;R[60]=Q;R[61]=Q;R[62]=Q;R[63]=Q;for(let r=64;r<=87;r++)R[r]=Oh;R[88]=Vh;R[89]=Fh;R[90]=Mh;R[91]=Hh;R[92]=Q;R[93]=Q;R[94]=Q;R[95]=mi("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)R[r]=$h;R[120]=Kh;R[121]=qh;R[122]=zh;R[123]=Gh;R[124]=Q;R[125]=Q;R[126]=Q;R[127]=mi("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)R[r]=Wh;R[152]=Yh;R[153]=Zh;R[154]=Jh;R[155]=Xh;R[156]=Q;R[157]=Q;R[158]=Q;R[159]=Qh;for(let r=160;r<=183;r++)R[r]=ed;R[184]=td;R[185]=rd;R[186]=nd;R[187]=od;R[188]=Q;R[189]=Q;R[190]=Q;R[191]=sd;for(let r=192;r<=215;r++)R[r]=id;R[216]=ad;R[217]=cd;R[218]=ud;R[219]=ld;R[220]=Q;R[221]=Q;R[222]=Q;R[223]=Q;for(let r=224;r<=243;r++)R[r]=mi("simple values are not supported");R[244]=Q;R[245]=Q;R[246]=Q;R[247]=fd;R[248]=mi("simple values are not supported");R[249]=dd;R[250]=pd;R[251]=md;R[252]=Q;R[253]=Q;R[254]=Q;R[255]=hd;var yt=[];for(let r=0;r<24;r++)yt[r]=new A(h.uint,r,1);for(let r=-1;r>=-24;r--)yt[31-r]=new A(h.negint,r,1);yt[64]=new A(h.bytes,new Uint8Array(0),1);yt[96]=new A(h.string,"",1);yt[128]=new A(h.array,0,1);yt[160]=new A(h.map,0,1);yt[244]=new A(h.false,!1,1);yt[245]=new A(h.true,!0,1);yt[246]=new A(h.null,null,1);function xd(r){switch(r.type){case h.false:return Bt([244]);case h.true:return Bt([245]);case h.null:return Bt([246]);case h.bytes:return r.value.length?void 0:Bt([64]);case h.string:return r.value===""?Bt([96]):void 0;case h.array:return r.value===0?Bt([128]):void 0;case h.map:return r.value===0?Bt([160]):void 0;case h.uint:return r.value<24?Bt([Number(r.value)]):void 0;case h.negint:if(r.value>=-24)return Bt([31-Number(r.value)])}}var pw={float64:!1,mapSorter:gw,quickEncodeToken:xd};function mw(){let r=[];return r[h.uint.major]=tt,r[h.negint.major]=ui,r[h.bytes.major]=Ln,r[h.string.major]=jh,r[h.array.major]=fi,r[h.map.major]=hi,r[h.tag.major]=di,r[h.float.major]=pi,r}var Ed=mw(),Oc=new bo,gi=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(`${Nn} object contains circular references`);return new r(t,e)}},br={null:new A(h.null,null),undefined:new A(h.undefined,void 0),true:new A(h.true,!0),false:new A(h.false,!1),emptyArray:new A(h.array,0),emptyMap:new A(h.map,0)},xr={number(r,e,t,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new A(h.float,r):r>=0?new A(h.uint,r):new A(h.negint,r)},bigint(r,e,t,n){return r>=BigInt(0)?new A(h.uint,r):new A(h.negint,r)},Uint8Array(r,e,t,n){return new A(h.bytes,r)},string(r,e,t,n){return new A(h.string,r)},boolean(r,e,t,n){return r?br.true:br.false},null(r,e,t,n){return br.null},undefined(r,e,t,n){return br.undefined},ArrayBuffer(r,e,t,n){return new A(h.bytes,new Uint8Array(r))},DataView(r,e,t,n){return new A(h.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,e,t,n){if(!r.length)return t.addBreakTokens===!0?[br.emptyArray,new A(h.break)]:br.emptyArray;n=gi.createCheck(n,r);let o=[],s=0;for(let i of r)o[s++]=yi(i,t,n);return t.addBreakTokens?[new A(h.array,r.length),o,new A(h.break)]:[new A(h.array,r.length),o]},Object(r,e,t,n){let o=e!=="Object",s=o?r.keys():Object.keys(r),i=o?r.size:s.length;if(!i)return t.addBreakTokens===!0?[br.emptyMap,new A(h.break)]:br.emptyMap;n=gi.createCheck(n,r);let a=[],c=0;for(let f of s)a[c++]=[yi(f,t,n),yi(o?r.get(f):r[f],t,n)];return yw(a,t),t.addBreakTokens?[new A(h.map,i),a,new A(h.break)]:[new A(h.map,i),a]}};xr.Map=xr.Object;xr.Buffer=xr.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))xr[`${r}Array`]=xr.DataView;function yi(r,e={},t){let n=xh(r),o=e&&e.typeEncoders&&e.typeEncoders[n]||xr[n];if(typeof o=="function"){let i=o(r,n,e,t);if(i!=null)return i}let s=xr[n];if(!s)throw new Error(`${Nn} unsupported type: ${n}`);return s(r,n,e,t)}function yw(r,e){e.mapSorter&&r.sort(e.mapSorter)}function gw(r,e){let t=Array.isArray(r[0])?r[0][0]:r[0],n=Array.isArray(e[0])?e[0][0]:e[0];if(t.type!==n.type)return t.type.compare(n.type);let o=t.type.major,s=Ed[o].compareTokens(t,n);return s===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),s}function vd(r,e,t,n){if(Array.isArray(e))for(let o of e)vd(r,o,t,n);else t[e.type.major](r,e,n)}function Ad(r,e,t){let n=yi(r,t);if(!Array.isArray(n)&&t.quickEncodeToken){let o=t.quickEncodeToken(n);if(o)return o;let s=e[n.type.major];if(s.encodedSize){let i=s.encodedSize(n,t),a=new bo(i);if(s(a,n,t),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return wo(a.chunks[0])}}return Oc.reset(),vd(Oc,n,e,t),Oc.toBytes(!0)}function Pn(r,e){return e=Object.assign({},pw,e),Ad(r,Ed,e)}var ww={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},wi=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=yt[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}},Ao=Symbol.for("DONE"),bi=Symbol.for("BREAK");function bw(r,e,t){let n=[];for(let o=0;o<r.value;o++){let s=On(e,t);if(s===bi){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed array`)}if(s===Ao)throw new Error(`${V} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=s}return n}function xw(r,e,t){let n=t.useMaps===!0,o=n?void 0:{},s=n?new Map:void 0;for(let i=0;i<r.value;i++){let a=On(e,t);if(a===bi){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed map`)}if(a===Ao)throw new Error(`${V} found map but not enough entries (got ${i} [no key], expected ${r.value})`);if(n!==!0&&typeof a!="string")throw new Error(`${V} non-string keys not supported (got ${typeof a})`);if(t.rejectDuplicateMapKeys===!0&&(n&&s.has(a)||!n&&a in o))throw new Error(`${V} found repeat map key "${a}"`);let c=On(e,t);if(c===Ao)throw new Error(`${V} found map but not enough entries (got ${i} [no value], expected ${r.value})`);n?s.set(a,c):o[a]=c}return n?s:o}function On(r,e){if(r.done())return Ao;let t=r.next();if(t.type===h.break)return bi;if(t.type.terminal)return t.value;if(t.type===h.array)return bw(t,r,e);if(t.type===h.map)return xw(t,r,e);if(t.type===h.tag){if(e.tags&&typeof e.tags[t.value]=="function"){let n=On(r,e);return e.tags[t.value](n)}throw new Error(`${V} tag not supported (${t.value})`)}throw new Error("unsupported")}function Vc(r,e){if(!(r instanceof Uint8Array))throw new Error(`${V} data to decode must be a Uint8Array`);e=Object.assign({},ww,e);let t=e.tokenizer||new wi(r,e),n=On(t,e);if(n===Ao)throw new Error(`${V} did not find any content to decode`);if(n===bi)throw new Error(`${V} got unexpected break`);return[n,r.subarray(t.pos())]}function nt(r,e){let[t,n]=Vc(r,e);if(n.length>0)throw new Error(`${V} too many terminals, data makes no sense`);return t}var Ze=st(sn(),1);var Bd=Ke("ipns:utils"),kd=j("/ipns/"),Ew=114,Sd=async(r,e)=>{if(e==null||r==null){let n=new Error("one or more of the provided parameters are not defined");throw Bd.error(n),(0,Ze.default)(n,Cc)}let t;if(e.pubKey!=null){try{t=Rc(e.pubKey)}catch(o){throw Bd.error(o),o}if(!(await gl(e.pubKey)).equals(r))throw(0,Ze.default)(new Error("Embedded public key did not match PeerID"),gh)}else r.publicKey!=null&&(t=Rc(r.publicKey));if(t!=null)return t;throw(0,Ze.default)(new Error("no public key is available"),Cc)};var Id=r=>{let e=j("ipns-signature:");return Le([e,r])},Hr=r=>"signatureV1"in r?pt.encode({value:j(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:j(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):pt.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data});function kt(r){let e=pt.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"),Wt);let t=Rd(e.data),n=vw(t.Value),o=z(t.Validity);if(e.value!=null&&e.signatureV1!=null)return Aw(e),{value:n,validityType:pt.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:pt.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 Fc=r=>Le([kd,r.toBytes()]),Vn=r=>Xn(r.slice(kd.length));var Rd=r=>{let e=nt(r);if(e.ValidityType===0)e.ValidityType=pt.ValidityType.EOL;else throw(0,Ze.default)(new Error("Unknown validity type"),ii);return Number.isInteger(e.Sequence)&&(e.Sequence=BigInt(e.Sequence)),Number.isInteger(e.TTL)&&(e.TTL=BigInt(e.TTL)),e},vw=r=>{if(r!=null){if(Mu(r))return`/ipns/${r.toCID().toString(sr)}`;if(r instanceof Uint8Array){let n=z(r);n.startsWith("/")&&(r=n)}let e=r.toString().trim();if(e.startsWith("/")&&e.length>1)return e;let t=te.asCID(r);if(t!=null)return t.code===Ew?`/ipns/${t.toString(sr)}`:`/ipfs/${t.toV1().toString()}`;try{return r instanceof Uint8Array?`/ipfs/${te.decode(r).toV1().toString()}`:`/ipfs/${te.parse(e).toV1().toString()}`}catch{}}throw(0,Ze.default)(new Error("Value must be a valid content path starting with /"),yh)},Aw=r=>{if(r.data==null)throw(0,Ze.default)(new Error("Record data is missing"),mh);let e=Rd(r.data);if(!se(e.Value,r.value??new Uint8Array(0)))throw(0,Ze.default)(new Error('Field "value" did not match between protobuf and CBOR'),Wt);if(!se(e.Validity,r.validity??new Uint8Array(0)))throw(0,Ze.default)(new Error('Field "validity" did not match between protobuf and CBOR'),Wt);if(e.ValidityType!==r.validityType)throw(0,Ze.default)(new Error('Field "validityType" did not match between protobuf and CBOR'),Wt);if(e.Sequence!==r.sequence)throw(0,Ze.default)(new Error('Field "sequence" did not match between protobuf and CBOR'),Wt);if(e.TTL!==r.ttl)throw(0,Ze.default)(new Error('Field "ttl" did not match between protobuf and CBOR'),Wt)};var QB=Ke("ipns"),e8=Je.code,Sw="/ipns/",t8=Sw.length;var Bo=st(sn(),1),Td=st(_c(),1);var Ei=Ke("ipns:validator"),Iw=1024*10,Rw=async(r,e)=>{let t=kt(e),n;try{let o=Id(t.data);n=await r.verify(o,t.signatureV2)}catch{n=!1}if(!n)throw Ei.error("record signature verification failed"),(0,Bo.default)(new Error("record signature verification failed"),Wt);if(t.validityType===pt.ValidityType.EOL){if(Td.default.fromString(t.validity).toDate().getTime()<Date.now())throw Ei.error("record has expired"),(0,Bo.default)(new Error("record has expired"),ph)}else if(t.validityType!=null)throw Ei.error("unrecognized validity type"),(0,Bo.default)(new Error("unrecognized validity type"),ii);Ei("ipns record for %s is valid",t.value)};async function _d(r,e){if(e.byteLength>Iw)throw(0,Bo.default)(new Error("record too large"),wh);let t=Vn(r),n=kt(e),o=await Sd(t,n);await Rw(o,e)}async function*ko(r){let e=/\r?\n/,t=new TextDecoder("utf8"),n="";for await(let o of r){typeof o=="string"&&(o=new TextEncoder().encode(o)),n+=t.decode(o,{stream:!0});let s=n.split(e);n=s.pop()??"";for(let i=0;i<s.length;i++)yield JSON.parse(s[i])}n+=t.decode(),n!==""&&(yield JSON.parse(n))}var Hc=st(Nd(),1);var Io=class extends Error{constructor(e){super(e),this.name="TimeoutError"}},$c=class extends Error{constructor(e){super(),this.name="AbortError",this.message=e}},Ld=r=>globalThis.DOMException===void 0?new $c(r):new DOMException(r),Ud=r=>{let e=r.reason===void 0?Ld("This operation was aborted."):r.reason;return e instanceof Error?e:Ld(e)};function Ro(r,e){let{milliseconds:t,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout}}=e,i,c=new Promise((f,u)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(e.signal){let{signal:p}=e;p.aborted&&u(Ud(p)),p.addEventListener("abort",()=>{u(Ud(p))})}if(t===Number.POSITIVE_INFINITY){r.then(f,u);return}let l=new Io;i=s.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(p){u(p)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?f():o instanceof Error?u(o):(l.message=o??`Promise timed out after ${t} milliseconds`,u(l))},t),(async()=>{try{f(await r)}catch(p){u(p)}})()}).finally(()=>{c.clear()});return c.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},c}function Kc(r,e,t){let n=0,o=r.length;for(;o>0;){let s=Math.trunc(o/2),i=n+s;t(r[i],e)<=0?(n=++i,o-=s+1):o=s}return n}var To=class{#e=[];enqueue(e,t){t={priority:0,...t};let n={priority:t.priority,run:e};if(this.size&&this.#e[this.size-1].priority>=t.priority){this.#e.push(n);return}let o=Kc(this.#e,n,(s,i)=>i.priority-s.priority);this.#e.splice(o,0,n)}dequeue(){return this.#e.shift()?.run}filter(e){return this.#e.filter(t=>t.priority===e.priority).map(t=>t.run)}get size(){return this.#e.length}};var St=class extends Hc.default{#e;#t;#r=0;#i;#c;#p=0;#o;#u;#n;#m;#s=0;#l;#a;#y;timeout;constructor(e){if(super(),e={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:To,...e},!(typeof e.intervalCap=="number"&&e.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${e.intervalCap?.toString()??""}\` (${typeof e.intervalCap})`);if(e.interval===void 0||!(Number.isFinite(e.interval)&&e.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${e.interval?.toString()??""}\` (${typeof e.interval})`);this.#e=e.carryoverConcurrencyCount,this.#t=e.intervalCap===Number.POSITIVE_INFINITY||e.interval===0,this.#i=e.intervalCap,this.#c=e.interval,this.#n=new e.queueClass,this.#m=e.queueClass,this.concurrency=e.concurrency,this.timeout=e.timeout,this.#y=e.throwOnTimeout===!0,this.#a=e.autoStart===!1}get#b(){return this.#t||this.#r<this.#i}get#x(){return this.#s<this.#l}#E(){this.#s--,this.#f(),this.emit("next")}#v(){this.#w(),this.#g(),this.#u=void 0}get#A(){let e=Date.now();if(this.#o===void 0){let t=this.#p-e;if(t<0)this.#r=this.#e?this.#s:0;else return this.#u===void 0&&(this.#u=setTimeout(()=>{this.#v()},t)),!0}return!1}#f(){if(this.#n.size===0)return this.#o&&clearInterval(this.#o),this.#o=void 0,this.emit("empty"),this.#s===0&&this.emit("idle"),!1;if(!this.#a){let e=!this.#A;if(this.#b&&this.#x){let t=this.#n.dequeue();return t?(this.emit("active"),t(),e&&this.#g(),!0):!1}}return!1}#g(){this.#t||this.#o!==void 0||(this.#o=setInterval(()=>{this.#w()},this.#c),this.#p=Date.now()+this.#c)}#w(){this.#r===0&&this.#s===0&&this.#o&&(clearInterval(this.#o),this.#o=void 0),this.#r=this.#e?this.#s:0,this.#h()}#h(){for(;this.#f(););}get concurrency(){return this.#l}set concurrency(e){if(!(typeof e=="number"&&e>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${e}\` (${typeof e})`);this.#l=e,this.#h()}async#B(e){return new Promise((t,n)=>{e.addEventListener("abort",()=>{n(e.reason)},{once:!0})})}async add(e,t={}){return t={timeout:this.timeout,throwOnTimeout:this.#y,...t},new Promise((n,o)=>{this.#n.enqueue(async()=>{this.#s++,this.#r++;try{t.signal?.throwIfAborted();let s=e({signal:t.signal});t.timeout&&(s=Ro(Promise.resolve(s),{milliseconds:t.timeout})),t.signal&&(s=Promise.race([s,this.#B(t.signal)]));let i=await s;n(i),this.emit("completed",i)}catch(s){if(s instanceof Io&&!t.throwOnTimeout){n();return}o(s),this.emit("error",s)}finally{this.#E()}},t),this.emit("add"),this.#f()})}async addAll(e,t){return Promise.all(e.map(async n=>this.add(n,t)))}start(){return this.#a?(this.#a=!1,this.#h(),this):this}pause(){this.#a=!0}clear(){this.#n=new this.#m}async onEmpty(){this.#n.size!==0&&await this.#d("empty")}async onSizeLessThan(e){this.#n.size<e||await this.#d("next",()=>this.#n.size<e)}async onIdle(){this.#s===0&&this.#n.size===0||await this.#d("idle")}async#d(e,t){return new Promise(n=>{let o=()=>{t&&!t()||(this.off(e,o),n())};this.on(e,o)})}get size(){return this.#n.size}sizeBy(e){return this.#n.filter(e).length}get pending(){return this.#s}get isPaused(){return this.#a}};function Cw(r){return r[Symbol.asyncIterator]!=null}function Nw(r){if(Cw(r))return(async()=>{for await(let e of r)return e})();for(let e of r)return e}var Ai=Nw;var qc=j("/ipns/");function Dd(r){return se(r.subarray(0,qc.byteLength),qc)}var Pd=r=>Xn(r.slice(qc.length)),Bi=class{client;constructor(e){this.client=e}async*findProviders(e,t={}){yield*an(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async put(e,t,n){if(!Dd(e))return;let o=Pd(e),s=kt(t);await this.client.putIPNS(o,s,n)}async get(e,t){if(!Dd(e))throw new N("Not found","ERR_NOT_FOUND");let n=Pd(e);try{let o=await this.client.getIPNS(n,t);return Hr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new N("Not found","ERR_NOT_FOUND"):o}}},ki=class{client;constructor(e){this.client=e}async findPeer(e,t={}){let n=await Ai(this.client.getPeers(e,t));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new N("Not found","ERR_NOT_FOUND")}async*getClosestPeers(e,t={}){}};var Me=Ke("delegated-routing-v1-http-api-client"),Od={concurrentRequests:4,timeout:3e4},Si=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;constructor(e,t={}){this.started=!1,this.shutDownController=new AbortController,Zr(1/0,this.shutDownController.signal),this.httpQueue=new St({concurrency:t.concurrentRequests??Od.concurrentRequests}),this.clientUrl=e instanceof URL?e:new URL(e),this.timeout=t.timeout??Od.timeout,this.contentRouting=new Bi(this),this.peerRouting=new ki(this)}get[Gn](){return this.contentRouting}get[jn](){return this.peerRouting}isStarted(){return this.started}start(){this.started=!0}stop(){this.httpQueue.clear(),this.shutDownController.abort(),this.started=!1}async*getProviders(e,t={}){Me("getProviders starts: %c",e);let n=Sr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=Ue(),s=Ue();this.httpQueue.add(async()=>(o.resolve(),s.promise));try{await o.promise;let i=`${this.clientUrl}routing/v1/providers/${e.toString()}`,c=await fetch(i,{headers:{Accept:"application/x-ndjson"},signal:n});if(c.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new N("Routing response had no body","ERR_BAD_RESPONSE");if(c.headers.get("Content-Type")==="application/json"){let u=await c.json();for(let l of u.Providers){let p=this.#e(l);p!=null&&(yield p)}}else for await(let u of ko(Qo(c.body))){let l=this.#e(u);l!=null&&(yield l)}}catch(i){Me.error("getProviders errored:",i)}finally{n.clear(),s.resolve(),Me("getProviders finished: %c",e)}}async*getPeers(e,t={}){Me("getPeers starts: %c",e);let n=Sr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=Ue(),s=Ue();this.httpQueue.add(async()=>(o.resolve(),s.promise));try{await o.promise;let i=`${this.clientUrl}routing/v1/peers/${e.toCID().toString()}`,c=await fetch(i,{headers:{Accept:"application/x-ndjson"},signal:n});if(c.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new N("Routing response had no body","ERR_BAD_RESPONSE");if(c.headers.get("Content-Type")==="application/json"){let u=await c.json();for(let l of u.Peers){let p=this.#e(l);p!=null&&(yield p)}}else for await(let u of ko(Qo(c.body))){let l=this.#e(u);l!=null&&(yield l)}}catch(i){Me.error("getPeers errored:",i)}finally{n.clear(),s.resolve(),Me("getPeers finished: %c",e)}}async getIPNS(e,t={}){Me("getIPNS starts: %c",e);let n=Sr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=Ue(),s=Ue();this.httpQueue.add(async()=>(o.resolve(),s.promise));let i=`${this.clientUrl}routing/v1/ipns/${e.toCID().toString()}`;try{await o.promise;let c=await fetch(i,{headers:{Accept:"application/vnd.ipfs.ipns-record"},signal:n});if(Me("getIPNS GET %s %d",i,c.status),c.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new N("GET ipns response had no body","ERR_BAD_RESPONSE");let f=await c.arrayBuffer(),u=new Uint8Array(f,0,f.byteLength);return t.validate!==!1&&await _d(Fc(e),u),kt(u)}catch(a){throw Me.error("getIPNS GET %s error:",i,a),a}finally{n.clear(),s.resolve(),Me("getIPNS finished: %c",e)}}async putIPNS(e,t,n={}){Me("putIPNS starts: %c",e);let o=Sr([this.shutDownController.signal,n.signal,AbortSignal.timeout(this.timeout)]),s=Ue(),i=Ue();this.httpQueue.add(async()=>(s.resolve(),i.promise));let a=`${this.clientUrl}routing/v1/ipns/${e.toCID().toString()}`;try{await s.promise;let c=Hr(t),u=await fetch(a,{method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:c,signal:o});if(Me("putIPNS PUT %s %d",a,u.status),u.status!==200)throw new N("PUT ipns response had status other than 200","ERR_BAD_RESPONSE")}catch(c){throw Me.error("putIPNS PUT %s error:",a,c.stack),c}finally{o.clear(),i.resolve(),Me("putIPNS finished: %c",e)}}#e(e){let t=[],n=e.Addrs?.map(Qn)??[];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 Vd(r,e={}){return new Si(new URL(r),e)}var Fd=j("/ipns/");function Md(r){return se(r.subarray(0,Fd.byteLength),Fd)}var zc=class{client;constructor(e){this.client=Vd(e)}async provide(e,t){}async*findProviders(e,t){yield*an(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs,protocols:n.Protocols}))}async put(e,t,n){if(!Md(e))return;let o=Vn(e),s=kt(t);await this.client.putIPNS(o,s,n)}async get(e,t){if(!Md(e))throw new N("Not found","ERR_NOT_FOUND");let n=Vn(e);try{let o=await this.client.getIPNS(n,t);return Hr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new N("Not found","ERR_NOT_FOUND"):o}}async findPeer(e,t){let n=await Ai(this.client.getPeers(e,t));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new N("Not found","ERR_NOT_FOUND")}async*getClosestPeers(e,t){}};function Gc(r){return new zc(new URL(r))}var jc=60;function Ii(r){return{Status:r.Status??0,TC:r.TC??r.flag_tc??!1,RD:r.RD??r.flag_rd??!1,RA:r.RA??r.flag_ra??!1,AD:r.AD??r.flag_ad??!1,CD:r.CD??r.flag_cd??!1,Question:(r.Question??r.questions??[]).map(e=>({name:e.name,type:Er[e.type]})),Answer:(r.Answer??r.answers??[]).map(e=>({name:e.name,type:Er[e.type],TTL:e.TTL??e.ttl??jc,data:e.data instanceof Uint8Array?z(e.data):e.data}))}}var Lw=4;function Wc(r,e={}){let t=new St({concurrency:e.queryConcurrency??Lw});return async(n,o,s={})=>{let i=new URLSearchParams;i.set("name",n),o.forEach(c=>{i.append("type",c.toString())}),s.onProgress?.(new ee("dns:query",{detail:n}));let a=await t.add(async()=>{let c=await fetch(`${r}?${i}`,{headers:{accept:"application/dns-json"},signal:s?.signal});if(c.status!==200)throw new Error(`Unexpected HTTP status: ${c.status} - ${c.statusText}`);let f=Ii(await c.json());return s.onProgress?.(new ee("dns:response",{detail:f})),f},{signal:s.signal});if(a==null)throw new Error("No DNS response received");return a}}function Hd(){return[Wc("https://cloudflare-dns.com/dns-query"),Wc("https://dns.google/resolve")]}var qd=st(Kd(),1);var Yc=class{lru;constructor(e){this.lru=(0,qd.default)(e)}get(e,t){let n=!0,o=[];for(let s of t){let i=this.getAnswers(e,s);if(i.length===0){n=!1;break}o.push(...i)}if(n)return Ii({answers:o})}getAnswers(e,t){let n=`${e.toLowerCase()}-${t}`,o=this.lru.get(n);if(o!=null){let s=o.filter(i=>i.expires>Date.now()).map(({value:i})=>i);return s.length===0&&this.lru.remove(n),s}return[]}add(e,t){let n=`${e.toLowerCase()}-${t.type}`,o=this.lru.get(n)??[];o.push({expires:Date.now()+(t.TTL??jc)*1e3,value:t}),this.lru.set(n,o)}remove(e,t){let n=`${e.toLowerCase()}-${t}`;this.lru.remove(n)}clear(){this.lru.clear()}},Zc=new Yc(1e3);var Ri=class{resolvers;constructor(e){this.resolvers={},Object.entries(e.resolvers??{}).forEach(([t,n])=>{Array.isArray(n)||(n=[n]),t.endsWith(".")||(t=`${t}.`),this.resolvers[t]=n}),this.resolvers["."]==null&&(this.resolvers["."]=Hd())}async query(e,t={}){let n=[];t.types!=null?Array.isArray(t.types)?n.push(...t.types):n.push(t.types):n.push(Er.A,Er.AAAA);let o=t.cached!==!1?Zc.get(e,n):void 0;if(o!=null)return t.onProgress?.(new ee("dns:cache",{detail:o})),o;let s=`${e.split(".").pop()}.`,i=(this.resolvers[s]??this.resolvers["."]).sort(()=>Math.random()>.5?-1:1),a=[];for(let c of i)try{let f=await c(e,Array.isArray(n)?n:[n],t);for(let u of f.Answer)Zc.add(e,u);return f}catch(f){a.push(f),t.onProgress?.(new ee("dns:error",{detail:f}))}throw a.length===1?a[0]:new AggregateError(a,`DNS lookup of ${e} ${n} failed`)}};var Er;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(Er||(Er={}));function zd(r={}){return new Ri(r)}var Jc=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 Ti(r,e,t,n){let o=new Jc(n?.errorMessage,n?.errorCode);return t?.aborted===!0?Promise.reject(o):new Promise((s,i)=>{let a=f=>{try{if(n?.filter?.(f)===!1)return}catch(u){r.removeEventListener(e,a),t?.removeEventListener("abort",c),i(u);return}r.removeEventListener(e,a),t?.removeEventListener("abort",c),s(f)},c=()=>{r.removeEventListener(e,a),t?.removeEventListener("abort",c),i(o)};r.addEventListener(e,a),t?.addEventListener("abort",c)})}var _i=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 Gd(r,e,t){if(e==null)return r;if(e.aborted)return Promise.reject(new _i(t?.errorMessage,t?.errorCode));let n,o=new _i(t?.errorMessage,t?.errorCode);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var Ci=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 er)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function Uw(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var Ni=class{id;fn;options;priority;recipients;status;timeline;controller;constructor(e,t,n=0){this.id=Uw(),this.status="queued",this.fn=e,this.priority=n,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,Zr(1/0,this.controller.signal),this.onAbort=this.onAbort.bind(this)}abort(e){this.controller.abort(e)}onAbort(){this.recipients.reduce((t,n)=>t&&n.signal?.aborted===!0,!0)&&this.controller.abort(new er)}async join(e={}){let t=new Ci(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 Gd(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(t=>{t.deferred.resolve(e)}),this.status="complete"}catch(e){this.recipients.forEach(t=>{t.deferred.reject(e)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(e=>{e.signal?.removeEventListener("abort",this.onAbort)})}};function Dw(r,e,t){let n=0,o=r.length;for(;o>0;){let s=Math.trunc(o/2),i=n+s;t(r[i],e)<=0?(n=++i,o-=s+1):o=s}return n}var _o=class extends Oo{concurrency;queue;pending;constructor(e={}){super(),this.concurrency=e.concurrency??Number.POSITIVE_INFINITY,this.pending=0,e.metricName!=null&&e.metrics?.registerMetricGroup(e.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.queue=[]}tryToStartAnother(){if(this.size===0)return queueMicrotask(()=>{this.safeDispatchEvent("empty")}),this.running===0&&queueMicrotask(()=>{this.safeDispatchEvent("idle")}),!1;if(this.pending<this.concurrency){let e;for(let t of this.queue)if(t.status==="queued"){e=t;break}return e==null?!1:(this.safeDispatchEvent("active"),this.pending++,e.run().finally(()=>{for(let t=0;t<this.queue.length;t++)if(this.queue[t]===e){this.queue.splice(t,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(e){if(this.queue[this.size-1]?.priority>=e.priority){this.queue.push(e);return}let t=Dw(this.queue,e,(n,o)=>o.priority-n.priority);this.queue.splice(t,0,e)}async add(e,t){t?.signal?.throwIfAborted();let n=new Ni(e,t,t?.priority),o=n.join(t).then(s=>(this.safeDispatchEvent("completed",{detail:s}),s)).catch(s=>{throw this.safeDispatchEvent("error",{detail:s}),s});return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),o}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(e=>{e.abort(new er)}),this.clear()}async onEmpty(e){this.size!==0&&await Ti(this,"empty",e?.signal)}async onSizeLessThan(e,t){this.size<e||await Ti(this,"next",t?.signal,{filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await Ti(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)},s=c=>{n(c.detail)},i=()=>{n()},a=()=>{n(new N("Queue aborted","ERR_QUEUE_ABORTED"))};this.addEventListener("completed",o),this.addEventListener("error",s),this.addEventListener("idle",i),e?.signal?.addEventListener("abort",a);try{yield*t}finally{this.removeEventListener("completed",o),this.removeEventListener("error",s),this.removeEventListener("idle",i),e?.signal?.removeEventListener("abort",a),n()}}};var Zd="/pin/",jd="/pinned-block/",Xc=sr,Wd=1;function Yd(r){return r.version===0&&(r=r.toV1()),new Se(`${Zd}${r.toString(Xc)}`)}var Li=class{datastore;blockstore;dagWalkers;constructor(e,t,n){this.datastore=e,this.blockstore=t,this.dagWalkers=n}async*add(e,t={}){let n=Yd(e);if(await this.datastore.has(n))throw new Error("Already pinned");let o=Math.round(t.depth??1/0);if(o<0)throw new Error("Depth must be greater than or equal to 0");let s=new _o({concurrency:Wd});for await(let a of this.#e(e,s,{...t,depth:o}))await this.#t(a,c=>c.pinnedBy.find(f=>se(f,e.bytes))!=null?!1:(c.pinCount++,c.pinnedBy.push(e.bytes),!0),t),yield a;let i={depth:o,metadata:t.metadata??{}};await this.datastore.put(n,Pn(i),t)}async*#e(e,t,n){if(n.depth===-1)return;let o=this.dagWalkers[e.code];if(o==null)throw new Error(`No dag walker found for cid codec ${e.code}`);let s=await this.blockstore.get(e,n);yield e;for await(let i of o.walk(s))yield*await t.add(async()=>this.#e(i,t,{...n,depth:n.depth-1}))}async#t(e,t,n){let o=new Se(`${jd}${Xc.encode(e.multihash.bytes)}`),s={pinCount:0,pinnedBy:[]};try{s=nt(await this.datastore.get(o,n))}catch(a){if(a.code!=="ERR_NOT_FOUND")throw a}if(t(s)){if(s.pinCount===0&&await this.datastore.has(o)){await this.datastore.delete(o);return}await this.datastore.put(o,Pn(s),n),n.onProgress?.(new ee("helia:pin:add",e))}}async*rm(e,t={}){let n=Yd(e),o=await this.datastore.get(n,t),s=nt(o);await this.datastore.delete(n,t);let i=new _o({concurrency:Wd});for await(let a of this.#e(e,i,{...t,depth:s.depth}))await this.#t(a,c=>(c.pinCount--,c.pinnedBy=c.pinnedBy.filter(f=>se(f,e.bytes)),!0),{...t,depth:s.depth}),yield a}async*ls(e={}){for await(let{key:t,value:n}of this.datastore.query({prefix:Zd+(e.cid!=null?`${e.cid.toString(sr)}`:"")},e)){let o=te.parse(t.toString().substring(5),sr),s=nt(n);yield{cid:o,...s}}}async isPinned(e,t={}){let n=new Se(`${jd}${Xc.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 Fn=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=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 Qc(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 Ui=class{log;routers;constructor(e,t){this.log=e.logger.forComponent("helia:routing"),this.routers=t.routers??[]}async start(){await tr(...this.routers)}async stop(){await rr(...this.routers)}async*findProviders(e,t={}){if(this.routers.length===0)throw new N("No content routers available","ERR_NO_ROUTERS_AVAILABLE");let n=new Fn;for await(let o of ar(...Mn(this.routers,"findProviders").map(s=>s.findProviders(e,t))))o!=null&&(n.has(o.id)||(n.add(o.id),yield o))}async provide(e,t={}){if(this.routers.length===0)throw new N("No content routers available","ERR_NO_ROUTERS_AVAILABLE");await Promise.all(Mn(this.routers,"provide").map(async n=>{await n.provide(e,t)}))}async put(e,t,n){await Promise.all(Mn(this.routers,"put").map(async o=>{await o.put(e,t,n)}))}async get(e,t){return Promise.any(Mn(this.routers,"get").map(async n=>n.get(e,t)))}async findPeer(e,t){if(this.routers.length===0)throw new N("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");let n=this,o=ar(...Mn(this.routers,"findPeer").map(s=>async function*(){try{yield await s.findPeer(e,t)}catch(i){n.log.error(i)}}()));for await(let s of o)if(s!=null)return s;throw new N("Could not find peer in routing","ERR_NOT_FOUND")}async*getClosestPeers(e,t={}){if(this.routers.length===0)throw new N("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");let n=new Fn;for await(let o of ar(...Mn(this.routers,"getClosestPeers").map(s=>s.getClosestPeers(e,t))))o!=null&&(n.has(o.id)||(n.add(o.id),yield o))}};function Mn(r,e){return r.filter(t=>t[e]!=null)}var vr={},Hn=r=>{r.addEventListener("message",e=>{Hn.dispatchEvent("message",r,e)}),r.port!=null&&r.port.addEventListener("message",e=>{Hn.dispatchEvent("message",r,e)})};Hn.addEventListener=(r,e)=>{vr[r]==null&&(vr[r]=[]),vr[r].push(e)};Hn.removeEventListener=(r,e)=>{vr[r]!=null&&(vr[r]=vr[r].filter(t=>t===e))};Hn.dispatchEvent=function(r,e,t){vr[r]!=null&&vr[r].forEach(n=>n(e,t))};var eu=Hn;var tu="lock:worker:request-read",ru="lock:worker:release-read",nu="lock:master:grant-read",ou="lock:worker:request-write",su="lock:worker:release-write",iu="lock:master:grant-write";var Jd=(r=21)=>Math.random().toString().substring(2);var Xd=(r,e,t,n,o)=>(s,i)=>{if(i.data.type!==t)return;let a={type:i.data.type,name:i.data.name,identifier:i.data.identifier};r.dispatchEvent(new MessageEvent(e,{data:{name:a.name,handler:async()=>{s.postMessage({type:o,name:a.name,identifier:a.identifier}),await new Promise(c=>{let f=u=>{if(u==null||u.data==null)return;let l={type:u.data.type,name:u.data.name,identifier:u.data.identifier};l.type===n&&l.identifier===a.identifier&&(s.removeEventListener("message",f),c())};s.addEventListener("message",f)})}}}))},Qd=(r,e,t,n)=>async()=>{let o=Jd();return globalThis.postMessage({type:e,identifier:o,name:r}),new Promise(s=>{let i=a=>{if(a==null||a.data==null)return;let c={type:a.data.type,identifier:a.data.identifier};c.type===t&&c.identifier===o&&(globalThis.removeEventListener("message",i),s(()=>{globalThis.postMessage({type:n,identifier:o,name:r})}))};globalThis.addEventListener("message",i)})},Pw={singleProcess:!1},ep=r=>{if(r=Object.assign({},Pw,r),!!globalThis.document||r.singleProcess){let t=new EventTarget;return eu.addEventListener("message",Xd(t,"requestReadLock",tu,ru,nu)),eu.addEventListener("message",Xd(t,"requestWriteLock",ou,su,iu)),t}return{isWorker:!0,readLock:t=>Qd(t,tu,nu,ru),writeLock:t=>Qd(t,ou,iu,su)}};var $r={},Ar;async function au(r,e){let t,n=new Promise(o=>{t=o});return r.add(async()=>Ro((async()=>{await new Promise(o=>{t(()=>{o()})})})(),{milliseconds:e.timeout})),n}var Ow=(r,e)=>{if(Ar.isWorker===!0)return{readLock:Ar.readLock(r,e),writeLock:Ar.writeLock(r,e)};let t=new St({concurrency:1}),n;return{async readLock(){if(n!=null)return au(n,e);n=new St({concurrency:e.concurrency,autoStart:!1});let o=n,s=au(n,e);return t.add(async()=>{o.start(),await o.onIdle().then(()=>{n===o&&(n=null)})}),s},async writeLock(){return n=null,au(t,e)}}},Vw={name:"lock",concurrency:1/0,timeout:846e5,singleProcess:!1};function cu(r){let e=Object.assign({},Vw,r);return Ar==null&&(Ar=ep(e),Ar.isWorker!==!0&&(Ar.addEventListener("requestReadLock",t=>{$r[t.data.name]!=null&&$r[t.data.name].readLock().then(async n=>t.data.handler().finally(()=>{n()}))}),Ar.addEventListener("requestWriteLock",async t=>{$r[t.data.name]!=null&&$r[t.data.name].writeLock().then(async n=>t.data.handler().finally(()=>{n()}))}))),$r[e.name]==null&&($r[e.name]=Ow(e.name,e)),$r[e.name]}var Di=class{lock;child;pins;started;constructor(e,t,n={}){this.child=e,this.pins=t,this.lock=cu({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await tr(this.child),this.started=!0}async stop(){await rr(this.child),this.started=!1}unwrap(){return this.child}async put(e,t,n={}){let o=await this.lock.readLock();try{return await this.child.put(e,t,n)}finally{o()}}async*putMany(e,t={}){let n=await this.lock.readLock();try{yield*this.child.putMany(e,t)}finally{n()}}async get(e,t={}){let n=await this.lock.readLock();try{return await this.child.get(e,t)}finally{n()}}async*getMany(e,t={}){let n=await this.lock.readLock();try{yield*this.child.getMany(e,t)}finally{n()}}async delete(e,t={}){let n=await this.lock.writeLock();try{if(await this.pins.isPinned(e))throw new Error("CID was pinned");await this.child.delete(e,t)}finally{n()}}async*deleteMany(e,t={}){let n=await this.lock.writeLock();try{let o=this;yield*this.child.deleteMany(async function*(){for await(let s of e){if(await o.pins.isPinned(s))throw new Error("CID was pinned");yield s}}(),t)}finally{n()}}async has(e,t={}){let n=await this.lock.readLock();try{return await this.child.has(e,t)}finally{n()}}async*getAll(e={}){let t=await this.lock.readLock();try{yield*this.child.getAll(e)}finally{t()}}};var rp=42;function Fw(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let e=te.asCID(r);if(!e)return null;let t=new Uint8Array(e.bytes.byteLength+1);return t.set(e.bytes,1),[new A(h.tag,rp),new A(h.bytes,t)]}function Mw(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function Hw(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 tp={float64:!0,typeEncoders:{Object:Fw,undefined:Mw,number:Hw}},ES={...tp,typeEncoders:{...tp.typeEncoders}};function $w(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return te.decode(r.subarray(1))}var uu={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};uu.tags[rp]=$w;var vS={...uu,tags:uu.tags.slice()};var np=113;var op=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(e){let t=this.inRecursive[this.inRecursive.length-1];t&&(t.type===h.array&&(t.elements++,t.elements!==1&&e.push([44])),t.type===h.map&&(t.elements++,t.elements!==1&&(t.elements%2===1?e.push([44]):e.push([58]))))}[h.uint.major](e,t){this.prefix(e);let n=String(t.value),o=[];for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);e.push(o)}[h.negint.major](e,t){this[h.uint.major](e,t)}[h.bytes.major](e,t){throw new Error(`${Nn} unsupported type: Uint8Array`)}[h.string.major](e,t){this.prefix(e);let n=ci(JSON.stringify(t.value));e.push(n.length>32?wo(n):n)}[h.array.major](e,t){this.prefix(e),this.inRecursive.push({type:h.array,elements:0}),e.push([91])}[h.map.major](e,t){this.prefix(e),this.inRecursive.push({type:h.map,elements:0}),e.push([123])}[h.tag.major](e,t){}[h.float.major](e,t){if(t.type.name==="break"){let i=this.inRecursive.pop();if(i){if(i.type===h.array)e.push([93]);else if(i.type===h.map)e.push([125]);else throw new Error("Unexpected recursive type; this should not happen!");return}throw new Error("Unexpected break; this should not happen!")}if(t.value===void 0)throw new Error(`${Nn} unsupported type: undefined`);if(this.prefix(e),t.type.name==="true"){e.push([116,114,117,101]);return}else if(t.type.name==="false"){e.push([102,97,108,115,101]);return}else if(t.type.name==="null"){e.push([110,117,108,108]);return}let n=String(t.value),o=[],s=!1;for(let i=0;i<n.length;i++)o[i]=n.charCodeAt(i),!s&&(o[i]===46||o[i]===101||o[i]===69)&&(s=!0);s||(o.push(46),o.push(48)),e.push(o)}};var Kr=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t,this.modeStack=["value"],this.lastToken=""}pos(){return this._pos}done(){return this._pos>=this.data.length}ch(){return this.data[this._pos]}currentMode(){return this.modeStack[this.modeStack.length-1]}skipWhitespace(){let e=this.ch();for(;e===32||e===9||e===13||e===10;)e=this.data[++this._pos]}expect(e){if(this.data.length-this._pos<e.length)throw new Error(`${V} unexpected end of input at position ${this._pos}`);for(let t=0;t<e.length;t++)if(this.data[this._pos++]!==e[t])throw new Error(`${V} unexpected token at position ${this._pos}, expected to find '${String.fromCharCode(...e)}'`)}parseNumber(){let e=this._pos,t=!1,n=!1,o=a=>{for(;!this.done();){let c=this.ch();if(a.includes(c))this._pos++;else break}};if(this.ch()===45&&(t=!0,this._pos++),this.ch()===48)if(this._pos++,this.ch()===46)this._pos++,n=!0;else return new A(h.uint,0,this._pos-e);if(o([48,49,50,51,52,53,54,55,56,57]),t&&this._pos===e+1)throw new Error(`${V} unexpected token at position ${this._pos}`);if(!this.done()&&this.ch()===46){if(n)throw new Error(`${V} unexpected token at position ${this._pos}`);n=!0,this._pos++,o([48,49,50,51,52,53,54,55,56,57])}!this.done()&&(this.ch()===101||this.ch()===69)&&(n=!0,this._pos++,!this.done()&&(this.ch()===43||this.ch()===45)&&this._pos++,o([48,49,50,51,52,53,54,55,56,57]));let s=String.fromCharCode.apply(null,this.data.subarray(e,this._pos)),i=parseFloat(s);return n?new A(h.float,i,this._pos-e):this.options.allowBigInt!==!0||Number.isSafeInteger(i)?new A(i>=0?h.uint:h.negint,i,this._pos-e):new A(i>=0?h.uint:h.negint,BigInt(s),this._pos-e)}parseString(){if(this.ch()!==34)throw new Error(`${V} unexpected character at position ${this._pos}; this shouldn't happen`);this._pos++;for(let s=this._pos,i=0;s<this.data.length&&i<65536;s++,i++){let a=this.data[s];if(a===92||a<32||a>=128)break;if(a===34){let c=String.fromCharCode.apply(null,this.data.subarray(this._pos,s));return this._pos=s+1,new A(h.string,c,i)}}let e=this._pos,t=[],n=()=>{if(this._pos+4>=this.data.length)throw new Error(`${V} unexpected end of unicode escape sequence at position ${this._pos}`);let s=0;for(let i=0;i<4;i++){let a=this.ch();if(a>=48&&a<=57)a-=48;else if(a>=97&&a<=102)a=a-97+10;else if(a>=65&&a<=70)a=a-65+10;else throw new Error(`${V} unexpected unicode escape character at position ${this._pos}`);s=s*16+a,this._pos++}return s},o=()=>{let s=this.ch(),i=null,a=s>239?4:s>223?3:s>191?2:1;if(this._pos+a>this.data.length)throw new Error(`${V} unexpected unicode sequence at position ${this._pos}`);let c,f,u,l;switch(a){case 1:s<128&&(i=s);break;case 2:c=this.data[this._pos+1],(c&192)===128&&(l=(s&31)<<6|c&63,l>127&&(i=l));break;case 3:c=this.data[this._pos+1],f=this.data[this._pos+2],(c&192)===128&&(f&192)===128&&(l=(s&15)<<12|(c&63)<<6|f&63,l>2047&&(l<55296||l>57343)&&(i=l));break;case 4:c=this.data[this._pos+1],f=this.data[this._pos+2],u=this.data[this._pos+3],(c&192)===128&&(f&192)===128&&(u&192)===128&&(l=(s&15)<<18|(c&63)<<12|(f&63)<<6|u&63,l>65535&&l<1114112&&(i=l))}i===null?(i=65533,a=1):i>65535&&(i-=65536,t.push(i>>>10&1023|55296),i=56320|i&1023),t.push(i),this._pos+=a};for(;!this.done();){let s=this.ch(),i;switch(s){case 92:if(this._pos++,this.done())throw new Error(`${V} unexpected string termination at position ${this._pos}`);switch(i=this.ch(),this._pos++,i){case 34:case 39:case 92:case 47:t.push(i);break;case 98:t.push(8);break;case 116:t.push(9);break;case 110:t.push(10);break;case 102:t.push(12);break;case 114:t.push(13);break;case 117:t.push(n());break;default:throw new Error(`${V} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new A(h.string,Nc(t),this._pos-e);default:if(s<32)throw new Error(`${V} invalid control character at position ${this._pos}`);s<128?(t.push(s),this._pos++):o()}}throw new Error(`${V} unexpected end of string at position ${this._pos}`)}parseValue(){switch(this.ch()){case 123:return this.modeStack.push("obj-start"),this._pos++,new A(h.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new A(h.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new A(h.null,null,4);case 102:return this.expect([102,97,108,115,101]),new A(h.false,!1,5);case 116:return this.expect([116,114,117,101]),new A(h.true,!0,4);case 45:case 48:case 49:case 50:case 51:case 52:case 53:case 54:case 55:case 56:case 57:return this.parseNumber();default:throw new Error(`${V} unexpected character at position ${this._pos}`)}}next(){switch(this.skipWhitespace(),this.currentMode()){case"value":return this.modeStack.pop(),this.parseValue();case"array-value":{if(this.modeStack.pop(),this.ch()===93)return this._pos++,this.skipWhitespace(),new A(h.break,void 0,1);if(this.ch()!==44)throw new Error(`${V} unexpected character at position ${this._pos}, was expecting array delimiter but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue()}case"array-start":return this.modeStack.pop(),this.ch()===93?(this._pos++,this.skipWhitespace(),new A(h.break,void 0,1)):(this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue());case"obj-key":if(this.ch()===125)return this.modeStack.pop(),this._pos++,this.skipWhitespace(),new A(h.break,void 0,1);if(this.ch()!==44)throw new Error(`${V} unexpected character at position ${this._pos}, was expecting object delimiter but found '${String.fromCharCode(this.ch())}'`);this._pos++,this.skipWhitespace();case"obj-start":{if(this.modeStack.pop(),this.ch()===125)return this._pos++,this.skipWhitespace(),new A(h.break,void 0,1);let e=this.parseString();if(this.skipWhitespace(),this.ch()!==58)throw new Error(`${V} unexpected character at position ${this._pos}, was expecting key/value delimiter ':' but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("obj-value"),e}case"obj-value":return this.modeStack.pop(),this.modeStack.push("obj-key"),this.skipWhitespace(),this.parseValue();default:throw new Error(`${V} unexpected parse state at position ${this._pos}; this shouldn't happen`)}}};function Pi(r,e){return e=Object.assign({tokenizer:new Kr(r,e)},e),nt(r,e)}var zw={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};zw.tags[42]=te.parse;var ip=297;var FS=new TextDecoder;var MS=new TextEncoder;var jw=new TextDecoder;function lu(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 Oi(r,e){let t;[t,e]=lu(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 ap(r,e){let t;return[t,e]=lu(r,e),[t&7,t>>3,e]}function Ww(r){let e={},t=r.length,n=0;for(;n<t;){let o,s;if([o,s,n]=ap(r,n),s===1){if(e.Hash)throw new Error("protobuf: (PBLink) duplicate Hash section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Hash`);if(e.Name!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Name before Hash");if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Hash");[e.Hash,n]=Oi(r,n)}else if(s===2){if(e.Name!==void 0)throw new Error("protobuf: (PBLink) duplicate Name section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Name`);if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Name");let i;[i,n]=Oi(r,n),e.Name=jw.decode(i)}else if(s===3){if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) duplicate Tsize section");if(o!==0)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Tsize`);[e.Tsize,n]=lu(r,n)}else throw new Error(`protobuf: (PBLink) invalid fieldNumber, expected 1, 2 or 3, got ${s}`)}if(n>t)throw new Error("protobuf: (PBLink) unexpected end of data");return e}function cp(r){let e=r.length,t=0,n,o=!1,s;for(;t<e;){let a,c;if([a,c,t]=ap(r,t),a!==2)throw new Error(`protobuf: (PBNode) invalid wireType, expected 2, got ${a}`);if(c===1){if(s)throw new Error("protobuf: (PBNode) duplicate Data section");[s,t]=Oi(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]=Oi(r,t),n.push(Ww(f))}else throw new Error(`protobuf: (PBNode) invalid fieldNumber, expected 1 or 2, got ${c}`)}if(t>e)throw new Error("protobuf: (PBNode) unexpected end of data");let i={};return s&&(i.Data=s),i.Links=n||[],i}var $S=new TextEncoder,KS=2**32,qS=2**31;var jS=new TextEncoder;function up(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var lp=112;function fp(r){let e=up(r),t=cp(e),n={};return t.Data&&(n.Data=t.Data),t.Links&&(n.Links=t.Links.map(o=>{let s={};try{s.Hash=te.decode(o.Hash)}catch{}if(!s.Hash)throw new Error("Invalid Hash field found in link, expected CID");return o.Name!==void 0&&(s.Name=o.Name),o.Tsize!==void 0&&(s.Tsize=o.Tsize),s})),n}var Zw={codec:lp,*walk(r){yield*fp(r).Links.map(t=>t.Hash)}},Jw={codec:Ho,*walk(){}},hp=42,Xw={codec:np,*walk(r){let e=[],t=[];t[hp]=n=>{if(n[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");let o=te.decode(n.subarray(1));return e.push(o),o},nt(r,{tags:t}),yield*e}},fu=class extends Kr{tokenBuffer;constructor(e,t){super(e,t),this.tokenBuffer=[]}done(){return this.tokenBuffer.length===0&&super.done()}_next(){return this.tokenBuffer.length>0?this.tokenBuffer.pop():super.next()}next(){let e=this._next();if(e.type===h.map){let t=this._next();if(t.type===h.string&&t.value==="/"){let n=this._next();if(n.type===h.string){if(this._next().type!==h.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new A(h.tag,42,0)}if(n.type===h.map){let o=this._next();if(o.type===h.string&&o.value==="bytes"){let s=this._next();if(s.type===h.string){for(let a=0;a<2;a++)if(this._next().type!==h.break)throw new Error("Invalid encoded Bytes form");let i=nr.decode(`m${s.value}`);return new A(h.bytes,i,s.value.length)}this.tokenBuffer.push(s)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(t)}return e}},Qw={codec:ip,*walk(r){let e=[],t=[];t[hp]=n=>{let o=te.parse(n);return e.push(o),o},Pi(r,{tags:t,tokenizer:new fu(r,{tags:t,allowIndefinite:!0,allowUndefined:!0,allowNaN:!0,allowInfinity:!0,allowBigInt:!0,strict:!1,rejectDuplicateMapKeys:!1})}),yield*e}},eb={codec:il,*walk(){}};function dp(r=[]){let e={};return[Zw,Jw,Xw,Qw,eb,...r].forEach(t=>{e[t.codec]=t}),e}var hu=new Se("/version"),pp=1;async function mp(r){if(!await r.has(hu)){await r.put(hu,j(`${pp}`));return}let e=await r.get(hu),t=z(e);if(parseInt(t,10)!==pp)throw new Error("Unknown datastore version, a datastore migration may be required")}function yp(r=[]){let e={};return[we,na,Je,...r].forEach(t=>{e[t.code]=t}),e}var It=class{has(e,t){return Promise.reject(new Error(".has is not implemented"))}put(e,t,n){return Promise.reject(new Error(".put is not implemented"))}async*putMany(e,t){for await(let{cid:n,block:o}of e)await this.put(n,o,t),yield n}get(e,t){return Promise.reject(new Error(".get is not implemented"))}async*getMany(e,t){for await(let n of e)yield{cid:n,block:await this.get(n,t)}}delete(e,t){return Promise.reject(new Error(".delete is not implemented"))}async*deleteMany(e,t){for await(let n of e)await this.delete(n,t),yield n}async*getAll(e){throw new Error(".getAll is not implemented")}};var qr={};ge(qr,{abortedError:()=>sb,closeFailedError:()=>rb,deleteFailedError:()=>pu,getFailedError:()=>nb,hasFailedError:()=>ob,notFoundError:()=>Br,openFailedError:()=>tb,putFailedError:()=>du});var Zt=st(sn(),1);function tb(r){return r=r??new Error("Open failed"),(0,Zt.default)(r,"ERR_OPEN_FAILED")}function rb(r){return r=r??new Error("Close failed"),(0,Zt.default)(r,"ERR_CLOSE_FAILED")}function du(r){return r=r??new Error("Put failed"),(0,Zt.default)(r,"ERR_PUT_FAILED")}function nb(r){return r=r??new Error("Get failed"),(0,Zt.default)(r,"ERR_GET_FAILED")}function pu(r){return r=r??new Error("Delete failed"),(0,Zt.default)(r,"ERR_DELETE_FAILED")}function ob(r){return r=r??new Error("Has failed"),(0,Zt.default)(r,"ERR_HAS_FAILED")}function Br(r){return r=r??new Error("Not Found"),(0,Zt.default)(r,"ERR_NOT_FOUND")}function sb(r){return r=r??new Error("Aborted"),(0,Zt.default)(r,"ERR_ABORTED")}var gp=0,Vi=class extends It{put(e){return e}get(e){if(e.code===gp)return e.multihash.digest;throw Br()}has(e){return e.code===gp}delete(){}*getAll(){}};function ib(r){return r[Symbol.asyncIterator]!=null}function ab(r,e){if(ib(r))return async function*(){for await(let a of r)await e(a)&&(yield a)}();let t=zr(r),{value:n,done:o}=t.next();if(o===!0)return function*(){}();let s=e(n);if(typeof s.then=="function")return async function*(){await s&&(yield n);for await(let a of t)await e(a)&&(yield a)}();let i=e;return function*(){s===!0&&(yield n);for(let a of t)i(a)&&(yield a)}()}var ot=ab;var cb=Ke("blockstore:core:tiered"),Co=class extends It{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 du(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){cb.error(o)}throw Br()}async has(e,t){for(let n of this.stores)if(await n.has(e,t))return!0;return!1}async delete(e,t){try{await Promise.all(this.stores.map(async n=>{await n.delete(e,t)}))}catch(n){throw pu(n)}}async*putMany(e,t={}){let n,o=this.stores.map(s=>{let i=Nt({objectMode:!0});return Ct(s.putMany(i,t)).catch(a=>{n=a}),i});try{for await(let s of e){if(n!=null)throw n;o.forEach(i=>i.push(s)),yield s.cid}}finally{o.forEach(s=>s.end())}}async*deleteMany(e,t={}){let n,o=this.stores.map(s=>{let i=Nt({objectMode:!0});return Ct(s.deleteMany(i,t)).catch(a=>{n=a}),i});try{for await(let s of e){if(n!=null)throw n;o.forEach(i=>i.push(s)),yield s}}finally{o.forEach(s=>s.end())}}async*getAll(e){let t=new Set;yield*ot(ar(...this.stores.map(n=>n.getAll(e))),n=>{let o=n.cid.toString();return t.has(o)?!1:(t.add(o),!0)})}};function ub(r){return typeof r.retrieve=="function"}function lb(r){return typeof r.announce=="function"}var Fi=class{child;blockRetrievers;blockAnnouncers;hashers;started;log;constructor(e){this.log=e.logger.forComponent("helia:networked-storage"),this.child=new Co([new Vi,e.blockstore]),this.blockRetrievers=(e.blockBrokers??[]).filter(ub),this.blockAnnouncers=(e.blockBrokers??[]).filter(lb),this.hashers=e.hashers??{},this.started=!1}isStarted(){return this.started}async start(){await tr(this.child,...new Set([...this.blockRetrievers,...this.blockAnnouncers])),this.started=!0}async stop(){await rr(this.child,...new Set([...this.blockRetrievers,...this.blockAnnouncers])),this.started=!1}unwrap(){return this.child}async put(e,t,n={}){return await this.child.has(e)?(n.onProgress?.(new ee("blocks:put:duplicate",e)),e):(n.onProgress?.(new ee("blocks:put:providers:notify",e)),this.blockAnnouncers.forEach(o=>{o.announce(e,t,n)}),n.onProgress?.(new ee("blocks:put:blockstore:put",e)),this.child.put(e,t,n))}async*putMany(e,t={}){let n=ot(e,async({cid:s})=>{let i=await this.child.has(s);return i&&t.onProgress?.(new ee("blocks:put-many:duplicate",s)),!i}),o=qi(n,({cid:s,block:i})=>{t.onProgress?.(new ee("blocks:put-many:providers:notify",s)),this.blockAnnouncers.forEach(a=>{a.announce(s,i,t)})});t.onProgress?.(new ee("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 ee("blocks:get:providers:get",e));let n=await wp(e,this.blockRetrievers,this.hashers[e.multihash.code],{...t,log:this.log});return t.onProgress?.(new ee("blocks:get:blockstore:put",e)),await this.child.put(e,n,t),t.onProgress?.(new ee("blocks:get:providers:notify",e)),this.blockAnnouncers.forEach(o=>{o.announce(e,n,t)}),n}return t.onProgress?.(new ee("blocks:get:blockstore:get",e)),this.child.get(e,t)}async*getMany(e,t={}){t.onProgress?.(new ee("blocks:get-many:blockstore:get-many")),yield*this.child.getMany(qi(e,async n=>{if(t.offline!==!0&&!await this.child.has(n)){t.onProgress?.(new ee("blocks:get-many:providers:get",n));let o=await wp(n,this.blockRetrievers,this.hashers[n.multihash.code],{...t,log:this.log});t.onProgress?.(new ee("blocks:get-many:blockstore:put",n)),await this.child.put(n,o,t),t.onProgress?.(new ee("blocks:get-many:providers:notify",n)),this.blockAnnouncers.forEach(s=>{s.announce(n,o,t)})}}))}async delete(e,t={}){t.onProgress?.(new ee("blocks:delete:blockstore:delete",e)),await this.child.delete(e,t)}async*deleteMany(e,t={}){t.onProgress?.(new ee("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 ee("blocks:get-all:blockstore:get-many")),yield*this.child.getAll(e)}},fb=(r,e)=>{if(e==null)throw new N(`No hasher configured for multihash code 0x${r.multihash.code.toString(16)}, please configure one. You can look up which hash this is at https://github.com/multiformats/multicodec/blob/master/table.csv`,"ERR_UNKNOWN_HASH_ALG");return async t=>{let n=await e.digest(t);if(!se(n.digest,r.multihash.digest))throw new N("Hash of downloaded block did not match multihash from passed CID","ERR_HASH_MISMATCH")}};async function wp(r,e,t,n){let o=fb(r,t),s=new AbortController,i=Sr([s.signal,n.signal]);try{return await Promise.any(e.map(async a=>{try{let c=!1,f=await a.retrieve(r,{...n,signal:i,validateFn:async u=>{await o(u),c=!0}});return c||await o(f),f}catch(c){throw n.log.error("could not retrieve verified block for %c",r,c),c}}))}finally{i.clear()}}var Mi=class{blockstore;datastore;pins;logger;routing;dagWalkers;hashers;dns;log;constructor(e){this.logger=e.logger??Yu(),this.log=this.logger.forComponent("helia"),this.hashers=yp(e.hashers),this.dagWalkers=dp(e.dagWalkers),this.dns=e.dns??zd();let t={blockstore:e.blockstore,datastore:e.datastore,hashers:this.hashers,dagWalkers:this.dagWalkers,logger:this.logger,blockBrokers:[],dns:this.dns,...e.components??{}};t.blockBrokers=e.blockBrokers.map(o=>o(t));let n=new Fi(t);this.pins=new Li(e.datastore,n,this.dagWalkers),this.blockstore=new Di(n,this.pins,{holdGcLock:e.holdGcLock??!0}),this.datastore=e.datastore,this.routing=new Ui(t,{routers:(e.routers??[]).flatMap(o=>{let s=[o];return o[Gn]!=null&&s.push(o[Gn]),o[jn]!=null&&s.push(o[jn]),s})})}async start(){await mp(this.datastore),await tr(this.blockstore,this.datastore,this.routing)}async stop(){await rr(this.blockstore,this.datastore,this.routing)}async gc(e={}){let t=await this.blockstore.lock.writeLock();try{let n=this,o=this.blockstore.unwrap();this.log("gc start"),await Ct(o.deleteMany(async function*(){for await(let{cid:s}of o.getAll())try{if(await n.pins.isPinned(s,e))continue;yield s,e.onProgress?.(new ee("helia:gc:deleted",s))}catch(i){n.log.error("Error during gc",i),e.onProgress?.(new ee("helia:gc:error",i))}}()))}finally{t()}this.log("gc finished")}};var No=class extends It{data;constructor(){super(),this.data=new Map}put(e,t){return this.data.set(Be.encode(e.multihash.bytes),t),e}get(e){let t=this.data.get(Be.encode(e.multihash.bytes));if(t==null)throw Br();return t}has(e){return this.data.has(Be.encode(e.multihash.bytes))}async delete(e){this.data.delete(Be.encode(e.multihash.bytes))}async*getAll(){for(let[e,t]of this.data.entries())yield{cid:te.createV1(Ho,wt(Be.decode(e))),block:t}}};var r6={...qr};var bp=st(sn(),1);function Hi(r){return r=r??new Error("Not Found"),(0,bp.default)(r,"ERR_NOT_FOUND")}var xp="SHARDING";function db(r){return r[Symbol.asyncIterator]!=null}function pb(r){if(db(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 mu=pb;function mb(r){return r[Symbol.asyncIterator]!=null}function yb(r,e){return mb(r)?async function*(){yield*(await mu(r)).sort(e)}():function*(){yield*mu(r).sort(e)}()}var $i=yb;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 Ct(this.putMany(e,n)),e=[],await Ct(this.deleteMany(t,n)),t=[]}}}async*_all(e,t){throw new Error("._all is not implemented")}async*_allKeys(e,t){throw new Error("._allKeys is not implemented")}query(e,t){let n=this._all(e,t);if(e.prefix!=null){let o=e.prefix;n=ot(n,s=>s.key.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,s)=>ot(o,s),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,s)=>$i(o,s),n)),e.offset!=null){let o=0,s=e.offset;n=ot(n,()=>o++>=s)}return e.limit!=null&&(n=Go(n,e.limit)),n}queryKeys(e,t){let n=this._allKeys(e,t);if(e.prefix!=null){let o=e.prefix;n=ot(n,s=>s.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,s)=>ot(o,s),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,s)=>$i(o,s),n)),e.offset!=null){let o=e.offset,s=0;n=ot(n,()=>s++>=o)}return e.limit!=null&&(n=Go(n,e.limit)),n}};var Uo=class extends Jt{data;constructor(){super(),this.data=new Map}put(e,t){return this.data.set(e.toString(),t),e}get(e){let t=this.data.get(e.toString());if(t==null)throw Hi();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 C6=new Se(xp);var K6=Ke("datastore:core:tiered");async function bb(r={}){let e=r.datastore??new Uo,t=r.blockstore??new No,n=new Mi({...r,datastore:e,blockstore:t,blockBrokers:r.blockBrokers??[Ua()],routers:r.routers??[Gc("https://delegated-ipfs.dev")]});return r.start!==!1&&await n.start(),n}return Dp(xb);})();
9
9
  /*! Bundled license information:
10
10
 
11
11
  pvtsutils/build/index.js: