@helia/http 1.0.3-9ac5909 → 1.0.3-9c8a2c0

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 Np=Object.create;var Po=Object.defineProperty;var Lp=Object.getOwnPropertyDescriptor;var Dp=Object.getOwnPropertyNames;var Up=Object.getPrototypeOf,Pp=Object.prototype.hasOwnProperty;var Xt=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),ge=(r,e)=>{for(var t in e)Po(r,t,{get:e[t],enumerable:!0})},Bu=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Dp(e))!Pp.call(r,o)&&o!==t&&Po(r,o,{get:()=>e[o],enumerable:!(n=Lp(e,o))||n.enumerable});return r};var st=(r,e,t)=>(t=r!=null?Np(Up(r)):{},Bu(e||!r||!r.__esModule?Po(t,"default",{value:r,enumerable:!0}):t,r)),Op=r=>Bu(Po({},"__esModule",{value:!0}),r);var zu=Xt((Zb,qu)=>{var Zr=1e3,Jr=Zr*60,Xr=Jr*60,Ir=Xr*24,Bm=Ir*7,km=Ir*365.25;qu.exports=function(r,e){e=e||{};var t=typeof r;if(t==="string"&&r.length>0)return Sm(r);if(t==="number"&&isFinite(r))return e.long?Rm(r):Im(r);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(r))};function Sm(r){if(r=String(r),!(r.length>100)){var e=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(r);if(e){var t=parseFloat(e[1]),n=(e[2]||"ms").toLowerCase();switch(n){case"years":case"year":case"yrs":case"yr":case"y":return t*km;case"weeks":case"week":case"w":return t*Bm;case"days":case"day":case"d":return t*Ir;case"hours":case"hour":case"hrs":case"hr":case"h":return t*Xr;case"minutes":case"minute":case"mins":case"min":case"m":return t*Jr;case"seconds":case"second":case"secs":case"sec":case"s":return t*Zr;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return t;default:return}}}}function Im(r){var e=Math.abs(r);return e>=Ir?Math.round(r/Ir)+"d":e>=Xr?Math.round(r/Xr)+"h":e>=Jr?Math.round(r/Jr)+"m":e>=Zr?Math.round(r/Zr)+"s":r+"ms"}function Rm(r){var e=Math.abs(r);return e>=Ir?Fo(r,e,Ir,"day"):e>=Xr?Fo(r,e,Xr,"hour"):e>=Jr?Fo(r,e,Jr,"minute"):e>=Zr?Fo(r,e,Zr,"second"):r+" ms"}function Fo(r,e,t,n){var o=e>=t*1.5;return Math.round(r/t)+" "+n+(o?"s":"")}});var ju=Xt((Jb,Gu)=>{function _m(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 D=0;m[0]=m[0].replace(/%([a-zA-Z%])/g,(_,L)=>{if(_==="%%")return"%";D++;let w=t.formatters[L];if(typeof w=="function"){let C=m[D];_=w.call(g,C),m.splice(D,1),D--}return _}),t.formatArgs.call(g,m),(g.log||t.log).apply(g,m)}return d.namespace=u,d.useColors=t.useColors(),d.color=t.selectColor(u),d.extend=n,d.destroy=t.destroy,Object.defineProperty(d,"enabled",{enumerable:!0,configurable:!1,get:()=>p!==null?p:(E!==t.namespaces&&(E=t.namespaces,y=t.enabled(u)),y),set:m=>{p=m}}),typeof t.init=="function"&&t.init(d),d}function n(u,l){let p=t(this.namespace+(typeof l>"u"?":":l)+u);return p.log=this.log,p}function o(u){t.save(u),t.namespaces=u,t.names=[],t.skips=[];let l,p=(typeof u=="string"?u:"").split(/[\s,]+/),E=p.length;for(l=0;l<E;l++)p[l]&&(u=p[l].replace(/\*/g,".*?"),u[0]==="-"?t.skips.push(new RegExp("^"+u.slice(1)+"$")):t.names.push(new RegExp("^"+u+"$")))}function s(){let u=[...t.names.map(a),...t.skips.map(a).map(l=>"-"+l)].join(",");return t.enable(""),u}function i(u){if(u[u.length-1]==="*")return!0;let l,p;for(l=0,p=t.skips.length;l<p;l++)if(t.skips[l].test(u))return!1;for(l=0,p=t.names.length;l<p;l++)if(t.names[l].test(u))return!0;return!1}function a(u){return u.toString().substring(2,u.toString().length-2).replace(/\.\*\?$/,"*")}function c(u){return u instanceof Error?u.stack||u.message:u}function f(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return t.enable(t.load()),t}Gu.exports=_m});var Wu=Xt((He,Mo)=>{He.formatArgs=Cm;He.save=Nm;He.load=Lm;He.useColors=Tm;He.storage=Dm();He.destroy=(()=>{let r=!1;return()=>{r||(r=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})();He.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function Tm(){return typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs)?!0:typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)?!1:typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function Cm(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+Mo.exports.humanize(this.diff),!this.useColors)return;let e="color: "+this.color;r.splice(1,0,e,"color: inherit");let t=0,n=0;r[0].replace(/%[a-zA-Z%]/g,o=>{o!=="%%"&&(t++,o==="%c"&&(n=t))}),r.splice(n,0,e)}He.log=console.debug||console.log||(()=>{});function Nm(r){try{r?He.storage.setItem("debug",r):He.storage.removeItem("debug")}catch{}}function Lm(){let r;try{r=He.storage.getItem("debug")}catch{}return!r&&typeof process<"u"&&"env"in process&&(r=process.env.DEBUG),r}function Dm(){try{return localStorage}catch{}}Mo.exports=ju()(He);var{formatters:Um}=Mo.exports;Um.j=function(r){try{return JSON.stringify(r)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}});var on=Xt((g1,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 y0(r,e,t){if(!r||typeof r=="string")throw new TypeError("Please pass an Error to err-code");t||(t={}),typeof e=="object"&&(t=e,e=""),e&&(t.code=e);try{return 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=y0});var uf=Xt(Sn=>{"use strict";var og="[object ArrayBuffer]",Ft=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===og}static toArrayBuffer(e){return this.isArrayBuffer(e)?e:e.byteLength===e.buffer.byteLength||e.byteOffset===0&&e.byteLength===e.buffer.byteLength?e.buffer:this.toUint8Array(e.buffer).slice(e.byteOffset,e.byteOffset+e.byteLength).buffer}static toUint8Array(e){return this.toView(e,Uint8Array)}static toView(e,t){if(e.constructor===t)return e;if(this.isArrayBuffer(e))return new t(e);if(this.isArrayBufferView(e))return new t(e.buffer,e.byteOffset,e.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(e){return this.isArrayBufferView(e)||this.isArrayBuffer(e)}static isArrayBufferView(e){return ArrayBuffer.isView(e)||e&&this.isArrayBuffer(e.buffer)}static isEqual(e,t){let n=r.toUint8Array(e),o=r.toUint8Array(t);if(n.length!==o.byteLength)return!1;for(let s=0;s<n.length;s++)if(n[s]!==o[s])return!1;return!0}static concat(...e){let t;Array.isArray(e[0])&&!(e[1]instanceof Function)||Array.isArray(e[0])&&e[1]instanceof Function?t=e[0]:e[e.length-1]instanceof Function?t=e.slice(0,e.length-1):t=e;let n=0;for(let i of t)n+=i.byteLength;let o=new Uint8Array(n),s=0;for(let i of t){let a=this.toUint8Array(i);o.set(a,s),s+=a.length}return e[e.length-1]instanceof Function?this.toView(o,e[e.length-1]):o.buffer}},mc="string",sg=/^[0-9a-f]+$/i,ig=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,ag=/^[a-zA-Z0-9-_]+$/,ys=class{static fromString(e){let t=unescape(encodeURIComponent(e)),n=new Uint8Array(t.length);for(let o=0;o<t.length;o++)n[o]=t.charCodeAt(o);return n.buffer}static toString(e){let t=Ft.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return decodeURIComponent(escape(n))}},Qe=class{static toString(e,t=!1){let n=Ft.toArrayBuffer(e),o=new DataView(n),s="";for(let i=0;i<n.byteLength;i+=2){let a=o.getUint16(i,t);s+=String.fromCharCode(a)}return s}static fromString(e,t=!1){let n=new ArrayBuffer(e.length*2),o=new DataView(n);for(let s=0;s<e.length;s++)o.setUint16(s*2,e.charCodeAt(s),t);return n}},gs=class r{static isHex(e){return typeof e===mc&&sg.test(e)}static isBase64(e){return typeof e===mc&&ig.test(e)}static isBase64Url(e){return typeof e===mc&&ag.test(e)}static ToString(e,t="utf8"){let n=Ft.toUint8Array(e);switch(t.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Qe.toString(n,!0);case"utf16":case"utf16be":return Qe.toString(n);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromString(e,t="utf8"){if(!e)return new ArrayBuffer(0);switch(t.toLowerCase()){case"utf8":return this.FromUtf8String(e);case"binary":return this.FromBinary(e);case"hex":return this.FromHex(e);case"base64":return this.FromBase64(e);case"base64url":return this.FromBase64Url(e);case"utf16le":return Qe.fromString(e,!0);case"utf16":case"utf16be":return Qe.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=Ft.toUint8Array(e);if(typeof btoa<"u"){let n=this.ToString(t,"binary");return btoa(n)}else return Buffer.from(t).toString("base64")}static FromBase64(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64(t))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(t)):new Uint8Array(Buffer.from(t,"base64")).buffer}static FromBase64Url(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64Url(t))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(t.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(e){return this.ToBase64(e).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.FromBinary(e);case"utf8":return ys.fromString(e);case"utf16":case"utf16be":return Qe.fromString(e);case"utf16le":case"usc2":return Qe.fromString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.ToBinary(e);case"utf8":return ys.toString(e);case"utf16":case"utf16be":return Qe.toString(e);case"utf16le":case"usc2":return Qe.toString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromBinary(e){let t=e.length,n=new Uint8Array(t);for(let o=0;o<t;o++)n[o]=e.charCodeAt(o);return n.buffer}static ToBinary(e){let t=Ft.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return n}static ToHex(e){let t=Ft.toUint8Array(e),n="",o=t.length;for(let s=0;s<o;s++){let i=t[s];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isHex(t))throw new TypeError("Argument 'hexString' is not HEX encoded");t.length%2&&(t=`0${t}`);let n=new Uint8Array(t.length/2);for(let o=0;o<t.length;o=o+2){let s=t.slice(o,o+2);n[o/2]=parseInt(s,16)}return n.buffer}static ToUtf16String(e,t=!1){return Qe.toString(e,t)}static FromUtf16String(e,t=!1){return Qe.fromString(e,t)}static Base64Padding(e){let t=4-e.length%4;if(t<4)for(let n=0;n<t;n++)e+="=";return e}static formatString(e){return e?.replace(/[\n\r\t ]/g,"")||""}};gs.DEFAULT_UTF8_ENCODING="utf8";function cg(r,...e){let t=arguments[0];for(let n=1;n<arguments.length;n++){let o=arguments[n];for(let s in o)t[s]=o[s]}return t}function ug(...r){let e=r.map(o=>o.byteLength).reduce((o,s)=>o+s),t=new Uint8Array(e),n=0;return r.map(o=>new Uint8Array(o)).forEach(o=>{for(let s of o)t[n++]=s}),t.buffer}function lg(r,e){if(!(r&&e)||r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let o=0;o<r.byteLength;o++)if(t[o]!==n[o])return!1;return!0}Sn.BufferSourceConverter=Ft;Sn.Convert=gs;Sn.assign=cg;Sn.combine=ug;Sn.isEqual=lg});var Cc=Xt((PA,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=D(0,1,2,3,0,4),d.fromInt64LE=D(3,2,1,0,4,0),d.fromString=function(T){var C,O=new d,T=(T+="").replace(/^\s*[+\-]?\d+/,function($){var $=+$,J=1970+($-1970)%400;return O.year=$-J,J}).replace(/(?:Z|([+\-]\d{2}):?(\d{2}))$/,function(F,$,J){return $<0&&(J*=-1),C=6e4*(60*+$+ +J),""}).replace(/\.\d+$/,function(F){return O.nano=+(F+c).substr(1,9),""}).split(/\D+/);if(1<T.length?T[1]--:T[1]=0,O.time=C=Date.UTC.apply(Date,T)-(C||0),isNaN(C))throw new TypeError("Invalid Date");return m(O)},d.fromTimeT=function(w){return I(w,0)},u.year=0,u.time=0,u.nano=0,u.addNano=function(w){return this.nano+=+w||0,this},u.getNano=function(){var w=m(this);return(w.time%1e3*a+ +w.nano+1e9)%1e9},u.getTimeT=function(){var C=m(this),w=Math.floor(C.time/1e3),C=C.year;return C&&(w+=C*t*r/e),w},u.getYear=function(){return this.toDate().getUTCFullYear()+this.year},u.toDate=function(){return g(m(this).time)},u.toJSON=function(){return this.toString().replace(/0{1,6}Z$/,"Z")},u.toString=function(w){var C=this,O=C.toDate(),T={H:function(){return _(O.getUTCHours())},L:function(){return L(O.getUTCMilliseconds(),3)},M:function(){return _(O.getUTCMinutes())},N:function(){return L(C.getNano(),9)},S:function(){return _(O.getUTCSeconds())},Y:function(){var F=C.getYear();return 999999<F?"+"+F:9999<F?"+"+L(F,6):0<=F?L(F,4):-999999<=F?"-"+L(-F,6):F},a:function(){return E[O.getUTCDay()]},b:function(){return p[O.getUTCMonth()]},d:function(){return _(O.getUTCDate())},e:function(){return function(F){return(9<F?"":" ")+(0|F)}(O.getUTCDate())},m:function(){return _(O.getUTCMonth()+1)}};return function F($){return $.replace(/%./g,function(J){var k=J[1],x=y[k],k=T[k];return x?F(x):k?k():J})}(w||l)},u.writeInt64BE=v(0,1,2,3,0,4),u.writeInt64LE=v(3,2,1,0,4,0),"%Y-%m-%dT%H:%M:%S.%NZ"),p=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],E=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],y={"%":"%",F:"%Y-%m-%d",n:`
3
- `,R:"%H:%M",T:"%H:%M:%S",t:" ",X:"%T",Z:"GMT",z:"+0000"};return d;function d(w,C,O){var T=this;if(!(T instanceof d))return new d(w,C,O);T.time=+w||0,T.nano=+C||0,T.year=+O||0,m(T)}function m(w){var C,O,T,F=w.year,$=w.time,J=w.nano,x=((J<0||a<=J)&&(J-=(O=Math.floor(J/a))*a,$+=O,O=1),F%e);return($<-s||s<$||x)&&((C=f($/o))&&(F+=C*e,$-=C*o),(T=g($)).setUTCFullYear(x+T.getUTCFullYear()),T=($=+T)+(C=f((F-=x)/e))*o,C&&-s<=T&&T<=s&&(F-=C*e,$=T),O=1),O&&(w.year=F,w.time=$,w.nano=J),w}function g(w){var C=new Date(0);return C.setTime(w),C}function I(F,T){F=+F||0;var O=f((T=(T|0)*i)/n)+f(F/n),T=T%n+F%n,F=f(T/n);return F&&(O+=F,T-=F*n),new d(1e3*T,0,O*e)}function v(w,C,O,T,F,$){return function(x,k){var B=m(this);x=x||new Array(8),S(x,k|=0);var b=Math.floor(B.time/1e3),B=B.year*(t*r/e),H=f(B/i)+f(b/i),B=B%i+b%i,b=Math.floor(B/i);return b&&(H+=b,B-=b*i),J(x,k+F,H),J(x,k+$,B),x};function J(x,k,H){x[k+w]=H>>24&255,x[k+C]=H>>16&255,x[k+O]=H>>8&255,x[k+T]=255&H}}function D(w,C,O,T,F,$){return function(x,k){S(x,k|=0);var H=J(x,k+F);return I(J(x,k+$),H)};function J(x,k){return 16777216*x[k+w]+(x[k+C]<<16|x[k+O]<<8|x[k+T])}}function S(w,C){if(w=w&&w.length,w==null)throw new TypeError("Invalid Buffer");if(w<C+8)throw new RangeError("Out of range")}function _(w){return(9<w?"":"0")+(0|w)}function L(w,C){return(c+(0|w)).substr(-C)}}()});var Ld=Xt((w8,Hc)=>{"use strict";var Rw=Object.prototype.hasOwnProperty,Oe="~";function Io(){}Object.create&&(Io.prototype=Object.create(null),new Io().__proto__||(Oe=!1));function _w(r,e,t){this.fn=r,this.context=e,this.once=t||!1}function Nd(r,e,t,n,o){if(typeof t!="function")throw new TypeError("The listener must be a function");var s=new _w(t,n||r,o),i=Oe?Oe+e:e;return r._events[i]?r._events[i].fn?r._events[i]=[r._events[i],s]:r._events[i].push(s):(r._events[i]=s,r._eventsCount++),r}function Ai(r,e){--r._eventsCount===0?r._events=new Io:delete r._events[e]}function Ne(){this._events=new Io,this._eventsCount=0}Ne.prototype.eventNames=function(){var e=[],t,n;if(this._eventsCount===0)return e;for(n in t=this._events)Rw.call(t,n)&&e.push(Oe?n.slice(1):n);return Object.getOwnPropertySymbols?e.concat(Object.getOwnPropertySymbols(t)):e};Ne.prototype.listeners=function(e){var t=Oe?Oe+e:e,n=this._events[t];if(!n)return[];if(n.fn)return[n.fn];for(var o=0,s=n.length,i=new Array(s);o<s;o++)i[o]=n[o].fn;return i};Ne.prototype.listenerCount=function(e){var t=Oe?Oe+e:e,n=this._events[t];return n?n.fn?1:n.length:0};Ne.prototype.emit=function(e,t,n,o,s,i){var a=Oe?Oe+e:e;if(!this._events[a])return!1;var c=this._events[a],f=arguments.length,u,l;if(c.fn){switch(c.once&&this.removeListener(e,c.fn,void 0,!0),f){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,t),!0;case 3:return c.fn.call(c.context,t,n),!0;case 4:return c.fn.call(c.context,t,n,o),!0;case 5:return c.fn.call(c.context,t,n,o,s),!0;case 6:return c.fn.call(c.context,t,n,o,s,i),!0}for(l=1,u=new Array(f-1);l<f;l++)u[l-1]=arguments[l];c.fn.apply(c.context,u)}else{var p=c.length,E;for(l=0;l<p;l++)switch(c[l].once&&this.removeListener(e,c[l].fn,void 0,!0),f){case 1:c[l].fn.call(c[l].context);break;case 2:c[l].fn.call(c[l].context,t);break;case 3:c[l].fn.call(c[l].context,t,n);break;case 4:c[l].fn.call(c[l].context,t,n,o);break;default:if(!u)for(E=1,u=new Array(f-1);E<f;E++)u[E-1]=arguments[E];c[l].fn.apply(c[l].context,u)}}return!0};Ne.prototype.on=function(e,t,n){return Nd(this,e,t,n,!1)};Ne.prototype.once=function(e,t,n){return Nd(this,e,t,n,!0)};Ne.prototype.removeListener=function(e,t,n,o){var s=Oe?Oe+e:e;if(!this._events[s])return this;if(!t)return Ai(this,s),this;var i=this._events[s];if(i.fn)i.fn===t&&(!o||i.once)&&(!n||i.context===n)&&Ai(this,s);else{for(var a=0,c=[],f=i.length;a<f;a++)(i[a].fn!==t||o&&!i[a].once||n&&i[a].context!==n)&&c.push(i[a]);c.length?this._events[s]=c.length===1?c[0]:c:Ai(this,s)}return this};Ne.prototype.removeAllListeners=function(e){var t;return e?(t=Oe?Oe+e:e,this._events[t]&&Ai(this,t)):(this._events=new Io,this._eventsCount=0),this};Ne.prototype.off=Ne.prototype.removeListener;Ne.prototype.addListener=Ne.prototype.on;Ne.prefixed=Oe;Ne.EventEmitter=Ne;typeof Hc<"u"&&(Hc.exports=Ne)});var qd=Xt((xk,Kd)=>{Kd.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 Vp(r){let[e,t]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>e.next(),push:o=>{n.push(o)},next:()=>n.length>0?{done:!1,value:n.shift()}:e.next(),[t](){return this}}}var qr=Vp;function Fp(r){return r[Symbol.asyncIterator]!=null}function ku(r){return r?.then!=null}function Mp(r,e){if(Fp(r))return async function*(){for await(let a of r){let c=e(a);ku(c)&&await c,yield a}}();let t=qr(r),{value:n,done:o}=t.next();if(o===!0)return function*(){}();if(typeof e(n)?.then=="function")return async function*(){yield n;for await(let a of t){let c=e(a);ku(c)&&await c,yield a}}();let i=e;return function*(){yield n;for(let a of t)i(a),yield a}()}var Gi=Mp;var Ji={};ge(Ji,{base32:()=>Be,base32hex:()=>Wp,base32hexpad:()=>Zp,base32hexpadupper:()=>Jp,base32hexupper:()=>Yp,base32pad:()=>Gp,base32padupper:()=>jp,base32upper:()=>Nu,base32z:()=>Xp});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 Rt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Iu(r){return new TextEncoder().encode(r)}function Ru(r){return new TextDecoder().decode(r)}function Hp(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(t[i]!==255)throw new TypeError(s+" is ambiguous");t[i]=o}var a=r.length,c=r.charAt(0),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(y){if(y instanceof Uint8Array||(ArrayBuffer.isView(y)?y=new Uint8Array(y.buffer,y.byteOffset,y.byteLength):Array.isArray(y)&&(y=Uint8Array.from(y))),!(y instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(y.length===0)return"";for(var d=0,m=0,g=0,I=y.length;g!==I&&y[g]===0;)g++,d++;for(var v=(I-g)*u+1>>>0,D=new Uint8Array(v);g!==I;){for(var S=y[g],_=0,L=v-1;(S!==0||_<m)&&L!==-1;L--,_++)S+=256*D[L]>>>0,D[L]=S%a>>>0,S=S/a>>>0;if(S!==0)throw new Error("Non-zero carry");m=_,g++}for(var w=v-m;w!==v&&D[w]===0;)w++;for(var C=c.repeat(d);w<v;++w)C+=r.charAt(D[w]);return C}function p(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var d=0;if(y[d]!==" "){for(var m=0,g=0;y[d]===c;)m++,d++;for(var I=(y.length-d)*f+1>>>0,v=new Uint8Array(I);y[d];){var D=t[y.charCodeAt(d)];if(D===255)return;for(var S=0,_=I-1;(D!==0||S<g)&&_!==-1;_--,S++)D+=a*v[_]>>>0,v[_]=D%256>>>0,D=D/256>>>0;if(D!==0)throw new Error("Non-zero carry");g=S,d++}if(y[d]!==" "){for(var L=I-g;L!==I&&v[L]===0;)L++;for(var w=new Uint8Array(m+(I-L)),C=m;L!==I;)w[C++]=v[L++];return w}}}function E(y){var d=p(y);if(d)return d;throw new Error(`Non-${e} character`)}return{encode:l,decodeUnsafe:p,decode:E}}var $p=Hp,Kp=$p,Tu=Kp;var ji=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},Wi=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){if(this.name=e,this.prefix=t,t.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=t.codePointAt(0),this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return Cu(this,e)}},Yi=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 Yi({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var Zi=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,o){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=o,this.encoder=new ji(e,t,n),this.decoder=new Wi(e,t,o)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function zr({name:r,prefix:e,encode:t,decode:n}){return new Zi(r,e,t,n)}function Qt({name:r,prefix:e,alphabet:t}){let{encode:n,decode:o}=Tu(t,r);return zr({prefix:e,name:r,encode:n,decode:s=>Rt(o(s))})}function qp(r,e,t,n){let o={};for(let u=0;u<e.length;++u)o[e[u]]=u;let s=r.length;for(;r[s-1]==="=";)--s;let i=new Uint8Array(s*t/8|0),a=0,c=0,f=0;for(let u=0;u<s;++u){let l=o[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<t|l,a+=t,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=t||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function zp(r,e,t){let n=e[e.length-1]==="=",o=(1<<t)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,s+=e[o&a>>i];if(i!==0&&(s+=e[o&a<<t-i]),n)for(;s.length*t&7;)s+="=";return s}function le({name:r,prefix:e,bitsPerChar:t,alphabet:n}){return zr({prefix:e,name:r,encode(o){return zp(o,n,t)},decode(o){return qp(o,n,t,r)}})}var Be=le({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Nu=le({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Gp=le({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),jp=le({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Wp=le({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Yp=le({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Zp=le({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Jp=le({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Xp=le({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Xi={};ge(Xi,{base58btc:()=>he,base58flickr:()=>Qp});var he=Qt({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Qp=Qt({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var em=Uu,Lu=128,tm=127,rm=~tm,nm=Math.pow(2,31);function Uu(r,e,t){e=e||[],t=t||0;for(var n=t;r>=nm;)e[t++]=r&255|Lu,r/=128;for(;r&rm;)e[t++]=r&255|Lu,r>>>=7;return e[t]=r|0,Uu.bytes=t-n+1,e}var om=Qi,sm=128,Du=127;function Qi(r,n){var t=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw Qi.bytes=0,new RangeError("Could not decode varint");i=r[s++],t+=o<28?(i&Du)<<o:(i&Du)*Math.pow(2,o),o+=7}while(i>=sm);return Qi.bytes=s-n,t}var im=Math.pow(2,7),am=Math.pow(2,14),cm=Math.pow(2,21),um=Math.pow(2,28),lm=Math.pow(2,35),fm=Math.pow(2,42),hm=Math.pow(2,49),dm=Math.pow(2,56),pm=Math.pow(2,63),mm=function(r){return r<im?1:r<am?2:r<cm?3:r<um?4:r<lm?5:r<fm?6:r<hm?7:r<dm?8:r<pm?9:10},ym={encode:em,decode:om,encodingLength:mm},gm=ym,qn=gm;function zn(r,e=0){return[qn.decode(r,e),qn.decode.bytes]}function Gr(r,e,t=0){return qn.encode(r,e,t),e}function jr(r){return qn.encodingLength(r)}function yt(r,e){let t=e.byteLength,n=jr(r),o=n+jr(t),s=new Uint8Array(o+t);return Gr(r,s,0),Gr(t,s,n),s.set(e,o),new Wr(r,t,e,s)}function gt(r){let e=Rt(r),[t,n]=zn(e),[o,s]=zn(e.subarray(n)),i=e.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Wr(t,o,i,e)}function 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 Wr=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 bm(t,ea(r),e??he.encoder);default:return xm(t,ea(r),e??Be.encoder)}}var Vu=new WeakMap;function ea(r){let e=Vu.get(r);if(e==null){let t=new Map;return Vu.set(r,t),t}return e}var re=class r{code;version;multihash;bytes;"/";constructor(e,t,n,o){this.code=t,this.version=e,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:e,multihash:t}=this;if(e!==Gn)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==Em)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:e,digest:t}=this.multihash,n=yt(e,t);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&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[vm]===!0){let{version:n,multihash:o,code:s}=t,i=gt(o);return r.create(n,s,i)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==Gn)throw new Error(`Version 0 CID must use dag-pb (code: ${Gn}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let o=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,Gn,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,o=Rt(e.subarray(n,n+t.multihashSize));if(o.byteLength!==t.multihashSize)throw new Error("Incorrect length");let s=o.subarray(t.multihashSize-t.digestSize),i=new Wr(t.multihashCode,t.digestSize,s,o);return[t.version===0?r.createV0(i):r.createV1(t.codec,i),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[l,p]=zn(e.subarray(t));return t+=p,l},o=n(),s=Gn;if(o===18?(o=0,t=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=t,a=n(),c=n(),f=t+c,u=f-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(e,t){let[n,o]=wm(e,t),s=r.decode(o);if(s.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return ea(s).set(n,e),s}};function wm(r,e){switch(r[0]){case"Q":{let t=e??he;return[he.prefix,t.decode(`${he.prefix}${r}`)]}case he.prefix:{let t=e??he;return[he.prefix,t.decode(r)]}case Be.prefix:{let t=e??Be;return[Be.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function bm(r,e,t){let{prefix:n}=t;if(n!==he.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let o=e.get(n);if(o==null){let s=t.encode(r).slice(1);return e.set(n,s),s}else return o}function xm(r,e,t){let{prefix:n}=t,o=e.get(n);if(o==null){let s=t.encode(r);return e.set(n,s),s}else return o}var Gn=112,Em=18;function Fu(r,e,t){let n=jr(r),o=n+jr(e),s=new Uint8Array(o+t.byteLength);return Gr(r,s,0),Gr(e,s,n),s.set(t,o),s}var vm=Symbol.for("@ipld/js-cid/CID");var jn=Symbol.for("@libp2p/content-routing");var ta=Symbol.for("@libp2p/peer-id");function Mu(r){return r!=null&&!!r[ta]}var Wn=Symbol.for("@libp2p/peer-routing");var er=class r extends Error{code;type;constructor(e="The operation was aborted"){super(e),this.code=r.code,this.type=r.type}static code="ABORT_ERR";static type="aborted"},N=class extends Error{code;props;constructor(e,t,n){super(e),this.code=t,this.name=n?.name??"CodeError",this.props=n??{}}};var Yr=(r,...e)=>{try{[...e]}catch{}};var Vo=class extends EventTarget{#e=new Map;constructor(){super(),Yr(1/0,this)}listenerCount(e){let t=this.#e.get(e);return t==null?0:t.length}addEventListener(e,t,n){super.addEventListener(e,t,n);let o=this.#e.get(e);o==null&&(o=[],this.#e.set(e,o)),o.push({callback:t,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(e,t,n){super.removeEventListener(e.toString(),t??null,n);let o=this.#e.get(e);o!=null&&(o=o.filter(({callback:s})=>s!==t),this.#e.set(e,o))}dispatchEvent(e){let t=super.dispatchEvent(e),n=this.#e.get(e.type);return n==null||(n=n.filter(({once:o})=>!o),this.#e.set(e.type,n)),t}safeDispatchEvent(e,t={}){return this.dispatchEvent(new Am(e,t))}},ra=class extends Event{detail;constructor(e,t){super(e,t),this.detail=t?.detail}},Am=globalThis.CustomEvent??ra;function 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 ia={};ge(ia,{sha256:()=>we,sha512:()=>sa});function oa({name:r,code:e,encode:t}){return new na(r,e,t)}var na=class{name;code;encode;constructor(e,t,n){this.name=e,this.code=t,this.encode=n}digest(e){if(e instanceof Uint8Array){let t=this.encode(e);return t instanceof Uint8Array?yt(this.code,t):t.then(n=>yt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Ku(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var we=oa({name:"sha2-256",code:18,encode:Ku("SHA-256")}),sa=oa({name:"sha2-512",code:19,encode:Ku("SHA-512")});var $e=st(Wu(),1);var aa={};ge(aa,{base64:()=>nr,base64pad:()=>Pm,base64url:()=>Om,base64urlpad:()=>Vm});var nr=le({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Pm=le({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Om=le({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Vm=le({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});$e.default.formatters.b=r=>r==null?"undefined":he.baseEncode(r);$e.default.formatters.t=r=>r==null?"undefined":Be.baseEncode(r);$e.default.formatters.m=r=>r==null?"undefined":nr.baseEncode(r);$e.default.formatters.p=r=>r==null?"undefined":r.toString();$e.default.formatters.c=r=>r==null?"undefined":r.toString();$e.default.formatters.k=r=>r==null?"undefined":r.toString();$e.default.formatters.a=r=>r==null?"undefined":r.toString();function Fm(r){let e=()=>{};return e.enabled=!1,e.color="",e.diff=0,e.log=()=>{},e.namespace=r,e.destroy=()=>!0,e.extend=()=>e,e}function Yu(){return{forComponent(r){return Ke(r)}}}function Ke(r){let e=Fm(`${r}:trace`);return $e.default.enabled(`${r}:trace`)&&$e.default.names.map(t=>t.toString()).find(t=>t.includes(":trace"))!=null&&(e=(0,$e.default)(`${r}:trace`)),Object.assign((0,$e.default)(r),{error:(0,$e.default)(`${r}:error`),trace:e})}function se(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function it(r=0){return new Uint8Array(r)}var Mm=Math.pow(2,7),Hm=Math.pow(2,14),$m=Math.pow(2,21),ca=Math.pow(2,28),ua=Math.pow(2,35),la=Math.pow(2,42),fa=Math.pow(2,49),ne=128,_e=127;function Ve(r){if(r<Mm)return 1;if(r<Hm)return 2;if(r<$m)return 3;if(r<ca)return 4;if(r<ua)return 5;if(r<la)return 6;if(r<fa)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ha(r,e,t=0){switch(Ve(r)){case 8:e[t++]=r&255|ne,r/=128;case 7:e[t++]=r&255|ne,r/=128;case 6:e[t++]=r&255|ne,r/=128;case 5:e[t++]=r&255|ne,r/=128;case 4:e[t++]=r&255|ne,r>>>=7;case 3:e[t++]=r&255|ne,r>>>=7;case 2:e[t++]=r&255|ne,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function Km(r,e,t=0){switch(Ve(r)){case 8:e.set(t++,r&255|ne),r/=128;case 7:e.set(t++,r&255|ne),r/=128;case 6:e.set(t++,r&255|ne),r/=128;case 5:e.set(t++,r&255|ne),r/=128;case 4:e.set(t++,r&255|ne),r>>>=7;case 3:e.set(t++,r&255|ne),r>>>=7;case 2:e.set(t++,r&255|ne),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function da(r,e){let t=r[e],n=0;if(n+=t&_e,t<ne||(t=r[e+1],n+=(t&_e)<<7,t<ne)||(t=r[e+2],n+=(t&_e)<<14,t<ne)||(t=r[e+3],n+=(t&_e)<<21,t<ne)||(t=r[e+4],n+=(t&_e)*ca,t<ne)||(t=r[e+5],n+=(t&_e)*ua,t<ne)||(t=r[e+6],n+=(t&_e)*la,t<ne)||(t=r[e+7],n+=(t&_e)*fa,t<ne))return n;throw new RangeError("Could not decode varint")}function qm(r,e){let t=r.get(e),n=0;if(n+=t&_e,t<ne||(t=r.get(e+1),n+=(t&_e)<<7,t<ne)||(t=r.get(e+2),n+=(t&_e)<<14,t<ne)||(t=r.get(e+3),n+=(t&_e)<<21,t<ne)||(t=r.get(e+4),n+=(t&_e)*ca,t<ne)||(t=r.get(e+5),n+=(t&_e)*ua,t<ne)||(t=r.get(e+6),n+=(t&_e)*la,t<ne)||(t=r.get(e+7),n+=(t&_e)*fa,t<ne))return n;throw new RangeError("Could not decode varint")}function Qr(r,e,t=0){return e==null&&(e=it(Ve(r))),e instanceof Uint8Array?ha(r,e,t):Km(r,e,t)}function Rr(r,e=0){return r instanceof Uint8Array?da(r,e):qm(r,e)}var pa=new Float32Array([-0]),or=new Uint8Array(pa.buffer);function Ju(r,e,t){pa[0]=r,e[t]=or[0],e[t+1]=or[1],e[t+2]=or[2],e[t+3]=or[3]}function Xu(r,e){return or[0]=r[e],or[1]=r[e+1],or[2]=r[e+2],or[3]=r[e+3],pa[0]}var ma=new Float64Array([-0]),Te=new Uint8Array(ma.buffer);function Qu(r,e,t){ma[0]=r,e[t]=Te[0],e[t+1]=Te[1],e[t+2]=Te[2],e[t+3]=Te[3],e[t+4]=Te[4],e[t+5]=Te[5],e[t+6]=Te[6],e[t+7]=Te[7]}function el(r,e){return Te[0]=r[e],Te[1]=r[e+1],Te[2]=r[e+2],Te[3]=r[e+3],Te[4]=r[e+4],Te[5]=r[e+5],Te[6]=r[e+6],Te[7]=r[e+7],ma[0]}var zm=BigInt(Number.MAX_SAFE_INTEGER),Gm=BigInt(Number.MIN_SAFE_INTEGER),qe=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return _r;if(e<zm&&e>Gm)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,o=e-(n<<32n);return t&&(n=~n|0n,o=~o|0n,++o>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 ya(r,e,t){let n=t,o,s;for(let i=0;i<r.length;++i)o=r.charCodeAt(i),o<128?e[t++]=o:o<2048?(e[t++]=o>>6|192,e[t++]=o&63|128):(o&64512)===55296&&((s=r.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,e[t++]=o>>18|240,e[t++]=o>>12&63|128,e[t++]=o>>6&63|128,e[t++]=o&63|128):(e[t++]=o>>12|224,e[t++]=o>>6&63|128,e[t++]=o&63|128);return t-n}function at(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function Ho(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var ga=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,at(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw at(this,4);return Ho(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw at(this,4);return Ho(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw at(this,4);let e=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=Ho(this.buf,this.pos+=4),t=Ho(this.buf,this.pos+=4);return new qe(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=da(this.buf,this.pos);return this.pos+=Ve(e),e}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function wa(r){return new ga(r instanceof Uint8Array?r:r.subarray())}function en(r,e,t){let n=wa(r);return e.decode(n,void 0,t)}var ba={};ge(ba,{base10:()=>jm});var jm=Qt({prefix:"9",name:"base10",alphabet:"0123456789"});var xa={};ge(xa,{base16:()=>Wm,base16upper:()=>Ym});var Wm=le({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Ym=le({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ea={};ge(Ea,{base2:()=>Zm});var Zm=le({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var va={};ge(va,{base256emoji:()=>t0});var 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}"),Jm=sl.reduce((r,e,t)=>(r[t]=e,r),[]),Xm=sl.reduce((r,e,t)=>(r[e.codePointAt(0)]=t,r),[]);function Qm(r){return r.reduce((e,t)=>(e+=Jm[t],e),"")}function e0(r){let e=[];for(let t of r){let n=Xm[t.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${t}`);e.push(n)}return new Uint8Array(e)}var t0=zr({prefix:"\u{1F680}",name:"base256emoji",encode:Qm,decode:e0});var Aa={};ge(Aa,{base36:()=>sr,base36upper:()=>r0});var sr=Qt({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),r0=Qt({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ba={};ge(Ba,{base8:()=>n0});var n0=le({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ka={};ge(ka,{identity:()=>o0});var o0=zr({prefix:"\0",name:"identity",encode:r=>Ru(r),decode:r=>Iu(r)});var vx=new TextEncoder,Ax=new TextDecoder;var il=512;var $o=85;var Ia={};ge(Ia,{identity:()=>Je});var cl=0,s0="identity",ul=Rt;function i0(r){return yt(cl,ul(r))}var Je={code:cl,name:s0,encode:ul,digest:i0};var ir={...ka,...Ea,...Ba,...ba,...xa,...Ji,...Aa,...Xi,...aa,...va},Ux={...ia,...Ia};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))),Ra=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}),a0={utf8:ll,"utf-8":ll,hex:ir.base16,latin1:Ra,ascii:Ra,binary:Ra,...ir},Ko=a0;function W(r,e="utf8"){let t=Ko[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function _a(r){let e=r??8192,t=e>>>1,n,o=e;return function(i){if(i<1||i>t)return it(i);o+i>e&&(n=it(e),o=0);let a=n.subarray(o,o+=i);return o&7&&(o=(o|7)+1),a}}var Tr=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function Ta(){}var Na=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},c0=_a();function u0(r){return globalThis.Buffer!=null?it(r):c0(r)}var Zn=class{len;head;tail;states;constructor(){this.len=0,this.head=new Tr(Ta,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new Tr(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new La((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(qo,10,qe.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=qe.fromBigInt(e);return this._push(qo,t.length(),t)}uint64Number(e){return this._push(ha,Ve(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=qe.fromBigInt(e).zzEncode();return this._push(qo,t.length(),t)}sint64Number(e){let t=qe.fromNumber(e).zzEncode();return this._push(qo,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(Ca,1,e?1:0)}fixed32(e){return this._push(Yn,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=qe.fromBigInt(e);return this._push(Yn,4,t.lo)._push(Yn,4,t.hi)}fixed64Number(e){let t=qe.fromNumber(e);return this._push(Yn,4,t.lo)._push(Yn,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push(Ju,4,e)}double(e){return this._push(Qu,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(Ca,1,0):this.uint32(t)._push(f0,t,e)}string(e){let t=rl(e);return t!==0?this.uint32(t)._push(ya,t,e):this._push(Ca,1,0)}fork(){return this.states=new Na(this),this.head=this.tail=new Tr(Ta,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Tr(Ta,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=e.next,this.tail=t,this.len+=n),this}finish(){let e=this.head.next,t=u0(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function Ca(r,e,t){e[t]=r&255}function l0(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var La=class extends Tr{next;constructor(e,t){super(l0,e,t),this.next=void 0}};function qo(r,e,t){for(;r.hi!==0;)e[t++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)e[t++]=r.lo&127|128,r.lo=r.lo>>>7;e[t++]=r.lo}function Yn(r,e,t){e[t]=r&255,e[t+1]=r>>>8&255,e[t+2]=r>>>16&255,e[t+3]=r>>>24}function f0(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(Zn.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(h0,e,r),this},Zn.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(d0,e,r),this});function h0(r,e,t){e.set(r,t)}function d0(r,e,t){r.length<40?ya(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(W(r),t)}function Da(){return new Zn}function tn(r,e){let t=Da();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var rn;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(rn||(rn={}));function zo(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function Jn(r){function e(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let t=function(s,i){let a=e(s);i.int32(a)},n=function(s){let i=s.int32();return e(i)};return zo("enum",rn.VARINT,t,n)}function nn(r,e){return zo("message",rn.LENGTH_DELIMITED,r,e)}function p0(r){return r[Symbol.asyncIterator]!=null}function m0(r){if(p0(r))return(async()=>{for await(let e of r);})();for(let e of r);}var Tt=m0;function Le(r,e){e==null&&(e=r.reduce((o,s)=>o+s.length,0));let t=it(e),n=0;for(let o of r)t.set(o,n),n+=o.length;return t}function g0(r){return r[Symbol.asyncIterator]!=null}function w0(r,e){if(g0(r))return async function*(){for await(let a of r)yield e(a)}();let t=qr(r),{value:n,done:o}=t.next();if(o===!0)return function*(){}();let s=e(n);if(typeof s.then=="function")return async function*(){yield await s;for await(let a of t)yield e(a)}();let i=e;return function*(){yield s;for(let a of t)yield i(a)}()}var sn=w0;function De(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var Go=class{buffer;mask;top;btm;next;constructor(e){if(!(e>0)||e-1&e)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},an=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new Go(this.hwm),this.tail=this.head,this.size=0}calculateSize(e){return e?.byteLength!=null?e.byteLength:1}push(e){if(e?.value!=null&&(this.size+=this.calculateSize(e.value)),!this.head.push(e)){let t=this.head;this.head=t.next=new Go(2*this.head.buffer.length),this.head.push(e)}}shift(){let e=this.tail.shift();if(e===void 0&&this.tail.next!=null){let t=this.tail.next;this.tail.next=null,this.tail=t,e=this.tail.shift()}return e?.value!=null&&(this.size-=this.calculateSize(e.value)),e}isEmpty(){return this.head.isEmpty()}};var Ua=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function Ct(r={}){return b0(t=>{let n=t.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function b0(r,e){e=e??{};let t=e.onEnd,n=new an,o,s,i,a=De(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((m,g)=>{s=I=>{s=null,n.push(I);try{m(r(n))}catch(v){g(v)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=De()})}},f=m=>s!=null?s(m):(n.push(m),o),u=m=>(n=new an,s!=null?s({error:m}):(n.push({error:m}),o)),l=m=>{if(i)return o;if(e?.objectMode!==!0&&m?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:m})},p=m=>i?o:(i=!0,m!=null?u(m):f({done:!0})),E=()=>(n=new an,p(),{done:!0}),y=m=>(p(m),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:E,throw:y,push:l,end:p,get readableLength(){return n.size},onEmpty:async m=>{let g=m?.signal;if(g?.throwIfAborted(),n.isEmpty())return;let I,v;g!=null&&(I=new Promise((D,S)=>{v=()=>{S(new Ua)},g.addEventListener("abort",v)}));try{await Promise.race([a.promise,I])}finally{v!=null&&g!=null&&g?.removeEventListener("abort",v)}}},t==null)return o;let d=o;return o={[Symbol.asyncIterator](){return this},next(){return d.next()},throw(m){return d.throw(m),t!=null&&(t(m),t=void 0),{done:!0}},return(){return d.return(),t!=null&&(t(),t=void 0),{done:!0}},push:l,end(m){return d.end(m),t!=null&&(t(m),t=void 0),o},get readableLength(){return d.readableLength},onEmpty:m=>d.onEmpty(m)},o}function x0(r){return r[Symbol.asyncIterator]!=null}function E0(...r){let e=[];for(let t of r)x0(t)||e.push(t);return e.length===r.length?function*(){for(let t of e)yield*t}():async function*(){let t=Ct({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let o of n)t.push(o)})),t.end()}catch(n){t.end(n)}}),yield*t}()}var ar=E0;function v0(r){return r[Symbol.asyncIterator]!=null}function A0(r,e){return v0(r)?async function*(){let t=0;if(!(e<1)){for await(let n of r)if(yield n,t++,t===e)return}}():function*(){let t=0;if(!(e<1)){for(let n of r)if(yield n,t++,t===e)return}}()}var jo=A0;var te=class extends Event{constructor(e,t){super(e),this.detail=t}};function z(r,e="utf8"){let t=Ko[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var Wo=class{url;#e=0;#t=0;#r=0;#i=0;constructor(e){this.url=e instanceof URL?e:new URL(e)}async getRawBlock(e,t){let n=this.url;if(n.pathname=`/ipfs/${e.toString()}`,n.search="?format=raw",t?.aborted===!0)throw new Error(`Signal to fetch raw block for CID ${e} from gateway ${this.url} was aborted prior to fetch`);try{this.#e++;let o=await fetch(n.toString(),{signal:t,headers:{Accept:"application/vnd.ipld.raw"},cache:"force-cache"});if(!o.ok)throw this.#t++,new Error(`unable to fetch raw block for CID ${e} from gateway ${this.url}`);return this.#i++,new Uint8Array(await o.arrayBuffer())}catch{throw t?.aborted===!0?new Error(`fetching raw block for CID ${e} from gateway ${this.url} was aborted`):(this.#t++,new Error(`unable to fetch raw block for CID ${e}`))}}reliability(){return this.#e===0?1:this.#r>0?-1/0:this.#i/(this.#e+this.#t*3)}incrementInvalidBlocks(){this.#r++}};var Yo=class{gateways;log;constructor(e,t={}){this.log=e.logger.forComponent("helia:trustless-gateway-block-broker"),this.gateways=(t.gateways??pl).map(n=>new Wo(n))}async retrieve(e,t={}){let n=this.gateways.sort((s,i)=>i.reliability()-s.reliability()),o=[];for(let s of n){this.log("getting block for %c from %s",e,s.url);try{let i=await s.getRawBlock(e,t.signal);this.log.trace("got block for %c from %s",e,s.url);try{await t.validateFn?.(i)}catch(a){throw this.log.error("failed to validate block for %c from %s",e,s.url,a),s.incrementInvalidBlocks(),new Error(`unable to validate block for CID ${e} from gateway ${s.url}`)}return i}catch(i){if(this.log.error("failed to get block for %c from %s",e,s.url,i),i instanceof Error?o.push(i):o.push(new Error(`unable to fetch raw block for CID ${e} from gateway ${s.url}`)),t.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",e,s.url);break}}}throw new AggregateError(o,`unable to fetch raw block for CID ${e} from any gateway`)}};var pl=["https://trustless-gateway.link","https://cloudflare-ipfs.com","https://4everland.io"];function Pa(r={}){return e=>new Yo(e,r)}var B0=Symbol.for("nodejs.util.inspect.custom"),ml=Object.values(ir).map(r=>r.decoder).reduce((r,e)=>r.or(e),ir.identity.decoder),yl=114,Oa=36,Va=37,Xn=class{type;multihash;privateKey;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,this.privateKey=e.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[ta]=!0;toString(){return this.string==null&&(this.string=he.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return re.createV1(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 Cr(e).equals(this);if(e?.multihash?.bytes!=null)return se(this.multihash.bytes,e.multihash.bytes);throw new Error("not valid Id")}[B0](){return`PeerId(${this.toString()})`}},cn=class extends Xn{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},un=class extends Xn{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.multihash.digest}},ln=class extends Xn{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.multihash.digest}};function Cr(r,e){if(e=e??ml,r.charAt(0)==="1"||r.charAt(0)==="Q"){let t=gt(he.decode(`z${r}`));return r.startsWith("12D")?new un({multihash:t}):r.startsWith("16U")?new ln({multihash:t}):new cn({multihash:t})}return Qn(ml.decode(r))}function Qn(r){try{let e=gt(r);if(e.code===Je.code){if(e.digest.length===Oa)return new un({multihash:e});if(e.digest.length===Va)return new ln({multihash:e})}if(e.code===we.code)return new cn({multihash:e})}catch{return k0(re.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function k0(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==yl)throw new Error("Supplied PeerID CID is invalid");let e=r.multihash;if(e.code===we.code)return new cn({multihash:r.multihash});if(e.code===Je.code){if(e.digest.length===Oa)return new un({multihash:r.multihash});if(e.digest.length===Va)return new ln({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function gl(r,e){return r.length===Oa?new un({multihash:yt(Je.code,r),privateKey:e}):r.length===Va?new ln({multihash:yt(Je.code,r),privateKey:e}):new cn({multihash:await we.digest(r),publicKey:r,privateKey:e})}var Zo=class{index=0;input="";new(e){return this.index=0,this.input=e,this}readAtomically(e){let t=this.index,n=e();return n===void 0&&(this.index=t),n}parseWith(e){let t=e();if(this.index===this.input.length)return t}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(e){return this.readAtomically(()=>{let t=this.readChar();if(t===e)return t})}readSeparator(e,t,n){return this.readAtomically(()=>{if(!(t>0&&this.readGivenChar(e)===void 0))return n()})}readNumber(e,t,n,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",f=2**(8*o)-1;for(;;){let u=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let p=Number.parseInt(l,e);if(!Number.isNaN(p))return p});if(u===void 0)break;if(s*=e,s+=u,s>f||(i+=1,t!==void 0&&i>t))return}if(i!==0)return!n&&c&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let e=new Uint8Array(4);for(let t=0;t<e.length;t++){let n=this.readSeparator(".",t,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;e[t]=n}return e})}readIPv6Addr(){let e=t=>{for(let n=0;n<t.length/2;n++){let o=n*2;if(n<t.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return t[o]=i[0],t[o+1]=i[1],t[o+2]=i[2],t[o+3]=i[3],[o+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[o,!1];t[o]=s>>8,t[o+1]=s&255}return[t.length,!1]};return this.readAtomically(()=>{let t=new Uint8Array(16),[n,o]=e(t);if(n===16)return t;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=e(s.subarray(0,i));return t.set(s.subarray(0,a),16-a),t})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var wl=45,S0=15,fn=new Zo;function Fa(r){if(!(r.length>S0))return fn.new(r).parseWith(()=>fn.readIPv4Addr())}function Ma(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>wl))return fn.new(r).parseWith(()=>fn.readIPv6Addr())}function Jo(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>wl))return fn.new(r).parseWith(()=>fn.readIPAddr())}var cE=parseInt("0xFFFF",16),uE=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function El(r){return!!Fa(r)}function vl(r){return!!Ma(r)}function Xo(r){return!!Jo(r)}var Al=El,C0=vl,Ha=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(C0(r)){let t=r.split(":",8),n;for(n=0;n<t.length;n++){let s=Al(t[n]),i;s&&(i=Ha(t[n]),t[n]=z(i.slice(0,2),"base16")),i!=null&&++n<8&&t.splice(n,0,z(i.slice(2,4),"base16"))}if(t[0]==="")for(;t.length<8;)t.unshift("0");else if(t[t.length-1]==="")for(;t.length<8;)t.push("0");else if(t.length<8){for(n=0;n<t.length&&t[n]!=="";n++);let s=[n,1];for(n=9-t.length;n>0;n--)s.push("0");t.splice.apply(t,s)}let o=new Uint8Array(e+16);for(n=0;n<t.length;n++){let s=parseInt(t[n],16);o[e++]=s>>8&255,o[e++]=s&255}return o}throw new Error("invalid ip address")},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 hn={},$a={},L0=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[777,-1,"memory"]];L0.forEach(r=>{let e=D0(...r);$a[e.code]=e,hn[e.name]=e});function D0(r,e,t,n,o){return{code:r,size:e,name:t,resolvable:!!n,path:!!o}}function ie(r){if(typeof r=="number"){if($a[r]!=null)return $a[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(hn[r]!=null)return hn[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var GE=ie("ip4"),jE=ie("ip6"),WE=ie("ipcidr");function qa(r,e){switch(ie(r).code){case 4:case 41:return P0(e);case 42:return Il(e);case 6:case 273:case 33:case 132:return _l(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Il(e);case 421:return M0(e);case 444:return Rl(e);case 445:return Rl(e);case 466:return F0(e);default:return z(e,"base16")}}function za(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 Ga(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Sl(e);case 421:return O0(e);case 444:return H0(e);case 445:return $0(e);case 466:return V0(e);default:return W(e,"base16")}}var Ka=Object.values(ir).map(r=>r.decoder),U0=function(){let r=Ka[0].or(Ka[1]);return Ka.slice(2).forEach(e=>r=r.or(e)),r}();function kl(r){if(!Xo(r))throw new Error("invalid ip address");return Ha(r)}function P0(r){let e=Bl(r,0,r.length);if(e==null)throw new Error("ipBuff is required");if(!Xo(e))throw new Error("invalid ip address");return e}function Ga(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,r),new Uint8Array(e)}function _l(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Sl(r){let e=W(r),t=Uint8Array.from(Qr(e.length));return Le([t,e],t.length+e.length)}function Il(r){let e=Rr(r);if(r=r.slice(Ve(e)),r.length!==e)throw new Error("inconsistent lengths");return z(r)}function O0(r){let e;r[0]==="Q"||r[0]==="1"?e=gt(he.decode(`z${r}`)).bytes:e=re.parse(r).multihash.bytes;let t=Uint8Array.from(Qr(e.length));return Le([t,e],t.length+e.length)}function V0(r){let e=U0.decode(r),t=Uint8Array.from(Qr(e.length));return Le([t,e],t.length+e.length)}function F0(r){let e=Rr(r),t=r.slice(Ve(e));if(t.length!==e)throw new Error("inconsistent lengths");return"u"+z(t,"base64url")}function M0(r){let e=Rr(r),t=r.slice(Ve(e));if(t.length!==e)throw new Error("inconsistent lengths");return z(t,"base58btc")}function H0(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==16)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion address.`);let t=Be.decode("b"+e[0]),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Ga(n);return Le([t,o],t.length+o.length)}function $0(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==56)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion3 address.`);let t=Be.decode(`b${e[0]}`),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Ga(n);return Le([t,o],t.length+o.length)}function Rl(r){let e=r.slice(0,r.length-2),t=r.slice(r.length-2),n=z(e,"base32"),o=_l(t);return`${n}:${o}`}function Tl(r){r=ja(r);let e=[],t=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=ie(i);if(a.size===0){e.push([a.code]),t.push([a.code]);continue}if(s++,s>=o.length)throw Nl("invalid address: "+r);if(a.path===!0){n=ja(o.slice(s).join("/")),e.push([a.code,za(a.code,n)]),t.push([a.code,n]);break}let c=za(a.code,o[s]);e.push([a.code,c]),t.push([a.code,qa(a.code,c)])}return{string:Cl(t),bytes:Ya(e),tuples:e,stringTuples:t,path:n}}function Wa(r){let e=[],t=[],n=null,o=0;for(;o<r.length;){let s=Rr(r,o),i=Ve(s),a=ie(s),c=K0(a,r.slice(o+i));if(c===0){e.push([s]),t.push([s]),o+=i;continue}let f=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw Nl("Invalid address Uint8Array: "+z(r,"base16"));e.push([s,f]);let u=qa(s,f);if(t.push([s,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string: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}),ja(e.join("/"))}function Ya(r){return Le(r.map(e=>{let t=ie(e[0]),n=Uint8Array.from(Qr(t.code));return e.length>1&&e[1]!=null&&(n=Le([n,e[1]])),n}))}function K0(r,e){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let t=Rr(e instanceof Uint8Array?e:Uint8Array.from(e));return t+Ve(t)}}function ja(r){return"/"+r.trim().split("/").filter(e=>e).join("/")}function Nl(r){return new Error("Error parsing address: "+r)}var q0=Symbol.for("nodejs.util.inspect.custom"),Za=Symbol.for("@multiformats/js-multiaddr/multiaddr"),z0=[ie("dns").code,ie("dns4").code,ie("dns6").code,ie("dnsaddr").code],Qo=class r{bytes;#e;#t;#r;#i;[Za]=!0;constructor(e){e==null&&(e="");let t;if(e instanceof Uint8Array)t=Wa(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);t=Tl(e)}else if(Dl(e))t=Wa(e.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=t.bytes,this.#e=t.string,this.#t=t.tuples,this.#r=t.stringTuples,this.#i=t.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let e,t,n,o,s="",i=ie("tcp"),a=ie("udp"),c=ie("ip4"),f=ie("ip6"),u=ie("dns6"),l=ie("ip6zone");for(let[E,y]of this.stringTuples())E===l.code&&(s=`%${y??""}`),z0.includes(E)&&(t=i.name,o=443,n=`${y??""}${s}`,e=E===u.code?6:4),(E===i.code||E===a.code)&&(t=ie(E).name,o=parseInt(y??"")),(E===c.code||E===f.code)&&(t=ie(E).name,n=`${y??""}${s}`,e=E===f.code?6:4);if(e==null||t==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:e,host:n,transport:t,port:o}}protos(){return this.#t.map(([e])=>Object.assign({},ie(e)))}protoCodes(){return this.#t.map(([e])=>e)}protoNames(){return this.#t.map(([e])=>ie(e).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(e){return e=new r(e),new r(this.toString()+e.toString())}decapsulate(e){let t=e.toString(),n=this.toString(),o=n.lastIndexOf(t);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${e.toString()}`);return new r(n.slice(0,o))}decapsulateCode(e){let t=this.tuples();for(let n=t.length-1;n>=0;n--)if(t[n][0]===e)return new r(Ya(t.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,o])=>{n===hn.p2p.code&&e.push([n,o]),n===hn["p2p-circuit"].code&&(e=[])});let t=e.pop();if(t?.[1]!=null){let n=t[1];return n[0]==="Q"||n[0]==="1"?z(he.decode(`z${n}`),"base58btc"):z(re.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#i}equals(e){return se(this.bytes,e.bytes)}async resolve(e){let t=this.protos().find(s=>s.resolvable);if(t==null)return[this];let n=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=>eo(s))}nodeAddress(){let e=this.toOptions();if(e.transport!=="tcp"&&e.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${e.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:e.family,address:e.host,port:e.port}}isThinWaistAddress(e){let t=(e??this).protos();return!(t.length!==2||t[0].code!==4&&t[0].code!==41||t[1].code!==6&&t[1].code!==273)}[q0](){return`Multiaddr(${this.#e})`}};var Ll=new Map;function Dl(r){return!!r?.[Za]}function eo(r){return new Qo(r)}async function*es(r,e={}){let t=r.getReader();try{for(;;){let n=await t.read();if(n.done)return;yield n.value}}finally{e.preventCancel!==!0&&await t.cancel(),t.releaseLock()}}var dc={};ge(dc,{Ed25519PrivateKey:()=>Ur,Ed25519PublicKey:()=>no,generateKeyPair:()=>tg,generateKeyPairFromSeed:()=>cf,unmarshalEd25519PrivateKey:()=>Qy,unmarshalEd25519PublicKey:()=>eg});function Xe(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function dn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function G0(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function pn(r,...e){if(!G0(r))throw new Error("Uint8Array expected");if(e.length>0&&!e.includes(r.length))throw new Error(`Uint8Array expected of length ${e}, not of length=${r.length}`)}function ts(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");dn(r.outputLen),dn(r.blockLen)}function mn(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function Ul(r,e){pn(r);let t=e.outputLen;if(r.length<t)throw new Error(`digestInto() expects output buffer of length at least ${t}`)}var rs=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var gn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),ct=(r,e)=>r<<32-e|r>>>e;var Iv=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var j0=async()=>{};async function Pl(r,e,t){let n=Date.now();for(let o=0;o<r;o++){t(o);let s=Date.now()-n;s>=0&&s<e||(await j0(),n+=s)}}function Ja(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function cr(r){return typeof r=="string"&&(r=Ja(r)),pn(r),r}function ns(...r){let e=0;for(let n=0;n<r.length;n++){let o=r[n];pn(o),e+=o.length}let t=new Uint8Array(e);for(let n=0,o=0;n<r.length;n++){let s=r[n];t.set(s,o),o+=s.length}return t}var yn=class{clone(){return this._cloneInto()}},W0={}.toString;function Ol(r,e){if(e!==void 0&&W0.call(e)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,e)}function os(r){let e=n=>r().update(cr(n)).digest(),t=r();return e.outputLen=t.outputLen,e.blockLen=t.blockLen,e.create=()=>r(),e}function wn(r=32){if(rs&&typeof rs.getRandomValues=="function")return rs.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Y0(r,e,t,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(e,t,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(t>>o&s),a=Number(t&s),c=n?4:0,f=n?0:4;r.setUint32(e+c,i,n),r.setUint32(e+f,a,n)}var Vl=(r,e,t)=>r&e^~r&t,Fl=(r,e,t)=>r&e^r&t^e&t,bn=class extends yn{constructor(e,t,n,o){super(),this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=o,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(e),this.view=gn(this.buffer)}update(e){mn(this);let{view:t,buffer:n,blockLen:o}=this;e=cr(e);let s=e.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=gn(e);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){mn(this),Ul(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;t[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)t[l]=0;Y0(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=gn(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],s)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());let{blockLen:t,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return e.length=o,e.pos=a,e.finished=s,e.destroyed=i,o%t&&e.buffer.set(n),e}};var ss=BigInt(4294967295),Xa=BigInt(32);function Ml(r,e=!1){return e?{h:Number(r&ss),l:Number(r>>Xa&ss)}:{h:Number(r>>Xa&ss)|0,l:Number(r&ss)|0}}function Z0(r,e=!1){let t=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let o=0;o<r.length;o++){let{h:s,l:i}=Ml(r[o],e);[t[o],n[o]]=[s,i]}return[t,n]}var J0=(r,e)=>BigInt(r>>>0)<<Xa|BigInt(e>>>0),X0=(r,e,t)=>r>>>t,Q0=(r,e,t)=>r<<32-t|e>>>t,ey=(r,e,t)=>r>>>t|e<<32-t,ty=(r,e,t)=>r<<32-t|e>>>t,ry=(r,e,t)=>r<<64-t|e>>>t-32,ny=(r,e,t)=>r>>>t-32|e<<64-t,oy=(r,e)=>e,sy=(r,e)=>r,iy=(r,e,t)=>r<<t|e>>>32-t,ay=(r,e,t)=>e<<t|r>>>32-t,cy=(r,e,t)=>e<<t-32|r>>>64-t,uy=(r,e,t)=>r<<t-32|e>>>64-t;function ly(r,e,t,n){let o=(e>>>0)+(n>>>0);return{h:r+t+(o/2**32|0)|0,l:o|0}}var fy=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),hy=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,dy=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),py=(r,e,t,n,o)=>e+t+n+o+(r/2**32|0)|0,my=(r,e,t,n,o)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(o>>>0),yy=(r,e,t,n,o,s)=>e+t+n+o+s+(r/2**32|0)|0;var gy={fromBig:Ml,split:Z0,toBig:J0,shrSH:X0,shrSL:Q0,rotrSH:ey,rotrSL:ty,rotrBH:ry,rotrBL:ny,rotr32H:oy,rotr32L:sy,rotlSH:iy,rotlSL:ay,rotlBH:cy,rotlBL:uy,add:ly,add3L:fy,add3H:hy,add4L:dy,add4H:py,add5H:yy,add5L:my},q=gy;var[wy,by]=q.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),ur=new Uint32Array(80),lr=new Uint32Array(80),Qa=class extends bn{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:e,Al:t,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:f,El:u,Fh:l,Fl:p,Gh:E,Gl:y,Hh:d,Hl:m}=this;return[e,t,n,o,s,i,a,c,f,u,l,p,E,y,d,m]}set(e,t,n,o,s,i,a,c,f,u,l,p,E,y,d,m){this.Ah=e|0,this.Al=t|0,this.Bh=n|0,this.Bl=o|0,this.Ch=s|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=f|0,this.El=u|0,this.Fh=l|0,this.Fl=p|0,this.Gh=E|0,this.Gl=y|0,this.Hh=d|0,this.Hl=m|0}process(e,t){for(let v=0;v<16;v++,t+=4)ur[v]=e.getUint32(t),lr[v]=e.getUint32(t+=4);for(let v=16;v<80;v++){let D=ur[v-15]|0,S=lr[v-15]|0,_=q.rotrSH(D,S,1)^q.rotrSH(D,S,8)^q.shrSH(D,S,7),L=q.rotrSL(D,S,1)^q.rotrSL(D,S,8)^q.shrSL(D,S,7),w=ur[v-2]|0,C=lr[v-2]|0,O=q.rotrSH(w,C,19)^q.rotrBH(w,C,61)^q.shrSH(w,C,6),T=q.rotrSL(w,C,19)^q.rotrBL(w,C,61)^q.shrSL(w,C,6),F=q.add4L(L,T,lr[v-7],lr[v-16]),$=q.add4H(F,_,O,ur[v-7],ur[v-16]);ur[v]=$|0,lr[v]=F|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:p,Fh:E,Fl:y,Gh:d,Gl:m,Hh:g,Hl:I}=this;for(let v=0;v<80;v++){let D=q.rotrSH(l,p,14)^q.rotrSH(l,p,18)^q.rotrBH(l,p,41),S=q.rotrSL(l,p,14)^q.rotrSL(l,p,18)^q.rotrBL(l,p,41),_=l&E^~l&d,L=p&y^~p&m,w=q.add5L(I,S,L,by[v],lr[v]),C=q.add5H(w,g,D,_,wy[v],ur[v]),O=w|0,T=q.rotrSH(n,o,28)^q.rotrBH(n,o,34)^q.rotrBH(n,o,39),F=q.rotrSL(n,o,28)^q.rotrBL(n,o,34)^q.rotrBL(n,o,39),$=n&s^n&a^s&a,J=o&i^o&c^i&c;g=d|0,I=m|0,d=E|0,m=y|0,E=l|0,y=p|0,{h:l,l:p}=q.add(f|0,u|0,C|0,O|0),f=a|0,u=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let x=q.add3L(O,F,J);n=q.add3H(x,C,T,$),o=x|0}({h:n,l:o}=q.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=q.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=q.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:u}=q.add(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:p}=q.add(this.Eh|0,this.El|0,l|0,p|0),{h:E,l:y}=q.add(this.Fh|0,this.Fl|0,E|0,y|0),{h:d,l:m}=q.add(this.Gh|0,this.Gl|0,d|0,m|0),{h:g,l:I}=q.add(this.Hh|0,this.Hl|0,g|0,I|0),this.set(n,o,s,i,a,c,f,u,l,p,E,y,d,m,g,I)}roundClean(){ur.fill(0),lr.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var xn=os(()=>new Qa);var as={};ge(as,{abytes:()=>En,bitGet:()=>Sy,bitLen:()=>ky,bitMask:()=>to,bitSet:()=>Iy,bytesToHex:()=>Lt,bytesToNumberBE:()=>Dt,bytesToNumberLE:()=>hr,concatBytes:()=>Ut,createHmacDrbg:()=>rc,ensureBytes:()=>fe,equalBytes:()=>Ay,hexToBytes:()=>Nr,hexToNumber:()=>tc,isBytes:()=>fr,numberToBytesBE:()=>dr,numberToBytesLE:()=>Lr,numberToHexUnpadded:()=>ql,numberToVarBytesBE:()=>vy,utf8ToBytes:()=>By,validateObject:()=>wt});var Kl=BigInt(0),is=BigInt(1),xy=BigInt(2);function fr(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function En(r){if(!fr(r))throw new Error("Uint8Array expected")}var Ey=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function Lt(r){En(r);let e="";for(let t=0;t<r.length;t++)e+=Ey[r[t]];return e}function ql(r){let e=r.toString(16);return e.length&1?`0${e}`:e}function tc(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Nt={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Hl(r){if(r>=Nt._0&&r<=Nt._9)return r-Nt._0;if(r>=Nt._A&&r<=Nt._F)return r-(Nt._A-10);if(r>=Nt._a&&r<=Nt._f)return r-(Nt._a-10)}function Nr(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let e=r.length,t=e/2;if(e%2)throw new Error("padded hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let o=0,s=0;o<t;o++,s+=2){let i=Hl(r.charCodeAt(s)),a=Hl(r.charCodeAt(s+1));if(i===void 0||a===void 0){let c=r[s]+r[s+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+s)}n[o]=i*16+a}return n}function Dt(r){return tc(Lt(r))}function hr(r){return En(r),tc(Lt(Uint8Array.from(r).reverse()))}function dr(r,e){return Nr(r.toString(16).padStart(e*2,"0"))}function Lr(r,e){return dr(r,e).reverse()}function vy(r){return Nr(ql(r))}function fe(r,e,t){let n;if(typeof e=="string")try{n=Nr(e)}catch(s){throw new Error(`${r} must be valid hex string, got "${e}". Cause: ${s}`)}else if(fr(e))n=Uint8Array.from(e);else throw new Error(`${r} must be hex string or Uint8Array`);let o=n.length;if(typeof t=="number"&&o!==t)throw new Error(`${r} expected ${t} bytes, got ${o}`);return n}function Ut(...r){let e=0;for(let n=0;n<r.length;n++){let o=r[n];En(o),e+=o.length}let t=new Uint8Array(e);for(let n=0,o=0;n<r.length;n++){let s=r[n];t.set(s,o),o+=s.length}return t}function Ay(r,e){if(r.length!==e.length)return!1;let t=0;for(let n=0;n<r.length;n++)t|=r[n]^e[n];return t===0}function By(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function ky(r){let e;for(e=0;r>Kl;r>>=is,e+=1);return e}function Sy(r,e){return r>>BigInt(e)&is}function Iy(r,e,t){return r|(t?is:Kl)<<BigInt(e)}var to=r=>(xy<<BigInt(r-1))-is,ec=r=>new Uint8Array(r),$l=r=>Uint8Array.from(r);function rc(r,e,t){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof e!="number"||e<2)throw new Error("qByteLen must be a number");if(typeof t!="function")throw new Error("hmacFn must be a function");let n=ec(r),o=ec(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>t(o,n,...l),c=(l=ec())=>{o=a($l([0]),l),n=a(),l.length!==0&&(o=a($l([1]),l),n=a())},f=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,p=[];for(;l<e;){n=a();let E=n.slice();p.push(E),l+=n.length}return Ut(...p)};return(l,p)=>{i(),c(l);let E;for(;!(E=p(f()));)c();return i(),E}}var Ry={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||fr(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,e)=>e.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function wt(r,e,t={}){let n=(o,s,i)=>{let a=Ry[s];if(typeof a!="function")throw new Error(`Invalid validator "${s}", expected function`);let c=r[o];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(o)}=${c} (${typeof c}), expected ${s}`)};for(let[o,s]of Object.entries(e))n(o,s,!1);for(let[o,s]of Object.entries(t))n(o,s,!0);return r}var be=BigInt(0),ae=BigInt(1),Dr=BigInt(2),_y=BigInt(3),nc=BigInt(4),zl=BigInt(5),Gl=BigInt(8),Ty=BigInt(9),Cy=BigInt(16);function oe(r,e){let t=r%e;return t>=be?t:e+t}function Ny(r,e,t){if(t<=be||e<be)throw new Error("Expected power/modulo > 0");if(t===ae)return be;let n=ae;for(;e>be;)e&ae&&(n=n*r%t),r=r*r%t,e>>=ae;return n}function ce(r,e,t){let n=r;for(;e-- >be;)n*=n,n%=t;return n}function cs(r,e){if(r===be||e<=be)throw new Error(`invert: expected positive integers, got n=${r} mod=${e}`);let t=oe(r,e),n=e,o=be,s=ae,i=ae,a=be;for(;t!==be;){let f=n/t,u=n%t,l=o-i*f,p=s-a*f;n=t,t=u,o=i,s=a,i=l,a=p}if(n!==ae)throw new Error("invert: does not exist");return oe(o,e)}function Ly(r){let e=(r-ae)/Dr,t,n,o;for(t=r-ae,n=0;t%Dr===be;t/=Dr,n++);for(o=Dr;o<r&&Ny(o,e,r)!==r-ae;o++);if(n===1){let i=(r+ae)/nc;return function(c,f){let u=c.pow(f,i);if(!c.eql(c.sqr(u),f))throw new Error("Cannot find square root");return u}}let s=(t+ae)/Dr;return function(a,c){if(a.pow(c,e)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,u=a.pow(a.mul(a.ONE,o),t),l=a.pow(c,s),p=a.pow(c,t);for(;!a.eql(p,a.ONE);){if(a.eql(p,a.ZERO))return a.ZERO;let E=1;for(let d=a.sqr(p);E<f&&!a.eql(d,a.ONE);E++)d=a.sqr(d);let y=a.pow(u,ae<<BigInt(f-E-1));u=a.sqr(y),l=a.mul(l,y),p=a.mul(p,u),f=E}return l}}function Dy(r){if(r%nc===_y){let e=(r+ae)/nc;return function(n,o){let s=n.pow(o,e);if(!n.eql(n.sqr(s),o))throw new Error("Cannot find square root");return s}}if(r%Gl===zl){let e=(r-zl)/Gl;return function(n,o){let s=n.mul(o,Dr),i=n.pow(s,e),a=n.mul(o,i),c=n.mul(n.mul(a,Dr),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),o))throw new Error("Cannot find square root");return f}}return r%Cy,Ly(r)}var jl=(r,e)=>(oe(r,e)&ae)===ae,Uy=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function oc(r){let e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},t=Uy.reduce((n,o)=>(n[o]="function",n),e);return wt(r,t)}function Py(r,e,t){if(t<be)throw new Error("Expected power > 0");if(t===be)return r.ONE;if(t===ae)return e;let n=r.ONE,o=e;for(;t>be;)t&ae&&(n=r.mul(n,o)),o=r.sqr(o),t>>=ae;return n}function Oy(r,e){let t=new Array(e.length),n=e.reduce((s,i,a)=>r.is0(i)?s:(t[a]=s,r.mul(s,i)),r.ONE),o=r.inv(n);return e.reduceRight((s,i,a)=>r.is0(i)?s:(t[a]=r.mul(s,t[a]),r.mul(s,i)),o),t}function sc(r,e){let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}function us(r,e,t=!1,n={}){if(r<=be)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:o,nByteLength:s}=sc(r,e);if(s>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Dy(r),a=Object.freeze({ORDER:r,BITS:o,BYTES:s,MASK:to(o),ZERO:be,ONE:ae,create:c=>oe(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return be<=c&&c<r},is0:c=>c===be,isOdd:c=>(c&ae)===ae,neg:c=>oe(-c,r),eql:(c,f)=>c===f,sqr:c=>oe(c*c,r),add:(c,f)=>oe(c+f,r),sub:(c,f)=>oe(c-f,r),mul:(c,f)=>oe(c*f,r),pow:(c,f)=>Py(a,c,f),div:(c,f)=>oe(c*cs(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>cs(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Oy(a,c),cmov:(c,f,u)=>u?f:c,toBytes:c=>t?Lr(c,s):dr(c,s),fromBytes:c=>{if(c.length!==s)throw new Error(`Fp.fromBytes: expected ${s}, got ${c.length}`);return t?hr(c):Dt(c)}});return Object.freeze(a)}function Wl(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 Yl(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let e=r.toString(2).length;return Math.ceil(e/8)}function ic(r){let e=Yl(r);return e+Math.ceil(e/2)}function Zl(r,e,t=!1){let n=r.length,o=Yl(e),s=ic(e);if(n<16||n<s||n>1024)throw new Error(`expected ${s}-1024 bytes of input, got ${n}`);let i=t?Dt(r):hr(r),a=oe(i,e-ae)+ae;return t?Lr(a,o):dr(a,o)}var Fy=BigInt(0),ac=BigInt(1);function ls(r,e){let t=(o,s)=>{let i=s.negate();return o?i:s},n=o=>{let s=Math.ceil(e/o)+1,i=2**(o-1);return{windows:s,windowSize:i}};return{constTimeNegate:t,unsafeLadder(o,s){let i=r.ZERO,a=o;for(;s>Fy;)s&ac&&(i=i.add(a)),a=a.double(),s>>=ac;return i},precomputeWindow(o,s){let{windows:i,windowSize:a}=n(s),c=[],f=o,u=f;for(let l=0;l<i;l++){u=f,c.push(u);for(let p=1;p<a;p++)u=u.add(f),c.push(u);f=u.double()}return c},wNAF(o,s,i){let{windows:a,windowSize:c}=n(o),f=r.ZERO,u=r.BASE,l=BigInt(2**o-1),p=2**o,E=BigInt(o);for(let y=0;y<a;y++){let d=y*c,m=Number(i&l);i>>=E,m>c&&(m-=p,i+=ac);let g=d,I=d+Math.abs(m)-1,v=y%2!==0,D=m<0;m===0?u=u.add(t(v,s[g])):f=f.add(t(D,s[I]))}return{p:f,f:u}},wNAFCached(o,s,i,a){let c=o._WINDOW_SIZE||1,f=s.get(o);return f||(f=this.precomputeWindow(o,c),c!==1&&s.set(o,a(f))),this.wNAF(c,f,i)}}}function ro(r){return oc(r.Fp),wt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...sc(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var ut=BigInt(0),ze=BigInt(1),fs=BigInt(2),My=BigInt(8),Hy={zip215:!0};function $y(r){let e=ro(r);return wt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...e})}function hs(r){let e=$y(r),{Fp:t,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=e,f=fs<<BigInt(a*8)-ze,u=t.create,l=e.uvRatio||((B,b)=>{try{return{isValid:!0,value:t.sqrt(B*t.inv(b))}}catch{return{isValid:!1,value:ut}}}),p=e.adjustScalarBytes||(B=>B),E=e.domain||((B,b,P)=>{if(b.length||P)throw new Error("Contexts/pre-hash are not supported");return B}),y=B=>typeof B=="bigint"&&ut<B,d=(B,b)=>y(B)&&y(b)&&B<b,m=B=>B===ut||d(B,f);function g(B,b){if(d(B,b))return B;throw new Error(`Expected valid scalar < ${b}, got ${typeof B} ${B}`)}function I(B){return B===ut?B:g(B,n)}let v=new Map;function D(B){if(!(B instanceof S))throw new Error("ExtendedPoint expected")}class S{constructor(b,P,M,K){if(this.ex=b,this.ey=P,this.ez=M,this.et=K,!m(b))throw new Error("x required");if(!m(P))throw new Error("y required");if(!m(M))throw new Error("z required");if(!m(K))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(b){if(b instanceof S)throw new Error("extended point not allowed");let{x:P,y:M}=b||{};if(!m(P)||!m(M))throw new Error("invalid affine point");return new S(P,M,ze,u(P*M))}static normalizeZ(b){let P=t.invertBatch(b.map(M=>M.ez));return b.map((M,K)=>M.toAffine(P[K])).map(S.fromAffine)}_setWindowSize(b){this._WINDOW_SIZE=b,v.delete(this)}assertValidity(){let{a:b,d:P}=e;if(this.is0())throw new Error("bad point: ZERO");let{ex:M,ey:K,ez:G,et:j}=this,ee=u(M*M),Z=u(K*K),X=u(G*G),pe=u(X*X),ue=u(ee*b),ve=u(X*u(ue+Z)),Ae=u(pe+u(P*u(ee*Z)));if(ve!==Ae)throw new Error("bad point: equation left != right (1)");let ye=u(M*K),Re=u(G*j);if(ye!==Re)throw new Error("bad point: equation left != right (2)")}equals(b){D(b);let{ex:P,ey:M,ez:K}=this,{ex:G,ey:j,ez:ee}=b,Z=u(P*ee),X=u(G*K),pe=u(M*ee),ue=u(j*K);return Z===X&&pe===ue}is0(){return this.equals(S.ZERO)}negate(){return new S(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:b}=e,{ex:P,ey:M,ez:K}=this,G=u(P*P),j=u(M*M),ee=u(fs*u(K*K)),Z=u(b*G),X=P+M,pe=u(u(X*X)-G-j),ue=Z+j,ve=ue-ee,Ae=Z-j,ye=u(pe*ve),Re=u(ue*Ae),It=u(pe*Ae),kr=u(ve*ue);return new S(ye,Re,kr,It)}add(b){D(b);let{a:P,d:M}=e,{ex:K,ey:G,ez:j,et:ee}=this,{ex:Z,ey:X,ez:pe,et:ue}=b;if(P===BigInt(-1)){let gu=u((G-K)*(X+Z)),wu=u((G+K)*(X-Z)),zi=u(wu-gu);if(zi===ut)return this.double();let bu=u(j*fs*ue),xu=u(ee*fs*pe),Eu=xu+bu,vu=wu+gu,Au=xu-bu,Rp=u(Eu*zi),_p=u(vu*Au),Tp=u(Eu*Au),Cp=u(zi*vu);return new S(Rp,_p,Cp,Tp)}let ve=u(K*Z),Ae=u(G*X),ye=u(ee*M*ue),Re=u(j*pe),It=u((K+G)*(Z+X)-ve-Ae),kr=Re-ye,Kn=Re+ye,yu=u(Ae-P*ve),Bp=u(It*kr),kp=u(Kn*yu),Sp=u(It*yu),Ip=u(kr*Kn);return new S(Bp,kp,Ip,Sp)}subtract(b){return this.add(b.negate())}wNAF(b){return w.wNAFCached(this,v,b,S.normalizeZ)}multiply(b){let{p:P,f:M}=this.wNAF(g(b,n));return S.normalizeZ([P,M])[0]}multiplyUnsafe(b){let P=I(b);return P===ut?L:this.equals(L)||P===ze?this:this.equals(_)?this.wNAF(P).p:w.unsafeLadder(this,P)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return w.unsafeLadder(this,n).is0()}toAffine(b){let{ex:P,ey:M,ez:K}=this,G=this.is0();b==null&&(b=G?My:t.inv(K));let j=u(P*b),ee=u(M*b),Z=u(K*b);if(G)return{x:ut,y:ze};if(Z!==ze)throw new Error("invZ was invalid");return{x:j,y:ee}}clearCofactor(){let{h:b}=e;return b===ze?this:this.multiplyUnsafe(b)}static fromHex(b,P=!1){let{d:M,a:K}=e,G=t.BYTES;b=fe("pointHex",b,G);let j=b.slice(),ee=b[G-1];j[G-1]=ee&-129;let Z=hr(j);Z===ut||(P?g(Z,f):g(Z,t.ORDER));let X=u(Z*Z),pe=u(X-ze),ue=u(M*X-K),{isValid:ve,value:Ae}=l(pe,ue);if(!ve)throw new Error("Point.fromHex: invalid y coordinate");let ye=(Ae&ze)===ze,Re=(ee&128)!==0;if(!P&&Ae===ut&&Re)throw new Error("Point.fromHex: x=0 and x_0=1");return Re!==ye&&(Ae=u(-Ae)),S.fromAffine({x:Ae,y:Z})}static fromPrivateKey(b){return T(b).point}toRawBytes(){let{x:b,y:P}=this.toAffine(),M=Lr(P,t.BYTES);return M[M.length-1]|=b&ze?128:0,M}toHex(){return Lt(this.toRawBytes())}}S.BASE=new S(e.Gx,e.Gy,ze,u(e.Gx*e.Gy)),S.ZERO=new S(ut,ze,ze,ut);let{BASE:_,ZERO:L}=S,w=ls(S,a*8);function C(B){return oe(B,n)}function O(B){return C(hr(B))}function T(B){let b=a;B=fe("private key",B,b);let P=fe("hashed private key",s(B),2*b),M=p(P.slice(0,b)),K=P.slice(b,2*b),G=O(M),j=_.multiply(G),ee=j.toRawBytes();return{head:M,prefix:K,scalar:G,point:j,pointBytes:ee}}function F(B){return T(B).pointBytes}function $(B=new Uint8Array,...b){let P=Ut(...b);return O(s(E(P,fe("context",B),!!o)))}function J(B,b,P={}){B=fe("message",B),o&&(B=o(B));let{prefix:M,scalar:K,pointBytes:G}=T(b),j=$(P.context,M,B),ee=_.multiply(j).toRawBytes(),Z=$(P.context,ee,G,B),X=C(j+Z*K);I(X);let pe=Ut(ee,Lr(X,t.BYTES));return fe("result",pe,a*2)}let x=Hy;function k(B,b,P,M=x){let{context:K,zip215:G}=M,j=t.BYTES;B=fe("signature",B,2*j),b=fe("message",b),o&&(b=o(b));let ee=hr(B.slice(j,2*j)),Z,X,pe;try{Z=S.fromHex(P,G),X=S.fromHex(B.slice(0,j),G),pe=_.multiplyUnsafe(ee)}catch{return!1}if(!G&&Z.isSmallOrder())return!1;let ue=$(K,X.toRawBytes(),Z.toRawBytes(),b);return X.add(Z.multiplyUnsafe(ue)).subtract(pe).clearCofactor().equals(S.ZERO)}return _._setWindowSize(8),{CURVE:e,getPublicKey:F,sign:J,verify:k,ExtendedPoint:S,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>i(t.BYTES),precompute(B=8,b=S.BASE){return b._setWindowSize(B),b.multiply(BigInt(3)),b}}}}var uc=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Jl=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),Yv=BigInt(0),Ky=BigInt(1),cc=BigInt(2),qy=BigInt(5),Xl=BigInt(10),zy=BigInt(20),Gy=BigInt(40),Ql=BigInt(80);function jy(r){let e=uc,n=r*r%e*r%e,o=ce(n,cc,e)*n%e,s=ce(o,Ky,e)*r%e,i=ce(s,qy,e)*s%e,a=ce(i,Xl,e)*i%e,c=ce(a,zy,e)*a%e,f=ce(c,Gy,e)*c%e,u=ce(f,Ql,e)*f%e,l=ce(u,Ql,e)*f%e,p=ce(l,Xl,e)*i%e;return{pow_p_5_8:ce(p,cc,e)*r%e,b2:n}}function Wy(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Yy(r,e){let t=uc,n=oe(e*e*e,t),o=oe(n*n*e,t),s=jy(r*o).pow_p_5_8,i=oe(r*n*s,t),a=oe(e*i*i,t),c=i,f=oe(i*Jl,t),u=a===r,l=a===oe(-r,t),p=a===oe(-r*Jl,t);return u&&(i=c),(l||p)&&(i=f),jl(i,t)&&(i=oe(-i,t)),{isValid:u||l,value:i}}var Pt=us(uc,void 0,!0),lc={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Pt,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:xn,randomBytes:wn,adjustScalarBytes:Wy,uvRatio:Yy},vn=hs(lc);function ef(r,e,t){if(e.length>255)throw new Error("Context is too big");return ns(Ja("SigEd25519 no Ed25519 collisions"),new Uint8Array([t?1:0,e.length]),e,r)}var Zv=hs({...lc,domain:ef}),Jv=hs({...lc,domain:ef,prehash:xn});var Zy=(Pt.ORDER+BigInt(3))/BigInt(8),Xv=Pt.pow(cc,Zy),Qv=Pt.sqrt(Pt.neg(Pt.ONE)),e2=(Pt.ORDER-BigInt(5))/BigInt(8),t2=BigInt(486662);var r2=Wl(Pt,Pt.neg(BigInt(486664)));var n2=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),o2=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),s2=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),i2=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var a2=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var An=32,Ot=64,ds=32;function tf(){let r=vn.utils.randomPrivateKey(),e=vn.getPublicKey(r);return{privateKey:sf(r,e),publicKey:e}}function rf(r){if(r.length!==ds)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let e=r,t=vn.getPublicKey(e);return{privateKey:sf(e,t),publicKey:t}}function nf(r,e){let t=r.subarray(0,ds);return vn.sign(e instanceof Uint8Array?e:e.subarray(),t)}function of(r,e,t){return vn.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}function sf(r,e){let t=new Uint8Array(Ot);for(let n=0;n<ds;n++)t[n]=r[n],t[ds+n]=e[n];return t}var Ue={get(r=globalThis){let e=r.crypto;if(e==null||e.subtle==null)throw Object.assign(new Error("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api"),{code:"ERR_MISSING_WEB_CRYPTO"});return e}};var fc={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function af(r){let e=r?.algorithm??"AES-GCM",t=r?.keyLength??16,n=r?.nonceLength??12,o=r?.digest??"SHA-256",s=r?.saltLength??16,i=r?.iterations??32767,a=Ue.get();t*=8;async function c(l,p){let E=a.getRandomValues(new Uint8Array(s)),y=a.getRandomValues(new Uint8Array(n)),d={name:e,iv:y};typeof p=="string"&&(p=W(p));let m;if(p.length===0){m=await a.subtle.importKey("jwk",fc,{name:"AES-GCM"},!0,["encrypt"]);try{let I={name:"PBKDF2",salt:E,iterations:i,hash:{name:o}},v=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(I,v,{name:e,length:t},!0,["encrypt"])}catch{m=await a.subtle.importKey("jwk",fc,{name:"AES-GCM"},!0,["encrypt"])}}else{let I={name:"PBKDF2",salt:E,iterations:i,hash:{name:o}},v=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(I,v,{name:e,length:t},!0,["encrypt"])}let g=await a.subtle.encrypt(d,m,l);return Le([E,d.iv,new Uint8Array(g)])}async function f(l,p){let E=l.subarray(0,s),y=l.subarray(s,s+n),d=l.subarray(s+n),m={name:e,iv:y};typeof p=="string"&&(p=W(p));let g;if(p.length===0)try{let v={name:"PBKDF2",salt:E,iterations:i,hash:{name:o}},D=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(v,D,{name:e,length:t},!0,["decrypt"])}catch{g=await a.subtle.importKey("jwk",fc,{name:"AES-GCM"},!0,["decrypt"])}else{let v={name:"PBKDF2",salt:E,iterations:i,hash:{name:o}},D=await a.subtle.importKey("raw",p,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(v,D,{name:e,length:t},!0,["decrypt"])}let I=await a.subtle.decrypt(m,g,d);return new Uint8Array(I)}return{encrypt:c,decrypt:f}}async function Bn(r,e){let n=await af().encrypt(r,e);return nr.encode(n)}var de;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(de||(de={}));var hc;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(hc||(hc={}));(function(r){r.codec=()=>Jn(hc)})(de||(de={}));var bt;(function(r){let e;r.codec=()=>(e==null&&(e=nn((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),de.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),o.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let o={},s=n==null?t.len:t.pos+n;for(;t.pos<s;){let i=t.uint32();switch(i>>>3){case 1:o.Type=de.codec().decode(t);break;case 2:o.Data=t.bytes();break;default:t.skipType(i&7);break}}return o})),e),r.encode=t=>tn(t,r.codec()),r.decode=t=>en(t,r.codec())})(bt||(bt={}));var Vt;(function(r){let e;r.codec=()=>(e==null&&(e=nn((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),de.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),o.lengthDelimited!==!1&&n.ldelim()},(t,n)=>{let o={},s=n==null?t.len:t.pos+n;for(;t.pos<s;){let i=t.uint32();switch(i>>>3){case 1:o.Type=de.codec().decode(t);break;case 2:o.Data=t.bytes();break;default:t.skipType(i&7);break}}return o})),e),r.encode=t=>tn(t,r.codec()),r.decode=t=>en(t,r.codec())})(Vt||(Vt={}));var no=class{_key;constructor(e){this._key=kn(e,An)}verify(e,t){return of(this._key,t,e)}marshal(){return this._key}get bytes(){return bt.encode({Type:de.Ed25519,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(e)?e.then(({bytes:t})=>t):e.bytes}},Ur=class{_key;_publicKey;constructor(e,t){this._key=kn(e,Ot),this._publicKey=kn(t,An)}sign(e){return nf(this._key,e)}get public(){return new no(this._publicKey)}marshal(){return this._key}get bytes(){return Vt.encode({Type:de.Ed25519,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}async hash(){let e=we.digest(this.bytes),t;return Xe(e)?{bytes:t}=await e:t=e.bytes,t}async id(){let e=Je.digest(this.public.bytes);return he.encode(e.bytes).substring(1)}async export(e,t="libp2p-key"){if(t==="libp2p-key")return Bn(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Qy(r){if(r.length>Ot){r=kn(r,Ot+An);let n=r.subarray(0,Ot),o=r.subarray(Ot,r.length);return new Ur(n,o)}r=kn(r,Ot);let e=r.subarray(0,Ot),t=r.subarray(An);return new Ur(e,t)}function eg(r){return r=kn(r,An),new no(r)}async function tg(){let{privateKey:r,publicKey:e}=tf();return new Ur(r,e)}async function cf(r){let{privateKey:e,publicKey:t}=rf(r);return new Ur(e,t)}function kn(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new N(`Key must be a Uint8Array of length ${e}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}var Ac={};ge(Ac,{MAX_RSA_KEY_SIZE:()=>yo,RsaPrivateKey:()=>Tn,RsaPublicKey:()=>mo,fromJwk:()=>Rg,generateKeyPair:()=>_g,unmarshalRsaPrivateKey:()=>Ec,unmarshalRsaPublicKey:()=>Ig});function Pr(r){if(isNaN(r)||r<=0)throw new N("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return wn(r)}var gr={};ge(gr,{exportToPem:()=>vg,importFromPem:()=>Ag,jwkToPkcs1:()=>wg,jwkToPkix:()=>xg,pkcs1ToJwk:()=>gg,pkixToJwk:()=>bg});var ms=class extends yn{constructor(e,t){super(),this.finished=!1,this.destroyed=!1,ts(e);let n=cr(t);if(this.iHash=e.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let o=this.blockLen,s=new Uint8Array(o);s.set(n.length>o?e.create().update(n).digest():n);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=e.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),s.fill(0)}update(e){return mn(this),this.iHash.update(e),this}digestInto(e){mn(this),pn(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));let{oHash:t,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return e=e,e.finished=o,e.destroyed=s,e.blockLen=i,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},oo=(r,e,t)=>new ms(r,e).update(t).digest();oo.create=(r,e)=>new ms(r,e);function rg(r,e,t,n){ts(r);let o=Ol({dkLen:32,asyncTick:10},n),{c:s,dkLen:i,asyncTick:a}=o;if(dn(s),dn(i),dn(a),s<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=cr(e),f=cr(t),u=new Uint8Array(i),l=oo.create(r,c),p=l._cloneInto().update(f);return{c:s,dkLen:i,asyncTick:a,DK:u,PRF:l,PRFSalt:p}}function ng(r,e,t,n,o){return r.destroy(),e.destroy(),n&&n.destroy(),o.fill(0),t}async function pc(r,e,t,n){let{c:o,dkLen:s,asyncTick:i,DK:a,PRF:c,PRFSalt:f}=rg(r,e,t,n),u,l=new Uint8Array(4),p=gn(l),E=new Uint8Array(c.outputLen);for(let y=1,d=0;d<s;y++,d+=c.outputLen){let m=a.subarray(d,d+c.outputLen);p.setInt32(0,y,!1),(u=f._cloneInto(u)).update(l).digestInto(E),m.set(E.subarray(0,m.length)),await Pl(o-1,i,()=>{c._cloneInto(u).update(E).digestInto(E);for(let g=0;g<m.length;g++)m[g]^=E[g]})}return ng(c,f,a,u,E)}var Y=st(uf());function Or(r,e){let t=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)t+=r[r.length-1-n]*Math.pow(2,e*n);return t}function pr(r,e,t=-1){let n=t,o=r,s=0,i=Math.pow(2,e);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),s=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),s=n}let f=new Uint8Array(c);for(let u=a-1;u>=0;u--){let l=Math.pow(2,u*e);f[s-u-1]=Math.floor(o/l),o-=f[s-u-1]*l}return c}i*=Math.pow(2,e)}return new ArrayBuffer(0)}function ws(...r){let e=0,t=0;for(let s of r)e+=s.length;let n=new ArrayBuffer(e),o=new Uint8Array(n);for(let s of r)o.set(s,t),t+=s.length;return o}function yc(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let e=new ArrayBuffer(this.valueHex.byteLength),t=new Uint8Array(e);for(let a=0;a<this.valueHex.byteLength;a++)t[a]=0;t[0]=r[0]&128;let n=Or(t,8),o=new ArrayBuffer(this.valueHex.byteLength),s=new Uint8Array(o);for(let a=0;a<this.valueHex.byteLength;a++)s[a]=r[a];return s[0]&=127,Or(s,8)-n}function lf(r){let e=r<0?r*-1:r,t=128;for(let n=1;n<8;n++){if(e<=t){if(r<0){let i=t-e,a=pr(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=pr(e,8,n),s=new Uint8Array(o);if(s[0]&128){let i=o.slice(0),a=new Uint8Array(i);o=new ArrayBuffer(o.byteLength+1),s=new Uint8Array(o);for(let c=0;c<i.byteLength;c++)s[c+1]=a[c];s[0]=0}return o}t*=Math.pow(2,8)}return new ArrayBuffer(0)}function ff(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 bs(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function gc(r){let e=0,t=0;for(let o=0;o<r.length;o++){let s=r[o];e+=s.byteLength}let n=new Uint8Array(e);for(let o=0;o<r.length;o++){let s=r[o];n.set(new Uint8Array(s),t),t+=s.byteLength}return n.buffer}function Kt(r,e,t,n){return e instanceof Uint8Array?e.byteLength?t<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):e.byteLength-t-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var io=class{constructor(){this.items=[]}write(e){this.items.push(e)}final(){return gc(this.items)}},so=[new Uint8Array([1])],hf="0123456789";var Rn="",ft=new ArrayBuffer(0),wc=new Uint8Array(0),ao="EndOfContent",pf="OCTET STRING",mf="BIT STRING";function qt(r){var e;return e=class extends r{constructor(...n){var o;super(...n);let s=n[0]||{};this.isHexOnly=(o=s.isHexOnly)!==null&&o!==void 0?o:!1,this.valueHexView=s.valueHex?Y.BufferSourceConverter.toUint8Array(s.valueHex):wc}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,o,s){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Kt(this,i,o,s))return-1;let a=o+s;return this.valueHexView=i.subarray(o,a),this.valueHexView.length?(this.blockLength=s,a):(this.warnings.push("Zero buffer length"),o)}toBER(n=!1){return this.isHexOnly?n?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.byteLength===this.valueHexView.buffer.byteLength?this.valueHexView.buffer:this.valueHexView.slice().buffer:(this.error="Flag 'isHexOnly' is not set, abort",ft)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Y.Convert.ToHex(this.valueHexView)}}},e.NAME="hexBlock",e}var Mt=class{constructor({blockLength:e=0,error:t=Rn,warnings:n=[],valueBeforeDecode:o=wc}={}){this.blockLength=e,this.error=t,this.warnings=n,this.valueBeforeDecodeView=Y.BufferSourceConverter.toUint8Array(o)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(e){this.valueBeforeDecodeView=new Uint8Array(e)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:Y.Convert.ToHex(this.valueBeforeDecodeView)}}};Mt.NAME="baseBlock";var Ce=class extends Mt{fromBER(e,t,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(e,t){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};Ce.NAME="valueBlock";var xs=class extends qt(Mt){constructor({idBlock:e={}}={}){var t,n,o,s;super(),e?(this.isHexOnly=(t=e.isHexOnly)!==null&&t!==void 0?t:!1,this.valueHexView=e.valueHex?Y.BufferSourceConverter.toUint8Array(e.valueHex):wc,this.tagClass=(n=e.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(o=e.tagNumber)!==null&&o!==void 0?o:-1,this.isConstructed=(s=e.isConstructed)!==null&&s!==void 0?s:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(e=!1){let t=0;switch(this.tagClass){case 1:t|=0;break;case 2:t|=64;break;case 3:t|=128;break;case 4:t|=192;break;default:return this.error="Unknown tag class",ft}if(this.isConstructed&&(t|=32),this.tagNumber<31&&!this.isHexOnly){let o=new Uint8Array(1);if(!e){let s=this.tagNumber;s&=31,t|=s,o[0]=t}return o.buffer}if(!this.isHexOnly){let o=pr(this.tagNumber,7),s=new Uint8Array(o),i=o.byteLength,a=new Uint8Array(i+1);if(a[0]=t|31,!e){for(let c=0;c<i-1;c++)a[c+1]=s[c]|128;a[i]=s[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=t|31,!e){let o=this.valueHexView;for(let s=0;s<o.length-1;s++)n[s+1]=o[s]|128;n[this.valueHexView.byteLength]=o[o.length-1]}return n.buffer}fromBER(e,t,n){let o=Y.BufferSourceConverter.toUint8Array(e);if(!Kt(this,o,t,n))return-1;let s=o.subarray(t,t+n);if(s.length===0)return this.error="Zero buffer length",-1;switch(s[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(s[0]&32)===32,this.isHexOnly=!1;let a=s[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,f=this.valueHexView=new Uint8Array(255),u=255;for(;s[c]&128;){if(f[c-1]=s[c]&127,c++,c>=s.length)return this.error="End of input reached before message was fully decoded",-1;if(c===u){u+=255;let p=new Uint8Array(u);for(let E=0;E<f.length;E++)p[E]=f[E];f=this.valueHexView=new Uint8Array(u)}}this.blockLength=c+1,f[c-1]=s[c]&127;let l=new Uint8Array(c);for(let p=0;p<c;p++)l[p]=f[p];f=this.valueHexView=new Uint8Array(c),f.set(l),this.blockLength<=9?this.tagNumber=Or(f,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return t+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};xs.NAME="identificationBlock";var Es=class extends Mt{constructor({lenBlock:e={}}={}){var t,n,o;super(),this.isIndefiniteForm=(t=e.isIndefiniteForm)!==null&&t!==void 0?t:!1,this.longFormUsed=(n=e.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(o=e.length)!==null&&o!==void 0?o:0}fromBER(e,t,n){let o=Y.BufferSourceConverter.toUint8Array(e);if(!Kt(this,o,t,n))return-1;let s=o.subarray(t,t+n);if(s.length===0)return this.error="Zero buffer length",-1;if(s[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=s[0]===128,this.isIndefiniteForm)return this.blockLength=1,t+this.blockLength;if(this.longFormUsed=!!(s[0]&128),this.longFormUsed===!1)return this.length=s[0],this.blockLength=1,t+this.blockLength;let i=s[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>s.length)return this.error="End of input reached before message was fully decoded",-1;let a=t+1,c=o.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Or(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,t+this.blockLength}toBER(e=!1){let t,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=128),t;if(this.longFormUsed){let o=pr(this.length,8);if(o.byteLength>127)return this.error="Too big length",ft;if(t=new ArrayBuffer(o.byteLength+1),e)return t;let s=new Uint8Array(o);n=new Uint8Array(t),n[0]=o.byteLength|128;for(let i=0;i<o.byteLength;i++)n[i+1]=s[i];return t}return t=new ArrayBuffer(1),e===!1&&(n=new Uint8Array(t),n[0]=this.length),t}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Es.NAME="lengthBlock";var U={},ke=class extends Mt{constructor({name:e=Rn,optional:t=!1,primitiveSchema:n,...o}={},s){super(o),this.name=e,this.optional=t,n&&(this.primitiveSchema=n),this.idBlock=new xs(o),this.lenBlock=new Es(o),this.valueBlock=s?new s(o):new Ce(o)}fromBER(e,t,n){let o=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return o===-1?(this.error=this.valueBlock.error,o):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),o)}toBER(e,t){let n=t||new io;t||yf(this);let o=this.idBlock.toBER(e);if(n.write(o),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(e,n),n.write(new ArrayBuffer(2));else{let s=this.valueBlock.toBER(e);this.lenBlock.length=s.byteLength;let i=this.lenBlock.toBER(e);n.write(i),n.write(s)}return t?ft:n.final()}toJSON(){let e={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(e.primitiveSchema=this.primitiveSchema.toJSON()),e}toString(e="ascii"){return e==="ascii"?this.onAsciiEncoding():Y.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${Y.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(e){if(this===e)return!0;if(!(e instanceof this.constructor))return!1;let t=this.toBER(),n=e.toBER();return ff(t,n)}};ke.NAME="BaseBlock";function yf(r){if(r instanceof U.Constructed)for(let e of r.valueBlock.value)yf(e)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var vs=class extends ke{constructor({value:e=Rn,...t}={},n){super(t,n),e&&this.fromString(e)}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}fromBER(e,t,n){let o=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return o===-1?(this.error=this.valueBlock.error,o):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),o)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};vs.NAME="BaseStringBlock";var As=class extends qt(Ce){constructor({isHexOnly:e=!0,...t}={}){super(t),this.isHexOnly=e}};As.NAME="PrimitiveValueBlock";var gf,Bs=class extends ke{constructor(e={}){super(e,As),this.idBlock.isConstructed=!1}};gf=Bs;U.Primitive=gf;Bs.NAME="PRIMITIVE";function hg(r,e){if(r instanceof e)return r;let t=new e;return t.idBlock=r.idBlock,t.lenBlock=r.lenBlock,t.warnings=r.warnings,t.valueBeforeDecodeView=r.valueBeforeDecodeView,t}function ni(r,e=0,t=r.length){let n=e,o=new ke({},Ce),s=new Mt;if(!Kt(s,r,e,t))return o.error=s.error,{offset:-1,result:o};if(!r.subarray(e,e+t).length)return o.error="Zero buffer length",{offset:-1,result:o};let a=o.idBlock.fromBER(r,e,t);if(o.idBlock.warnings.length&&o.warnings.concat(o.idBlock.warnings),a===-1)return o.error=o.idBlock.error,{offset:-1,result:o};if(e=a,t-=o.idBlock.blockLength,a=o.lenBlock.fromBER(r,e,t),o.lenBlock.warnings.length&&o.warnings.concat(o.lenBlock.warnings),a===-1)return o.error=o.lenBlock.error,{offset:-1,result:o};if(e=a,t-=o.lenBlock.blockLength,!o.idBlock.isConstructed&&o.lenBlock.isIndefiniteForm)return o.error="Indefinite length form used for primitive encoding form",{offset:-1,result:o};let c=ke;switch(o.idBlock.tagClass){case 1:if(o.idBlock.tagNumber>=37&&o.idBlock.isHexOnly===!1)return o.error="UNIVERSAL 37 and upper tags are reserved by ASN.1 standard",{offset:-1,result:o};switch(o.idBlock.tagNumber){case 0:if(o.idBlock.isConstructed&&o.lenBlock.length>0)return o.error="Type [UNIVERSAL 0] is reserved",{offset:-1,result:o};c=U.EndOfContent;break;case 1:c=U.Boolean;break;case 2:c=U.Integer;break;case 3:c=U.BitString;break;case 4:c=U.OctetString;break;case 5:c=U.Null;break;case 6:c=U.ObjectIdentifier;break;case 10:c=U.Enumerated;break;case 12:c=U.Utf8String;break;case 13:c=U.RelativeObjectIdentifier;break;case 14:c=U.TIME;break;case 15:return o.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:o};case 16:c=U.Sequence;break;case 17:c=U.Set;break;case 18:c=U.NumericString;break;case 19:c=U.PrintableString;break;case 20:c=U.TeletexString;break;case 21:c=U.VideotexString;break;case 22:c=U.IA5String;break;case 23:c=U.UTCTime;break;case 24:c=U.GeneralizedTime;break;case 25:c=U.GraphicString;break;case 26:c=U.VisibleString;break;case 27:c=U.GeneralString;break;case 28:c=U.UniversalString;break;case 29:c=U.CharacterString;break;case 30:c=U.BmpString;break;case 31:c=U.DATE;break;case 32:c=U.TimeOfDay;break;case 33:c=U.DateTime;break;case 34:c=U.Duration;break;default:{let f=o.idBlock.isConstructed?new U.Constructed:new U.Primitive;f.idBlock=o.idBlock,f.lenBlock=o.lenBlock,f.warnings=o.warnings,o=f}}break;case 2:case 3:case 4:default:c=o.idBlock.isConstructed?U.Constructed:U.Primitive}return o=hg(o,c),a=o.fromBER(r,e,o.lenBlock.isIndefiniteForm?t:o.lenBlock.length),o.valueBeforeDecodeView=r.subarray(n,n+o.blockLength),{offset:a,result:o}}function _n(r){if(!r.byteLength){let e=new ke({},Ce);return e.error="Input buffer has zero length",{offset:-1,result:e}}return ni(Y.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function dg(r,e){return r?1:e}var xt=class extends Ce{constructor({value:e=[],isIndefiniteForm:t=!1,...n}={}){super(n),this.value=e,this.isIndefiniteForm=t}fromBER(e,t,n){let o=Y.BufferSourceConverter.toUint8Array(e);if(!Kt(this,o,t,n))return-1;if(this.valueBeforeDecodeView=o.subarray(t,t+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),t;let s=t;for(;dg(this.isIndefiniteForm,n)>0;){let i=ni(o,s,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(s=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===ao)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===ao?this.value.pop():this.warnings.push("No EndOfContent block encoded")),s}toBER(e,t){let n=t||new io;for(let o=0;o<this.value.length;o++)this.value[o].toBER(e,n);return t?ft:n.final()}toJSON(){let e={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let t of this.value)e.value.push(t.toJSON());return e}};xt.NAME="ConstructedValueBlock";var wf,mr=class extends ke{constructor(e={}){super(e,xt),this.idBlock.isConstructed=!0}fromBER(e,t,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let o=this.valueBlock.fromBER(e,t,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return o===-1?(this.error=this.valueBlock.error,o):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),o)}onAsciiEncoding(){let e=[];for(let n of this.valueBlock.value)e.push(n.toString("ascii").split(`
2
+ "use strict";var HeliaHttp=(()=>{var vm=Object.create;var jo=Object.defineProperty;var Am=Object.getOwnPropertyDescriptor;var Bm=Object.getOwnPropertyNames;var km=Object.getPrototypeOf,Sm=Object.prototype.hasOwnProperty;var Oe=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),xt=(r,t)=>{for(var e in t)jo(r,e,{get:t[e],enumerable:!0})},Gu=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Bm(t))!Sm.call(r,o)&&o!==e&&jo(r,o,{get:()=>t[o],enumerable:!(n=Am(t,o))||n.enumerable});return r};var oe=(r,t,e)=>(e=r!=null?vm(km(r)):{},Gu(t||!r||!r.__esModule?jo(e,"default",{value:r,enumerable:!0}):e,r)),Im=r=>Gu(jo({},"__esModule",{value:!0}),r);var Jl=Oe((Hv,Zl)=>{var un=1e3,ln=un*60,fn=ln*60,Pr=fn*24,uy=Pr*7,ly=Pr*365.25;Zl.exports=function(r,t){t=t||{};var e=typeof r;if(e==="string"&&r.length>0)return fy(r);if(e==="number"&&isFinite(r))return t.long?dy(r):hy(r);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(r))};function fy(r){if(r=String(r),!(r.length>100)){var t=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(r);if(t){var e=parseFloat(t[1]),n=(t[2]||"ms").toLowerCase();switch(n){case"years":case"year":case"yrs":case"yr":case"y":return e*ly;case"weeks":case"week":case"w":return e*uy;case"days":case"day":case"d":return e*Pr;case"hours":case"hour":case"hrs":case"hr":case"h":return e*fn;case"minutes":case"minute":case"mins":case"min":case"m":return e*ln;case"seconds":case"second":case"secs":case"sec":case"s":return e*un;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return e;default:return}}}}function hy(r){var t=Math.abs(r);return t>=Pr?Math.round(r/Pr)+"d":t>=fn?Math.round(r/fn)+"h":t>=ln?Math.round(r/ln)+"m":t>=un?Math.round(r/un)+"s":r+"ms"}function dy(r){var t=Math.abs(r);return t>=Pr?ps(r,t,Pr,"day"):t>=fn?ps(r,t,fn,"hour"):t>=ln?ps(r,t,ln,"minute"):t>=un?ps(r,t,un,"second"):r+" ms"}function ps(r,t,e,n){var o=t>=e*1.5;return Math.round(r/e)+" "+n+(o?"s":"")}});var Ql=Oe((Kv,Xl)=>{function py(r){e.debug=e,e.default=e,e.coerce=c,e.disable=s,e.enable=o,e.enabled=i,e.humanize=Jl(),e.destroy=u,Object.keys(r).forEach(l=>{e[l]=r[l]}),e.names=[],e.skips=[],e.formatters={};function t(l){let f=0;for(let h=0;h<l.length;h++)f=(f<<5)-f+l.charCodeAt(h),f|=0;return e.colors[Math.abs(f)%e.colors.length]}e.selectColor=t;function e(l){let f,h=null,g,y;function p(...m){if(!p.enabled)return;let w=p,I=Number(new Date),v=I-(f||I);w.diff=v,w.prev=f,w.curr=I,f=I,m[0]=e.coerce(m[0]),typeof m[0]!="string"&&m.unshift("%O");let U=0;m[0]=m[0].replace(/%([a-zA-Z%])/g,(_,L)=>{if(_==="%%")return"%";U++;let b=e.formatters[L];if(typeof b=="function"){let C=m[U];_=b.call(w,C),m.splice(U,1),U--}return _}),e.formatArgs.call(w,m),(w.log||e.log).apply(w,m)}return p.namespace=l,p.useColors=e.useColors(),p.color=e.selectColor(l),p.extend=n,p.destroy=e.destroy,Object.defineProperty(p,"enabled",{enumerable:!0,configurable:!1,get:()=>h!==null?h:(g!==e.namespaces&&(g=e.namespaces,y=e.enabled(l)),y),set:m=>{h=m}}),typeof e.init=="function"&&e.init(p),p}function n(l,f){let h=e(this.namespace+(typeof f>"u"?":":f)+l);return h.log=this.log,h}function o(l){e.save(l),e.namespaces=l,e.names=[],e.skips=[];let f,h=(typeof l=="string"?l:"").split(/[\s,]+/),g=h.length;for(f=0;f<g;f++)h[f]&&(l=h[f].replace(/\*/g,".*?"),l[0]==="-"?e.skips.push(new RegExp("^"+l.slice(1)+"$")):e.names.push(new RegExp("^"+l+"$")))}function s(){let l=[...e.names.map(a),...e.skips.map(a).map(f=>"-"+f)].join(",");return e.enable(""),l}function i(l){if(l[l.length-1]==="*")return!0;let f,h;for(f=0,h=e.skips.length;f<h;f++)if(e.skips[f].test(l))return!1;for(f=0,h=e.names.length;f<h;f++)if(e.names[f].test(l))return!0;return!1}function a(l){return l.toString().substring(2,l.toString().length-2).replace(/\.\*\?$/,"*")}function c(l){return l instanceof Error?l.stack||l.message:l}function u(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return e.enable(e.load()),e}Xl.exports=py});var tf=Oe((jt,ms)=>{jt.formatArgs=yy;jt.save=gy;jt.load=wy;jt.useColors=my;jt.storage=by();jt.destroy=(()=>{let r=!1;return()=>{r||(r=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})();jt.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function my(){return typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs)?!0:typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)?!1:typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function yy(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+ms.exports.humanize(this.diff),!this.useColors)return;let t="color: "+this.color;r.splice(1,0,t,"color: inherit");let e=0,n=0;r[0].replace(/%[a-zA-Z%]/g,o=>{o!=="%%"&&(e++,o==="%c"&&(n=e))}),r.splice(n,0,t)}jt.log=console.debug||console.log||(()=>{});function gy(r){try{r?jt.storage.setItem("debug",r):jt.storage.removeItem("debug")}catch{}}function wy(){let r;try{r=jt.storage.getItem("debug")}catch{}return!r&&typeof process<"u"&&"env"in process&&(r=process.env.DEBUG),r}function by(){try{return localStorage}catch{}}ms.exports=Ql()(jt);var{formatters:xy}=ms.exports;xy.j=function(r){try{return JSON.stringify(r)}catch(t){return"[UnexpectedJSONParseError]: "+t.message}}});var hn=Oe((zv,rf)=>{"use strict";function ef(r,t){for(let e in t)Object.defineProperty(r,e,{value:t[e],enumerable:!0,configurable:!0});return r}function Ay(r,t,e){if(!r||typeof r=="string")throw new TypeError("Please pass an Error to err-code");e||(e={}),typeof t=="object"&&(e=t,t=""),t&&(e.code=t);try{return ef(r,e)}catch{e.message=r.message,e.stack=r.stack;let o=function(){};return o.prototype=Object.create(Object.getPrototypeOf(r)),ef(new o,e)}}rf.exports=Ay});var mf=Oe(fo=>{(function(){var r,t,e,n,o,s,i,a;a=function(c){var u,l,f,h;return u=(c&255<<24)>>>24,l=(c&255<<16)>>>16,f=(c&65280)>>>8,h=c&255,[u,l,f,h].join(".")},i=function(c){var u,l,f,h,g,y;for(u=[],f=h=0;h<=3&&c.length!==0;f=++h){if(f>0){if(c[0]!==".")throw new Error("Invalid IP");c=c.substring(1)}y=t(c),g=y[0],l=y[1],c=c.substring(l),u.push(g)}if(c.length!==0)throw new Error("Invalid IP");switch(u.length){case 1:if(u[0]>4294967295)throw new Error("Invalid IP");return u[0]>>>0;case 2:if(u[0]>255||u[1]>16777215)throw new Error("Invalid IP");return(u[0]<<24|u[1])>>>0;case 3:if(u[0]>255||u[1]>255||u[2]>65535)throw new Error("Invalid IP");return(u[0]<<24|u[1]<<16|u[2])>>>0;case 4:if(u[0]>255||u[1]>255||u[2]>255||u[3]>255)throw new Error("Invalid IP");return(u[0]<<24|u[1]<<16|u[2]<<8|u[3])>>>0;default:throw new Error("Invalid IP")}},e=function(c){return c.charCodeAt(0)},n=e("0"),s=e("a"),o=e("A"),t=function(c){var u,l,f,h,g;for(h=0,u=10,l="9",f=0,c.length>1&&c[f]==="0"&&(c[f+1]==="x"||c[f+1]==="X"?(f+=2,u=16):"0"<=c[f+1]&&c[f+1]<="9"&&(f++,u=8,l="7")),g=f;f<c.length;){if("0"<=c[f]&&c[f]<=l)h=h*u+(e(c[f])-n)>>>0;else if(u===16)if("a"<=c[f]&&c[f]<="f")h=h*u+(10+e(c[f])-s)>>>0;else if("A"<=c[f]&&c[f]<="F")h=h*u+(10+e(c[f])-o)>>>0;else break;else break;if(h>4294967295)throw new Error("too large");f++}if(f===g)throw new Error("empty octet");return[h,f]},r=function(){function c(u,l){var f,h,g,y;if(typeof u!="string")throw new Error("Missing `net' parameter");if(l||(y=u.split("/",2),u=y[0],l=y[1]),l||(l=32),typeof l=="string"&&l.indexOf(".")>-1){try{this.maskLong=i(l)}catch(p){throw f=p,new Error("Invalid mask: "+l)}for(h=g=32;g>=0;h=--g)if(this.maskLong===4294967295<<32-h>>>0){this.bitmask=h;break}}else if(l||l===0)this.bitmask=parseInt(l,10),this.maskLong=0,this.bitmask>0&&(this.maskLong=4294967295<<32-this.bitmask>>>0);else throw new Error("Invalid mask: empty");try{this.netLong=(i(u)&this.maskLong)>>>0}catch(p){throw f=p,new Error("Invalid net address: "+u)}if(!(this.bitmask<=32))throw new Error("Invalid mask for ip4: "+l);this.size=Math.pow(2,32-this.bitmask),this.base=a(this.netLong),this.mask=a(this.maskLong),this.hostmask=a(~this.maskLong),this.first=this.bitmask<=30?a(this.netLong+1):this.base,this.last=this.bitmask<=30?a(this.netLong+this.size-2):a(this.netLong+this.size-1),this.broadcast=this.bitmask<=30?a(this.netLong+this.size-1):void 0}return c.prototype.contains=function(u){return typeof u=="string"&&(u.indexOf("/")>0||u.split(".").length!==4)&&(u=new c(u)),u instanceof c?this.contains(u.base)&&this.contains(u.broadcast||u.last):(i(u)&this.maskLong)>>>0===(this.netLong&this.maskLong)>>>0},c.prototype.next=function(u){return u==null&&(u=1),new c(a(this.netLong+this.size*u),this.mask)},c.prototype.forEach=function(u){var l,f,h;for(h=i(this.first),f=i(this.last),l=0;h<=f;)u(a(h),h,l),l++,h++},c.prototype.toString=function(){return this.base+"/"+this.bitmask},c}(),fo.ip2long=i,fo.long2ip=a,fo.Netmask=r}).call(fo)});var Jf=Oe(Dn=>{"use strict";var uw="[object ArrayBuffer]",je=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===uw}static toArrayBuffer(t){return this.isArrayBuffer(t)?t:t.byteLength===t.buffer.byteLength||t.byteOffset===0&&t.byteLength===t.buffer.byteLength?t.buffer:this.toUint8Array(t.buffer).slice(t.byteOffset,t.byteOffset+t.byteLength).buffer}static toUint8Array(t){return this.toView(t,Uint8Array)}static toView(t,e){if(t.constructor===e)return t;if(this.isArrayBuffer(t))return new e(t);if(this.isArrayBufferView(t))return new e(t.buffer,t.byteOffset,t.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(t){return this.isArrayBufferView(t)||this.isArrayBuffer(t)}static isArrayBufferView(t){return ArrayBuffer.isView(t)||t&&this.isArrayBuffer(t.buffer)}static isEqual(t,e){let n=r.toUint8Array(t),o=r.toUint8Array(e);if(n.length!==o.byteLength)return!1;for(let s=0;s<n.length;s++)if(n[s]!==o[s])return!1;return!0}static concat(...t){let e;Array.isArray(t[0])&&!(t[1]instanceof Function)||Array.isArray(t[0])&&t[1]instanceof Function?e=t[0]:t[t.length-1]instanceof Function?e=t.slice(0,t.length-1):e=t;let n=0;for(let i of e)n+=i.byteLength;let o=new Uint8Array(n),s=0;for(let i of e){let a=this.toUint8Array(i);o.set(a,s),s+=a.length}return t[t.length-1]instanceof Function?this.toView(o,t[t.length-1]):o.buffer}},$c="string",lw=/^[0-9a-f]+$/i,fw=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,hw=/^[a-zA-Z0-9-_]+$/,Os=class{static fromString(t){let e=unescape(encodeURIComponent(t)),n=new Uint8Array(e.length);for(let o=0;o<e.length;o++)n[o]=e.charCodeAt(o);return n.buffer}static toString(t){let e=je.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return decodeURIComponent(escape(n))}},ce=class{static toString(t,e=!1){let n=je.toArrayBuffer(t),o=new DataView(n),s="";for(let i=0;i<n.byteLength;i+=2){let a=o.getUint16(i,e);s+=String.fromCharCode(a)}return s}static fromString(t,e=!1){let n=new ArrayBuffer(t.length*2),o=new DataView(n);for(let s=0;s<t.length;s++)o.setUint16(s*2,t.charCodeAt(s),e);return n}},Fs=class r{static isHex(t){return typeof t===$c&&lw.test(t)}static isBase64(t){return typeof t===$c&&fw.test(t)}static isBase64Url(t){return typeof t===$c&&hw.test(t)}static ToString(t,e="utf8"){let n=je.toUint8Array(t);switch(e.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return ce.toString(n,!0);case"utf16":case"utf16be":return ce.toString(n);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromString(t,e="utf8"){if(!t)return new ArrayBuffer(0);switch(e.toLowerCase()){case"utf8":return this.FromUtf8String(t);case"binary":return this.FromBinary(t);case"hex":return this.FromHex(t);case"base64":return this.FromBase64(t);case"base64url":return this.FromBase64Url(t);case"utf16le":return ce.fromString(t,!0);case"utf16":case"utf16be":return ce.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=je.toUint8Array(t);if(typeof btoa<"u"){let n=this.ToString(e,"binary");return btoa(n)}else return Buffer.from(e).toString("base64")}static FromBase64(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64(e))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(e)):new Uint8Array(Buffer.from(e,"base64")).buffer}static FromBase64Url(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isBase64Url(e))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(e.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(t){return this.ToBase64(t).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.FromBinary(t);case"utf8":return Os.fromString(t);case"utf16":case"utf16be":return ce.fromString(t);case"utf16le":case"usc2":return ce.fromString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToUtf8String(t,e=r.DEFAULT_UTF8_ENCODING){switch(e){case"ascii":return this.ToBinary(t);case"utf8":return Os.toString(t);case"utf16":case"utf16be":return ce.toString(t);case"utf16le":case"usc2":return ce.toString(t,!0);default:throw new Error(`Unknown type of encoding '${e}'`)}}static FromBinary(t){let e=t.length,n=new Uint8Array(e);for(let o=0;o<e;o++)n[o]=t.charCodeAt(o);return n.buffer}static ToBinary(t){let e=je.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return n}static ToHex(t){let e=je.toUint8Array(t),n="",o=e.length;for(let s=0;s<o;s++){let i=e[s];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(t){let e=this.formatString(t);if(!e)return new ArrayBuffer(0);if(!r.isHex(e))throw new TypeError("Argument 'hexString' is not HEX encoded");e.length%2&&(e=`0${e}`);let n=new Uint8Array(e.length/2);for(let o=0;o<e.length;o=o+2){let s=e.slice(o,o+2);n[o/2]=parseInt(s,16)}return n.buffer}static ToUtf16String(t,e=!1){return ce.toString(t,e)}static FromUtf16String(t,e=!1){return ce.fromString(t,e)}static Base64Padding(t){let e=4-t.length%4;if(e<4)for(let n=0;n<e;n++)t+="=";return t}static formatString(t){return t?.replace(/[\n\r\t ]/g,"")||""}};Fs.DEFAULT_UTF8_ENCODING="utf8";function dw(r,...t){let e=arguments[0];for(let n=1;n<arguments.length;n++){let o=arguments[n];for(let s in o)e[s]=o[s]}return e}function pw(...r){let t=r.map(o=>o.byteLength).reduce((o,s)=>o+s),e=new Uint8Array(t),n=0;return r.map(o=>new Uint8Array(o)).forEach(o=>{for(let s of o)e[n++]=s}),e.buffer}function mw(r,t){if(!(r&&t)||r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let o=0;o<r.byteLength;o++)if(e[o]!==n[o])return!1;return!0}Dn.BufferSourceConverter=je;Dn.Convert=Fs;Dn.assign=dw;Dn.combine=pw;Dn.isEqual=mw});var nu=Oe((Ck,ru)=>{var Nk=function(){typeof ru<"u"&&(ru.exports=p);var r=86400,t=3200,e=146097*t/400,n=r*e,o=1e3*n,s=864e13,i=4294967296,a=1e6,c="000000000",u=Math.trunc||function(b){var C=b-b%1;return C==0&&(b<0||b===0&&1/b!=1/0)?-0:C},l=p.prototype,f=(p.fromDate=function(b){return new p(+b)},p.fromInt64BE=U(0,1,2,3,0,4),p.fromInt64LE=U(3,2,1,0,4,0),p.fromString=function(T){var C,O=new p,T=(T+="").replace(/^\s*[+\-]?\d+/,function(H){var H=+H,X=1970+(H-1970)%400;return O.year=H-X,X}).replace(/(?:Z|([+\-]\d{2}):?(\d{2}))$/,function(V,H,X){return H<0&&(X*=-1),C=6e4*(60*+H+ +X),""}).replace(/\.\d+$/,function(V){return O.nano=+(V+c).substr(1,9),""}).split(/\D+/);if(1<T.length?T[1]--:T[1]=0,O.time=C=Date.UTC.apply(Date,T)-(C||0),isNaN(C))throw new TypeError("Invalid Date");return m(O)},p.fromTimeT=function(b){return I(b,0)},l.year=0,l.time=0,l.nano=0,l.addNano=function(b){return this.nano+=+b||0,this},l.getNano=function(){var b=m(this);return(b.time%1e3*a+ +b.nano+1e9)%1e9},l.getTimeT=function(){var C=m(this),b=Math.floor(C.time/1e3),C=C.year;return C&&(b+=C*e*r/t),b},l.getYear=function(){return this.toDate().getUTCFullYear()+this.year},l.toDate=function(){return w(m(this).time)},l.toJSON=function(){return this.toString().replace(/0{1,6}Z$/,"Z")},l.toString=function(b){var C=this,O=C.toDate(),T={H:function(){return _(O.getUTCHours())},L:function(){return L(O.getUTCMilliseconds(),3)},M:function(){return _(O.getUTCMinutes())},N:function(){return L(C.getNano(),9)},S:function(){return _(O.getUTCSeconds())},Y:function(){var V=C.getYear();return 999999<V?"+"+V:9999<V?"+"+L(V,6):0<=V?L(V,4):-999999<=V?"-"+L(-V,6):V},a:function(){return g[O.getUTCDay()]},b:function(){return h[O.getUTCMonth()]},d:function(){return _(O.getUTCDate())},e:function(){return function(V){return(9<V?"":" ")+(0|V)}(O.getUTCDate())},m:function(){return _(O.getUTCMonth()+1)}};return function V(H){return H.replace(/%./g,function(X){var k=X[1],E=y[k],k=T[k];return E?V(E):k?k():X})}(b||f)},l.writeInt64BE=v(0,1,2,3,0,4),l.writeInt64LE=v(3,2,1,0,4,0),"%Y-%m-%dT%H:%M:%S.%NZ"),h=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],g=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],y={"%":"%",F:"%Y-%m-%d",n:`
3
+ `,R:"%H:%M",T:"%H:%M:%S",t:" ",X:"%T",Z:"GMT",z:"+0000"};return p;function p(b,C,O){var T=this;if(!(T instanceof p))return new p(b,C,O);T.time=+b||0,T.nano=+C||0,T.year=+O||0,m(T)}function m(b){var C,O,T,V=b.year,H=b.time,X=b.nano,E=((X<0||a<=X)&&(X-=(O=Math.floor(X/a))*a,H+=O,O=1),V%t);return(H<-s||s<H||E)&&((C=u(H/o))&&(V+=C*t,H-=C*o),(T=w(H)).setUTCFullYear(E+T.getUTCFullYear()),T=(H=+T)+(C=u((V-=E)/t))*o,C&&-s<=T&&T<=s&&(V-=C*t,H=T),O=1),O&&(b.year=V,b.time=H,b.nano=X),b}function w(b){var C=new Date(0);return C.setTime(b),C}function I(V,T){V=+V||0;var O=u((T=(T|0)*i)/n)+u(V/n),T=T%n+V%n,V=u(T/n);return V&&(O+=V,T-=V*n),new p(1e3*T,0,O*t)}function v(b,C,O,T,V,H){return function(E,k){var B=m(this);E=E||new Array(8),S(E,k|=0);var x=Math.floor(B.time/1e3),B=B.year*(e*r/t),$=u(B/i)+u(x/i),B=B%i+x%i,x=Math.floor(B/i);return x&&($+=x,B-=x*i),X(E,k+V,$),X(E,k+H,B),E};function X(E,k,$){E[k+b]=$>>24&255,E[k+C]=$>>16&255,E[k+O]=$>>8&255,E[k+T]=255&$}}function U(b,C,O,T,V,H){return function(E,k){S(E,k|=0);var $=X(E,k+V);return I(X(E,k+H),$)};function X(E,k){return 16777216*E[k+b]+(E[k+C]<<16|E[k+O]<<8|E[k+T])}}function S(b,C){if(b=b&&b.length,b==null)throw new TypeError("Invalid Buffer");if(b<C+8)throw new RangeError("Out of range")}function _(b){return(9<b?"":"0")+(0|b)}function L(b,C){return(c+(0|b)).substr(-C)}}()});var Ep=Oe((mS,du)=>{"use strict";var Lb=Object.prototype.hasOwnProperty,Ht="~";function Vo(){}Object.create&&(Vo.prototype=Object.create(null),new Vo().__proto__||(Ht=!1));function Ub(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function xp(r,t,e,n,o){if(typeof e!="function")throw new TypeError("The listener must be a function");var s=new Ub(e,n||r,o),i=Ht?Ht+t:t;return r._events[i]?r._events[i].fn?r._events[i]=[r._events[i],s]:r._events[i].push(s):(r._events[i]=s,r._eventsCount++),r}function qi(r,t){--r._eventsCount===0?r._events=new Vo:delete r._events[t]}function Ot(){this._events=new Vo,this._eventsCount=0}Ot.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)Lb.call(e,n)&&t.push(Ht?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};Ot.prototype.listeners=function(t){var e=Ht?Ht+t:t,n=this._events[e];if(!n)return[];if(n.fn)return[n.fn];for(var o=0,s=n.length,i=new Array(s);o<s;o++)i[o]=n[o].fn;return i};Ot.prototype.listenerCount=function(t){var e=Ht?Ht+t:t,n=this._events[e];return n?n.fn?1:n.length:0};Ot.prototype.emit=function(t,e,n,o,s,i){var a=Ht?Ht+t:t;if(!this._events[a])return!1;var c=this._events[a],u=arguments.length,l,f;if(c.fn){switch(c.once&&this.removeListener(t,c.fn,void 0,!0),u){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,e),!0;case 3:return c.fn.call(c.context,e,n),!0;case 4:return c.fn.call(c.context,e,n,o),!0;case 5:return c.fn.call(c.context,e,n,o,s),!0;case 6:return c.fn.call(c.context,e,n,o,s,i),!0}for(f=1,l=new Array(u-1);f<u;f++)l[f-1]=arguments[f];c.fn.apply(c.context,l)}else{var h=c.length,g;for(f=0;f<h;f++)switch(c[f].once&&this.removeListener(t,c[f].fn,void 0,!0),u){case 1:c[f].fn.call(c[f].context);break;case 2:c[f].fn.call(c[f].context,e);break;case 3:c[f].fn.call(c[f].context,e,n);break;case 4:c[f].fn.call(c[f].context,e,n,o);break;default:if(!l)for(g=1,l=new Array(u-1);g<u;g++)l[g-1]=arguments[g];c[f].fn.apply(c[f].context,l)}}return!0};Ot.prototype.on=function(t,e,n){return xp(this,t,e,n,!1)};Ot.prototype.once=function(t,e,n){return xp(this,t,e,n,!0)};Ot.prototype.removeListener=function(t,e,n,o){var s=Ht?Ht+t:t;if(!this._events[s])return this;if(!e)return qi(this,s),this;var i=this._events[s];if(i.fn)i.fn===e&&(!o||i.once)&&(!n||i.context===n)&&qi(this,s);else{for(var a=0,c=[],u=i.length;a<u;a++)(i[a].fn!==e||o&&!i[a].once||n&&i[a].context!==n)&&c.push(i[a]);c.length?this._events[s]=c.length===1?c[0]:c:qi(this,s)}return this};Ot.prototype.removeAllListeners=function(t){var e;return t?(e=Ht?Ht+t:t,this._events[e]&&qi(this,e)):(this._events=new Vo,this._eventsCount=0),this};Ot.prototype.off=Ot.prototype.removeListener;Ot.prototype.addListener=Ot.prototype.on;Ot.prefixed=Ht;Ot.EventEmitter=Ot;typeof du<"u"&&(du.exports=Ot)});var Cp=Oe((wI,Np)=>{Np.exports=function(r){if(!r)throw Error("hashlru must have a max value, of type number, greater than 0");var t=0,e=Object.create(null),n=Object.create(null);function o(s,i){e[s]=i,t++,t>=r&&(t=0,n=e,e=Object.create(null))}return{has:function(s){return e[s]!==void 0||n[s]!==void 0},remove:function(s){e[s]!==void 0&&(e[s]=void 0),n[s]!==void 0&&(n[s]=void 0)},get:function(s){var i=e[s];if(i!==void 0)return i;if((i=n[s])!==void 0)return o(s,i),i},set:function(s,i){e[s]!==void 0?e[s]=i:o(s,i)},clear:function(){e=Object.create(null),n=Object.create(null)}}}});var bx={};xt(bx,{DEFAULT_SESSION_MAX_PROVIDERS:()=>Wu,DEFAULT_SESSION_MIN_PROVIDERS:()=>ju,DEFAULT_SESSION_PROVIDER_QUERY_CONCURRENCY:()=>Yu,DEFAULT_SESSION_PROVIDER_QUERY_TIMEOUT:()=>Zu,createHeliaHTTP:()=>wx});var ju=1,Wu=5,Yu=5,Zu=5e3;var Qn=Symbol.for("@libp2p/content-routing");var la=Symbol.for("@libp2p/peer-id");function Ju(r){return r!=null&&!!r[la]}var to=Symbol.for("@libp2p/peer-routing");var ir=class r extends Error{code;type;constructor(t="The operation was aborted"){super(t),this.name="AbortError",this.code=r.code,this.type=r.type}static code="ABORT_ERR";static type="aborted"},N=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var se=(r,...t)=>{try{[...t]}catch{}};var Wo=class extends EventTarget{#t=new Map;constructor(){super(),se(1/0,this)}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let o=this.#t.get(t);o==null&&(o=[],this.#t.set(t,o)),o.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let o=this.#t.get(t);o!=null&&(o=o.filter(({callback:s})=>s!==e),this.#t.set(t,o))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:o})=>!o),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new Rm(t,e))}},fa=class extends Event{detail;constructor(t,e){super(t,e),this.detail=e?.detail}},Rm=globalThis.CustomEvent??fa;function Xu(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function ar(...r){let t=[];for(let e of r)Xu(e)&&t.push(e);await Promise.all(t.map(async e=>{e.beforeStart!=null&&await e.beforeStart()})),await Promise.all(t.map(async e=>{await e.start()})),await Promise.all(t.map(async e=>{e.afterStart!=null&&await e.afterStart()}))}async function cr(...r){let t=[];for(let e of r)Xu(e)&&t.push(e);await Promise.all(t.map(async e=>{e.beforeStop!=null&&await e.beforeStop()})),await Promise.all(t.map(async e=>{await e.stop()})),await Promise.all(t.map(async e=>{e.afterStop!=null&&await e.afterStop()}))}function Nr(r){let t=new globalThis.AbortController;function e(){t.abort();for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",e)}for(let s of r){if(s?.aborted===!0){e();break}s?.addEventListener!=null&&s.addEventListener("abort",e)}function n(){for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",e)}let o=t.signal;return o.clear=n,o}function It(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Yo=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},Xr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Yo(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new Yo(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var ha=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Cr(r={}){return _m(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function _m(r,t){t=t??{};let e=t.onEnd,n=new Xr,o,s,i,a=It(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((m,w)=>{s=I=>{s=null,n.push(I);try{m(r(n))}catch(v){w(v)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=It()})}},u=m=>s!=null?s(m):(n.push(m),o),l=m=>(n=new Xr,s!=null?s({error:m}):(n.push({error:m}),o)),f=m=>{if(i)return o;if(t?.objectMode!==!0&&m?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return u({done:!1,value:m})},h=m=>i?o:(i=!0,m!=null?l(m):u({done:!0})),g=()=>(n=new Xr,h(),{done:!0}),y=m=>(h(m),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:g,throw:y,push:f,end:h,get readableLength(){return n.size},onEmpty:async m=>{let w=m?.signal;if(w?.throwIfAborted(),n.isEmpty())return;let I,v;w!=null&&(I=new Promise((U,S)=>{v=()=>{S(new ha)},w.addEventListener("abort",v)}));try{await Promise.race([a.promise,I])}finally{v!=null&&w!=null&&w?.removeEventListener("abort",v)}}},e==null)return o;let p=o;return o={[Symbol.asyncIterator](){return this},next(){return p.next()},throw(m){return p.throw(m),e!=null&&(e(m),e=void 0),{done:!0}},return(){return p.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(m){return p.end(m),e!=null&&(e(m),e=void 0),o},get readableLength(){return p.readableLength},onEmpty:m=>p.onEmpty(m)},o}var da=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=e??"ABORT_ERR"}};async function Zo(r,t,e,n){let o=new da(n?.errorMessage,n?.errorCode);return e?.aborted===!0?Promise.reject(o):new Promise((s,i)=>{let a=u=>{try{if(n?.filter?.(u)===!1)return}catch(l){r.removeEventListener(t,a),e?.removeEventListener("abort",c),i(l);return}r.removeEventListener(t,a),e?.removeEventListener("abort",c),s(u)},c=()=>{r.removeEventListener(t,a),e?.removeEventListener("abort",c),i(o)};r.addEventListener(t,a),e?.addEventListener("abort",c)})}var Jo=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=e??"ABORT_ERR"}};async function Qu(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new Jo(e?.errorMessage,e?.errorCode));let n,o=new Jo(e?.errorMessage,e?.errorCode);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var Xo=class{deferred;signal;where;constructor(t,e){this.signal=e,this.deferred=It(),this.where=t,this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(new ir)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function Tm(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var Qo=class{id;fn;options;priority;recipients;status;timeline;controller;constructor(t,e,n=0){this.id=Tm(),this.status="queued",this.fn=t,this.priority=n,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,se(1/0,this.controller.signal),this.onAbort=this.onAbort.bind(this)}abort(t){this.controller.abort(t)}onAbort(){this.recipients.reduce((e,n)=>e&&n.signal?.aborted===!0,!0)&&this.controller.abort(new ir)}async join(t={}){let e=new Xo(new Error("where").stack,t.signal);return this.recipients.push(e),t.signal?.addEventListener("abort",this.onAbort),e.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let t=await Qu(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(e=>{e.deferred.resolve(t)}),this.status="complete"}catch(t){this.recipients.forEach(e=>{e.deferred.reject(t)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(t=>{t.signal?.removeEventListener("abort",this.onAbort)})}};function Nm(r,t,e){let n=0,o=r.length;for(;o>0;){let s=Math.trunc(o/2),i=n+s;e(r[i],t)<=0?(n=++i,o-=s+1):o=s}return n}var Lr=class extends Wo{concurrency;queue;pending;constructor(t={}){super(),this.concurrency=t.concurrency??Number.POSITIVE_INFINITY,this.pending=0,t.metricName!=null&&t.metrics?.registerMetricGroup(t.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.queue=[]}tryToStartAnother(){if(this.size===0)return queueMicrotask(()=>{this.safeDispatchEvent("empty")}),this.running===0&&queueMicrotask(()=>{this.safeDispatchEvent("idle")}),!1;if(this.pending<this.concurrency){let t;for(let e of this.queue)if(e.status==="queued"){t=e;break}return t==null?!1:(this.safeDispatchEvent("active"),this.pending++,t.run().finally(()=>{for(let e=0;e<this.queue.length;e++)if(this.queue[e]===t){this.queue.splice(e,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(t){if(this.queue[this.size-1]?.priority>=t.priority){this.queue.push(t);return}let e=Nm(this.queue,t,(n,o)=>o.priority-n.priority);this.queue.splice(e,0,t)}async add(t,e){e?.signal?.throwIfAborted();let n=new Qo(t,e,e?.priority),o=n.join(e).then(s=>(this.safeDispatchEvent("completed",{detail:s}),this.safeDispatchEvent("success",{detail:{job:n,result:s}}),s)).catch(s=>{throw this.safeDispatchEvent("error",{detail:s}),this.safeDispatchEvent("failure",{detail:{job:n,error:s}}),s});return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),o}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(t=>{t.abort(new ir)}),this.clear()}async onEmpty(t){this.size!==0&&await Zo(this,"empty",t?.signal)}async onSizeLessThan(t,e){this.size<t||await Zo(this,"next",e?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await Zo(this,"idle",t?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(t){t?.signal?.throwIfAborted();let e=Cr({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),e.end(c)},o=c=>{c.detail!=null&&e.push(c.detail)},s=c=>{n(c.detail)},i=()=>{n()},a=()=>{n(new N("Queue aborted","ERR_QUEUE_ABORTED"))};this.addEventListener("completed",o),this.addEventListener("error",s),this.addEventListener("idle",i),t?.signal?.addEventListener("abort",a);try{yield*e}finally{this.removeEventListener("completed",o),this.removeEventListener("error",s),this.removeEventListener("idle",i),t?.signal?.removeEventListener("abort",a),n()}}};var ts=class extends Lr{has(t){return this.find(t)!=null}find(t){return this.queue.find(e=>t.equals(e.options.peerId))}};var es=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",u=2**(8*o)-1;for(;;){let l=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let h=Number.parseInt(f,t);if(!Number.isNaN(h))return h});if(l===void 0)break;if(s*=t,s+=l,s>u||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&c&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let o=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[o]=i[0],e[o+1]=i[1],e[o+2]=i[2],e[o+3]=i[3],[o+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[o,!1];e[o]=s>>8,e[o+1]=s&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,o]=t(e);if(n===16)return e;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=t(s.subarray(0,i));return e.set(s.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var tl=45,Cm=15,Qr=new es;function pa(r){if(!(r.length>Cm))return Qr.new(r).parseWith(()=>Qr.readIPv4Addr())}function ma(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>tl))return Qr.new(r).parseWith(()=>Qr.readIPv6Addr())}function rs(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>tl))return Qr.new(r).parseWith(()=>Qr.readIPAddr())}function tn(r){return!!pa(r)}function en(r){return!!ma(r)}function ns(r){return!!rs(r)}var xa={};xt(xa,{base58btc:()=>ft,base58flickr:()=>Fm});var n1=new Uint8Array(0);function el(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Fe(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 rl(r){return new TextEncoder().encode(r)}function nl(r){return new TextDecoder().decode(r)}function Lm(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(e[i]!==255)throw new TypeError(s+" is ambiguous");e[i]=o}var a=r.length,c=r.charAt(0),u=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function f(y){if(y instanceof Uint8Array||(ArrayBuffer.isView(y)?y=new Uint8Array(y.buffer,y.byteOffset,y.byteLength):Array.isArray(y)&&(y=Uint8Array.from(y))),!(y instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(y.length===0)return"";for(var p=0,m=0,w=0,I=y.length;w!==I&&y[w]===0;)w++,p++;for(var v=(I-w)*l+1>>>0,U=new Uint8Array(v);w!==I;){for(var S=y[w],_=0,L=v-1;(S!==0||_<m)&&L!==-1;L--,_++)S+=256*U[L]>>>0,U[L]=S%a>>>0,S=S/a>>>0;if(S!==0)throw new Error("Non-zero carry");m=_,w++}for(var b=v-m;b!==v&&U[b]===0;)b++;for(var C=c.repeat(p);b<v;++b)C+=r.charAt(U[b]);return C}function h(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var p=0;if(y[p]!==" "){for(var m=0,w=0;y[p]===c;)m++,p++;for(var I=(y.length-p)*u+1>>>0,v=new Uint8Array(I);y[p];){var U=e[y.charCodeAt(p)];if(U===255)return;for(var S=0,_=I-1;(U!==0||S<w)&&_!==-1;_--,S++)U+=a*v[_]>>>0,v[_]=U%256>>>0,U=U/256>>>0;if(U!==0)throw new Error("Non-zero carry");w=S,p++}if(y[p]!==" "){for(var L=I-w;L!==I&&v[L]===0;)L++;for(var b=new Uint8Array(m+(I-L)),C=m;L!==I;)b[C++]=v[L++];return b}}}function g(y){var p=h(y);if(p)return p;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:h,decode:g}}var Um=Lm,Dm=Um,sl=Dm;var ya=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},ga=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){if(this.name=t,this.prefix=e,e.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=e.codePointAt(0),this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return il(this,t)}},wa=class{decoders;constructor(t){this.decoders=t}or(t){return il(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function il(r,t){return new wa({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var ba=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,o){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=o,this.encoder=new ya(t,e,n),this.decoder=new ga(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function rn({name:r,prefix:t,encode:e,decode:n}){return new ba(r,t,e,n)}function ur({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=sl(e,r);return rn({prefix:t,name:r,encode:n,decode:s=>Fe(o(s))})}function Pm(r,t,e,n){let o={};for(let l=0;l<t.length;++l)o[t[l]]=l;let s=r.length;for(;r[s-1]==="=";)--s;let i=new Uint8Array(s*e/8|0),a=0,c=0,u=0;for(let l=0;l<s;++l){let f=o[r[l]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|f,a+=e,a>=8&&(a-=8,i[u++]=255&c>>a)}if(a>=e||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return i}function Om(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,s+=t[o&a>>i];if(i!==0&&(s+=t[o&a<<e-i]),n)for(;s.length*e&7;)s+="=";return s}function dt({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return rn({prefix:t,name:r,encode(o){return Om(o,n,e)},decode(o){return Pm(o,n,e,r)}})}var ft=ur({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Fm=ur({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Ea={};xt(Ea,{base32:()=>Rt,base32hex:()=>$m,base32hexpad:()=>Km,base32hexpadupper:()=>qm,base32hexupper:()=>Hm,base32pad:()=>Vm,base32padupper:()=>Mm,base32upper:()=>al,base32z:()=>zm});var Rt=dt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),al=dt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Vm=dt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Mm=dt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),$m=dt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Hm=dt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Km=dt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),qm=dt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),zm=dt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Gm=ll,cl=128,jm=127,Wm=~jm,Ym=Math.pow(2,31);function ll(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Ym;)t[e++]=r&255|cl,r/=128;for(;r&Wm;)t[e++]=r&255|cl,r>>>=7;return t[e]=r|0,ll.bytes=e-n+1,t}var Zm=va,Jm=128,ul=127;function va(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw va.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&ul)<<o:(i&ul)*Math.pow(2,o),o+=7}while(i>=Jm);return va.bytes=s-n,e}var Xm=Math.pow(2,7),Qm=Math.pow(2,14),t0=Math.pow(2,21),e0=Math.pow(2,28),r0=Math.pow(2,35),n0=Math.pow(2,42),o0=Math.pow(2,49),s0=Math.pow(2,56),i0=Math.pow(2,63),a0=function(r){return r<Xm?1:r<Qm?2:r<t0?3:r<e0?4:r<r0?5:r<n0?6:r<o0?7:r<s0?8:r<i0?9:10},c0={encode:Gm,decode:Zm,encodingLength:a0},u0=c0,eo=u0;function ro(r,t=0){return[eo.decode(r,t),eo.decode.bytes]}function nn(r,t,e=0){return eo.encode(r,t,e),t}function on(r){return eo.encodingLength(r)}function ke(r,t){let e=t.byteLength,n=on(r),o=n+on(e),s=new Uint8Array(o+e);return nn(r,s,0),nn(e,s,n),s.set(t,o),new sn(r,e,t,s)}function Se(r){let t=Fe(r),[e,n]=ro(t),[o,s]=ro(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new sn(e,o,i,t)}function fl(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&el(r.bytes,e.bytes)}}var sn=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function hl(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return f0(e,Aa(r),t??ft.encoder);default:return h0(e,Aa(r),t??Rt.encoder)}}var dl=new WeakMap;function Aa(r){let t=dl.get(r);if(t==null){let e=new Map;return dl.set(r,e),e}return t}var ot=class r{code;version;multihash;bytes;"/";constructor(t,e,n,o){this.code=e,this.version=t,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==no)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==d0)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=ke(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&fl(t.multihash,n.multihash)}toString(t){return hl(this,t)}toJSON(){return{"/":hl(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:o,multihash:s,bytes:i}=e;return new r(n,o,s,i??pl(n,o,s.bytes))}else if(e[p0]===!0){let{version:n,multihash:o,code:s}=e,i=Se(o);return r.create(n,s,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==no)throw new Error(`Version 0 CID must use dag-pb (code: ${no}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=pl(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,no,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,o=Fe(t.subarray(n,n+e.multihashSize));if(o.byteLength!==e.multihashSize)throw new Error("Incorrect length");let s=o.subarray(e.multihashSize-e.digestSize),i=new sn(e.multihashCode,e.digestSize,s,o);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[f,h]=ro(t.subarray(e));return e+=h,f},o=n(),s=no;if(o===18?(o=0,e=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=e,a=n(),c=n(),u=e+c,l=u-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:l,size:u}}static parse(t,e){let[n,o]=l0(t,e),s=r.decode(o);if(s.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Aa(s).set(n,t),s}};function l0(r,t){switch(r[0]){case"Q":{let e=t??ft;return[ft.prefix,e.decode(`${ft.prefix}${r}`)]}case ft.prefix:{let e=t??ft;return[ft.prefix,e.decode(r)]}case Rt.prefix:{let e=t??Rt;return[Rt.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function f0(r,t,e){let{prefix:n}=e;if(n!==ft.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let o=t.get(n);if(o==null){let s=e.encode(r).slice(1);return t.set(n,s),s}else return o}function h0(r,t,e){let{prefix:n}=e,o=t.get(n);if(o==null){let s=e.encode(r);return t.set(n,s),s}else return o}var no=112,d0=18;function pl(r,t,e){let n=on(r),o=n+on(t),s=new Uint8Array(o+e.byteLength);return nn(r,s,0),nn(t,s,n),s.set(e,o),s}var p0=Symbol.for("@ipld/js-cid/CID");function ct(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}var Ba={};xt(Ba,{base10:()=>m0});var m0=ur({prefix:"9",name:"base10",alphabet:"0123456789"});var ka={};xt(ka,{base16:()=>y0,base16upper:()=>g0});var y0=dt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),g0=dt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Sa={};xt(Sa,{base2:()=>w0});var w0=dt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ia={};xt(Ia,{base256emoji:()=>A0});var ml=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}"),b0=ml.reduce((r,t,e)=>(r[e]=t,r),[]),x0=ml.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function E0(r){return r.reduce((t,e)=>(t+=b0[e],t),"")}function v0(r){let t=[];for(let e of r){let n=x0[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var A0=rn({prefix:"\u{1F680}",name:"base256emoji",encode:E0,decode:v0});var Ra={};xt(Ra,{base36:()=>lr,base36upper:()=>B0});var lr=ur({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),B0=ur({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ta={};xt(Ta,{base64:()=>fr,base64pad:()=>k0,base64url:()=>_a,base64urlpad:()=>S0});var fr=dt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),k0=dt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),_a=dt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),S0=dt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Na={};xt(Na,{base8:()=>I0});var I0=dt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ca={};xt(Ca,{identity:()=>R0});var R0=rn({prefix:"\0",name:"identity",encode:r=>nl(r),decode:r=>rl(r)});var R1=new TextEncoder,_1=new TextDecoder;var yl=512;var ss=85;var Ua={};xt(Ua,{identity:()=>ie});var wl=0,_0="identity",bl=Fe;function T0(r){return ke(wl,bl(r))}var ie={code:wl,name:_0,encode:bl,digest:T0};var Fa={};xt(Fa,{sha256:()=>Et,sha512:()=>Oa});function Pa({name:r,code:t,encode:e}){return new Da(r,t,e)}var Da=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?ke(this.code,e):e.then(n=>ke(this.code,n))}else throw Error("Unknown type, must be binary type")}};function El(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Et=Pa({name:"sha2-256",code:18,encode:El("SHA-256")}),Oa=Pa({name:"sha2-512",code:19,encode:El("SHA-512")});var hr={...Ca,...Sa,...Na,...Ba,...ka,...Ea,...Ra,...xa,...Ta,...Ia},H1={...Fa,...Ua};function de(r=0){return new Uint8Array(r)}function Al(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var vl=Al("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Va=Al("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=de(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),N0={utf8:vl,"utf-8":vl,hex:hr.base16,latin1:Va,ascii:Va,binary:Va,...hr},is=N0;function z(r,t="utf8"){let e=is[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var C0=Math.pow(2,7),L0=Math.pow(2,14),U0=Math.pow(2,21),Ma=Math.pow(2,28),$a=Math.pow(2,35),Ha=Math.pow(2,42),Ka=Math.pow(2,49),st=128,Ut=127;function Kt(r){if(r<C0)return 1;if(r<L0)return 2;if(r<U0)return 3;if(r<Ma)return 4;if(r<$a)return 5;if(r<Ha)return 6;if(r<Ka)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function qa(r,t,e=0){switch(Kt(r)){case 8:t[e++]=r&255|st,r/=128;case 7:t[e++]=r&255|st,r/=128;case 6:t[e++]=r&255|st,r/=128;case 5:t[e++]=r&255|st,r/=128;case 4:t[e++]=r&255|st,r>>>=7;case 3:t[e++]=r&255|st,r>>>=7;case 2:t[e++]=r&255|st,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function D0(r,t,e=0){switch(Kt(r)){case 8:t.set(e++,r&255|st),r/=128;case 7:t.set(e++,r&255|st),r/=128;case 6:t.set(e++,r&255|st),r/=128;case 5:t.set(e++,r&255|st),r/=128;case 4:t.set(e++,r&255|st),r>>>=7;case 3:t.set(e++,r&255|st),r>>>=7;case 2:t.set(e++,r&255|st),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function za(r,t){let e=r[t],n=0;if(n+=e&Ut,e<st||(e=r[t+1],n+=(e&Ut)<<7,e<st)||(e=r[t+2],n+=(e&Ut)<<14,e<st)||(e=r[t+3],n+=(e&Ut)<<21,e<st)||(e=r[t+4],n+=(e&Ut)*Ma,e<st)||(e=r[t+5],n+=(e&Ut)*$a,e<st)||(e=r[t+6],n+=(e&Ut)*Ha,e<st)||(e=r[t+7],n+=(e&Ut)*Ka,e<st))return n;throw new RangeError("Could not decode varint")}function P0(r,t){let e=r.get(t),n=0;if(n+=e&Ut,e<st||(e=r.get(t+1),n+=(e&Ut)<<7,e<st)||(e=r.get(t+2),n+=(e&Ut)<<14,e<st)||(e=r.get(t+3),n+=(e&Ut)<<21,e<st)||(e=r.get(t+4),n+=(e&Ut)*Ma,e<st)||(e=r.get(t+5),n+=(e&Ut)*$a,e<st)||(e=r.get(t+6),n+=(e&Ut)*Ha,e<st)||(e=r.get(t+7),n+=(e&Ut)*Ka,e<st))return n;throw new RangeError("Could not decode varint")}function an(r,t,e=0){return t==null&&(t=de(Kt(r))),t instanceof Uint8Array?qa(r,t,e):D0(r,t,e)}function Ur(r,t=0){return r instanceof Uint8Array?za(r,t):P0(r,t)}function Ft(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=de(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var cE=parseInt("0xFFFF",16),uE=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function Y(r,t="utf8"){let e=is[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}var Il=tn,$0=en,Ga=function(r){let t=0;if(r=r.toString().trim(),Il(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if($0(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=Il(e[n]),i;s&&(i=Ga(e[n]),e[n]=z(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,z(i.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let s=[n,1];for(n=9-e.length;n>0;n--)s.push("0");e.splice.apply(e,s)}let o=new Uint8Array(t+16);for(n=0;n<e.length;n++){let s=parseInt(e[n],16);o[t++]=s>>8&255,o[t++]=s&255}return o}throw new Error("invalid ip address")},Rl=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let o=[];for(let s=0;s<e;s++)o.push(r[t+s]);return o.join(".")}if(e===16){let o=[];for(let s=0;s<e;s+=2)o.push(n.getUint16(t+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var cn={},ja={},K0=[[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"]];K0.forEach(r=>{let t=q0(...r);ja[t.code]=t,cn[t.name]=t});function q0(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function G(r){if(typeof r=="number"){if(ja[r]!=null)return ja[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(cn[r]!=null)return cn[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var GE=G("ip4"),jE=G("ip6"),WE=G("ipcidr");function Ya(r,t){switch(G(r).code){case 4:case 41:return G0(t);case 42:return Nl(t);case 6:case 273:case 33:case 132:return Ll(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Nl(t);case 421:return Z0(t);case 444:return Cl(t);case 445:return Cl(t);case 466:return Y0(t);default:return z(t,"base16")}}function Za(r,t){switch(G(r).code){case 4:return _l(t);case 41:return _l(t);case 42:return Tl(t);case 6:case 273:case 33:case 132:return Ja(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Tl(t);case 421:return j0(t);case 444:return J0(t);case 445:return X0(t);case 466:return W0(t);default:return Y(t,"base16")}}var Wa=Object.values(hr).map(r=>r.decoder),z0=function(){let r=Wa[0].or(Wa[1]);return Wa.slice(2).forEach(t=>r=r.or(t)),r}();function _l(r){if(!ns(r))throw new Error("invalid ip address");return Ga(r)}function G0(r){let t=Rl(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!ns(t))throw new Error("invalid ip address");return t}function Ja(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Ll(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Tl(r){let t=Y(r),e=Uint8Array.from(an(t.length));return Ft([e,t],e.length+t.length)}function Nl(r){let t=Ur(r);if(r=r.slice(Kt(t)),r.length!==t)throw new Error("inconsistent lengths");return z(r)}function j0(r){let t;r[0]==="Q"||r[0]==="1"?t=Se(ft.decode(`z${r}`)).bytes:t=ot.parse(r).multihash.bytes;let e=Uint8Array.from(an(t.length));return Ft([e,t],e.length+t.length)}function W0(r){let t=z0.decode(r),e=Uint8Array.from(an(t.length));return Ft([e,t],e.length+t.length)}function Y0(r){let t=Ur(r),e=r.slice(Kt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+z(e,"base64url")}function Z0(r){let t=Ur(r),e=r.slice(Kt(t));if(e.length!==t)throw new Error("inconsistent lengths");return z(e,"base58btc")}function J0(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let e=Rt.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Ja(n);return Ft([e,o],e.length+o.length)}function X0(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let e=Rt.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=Ja(n);return Ft([e,o],e.length+o.length)}function Cl(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=z(t,"base32"),o=Ll(e);return`${n}:${o}`}function Ul(r){r=Xa(r);let t=[],e=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=G(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw Pl("invalid address: "+r);if(a.path===!0){n=Xa(o.slice(s).join("/")),t.push([a.code,Za(a.code,n)]),e.push([a.code,n]);break}let c=Za(a.code,o[s]);t.push([a.code,c]),e.push([a.code,Ya(a.code,c)])}return{string:Dl(e),bytes:tc(t),tuples:t,stringTuples:e,path:n}}function Qa(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=Ur(r,o),i=Kt(s),a=G(s),c=Q0(a,r.slice(o+i));if(c===0){t.push([s]),e.push([s]),o+=i;continue}let u=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw Pl("Invalid address Uint8Array: "+z(r,"base16"));t.push([s,u]);let l=Ya(s,u);if(e.push([s,l]),a.path===!0){n=l;break}}return{bytes:Uint8Array.from(r),string:Dl(e),tuples:t,stringTuples:e,path:n}}function Dl(r){let t=[];return r.map(e=>{let n=G(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Xa(t.join("/"))}function tc(r){return Ft(r.map(t=>{let e=G(t[0]),n=Uint8Array.from(an(e.code));return t.length>1&&t[1]!=null&&(n=Ft([n,t[1]])),n}))}function Q0(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Ur(t instanceof Uint8Array?t:Uint8Array.from(t));return e+Kt(e)}}function Xa(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function Pl(r){return new Error("Error parsing address: "+r)}var ty=Symbol.for("nodejs.util.inspect.custom"),ec=Symbol.for("@multiformats/js-multiaddr/multiaddr"),ey=[G("dns").code,G("dns4").code,G("dns6").code,G("dnsaddr").code],as=class r{bytes;#t;#e;#r;#i;[ec]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Qa(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Ul(t)}else if(Fl(t))e=Qa(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#t=e.string,this.#e=e.tuples,this.#r=e.stringTuples,this.#i=e.path}toString(){return this.#t}toJSON(){return this.toString()}toOptions(){let t,e,n,o,s="",i=G("tcp"),a=G("udp"),c=G("ip4"),u=G("ip6"),l=G("dns6"),f=G("ip6zone");for(let[g,y]of this.stringTuples())g===f.code&&(s=`%${y??""}`),ey.includes(g)&&(e=i.name,o=443,n=`${y??""}${s}`,t=g===l.code?6:4),(g===i.code||g===a.code)&&(e=G(g).name,o=parseInt(y??"")),(g===c.code||g===u.code)&&(e=G(g).name,n=`${y??""}${s}`,t=g===u.code?6:4);if(t==null||e==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:o}}protos(){return this.#e.map(([t])=>Object.assign({},G(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>G(t).name)}tuples(){return this.#e}stringTuples(){return this.#r}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),o=n.lastIndexOf(e);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,o))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(tc(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===cn.p2p.code&&t.push([n,o]),n===cn["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?z(ft.decode(`z${n}`),"base58btc"):z(ot.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#i}equals(t){return ct(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=Ol.get(e.name);if(n==null)throw new N(`no available resolver for ${e.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,t)).map(s=>Dr(s))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[ty](){return`Multiaddr(${this.#t})`}};var Ol=new Map;function Fl(r){return!!r?.[ec]}function Dr(r){return new as(r)}var ry=r=>r.toString().split("/").slice(1),oo=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),rt=r=>({match:t=>oo(e=>e===r).match(t),pattern:r}),ls=()=>({match:r=>oo(t=>typeof t=="string").match(r),pattern:"{string}"}),fs=()=>({match:r=>oo(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),_t=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{ft.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),cs=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{_a.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),Vt=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),Gt=(...r)=>({match:t=>{let e;for(let n of r){let o=n.match(t);o!==!1&&(e==null||o.length<e.length)&&(e=o)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),it=(...r)=>({match:t=>{for(let e of r){let n=e.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${r.map(t=>t.pattern).join(", ")})`});function mt(...r){function t(o){let s=ry(o);for(let i of r){let a=i.match(s);if(a===!1)return!1;s=a}return s}function e(o){return t(o)!==!1}function n(o){let s=t(o);return s===!1?!1:s.length===0}return{matches:e,exactMatch:n}}var nc=it(rt("dns4"),ls()),oc=it(rt("dns6"),ls()),sc=it(rt("dnsaddr"),ls()),Vl=it(rt("dns"),ls()),Av=mt(nc),Bv=mt(oc),kv=mt(sc),Ml=mt(Gt(Vl,sc,nc,oc)),$l=it(rt("ip4"),oo(tn)),Hl=it(rt("ip6"),oo(en)),Kl=Gt($l,Hl),Ie=Gt(Kl,Vl,nc,oc,sc),Sv=mt(Ie),Iv=mt($l),Rv=mt(Hl),_v=mt(Kl),hs=it(Ie,rt("tcp"),fs()),so=it(Ie,rt("udp"),fs()),ny=Gt(hs,so),Tv=mt(hs),Nv=mt(so),ic=it(so,rt("quic")),ds=it(so,rt("quic-v1")),oy=Gt(ic,ds),Cv=mt(ic),Lv=mt(ds),rc=Gt(Ie,hs,so,ic,ds),ql=Gt(it(rc,rt("ws"),Vt(_t()))),Uv=mt(ql),zl=Gt(it(rc,rt("wss"),Vt(_t())),it(rc,rt("tls"),rt("ws"),Vt(_t()))),Dv=mt(zl),Gl=it(ny,rt("webrtc-direct"),cs(),Vt(cs()),Vt(_t())),Pv=mt(Gl),jl=it(ds,rt("webtransport"),cs(),cs(),Vt(_t())),Ov=mt(jl),us=Gt(ql,zl,it(hs,Vt(_t())),it(oy,Vt(_t())),it(Ie,Vt(_t())),Gl,jl,_t()),Fv=mt(us),sy=it(us,rt("p2p-circuit"),_t()),Vv=mt(sy),iy=Gt(it(us,rt("p2p-circuit"),rt("webrtc"),_t()),it(us,rt("webrtc"),Vt(_t())),rt("webrtc")),Mv=mt(iy),ay=Gt(it(Ie,rt("tcp"),fs(),rt("http"),Vt(_t())),it(Ie,rt("http"),Vt(_t()))),Wl=mt(ay),cy=Gt(it(Ie,rt("tcp"),Gt(it(rt("443"),rt("http")),it(fs(),rt("https"))),Vt(_t())),it(Ie,rt("tls"),rt("http"),Vt(_t())),it(Ie,rt("https"),Vt(_t()))),Yl=mt(cy);function Ey(r){return r[Symbol.asyncIterator]!=null}function vy(r){if(Ey(r))return(async()=>{for await(let t of r);})();for(let t of r);}var Or=vy;function By(r){let[t,e]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>t.next(),push:o=>{n.push(o)},next:()=>n.length>0?{done:!1,value:n.shift()}:t.next(),[e](){return this}}}var dn=By;function ky(r){return r[Symbol.asyncIterator]!=null}function Sy(r,t){if(ky(r))return async function*(){for await(let a of r)yield t(a)}();let e=dn(r),{value:n,done:o}=e.next();if(o===!0)return function*(){}();let s=t(n);if(typeof s.then=="function")return async function*(){yield await s;for await(let a of e)yield t(a)}();let i=t;return function*(){yield s;for(let a of e)yield i(a)}()}var pn=Sy;function Iy(r){return r[Symbol.asyncIterator]!=null}function Ry(...r){let t=[];for(let e of r)Iy(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Cr({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let o of n)e.push(o)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var Fr=Ry;function _y(r){return r[Symbol.asyncIterator]!=null}function Ty(r,t){return _y(r)?async function*(){let e=0;if(!(t<1)){for await(let n of r)if(yield n,e++,e===t)return}}():function*(){let e=0;if(!(t<1)){for(let n of r)if(yield n,e++,e===t)return}}()}var ys=Ty;var nt=class extends Event{constructor(t,e){super(t),this.detail=e}};var ac=new Float32Array([-0]),dr=new Uint8Array(ac.buffer);function nf(r,t,e){ac[0]=r,t[e]=dr[0],t[e+1]=dr[1],t[e+2]=dr[2],t[e+3]=dr[3]}function of(r,t){return dr[0]=r[t],dr[1]=r[t+1],dr[2]=r[t+2],dr[3]=r[t+3],ac[0]}var cc=new Float64Array([-0]),Dt=new Uint8Array(cc.buffer);function sf(r,t,e){cc[0]=r,t[e]=Dt[0],t[e+1]=Dt[1],t[e+2]=Dt[2],t[e+3]=Dt[3],t[e+4]=Dt[4],t[e+5]=Dt[5],t[e+6]=Dt[6],t[e+7]=Dt[7]}function af(r,t){return Dt[0]=r[t],Dt[1]=r[t+1],Dt[2]=r[t+2],Dt[3]=r[t+3],Dt[4]=r[t+4],Dt[5]=r[t+5],Dt[6]=r[t+6],Dt[7]=r[t+7],cc[0]}var Ny=BigInt(Number.MAX_SAFE_INTEGER),Cy=BigInt(Number.MIN_SAFE_INTEGER),Wt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Vr;if(t<Ny&&t>Cy)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,o=t-(n<<32n);return e&&(n=~n|0n,o=~o|0n,++o>cf&&(o=0n,++n>cf&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Vr;let e=t<0;e&&(t=-t);let n=t>>>0,o=(t-n)/4294967296>>>0;return e&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new r(n,o)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Vr}},Vr=new Wt(0,0);Vr.toBigInt=function(){return 0n};Vr.zzEncode=Vr.zzDecode=function(){return this};Vr.length=function(){return 1};var cf=4294967296n;function uf(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function lf(r,t,e){if(e-t<1)return"";let o,s=[],i=0,a;for(;t<e;)a=r[t++],a<128?s[i++]=a:a>191&&a<224?s[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,s)),i=0);return o!=null?(i>0&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))}function uc(r,t,e){let n=e,o,s;for(let i=0;i<r.length;++i)o=r.charCodeAt(i),o<128?t[e++]=o:o<2048?(t[e++]=o>>6|192,t[e++]=o&63|128):(o&64512)===55296&&((s=r.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,t[e++]=o>>18|240,t[e++]=o>>12&63|128,t[e++]=o>>6&63|128,t[e++]=o&63|128):(t[e++]=o>>12|224,t[e++]=o>>6&63|128,t[e++]=o&63|128);return e-n}function pe(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function gs(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var lc=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,pe(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw pe(this,4);return gs(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw pe(this,4);return gs(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw pe(this,4);let t=of(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw pe(this,4);let t=af(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw pe(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return lf(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw pe(this,t);this.pos+=t}else do if(this.pos>=this.len)throw pe(this);while(this.buf[this.pos++]&128);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new Wt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw pe(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw pe(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw pe(this,8);let t=gs(this.buf,this.pos+=4),e=gs(this.buf,this.pos+=4);return new Wt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=za(this.buf,this.pos);return this.pos+=Kt(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function fc(r){return new lc(r instanceof Uint8Array?r:r.subarray())}function mn(r,t,e){let n=fc(r);return t.decode(n,void 0,e)}function hc(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return de(i);o+i>t&&(n=de(t),o=0);let a=n.subarray(o,o+=i);return o&7&&(o=(o|7)+1),a}}var Mr=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function dc(){}var mc=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Ly=hc();function Uy(r){return globalThis.Buffer!=null?de(r):Ly(r)}var ao=class{len;head;tail;states;constructor(){this.len=0,this.head=new Mr(dc,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Mr(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new yc((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(ws,10,Wt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Wt.fromBigInt(t);return this._push(ws,e.length(),e)}uint64Number(t){return this._push(qa,Kt(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Wt.fromBigInt(t).zzEncode();return this._push(ws,e.length(),e)}sint64Number(t){let e=Wt.fromNumber(t).zzEncode();return this._push(ws,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(pc,1,t?1:0)}fixed32(t){return this._push(io,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Wt.fromBigInt(t);return this._push(io,4,e.lo)._push(io,4,e.hi)}fixed64Number(t){let e=Wt.fromNumber(t);return this._push(io,4,e.lo)._push(io,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(nf,4,t)}double(t){return this._push(sf,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(pc,1,0):this.uint32(e)._push(Py,e,t)}string(t){let e=uf(t);return e!==0?this.uint32(e)._push(uc,e,t):this._push(pc,1,0)}fork(){return this.states=new mc(this),this.head=this.tail=new Mr(dc,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Mr(dc,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=Uy(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function pc(r,t,e){t[e]=r&255}function Dy(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var yc=class extends Mr{next;constructor(t,e){super(Dy,t,e),this.next=void 0}};function ws(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function io(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Py(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(ao.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Oy,t,r),this},ao.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Fy,t,r),this});function Oy(r,t,e){t.set(r,e)}function Fy(r,t,e){r.length<40?uc(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Y(r),e)}function gc(){return new ao}function yn(r,t){let e=gc();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var gn;(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"})(gn||(gn={}));function bs(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function co(r){function t(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let e=function(s,i){let a=t(s);i.int32(a)},n=function(s){let i=s.int32();return t(i)};return bs("enum",gn.VARINT,e,n)}function wn(r,t){return bs("message",gn.LENGTH_DELIMITED,r,t)}var Vy=Symbol.for("nodejs.util.inspect.custom"),hf=Object.values(hr).map(r=>r.decoder).reduce((r,t)=>r.or(t),hr.identity.decoder),df=114,wc=36,bc=37,uo=class{type;multihash;privateKey;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,this.privateKey=t.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[la]=!0;toString(){return this.string==null&&(this.string=ft.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return ot.createV1(df,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return ct(this.multihash.bytes,t);if(typeof t=="string")return xc(t).equals(this);if(t?.multihash?.bytes!=null)return ct(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[Vy](){return`PeerId(${this.toString()})`}},bn=class extends uo{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},xn=class extends uo{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},En=class extends uo{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function xc(r,t){if(t=t??hf,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Se(ft.decode(`z${r}`));return r.startsWith("12D")?new xn({multihash:e}):r.startsWith("16U")?new En({multihash:e}):new bn({multihash:e})}return lo(hf.decode(r))}function lo(r){try{let t=Se(r);if(t.code===ie.code){if(t.digest.length===wc)return new xn({multihash:t});if(t.digest.length===bc)return new En({multihash:t})}if(t.code===Et.code)return new bn({multihash:t})}catch{return My(ot.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function My(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==df)throw new Error("Supplied PeerID CID is invalid");let t=r.multihash;if(t.code===Et.code)return new bn({multihash:r.multihash});if(t.code===ie.code){if(t.digest.length===wc)return new xn({multihash:r.multihash});if(t.digest.length===bc)return new En({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function pf(r,t){return r.length===wc?new xn({multihash:ke(ie.code,r),privateKey:t}):r.length===bc?new En({multihash:ke(ie.code,r),privateKey:t}):new bn({multihash:await Et.digest(r),publicKey:r,privateKey:t})}function $y(r){return r[Symbol.asyncIterator]!=null}function Hy(r){if($y(r))return(async()=>{let e=[];for await(let n of r)e.push(n);return e})();let t=[];for(let e of r)t.push(e);return t}var Ec=Hy;function Ky(r){return r[Symbol.asyncIterator]!=null}function qy(r,t){if(Ky(r))return async function*(){for await(let a of r)await t(a)&&(yield a)}();let e=dn(r),{value:n,done:o}=e.next();if(o===!0)return function*(){}();let s=t(n);if(typeof s.then=="function")return async function*(){await s&&(yield n);for await(let a of e)await t(a)&&(yield a)}();let i=t;return function*(){s===!0&&(yield n);for(let a of e)i(a)&&(yield a)}()}var me=qy;var yf=oe(mf(),1),zy=["0.0.0.0/8","10.0.0.0/8","100.64.0.0/10","127.0.0.0/8","169.254.0.0/16","172.16.0.0/12","192.0.0.0/24","192.0.0.0/29","192.0.0.8/32","192.0.0.9/32","192.0.0.10/32","192.0.0.170/32","192.0.0.171/32","192.0.2.0/24","192.31.196.0/24","192.52.193.0/24","192.88.99.0/24","192.168.0.0/16","192.175.48.0/24","198.18.0.0/15","198.51.100.0/24","203.0.113.0/24","240.0.0.0/4","255.255.255.255/32"],Gy=zy.map(r=>new yf.Netmask(r));function jy(r){for(let t of Gy)if(t.contains(r))return!0;return!1}function Wy(r){return/^::$/.test(r)||/^::1$/.test(r)||/^::f{4}:([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)||/^::f{4}:0.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)||/^64:ff9b::([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)||/^100::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001::([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001:2[0-9a-fA-F]:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2001:db8:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^2002:([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4}):?([0-9a-fA-F]{0,4})$/.test(r)||/^f[c-d]([0-9a-fA-F]{2,2}):/i.test(r)||/^fe[8-9a-bA-B][0-9a-fA-F]:/i.test(r)||/^ff([0-9a-fA-F]{2,2}):/i.test(r)}function gf(r){return tn(r)?jy(r):en(r)?Wy(r):void 0}var Yy=[G("tcp").code,G("dns").code,G("dnsaddr").code,G("dns4").code,G("dns6").code];function wf(r){let t;try{t=G("sni").code}catch{return null}for(let[e,n]of r)if(e===t&&n!==void 0)return n;return null}function bf(r){return r.some(([t,e])=>t===G("tls").code)}function Yt(r,t,e){let n=xf[G(r).name];if(n===void 0)throw new Error(`Can't interpret protocol ${G(r).name}`);let o=n(t,e);return r===G("ip6").code?`[${o}]`:o}var xf={ip4:(r,t)=>r,ip6:(r,t)=>t.length===0?r:`[${r}]`,tcp:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`tcp://${Yt(e[0],e[1]??"",t)}:${r}`},udp:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`udp://${Yt(e[0],e[1]??"",t)}:${r}`},dnsaddr:(r,t)=>r,dns4:(r,t)=>r,dns6:(r,t)=>r,dns:(r,t)=>r,ipfs:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${Yt(e[0],e[1]??"",t)}/ipfs/${r}`},p2p:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${Yt(e[0],e[1]??"",t)}/p2p/${r}`},http:(r,t)=>{let e=bf(t),n=wf(t);if(e&&n!==null)return`https://${n}`;let o=e?"https://":"http://",s=t.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let i=Yt(s[0],s[1]??"",t);return i=i.replace("tcp://",""),`${o}${i}`},tls:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return Yt(e[0],e[1]??"",t)},sni:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return Yt(e[0],e[1]??"",t)},https:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");let n=Yt(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`https://${n}`},ws:(r,t)=>{let e=bf(t),n=wf(t);if(e&&n!==null)return`wss://${n}`;let o=e?"wss://":"ws://",s=t.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let i=Yt(s[0],s[1]??"",t);return i=i.replace("tcp://",""),`${o}${i}`},wss:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");let n=Yt(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`wss://${n}`},"p2p-websocket-star":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${Yt(e[0],e[1]??"",t)}/p2p-websocket-star`},"p2p-webrtc-star":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${Yt(e[0],e[1]??"",t)}/p2p-webrtc-star`},"p2p-webrtc-direct":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return`${Yt(e[0],e[1]??"",t)}/p2p-webrtc-direct`}};function Ef(r,t){let n=Dr(r).stringTuples(),o=n.pop();if(o===void 0)throw new Error("Unexpected end of multiaddr");let s=G(o[0]),i=xf[s.name];if(i==null)throw new Error(`No interpreter found for ${s.name}`);let a=i(o[1]??"",n);return t?.assumeHttp!==!1&&Yy.includes(o[0])&&(a=a.replace(/^.*:\/\//,""),o[1]==="443"?a=`https://${a}`:a=`http://${a}`),(a.startsWith("http://")||a.startsWith("https://"))&&(a=new URL(a).toString(),a.endsWith("/")&&(a=a.substring(0,a.length-1))),a}var ho=class{url;#t=0;#e=0;#r=0;#i=0;log;constructor(t,e){this.url=t instanceof URL?t:new URL(t),this.log=e.forComponent(`helia:trustless-gateway-block-broker:${this.url.hostname}`)}async getRawBlock(t,e){let n=this.url;if(n.pathname=`/ipfs/${t.toString()}`,n.search="?format=raw",e?.aborted===!0)throw new Error(`Signal to fetch raw block for CID ${t} from gateway ${this.url} was aborted prior to fetch`);try{this.#t++;let o=await fetch(n.toString(),{signal:e,headers:{Accept:"application/vnd.ipld.raw"},cache:"force-cache"});if(this.log("GET %s %d",n,o.status),!o.ok)throw this.#e++,new Error(`unable to fetch raw block for CID ${t} from gateway ${this.url}`);return this.#i++,new Uint8Array(await o.arrayBuffer())}catch{throw e?.aborted===!0?new Error(`fetching raw block for CID ${t} from gateway ${this.url} was aborted`):(this.#e++,new Error(`unable to fetch raw block for CID ${t}`))}}reliability(){return this.#t===0?1:this.#r>0?-1/0:this.#i/(this.#t+this.#e*3)}incrementInvalidBlocks(){this.#r++}};var xs=class r{components;gateways;routing;log;constructor(t,e={}){this.components=t,this.log=t.logger.forComponent("helia:trustless-gateway-block-broker"),this.routing=t.routing,this.gateways=(e.gateways??vf).map(n=>new ho(n,t.logger))}addGateway(t){this.gateways.push(new ho(t,this.components.logger))}async retrieve(t,e={}){let n=this.gateways.sort((s,i)=>i.reliability()-s.reliability()),o=[];for(let s of n){this.log("getting block for %c from %s",t,s.url);try{let i=await s.getRawBlock(t,e.signal);this.log.trace("got block for %c from %s",t,s.url);try{await e.validateFn?.(i)}catch(a){throw this.log.error("failed to validate block for %c from %s",t,s.url,a),s.incrementInvalidBlocks(),new Error(`Block for CID ${t} from gateway ${s.url} failed validation`)}return i}catch(i){if(this.log.error("failed to get block for %c from %s",t,s.url,i),i instanceof Error?o.push(i):o.push(new Error(`Unable to fetch raw block for CID ${t} from gateway ${s.url}`)),e.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",t,s.url);break}}}throw o.length>0?new AggregateError(o,`Unable to fetch raw block for CID ${t} from any gateway`):new Error(`Unable to fetch raw block for CID ${t} from any gateway`)}async createSession(t,e={}){let n=[],o=e.minProviders??1,s=e.minProviders??5,i=It(),a=new r(this.components,{gateways:n});this.log("finding transport-ipfs-gateway-http providers for cid %c",t);let c=new ts({concurrency:e.providerQueryConcurrency??5});return Promise.resolve().then(async()=>{for await(let u of this.routing.findProviders(t,e)){let l=u.multiaddrs.filter(f=>Yl.matches(f)||e.allowInsecure===!0&&Wl.matches(f)?e.allowLocal===!0||Ml.matches(f)?!0:gf(f.toOptions().host)===!1:!1);l.length!==0&&(this.log("found transport-ipfs-gateway-http provider %p for cid %c",u.id,t),c.add(async()=>{for(let f of l){let h;try{h=Ef(f);let g=`${h}/ipfs/${t.toString()}?format=raw`,y=await fetch(g,{method:"HEAD",headers:{Accept:"application/vnd.ipld.raw","Cache-Control":e.cacheControl??"only-if-cached"},signal:AbortSignal.timeout(e.providerQueryTimeout??5e3)});this.log("HEAD %s %d",g,y.status),n.push(h),a.addGateway(h),this.log("found %d transport-ipfs-gateway-http providers for cid %c",n.length,t),n.length===o&&i.resolve(a),n.length===s&&c.clear()}catch(g){this.log.error("could not fetch %c from %a",t,h??f,g)}}}))}}).catch(u=>{this.log.error("error creating session for %c",t,u)}),i.promise}};var vf=["https://trustless-gateway.link","https://cloudflare-ipfs.com","https://4everland.io"];function vc(r={}){return t=>new xs(t,r)}var Zt=oe(tf(),1);Zt.default.formatters.b=r=>r==null?"undefined":ft.baseEncode(r);Zt.default.formatters.t=r=>r==null?"undefined":Rt.baseEncode(r);Zt.default.formatters.m=r=>r==null?"undefined":fr.baseEncode(r);Zt.default.formatters.p=r=>r==null?"undefined":r.toString();Zt.default.formatters.c=r=>r==null?"undefined":r.toString();Zt.default.formatters.k=r=>r==null?"undefined":r.toString();Zt.default.formatters.a=r=>r==null?"undefined":r.toString();function Zy(r){let t=()=>{};return t.enabled=!1,t.color="",t.diff=0,t.log=()=>{},t.namespace=r,t.destroy=()=>!0,t.extend=()=>t,t}function Af(){return{forComponent(r){return Jt(r)}}}function Jt(r){let t=Zy(`${r}:trace`);return Zt.default.enabled(`${r}:trace`)&&Zt.default.names.map(e=>e.toString()).find(e=>e.includes(":trace"))!=null&&(t=(0,Zt.default)(`${r}:trace`)),Object.assign((0,Zt.default)(r),{error:(0,Zt.default)(`${r}:error`),trace:t})}async function*Es(r,t={}){let e=r.getReader();try{for(;;){let n=await e.read();if(n.done)return;yield n.value}}finally{t.preventCancel!==!0&&await e.cancel(),e.releaseLock()}}var Vc={};xt(Vc,{Ed25519PrivateKey:()=>qr,Ed25519PublicKey:()=>yo,generateKeyPair:()=>iw,generateKeyPairFromSeed:()=>Zf,unmarshalEd25519PrivateKey:()=>ow,unmarshalEd25519PublicKey:()=>sw});function ae(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function vn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Jy(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function An(r,...t){if(!Jy(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function vs(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");vn(r.outputLen),vn(r.blockLen)}function Bn(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function Bf(r,t){An(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var As=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Sn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),ye=(r,t)=>r<<32-t|r>>>t;var AA=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Xy=async()=>{};async function kf(r,t,e){let n=Date.now();for(let o=0;o<r;o++){e(o);let s=Date.now()-n;s>=0&&s<t||(await Xy(),n+=s)}}function Ac(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function pr(r){return typeof r=="string"&&(r=Ac(r)),An(r),r}function Bs(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];An(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let s=r[n];e.set(s,o),o+=s.length}return e}var kn=class{clone(){return this._cloneInto()}},Qy={}.toString;function Sf(r,t){if(t!==void 0&&Qy.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function ks(r){let t=n=>r().update(pr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function In(r=32){if(As&&typeof As.getRandomValues=="function")return As.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function tg(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(e>>o&s),a=Number(e&s),c=n?4:0,u=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+u,a,n)}var If=(r,t,e)=>r&t^~r&e,Rf=(r,t,e)=>r&t^r&e^t&e,Rn=class extends kn{constructor(t,e,n,o){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=o,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=Sn(this.buffer)}update(t){Bn(this);let{view:e,buffer:n,blockLen:o}=this;t=pr(t);let s=t.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=Sn(t);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){Bn(this),Bf(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>o-i&&(this.process(n,0),i=0);for(let f=i;f<o;f++)e[f]=0;tg(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=Sn(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=c/4,l=this.get();if(u>l.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<u;f++)a.setUint32(4*f,l[f],s)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return t.length=o,t.pos=a,t.finished=s,t.destroyed=i,o%e&&t.buffer.set(n),t}};var Ss=BigInt(4294967295),Bc=BigInt(32);function _f(r,t=!1){return t?{h:Number(r&Ss),l:Number(r>>Bc&Ss)}:{h:Number(r>>Bc&Ss)|0,l:Number(r&Ss)|0}}function eg(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let o=0;o<r.length;o++){let{h:s,l:i}=_f(r[o],t);[e[o],n[o]]=[s,i]}return[e,n]}var rg=(r,t)=>BigInt(r>>>0)<<Bc|BigInt(t>>>0),ng=(r,t,e)=>r>>>e,og=(r,t,e)=>r<<32-e|t>>>e,sg=(r,t,e)=>r>>>e|t<<32-e,ig=(r,t,e)=>r<<32-e|t>>>e,ag=(r,t,e)=>r<<64-e|t>>>e-32,cg=(r,t,e)=>r>>>e-32|t<<64-e,ug=(r,t)=>t,lg=(r,t)=>r,fg=(r,t,e)=>r<<e|t>>>32-e,hg=(r,t,e)=>t<<e|r>>>32-e,dg=(r,t,e)=>t<<e-32|r>>>64-e,pg=(r,t,e)=>r<<e-32|t>>>64-e;function mg(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var yg=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),gg=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,wg=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),bg=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,xg=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),Eg=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var vg={fromBig:_f,split:eg,toBig:rg,shrSH:ng,shrSL:og,rotrSH:sg,rotrSL:ig,rotrBH:ag,rotrBL:cg,rotr32H:ug,rotr32L:lg,rotlSH:fg,rotlSL:hg,rotlBH:dg,rotlBL:pg,add:mg,add3L:yg,add3H:gg,add4L:wg,add4H:bg,add5H:Eg,add5L:xg},q=vg;var[Ag,Bg]=q.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),mr=new Uint32Array(80),yr=new Uint32Array(80),kc=class extends Rn{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:u,El:l,Fh:f,Fl:h,Gh:g,Gl:y,Hh:p,Hl:m}=this;return[t,e,n,o,s,i,a,c,u,l,f,h,g,y,p,m]}set(t,e,n,o,s,i,a,c,u,l,f,h,g,y,p,m){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=o|0,this.Ch=s|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=u|0,this.El=l|0,this.Fh=f|0,this.Fl=h|0,this.Gh=g|0,this.Gl=y|0,this.Hh=p|0,this.Hl=m|0}process(t,e){for(let v=0;v<16;v++,e+=4)mr[v]=t.getUint32(e),yr[v]=t.getUint32(e+=4);for(let v=16;v<80;v++){let U=mr[v-15]|0,S=yr[v-15]|0,_=q.rotrSH(U,S,1)^q.rotrSH(U,S,8)^q.shrSH(U,S,7),L=q.rotrSL(U,S,1)^q.rotrSL(U,S,8)^q.shrSL(U,S,7),b=mr[v-2]|0,C=yr[v-2]|0,O=q.rotrSH(b,C,19)^q.rotrBH(b,C,61)^q.shrSH(b,C,6),T=q.rotrSL(b,C,19)^q.rotrBL(b,C,61)^q.shrSL(b,C,6),V=q.add4L(L,T,yr[v-7],yr[v-16]),H=q.add4H(V,_,O,mr[v-7],mr[v-16]);mr[v]=H|0,yr[v]=V|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:u,Dl:l,Eh:f,El:h,Fh:g,Fl:y,Gh:p,Gl:m,Hh:w,Hl:I}=this;for(let v=0;v<80;v++){let U=q.rotrSH(f,h,14)^q.rotrSH(f,h,18)^q.rotrBH(f,h,41),S=q.rotrSL(f,h,14)^q.rotrSL(f,h,18)^q.rotrBL(f,h,41),_=f&g^~f&p,L=h&y^~h&m,b=q.add5L(I,S,L,Bg[v],yr[v]),C=q.add5H(b,w,U,_,Ag[v],mr[v]),O=b|0,T=q.rotrSH(n,o,28)^q.rotrBH(n,o,34)^q.rotrBH(n,o,39),V=q.rotrSL(n,o,28)^q.rotrBL(n,o,34)^q.rotrBL(n,o,39),H=n&s^n&a^s&a,X=o&i^o&c^i&c;w=p|0,I=m|0,p=g|0,m=y|0,g=f|0,y=h|0,{h:f,l:h}=q.add(u|0,l|0,C|0,O|0),u=a|0,l=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let E=q.add3L(O,V,X);n=q.add3H(E,C,T,H),o=E|0}({h:n,l:o}=q.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=q.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=q.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l}=q.add(this.Dh|0,this.Dl|0,u|0,l|0),{h:f,l:h}=q.add(this.Eh|0,this.El|0,f|0,h|0),{h:g,l:y}=q.add(this.Fh|0,this.Fl|0,g|0,y|0),{h:p,l:m}=q.add(this.Gh|0,this.Gl|0,p|0,m|0),{h:w,l:I}=q.add(this.Hh|0,this.Hl|0,w|0,I|0),this.set(n,o,s,i,a,c,u,l,f,h,g,y,p,m,w,I)}roundClean(){mr.fill(0),yr.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var _n=ks(()=>new kc);var Rs={};xt(Rs,{abytes:()=>Tn,bitGet:()=>Ng,bitLen:()=>Tg,bitMask:()=>po,bitSet:()=>Cg,bytesToHex:()=>$e,bytesToNumberBE:()=>He,bytesToNumberLE:()=>wr,concatBytes:()=>Ke,createHmacDrbg:()=>Rc,ensureBytes:()=>pt,equalBytes:()=>Rg,hexToBytes:()=>$r,hexToNumber:()=>Ic,isBytes:()=>gr,numberToBytesBE:()=>br,numberToBytesLE:()=>Hr,numberToHexUnpadded:()=>Lf,numberToVarBytesBE:()=>Ig,utf8ToBytes:()=>_g,validateObject:()=>Re});var Cf=BigInt(0),Is=BigInt(1),kg=BigInt(2);function gr(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Tn(r){if(!gr(r))throw new Error("Uint8Array expected")}var Sg=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function $e(r){Tn(r);let t="";for(let e=0;e<r.length;e++)t+=Sg[r[e]];return t}function Lf(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Ic(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Me={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function Tf(r){if(r>=Me._0&&r<=Me._9)return r-Me._0;if(r>=Me._A&&r<=Me._F)return r-(Me._A-10);if(r>=Me._a&&r<=Me._f)return r-(Me._a-10)}function $r(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("padded hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let o=0,s=0;o<e;o++,s+=2){let i=Tf(r.charCodeAt(s)),a=Tf(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 He(r){return Ic($e(r))}function wr(r){return Tn(r),Ic($e(Uint8Array.from(r).reverse()))}function br(r,t){return $r(r.toString(16).padStart(t*2,"0"))}function Hr(r,t){return br(r,t).reverse()}function Ig(r){return $r(Lf(r))}function pt(r,t,e){let n;if(typeof t=="string")try{n=$r(t)}catch(s){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${s}`)}else if(gr(t))n=Uint8Array.from(t);else throw new Error(`${r} must be hex string or Uint8Array`);let o=n.length;if(typeof e=="number"&&o!==e)throw new Error(`${r} expected ${e} bytes, got ${o}`);return n}function Ke(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Tn(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let s=r[n];e.set(s,o),o+=s.length}return e}function Rg(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}function _g(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function Tg(r){let t;for(t=0;r>Cf;r>>=Is,t+=1);return t}function Ng(r,t){return r>>BigInt(t)&Is}function Cg(r,t,e){return r|(e?Is:Cf)<<BigInt(t)}var po=r=>(kg<<BigInt(r-1))-Is,Sc=r=>new Uint8Array(r),Nf=r=>Uint8Array.from(r);function Rc(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=Sc(r),o=Sc(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...f)=>e(o,n,...f),c=(f=Sc())=>{o=a(Nf([0]),f),n=a(),f.length!==0&&(o=a(Nf([1]),f),n=a())},u=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,h=[];for(;f<t;){n=a();let g=n.slice();h.push(g),f+=n.length}return Ke(...h)};return(f,h)=>{i(),c(f);let g;for(;!(g=h(u()));)c();return i(),g}}var Lg={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||gr(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Re(r,t,e={}){let n=(o,s,i)=>{let a=Lg[s];if(typeof a!="function")throw new Error(`Invalid validator "${s}", expected function`);let c=r[o];if(!(i&&c===void 0)&&!a(c,r))throw new Error(`Invalid param ${String(o)}=${c} (${typeof c}), expected ${s}`)};for(let[o,s]of Object.entries(t))n(o,s,!1);for(let[o,s]of Object.entries(e))n(o,s,!0);return r}var vt=BigInt(0),ut=BigInt(1),Kr=BigInt(2),Ug=BigInt(3),_c=BigInt(4),Uf=BigInt(5),Df=BigInt(8),Dg=BigInt(9),Pg=BigInt(16);function at(r,t){let e=r%t;return e>=vt?e:t+e}function Og(r,t,e){if(e<=vt||t<vt)throw new Error("Expected power/modulo > 0");if(e===ut)return vt;let n=ut;for(;t>vt;)t&ut&&(n=n*r%e),r=r*r%e,t>>=ut;return n}function lt(r,t,e){let n=r;for(;t-- >vt;)n*=n,n%=e;return n}function _s(r,t){if(r===vt||t<=vt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=at(r,t),n=t,o=vt,s=ut,i=ut,a=vt;for(;e!==vt;){let u=n/e,l=n%e,f=o-i*u,h=s-a*u;n=e,e=l,o=i,s=a,i=f,a=h}if(n!==ut)throw new Error("invert: does not exist");return at(o,t)}function Fg(r){let t=(r-ut)/Kr,e,n,o;for(e=r-ut,n=0;e%Kr===vt;e/=Kr,n++);for(o=Kr;o<r&&Og(o,t,r)!==r-ut;o++);if(n===1){let i=(r+ut)/_c;return function(c,u){let l=c.pow(u,i);if(!c.eql(c.sqr(l),u))throw new Error("Cannot find square root");return l}}let s=(e+ut)/Kr;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let u=n,l=a.pow(a.mul(a.ONE,o),e),f=a.pow(c,s),h=a.pow(c,e);for(;!a.eql(h,a.ONE);){if(a.eql(h,a.ZERO))return a.ZERO;let g=1;for(let p=a.sqr(h);g<u&&!a.eql(p,a.ONE);g++)p=a.sqr(p);let y=a.pow(l,ut<<BigInt(u-g-1));l=a.sqr(y),f=a.mul(f,y),h=a.mul(h,l),u=g}return f}}function Vg(r){if(r%_c===Ug){let t=(r+ut)/_c;return function(n,o){let s=n.pow(o,t);if(!n.eql(n.sqr(s),o))throw new Error("Cannot find square root");return s}}if(r%Df===Uf){let t=(r-Uf)/Df;return function(n,o){let s=n.mul(o,Kr),i=n.pow(s,t),a=n.mul(o,i),c=n.mul(n.mul(a,Kr),i),u=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(u),o))throw new Error("Cannot find square root");return u}}return r%Pg,Fg(r)}var Pf=(r,t)=>(at(r,t)&ut)===ut,Mg=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Tc(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Mg.reduce((n,o)=>(n[o]="function",n),t);return Re(r,e)}function $g(r,t,e){if(e<vt)throw new Error("Expected power > 0");if(e===vt)return r.ONE;if(e===ut)return t;let n=r.ONE,o=t;for(;e>vt;)e&ut&&(n=r.mul(n,o)),o=r.sqr(o),e>>=ut;return n}function Hg(r,t){let e=new Array(t.length),n=t.reduce((s,i,a)=>r.is0(i)?s:(e[a]=s,r.mul(s,i)),r.ONE),o=r.inv(n);return t.reduceRight((s,i,a)=>r.is0(i)?s:(e[a]=r.mul(s,e[a]),r.mul(s,i)),o),e}function Nc(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function Ts(r,t,e=!1,n={}){if(r<=vt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:o,nByteLength:s}=Nc(r,t);if(s>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Vg(r),a=Object.freeze({ORDER:r,BITS:o,BYTES:s,MASK:po(o),ZERO:vt,ONE:ut,create:c=>at(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error(`Invalid field element: expected bigint, got ${typeof c}`);return vt<=c&&c<r},is0:c=>c===vt,isOdd:c=>(c&ut)===ut,neg:c=>at(-c,r),eql:(c,u)=>c===u,sqr:c=>at(c*c,r),add:(c,u)=>at(c+u,r),sub:(c,u)=>at(c-u,r),mul:(c,u)=>at(c*u,r),pow:(c,u)=>$g(a,c,u),div:(c,u)=>at(c*_s(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>_s(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Hg(a,c),cmov:(c,u,l)=>l?u:c,toBytes:c=>e?Hr(c,s):br(c,s),fromBytes:c=>{if(c.length!==s)throw new Error(`Fp.fromBytes: expected ${s}, got ${c.length}`);return e?wr(c):He(c)}});return Object.freeze(a)}function Of(r,t){if(!r.isOdd)throw new Error("Field doesn't have isOdd");let e=r.sqrt(t);return r.isOdd(e)?r.neg(e):e}function Ff(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function Cc(r){let t=Ff(r);return t+Math.ceil(t/2)}function Vf(r,t,e=!1){let n=r.length,o=Ff(t),s=Cc(t);if(n<16||n<s||n>1024)throw new Error(`expected ${s}-1024 bytes of input, got ${n}`);let i=e?He(r):wr(r),a=at(i,t-ut)+ut;return e?Hr(a,o):br(a,o)}var qg=BigInt(0),Lc=BigInt(1);function Ns(r,t){let e=(o,s)=>{let i=s.negate();return o?i:s},n=o=>{let s=Math.ceil(t/o)+1,i=2**(o-1);return{windows:s,windowSize:i}};return{constTimeNegate:e,unsafeLadder(o,s){let i=r.ZERO,a=o;for(;s>qg;)s&Lc&&(i=i.add(a)),a=a.double(),s>>=Lc;return i},precomputeWindow(o,s){let{windows:i,windowSize:a}=n(s),c=[],u=o,l=u;for(let f=0;f<i;f++){l=u,c.push(l);for(let h=1;h<a;h++)l=l.add(u),c.push(l);u=l.double()}return c},wNAF(o,s,i){let{windows:a,windowSize:c}=n(o),u=r.ZERO,l=r.BASE,f=BigInt(2**o-1),h=2**o,g=BigInt(o);for(let y=0;y<a;y++){let p=y*c,m=Number(i&f);i>>=g,m>c&&(m-=h,i+=Lc);let w=p,I=p+Math.abs(m)-1,v=y%2!==0,U=m<0;m===0?l=l.add(e(v,s[w])):u=u.add(e(U,s[I]))}return{p:u,f:l}},wNAFCached(o,s,i,a){let c=o._WINDOW_SIZE||1,u=s.get(o);return u||(u=this.precomputeWindow(o,c),c!==1&&s.set(o,a(u))),this.wNAF(c,u,i)}}}function mo(r){return Tc(r.Fp),Re(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Nc(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var ge=BigInt(0),Xt=BigInt(1),Cs=BigInt(2),zg=BigInt(8),Gg={zip215:!0};function jg(r){let t=mo(r);return Re(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Ls(r){let t=jg(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,u=Cs<<BigInt(a*8)-Xt,l=e.create,f=t.uvRatio||((B,x)=>{try{return{isValid:!0,value:e.sqrt(B*e.inv(x))}}catch{return{isValid:!1,value:ge}}}),h=t.adjustScalarBytes||(B=>B),g=t.domain||((B,x,P)=>{if(x.length||P)throw new Error("Contexts/pre-hash are not supported");return B}),y=B=>typeof B=="bigint"&&ge<B,p=(B,x)=>y(B)&&y(x)&&B<x,m=B=>B===ge||p(B,u);function w(B,x){if(p(B,x))return B;throw new Error(`Expected valid scalar < ${x}, got ${typeof B} ${B}`)}function I(B){return B===ge?B:w(B,n)}let v=new Map;function U(B){if(!(B instanceof S))throw new Error("ExtendedPoint expected")}class S{constructor(x,P,M,K){if(this.ex=x,this.ey=P,this.ez=M,this.et=K,!m(x))throw new Error("x required");if(!m(P))throw new Error("y required");if(!m(M))throw new Error("z required");if(!m(K))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(x){if(x instanceof S)throw new Error("extended point not allowed");let{x:P,y:M}=x||{};if(!m(P)||!m(M))throw new Error("invalid affine point");return new S(P,M,Xt,l(P*M))}static normalizeZ(x){let P=e.invertBatch(x.map(M=>M.ez));return x.map((M,K)=>M.toAffine(P[K])).map(S.fromAffine)}_setWindowSize(x){this._WINDOW_SIZE=x,v.delete(this)}assertValidity(){let{a:x,d:P}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:M,ey:K,ez:j,et:W}=this,et=l(M*M),J=l(K*K),Q=l(j*j),gt=l(Q*Q),ht=l(et*x),kt=l(Q*l(ht+J)),St=l(gt+l(P*l(et*J)));if(kt!==St)throw new Error("bad point: equation left != right (1)");let bt=l(M*K),Lt=l(j*W);if(bt!==Lt)throw new Error("bad point: equation left != right (2)")}equals(x){U(x);let{ex:P,ey:M,ez:K}=this,{ex:j,ey:W,ez:et}=x,J=l(P*et),Q=l(j*K),gt=l(M*et),ht=l(W*K);return J===Q&&gt===ht}is0(){return this.equals(S.ZERO)}negate(){return new S(l(-this.ex),this.ey,this.ez,l(-this.et))}double(){let{a:x}=t,{ex:P,ey:M,ez:K}=this,j=l(P*P),W=l(M*M),et=l(Cs*l(K*K)),J=l(x*j),Q=P+M,gt=l(l(Q*Q)-j-W),ht=J+W,kt=ht-et,St=J-W,bt=l(gt*kt),Lt=l(ht*St),Pe=l(gt*St),Tr=l(kt*ht);return new S(bt,Lt,Tr,Pe)}add(x){U(x);let{a:P,d:M}=t,{ex:K,ey:j,ez:W,et}=this,{ex:J,ey:Q,ez:gt,et:ht}=x;if(P===BigInt(-1)){let Vu=l((j-K)*(Q+J)),Mu=l((j+K)*(Q-J)),ua=l(Mu-Vu);if(ua===ge)return this.double();let $u=l(W*Cs*ht),Hu=l(et*Cs*gt),Ku=Hu+$u,qu=Mu+Vu,zu=Hu-$u,wm=l(Ku*ua),bm=l(qu*zu),xm=l(Ku*zu),Em=l(ua*qu);return new S(wm,bm,Em,xm)}let kt=l(K*J),St=l(j*Q),bt=l(et*M*ht),Lt=l(W*gt),Pe=l((K+j)*(J+Q)-kt-St),Tr=Lt-bt,Xn=Lt+bt,Fu=l(St-P*kt),pm=l(Pe*Tr),mm=l(Xn*Fu),ym=l(Pe*Fu),gm=l(Tr*Xn);return new S(pm,mm,gm,ym)}subtract(x){return this.add(x.negate())}wNAF(x){return b.wNAFCached(this,v,x,S.normalizeZ)}multiply(x){let{p:P,f:M}=this.wNAF(w(x,n));return S.normalizeZ([P,M])[0]}multiplyUnsafe(x){let P=I(x);return P===ge?L:this.equals(L)||P===Xt?this:this.equals(_)?this.wNAF(P).p:b.unsafeLadder(this,P)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return b.unsafeLadder(this,n).is0()}toAffine(x){let{ex:P,ey:M,ez:K}=this,j=this.is0();x==null&&(x=j?zg:e.inv(K));let W=l(P*x),et=l(M*x),J=l(K*x);if(j)return{x:ge,y:Xt};if(J!==Xt)throw new Error("invZ was invalid");return{x:W,y:et}}clearCofactor(){let{h:x}=t;return x===Xt?this:this.multiplyUnsafe(x)}static fromHex(x,P=!1){let{d:M,a:K}=t,j=e.BYTES;x=pt("pointHex",x,j);let W=x.slice(),et=x[j-1];W[j-1]=et&-129;let J=wr(W);J===ge||(P?w(J,u):w(J,e.ORDER));let Q=l(J*J),gt=l(Q-Xt),ht=l(M*Q-K),{isValid:kt,value:St}=f(gt,ht);if(!kt)throw new Error("Point.fromHex: invalid y coordinate");let bt=(St&Xt)===Xt,Lt=(et&128)!==0;if(!P&&St===ge&&Lt)throw new Error("Point.fromHex: x=0 and x_0=1");return Lt!==bt&&(St=l(-St)),S.fromAffine({x:St,y:J})}static fromPrivateKey(x){return T(x).point}toRawBytes(){let{x,y:P}=this.toAffine(),M=Hr(P,e.BYTES);return M[M.length-1]|=x&Xt?128:0,M}toHex(){return $e(this.toRawBytes())}}S.BASE=new S(t.Gx,t.Gy,Xt,l(t.Gx*t.Gy)),S.ZERO=new S(ge,Xt,Xt,ge);let{BASE:_,ZERO:L}=S,b=Ns(S,a*8);function C(B){return at(B,n)}function O(B){return C(wr(B))}function T(B){let x=a;B=pt("private key",B,x);let P=pt("hashed private key",s(B),2*x),M=h(P.slice(0,x)),K=P.slice(x,2*x),j=O(M),W=_.multiply(j),et=W.toRawBytes();return{head:M,prefix:K,scalar:j,point:W,pointBytes:et}}function V(B){return T(B).pointBytes}function H(B=new Uint8Array,...x){let P=Ke(...x);return O(s(g(P,pt("context",B),!!o)))}function X(B,x,P={}){B=pt("message",B),o&&(B=o(B));let{prefix:M,scalar:K,pointBytes:j}=T(x),W=H(P.context,M,B),et=_.multiply(W).toRawBytes(),J=H(P.context,et,j,B),Q=C(W+J*K);I(Q);let gt=Ke(et,Hr(Q,e.BYTES));return pt("result",gt,a*2)}let E=Gg;function k(B,x,P,M=E){let{context:K,zip215:j}=M,W=e.BYTES;B=pt("signature",B,2*W),x=pt("message",x),o&&(x=o(x));let et=wr(B.slice(W,2*W)),J,Q,gt;try{J=S.fromHex(P,j),Q=S.fromHex(B.slice(0,W),j),gt=_.multiplyUnsafe(et)}catch{return!1}if(!j&&J.isSmallOrder())return!1;let ht=H(K,Q.toRawBytes(),J.toRawBytes(),x);return Q.add(J.multiplyUnsafe(ht)).subtract(gt).clearCofactor().equals(S.ZERO)}return _._setWindowSize(8),{CURVE:t,getPublicKey:V,sign:X,verify:k,ExtendedPoint:S,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>i(e.BYTES),precompute(B=8,x=S.BASE){return x._setWindowSize(B),x.multiply(BigInt(3)),x}}}}var Dc=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Mf=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),zA=BigInt(0),Wg=BigInt(1),Uc=BigInt(2),Yg=BigInt(5),$f=BigInt(10),Zg=BigInt(20),Jg=BigInt(40),Hf=BigInt(80);function Xg(r){let t=Dc,n=r*r%t*r%t,o=lt(n,Uc,t)*n%t,s=lt(o,Wg,t)*r%t,i=lt(s,Yg,t)*s%t,a=lt(i,$f,t)*i%t,c=lt(a,Zg,t)*a%t,u=lt(c,Jg,t)*c%t,l=lt(u,Hf,t)*u%t,f=lt(l,Hf,t)*u%t,h=lt(f,$f,t)*i%t;return{pow_p_5_8:lt(h,Uc,t)*r%t,b2:n}}function Qg(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function tw(r,t){let e=Dc,n=at(t*t*t,e),o=at(n*n*t,e),s=Xg(r*o).pow_p_5_8,i=at(r*n*s,e),a=at(t*i*i,e),c=i,u=at(i*Mf,e),l=a===r,f=a===at(-r,e),h=a===at(-r*Mf,e);return l&&(i=c),(f||h)&&(i=u),Pf(i,e)&&(i=at(-i,e)),{isValid:l||f,value:i}}var qe=Ts(Dc,void 0,!0),Pc={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:qe,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:BigInt(8),Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:_n,randomBytes:In,adjustScalarBytes:Qg,uvRatio:tw},Nn=Ls(Pc);function Kf(r,t,e){if(t.length>255)throw new Error("Context is too big");return Bs(Ac("SigEd25519 no Ed25519 collisions"),new Uint8Array([e?1:0,t.length]),t,r)}var GA=Ls({...Pc,domain:Kf}),jA=Ls({...Pc,domain:Kf,prehash:_n});var ew=(qe.ORDER+BigInt(3))/BigInt(8),WA=qe.pow(Uc,ew),YA=qe.sqrt(qe.neg(qe.ONE)),ZA=(qe.ORDER-BigInt(5))/BigInt(8),JA=BigInt(486662);var XA=Of(qe,qe.neg(BigInt(486664)));var QA=BigInt("25063068953384623474111414158702152701244531502492656460079210482610430750235"),tB=BigInt("54469307008909316920995813868745141605393597292927456921205312896311721017578"),eB=BigInt("1159843021668779879193775521855586647937357759715417654439879720876111806838"),rB=BigInt("40440834346308536858101042469323190826248399146238708352240133220865137265952");var nB=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff");var Cn=32,ze=64,Us=32;function qf(){let r=Nn.utils.randomPrivateKey(),t=Nn.getPublicKey(r);return{privateKey:Wf(r,t),publicKey:t}}function zf(r){if(r.length!==Us)throw new TypeError('"seed" must be 32 bytes in length.');if(!(r instanceof Uint8Array))throw new TypeError('"seed" must be a node.js Buffer, or Uint8Array.');let t=r,e=Nn.getPublicKey(t);return{privateKey:Wf(t,e),publicKey:e}}function Gf(r,t){let e=r.subarray(0,Us);return Nn.sign(t instanceof Uint8Array?t:t.subarray(),e)}function jf(r,t,e){return Nn.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Wf(r,t){let e=new Uint8Array(ze);for(let n=0;n<Us;n++)e[n]=r[n],e[Us+n]=t[n];return e}var Mt={get(r=globalThis){let t=r.crypto;if(t==null||t.subtle==null)throw Object.assign(new Error("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api"),{code:"ERR_MISSING_WEB_CRYPTO"});return t}};var Oc={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Yf(r){let t=r?.algorithm??"AES-GCM",e=r?.keyLength??16,n=r?.nonceLength??12,o=r?.digest??"SHA-256",s=r?.saltLength??16,i=r?.iterations??32767,a=Mt.get();e*=8;async function c(f,h){let g=a.getRandomValues(new Uint8Array(s)),y=a.getRandomValues(new Uint8Array(n)),p={name:t,iv:y};typeof h=="string"&&(h=Y(h));let m;if(h.length===0){m=await a.subtle.importKey("jwk",Oc,{name:"AES-GCM"},!0,["encrypt"]);try{let I={name:"PBKDF2",salt:g,iterations:i,hash:{name:o}},v=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(I,v,{name:t,length:e},!0,["encrypt"])}catch{m=await a.subtle.importKey("jwk",Oc,{name:"AES-GCM"},!0,["encrypt"])}}else{let I={name:"PBKDF2",salt:g,iterations:i,hash:{name:o}},v=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);m=await a.subtle.deriveKey(I,v,{name:t,length:e},!0,["encrypt"])}let w=await a.subtle.encrypt(p,m,f);return Ft([g,p.iv,new Uint8Array(w)])}async function u(f,h){let g=f.subarray(0,s),y=f.subarray(s,s+n),p=f.subarray(s+n),m={name:t,iv:y};typeof h=="string"&&(h=Y(h));let w;if(h.length===0)try{let v={name:"PBKDF2",salt:g,iterations:i,hash:{name:o}},U=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(v,U,{name:t,length:e},!0,["decrypt"])}catch{w=await a.subtle.importKey("jwk",Oc,{name:"AES-GCM"},!0,["decrypt"])}else{let v={name:"PBKDF2",salt:g,iterations:i,hash:{name:o}},U=await a.subtle.importKey("raw",h,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(v,U,{name:t,length:e},!0,["decrypt"])}let I=await a.subtle.decrypt(m,w,p);return new Uint8Array(I)}return{encrypt:c,decrypt:u}}async function Ln(r,t){let n=await Yf().encrypt(r,t);return fr.encode(n)}var yt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(yt||(yt={}));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=()=>co(Fc)})(yt||(yt={}));var _e;(function(r){let t;r.codec=()=>(t==null&&(t=wn((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),yt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let o={},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let i=e.uint32();switch(i>>>3){case 1:o.Type=yt.codec().decode(e);break;case 2:o.Data=e.bytes();break;default:e.skipType(i&7);break}}return o})),t),r.encode=e=>yn(e,r.codec()),r.decode=e=>mn(e,r.codec())})(_e||(_e={}));var Ge;(function(r){let t;r.codec=()=>(t==null&&(t=wn((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),yt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let o={},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let i=e.uint32();switch(i>>>3){case 1:o.Type=yt.codec().decode(e);break;case 2:o.Data=e.bytes();break;default:e.skipType(i&7);break}}return o})),t),r.encode=e=>yn(e,r.codec()),r.decode=e=>mn(e,r.codec())})(Ge||(Ge={}));var yo=class{_key;constructor(t){this._key=Un(t,Cn)}verify(t,e){return jf(this._key,e,t)}marshal(){return this._key}get bytes(){return _e.encode({Type:yt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return ct(this.bytes,t.bytes)}hash(){let t=Et.digest(this.bytes);return ae(t)?t.then(({bytes:e})=>e):t.bytes}},qr=class{_key;_publicKey;constructor(t,e){this._key=Un(t,ze),this._publicKey=Un(e,Cn)}sign(t){return Gf(this._key,t)}get public(){return new yo(this._publicKey)}marshal(){return this._key}get bytes(){return Ge.encode({Type:yt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return ct(this.bytes,t.bytes)}async hash(){let t=Et.digest(this.bytes),e;return ae(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=ie.digest(this.public.bytes);return ft.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Ln(this.bytes,t);throw new N(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function ow(r){if(r.length>ze){r=Un(r,ze+Cn);let n=r.subarray(0,ze),o=r.subarray(ze,r.length);return new qr(n,o)}r=Un(r,ze);let t=r.subarray(0,ze),e=r.subarray(Cn);return new qr(t,e)}function sw(r){return r=Un(r,Cn),new yo(r)}async function iw(){let{privateKey:r,publicKey:t}=qf();return new qr(r,t)}async function Zf(r){let{privateKey:t,publicKey:e}=zf(r);return new qr(t,e)}function Un(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new N(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}var Yc={};xt(Yc,{MAX_RSA_KEY_SIZE:()=>Ro,RsaPrivateKey:()=>Vn,RsaPublicKey:()=>Io,fromJwk:()=>Lw,generateKeyPair:()=>Uw,unmarshalRsaPrivateKey:()=>jc,unmarshalRsaPublicKey:()=>Cw});function zr(r){if(isNaN(r)||r<=0)throw new N("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return In(r)}var Ar={};xt(Ar,{exportToPem:()=>Iw,importFromPem:()=>Rw,jwkToPkcs1:()=>Aw,jwkToPkix:()=>kw,pkcs1ToJwk:()=>vw,pkixToJwk:()=>Bw});var Ps=class extends kn{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,vs(t);let n=pr(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let o=this.blockLen,s=new Uint8Array(o);s.set(n.length>o?t.create().update(n).digest():n);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=t.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),s.fill(0)}update(t){return Bn(this),this.iHash.update(t),this}digestInto(t){Bn(this),An(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return t=t,t.finished=o,t.destroyed=s,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},go=(r,t,e)=>new Ps(r,t).update(e).digest();go.create=(r,t)=>new Ps(r,t);function aw(r,t,e,n){vs(r);let o=Sf({dkLen:32,asyncTick:10},n),{c:s,dkLen:i,asyncTick:a}=o;if(vn(s),vn(i),vn(a),s<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=pr(t),u=pr(e),l=new Uint8Array(i),f=go.create(r,c),h=f._cloneInto().update(u);return{c:s,dkLen:i,asyncTick:a,DK:l,PRF:f,PRFSalt:h}}function cw(r,t,e,n,o){return r.destroy(),t.destroy(),n&&n.destroy(),o.fill(0),e}async function Mc(r,t,e,n){let{c:o,dkLen:s,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=aw(r,t,e,n),l,f=new Uint8Array(4),h=Sn(f),g=new Uint8Array(c.outputLen);for(let y=1,p=0;p<s;y++,p+=c.outputLen){let m=a.subarray(p,p+c.outputLen);h.setInt32(0,y,!1),(l=u._cloneInto(l)).update(f).digestInto(g),m.set(g.subarray(0,m.length)),await kf(o-1,i,()=>{c._cloneInto(l).update(g).digestInto(g);for(let w=0;w<m.length;w++)m[w]^=g[w]})}return cw(c,u,a,l,g)}var Z=oe(Jf());function Gr(r,t){let e=0;if(r.length===1)return r[0];for(let n=r.length-1;n>=0;n--)e+=r[r.length-1-n]*Math.pow(2,t*n);return e}function xr(r,t,e=-1){let n=e,o=r,s=0,i=Math.pow(2,t);for(let a=1;a<8;a++){if(r<i){let c;if(n<0)c=new ArrayBuffer(a),s=a;else{if(n<a)return new ArrayBuffer(0);c=new ArrayBuffer(n),s=n}let u=new Uint8Array(c);for(let l=a-1;l>=0;l--){let f=Math.pow(2,l*t);u[s-l-1]=Math.floor(o/f),o-=u[s-l-1]*f}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Vs(...r){let t=0,e=0;for(let s of r)t+=s.length;let n=new ArrayBuffer(t),o=new Uint8Array(n);for(let s of r)o.set(s,e),e+=s.length;return o}function Hc(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let t=new ArrayBuffer(this.valueHex.byteLength),e=new Uint8Array(t);for(let a=0;a<this.valueHex.byteLength;a++)e[a]=0;e[0]=r[0]&128;let n=Gr(e,8),o=new ArrayBuffer(this.valueHex.byteLength),s=new Uint8Array(o);for(let a=0;a<this.valueHex.byteLength;a++)s[a]=r[a];return s[0]&=127,Gr(s,8)-n}function Xf(r){let t=r<0?r*-1:r,e=128;for(let n=1;n<8;n++){if(t<=e){if(r<0){let i=e-t,a=xr(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=xr(t,8,n),s=new Uint8Array(o);if(s[0]&128){let i=o.slice(0),a=new Uint8Array(i);o=new ArrayBuffer(o.byteLength+1),s=new Uint8Array(o);for(let c=0;c<i.byteLength;c++)s[c+1]=a[c];s[0]=0}return o}e*=Math.pow(2,8)}return new ArrayBuffer(0)}function Qf(r,t){if(r.byteLength!==t.byteLength)return!1;let e=new Uint8Array(r),n=new Uint8Array(t);for(let o=0;o<e.length;o++)if(e[o]!==n[o])return!1;return!0}function qt(r,t){let e=r.toString(10);if(t<e.length)return"";let n=t-e.length,o=new Array(n);for(let i=0;i<n;i++)o[i]="0";return o.join("").concat(e)}var NB=Math.log(2);function Ms(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Kc(r){let t=0,e=0;for(let o=0;o<r.length;o++){let s=r[o];t+=s.byteLength}let n=new Uint8Array(t);for(let o=0;o<r.length;o++){let s=r[o];n.set(new Uint8Array(s),e),e+=s.byteLength}return n.buffer}function Je(r,t,e,n){return t instanceof Uint8Array?t.byteLength?e<0?(r.error="Wrong parameter: inputOffset less than zero",!1):n<0?(r.error="Wrong parameter: inputLength less than zero",!1):t.byteLength-e-n<0?(r.error="End of input reached before message was fully decoded (inconsistent offset and length values)",!1):!0:(r.error="Wrong parameter: inputBuffer has zero length",!1):(r.error="Wrong parameter: inputBuffer must be 'Uint8Array'",!1)}var bo=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Kc(this.items)}},wo=[new Uint8Array([1])],th="0123456789";var On="",be=new ArrayBuffer(0),qc=new Uint8Array(0),xo="EndOfContent",rh="OCTET STRING",nh="BIT STRING";function Xe(r){var t;return t=class extends r{constructor(...n){var o;super(...n);let s=n[0]||{};this.isHexOnly=(o=s.isHexOnly)!==null&&o!==void 0?o:!1,this.valueHexView=s.valueHex?Z.BufferSourceConverter.toUint8Array(s.valueHex):qc}get valueHex(){return this.valueHexView.slice().buffer}set valueHex(n){this.valueHexView=new Uint8Array(n)}fromBER(n,o,s){let i=n instanceof ArrayBuffer?new Uint8Array(n):n;if(!Je(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",be)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Z.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var We=class{constructor({blockLength:t=0,error:e=On,warnings:n=[],valueBeforeDecode:o=qc}={}){this.blockLength=t,this.error=e,this.warnings=n,this.valueBeforeDecodeView=Z.BufferSourceConverter.toUint8Array(o)}static blockName(){return this.NAME}get valueBeforeDecode(){return this.valueBeforeDecodeView.slice().buffer}set valueBeforeDecode(t){this.valueBeforeDecodeView=new Uint8Array(t)}toJSON(){return{blockName:this.constructor.NAME,blockLength:this.blockLength,error:this.error,warnings:this.warnings,valueBeforeDecode:Z.Convert.ToHex(this.valueBeforeDecodeView)}}};We.NAME="baseBlock";var Pt=class extends We{fromBER(t,e,n){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}toBER(t,e){throw TypeError("User need to make a specific function in a class which extends 'ValueBlock'")}};Pt.NAME="valueBlock";var $s=class extends Xe(We){constructor({idBlock:t={}}={}){var e,n,o,s;super(),t?(this.isHexOnly=(e=t.isHexOnly)!==null&&e!==void 0?e:!1,this.valueHexView=t.valueHex?Z.BufferSourceConverter.toUint8Array(t.valueHex):qc,this.tagClass=(n=t.tagClass)!==null&&n!==void 0?n:-1,this.tagNumber=(o=t.tagNumber)!==null&&o!==void 0?o:-1,this.isConstructed=(s=t.isConstructed)!==null&&s!==void 0?s:!1):(this.tagClass=-1,this.tagNumber=-1,this.isConstructed=!1)}toBER(t=!1){let e=0;switch(this.tagClass){case 1:e|=0;break;case 2:e|=64;break;case 3:e|=128;break;case 4:e|=192;break;default:return this.error="Unknown tag class",be}if(this.isConstructed&&(e|=32),this.tagNumber<31&&!this.isHexOnly){let o=new Uint8Array(1);if(!t){let s=this.tagNumber;s&=31,e|=s,o[0]=e}return o.buffer}if(!this.isHexOnly){let o=xr(this.tagNumber,7),s=new Uint8Array(o),i=o.byteLength,a=new Uint8Array(i+1);if(a[0]=e|31,!t){for(let c=0;c<i-1;c++)a[c+1]=s[c]|128;a[i]=s[i-1]}return a.buffer}let n=new Uint8Array(this.valueHexView.byteLength+1);if(n[0]=e|31,!t){let o=this.valueHexView;for(let s=0;s<o.length-1;s++)n[s+1]=o[s]|128;n[this.valueHexView.byteLength]=o[o.length-1]}return n.buffer}fromBER(t,e,n){let o=Z.BufferSourceConverter.toUint8Array(t);if(!Je(this,o,e,n))return-1;let s=o.subarray(e,e+n);if(s.length===0)return this.error="Zero buffer length",-1;switch(s[0]&192){case 0:this.tagClass=1;break;case 64:this.tagClass=2;break;case 128:this.tagClass=3;break;case 192:this.tagClass=4;break;default:return this.error="Unknown tag class",-1}this.isConstructed=(s[0]&32)===32,this.isHexOnly=!1;let a=s[0]&31;if(a!==31)this.tagNumber=a,this.blockLength=1;else{let c=1,u=this.valueHexView=new Uint8Array(255),l=255;for(;s[c]&128;){if(u[c-1]=s[c]&127,c++,c>=s.length)return this.error="End of input reached before message was fully decoded",-1;if(c===l){l+=255;let h=new Uint8Array(l);for(let g=0;g<u.length;g++)h[g]=u[g];u=this.valueHexView=new Uint8Array(l)}}this.blockLength=c+1,u[c-1]=s[c]&127;let f=new Uint8Array(c);for(let h=0;h<c;h++)f[h]=u[h];u=this.valueHexView=new Uint8Array(c),u.set(f),this.blockLength<=9?this.tagNumber=Gr(u,7):(this.isHexOnly=!0,this.warnings.push("Tag too long, represented as hex-coded"))}if(this.tagClass===1&&this.isConstructed)switch(this.tagNumber){case 1:case 2:case 5:case 6:case 9:case 13:case 14:case 23:case 24:case 31:case 32:case 33:case 34:return this.error="Constructed encoding used for primitive type",-1}return e+this.blockLength}toJSON(){return{...super.toJSON(),tagClass:this.tagClass,tagNumber:this.tagNumber,isConstructed:this.isConstructed}}};$s.NAME="identificationBlock";var Hs=class extends We{constructor({lenBlock:t={}}={}){var e,n,o;super(),this.isIndefiniteForm=(e=t.isIndefiniteForm)!==null&&e!==void 0?e:!1,this.longFormUsed=(n=t.longFormUsed)!==null&&n!==void 0?n:!1,this.length=(o=t.length)!==null&&o!==void 0?o:0}fromBER(t,e,n){let o=Z.BufferSourceConverter.toUint8Array(t);if(!Je(this,o,e,n))return-1;let s=o.subarray(e,e+n);if(s.length===0)return this.error="Zero buffer length",-1;if(s[0]===255)return this.error="Length block 0xFF is reserved by standard",-1;if(this.isIndefiniteForm=s[0]===128,this.isIndefiniteForm)return this.blockLength=1,e+this.blockLength;if(this.longFormUsed=!!(s[0]&128),this.longFormUsed===!1)return this.length=s[0],this.blockLength=1,e+this.blockLength;let i=s[0]&127;if(i>8)return this.error="Too big integer",-1;if(i+1>s.length)return this.error="End of input reached before message was fully decoded",-1;let a=e+1,c=o.subarray(a,a+i);return c[i-1]===0&&this.warnings.push("Needlessly long encoded length"),this.length=Gr(c,8),this.longFormUsed&&this.length<=127&&this.warnings.push("Unnecessary usage of long length form"),this.blockLength=i+1,e+this.blockLength}toBER(t=!1){let e,n;if(this.length>127&&(this.longFormUsed=!0),this.isIndefiniteForm)return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=128),e;if(this.longFormUsed){let o=xr(this.length,8);if(o.byteLength>127)return this.error="Too big length",be;if(e=new ArrayBuffer(o.byteLength+1),t)return e;let s=new Uint8Array(o);n=new Uint8Array(e),n[0]=o.byteLength|128;for(let i=0;i<o.byteLength;i++)n[i+1]=s[i];return e}return e=new ArrayBuffer(1),t===!1&&(n=new Uint8Array(e),n[0]=this.length),e}toJSON(){return{...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,longFormUsed:this.longFormUsed,length:this.length}}};Hs.NAME="lengthBlock";var D={},Tt=class extends We{constructor({name:t=On,optional:e=!1,primitiveSchema:n,...o}={},s){super(o),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new $s(o),this.lenBlock=new Hs(o),this.valueBlock=s?new s(o):new Pt(o)}fromBER(t,e,n){let o=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return o===-1?(this.error=this.valueBlock.error,o):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),o)}toBER(t,e){let n=e||new bo;e||oh(this);let o=this.idBlock.toBER(t);if(n.write(o),this.lenBlock.isIndefiniteForm)n.write(new Uint8Array([128]).buffer),this.valueBlock.toBER(t,n),n.write(new ArrayBuffer(2));else{let s=this.valueBlock.toBER(t);this.lenBlock.length=s.byteLength;let i=this.lenBlock.toBER(t);n.write(i),n.write(s)}return e?be:n.final()}toJSON(){let t={...super.toJSON(),idBlock:this.idBlock.toJSON(),lenBlock:this.lenBlock.toJSON(),valueBlock:this.valueBlock.toJSON(),name:this.name,optional:this.optional};return this.primitiveSchema&&(t.primitiveSchema=this.primitiveSchema.toJSON()),t}toString(t="ascii"){return t==="ascii"?this.onAsciiEncoding():Z.Convert.ToHex(this.toBER())}onAsciiEncoding(){return`${this.constructor.NAME} : ${Z.Convert.ToHex(this.valueBlock.valueBeforeDecodeView)}`}isEqual(t){if(this===t)return!0;if(!(t instanceof this.constructor))return!1;let e=this.toBER(),n=t.toBER();return Qf(e,n)}};Tt.NAME="BaseBlock";function oh(r){if(r instanceof D.Constructed)for(let t of r.valueBlock.value)oh(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Ks=class extends Tt{constructor({value:t=On,...e}={},n){super(e,n),t&&this.fromString(t)}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}fromBER(t,e,n){let o=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return o===-1?(this.error=this.valueBlock.error,o):(this.fromBuffer(this.valueBlock.valueHexView),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),o)}onAsciiEncoding(){return`${this.constructor.NAME} : '${this.valueBlock.value}'`}};Ks.NAME="BaseStringBlock";var qs=class extends Xe(Pt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};qs.NAME="PrimitiveValueBlock";var sh,zs=class extends Tt{constructor(t={}){super(t,qs),this.idBlock.isConstructed=!1}};sh=zs;D.Primitive=sh;zs.NAME="PRIMITIVE";function gw(r,t){if(r instanceof t)return r;let e=new t;return e.idBlock=r.idBlock,e.lenBlock=r.lenBlock,e.warnings=r.warnings,e.valueBeforeDecodeView=r.valueBeforeDecodeView,e}function Bi(r,t=0,e=r.length){let n=t,o=new Tt({},Pt),s=new We;if(!Je(s,r,t,e))return o.error=s.error,{offset:-1,result:o};if(!r.subarray(t,t+e).length)return o.error="Zero buffer length",{offset:-1,result:o};let a=o.idBlock.fromBER(r,t,e);if(o.idBlock.warnings.length&&o.warnings.concat(o.idBlock.warnings),a===-1)return o.error=o.idBlock.error,{offset:-1,result:o};if(t=a,e-=o.idBlock.blockLength,a=o.lenBlock.fromBER(r,t,e),o.lenBlock.warnings.length&&o.warnings.concat(o.lenBlock.warnings),a===-1)return o.error=o.lenBlock.error,{offset:-1,result:o};if(t=a,e-=o.lenBlock.blockLength,!o.idBlock.isConstructed&&o.lenBlock.isIndefiniteForm)return o.error="Indefinite length form used for primitive encoding form",{offset:-1,result:o};let c=Tt;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 u=o.idBlock.isConstructed?new D.Constructed:new D.Primitive;u.idBlock=o.idBlock,u.lenBlock=o.lenBlock,u.warnings=o.warnings,o=u}}break;case 2:case 3:case 4:default:c=o.idBlock.isConstructed?D.Constructed:D.Primitive}return o=gw(o,c),a=o.fromBER(r,t,o.lenBlock.isIndefiniteForm?e:o.lenBlock.length),o.valueBeforeDecodeView=r.subarray(n,n+o.blockLength),{offset:a,result:o}}function Fn(r){if(!r.byteLength){let t=new Tt({},Pt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return Bi(Z.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function ww(r,t){return r?1:t}var Te=class extends Pt{constructor({value:t=[],isIndefiniteForm:e=!1,...n}={}){super(n),this.value=t,this.isIndefiniteForm=e}fromBER(t,e,n){let o=Z.BufferSourceConverter.toUint8Array(t);if(!Je(this,o,e,n))return-1;if(this.valueBeforeDecodeView=o.subarray(e,e+n),this.valueBeforeDecodeView.length===0)return this.warnings.push("Zero buffer length"),e;let s=e;for(;ww(this.isIndefiniteForm,n)>0;){let i=Bi(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===xo)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===xo?this.value.pop():this.warnings.push("No EndOfContent block encoded")),s}toBER(t,e){let n=e||new bo;for(let o=0;o<this.value.length;o++)this.value[o].toBER(t,n);return e?be:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Te.NAME="ConstructedValueBlock";var ih,Er=class extends Tt{constructor(t={}){super(t,Te),this.idBlock.isConstructed=!0}fromBER(t,e,n){this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm;let o=this.valueBlock.fromBER(t,e,this.lenBlock.isIndefiniteForm?n:this.lenBlock.length);return o===-1?(this.error=this.valueBlock.error,o):(this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.valueBlock.error.length||(this.blockLength+=this.valueBlock.blockLength),o)}onAsciiEncoding(){let t=[];for(let n of this.valueBlock.value)t.push(n.toString("ascii").split(`
4
4
  `).map(o=>` ${o}`).join(`
5
- `));let t=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return e.length?`${t} :
6
- ${e.join(`
7
- `)}`:`${t} :`}};wf=mr;U.Constructed=wf;mr.NAME="CONSTRUCTED";var ks=class extends Ce{fromBER(e,t,n){return t}toBER(e){return ft}};ks.override="EndOfContentValueBlock";var bf,Ss=class extends ke{constructor(e={}){super(e,ks),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};bf=Ss;U.EndOfContent=bf;Ss.NAME=ao;var xf,yr=class extends ke{constructor(e={}){super(e,Ce),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(e,t,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,t+n>e.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):t+n}toBER(e,t){let n=new ArrayBuffer(2);if(!e){let o=new Uint8Array(n);o[0]=5,o[1]=0}return t&&t.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};xf=yr;U.Null=xf;yr.NAME="NULL";var Is=class extends qt(Ce){constructor({value:e,...t}={}){super(t),t.valueHex?this.valueHexView=Y.BufferSourceConverter.toUint8Array(t.valueHex):this.valueHexView=new Uint8Array(1),e&&(this.value=e)}get value(){for(let e of this.valueHexView)if(e>0)return!0;return!1}set value(e){this.valueHexView[0]=e?255:0}fromBER(e,t,n){let o=Y.BufferSourceConverter.toUint8Array(e);return Kt(this,o,t,n)?(this.valueHexView=o.subarray(t,t+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,yc.call(this),this.blockLength=n,t+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Is.NAME="BooleanValueBlock";var Ef,Rs=class extends ke{constructor(e={}){super(e,Is),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(e){this.valueBlock.value=e}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};Ef=Rs;U.Boolean=Ef;Rs.NAME="BOOLEAN";var _s=class extends qt(xt){constructor({isConstructed:e=!1,...t}={}){super(t),this.isConstructed=e}fromBER(e,t,n){let o=0;if(this.isConstructed){if(this.isHexOnly=!1,o=xt.prototype.fromBER.call(this,e,t,n),o===-1)return o;for(let s=0;s<this.value.length;s++){let i=this.value[s].constructor.NAME;if(i===ao){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==pf)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,o=super.fromBER(e,t,n),this.blockLength=n;return o}toBER(e,t){return this.isConstructed?xt.prototype.toBER.call(this,e,t):e?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};_s.NAME="OctetStringValueBlock";var vf,Ht=class r extends ke{constructor({idBlock:e={},lenBlock:t={},...n}={}){var o,s;(o=n.isConstructed)!==null&&o!==void 0||(n.isConstructed=!!(!((s=n.value)===null||s===void 0)&&s.length)),super({idBlock:{isConstructed:n.isConstructed,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},_s),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(e,t,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),t;if(!this.valueBlock.isConstructed){let s=(e instanceof ArrayBuffer?new Uint8Array(e):e).subarray(t,t+n);try{if(s.byteLength){let i=ni(s,0,s.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(e,t,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?mr.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${Y.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let e=[];for(let t of this.valueBlock.value)t instanceof r&&e.push(t.valueBlock.valueHexView);return Y.BufferSourceConverter.concat(e)}};vf=Ht;U.OctetString=vf;Ht.NAME=pf;var Ts=class extends qt(xt){constructor({unusedBits:e=0,isConstructed:t=!1,...n}={}){super(n),this.unusedBits=e,this.isConstructed=t,this.blockLength=this.valueHexView.byteLength}fromBER(e,t,n){if(!n)return t;let o=-1;if(this.isConstructed){if(o=xt.prototype.fromBER.call(this,e,t,n),o===-1)return o;for(let a of this.value){let c=a.constructor.NAME;if(c===ao){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==mf)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let f=a.valueBlock;if(this.unusedBits>0&&f.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=f.unusedBits}return o}let s=Y.BufferSourceConverter.toUint8Array(e);if(!Kt(this,s,t,n))return-1;let i=s.subarray(t,t+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=ni(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,t+n}toBER(e,t){if(this.isConstructed)return xt.prototype.toBER.call(this,e,t);if(e)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return ft;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};Ts.NAME="BitStringValueBlock";var Af,In=class extends ke{constructor({idBlock:e={},lenBlock:t={},...n}={}){var o,s;(o=n.isConstructed)!==null&&o!==void 0||(n.isConstructed=!!(!((s=n.value)===null||s===void 0)&&s.length)),super({idBlock:{isConstructed:n.isConstructed,...e},lenBlock:{...t,isIndefiniteForm:!!n.isIndefiniteForm},...n},Ts),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(e,t,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(e,t,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return mr.prototype.onAsciiEncoding.call(this);{let e=[],t=this.valueBlock.valueHexView;for(let o of t)e.push(o.toString(2).padStart(8,"0"));let n=e.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};Af=In;U.BitString=Af;In.NAME=mf;var Bf;function pg(r,e){let t=new Uint8Array([0]),n=new Uint8Array(r),o=new Uint8Array(e),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,f=0,u=c<i?i:c,l=0;for(let p=u;p>=0;p--,l++){switch(!0){case l<a.length:f=s[i-l]+a[c-l]+t[0];break;default:f=s[i-l]+t[0]}switch(t[0]=f/10,!0){case l>=s.length:s=ws(new Uint8Array([f%10]),s);break;default:s[i-l]=f%10}}return t[0]>0&&(s=ws(t,s)),s}function df(r){if(r>=so.length)for(let e=so.length;e<=r;e++){let t=new Uint8Array([0]),n=so[e-1].slice(0);for(let o=n.length-1;o>=0;o--){let s=new Uint8Array([(n[o]<<1)+t[0]]);t[0]=s[0]/10,n[o]=s[0]%10}t[0]>0&&(n=ws(t,n)),so.push(n)}return so[r]}function mg(r,e){let t=0,n=new Uint8Array(r),o=new Uint8Array(e),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,f,u=0;for(let l=c;l>=0;l--,u++)switch(f=s[i-u]-a[c-u]-t,!0){case f<0:t=1,s[i-u]=f+10;break;default:t=0,s[i-u]=f}if(t>0)for(let l=i-c+1;l>=0;l--,u++)if(f=s[i-u]-t,f<0)t=1,s[i-u]=f+10;else{t=0,s[i-u]=f;break}return s.slice()}var co=class extends qt(Ce){constructor({value:e,...t}={}){super(t),this._valueDec=0,t.valueHex&&this.setValueHex(),e!==void 0&&(this.valueDec=e)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=yc.call(this)))}set valueDec(e){this._valueDec=e,this.isHexOnly=!1,this.valueHexView=new Uint8Array(lf(e))}get valueDec(){return this._valueDec}fromDER(e,t,n,o=0){let s=this.fromBER(e,t,n);if(s===-1)return s;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):o!==0&&i.length<o&&(o-i.length>1&&(o=i.length+1),this.valueHexView=i.subarray(o-i.length)),s}toDER(e=!1){let t=this.valueHexView;switch(!0){case(t[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(t,1),this.valueHexView=n}break;case(t[0]===0&&(t[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(e)}fromBER(e,t,n){let o=super.fromBER(e,t,n);return o===-1||this.setValueHex(),o}toBER(e){return e?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let e=this.valueHexView.length*8-1,t=new Uint8Array(this.valueHexView.length*8/3),n=0,o,s=this.valueHexView,i="",a=!1;for(let c=s.byteLength-1;c>=0;c--){o=s[c];for(let f=0;f<8;f++){if((o&1)===1)switch(n){case e:t=mg(df(n),t),i="-";break;default:t=pg(t,df(n))}n++,o>>=1}}for(let c=0;c<t.length;c++)t[c]&&(a=!0),a&&(i+=hf.charAt(t[c]));return a===!1&&(i+=hf.charAt(0)),i}};Bf=co;co.NAME="IntegerValueBlock";Object.defineProperty(Bf.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var kf,me=class r extends ke{constructor(e={}){super(e,co),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return bs(),BigInt(this.valueBlock.toString())}static fromBigInt(e){bs();let t=BigInt(e),n=new io,o=t.toString(16).replace(/^-/,""),s=new Uint8Array(Y.Convert.FromHex(o));if(t<0){let a=new Uint8Array(s.length+(s[0]&128?1:0));a[0]|=128;let f=BigInt(`0x${Y.Convert.ToHex(a)}`)+t,u=Y.BufferSourceConverter.toUint8Array(Y.Convert.FromHex(f.toString(16)));u[0]|=128,n.write(u)}else s[0]&128&&n.write(new Uint8Array([0])),n.write(s);return new r({valueHex:n.final()})}convertToDER(){let e=new r({valueHex:this.valueBlock.valueHexView});return e.valueBlock.toDER(),e}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};kf=me;U.Integer=kf;me.NAME="INTEGER";var Sf,Cs=class extends me{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Sf=Cs;U.Enumerated=Sf;Cs.NAME="ENUMERATED";var uo=class extends qt(Ce){constructor({valueDec:e=-1,isFirstSid:t=!1,...n}={}){super(n),this.valueDec=e,this.isFirstSid=t}fromBER(e,t,n){if(!n)return t;let o=Y.BufferSourceConverter.toUint8Array(e);if(!Kt(this,o,t,n))return-1;let s=o.subarray(t,t+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=s[a]&127,this.blockLength++,!!(s[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,s[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Or(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}set valueBigInt(e){bs();let t=BigInt(e).toString(2);for(;t.length%7;)t="0"+t;let n=new Uint8Array(t.length/7);for(let o=0;o<n.length;o++)n[o]=parseInt(t.slice(o*7,o*7+7),2)+(o+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(e){if(this.isHexOnly){if(e)return new ArrayBuffer(this.valueHexView.byteLength);let o=this.valueHexView,s=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)s[i]=o[i]|128;return s[this.blockLength-1]=o[this.blockLength-1],s.buffer}let t=pr(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",ft;let n=new Uint8Array(t.byteLength);if(!e){let o=new Uint8Array(t),s=t.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n}toString(){let e="";if(this.isHexOnly)e=Y.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let t=this.valueDec;this.valueDec<=39?e="0.":this.valueDec<=79?(e="1.",t-=40):(e="2.",t-=80),e+=t.toString()}else e=this.valueDec.toString();return e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};uo.NAME="sidBlock";var Ns=class extends Ce{constructor({value:e=Rn,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let s=new uo;if(o=s.fromBER(e,o,n),o===-1)return this.blockLength=0,this.error=s.error,o;this.value.length===0&&(s.isFirstSid=!0),this.blockLength+=s.blockLength,n-=s.blockLength,this.value.push(s)}return o}toBER(e){let t=[];for(let n=0;n<this.value.length;n++){let o=this.value[n].toBER(e);if(o.byteLength===0)return this.error=this.value[n].error,ft;t.push(o)}return gc(t)}fromString(e){this.value=[];let t=0,n=0,o="",s=!1;do if(n=e.indexOf(".",t),n===-1?o=e.substring(t):o=e.substring(t,n),t=n+1,s){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(o,10);if(isNaN(c))return;i.valueDec=c+a,s=!1}else{let i=new uo;if(o>Number.MAX_SAFE_INTEGER){bs();let a=BigInt(o);i.valueBigInt=a}else if(i.valueDec=parseInt(o,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,s=!0),this.value.push(i)}while(n!==-1)}toString(){let e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let o=this.value[n].toString();n!==0&&(e=`${e}.`),t?(o=`{${o}}`,this.value[n].isFirstSid?e=`2.{${o} - 80}`:e+=o):e+=o}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};Ns.NAME="ObjectIdentifierValueBlock";var If,lt=class extends ke{constructor(e={}){super(e,Ns),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};If=lt;U.ObjectIdentifier=If;lt.NAME="OBJECT IDENTIFIER";var lo=class extends qt(Mt){constructor({valueDec:e=0,...t}={}){super(t),this.valueDec=e}fromBER(e,t,n){if(n===0)return t;let o=Y.BufferSourceConverter.toUint8Array(e);if(!Kt(this,o,t,n))return-1;let s=o.subarray(t,t+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=s[a]&127,this.blockLength++,!!(s[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,s[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Or(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),t+this.blockLength)}toBER(e){if(this.isHexOnly){if(e)return new ArrayBuffer(this.valueHexView.byteLength);let o=this.valueHexView,s=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)s[i]=o[i]|128;return s[this.blockLength-1]=o[this.blockLength-1],s.buffer}let t=pr(this.valueDec,7);if(t.byteLength===0)return this.error="Error during encoding SID value",ft;let n=new Uint8Array(t.byteLength);if(!e){let o=new Uint8Array(t),s=t.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n.buffer}toString(){let e="";return this.isHexOnly?e=Y.Convert.ToHex(this.valueHexView):e=this.valueDec.toString(),e}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};lo.NAME="relativeSidBlock";var Ls=class extends Ce{constructor({value:e=Rn,...t}={}){super(t),this.value=[],e&&this.fromString(e)}fromBER(e,t,n){let o=t;for(;n>0;){let s=new lo;if(o=s.fromBER(e,o,n),o===-1)return this.blockLength=0,this.error=s.error,o;this.blockLength+=s.blockLength,n-=s.blockLength,this.value.push(s)}return o}toBER(e,t){let n=[];for(let o=0;o<this.value.length;o++){let s=this.value[o].toBER(e);if(s.byteLength===0)return this.error=this.value[o].error,ft;n.push(s)}return gc(n)}fromString(e){this.value=[];let t=0,n=0,o="";do{n=e.indexOf(".",t),n===-1?o=e.substring(t):o=e.substring(t,n),t=n+1;let s=new lo;if(s.valueDec=parseInt(o,10),isNaN(s.valueDec))return!0;this.value.push(s)}while(n!==-1);return!0}toString(){let e="",t=!1;for(let n=0;n<this.value.length;n++){t=this.value[n].isHexOnly;let o=this.value[n].toString();n!==0&&(e=`${e}.`),t&&(o=`{${o}}`),e+=o}return e}toJSON(){let e={...super.toJSON(),value:this.toString(),sidArray:[]};for(let t=0;t<this.value.length;t++)e.sidArray.push(this.value[t].toJSON());return e}};Ls.NAME="RelativeObjectIdentifierValueBlock";var Rf,Ds=class extends ke{constructor(e={}){super(e,Ls),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(e){this.valueBlock.fromString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};Rf=Ds;U.RelativeObjectIdentifier=Rf;Ds.NAME="RelativeObjectIdentifier";var _f,xe=class extends mr{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};_f=xe;U.Sequence=_f;xe.NAME="SEQUENCE";var Tf,Us=class extends mr{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};Tf=Us;U.Set=Tf;Us.NAME="SET";var Ps=class extends qt(Ce){constructor({...e}={}){super(e),this.isHexOnly=!0,this.value=Rn}toJSON(){return{...super.toJSON(),value:this.value}}};Ps.NAME="StringValueBlock";var Os=class extends Ps{};Os.NAME="SimpleStringValueBlock";var Pe=class extends vs{constructor({...e}={}){super(e,Os)}fromBuffer(e){this.valueBlock.value=String.fromCharCode.apply(null,Y.BufferSourceConverter.toUint8Array(e))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t);for(let o=0;o<t;o++)n[o]=e.charCodeAt(o);this.valueBlock.value=e}};Pe.NAME="SIMPLE STRING";var Vs=class extends Pe{fromBuffer(e){this.valueBlock.valueHexView=Y.BufferSourceConverter.toUint8Array(e);try{this.valueBlock.value=Y.Convert.ToUtf8String(e)}catch(t){this.warnings.push(`Error during "decodeURIComponent": ${t}, using raw string`),this.valueBlock.value=Y.Convert.ToBinary(e)}}fromString(e){this.valueBlock.valueHexView=new Uint8Array(Y.Convert.FromUtf8String(e)),this.valueBlock.value=e}};Vs.NAME="Utf8StringValueBlock";var Cf,$t=class extends Vs{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};Cf=$t;U.Utf8String=Cf;$t.NAME="UTF8String";var Fs=class extends Pe{fromBuffer(e){this.valueBlock.value=Y.Convert.ToUtf16String(e),this.valueBlock.valueHexView=Y.BufferSourceConverter.toUint8Array(e)}fromString(e){this.valueBlock.value=e,this.valueBlock.valueHexView=new Uint8Array(Y.Convert.FromUtf16String(e))}};Fs.NAME="BmpStringValueBlock";var Nf,Ms=class extends Fs{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};Nf=Ms;U.BmpString=Nf;Ms.NAME="BMPString";var Hs=class extends Pe{fromBuffer(e){let t=ArrayBuffer.isView(e)?e.slice().buffer:e.slice(0),n=new Uint8Array(t);for(let o=0;o<n.length;o+=4)n[o]=n[o+3],n[o+1]=n[o+2],n[o+2]=0,n[o+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(t))}fromString(e){let t=e.length,n=this.valueBlock.valueHexView=new Uint8Array(t*4);for(let o=0;o<t;o++){let s=pr(e.charCodeAt(o),8),i=new Uint8Array(s);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[o*4+c+a]=i[c]}this.valueBlock.value=e}};Hs.NAME="UniversalStringValueBlock";var Lf,$s=class extends Hs{constructor({...e}={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Lf=$s;U.UniversalString=Lf;$s.NAME="UniversalString";var Df,Ks=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};Df=Ks;U.NumericString=Df;Ks.NAME="NumericString";var Uf,qs=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Uf=qs;U.PrintableString=Uf;qs.NAME="PrintableString";var Pf,zs=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Pf=zs;U.TeletexString=Pf;zs.NAME="TeletexString";var Of,Gs=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Of=Gs;U.VideotexString=Of;Gs.NAME="VideotexString";var Vf,js=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Vf=js;U.IA5String=Vf;js.NAME="IA5String";var Ff,Ws=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Ff=Ws;U.GraphicString=Ff;Ws.NAME="GraphicString";var Mf,fo=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Mf=fo;U.VisibleString=Mf;fo.NAME="VisibleString";var Hf,Ys=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Hf=Ys;U.GeneralString=Hf;Ys.NAME="GeneralString";var $f,Zs=class extends Pe{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};$f=Zs;U.CharacterString=$f;Zs.NAME="CharacterString";var Kf,ho=class extends fo{constructor({value:e,valueDate:t,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,e){this.fromString(e),this.valueBlock.valueHexView=new Uint8Array(e.length);for(let o=0;o<e.length;o++)this.valueBlock.valueHexView[o]=e.charCodeAt(o)}t&&(this.fromDate(t),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(e){this.fromString(String.fromCharCode.apply(null,Y.BufferSourceConverter.toUint8Array(e)))}toBuffer(){let e=this.toString(),t=new ArrayBuffer(e.length),n=new Uint8Array(t);for(let o=0;o<e.length;o++)n[o]=e.charCodeAt(o);return t}fromDate(e){this.year=e.getUTCFullYear(),this.month=e.getUTCMonth()+1,this.day=e.getUTCDate(),this.hour=e.getUTCHours(),this.minute=e.getUTCMinutes(),this.second=e.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(e){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(e);if(n===null){this.error="Wrong input string for conversion";return}let o=parseInt(n[1],10);o>=50?this.year=1900+o:this.year=2e3+o,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(e="iso"){if(e==="iso"){let t=new Array(7);return t[0]=Fe(this.year<2e3?this.year-1900:this.year-2e3,2),t[1]=Fe(this.month,2),t[2]=Fe(this.day,2),t[3]=Fe(this.hour,2),t[4]=Fe(this.minute,2),t[5]=Fe(this.second,2),t[6]="Z",t.join("")}return super.toString(e)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};Kf=ho;U.UTCTime=Kf;ho.NAME="UTCTime";var qf,Js=class extends ho{constructor(e={}){var t;super(e),(t=this.millisecond)!==null&&t!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(e){super.fromDate(e),this.millisecond=e.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(e){let t=!1,n="",o="",s=0,i,a=0,c=0;if(e[e.length-1]==="Z")n=e.substring(0,e.length-1),t=!0;else{let l=new Number(e[e.length-1]);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");n=e}if(t){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let l=1,p=n.indexOf("+"),E="";if(p===-1&&(p=n.indexOf("-"),l=-1),p!==-1){if(E=n.substring(p+1),n=n.substring(0,p),E.length!==2&&E.length!==4)throw new Error("Wrong input string for conversion");let y=parseInt(E.substring(0,2),10);if(isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*y,E.length===4){if(y=parseInt(E.substring(2,4),10),isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");c=l*y}}}let f=n.indexOf(".");if(f===-1&&(f=n.indexOf(",")),f!==-1){let l=new Number(`0${n.substring(f)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");s=l.valueOf(),o=n.substring(0,f)}else o=n;switch(!0){case o.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,f!==-1)throw new Error("Wrong input string for conversion");break;case o.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=60*s;this.minute=Math.floor(l),l=60*(l-this.minute),this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case o.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=60*s;this.second=Math.floor(l),l=1e3*(l-this.second),this.millisecond=Math.floor(l)}break;case o.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,f!==-1){let l=1e3*s;this.millisecond=Math.floor(l)}break;default:throw new Error("Wrong input string for conversion")}let u=i.exec(o);if(u===null)throw new Error("Wrong input string for conversion");for(let l=1;l<u.length;l++)switch(l){case 1:this.year=parseInt(u[l],10);break;case 2:this.month=parseInt(u[l],10);break;case 3:this.day=parseInt(u[l],10);break;case 4:this.hour=parseInt(u[l],10)+a;break;case 5:this.minute=parseInt(u[l],10)+c;break;case 6:this.second=parseInt(u[l],10);break;default:throw new Error("Wrong input string for conversion")}if(t===!1){let l=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=l.getUTCFullYear(),this.month=l.getUTCMonth(),this.day=l.getUTCDay(),this.hour=l.getUTCHours(),this.minute=l.getUTCMinutes(),this.second=l.getUTCSeconds(),this.millisecond=l.getUTCMilliseconds()}}toString(e="iso"){if(e==="iso"){let t=[];return t.push(Fe(this.year,4)),t.push(Fe(this.month,2)),t.push(Fe(this.day,2)),t.push(Fe(this.hour,2)),t.push(Fe(this.minute,2)),t.push(Fe(this.second,2)),this.millisecond!==0&&(t.push("."),t.push(Fe(this.millisecond,3))),t.push("Z"),t.join("")}return super.toString(e)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};qf=Js;U.GeneralizedTime=qf;Js.NAME="GeneralizedTime";var zf,Xs=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};zf=Xs;U.DATE=zf;Xs.NAME="DATE";var Gf,Qs=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Gf=Qs;U.TimeOfDay=Gf;Qs.NAME="TimeOfDay";var jf,ei=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};jf=ei;U.DateTime=jf;ei.NAME="DateTime";var Wf,ti=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Wf=ti;U.Duration=Wf;ti.NAME="Duration";var Yf,ri=class extends $t{constructor(e={}){super(e),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Yf=ri;U.TIME=Yf;ri.NAME="TIME";function gg(r){let{result:e}=_n(r),t=e.valueBlock.value;return{n:z(Et(t[1].toBigInt()),"base64url"),e:z(Et(t[2].toBigInt()),"base64url"),d:z(Et(t[3].toBigInt()),"base64url"),p:z(Et(t[4].toBigInt()),"base64url"),q:z(Et(t[5].toBigInt()),"base64url"),dp:z(Et(t[6].toBigInt()),"base64url"),dq:z(Et(t[7].toBigInt()),"base64url"),qi:z(Et(t[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function wg(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new N("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new xe({value:[new me({value:0}),me.fromBigInt(vt(W(r.n,"base64url"))),me.fromBigInt(vt(W(r.e,"base64url"))),me.fromBigInt(vt(W(r.d,"base64url"))),me.fromBigInt(vt(W(r.p,"base64url"))),me.fromBigInt(vt(W(r.q,"base64url"))),me.fromBigInt(vt(W(r.dp,"base64url"))),me.fromBigInt(vt(W(r.dq,"base64url"))),me.fromBigInt(vt(W(r.qi,"base64url")))]}).toBER();return new Uint8Array(t,0,t.byteLength)}function bg(r){let{result:e}=_n(r),t=e.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:z(Et(t[0].toBigInt()),"base64url"),e:z(Et(t[1].toBigInt()),"base64url")}}function xg(r){if(r.n==null||r.e==null)throw new N("JWK was missing components","ERR_INVALID_PARAMETERS");let t=new xe({value:[new xe({value:[new lt({value:"1.2.840.113549.1.1.1"}),new yr]}),new In({valueHex:new xe({value:[me.fromBigInt(vt(W(r.n,"base64url"))),me.fromBigInt(vt(W(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(t,0,t.byteLength)}function Et(r){let e=r.toString(16);e.length%2>0&&(e=`0${e}`);let t=e.length/2,n=new Uint8Array(t),o=0,s=0;for(;o<t;)n[o]=parseInt(e.slice(s,s+2),16),o+=1,s+=2;return n}function vt(r){let e=[];return r.forEach(function(t){let n=t.toString(16);n.length%2>0&&(n=`0${n}`),e.push(n)}),BigInt("0x"+e.join(""))}var Eg=16,bc=32,xc=1e4;async function vg(r,e){let t=Ue.get(),o=new xe({value:[new me({value:0}),new xe({value:[new lt({value:"1.2.840.113549.1.1.1"}),new yr]}),new Ht({valueHex:r.marshal()})]}).toBER(),s=new Uint8Array(o,0,o.byteLength),i=Pr(Eg),a=await pc(xn,e,i,{c:xc,dkLen:bc}),c=Pr(16),f=await t.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),u=await t.subtle.encrypt({name:"AES-CBC",iv:c},f,s),l=new xe({value:[new Ht({valueHex:i}),new me({value:xc}),new me({value:bc}),new xe({value:[new lt({value:"1.2.840.113549.2.11"}),new yr]})]}),p=new xe({value:[new lt({value:"1.2.840.113549.1.5.13"}),new xe({value:[new xe({value:[new lt({value:"1.2.840.113549.1.5.12"}),l]}),new xe({value:[new lt({value:"2.16.840.1.101.3.4.1.42"}),new Ht({valueHex:c})]})]})]}),y=new xe({value:[p,new Ht({valueHex:u})]}).toBER(),d=new Uint8Array(y,0,y.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...z(d,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
8
- `)}async function Ag(r,e){let t=Ue.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=W(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=_n(o),{iv:i,salt:a,iterations:c,keySize:f,cipherText:u}=Bg(s),l=await pc(xn,e,a,{c,dkLen:f}),p=await t.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),E=po(await t.subtle.decrypt({name:"AES-CBC",iv:i},p,u)),{result:y}=_n(E);n=Zf(y)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=W(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=_n(o);n=Zf(s)}else throw new N("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Ec(n)}function Bg(r){let e=r.valueBlock.value[0];if(e.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new N("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=e.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new N("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let s=n.valueBlock.value[1],i=po(s.valueBlock.value[0].getValue()),a=xc,c=bc;if(s.valueBlock.value.length===3)a=Number(s.valueBlock.value[1].toBigInt()),c=Number(s.valueBlock.value[2].toBigInt());else if(s.valueBlock.value.length===2)throw new N("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let f=e.valueBlock.value[1].valueBlock.value[1],u=f.valueBlock.value[0].toString();if(u!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(u!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new N("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=po(f.valueBlock.value[1].getValue());return{cipherText:po(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:l}}function Zf(r){return po(r.valueBlock.value[2].getValue())}function po(r){return new Uint8Array(r,0,r.byteLength)}async function Jf(r){let e=await Ue.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),t=await eh(e);return{privateKey:t[0],publicKey:t[1]}}async function vc(r){let t=[await Ue.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await kg(r)],n=await eh({privateKey:t[0],publicKey:t[1]});return{privateKey:n[0],publicKey:n[1]}}async function Xf(r,e){let t=await Ue.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ue.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},t,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(n,0,n.byteLength)}async function Qf(r,e,t){let n=await Ue.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ue.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,e,t instanceof Uint8Array?t:t.subarray())}async function eh(r){if(r.privateKey==null||r.publicKey==null)throw new N("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Ue.get().subtle.exportKey("jwk",r.privateKey),Ue.get().subtle.exportKey("jwk",r.publicKey)])}async function kg(r){return Ue.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function oi(r){if(r.kty!=="RSA")throw new N("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new N("invalid key modulus","ERR_INVALID_KEY_MODULUS");return W(r.n,"base64url").length*8}var yo=8192,mo=class{_key;constructor(e){this._key=e}verify(e,t){return Qf(this._key,t,e)}marshal(){return gr.jwkToPkix(this._key)}get bytes(){return bt.encode({Type:de.RSA,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(e)?e.then(({bytes:t})=>t):e.bytes}},Tn=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t}genSecret(){return Pr(16)}sign(e){return Xf(this._key,e)}get public(){if(this._publicKey==null)throw new N("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new mo(this._publicKey)}marshal(){return gr.jwkToPkcs1(this._key)}get bytes(){return Vt.encode({Type:de.RSA,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return z(e,"base58btc")}async export(e,t="pkcs-8"){if(t==="pkcs-8")return gr.exportToPem(this,e);if(t==="libp2p-key")return Bn(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Ec(r){let e=gr.pkcs1ToJwk(r);if(oi(e)>yo)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await vc(e);return new Tn(t.privateKey,t.publicKey)}function Ig(r){let e=gr.pkixToJwk(r);if(oi(e)>yo)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new mo(e)}async function Rg(r){if(oi(r)>yo)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await vc(r);return new Tn(e.privateKey,e.publicKey)}async function _g(r){if(r>yo)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Jf(r);return new Tn(e.privateKey,e.publicKey)}var Rc={};ge(Rc,{Secp256k1PrivateKey:()=>wo,Secp256k1PublicKey:()=>go,generateKeyPair:()=>$g,unmarshalSecp256k1PrivateKey:()=>Mg,unmarshalSecp256k1PublicKey:()=>Hg});var Tg=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),wr=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),br=new Uint32Array(64),Bc=class extends bn{constructor(){super(64,32,8,!1),this.A=wr[0]|0,this.B=wr[1]|0,this.C=wr[2]|0,this.D=wr[3]|0,this.E=wr[4]|0,this.F=wr[5]|0,this.G=wr[6]|0,this.H=wr[7]|0}get(){let{A:e,B:t,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[e,t,n,o,s,i,a,c]}set(e,t,n,o,s,i,a,c){this.A=e|0,this.B=t|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=a|0,this.H=c|0}process(e,t){for(let l=0;l<16;l++,t+=4)br[l]=e.getUint32(t,!1);for(let l=16;l<64;l++){let p=br[l-15],E=br[l-2],y=ct(p,7)^ct(p,18)^p>>>3,d=ct(E,17)^ct(E,19)^E>>>10;br[l]=d+br[l-7]+y+br[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let p=ct(a,6)^ct(a,11)^ct(a,25),E=u+p+Vl(a,c,f)+Tg[l]+br[l]|0,d=(ct(n,2)^ct(n,13)^ct(n,22))+Fl(n,o,s)|0;u=f,f=c,c=a,a=i+E|0,i=s,s=o,o=n,n=E+d|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,f=f+this.G|0,u=u+this.H|0,this.set(n,o,s,i,a,c,f,u)}roundClean(){br.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var th=os(()=>new Bc);function Cg(r){let e=ro(r);wt(e,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:t,Fp:n,a:o}=e;if(t){if(!n.eql(o,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof t!="object"||typeof t.beta!="bigint"||typeof t.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...e})}var{bytesToNumberBE:Ng,hexToBytes:Lg}=as,Vr={Err:class extends Error{constructor(e=""){super(e)}},_parseInt(r){let{Err:e}=Vr;if(r.length<2||r[0]!==2)throw new e("Invalid signature integer tag");let t=r[1],n=r.subarray(2,t+2);if(!t||n.length!==t)throw new e("Invalid signature integer: wrong length");if(n[0]&128)throw new e("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new e("Invalid signature integer: unnecessary leading zero");return{d:Ng(n),l:r.subarray(t+2)}},toSig(r){let{Err:e}=Vr,t=typeof r=="string"?Lg(r):r;En(t);let n=t.length;if(n<2||t[0]!=48)throw new e("Invalid signature tag");if(t[1]!==n-2)throw new e("Invalid signature: incorrect length");let{d:o,l:s}=Vr._parseInt(t.subarray(2)),{d:i,l:a}=Vr._parseInt(s);if(a.length)throw new e("Invalid signature: left bytes after parsing");return{r:o,s:i}},hexFromSig(r){let e=f=>Number.parseInt(f[0],16)&8?"00"+f:f,t=f=>{let u=f.toString(16);return u.length&1?`0${u}`:u},n=e(t(r.s)),o=e(t(r.r)),s=n.length/2,i=o.length/2,a=t(s),c=t(i);return`30${t(i+s+4)}02${c}${o}02${a}${n}`}},zt=BigInt(0),et=BigInt(1),aA=BigInt(2),rh=BigInt(3),cA=BigInt(4);function Dg(r){let e=Cg(r),{Fp:t}=e,n=e.toBytes||((y,d,m)=>{let g=d.toAffine();return Ut(Uint8Array.from([4]),t.toBytes(g.x),t.toBytes(g.y))}),o=e.fromBytes||(y=>{let d=y.subarray(1),m=t.fromBytes(d.subarray(0,t.BYTES)),g=t.fromBytes(d.subarray(t.BYTES,2*t.BYTES));return{x:m,y:g}});function s(y){let{a:d,b:m}=e,g=t.sqr(y),I=t.mul(g,y);return t.add(t.add(I,t.mul(y,d)),m)}if(!t.eql(t.sqr(e.Gy),s(e.Gx)))throw new Error("bad generator point: equation left != right");function i(y){return typeof y=="bigint"&&zt<y&&y<e.n}function a(y){if(!i(y))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(y){let{allowedPrivateKeyLengths:d,nByteLength:m,wrapPrivateKey:g,n:I}=e;if(d&&typeof y!="bigint"){if(fr(y)&&(y=Lt(y)),typeof y!="string"||!d.includes(y.length))throw new Error("Invalid key");y=y.padStart(m*2,"0")}let v;try{v=typeof y=="bigint"?y:Dt(fe("private key",y,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof y}`)}return g&&(v=oe(v,I)),a(v),v}let f=new Map;function u(y){if(!(y instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(d,m,g){if(this.px=d,this.py=m,this.pz=g,d==null||!t.isValid(d))throw new Error("x required");if(m==null||!t.isValid(m))throw new Error("y required");if(g==null||!t.isValid(g))throw new Error("z required")}static fromAffine(d){let{x:m,y:g}=d||{};if(!d||!t.isValid(m)||!t.isValid(g))throw new Error("invalid affine point");if(d instanceof l)throw new Error("projective point not allowed");let I=v=>t.eql(v,t.ZERO);return I(m)&&I(g)?l.ZERO:new l(m,g,t.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let m=t.invertBatch(d.map(g=>g.pz));return d.map((g,I)=>g.toAffine(m[I])).map(l.fromAffine)}static fromHex(d){let m=l.fromAffine(o(fe("pointHex",d)));return m.assertValidity(),m}static fromPrivateKey(d){return l.BASE.multiply(c(d))}_setWindowSize(d){this._WINDOW_SIZE=d,f.delete(this)}assertValidity(){if(this.is0()){if(e.allowInfinityPoint&&!t.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:d,y:m}=this.toAffine();if(!t.isValid(d)||!t.isValid(m))throw new Error("bad point: x or y not FE");let g=t.sqr(m),I=s(d);if(!t.eql(g,I))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:d}=this.toAffine();if(t.isOdd)return!t.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){u(d);let{px:m,py:g,pz:I}=this,{px:v,py:D,pz:S}=d,_=t.eql(t.mul(m,S),t.mul(v,I)),L=t.eql(t.mul(g,S),t.mul(D,I));return _&&L}negate(){return new l(this.px,t.neg(this.py),this.pz)}double(){let{a:d,b:m}=e,g=t.mul(m,rh),{px:I,py:v,pz:D}=this,S=t.ZERO,_=t.ZERO,L=t.ZERO,w=t.mul(I,I),C=t.mul(v,v),O=t.mul(D,D),T=t.mul(I,v);return T=t.add(T,T),L=t.mul(I,D),L=t.add(L,L),S=t.mul(d,L),_=t.mul(g,O),_=t.add(S,_),S=t.sub(C,_),_=t.add(C,_),_=t.mul(S,_),S=t.mul(T,S),L=t.mul(g,L),O=t.mul(d,O),T=t.sub(w,O),T=t.mul(d,T),T=t.add(T,L),L=t.add(w,w),w=t.add(L,w),w=t.add(w,O),w=t.mul(w,T),_=t.add(_,w),O=t.mul(v,D),O=t.add(O,O),w=t.mul(O,T),S=t.sub(S,w),L=t.mul(O,C),L=t.add(L,L),L=t.add(L,L),new l(S,_,L)}add(d){u(d);let{px:m,py:g,pz:I}=this,{px:v,py:D,pz:S}=d,_=t.ZERO,L=t.ZERO,w=t.ZERO,C=e.a,O=t.mul(e.b,rh),T=t.mul(m,v),F=t.mul(g,D),$=t.mul(I,S),J=t.add(m,g),x=t.add(v,D);J=t.mul(J,x),x=t.add(T,F),J=t.sub(J,x),x=t.add(m,I);let k=t.add(v,S);return x=t.mul(x,k),k=t.add(T,$),x=t.sub(x,k),k=t.add(g,I),_=t.add(D,S),k=t.mul(k,_),_=t.add(F,$),k=t.sub(k,_),w=t.mul(C,x),_=t.mul(O,$),w=t.add(_,w),_=t.sub(F,w),w=t.add(F,w),L=t.mul(_,w),F=t.add(T,T),F=t.add(F,T),$=t.mul(C,$),x=t.mul(O,x),F=t.add(F,$),$=t.sub(T,$),$=t.mul(C,$),x=t.add(x,$),T=t.mul(F,x),L=t.add(L,T),T=t.mul(k,x),_=t.mul(J,_),_=t.sub(_,T),T=t.mul(J,F),w=t.mul(k,w),w=t.add(w,T),new l(_,L,w)}subtract(d){return this.add(d.negate())}is0(){return this.equals(l.ZERO)}wNAF(d){return E.wNAFCached(this,f,d,m=>{let g=t.invertBatch(m.map(I=>I.pz));return m.map((I,v)=>I.toAffine(g[v])).map(l.fromAffine)})}multiplyUnsafe(d){let m=l.ZERO;if(d===zt)return m;if(a(d),d===et)return this;let{endo:g}=e;if(!g)return E.unsafeLadder(this,d);let{k1neg:I,k1:v,k2neg:D,k2:S}=g.splitScalar(d),_=m,L=m,w=this;for(;v>zt||S>zt;)v&et&&(_=_.add(w)),S&et&&(L=L.add(w)),w=w.double(),v>>=et,S>>=et;return I&&(_=_.negate()),D&&(L=L.negate()),L=new l(t.mul(L.px,g.beta),L.py,L.pz),_.add(L)}multiply(d){a(d);let m=d,g,I,{endo:v}=e;if(v){let{k1neg:D,k1:S,k2neg:_,k2:L}=v.splitScalar(m),{p:w,f:C}=this.wNAF(S),{p:O,f:T}=this.wNAF(L);w=E.constTimeNegate(D,w),O=E.constTimeNegate(_,O),O=new l(t.mul(O.px,v.beta),O.py,O.pz),g=w.add(O),I=C.add(T)}else{let{p:D,f:S}=this.wNAF(m);g=D,I=S}return l.normalizeZ([g,I])[0]}multiplyAndAddUnsafe(d,m,g){let I=l.BASE,v=(S,_)=>_===zt||_===et||!S.equals(I)?S.multiplyUnsafe(_):S.multiply(_),D=v(this,m).add(v(d,g));return D.is0()?void 0:D}toAffine(d){let{px:m,py:g,pz:I}=this,v=this.is0();d==null&&(d=v?t.ONE:t.inv(I));let D=t.mul(m,d),S=t.mul(g,d),_=t.mul(I,d);if(v)return{x:t.ZERO,y:t.ZERO};if(!t.eql(_,t.ONE))throw new Error("invZ was invalid");return{x:D,y:S}}isTorsionFree(){let{h:d,isTorsionFree:m}=e;if(d===et)return!0;if(m)return m(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:m}=e;return d===et?this:m?m(l,this):this.multiplyUnsafe(e.h)}toRawBytes(d=!0){return this.assertValidity(),n(l,this,d)}toHex(d=!0){return Lt(this.toRawBytes(d))}}l.BASE=new l(e.Gx,e.Gy,t.ONE),l.ZERO=new l(t.ZERO,t.ONE,t.ZERO);let p=e.nBitLength,E=ls(l,e.endo?Math.ceil(p/2):p);return{CURVE:e,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:s,isWithinCurveOrder:i}}function Ug(r){let e=ro(r);return wt(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function nh(r){let e=Ug(r),{Fp:t,n}=e,o=t.BYTES+1,s=2*t.BYTES+1;function i(x){return zt<x&&x<t.ORDER}function a(x){return oe(x,n)}function c(x){return cs(x,n)}let{ProjectivePoint:f,normPrivateKeyToScalar:u,weierstrassEquation:l,isWithinCurveOrder:p}=Dg({...e,toBytes(x,k,H){let B=k.toAffine(),b=t.toBytes(B.x),P=Ut;return H?P(Uint8Array.from([k.hasEvenY()?2:3]),b):P(Uint8Array.from([4]),b,t.toBytes(B.y))},fromBytes(x){let k=x.length,H=x[0],B=x.subarray(1);if(k===o&&(H===2||H===3)){let b=Dt(B);if(!i(b))throw new Error("Point is not on curve");let P=l(b),M;try{M=t.sqrt(P)}catch(j){let ee=j instanceof Error?": "+j.message:"";throw new Error("Point is not on curve"+ee)}let K=(M&et)===et;return(H&1)===1!==K&&(M=t.neg(M)),{x:b,y:M}}else if(k===s&&H===4){let b=t.fromBytes(B.subarray(0,t.BYTES)),P=t.fromBytes(B.subarray(t.BYTES,2*t.BYTES));return{x:b,y:P}}else throw new Error(`Point of length ${k} was invalid. Expected ${o} compressed bytes or ${s} uncompressed bytes`)}}),E=x=>Lt(dr(x,e.nByteLength));function y(x){let k=n>>et;return x>k}function d(x){return y(x)?a(-x):x}let m=(x,k,H)=>Dt(x.slice(k,H));class g{constructor(k,H,B){this.r=k,this.s=H,this.recovery=B,this.assertValidity()}static fromCompact(k){let H=e.nByteLength;return k=fe("compactSignature",k,H*2),new g(m(k,0,H),m(k,H,2*H))}static fromDER(k){let{r:H,s:B}=Vr.toSig(fe("DER",k));return new g(H,B)}assertValidity(){if(!p(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!p(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(k){return new g(this.r,this.s,k)}recoverPublicKey(k){let{r:H,s:B,recovery:b}=this,P=L(fe("msgHash",k));if(b==null||![0,1,2,3].includes(b))throw new Error("recovery id invalid");let M=b===2||b===3?H+e.n:H;if(M>=t.ORDER)throw new Error("recovery id 2 or 3 invalid");let K=b&1?"03":"02",G=f.fromHex(K+E(M)),j=c(M),ee=a(-P*j),Z=a(B*j),X=f.BASE.multiplyAndAddUnsafe(G,ee,Z);if(!X)throw new Error("point at infinify");return X.assertValidity(),X}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new g(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Nr(this.toDERHex())}toDERHex(){return Vr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Nr(this.toCompactHex())}toCompactHex(){return E(this.r)+E(this.s)}}let I={isValidPrivateKey(x){try{return u(x),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let x=ic(e.n);return Zl(e.randomBytes(x),e.n)},precompute(x=8,k=f.BASE){return k._setWindowSize(x),k.multiply(BigInt(3)),k}};function v(x,k=!0){return f.fromPrivateKey(x).toRawBytes(k)}function D(x){let k=fr(x),H=typeof x=="string",B=(k||H)&&x.length;return k?B===o||B===s:H?B===2*o||B===2*s:x instanceof f}function S(x,k,H=!0){if(D(x))throw new Error("first arg must be private key");if(!D(k))throw new Error("second arg must be public key");return f.fromHex(k).multiply(u(x)).toRawBytes(H)}let _=e.bits2int||function(x){let k=Dt(x),H=x.length*8-e.nBitLength;return H>0?k>>BigInt(H):k},L=e.bits2int_modN||function(x){return a(_(x))},w=to(e.nBitLength);function C(x){if(typeof x!="bigint")throw new Error("bigint expected");if(!(zt<=x&&x<w))throw new Error(`bigint expected < 2^${e.nBitLength}`);return dr(x,e.nByteLength)}function O(x,k,H=T){if(["recovered","canonical"].some(ue=>ue in H))throw new Error("sign() legacy options not supported");let{hash:B,randomBytes:b}=e,{lowS:P,prehash:M,extraEntropy:K}=H;P==null&&(P=!0),x=fe("msgHash",x),M&&(x=fe("prehashed msgHash",B(x)));let G=L(x),j=u(k),ee=[C(j),C(G)];if(K!=null&&K!==!1){let ue=K===!0?b(t.BYTES):K;ee.push(fe("extraEntropy",ue))}let Z=Ut(...ee),X=G;function pe(ue){let ve=_(ue);if(!p(ve))return;let Ae=c(ve),ye=f.BASE.multiply(ve).toAffine(),Re=a(ye.x);if(Re===zt)return;let It=a(Ae*a(X+Re*j));if(It===zt)return;let kr=(ye.x===Re?0:2)|Number(ye.y&et),Kn=It;return P&&y(It)&&(Kn=d(It),kr^=1),new g(Re,Kn,kr)}return{seed:Z,k2sig:pe}}let T={lowS:e.lowS,prehash:!1},F={lowS:e.lowS,prehash:!1};function $(x,k,H=T){let{seed:B,k2sig:b}=O(x,k,H),P=e;return rc(P.hash.outputLen,P.nByteLength,P.hmac)(B,b)}f.BASE._setWindowSize(8);function J(x,k,H,B=F){let b=x;if(k=fe("msgHash",k),H=fe("publicKey",H),"strict"in B)throw new Error("options.strict was renamed to lowS");let{lowS:P,prehash:M}=B,K,G;try{if(typeof b=="string"||fr(b))try{K=g.fromDER(b)}catch(ye){if(!(ye instanceof Vr.Err))throw ye;K=g.fromCompact(b)}else if(typeof b=="object"&&typeof b.r=="bigint"&&typeof b.s=="bigint"){let{r:ye,s:Re}=b;K=new g(ye,Re)}else throw new Error("PARSE");G=f.fromHex(H)}catch(ye){if(ye.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(P&&K.hasHighS())return!1;M&&(k=e.hash(k));let{r:j,s:ee}=K,Z=L(k),X=c(ee),pe=a(Z*X),ue=a(j*X),ve=f.BASE.multiplyAndAddUnsafe(G,pe,ue)?.toAffine();return ve?a(ve.x)===j:!1}return{CURVE:e,getPublicKey:v,getSharedSecret:S,sign:$,verify:J,ProjectivePoint:f,Signature:g,utils:I}}function Pg(r){return{hash:r,hmac:(e,...t)=>oo(r,e,ns(...t)),randomBytes:wn}}function oh(r,e){let t=n=>nh({...r,...Pg(n)});return Object.freeze({...t(e),create:t})}var ah=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),sh=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Og=BigInt(1),kc=BigInt(2),ih=(r,e)=>(r+e/kc)/e;function Vg(r){let e=ah,t=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%e,u=f*f*r%e,l=ce(u,t,e)*u%e,p=ce(l,t,e)*u%e,E=ce(p,kc,e)*f%e,y=ce(E,o,e)*E%e,d=ce(y,s,e)*y%e,m=ce(d,a,e)*d%e,g=ce(m,c,e)*m%e,I=ce(g,a,e)*d%e,v=ce(I,t,e)*u%e,D=ce(v,i,e)*y%e,S=ce(D,n,e)*f%e,_=ce(S,kc,e);if(!Sc.eql(Sc.sqr(_),r))throw new Error("Cannot find square root");return _}var Sc=us(ah,void 0,void 0,{sqrt:Vg}),ht=oh({a:BigInt(0),b:BigInt(7),Fp:Sc,n:sh,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let e=sh,t=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Og*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=t,i=BigInt("0x100000000000000000000000000000000"),a=ih(s*r,e),c=ih(-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}}}},th),gA=BigInt(0);var wA=ht.ProjectivePoint;function ch(){return ht.utils.randomPrivateKey()}function uh(r,e){let t=we.digest(e instanceof Uint8Array?e:e.subarray());if(Xe(t))return t.then(({digest:n})=>ht.sign(n,r).toDERRawBytes()).catch(n=>{throw new N(String(n),"ERR_INVALID_INPUT")});try{return ht.sign(t.digest,r).toDERRawBytes()}catch(n){throw new N(String(n),"ERR_INVALID_INPUT")}}function lh(r,e,t){let n=we.digest(t instanceof Uint8Array?t:t.subarray());if(Xe(n))return n.then(({digest:o})=>ht.verify(e,o,r)).catch(o=>{throw new N(String(o),"ERR_INVALID_INPUT")});try{return ht.verify(e,n.digest,r)}catch(o){throw new N(String(o),"ERR_INVALID_INPUT")}}function fh(r){return ht.ProjectivePoint.fromHex(r).toRawBytes(!0)}function hh(r){try{ht.getPublicKey(r,!0)}catch(e){throw new N(String(e),"ERR_INVALID_PRIVATE_KEY")}}function Ic(r){try{ht.ProjectivePoint.fromHex(r)}catch(e){throw new N(String(e),"ERR_INVALID_PUBLIC_KEY")}}function dh(r){try{return ht.getPublicKey(r,!0)}catch(e){throw new N(String(e),"ERR_INVALID_PRIVATE_KEY")}}var go=class{_key;constructor(e){Ic(e),this._key=e}verify(e,t){return lh(this._key,t,e)}marshal(){return fh(this._key)}get bytes(){return bt.encode({Type:de.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}async hash(){let e=we.digest(this.bytes),t;return Xe(e)?{bytes:t}=await e:t=e.bytes,t}},wo=class{_key;_publicKey;constructor(e,t){this._key=e,this._publicKey=t??dh(e),hh(this._key),Ic(this._publicKey)}sign(e){return uh(this._key,e)}get public(){return new go(this._publicKey)}marshal(){return this._key}get bytes(){return Vt.encode({Type:de.Secp256k1,Data:this.marshal()}).subarray()}equals(e){return se(this.bytes,e.bytes)}hash(){let e=we.digest(this.bytes);return Xe(e)?e.then(({bytes:t})=>t):e.bytes}async id(){let e=await this.public.hash();return z(e,"base58btc")}async export(e,t="libp2p-key"){if(t==="libp2p-key")return Bn(this.bytes,e);throw new N(`export format '${t}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Mg(r){return new wo(r)}function Hg(r){return new go(r)}async function $g(){let r=ch();return new wo(r)}var si={rsa:Ac,ed25519:dc,secp256k1:Rc};function Kg(r){let e=Object.keys(si).join(" / ");return new N(`invalid or unsupported key type ${r}. Must be ${e}`,"ERR_UNSUPPORTED_KEY_TYPE")}function _c(r){let e=bt.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case de.RSA:return si.rsa.unmarshalRsaPublicKey(t);case de.Ed25519:return si.ed25519.unmarshalEd25519PublicKey(t);case de.Secp256k1:return si.secp256k1.unmarshalSecp256k1PublicKey(t);default:throw Kg(e.Type??"unknown")}}var Aw=st(on(),1);var Gt="/",ph=new TextEncoder().encode(Gt),ii=ph[0],Se=class r{_buf;constructor(e,t){if(typeof e=="string")this._buf=W(e);else if(e instanceof Uint8Array)this._buf=e;else throw new Error("Invalid key, should be String of Uint8Array");if(t==null&&(t=!0),t&&this.clean(),this._buf.byteLength===0||this._buf[0]!==ii)throw new Error("Invalid key")}toString(e="utf8"){return z(this._buf,e)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(e){return new r(e.join(Gt))}static random(){return new r(Math.random().toString().substring(2))}static asKey(e){return e instanceof Uint8Array||typeof e=="string"?new r(e):typeof e.uint8Array=="function"?new r(e.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=ph),this._buf[0]!==ii){let e=new Uint8Array(this._buf.byteLength+1);e.fill(ii,0,1),e.set(this._buf,1),this._buf=e}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===ii;)this._buf=this._buf.subarray(0,-1)}less(e){let t=this.list(),n=e.list();for(let o=0;o<t.length;o++){if(n.length<o+1)return!1;let s=t[o],i=n[o];if(s<i)return!0;if(s>i)return!1}return t.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let e=this.namespaces();return e[e.length-1]}list(){return this.toString().split(Gt).slice(1)}type(){return qg(this.baseNamespace())}name(){return zg(this.baseNamespace())}instance(e){return new r(this.toString()+":"+e)}path(){let e=this.parent().toString();return e.endsWith(Gt)||(e+=Gt),e+=this.type(),new r(e)}parent(){let e=this.list();return e.length===1?new r(Gt):new r(e.slice(0,-1).join(Gt))}child(e){return this.toString()===Gt?e:e.toString()===Gt?this:new r(this.toString()+e.toString(),!1)}isAncestorOf(e){return e.toString()===this.toString()?!1:e.toString().startsWith(this.toString())}isDecendantOf(e){return e.toString()===this.toString()?!1:this.toString().startsWith(e.toString())}isTopLevel(){return this.list().length===1}concat(...e){return r.withNamespaces([...this.namespaces(),...Gg(e.map(t=>t.namespaces()))])}};function qg(r){let e=r.split(":");return e.length<2?"":e.slice(0,-1).join(":")}function zg(r){let e=r.split(":");return e[e.length-1]}function Gg(r){return[].concat(...r)}var Bw=st(Cc(),1);var mh="ERR_IPNS_EXPIRED_RECORD",ai="ERR_UNRECOGNIZED_VALIDITY";var jt="ERR_SIGNATURE_VERIFICATION";var Nc="ERR_UNDEFINED_PARAMETER",yh="ERR_INVALID_RECORD_DATA",gh="ERR_INVALID_VALUE",wh="ERR_INVALID_EMBEDDED_KEY";var bh="ERR_RECORD_TOO_LARGE";var dt;(function(r){let e;(function(o){o.EOL="EOL"})(e=r.ValidityType||(r.ValidityType={}));let t;(function(o){o[o.EOL=0]="EOL"})(t||(t={})),function(o){o.codec=()=>Jn(t)}(e=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=nn((o,s,i={})=>{i.lengthDelimited!==!1&&s.fork(),o.value!=null&&(s.uint32(10),s.bytes(o.value)),o.signatureV1!=null&&(s.uint32(18),s.bytes(o.signatureV1)),o.validityType!=null&&(s.uint32(24),r.ValidityType.codec().encode(o.validityType,s)),o.validity!=null&&(s.uint32(34),s.bytes(o.validity)),o.sequence!=null&&(s.uint32(40),s.uint64(o.sequence)),o.ttl!=null&&(s.uint32(48),s.uint64(o.ttl)),o.pubKey!=null&&(s.uint32(58),s.bytes(o.pubKey)),o.signatureV2!=null&&(s.uint32(66),s.bytes(o.signatureV2)),o.data!=null&&(s.uint32(74),s.bytes(o.data)),i.lengthDelimited!==!1&&s.ldelim()},(o,s)=>{let i={},a=s==null?o.len:o.pos+s;for(;o.pos<a;){let c=o.uint32();switch(c>>>3){case 1:i.value=o.bytes();break;case 2:i.signatureV1=o.bytes();break;case 3:i.validityType=r.ValidityType.codec().decode(o);break;case 4:i.validity=o.bytes();break;case 5:i.sequence=o.uint64();break;case 6:i.ttl=o.uint64();break;case 7:i.pubKey=o.bytes();break;case 8:i.signatureV2=o.bytes();break;case 9:i.data=o.bytes();break;default:o.skipType(c&7);break}}return i})),n),r.encode=o=>tn(o,r.codec()),r.decode=o=>en(o,r.codec())})(dt||(dt={}));var jg=["string","number","bigint","symbol"],Wg=["Function","Generator","AsyncGenerator","GeneratorFunction","AsyncGeneratorFunction","AsyncFunction","Observable","Array","Buffer","Object","RegExp","Date","Error","Map","Set","WeakMap","WeakSet","ArrayBuffer","SharedArrayBuffer","DataView","Promise","URL","HTMLElement","Int8Array","Uint8Array","Uint8ClampedArray","Int16Array","Uint16Array","Int32Array","Uint32Array","Float32Array","Float64Array","BigInt64Array","BigUint64Array"];function Eh(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let e=typeof r;if(jg.includes(e))return e;if(e==="function")return"Function";if(Array.isArray(r))return"Array";if(Yg(r))return"Buffer";let t=Zg(r);return t||"Object"}function Yg(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function Zg(r){let e=Object.prototype.toString.call(r).slice(8,-1);if(Wg.includes(e))return e}var h=class{constructor(e,t,n){this.major=e,this.majorEncoded=e<<5,this.name=t,this.terminal=n}toString(){return`Type[${this.major}].${this.name}`}compare(e){return this.major<e.major?-1:this.major>e.major?1:0}};h.uint=new h(0,"uint",!0);h.negint=new h(1,"negint",!0);h.bytes=new h(2,"bytes",!0);h.string=new h(3,"string",!0);h.array=new h(4,"array",!1);h.map=new h(5,"map",!1);h.tag=new h(6,"tag",!1);h.float=new h(7,"float",!0);h.false=new h(7,"false",!0);h.true=new h(7,"true",!0);h.null=new h(7,"null",!0);h.undefined=new h(7,"undefined",!0);h.break=new h(7,"break",!0);var A=class{constructor(e,t,n){this.type=e,this.value=t,this.encodedLength=n,this.encodedBytes=void 0,this.byteValue=void 0}toString(){return`Token[${this.type}].${this.value}`}};var Cn=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",Jg=new TextDecoder,Xg=new TextEncoder;function ci(r){return Cn&&globalThis.Buffer.isBuffer(r)}function bo(r){return r instanceof Uint8Array?ci(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var kh=Cn?(r,e,t)=>t-e>64?globalThis.Buffer.from(r.subarray(e,t)).toString("utf8"):Ah(r,e,t):(r,e,t)=>t-e>64?Jg.decode(r.subarray(e,t)):Ah(r,e,t),ui=Cn?r=>r.length>64?globalThis.Buffer.from(r):vh(r):r=>r.length>64?Xg.encode(r):vh(r),At=r=>Uint8Array.from(r),Nn=Cn?(r,e,t)=>ci(r)?new Uint8Array(r.subarray(e,t)):r.slice(e,t):(r,e,t)=>r.slice(e,t),Sh=Cn?(r,e)=>(r=r.map(t=>t instanceof Uint8Array?t:globalThis.Buffer.from(t)),bo(globalThis.Buffer.concat(r,e))):(r,e)=>{let t=new Uint8Array(e),n=0;for(let o of r)n+o.length>t.length&&(o=o.subarray(0,t.length-n)),t.set(o,n),n+=o.length;return t},Ih=Cn?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function Rh(r,e){if(ci(r)&&ci(e))return r.compare(e);for(let t=0;t<r.length;t++)if(r[t]!==e[t])return r[t]<e[t]?-1:1;return 0}function vh(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 Ah(r,e,t){let n=[];for(;e<t;){let o=r[e],s=null,i=o>239?4:o>223?3:o>191?2:1;if(e+i<=t){let a,c,f,u;switch(i){case 1:o<128&&(s=o);break;case 2:a=r[e+1],(a&192)===128&&(u=(o&31)<<6|a&63,u>127&&(s=u));break;case 3:a=r[e+1],c=r[e+2],(a&192)===128&&(c&192)===128&&(u=(o&15)<<12|(a&63)<<6|c&63,u>2047&&(u<55296||u>57343)&&(s=u));break;case 4:a=r[e+1],c=r[e+2],f=r[e+3],(a&192)===128&&(c&192)===128&&(f&192)===128&&(u=(o&15)<<18|(a&63)<<12|(c&63)<<6|f&63,u>65535&&u<1114112&&(s=u))}}s===null?(s=65533,i=1):s>65535&&(s-=65536,n.push(s>>>10&1023|55296),s=56320|s&1023),n.push(s),e+=i}return Lc(n)}var Bh=4096;function Lc(r){let e=r.length;if(e<=Bh)return String.fromCharCode.apply(String,r);let t="",n=0;for(;n<e;)t+=String.fromCharCode.apply(String,r.slice(n,n+=Bh));return t}var Qg=256,xo=class{constructor(e=Qg){this.chunkSize=e,this.cursor=0,this.maxCursor=-1,this.chunks=[],this._initReuseChunk=null}reset(){this.cursor=0,this.maxCursor=-1,this.chunks.length&&(this.chunks=[]),this._initReuseChunk!==null&&(this.chunks.push(this._initReuseChunk),this.maxCursor=this._initReuseChunk.length-1)}push(e){let t=this.chunks[this.chunks.length-1];if(this.cursor+e.length<=this.maxCursor+1){let o=t.length-(this.maxCursor-this.cursor)-1;t.set(e,o)}else{if(t){let o=t.length-(this.maxCursor-this.cursor)-1;o<t.length&&(this.chunks[this.chunks.length-1]=t.subarray(0,o),this.maxCursor=this.cursor-1)}e.length<64&&e.length<this.chunkSize?(t=Ih(this.chunkSize),this.chunks.push(t),this.maxCursor+=t.length,this._initReuseChunk===null&&(this._initReuseChunk=t),t.set(e,0)):(this.chunks.push(e),this.maxCursor+=e.length)}this.cursor+=e.length}toBytes(e=!1){let t;if(this.chunks.length===1){let n=this.chunks[0];e&&this.cursor>n.length/2?(t=this.cursor===n.length?n:n.subarray(0,this.cursor),this._initReuseChunk=null,this.chunks=[]):t=Nn(n,0,this.cursor)}else t=Sh(this.chunks,this.cursor);return e&&this.reset(),t}};var V="CBOR decode error:",Ln="CBOR encode error:",Eo=[];Eo[23]=1;Eo[24]=2;Eo[25]=3;Eo[26]=5;Eo[27]=9;function Wt(r,e,t){if(r.length-e<t)throw new Error(`${V} not enough data for type`)}var Ee=[24,256,65536,4294967296,BigInt("18446744073709551616")];function Ge(r,e,t){Wt(r,e,1);let n=r[e];if(t.strict===!0&&n<Ee[0])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function je(r,e,t){Wt(r,e,2);let n=r[e]<<8|r[e+1];if(t.strict===!0&&n<Ee[1])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function We(r,e,t){Wt(r,e,4);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3];if(t.strict===!0&&n<Ee[2])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function Ye(r,e,t){Wt(r,e,8);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3],o=r[e+4]*16777216+(r[e+5]<<16)+(r[e+6]<<8)+r[e+7],s=(BigInt(n)<<BigInt(32))+BigInt(o);if(t.strict===!0&&s<Ee[3])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);if(s<=Number.MAX_SAFE_INTEGER)return Number(s);if(t.allowBigInt===!0)return s;throw new Error(`${V} integers outside of the safe integer range are not supported`)}function _h(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 Ch(r,e,t,n){return new A(h.uint,We(r,e+1,n),5)}function Nh(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 Lh(r,e,t,n){return new A(h.negint,-1-Ge(r,e+1,n),2)}function Dh(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 Dc=BigInt(-1),Ph=BigInt(1);function Oh(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o!="bigint"){let s=-1-o;if(s>=Number.MIN_SAFE_INTEGER)return new A(h.negint,s,9)}if(n.allowBigInt!==!0)throw new Error(`${V} integers outside of the safe integer range are not supported`);return new A(h.negint,Dc-BigInt(o),9)}function li(r,e){let t=e.value,n=typeof t=="bigint"?t*Dc-Ph:t*-1-1;Ie(r,e.type.majorEncoded,n)}li.encodedSize=function(e){let t=e.value,n=typeof t=="bigint"?t*Dc-Ph:t*-1-1;return n<Ee[0]?1:n<Ee[1]?2:n<Ee[2]?3:n<Ee[3]?5:9};li.compareTokens=function(e,t){return e.value<t.value?1:e.value>t.value?-1:0};function vo(r,e,t,n){Wt(r,e,t+n);let o=Nn(r,e+t,e+t+n);return new A(h.bytes,o,t+n)}function Vh(r,e,t,n){return vo(r,e,1,t)}function Fh(r,e,t,n){return vo(r,e,2,Ge(r,e+1,n))}function Mh(r,e,t,n){return vo(r,e,3,je(r,e+1,n))}function Hh(r,e,t,n){return vo(r,e,5,We(r,e+1,n))}function $h(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer bytes lengths not supported`);return vo(r,e,9,o)}function fi(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===h.string?ui(r.value):r.value),r.encodedBytes}function Dn(r,e){let t=fi(e);Ie(r,e.type.majorEncoded,t.length),r.push(t)}Dn.encodedSize=function(e){let t=fi(e);return Ie.encodedSize(t.length)+t.length};Dn.compareTokens=function(e,t){return tw(fi(e),fi(t))};function tw(r,e){return r.length<e.length?-1:r.length>e.length?1:Rh(r,e)}function Ao(r,e,t,n,o){let s=t+n;Wt(r,e,s);let i=new A(h.string,kh(r,e+t,e+s),s);return o.retainStringBytes===!0&&(i.byteValue=Nn(r,e+t,e+s)),i}function Kh(r,e,t,n){return Ao(r,e,1,t,n)}function qh(r,e,t,n){return Ao(r,e,2,Ge(r,e+1,n),n)}function zh(r,e,t,n){return Ao(r,e,3,je(r,e+1,n),n)}function Gh(r,e,t,n){return Ao(r,e,5,We(r,e+1,n),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 string lengths not supported`);return Ao(r,e,9,o,n)}var Wh=Dn;function Un(r,e,t,n){return new A(h.array,n,t)}function Yh(r,e,t,n){return Un(r,e,1,t)}function Zh(r,e,t,n){return Un(r,e,2,Ge(r,e+1,n))}function Jh(r,e,t,n){return Un(r,e,3,je(r,e+1,n))}function Xh(r,e,t,n){return Un(r,e,5,We(r,e+1,n))}function Qh(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 ed(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Un(r,e,1,1/0)}function hi(r,e){Ie(r,h.array.majorEncoded,e.value)}hi.compareTokens=tt.compareTokens;hi.encodedSize=function(e){return Ie.encodedSize(e.value)};function Pn(r,e,t,n){return new A(h.map,n,t)}function td(r,e,t,n){return Pn(r,e,1,t)}function rd(r,e,t,n){return Pn(r,e,2,Ge(r,e+1,n))}function nd(r,e,t,n){return Pn(r,e,3,je(r,e+1,n))}function od(r,e,t,n){return Pn(r,e,5,We(r,e+1,n))}function sd(r,e,t,n){let o=Ye(r,e+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer map lengths not supported`);return Pn(r,e,9,o)}function id(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Pn(r,e,1,1/0)}function di(r,e){Ie(r,h.map.majorEncoded,e.value)}di.compareTokens=tt.compareTokens;di.encodedSize=function(e){return Ie.encodedSize(e.value)};function ad(r,e,t,n){return new A(h.tag,t,1)}function cd(r,e,t,n){return new A(h.tag,Ge(r,e+1,n),2)}function ud(r,e,t,n){return new A(h.tag,je(r,e+1,n),3)}function ld(r,e,t,n){return new A(h.tag,We(r,e+1,n),5)}function fd(r,e,t,n){return new A(h.tag,Ye(r,e+1,n),9)}function pi(r,e){Ie(r,h.tag.majorEncoded,e.value)}pi.compareTokens=tt.compareTokens;pi.encodedSize=function(e){return Ie.encodedSize(e.value)};var aw=20,cw=21,uw=22,lw=23;function hd(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 dd(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 pd(r,e,t,n){return Uc(Pc(r,e+1),3,n)}function md(r,e,t,n){return Uc(Oc(r,e+1),5,n)}function yd(r,e,t,n){return Uc(xd(r,e+1),9,n)}function mi(r,e,t){let n=e.value;if(n===!1)r.push([h.float.majorEncoded|aw]);else if(n===!0)r.push([h.float.majorEncoded|cw]);else if(n===null)r.push([h.float.majorEncoded|uw]);else if(n===void 0)r.push([h.float.majorEncoded|lw]);else{let o,s=!1;(!t||t.float64!==!0)&&(wd(n),o=Pc(pt,1),n===o||Number.isNaN(n)?(pt[0]=249,r.push(pt.slice(0,3)),s=!0):(bd(n),o=Oc(pt,1),n===o&&(pt[0]=250,r.push(pt.slice(0,5)),s=!0))),s||(fw(n),o=xd(pt,1),pt[0]=251,r.push(pt.slice(0,9)))}}mi.encodedSize=function(e,t){let n=e.value;if(n===!1||n===!0||n===null||n===void 0)return 1;if(!t||t.float64!==!0){wd(n);let o=Pc(pt,1);if(n===o||Number.isNaN(n))return 3;if(bd(n),o=Oc(pt,1),n===o)return 5}return 9};var gd=new ArrayBuffer(9),rt=new DataView(gd,1),pt=new Uint8Array(gd,0);function wd(r){if(r===1/0)rt.setUint16(0,31744,!1);else if(r===-1/0)rt.setUint16(0,64512,!1);else if(Number.isNaN(r))rt.setUint16(0,32256,!1);else{rt.setFloat32(0,r);let e=rt.getUint32(0),t=(e&2139095040)>>23,n=e&8388607;if(t===255)rt.setUint16(0,31744,!1);else if(t===0)rt.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let o=t-127;o<-24?rt.setUint16(0,0):o<-14?rt.setUint16(0,(e&2147483648)>>16|1<<24+o,!1):rt.setUint16(0,(e&2147483648)>>16|o+15<<10|n>>13,!1)}}}function Pc(r,e){if(r.length-e<2)throw new Error(`${V} not enough data for float16`);let t=(r[e]<<8)+r[e+1];if(t===31744)return 1/0;if(t===64512)return-1/0;if(t===32256)return NaN;let n=t>>10&31,o=t&1023,s;return n===0?s=o*2**-24:n!==31?s=(o+1024)*2**(n-25):s=o===0?1/0:NaN,t&32768?-s:s}function bd(r){rt.setFloat32(0,r,!1)}function Oc(r,e){if(r.length-e<4)throw new Error(`${V} not enough data for float32`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,4).getFloat32(0,!1)}function fw(r){rt.setFloat64(0,r,!1)}function xd(r,e){if(r.length-e<8)throw new Error(`${V} not enough data for float64`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,8).getFloat64(0,!1)}mi.compareTokens=tt.compareTokens;function Q(r,e,t){throw new Error(`${V} encountered invalid minor (${t}) for major ${r[e]>>>5}`)}function yi(r){return()=>{throw new Error(`${V} ${r}`)}}var R=[];for(let r=0;r<=23;r++)R[r]=Q;R[24]=_h;R[25]=Th;R[26]=Ch;R[27]=Nh;R[28]=Q;R[29]=Q;R[30]=Q;R[31]=Q;for(let r=32;r<=55;r++)R[r]=Q;R[56]=Lh;R[57]=Dh;R[58]=Uh;R[59]=Oh;R[60]=Q;R[61]=Q;R[62]=Q;R[63]=Q;for(let r=64;r<=87;r++)R[r]=Vh;R[88]=Fh;R[89]=Mh;R[90]=Hh;R[91]=$h;R[92]=Q;R[93]=Q;R[94]=Q;R[95]=yi("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)R[r]=Kh;R[120]=qh;R[121]=zh;R[122]=Gh;R[123]=jh;R[124]=Q;R[125]=Q;R[126]=Q;R[127]=yi("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)R[r]=Yh;R[152]=Zh;R[153]=Jh;R[154]=Xh;R[155]=Qh;R[156]=Q;R[157]=Q;R[158]=Q;R[159]=ed;for(let r=160;r<=183;r++)R[r]=td;R[184]=rd;R[185]=nd;R[186]=od;R[187]=sd;R[188]=Q;R[189]=Q;R[190]=Q;R[191]=id;for(let r=192;r<=215;r++)R[r]=ad;R[216]=cd;R[217]=ud;R[218]=ld;R[219]=fd;R[220]=Q;R[221]=Q;R[222]=Q;R[223]=Q;for(let r=224;r<=243;r++)R[r]=yi("simple values are not supported");R[244]=Q;R[245]=Q;R[246]=Q;R[247]=hd;R[248]=yi("simple values are not supported");R[249]=pd;R[250]=md;R[251]=yd;R[252]=Q;R[253]=Q;R[254]=Q;R[255]=dd;var mt=[];for(let r=0;r<24;r++)mt[r]=new A(h.uint,r,1);for(let r=-1;r>=-24;r--)mt[31-r]=new A(h.negint,r,1);mt[64]=new A(h.bytes,new Uint8Array(0),1);mt[96]=new A(h.string,"",1);mt[128]=new A(h.array,0,1);mt[160]=new A(h.map,0,1);mt[244]=new A(h.false,!1,1);mt[245]=new A(h.true,!0,1);mt[246]=new A(h.null,null,1);function Ed(r){switch(r.type){case h.false:return At([244]);case h.true:return At([245]);case h.null:return At([246]);case h.bytes:return r.value.length?void 0:At([64]);case h.string:return r.value===""?At([96]):void 0;case h.array:return r.value===0?At([128]):void 0;case h.map:return r.value===0?At([160]):void 0;case h.uint:return r.value<24?At([Number(r.value)]):void 0;case h.negint:if(r.value>=-24)return At([31-Number(r.value)])}}var dw={float64:!1,mapSorter:yw,quickEncodeToken:Ed};function pw(){let r=[];return r[h.uint.major]=tt,r[h.negint.major]=li,r[h.bytes.major]=Dn,r[h.string.major]=Wh,r[h.array.major]=hi,r[h.map.major]=di,r[h.tag.major]=pi,r[h.float.major]=mi,r}var vd=pw(),Vc=new xo,wi=class r{constructor(e,t){this.obj=e,this.parent=t}includes(e){let t=this;do if(t.obj===e)return!0;while(t=t.parent);return!1}static createCheck(e,t){if(e&&e.includes(t))throw new Error(`${Ln} object contains circular references`);return new r(t,e)}},xr={null:new A(h.null,null),undefined:new A(h.undefined,void 0),true:new A(h.true,!0),false:new A(h.false,!1),emptyArray:new A(h.array,0),emptyMap:new A(h.map,0)},Er={number(r,e,t,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new A(h.float,r):r>=0?new A(h.uint,r):new A(h.negint,r)},bigint(r,e,t,n){return r>=BigInt(0)?new A(h.uint,r):new A(h.negint,r)},Uint8Array(r,e,t,n){return new A(h.bytes,r)},string(r,e,t,n){return new A(h.string,r)},boolean(r,e,t,n){return r?xr.true:xr.false},null(r,e,t,n){return xr.null},undefined(r,e,t,n){return xr.undefined},ArrayBuffer(r,e,t,n){return new A(h.bytes,new Uint8Array(r))},DataView(r,e,t,n){return new A(h.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,e,t,n){if(!r.length)return t.addBreakTokens===!0?[xr.emptyArray,new A(h.break)]:xr.emptyArray;n=wi.createCheck(n,r);let o=[],s=0;for(let i of r)o[s++]=gi(i,t,n);return t.addBreakTokens?[new A(h.array,r.length),o,new A(h.break)]:[new A(h.array,r.length),o]},Object(r,e,t,n){let o=e!=="Object",s=o?r.keys():Object.keys(r),i=o?r.size:s.length;if(!i)return t.addBreakTokens===!0?[xr.emptyMap,new A(h.break)]:xr.emptyMap;n=wi.createCheck(n,r);let a=[],c=0;for(let f of s)a[c++]=[gi(f,t,n),gi(o?r.get(f):r[f],t,n)];return mw(a,t),t.addBreakTokens?[new A(h.map,i),a,new A(h.break)]:[new A(h.map,i),a]}};Er.Map=Er.Object;Er.Buffer=Er.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))Er[`${r}Array`]=Er.DataView;function gi(r,e={},t){let n=Eh(r),o=e&&e.typeEncoders&&e.typeEncoders[n]||Er[n];if(typeof o=="function"){let i=o(r,n,e,t);if(i!=null)return i}let s=Er[n];if(!s)throw new Error(`${Ln} unsupported type: ${n}`);return s(r,n,e,t)}function mw(r,e){e.mapSorter&&r.sort(e.mapSorter)}function yw(r,e){let t=Array.isArray(r[0])?r[0][0]:r[0],n=Array.isArray(e[0])?e[0][0]:e[0];if(t.type!==n.type)return t.type.compare(n.type);let o=t.type.major,s=vd[o].compareTokens(t,n);return s===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),s}function Ad(r,e,t,n){if(Array.isArray(e))for(let o of e)Ad(r,o,t,n);else t[e.type.major](r,e,n)}function Bd(r,e,t){let n=gi(r,t);if(!Array.isArray(n)&&t.quickEncodeToken){let o=t.quickEncodeToken(n);if(o)return o;let s=e[n.type.major];if(s.encodedSize){let i=s.encodedSize(n,t),a=new xo(i);if(s(a,n,t),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return bo(a.chunks[0])}}return Vc.reset(),Ad(Vc,n,e,t),Vc.toBytes(!0)}function On(r,e){return e=Object.assign({},dw,e),Bd(r,vd,e)}var gw={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},bi=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t}pos(){return this._pos}done(){return this._pos>=this.data.length}next(){let e=this.data[this._pos],t=mt[e];if(t===void 0){let n=R[e];if(!n)throw new Error(`${V} no decoder for major type ${e>>>5} (byte 0x${e.toString(16).padStart(2,"0")})`);let o=e&31;t=n(this.data,this._pos,o,this.options)}return this._pos+=t.encodedLength,t}},Bo=Symbol.for("DONE"),xi=Symbol.for("BREAK");function ww(r,e,t){let n=[];for(let o=0;o<r.value;o++){let s=Vn(e,t);if(s===xi){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed array`)}if(s===Bo)throw new Error(`${V} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=s}return n}function bw(r,e,t){let n=t.useMaps===!0,o=n?void 0:{},s=n?new Map:void 0;for(let i=0;i<r.value;i++){let a=Vn(e,t);if(a===xi){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed map`)}if(a===Bo)throw new Error(`${V} found map but not enough entries (got ${i} [no key], expected ${r.value})`);if(n!==!0&&typeof a!="string")throw new Error(`${V} non-string keys not supported (got ${typeof a})`);if(t.rejectDuplicateMapKeys===!0&&(n&&s.has(a)||!n&&a in o))throw new Error(`${V} found repeat map key "${a}"`);let c=Vn(e,t);if(c===Bo)throw new Error(`${V} found map but not enough entries (got ${i} [no value], expected ${r.value})`);n?s.set(a,c):o[a]=c}return n?s:o}function Vn(r,e){if(r.done())return Bo;let t=r.next();if(t.type===h.break)return xi;if(t.type.terminal)return t.value;if(t.type===h.array)return ww(t,r,e);if(t.type===h.map)return bw(t,r,e);if(t.type===h.tag){if(e.tags&&typeof e.tags[t.value]=="function"){let n=Vn(r,e);return e.tags[t.value](n)}throw new Error(`${V} tag not supported (${t.value})`)}throw new Error("unsupported")}function Fc(r,e){if(!(r instanceof Uint8Array))throw new Error(`${V} data to decode must be a Uint8Array`);e=Object.assign({},gw,e);let t=e.tokenizer||new bi(r,e),n=Vn(t,e);if(n===Bo)throw new Error(`${V} did not find any content to decode`);if(n===xi)throw new Error(`${V} got unexpected break`);return[n,r.subarray(t.pos())]}function nt(r,e){let[t,n]=Fc(r,e);if(n.length>0)throw new Error(`${V} too many terminals, data makes no sense`);return t}var Ze=st(on(),1);var kd=Ke("ipns:utils"),Sd=W("/ipns/"),xw=114,Id=async(r,e)=>{if(e==null||r==null){let n=new Error("one or more of the provided parameters are not defined");throw kd.error(n),(0,Ze.default)(n,Nc)}let t;if(e.pubKey!=null){try{t=_c(e.pubKey)}catch(o){throw kd.error(o),o}if(!(await gl(e.pubKey)).equals(r))throw(0,Ze.default)(new Error("Embedded public key did not match PeerID"),wh)}else r.publicKey!=null&&(t=_c(r.publicKey));if(t!=null)return t;throw(0,Ze.default)(new Error("no public key is available"),Nc)};var Rd=r=>{let e=W("ipns-signature:");return Le([e,r])},Mr=r=>"signatureV1"in r?dt.encode({value:W(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:W(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):dt.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data});function Bt(r){let e=dt.decode(r);if(e.sequence!=null&&(e.sequence=BigInt(e.sequence)),e.ttl!=null&&(e.ttl=BigInt(e.ttl)),e.signatureV2==null||e.data==null)throw(0,Ze.default)(new Error("missing data or signatureV2"),jt);let t=_d(e.data),n=Ew(t.Value),o=z(t.Validity);if(e.value!=null&&e.signatureV1!=null)return vw(e),{value:n,validityType:dt.ValidityType.EOL,validity:o,sequence:t.Sequence,ttl:t.TTL,pubKey:e.pubKey,signatureV1:e.signatureV1,signatureV2:e.signatureV2,data:e.data};if(e.signatureV2!=null)return{value:n,validityType:dt.ValidityType.EOL,validity:o,sequence:t.Sequence,ttl:t.TTL,pubKey:e.pubKey,signatureV2:e.signatureV2,data:e.data};throw new Error("invalid record: does not include signatureV1 or signatureV2")}var Mc=r=>Le([Sd,r.toBytes()]),Fn=r=>Qn(r.slice(Sd.length));var _d=r=>{let e=nt(r);if(e.ValidityType===0)e.ValidityType=dt.ValidityType.EOL;else throw(0,Ze.default)(new Error("Unknown validity type"),ai);return Number.isInteger(e.Sequence)&&(e.Sequence=BigInt(e.Sequence)),Number.isInteger(e.TTL)&&(e.TTL=BigInt(e.TTL)),e},Ew=r=>{if(r!=null){if(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=re.asCID(r);if(t!=null)return t.code===xw?`/ipns/${t.toString(sr)}`:`/ipfs/${t.toV1().toString()}`;try{return r instanceof Uint8Array?`/ipfs/${re.decode(r).toV1().toString()}`:`/ipfs/${re.parse(e).toV1().toString()}`}catch{}}throw(0,Ze.default)(new Error("Value must be a valid content path starting with /"),gh)},vw=r=>{if(r.data==null)throw(0,Ze.default)(new Error("Record data is missing"),yh);let e=_d(r.data);if(!se(e.Value,r.value??new Uint8Array(0)))throw(0,Ze.default)(new Error('Field "value" did not match between protobuf and CBOR'),jt);if(!se(e.Validity,r.validity??new Uint8Array(0)))throw(0,Ze.default)(new Error('Field "validity" did not match between protobuf and CBOR'),jt);if(e.ValidityType!==r.validityType)throw(0,Ze.default)(new Error('Field "validityType" did not match between protobuf and CBOR'),jt);if(e.Sequence!==r.sequence)throw(0,Ze.default)(new Error('Field "sequence" did not match between protobuf and CBOR'),jt);if(e.TTL!==r.ttl)throw(0,Ze.default)(new Error('Field "ttl" did not match between protobuf and CBOR'),jt)};var e8=Ke("ipns"),t8=Je.code,kw="/ipns/",r8=kw.length;var ko=st(on(),1),Td=st(Cc(),1);var vi=Ke("ipns:validator"),Sw=1024*10,Iw=async(r,e)=>{let t=Bt(e),n;try{let o=Rd(t.data);n=await r.verify(o,t.signatureV2)}catch{n=!1}if(!n)throw vi.error("record signature verification failed"),(0,ko.default)(new Error("record signature verification failed"),jt);if(t.validityType===dt.ValidityType.EOL){if(Td.default.fromString(t.validity).toDate().getTime()<Date.now())throw vi.error("record has expired"),(0,ko.default)(new Error("record has expired"),mh)}else if(t.validityType!=null)throw vi.error("unrecognized validity type"),(0,ko.default)(new Error("unrecognized validity type"),ai);vi("ipns record for %s is valid",t.value)};async function Cd(r,e){if(e.byteLength>Sw)throw(0,ko.default)(new Error("record too large"),bh);let t=Fn(r),n=Bt(e),o=await Id(t,n);await Iw(o,e)}async function*So(r){let e=/\r?\n/,t=new TextDecoder("utf8"),n="";for await(let o of r){typeof o=="string"&&(o=new TextEncoder().encode(o)),n+=t.decode(o,{stream:!0});let s=n.split(e);n=s.pop()??"";for(let i=0;i<s.length;i++)yield JSON.parse(s[i])}n+=t.decode(),n!==""&&(yield JSON.parse(n))}var $c=st(Ld(),1);var Ro=class extends Error{constructor(e){super(e),this.name="TimeoutError"}},Kc=class extends Error{constructor(e){super(),this.name="AbortError",this.message=e}},Dd=r=>globalThis.DOMException===void 0?new Kc(r):new DOMException(r),Ud=r=>{let e=r.reason===void 0?Dd("This operation was aborted."):r.reason;return e instanceof Error?e:Dd(e)};function _o(r,e){let{milliseconds:t,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout}}=e,i,c=new Promise((f,u)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(e.signal){let{signal:p}=e;p.aborted&&u(Ud(p)),p.addEventListener("abort",()=>{u(Ud(p))})}if(t===Number.POSITIVE_INFINITY){r.then(f,u);return}let l=new Ro;i=s.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(p){u(p)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?f():o instanceof Error?u(o):(l.message=o??`Promise timed out after ${t} milliseconds`,u(l))},t),(async()=>{try{f(await r)}catch(p){u(p)}})()}).finally(()=>{c.clear()});return c.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},c}function qc(r,e,t){let n=0,o=r.length;for(;o>0;){let s=Math.trunc(o/2),i=n+s;t(r[i],e)<=0?(n=++i,o-=s+1):o=s}return n}var To=class{#e=[];enqueue(e,t){t={priority:0,...t};let n={priority:t.priority,run:e};if(this.size&&this.#e[this.size-1].priority>=t.priority){this.#e.push(n);return}let o=qc(this.#e,n,(s,i)=>i.priority-s.priority);this.#e.splice(o,0,n)}dequeue(){return this.#e.shift()?.run}filter(e){return this.#e.filter(t=>t.priority===e.priority).map(t=>t.run)}get size(){return this.#e.length}};var kt=class extends $c.default{#e;#t;#r=0;#i;#c;#p=0;#o;#u;#n;#m;#s=0;#l;#a;#y;timeout;constructor(e){if(super(),e={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:To,...e},!(typeof e.intervalCap=="number"&&e.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${e.intervalCap?.toString()??""}\` (${typeof e.intervalCap})`);if(e.interval===void 0||!(Number.isFinite(e.interval)&&e.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${e.interval?.toString()??""}\` (${typeof e.interval})`);this.#e=e.carryoverConcurrencyCount,this.#t=e.intervalCap===Number.POSITIVE_INFINITY||e.interval===0,this.#i=e.intervalCap,this.#c=e.interval,this.#n=new e.queueClass,this.#m=e.queueClass,this.concurrency=e.concurrency,this.timeout=e.timeout,this.#y=e.throwOnTimeout===!0,this.#a=e.autoStart===!1}get#b(){return this.#t||this.#r<this.#i}get#x(){return this.#s<this.#l}#E(){this.#s--,this.#f(),this.emit("next")}#v(){this.#w(),this.#g(),this.#u=void 0}get#A(){let e=Date.now();if(this.#o===void 0){let t=this.#p-e;if(t<0)this.#r=this.#e?this.#s:0;else return this.#u===void 0&&(this.#u=setTimeout(()=>{this.#v()},t)),!0}return!1}#f(){if(this.#n.size===0)return this.#o&&clearInterval(this.#o),this.#o=void 0,this.emit("empty"),this.#s===0&&this.emit("idle"),!1;if(!this.#a){let e=!this.#A;if(this.#b&&this.#x){let t=this.#n.dequeue();return t?(this.emit("active"),t(),e&&this.#g(),!0):!1}}return!1}#g(){this.#t||this.#o!==void 0||(this.#o=setInterval(()=>{this.#w()},this.#c),this.#p=Date.now()+this.#c)}#w(){this.#r===0&&this.#s===0&&this.#o&&(clearInterval(this.#o),this.#o=void 0),this.#r=this.#e?this.#s:0,this.#h()}#h(){for(;this.#f(););}get concurrency(){return this.#l}set concurrency(e){if(!(typeof e=="number"&&e>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${e}\` (${typeof e})`);this.#l=e,this.#h()}async#B(e){return new Promise((t,n)=>{e.addEventListener("abort",()=>{n(e.reason)},{once:!0})})}async add(e,t={}){return t={timeout:this.timeout,throwOnTimeout:this.#y,...t},new Promise((n,o)=>{this.#n.enqueue(async()=>{this.#s++,this.#r++;try{t.signal?.throwIfAborted();let s=e({signal:t.signal});t.timeout&&(s=_o(Promise.resolve(s),{milliseconds:t.timeout})),t.signal&&(s=Promise.race([s,this.#B(t.signal)]));let i=await s;n(i),this.emit("completed",i)}catch(s){if(s instanceof Ro&&!t.throwOnTimeout){n();return}o(s),this.emit("error",s)}finally{this.#E()}},t),this.emit("add"),this.#f()})}async addAll(e,t){return Promise.all(e.map(async n=>this.add(n,t)))}start(){return this.#a?(this.#a=!1,this.#h(),this):this}pause(){this.#a=!0}clear(){this.#n=new this.#m}async onEmpty(){this.#n.size!==0&&await this.#d("empty")}async onSizeLessThan(e){this.#n.size<e||await this.#d("next",()=>this.#n.size<e)}async onIdle(){this.#s===0&&this.#n.size===0||await this.#d("idle")}async#d(e,t){return new Promise(n=>{let o=()=>{t&&!t()||(this.off(e,o),n())};this.on(e,o)})}get size(){return this.#n.size}sizeBy(e){return this.#n.filter(e).length}get pending(){return this.#s}get isPaused(){return this.#a}};function Tw(r){return r[Symbol.asyncIterator]!=null}function Cw(r){if(Tw(r))return(async()=>{for await(let e of r)return e})();for(let e of r)return e}var Bi=Cw;var zc=W("/ipns/");function Pd(r){return se(r.subarray(0,zc.byteLength),zc)}var Od=r=>Qn(r.slice(zc.length)),ki=class{client;constructor(e){this.client=e}async*findProviders(e,t={}){yield*sn(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async put(e,t,n){if(!Pd(e))return;let o=Od(e),s=Bt(t);await this.client.putIPNS(o,s,n)}async get(e,t){if(!Pd(e))throw new N("Not found","ERR_NOT_FOUND");let n=Od(e);try{let o=await this.client.getIPNS(n,t);return Mr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new N("Not found","ERR_NOT_FOUND"):o}}},Si=class{client;constructor(e){this.client=e}async findPeer(e,t={}){let n=await Bi(this.client.getPeers(e,t));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new N("Not found","ERR_NOT_FOUND")}async*getClosestPeers(e,t={}){}};var Me=Ke("delegated-routing-v1-http-api-client"),Vd={concurrentRequests:4,timeout:3e4},Ii=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;constructor(e,t={}){this.started=!1,this.shutDownController=new AbortController,Yr(1/0,this.shutDownController.signal),this.httpQueue=new kt({concurrency:t.concurrentRequests??Vd.concurrentRequests}),this.clientUrl=e instanceof URL?e:new URL(e),this.timeout=t.timeout??Vd.timeout,this.contentRouting=new ki(this),this.peerRouting=new Si(this)}get[jn](){return this.contentRouting}get[Wn](){return this.peerRouting}isStarted(){return this.started}start(){this.started=!0}stop(){this.httpQueue.clear(),this.shutDownController.abort(),this.started=!1}async*getProviders(e,t={}){Me("getProviders starts: %c",e);let n=Sr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=De(),s=De();this.httpQueue.add(async()=>(o.resolve(),s.promise));try{await o.promise;let i=`${this.clientUrl}routing/v1/providers/${e.toString()}`,c=await fetch(i,{headers:{Accept:"application/x-ndjson"},signal:n});if(c.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new N("Routing response had no body","ERR_BAD_RESPONSE");if(c.headers.get("Content-Type")==="application/json"){let u=await c.json();for(let l of u.Providers){let p=this.#e(l);p!=null&&(yield p)}}else for await(let u of So(es(c.body))){let l=this.#e(u);l!=null&&(yield l)}}catch(i){Me.error("getProviders errored:",i)}finally{n.clear(),s.resolve(),Me("getProviders finished: %c",e)}}async*getPeers(e,t={}){Me("getPeers starts: %c",e);let n=Sr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=De(),s=De();this.httpQueue.add(async()=>(o.resolve(),s.promise));try{await o.promise;let i=`${this.clientUrl}routing/v1/peers/${e.toCID().toString()}`,c=await fetch(i,{headers:{Accept:"application/x-ndjson"},signal:n});if(c.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new N("Routing response had no body","ERR_BAD_RESPONSE");if(c.headers.get("Content-Type")==="application/json"){let u=await c.json();for(let l of u.Peers){let p=this.#e(l);p!=null&&(yield p)}}else for await(let u of So(es(c.body))){let l=this.#e(u);l!=null&&(yield l)}}catch(i){Me.error("getPeers errored:",i)}finally{n.clear(),s.resolve(),Me("getPeers finished: %c",e)}}async getIPNS(e,t={}){Me("getIPNS starts: %c",e);let n=Sr([this.shutDownController.signal,t.signal,AbortSignal.timeout(this.timeout)]),o=De(),s=De();this.httpQueue.add(async()=>(o.resolve(),s.promise));let i=`${this.clientUrl}routing/v1/ipns/${e.toCID().toString()}`;try{await o.promise;let c=await fetch(i,{headers:{Accept:"application/vnd.ipfs.ipns-record"},signal:n});if(Me("getIPNS GET %s %d",i,c.status),c.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(c.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(c.body==null)throw new N("GET ipns response had no body","ERR_BAD_RESPONSE");let f=await c.arrayBuffer(),u=new Uint8Array(f,0,f.byteLength);return t.validate!==!1&&await Cd(Mc(e),u),Bt(u)}catch(a){throw Me.error("getIPNS GET %s error:",i,a),a}finally{n.clear(),s.resolve(),Me("getIPNS finished: %c",e)}}async putIPNS(e,t,n={}){Me("putIPNS starts: %c",e);let o=Sr([this.shutDownController.signal,n.signal,AbortSignal.timeout(this.timeout)]),s=De(),i=De();this.httpQueue.add(async()=>(s.resolve(),i.promise));let a=`${this.clientUrl}routing/v1/ipns/${e.toCID().toString()}`;try{await s.promise;let c=Mr(t),u=await fetch(a,{method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:c,signal:o});if(Me("putIPNS PUT %s %d",a,u.status),u.status!==200)throw new N("PUT ipns response had status other than 200","ERR_BAD_RESPONSE")}catch(c){throw Me.error("putIPNS PUT %s error:",a,c.stack),c}finally{o.clear(),i.resolve(),Me("putIPNS finished: %c",e)}}#e(e){let t=[],n=e.Addrs?.map(eo)??[];return e.Protocols!=null&&t.push(...e.Protocols),e.Protocol!=null&&(t.push(e.Protocol),delete e.Protocol),{...e,Schema:"peer",ID:Cr(e.ID),Addrs:n,Protocols:t}}};function Fd(r,e={}){return new Ii(new URL(r),e)}var Md=W("/ipns/");function Hd(r){return se(r.subarray(0,Md.byteLength),Md)}var Gc=class{client;constructor(e){this.client=Fd(e)}async provide(e,t){}async*findProviders(e,t){yield*sn(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs,protocols:n.Protocols}))}async put(e,t,n){if(!Hd(e))return;let o=Fn(e),s=Bt(t);await this.client.putIPNS(o,s,n)}async get(e,t){if(!Hd(e))throw new N("Not found","ERR_NOT_FOUND");let n=Fn(e);try{let o=await this.client.getIPNS(n,t);return Mr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new N("Not found","ERR_NOT_FOUND"):o}}async findPeer(e,t){let n=await Bi(this.client.getPeers(e,t));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new N("Not found","ERR_NOT_FOUND")}async*getClosestPeers(e,t){}};function jc(r){return new Gc(new URL(r))}function Ri(r){let e=[Yt.A];return r==null?e:Array.isArray(r)?r.length===0?e:r:[r]}var Wc=60;function _i(r){return{Status:r.Status??0,TC:r.TC??r.flag_tc??!1,RD:r.RD??r.flag_rd??!1,RA:r.RA??r.flag_ra??!1,AD:r.AD??r.flag_ad??!1,CD:r.CD??r.flag_cd??!1,Question:(r.Question??r.questions??[]).map(e=>({name:e.name,type:Yt[e.type]})),Answer:(r.Answer??r.answers??[]).map(e=>({name:e.name,type:Yt[e.type],TTL:e.TTL??e.ttl??Wc,data:e.data instanceof Uint8Array?z(e.data):e.data}))}}var Nw=4;function Yc(r,e={}){let t=new kt({concurrency:e.queryConcurrency??Nw});return async(n,o={})=>{let s=new URLSearchParams;s.set("name",n),Ri(o.types).forEach(a=>{s.append("type",a.toString())}),o.onProgress?.(new te("dns:query",{detail:n}));let i=await t.add(async()=>{let a=await fetch(`${r}?${s}`,{headers:{accept:"application/dns-json"},signal:o?.signal});if(a.status!==200)throw new Error(`Unexpected HTTP status: ${a.status} - ${a.statusText}`);let c=_i(await a.json());return o.onProgress?.(new te("dns:response",{detail:c})),c},{signal:o.signal});if(i==null)throw new Error("No DNS response received");return i}}function $d(){return[Yc("https://cloudflare-dns.com/dns-query"),Yc("https://dns.google/resolve")]}var zd=st(qd(),1);var Zc=class{lru;constructor(e){this.lru=(0,zd.default)(e)}get(e,t){let n=!0,o=[];for(let s of t){let i=this.getAnswers(e,s);if(i.length===0){n=!1;break}o.push(...i)}if(n)return _i({answers:o})}getAnswers(e,t){let n=`${e.toLowerCase()}-${t}`,o=this.lru.get(n);if(o!=null){let s=o.filter(i=>i.expires>Date.now()).map(({expires:i,value:a})=>({...a,TTL:Math.round((i-Date.now())/1e3),type:Yt[a.type]}));return s.length===0&&this.lru.remove(n),s}return[]}add(e,t){let n=`${e.toLowerCase()}-${t.type}`,o=this.lru.get(n)??[];o.push({expires:Date.now()+(t.TTL??Wc)*1e3,value:t}),this.lru.set(n,o)}remove(e,t){let n=`${e.toLowerCase()}-${t}`;this.lru.remove(n)}clear(){this.lru.clear()}};function Gd(r){return new Zc(r)}var Lw=1e3,Ti=class{resolvers;cache;constructor(e){this.resolvers={},this.cache=Gd(e.cacheSize??Lw),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["."]=$d())}async query(e,t={}){let n=Ri(t.types),o=t.cached!==!1?this.cache.get(e,n):void 0;if(o!=null)return t.onProgress?.(new te("dns:cache",{detail:o})),o;let s=`${e.split(".").pop()}.`,i=(this.resolvers[s]??this.resolvers["."]).sort(()=>Math.random()>.5?-1:1),a=[];for(let c of i){if(t.signal?.aborted===!0)break;try{let f=await c(e,{...t,types:n});for(let u of f.Answer)this.cache.add(e,u);return f}catch(f){a.push(f),t.onProgress?.(new te("dns:error",{detail:f}))}}throw a.length===1?a[0]:new AggregateError(a,`DNS lookup of ${e} ${n} failed`)}};var Yt;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(Yt||(Yt={}));function jd(r={}){return new Ti(r)}var 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 Ci(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 Ni=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=t??"ABORT_ERR"}};async function Wd(r,e,t){if(e==null)return r;if(e.aborted)return Promise.reject(new Ni(t?.errorMessage,t?.errorCode));let n,o=new Ni(t?.errorMessage,t?.errorCode);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var Li=class{deferred;signal;where;constructor(e,t){this.signal=t,this.deferred=De(),this.where=e,this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(new er)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function Dw(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var Di=class{id;fn;options;priority;recipients;status;timeline;controller;constructor(e,t,n=0){this.id=Dw(),this.status="queued",this.fn=e,this.priority=n,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,Yr(1/0,this.controller.signal),this.onAbort=this.onAbort.bind(this)}abort(e){this.controller.abort(e)}onAbort(){this.recipients.reduce((t,n)=>t&&n.signal?.aborted===!0,!0)&&this.controller.abort(new er)}async join(e={}){let t=new Li(new Error("where").stack,e.signal);return this.recipients.push(t),e.signal?.addEventListener("abort",this.onAbort),t.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let e=await Wd(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(t=>{t.deferred.resolve(e)}),this.status="complete"}catch(e){this.recipients.forEach(t=>{t.deferred.reject(e)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(e=>{e.signal?.removeEventListener("abort",this.onAbort)})}};function Uw(r,e,t){let n=0,o=r.length;for(;o>0;){let s=Math.trunc(o/2),i=n+s;t(r[i],e)<=0?(n=++i,o-=s+1):o=s}return n}var Co=class extends Vo{concurrency;queue;pending;constructor(e={}){super(),this.concurrency=e.concurrency??Number.POSITIVE_INFINITY,this.pending=0,e.metricName!=null&&e.metrics?.registerMetricGroup(e.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.queue=[]}tryToStartAnother(){if(this.size===0)return queueMicrotask(()=>{this.safeDispatchEvent("empty")}),this.running===0&&queueMicrotask(()=>{this.safeDispatchEvent("idle")}),!1;if(this.pending<this.concurrency){let e;for(let t of this.queue)if(t.status==="queued"){e=t;break}return e==null?!1:(this.safeDispatchEvent("active"),this.pending++,e.run().finally(()=>{for(let t=0;t<this.queue.length;t++)if(this.queue[t]===e){this.queue.splice(t,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(e){if(this.queue[this.size-1]?.priority>=e.priority){this.queue.push(e);return}let t=Uw(this.queue,e,(n,o)=>o.priority-n.priority);this.queue.splice(t,0,e)}async add(e,t){t?.signal?.throwIfAborted();let n=new Di(e,t,t?.priority),o=n.join(t).then(s=>(this.safeDispatchEvent("completed",{detail:s}),s)).catch(s=>{throw this.safeDispatchEvent("error",{detail:s}),s});return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),o}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(e=>{e.abort(new er)}),this.clear()}async onEmpty(e){this.size!==0&&await Ci(this,"empty",e?.signal)}async onSizeLessThan(e,t){this.size<e||await Ci(this,"next",t?.signal,{filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await Ci(this,"idle",e?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(e){e?.signal?.throwIfAborted();let t=Ct({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),t.end(c)},o=c=>{c.detail!=null&&t.push(c.detail)},s=c=>{n(c.detail)},i=()=>{n()},a=()=>{n(new N("Queue aborted","ERR_QUEUE_ABORTED"))};this.addEventListener("completed",o),this.addEventListener("error",s),this.addEventListener("idle",i),e?.signal?.addEventListener("abort",a);try{yield*t}finally{this.removeEventListener("completed",o),this.removeEventListener("error",s),this.removeEventListener("idle",i),e?.signal?.removeEventListener("abort",a),n()}}};var Xd="/pin/",Yd="/pinned-block/",Xc=sr,Zd=1;function Jd(r){return r.version===0&&(r=r.toV1()),new Se(`${Xd}${r.toString(Xc)}`)}var Ui=class{datastore;blockstore;dagWalkers;constructor(e,t,n){this.datastore=e,this.blockstore=t,this.dagWalkers=n}async*add(e,t={}){let n=Jd(e);if(await this.datastore.has(n))throw new Error("Already pinned");let o=Math.round(t.depth??1/0);if(o<0)throw new Error("Depth must be greater than or equal to 0");let s=new Co({concurrency:Zd});for await(let a of this.#e(e,s,{...t,depth:o}))await this.#t(a,c=>c.pinnedBy.find(f=>se(f,e.bytes))!=null?!1:(c.pinCount++,c.pinnedBy.push(e.bytes),!0),t),yield a;let i={depth:o,metadata:t.metadata??{}};await this.datastore.put(n,On(i),t)}async*#e(e,t,n){if(n.depth===-1)return;let o=this.dagWalkers[e.code];if(o==null)throw new Error(`No dag walker found for cid codec ${e.code}`);let s=await this.blockstore.get(e,n);yield e;for await(let i of o.walk(s))yield*await t.add(async()=>this.#e(i,t,{...n,depth:n.depth-1}))}async#t(e,t,n){let o=new Se(`${Yd}${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,On(s),n),n.onProgress?.(new te("helia:pin:add",e))}}async*rm(e,t={}){let n=Jd(e),o=await this.datastore.get(n,t),s=nt(o);await this.datastore.delete(n,t);let i=new Co({concurrency:Zd});for await(let a of this.#e(e,i,{...t,depth:s.depth}))await this.#t(a,c=>(c.pinCount--,c.pinnedBy=c.pinnedBy.filter(f=>se(f,e.bytes)),!0),{...t,depth:s.depth}),yield a}async*ls(e={}){for await(let{key:t,value:n}of this.datastore.query({prefix:Xd+(e.cid!=null?`${e.cid.toString(sr)}`:"")},e)){let o=re.parse(t.toString().substring(5),sr),s=nt(n);yield{cid:o,...s}}}async isPinned(e,t={}){let n=new Se(`${Yd}${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 Mn=class r{set;constructor(e){if(this.set=new Set,e!=null)for(let t of e)this.set.add(t.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(e){this.set.add(e.toString())}clear(){this.set.clear()}delete(e){this.set.delete(e.toString())}entries(){return Qc(this.set.entries(),e=>{let t=Cr(e[0]);return[t,t]})}forEach(e){this.set.forEach(t=>{let n=Cr(t);e(n,n,this)})}has(e){return this.set.has(e.toString())}values(){return Qc(this.set.values(),e=>Cr(e))}intersection(e){let t=new r;for(let n of e)this.has(n)&&t.add(n);return t}difference(e){let t=new r;for(let n of this)e.has(n)||t.add(n);return t}union(e){let t=new r;for(let n of e)t.add(n);for(let n of this)t.add(n);return t}};var Pi=class{log;routers;constructor(e,t){this.log=e.logger.forComponent("helia:routing"),this.routers=t.routers??[]}async start(){await tr(...this.routers)}async stop(){await rr(...this.routers)}async*findProviders(e,t={}){if(this.routers.length===0)throw new N("No content routers available","ERR_NO_ROUTERS_AVAILABLE");let n=new Mn;for await(let o of ar(...Hn(this.routers,"findProviders").map(s=>s.findProviders(e,t))))o!=null&&(n.has(o.id)||(n.add(o.id),yield o))}async provide(e,t={}){if(this.routers.length===0)throw new N("No content routers available","ERR_NO_ROUTERS_AVAILABLE");await Promise.all(Hn(this.routers,"provide").map(async n=>{await n.provide(e,t)}))}async put(e,t,n){await Promise.all(Hn(this.routers,"put").map(async o=>{await o.put(e,t,n)}))}async get(e,t){return Promise.any(Hn(this.routers,"get").map(async n=>n.get(e,t)))}async findPeer(e,t){if(this.routers.length===0)throw new N("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");let n=this,o=ar(...Hn(this.routers,"findPeer").map(s=>async function*(){try{yield await s.findPeer(e,t)}catch(i){n.log.error(i)}}()));for await(let s of o)if(s!=null)return s;throw new N("Could not find peer in routing","ERR_NOT_FOUND")}async*getClosestPeers(e,t={}){if(this.routers.length===0)throw new N("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");let n=new Mn;for await(let o of ar(...Hn(this.routers,"getClosestPeers").map(s=>s.getClosestPeers(e,t))))o!=null&&(n.has(o.id)||(n.add(o.id),yield o))}};function Hn(r,e){return r.filter(t=>t[e]!=null)}var vr={},$n=r=>{r.addEventListener("message",e=>{$n.dispatchEvent("message",r,e)}),r.port!=null&&r.port.addEventListener("message",e=>{$n.dispatchEvent("message",r,e)})};$n.addEventListener=(r,e)=>{vr[r]==null&&(vr[r]=[]),vr[r].push(e)};$n.removeEventListener=(r,e)=>{vr[r]!=null&&(vr[r]=vr[r].filter(t=>t===e))};$n.dispatchEvent=function(r,e,t){vr[r]!=null&&vr[r].forEach(n=>n(e,t))};var eu=$n;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 Qd=(r=21)=>Math.random().toString().substring(2);var ep=(r,e,t,n,o)=>(s,i)=>{if(i.data.type!==t)return;let a={type:i.data.type,name:i.data.name,identifier:i.data.identifier};r.dispatchEvent(new MessageEvent(e,{data:{name:a.name,handler:async()=>{s.postMessage({type:o,name:a.name,identifier:a.identifier}),await new Promise(c=>{let f=u=>{if(u==null||u.data==null)return;let l={type:u.data.type,name:u.data.name,identifier:u.data.identifier};l.type===n&&l.identifier===a.identifier&&(s.removeEventListener("message",f),c())};s.addEventListener("message",f)})}}}))},tp=(r,e,t,n)=>async()=>{let o=Qd();return globalThis.postMessage({type:e,identifier:o,name:r}),new Promise(s=>{let i=a=>{if(a==null||a.data==null)return;let c={type:a.data.type,identifier:a.data.identifier};c.type===t&&c.identifier===o&&(globalThis.removeEventListener("message",i),s(()=>{globalThis.postMessage({type:n,identifier:o,name:r})}))};globalThis.addEventListener("message",i)})},Pw={singleProcess:!1},rp=r=>{if(r=Object.assign({},Pw,r),!!globalThis.document||r.singleProcess){let t=new EventTarget;return eu.addEventListener("message",ep(t,"requestReadLock",tu,ru,nu)),eu.addEventListener("message",ep(t,"requestWriteLock",ou,su,iu)),t}return{isWorker:!0,readLock:t=>tp(t,tu,nu,ru),writeLock:t=>tp(t,ou,iu,su)}};var Hr={},Ar;async function au(r,e){let t,n=new Promise(o=>{t=o});return r.add(async()=>_o((async()=>{await new Promise(o=>{t(()=>{o()})})})(),{milliseconds:e.timeout})),n}var Ow=(r,e)=>{if(Ar.isWorker===!0)return{readLock:Ar.readLock(r,e),writeLock:Ar.writeLock(r,e)};let t=new kt({concurrency:1}),n;return{async readLock(){if(n!=null)return au(n,e);n=new kt({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=rp(e),Ar.isWorker!==!0&&(Ar.addEventListener("requestReadLock",t=>{Hr[t.data.name]!=null&&Hr[t.data.name].readLock().then(async n=>t.data.handler().finally(()=>{n()}))}),Ar.addEventListener("requestWriteLock",async t=>{Hr[t.data.name]!=null&&Hr[t.data.name].writeLock().then(async n=>t.data.handler().finally(()=>{n()}))}))),Hr[e.name]==null&&(Hr[e.name]=Ow(e.name,e)),Hr[e.name]}var Oi=class{lock;child;pins;started;constructor(e,t,n={}){this.child=e,this.pins=t,this.lock=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 op=42;function Fw(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let e=re.asCID(r);if(!e)return null;let t=new Uint8Array(e.bytes.byteLength+1);return t.set(e.bytes,1),[new A(h.tag,op),new A(h.bytes,t)]}function 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 np={float64:!0,typeEncoders:{Object:Fw,undefined:Mw,number:Hw}},SS={...np,typeEncoders:{...np.typeEncoders}};function $w(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return re.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[op]=$w;var IS={...uu,tags:uu.tags.slice()};var sp=113;var ip=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(e){let t=this.inRecursive[this.inRecursive.length-1];t&&(t.type===h.array&&(t.elements++,t.elements!==1&&e.push([44])),t.type===h.map&&(t.elements++,t.elements!==1&&(t.elements%2===1?e.push([44]):e.push([58]))))}[h.uint.major](e,t){this.prefix(e);let n=String(t.value),o=[];for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);e.push(o)}[h.negint.major](e,t){this[h.uint.major](e,t)}[h.bytes.major](e,t){throw new Error(`${Ln} unsupported type: Uint8Array`)}[h.string.major](e,t){this.prefix(e);let n=ui(JSON.stringify(t.value));e.push(n.length>32?bo(n):n)}[h.array.major](e,t){this.prefix(e),this.inRecursive.push({type:h.array,elements:0}),e.push([91])}[h.map.major](e,t){this.prefix(e),this.inRecursive.push({type:h.map,elements:0}),e.push([123])}[h.tag.major](e,t){}[h.float.major](e,t){if(t.type.name==="break"){let i=this.inRecursive.pop();if(i){if(i.type===h.array)e.push([93]);else if(i.type===h.map)e.push([125]);else throw new Error("Unexpected recursive type; this should not happen!");return}throw new Error("Unexpected break; this should not happen!")}if(t.value===void 0)throw new Error(`${Ln} unsupported type: undefined`);if(this.prefix(e),t.type.name==="true"){e.push([116,114,117,101]);return}else if(t.type.name==="false"){e.push([102,97,108,115,101]);return}else if(t.type.name==="null"){e.push([110,117,108,108]);return}let n=String(t.value),o=[],s=!1;for(let i=0;i<n.length;i++)o[i]=n.charCodeAt(i),!s&&(o[i]===46||o[i]===101||o[i]===69)&&(s=!0);s||(o.push(46),o.push(48)),e.push(o)}};var $r=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t,this.modeStack=["value"],this.lastToken=""}pos(){return this._pos}done(){return this._pos>=this.data.length}ch(){return this.data[this._pos]}currentMode(){return this.modeStack[this.modeStack.length-1]}skipWhitespace(){let e=this.ch();for(;e===32||e===9||e===13||e===10;)e=this.data[++this._pos]}expect(e){if(this.data.length-this._pos<e.length)throw new Error(`${V} unexpected end of input at position ${this._pos}`);for(let t=0;t<e.length;t++)if(this.data[this._pos++]!==e[t])throw new Error(`${V} unexpected token at position ${this._pos}, expected to find '${String.fromCharCode(...e)}'`)}parseNumber(){let e=this._pos,t=!1,n=!1,o=a=>{for(;!this.done();){let c=this.ch();if(a.includes(c))this._pos++;else break}};if(this.ch()===45&&(t=!0,this._pos++),this.ch()===48)if(this._pos++,this.ch()===46)this._pos++,n=!0;else return new A(h.uint,0,this._pos-e);if(o([48,49,50,51,52,53,54,55,56,57]),t&&this._pos===e+1)throw new Error(`${V} unexpected token at position ${this._pos}`);if(!this.done()&&this.ch()===46){if(n)throw new Error(`${V} unexpected token at position ${this._pos}`);n=!0,this._pos++,o([48,49,50,51,52,53,54,55,56,57])}!this.done()&&(this.ch()===101||this.ch()===69)&&(n=!0,this._pos++,!this.done()&&(this.ch()===43||this.ch()===45)&&this._pos++,o([48,49,50,51,52,53,54,55,56,57]));let s=String.fromCharCode.apply(null,this.data.subarray(e,this._pos)),i=parseFloat(s);return n?new A(h.float,i,this._pos-e):this.options.allowBigInt!==!0||Number.isSafeInteger(i)?new A(i>=0?h.uint:h.negint,i,this._pos-e):new A(i>=0?h.uint:h.negint,BigInt(s),this._pos-e)}parseString(){if(this.ch()!==34)throw new Error(`${V} unexpected character at position ${this._pos}; this shouldn't happen`);this._pos++;for(let s=this._pos,i=0;s<this.data.length&&i<65536;s++,i++){let a=this.data[s];if(a===92||a<32||a>=128)break;if(a===34){let c=String.fromCharCode.apply(null,this.data.subarray(this._pos,s));return this._pos=s+1,new A(h.string,c,i)}}let e=this._pos,t=[],n=()=>{if(this._pos+4>=this.data.length)throw new Error(`${V} unexpected end of unicode escape sequence at position ${this._pos}`);let s=0;for(let i=0;i<4;i++){let a=this.ch();if(a>=48&&a<=57)a-=48;else if(a>=97&&a<=102)a=a-97+10;else if(a>=65&&a<=70)a=a-65+10;else throw new Error(`${V} unexpected unicode escape character at position ${this._pos}`);s=s*16+a,this._pos++}return s},o=()=>{let s=this.ch(),i=null,a=s>239?4:s>223?3:s>191?2:1;if(this._pos+a>this.data.length)throw new Error(`${V} unexpected unicode sequence at position ${this._pos}`);let c,f,u,l;switch(a){case 1:s<128&&(i=s);break;case 2:c=this.data[this._pos+1],(c&192)===128&&(l=(s&31)<<6|c&63,l>127&&(i=l));break;case 3:c=this.data[this._pos+1],f=this.data[this._pos+2],(c&192)===128&&(f&192)===128&&(l=(s&15)<<12|(c&63)<<6|f&63,l>2047&&(l<55296||l>57343)&&(i=l));break;case 4:c=this.data[this._pos+1],f=this.data[this._pos+2],u=this.data[this._pos+3],(c&192)===128&&(f&192)===128&&(u&192)===128&&(l=(s&15)<<18|(c&63)<<12|(f&63)<<6|u&63,l>65535&&l<1114112&&(i=l))}i===null?(i=65533,a=1):i>65535&&(i-=65536,t.push(i>>>10&1023|55296),i=56320|i&1023),t.push(i),this._pos+=a};for(;!this.done();){let s=this.ch(),i;switch(s){case 92:if(this._pos++,this.done())throw new Error(`${V} unexpected string termination at position ${this._pos}`);switch(i=this.ch(),this._pos++,i){case 34:case 39:case 92:case 47:t.push(i);break;case 98:t.push(8);break;case 116:t.push(9);break;case 110:t.push(10);break;case 102:t.push(12);break;case 114:t.push(13);break;case 117:t.push(n());break;default:throw new Error(`${V} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new A(h.string,Lc(t),this._pos-e);default:if(s<32)throw new Error(`${V} invalid control character at position ${this._pos}`);s<128?(t.push(s),this._pos++):o()}}throw new Error(`${V} unexpected end of string at position ${this._pos}`)}parseValue(){switch(this.ch()){case 123:return this.modeStack.push("obj-start"),this._pos++,new A(h.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new A(h.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new A(h.null,null,4);case 102:return this.expect([102,97,108,115,101]),new A(h.false,!1,5);case 116:return this.expect([116,114,117,101]),new A(h.true,!0,4);case 45:case 48:case 49:case 50:case 51:case 52:case 53:case 54:case 55:case 56:case 57:return this.parseNumber();default:throw new Error(`${V} unexpected character at position ${this._pos}`)}}next(){switch(this.skipWhitespace(),this.currentMode()){case"value":return this.modeStack.pop(),this.parseValue();case"array-value":{if(this.modeStack.pop(),this.ch()===93)return this._pos++,this.skipWhitespace(),new A(h.break,void 0,1);if(this.ch()!==44)throw new Error(`${V} unexpected character at position ${this._pos}, was expecting array delimiter but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue()}case"array-start":return this.modeStack.pop(),this.ch()===93?(this._pos++,this.skipWhitespace(),new A(h.break,void 0,1)):(this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue());case"obj-key":if(this.ch()===125)return this.modeStack.pop(),this._pos++,this.skipWhitespace(),new A(h.break,void 0,1);if(this.ch()!==44)throw new Error(`${V} unexpected character at position ${this._pos}, was expecting object delimiter but found '${String.fromCharCode(this.ch())}'`);this._pos++,this.skipWhitespace();case"obj-start":{if(this.modeStack.pop(),this.ch()===125)return this._pos++,this.skipWhitespace(),new A(h.break,void 0,1);let e=this.parseString();if(this.skipWhitespace(),this.ch()!==58)throw new Error(`${V} unexpected character at position ${this._pos}, was expecting key/value delimiter ':' but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("obj-value"),e}case"obj-value":return this.modeStack.pop(),this.modeStack.push("obj-key"),this.skipWhitespace(),this.parseValue();default:throw new Error(`${V} unexpected parse state at position ${this._pos}; this shouldn't happen`)}}};function Vi(r,e){return e=Object.assign({tokenizer:new $r(r,e)},e),nt(r,e)}var zw={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};zw.tags[42]=re.parse;var cp=297;var qS=new TextDecoder;var zS=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 Fi(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 up(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]=up(r,n),s===1){if(e.Hash)throw new Error("protobuf: (PBLink) duplicate Hash section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Hash`);if(e.Name!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Name before Hash");if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Hash");[e.Hash,n]=Fi(r,n)}else if(s===2){if(e.Name!==void 0)throw new Error("protobuf: (PBLink) duplicate Name section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Name`);if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Name");let i;[i,n]=Fi(r,n),e.Name=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 lp(r){let e=r.length,t=0,n,o=!1,s;for(;t<e;){let a,c;if([a,c,t]=up(r,t),a!==2)throw new Error(`protobuf: (PBNode) invalid wireType, expected 2, got ${a}`);if(c===1){if(s)throw new Error("protobuf: (PBNode) duplicate Data section");[s,t]=Fi(r,t),n&&(o=!0)}else if(c===2){if(o)throw new Error("protobuf: (PBNode) duplicate Links section");n||(n=[]);let f;[f,t]=Fi(r,t),n.push(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 jS=new TextEncoder,WS=2**32,YS=2**31;var XS=new TextEncoder;function fp(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var hp=112;function dp(r){let e=fp(r),t=lp(e),n={};return t.Data&&(n.Data=t.Data),t.Links&&(n.Links=t.Links.map(o=>{let s={};try{s.Hash=re.decode(o.Hash)}catch{}if(!s.Hash)throw new Error("Invalid Hash field found in link, expected CID");return o.Name!==void 0&&(s.Name=o.Name),o.Tsize!==void 0&&(s.Tsize=o.Tsize),s})),n}var Zw={codec:hp,*walk(r){yield*dp(r).Links.map(t=>t.Hash)}},Jw={codec:$o,*walk(){}},pp=42,Xw={codec:sp,*walk(r){let e=[],t=[];t[pp]=n=>{if(n[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");let o=re.decode(n.subarray(1));return e.push(o),o},nt(r,{tags:t}),yield*e}},fu=class extends $r{tokenBuffer;constructor(e,t){super(e,t),this.tokenBuffer=[]}done(){return this.tokenBuffer.length===0&&super.done()}_next(){return this.tokenBuffer.length>0?this.tokenBuffer.pop():super.next()}next(){let e=this._next();if(e.type===h.map){let t=this._next();if(t.type===h.string&&t.value==="/"){let n=this._next();if(n.type===h.string){if(this._next().type!==h.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new A(h.tag,42,0)}if(n.type===h.map){let o=this._next();if(o.type===h.string&&o.value==="bytes"){let s=this._next();if(s.type===h.string){for(let a=0;a<2;a++)if(this._next().type!==h.break)throw new Error("Invalid encoded Bytes form");let i=nr.decode(`m${s.value}`);return new A(h.bytes,i,s.value.length)}this.tokenBuffer.push(s)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(t)}return e}},Qw={codec:cp,*walk(r){let e=[],t=[];t[pp]=n=>{let o=re.parse(n);return e.push(o),o},Vi(r,{tags:t,tokenizer:new 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 mp(r=[]){let e={};return[Zw,Jw,Xw,Qw,eb,...r].forEach(t=>{e[t.codec]=t}),e}var hu=new Se("/version"),yp=1;async function gp(r){if(!await r.has(hu)){await r.put(hu,W(`${yp}`));return}let e=await r.get(hu),t=z(e);if(parseInt(t,10)!==yp)throw new Error("Unknown datastore version, a datastore migration may be required")}function wp(r=[]){let e={};return[we,sa,Je,...r].forEach(t=>{e[t.code]=t}),e}var St=class{has(e,t){return Promise.reject(new Error(".has is not implemented"))}put(e,t,n){return Promise.reject(new Error(".put is not implemented"))}async*putMany(e,t){for await(let{cid:n,block:o}of e)await this.put(n,o,t),yield n}get(e,t){return Promise.reject(new Error(".get is not implemented"))}async*getMany(e,t){for await(let n of e)yield{cid:n,block:await this.get(n,t)}}delete(e,t){return Promise.reject(new Error(".delete is not implemented"))}async*deleteMany(e,t){for await(let n of e)await this.delete(n,t),yield n}async*getAll(e){throw new Error(".getAll is not implemented")}};var Kr={};ge(Kr,{abortedError:()=>sb,closeFailedError:()=>rb,deleteFailedError:()=>pu,getFailedError:()=>nb,hasFailedError:()=>ob,notFoundError:()=>Br,openFailedError:()=>tb,putFailedError:()=>du});var Zt=st(on(),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 bp=0,Mi=class extends St{put(e){return e}get(e){if(e.code===bp)return e.multihash.digest;throw Br()}has(e){return e.code===bp}delete(){}*getAll(){}};function 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=qr(r),{value:n,done:o}=t.next();if(o===!0)return function*(){}();let s=e(n);if(typeof s.then=="function")return async function*(){await s&&(yield n);for await(let a of t)await e(a)&&(yield a)}();let i=e;return function*(){s===!0&&(yield n);for(let a of t)i(a)&&(yield a)}()}var ot=ab;var cb=Ke("blockstore:core:tiered"),No=class extends St{stores;constructor(e){super(),this.stores=e.slice()}async put(e,t,n){try{return await Promise.all(this.stores.map(async o=>{await o.put(e,t,n)})),e}catch(o){throw 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=Ct({objectMode:!0});return Tt(s.putMany(i,t)).catch(a=>{n=a}),i});try{for await(let s of e){if(n!=null)throw n;o.forEach(i=>i.push(s)),yield s.cid}}finally{o.forEach(s=>s.end())}}async*deleteMany(e,t={}){let n,o=this.stores.map(s=>{let i=Ct({objectMode:!0});return Tt(s.deleteMany(i,t)).catch(a=>{n=a}),i});try{for await(let s of e){if(n!=null)throw n;o.forEach(i=>i.push(s)),yield s}}finally{o.forEach(s=>s.end())}}async*getAll(e){let t=new Set;yield*ot(ar(...this.stores.map(n=>n.getAll(e))),n=>{let o=n.cid.toString();return t.has(o)?!1:(t.add(o),!0)})}};function ub(r){return typeof r.retrieve=="function"}function lb(r){return typeof r.announce=="function"}var Hi=class{child;blockRetrievers;blockAnnouncers;hashers;started;log;constructor(e){this.log=e.logger.forComponent("helia:networked-storage"),this.child=new No([new Mi,e.blockstore]),this.blockRetrievers=(e.blockBrokers??[]).filter(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 te("blocks:put:duplicate",e)),e):(n.onProgress?.(new te("blocks:put:providers:notify",e)),this.blockAnnouncers.forEach(o=>{o.announce(e,t,n)}),n.onProgress?.(new te("blocks:put:blockstore:put",e)),this.child.put(e,t,n))}async*putMany(e,t={}){let n=ot(e,async({cid:s})=>{let i=await this.child.has(s);return i&&t.onProgress?.(new te("blocks:put-many:duplicate",s)),!i}),o=Gi(n,({cid:s,block:i})=>{t.onProgress?.(new te("blocks:put-many:providers:notify",s)),this.blockAnnouncers.forEach(a=>{a.announce(s,i,t)})});t.onProgress?.(new te("blocks:put-many:blockstore:put-many")),yield*this.child.putMany(o,t)}async get(e,t={}){if(t.offline!==!0&&!await this.child.has(e)){t.onProgress?.(new te("blocks:get:providers:get",e));let n=await xp(e,this.blockRetrievers,this.hashers[e.multihash.code],{...t,log:this.log});return t.onProgress?.(new te("blocks:get:blockstore:put",e)),await this.child.put(e,n,t),t.onProgress?.(new te("blocks:get:providers:notify",e)),this.blockAnnouncers.forEach(o=>{o.announce(e,n,t)}),n}return t.onProgress?.(new te("blocks:get:blockstore:get",e)),this.child.get(e,t)}async*getMany(e,t={}){t.onProgress?.(new te("blocks:get-many:blockstore:get-many")),yield*this.child.getMany(Gi(e,async n=>{if(t.offline!==!0&&!await this.child.has(n)){t.onProgress?.(new te("blocks:get-many:providers:get",n));let o=await xp(n,this.blockRetrievers,this.hashers[n.multihash.code],{...t,log:this.log});t.onProgress?.(new te("blocks:get-many:blockstore:put",n)),await this.child.put(n,o,t),t.onProgress?.(new te("blocks:get-many:providers:notify",n)),this.blockAnnouncers.forEach(s=>{s.announce(n,o,t)})}}))}async delete(e,t={}){t.onProgress?.(new te("blocks:delete:blockstore:delete",e)),await this.child.delete(e,t)}async*deleteMany(e,t={}){t.onProgress?.(new te("blocks:delete-many:blockstore:delete-many")),yield*this.child.deleteMany(async function*(){for await(let n of e)yield n}(),t)}async has(e,t={}){return this.child.has(e,t)}async*getAll(e={}){e.onProgress?.(new te("blocks:get-all:blockstore:get-many")),yield*this.child.getAll(e)}},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 xp(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 $i=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=wp(e.hashers),this.dagWalkers=mp(e.dagWalkers),this.dns=e.dns??jd();let t={blockstore:e.blockstore,datastore:e.datastore,hashers:this.hashers,dagWalkers:this.dagWalkers,logger:this.logger,blockBrokers:[],dns:this.dns,...e.components??{}};t.blockBrokers=e.blockBrokers.map(o=>o(t));let n=new Hi(t);this.pins=new Ui(e.datastore,n,this.dagWalkers),this.blockstore=new Oi(n,this.pins,{holdGcLock:e.holdGcLock??!0}),this.datastore=e.datastore,this.routing=new Pi(t,{routers:(e.routers??[]).flatMap(o=>{let s=[o];return o[jn]!=null&&s.push(o[jn]),o[Wn]!=null&&s.push(o[Wn]),s})})}async start(){await gp(this.datastore),await tr(this.blockstore,this.datastore,this.routing)}async stop(){await rr(this.blockstore,this.datastore,this.routing)}async gc(e={}){let t=await this.blockstore.lock.writeLock();try{let n=this,o=this.blockstore.unwrap();this.log("gc start"),await Tt(o.deleteMany(async function*(){for await(let{cid:s}of o.getAll())try{if(await n.pins.isPinned(s,e))continue;yield s,e.onProgress?.(new te("helia:gc:deleted",s))}catch(i){n.log.error("Error during gc",i),e.onProgress?.(new te("helia:gc:error",i))}}()))}finally{t()}this.log("gc finished")}};var Lo=class extends St{data;constructor(){super(),this.data=new Map}put(e,t){return this.data.set(Be.encode(e.multihash.bytes),t),e}get(e){let t=this.data.get(Be.encode(e.multihash.bytes));if(t==null)throw Br();return t}has(e){return this.data.has(Be.encode(e.multihash.bytes))}async delete(e){this.data.delete(Be.encode(e.multihash.bytes))}async*getAll(){for(let[e,t]of this.data.entries())yield{cid:re.createV1($o,gt(Be.decode(e))),block:t}}};var a6={...Kr};var Ep=st(on(),1);function Ki(r){return r=r??new Error("Not Found"),(0,Ep.default)(r,"ERR_NOT_FOUND")}var vp="SHARDING";function 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 qi=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 Tt(this.putMany(e,n)),e=[],await Tt(this.deleteMany(t,n)),t=[]}}}async*_all(e,t){throw new Error("._all is not implemented")}async*_allKeys(e,t){throw new Error("._allKeys is not implemented")}query(e,t){let n=this._all(e,t);if(e.prefix!=null){let o=e.prefix;n=ot(n,s=>s.key.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,s)=>ot(o,s),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,s)=>qi(o,s),n)),e.offset!=null){let o=0,s=e.offset;n=ot(n,()=>o++>=s)}return e.limit!=null&&(n=jo(n,e.limit)),n}queryKeys(e,t){let n=this._allKeys(e,t);if(e.prefix!=null){let o=e.prefix;n=ot(n,s=>s.toString().startsWith(o))}if(Array.isArray(e.filters)&&(n=e.filters.reduce((o,s)=>ot(o,s),n)),Array.isArray(e.orders)&&(n=e.orders.reduce((o,s)=>qi(o,s),n)),e.offset!=null){let o=e.offset,s=0;n=ot(n,()=>s++>=o)}return e.limit!=null&&(n=jo(n,e.limit)),n}};var Uo=class extends Jt{data;constructor(){super(),this.data=new Map}put(e,t){return this.data.set(e.toString(),t),e}get(e){let t=this.data.get(e.toString());if(t==null)throw Ki();return t}has(e){return this.data.has(e.toString())}delete(e){this.data.delete(e.toString())}*_all(){for(let[e,t]of this.data.entries())yield{key:new Se(e),value:t}}*_allKeys(){for(let e of this.data.keys())yield new Se(e)}};var P6=new Se(vp);var W6=Ke("datastore:core:tiered");async function bb(r={}){let e=r.datastore??new Uo,t=r.blockstore??new Lo,n=new $i({...r,datastore:e,blockstore:t,blockBrokers:r.blockBrokers??[Pa()],routers:r.routers??[jc("https://delegated-ipfs.dev")]});return r.start!==!1&&await n.start(),n}return Op(xb);})();
5
+ `));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
6
+ ${t.join(`
7
+ `)}`:`${e} :`}};ih=Er;D.Constructed=ih;Er.NAME="CONSTRUCTED";var Gs=class extends Pt{fromBER(t,e,n){return e}toBER(t){return be}};Gs.override="EndOfContentValueBlock";var ah,js=class extends Tt{constructor(t={}){super(t,Gs),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};ah=js;D.EndOfContent=ah;js.NAME=xo;var ch,vr=class extends Tt{constructor(t={}){super(t,Pt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let o=new Uint8Array(n);o[0]=5,o[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};ch=vr;D.Null=ch;vr.NAME="NULL";var Ws=class extends Xe(Pt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=Z.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let o=Z.BufferSourceConverter.toUint8Array(t);return Je(this,o,e,n)?(this.valueHexView=o.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,Hc.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Ws.NAME="BooleanValueBlock";var uh,Ys=class extends Tt{constructor(t={}){super(t,Ws),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};uh=Ys;D.Boolean=uh;Ys.NAME="BOOLEAN";var Zs=class extends Xe(Te){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let o=0;if(this.isConstructed){if(this.isHexOnly=!1,o=Te.prototype.fromBER.call(this,t,e,n),o===-1)return o;for(let s=0;s<this.value.length;s++){let i=this.value[s].constructor.NAME;if(i===xo){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==rh)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,o=super.fromBER(t,e,n),this.blockLength=n;return o}toBER(t,e){return this.isConstructed?Te.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};Zs.NAME="OctetStringValueBlock";var lh,Ye=class r extends Tt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var o,s;(o=n.isConstructed)!==null&&o!==void 0||(n.isConstructed=!!(!((s=n.value)===null||s===void 0)&&s.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Zs),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let s=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(s.byteLength){let i=Bi(s,0,s.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?Er.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${Z.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return Z.BufferSourceConverter.concat(t)}};lh=Ye;D.OctetString=lh;Ye.NAME=rh;var Js=class extends Xe(Te){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let o=-1;if(this.isConstructed){if(o=Te.prototype.fromBER.call(this,t,e,n),o===-1)return o;for(let a of this.value){let c=a.constructor.NAME;if(c===xo){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==nh)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let u=a.valueBlock;if(this.unusedBits>0&&u.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=u.unusedBits}return o}let s=Z.BufferSourceConverter.toUint8Array(t);if(!Je(this,s,e,n))return-1;let i=s.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=Bi(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return Te.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return be;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}}};Js.NAME="BitStringValueBlock";var fh,Pn=class extends Tt{constructor({idBlock:t={},lenBlock:e={},...n}={}){var o,s;(o=n.isConstructed)!==null&&o!==void 0||(n.isConstructed=!!(!((s=n.value)===null||s===void 0)&&s.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},Js),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Er.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let o of e)t.push(o.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};fh=Pn;D.BitString=fh;Pn.NAME=nh;var hh;function bw(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),o=new Uint8Array(t),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,u=0,l=c<i?i:c,f=0;for(let h=l;h>=0;h--,f++){switch(!0){case f<a.length:u=s[i-f]+a[c-f]+e[0];break;default:u=s[i-f]+e[0]}switch(e[0]=u/10,!0){case f>=s.length:s=Vs(new Uint8Array([u%10]),s);break;default:s[i-f]=u%10}}return e[0]>0&&(s=Vs(e,s)),s}function eh(r){if(r>=wo.length)for(let t=wo.length;t<=r;t++){let e=new Uint8Array([0]),n=wo[t-1].slice(0);for(let o=n.length-1;o>=0;o--){let s=new Uint8Array([(n[o]<<1)+e[0]]);e[0]=s[0]/10,n[o]=s[0]%10}e[0]>0&&(n=Vs(e,n)),wo.push(n)}return wo[r]}function xw(r,t){let e=0,n=new Uint8Array(r),o=new Uint8Array(t),s=n.slice(0),i=s.length-1,a=o.slice(0),c=a.length-1,u,l=0;for(let f=c;f>=0;f--,l++)switch(u=s[i-l]-a[c-l]-e,!0){case u<0:e=1,s[i-l]=u+10;break;default:e=0,s[i-l]=u}if(e>0)for(let f=i-c+1;f>=0;f--,l++)if(u=s[i-l]-e,u<0)e=1,s[i-l]=u+10;else{e=0,s[i-l]=u;break}return s.slice()}var Eo=class extends Xe(Pt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=Hc.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Xf(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,o=0){let s=this.fromBER(t,e,n);if(s===-1)return s;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):o!==0&&i.length<o&&(o-i.length>1&&(o=i.length+1),this.valueHexView=i.subarray(o-i.length)),s}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let o=super.fromBER(t,e,n);return o===-1||this.setValueHex(),o}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,o,s=this.valueHexView,i="",a=!1;for(let c=s.byteLength-1;c>=0;c--){o=s[c];for(let u=0;u<8;u++){if((o&1)===1)switch(n){case t:e=xw(eh(n),e),i="-";break;default:e=bw(e,eh(n))}n++,o>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=th.charAt(e[c]));return a===!1&&(i+=th.charAt(0)),i}};hh=Eo;Eo.NAME="IntegerValueBlock";Object.defineProperty(hh.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var dh,wt=class r extends Tt{constructor(t={}){super(t,Eo),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Ms(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Ms();let e=BigInt(t),n=new bo,o=e.toString(16).replace(/^-/,""),s=new Uint8Array(Z.Convert.FromHex(o));if(e<0){let a=new Uint8Array(s.length+(s[0]&128?1:0));a[0]|=128;let u=BigInt(`0x${Z.Convert.ToHex(a)}`)+e,l=Z.BufferSourceConverter.toUint8Array(Z.Convert.FromHex(u.toString(16)));l[0]|=128,n.write(l)}else s[0]&128&&n.write(new Uint8Array([0])),n.write(s);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};dh=wt;D.Integer=dh;wt.NAME="INTEGER";var ph,Xs=class extends wt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};ph=Xs;D.Enumerated=ph;Xs.NAME="ENUMERATED";var vo=class extends Xe(Pt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let o=Z.BufferSourceConverter.toUint8Array(t);if(!Je(this,o,e,n))return-1;let s=o.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=s[a]&127,this.blockLength++,!!(s[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,s[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Gr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Ms();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let o=0;o<n.length;o++)n[o]=parseInt(e.slice(o*7,o*7+7),2)+(o+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let o=this.valueHexView,s=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)s[i]=o[i]|128;return s[this.blockLength-1]=o[this.blockLength-1],s.buffer}let e=xr(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",be;let n=new Uint8Array(e.byteLength);if(!t){let o=new Uint8Array(e),s=e.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n}toString(){let t="";if(this.isHexOnly)t=Z.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};vo.NAME="sidBlock";var Qs=class extends Pt{constructor({value:t=On,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let o=e;for(;n>0;){let s=new vo;if(o=s.fromBER(t,o,n),o===-1)return this.blockLength=0,this.error=s.error,o;this.value.length===0&&(s.isFirstSid=!0),this.blockLength+=s.blockLength,n-=s.blockLength,this.value.push(s)}return o}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let o=this.value[n].toBER(t);if(o.byteLength===0)return this.error=this.value[n].error,be;e.push(o)}return Kc(e)}fromString(t){this.value=[];let e=0,n=0,o="",s=!1;do if(n=t.indexOf(".",e),n===-1?o=t.substring(e):o=t.substring(e,n),e=n+1,s){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(o,10);if(isNaN(c))return;i.valueDec=c+a,s=!1}else{let i=new vo;if(o>Number.MAX_SAFE_INTEGER){Ms();let a=BigInt(o);i.valueBigInt=a}else if(i.valueDec=parseInt(o,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,s=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let o=this.value[n].toString();n!==0&&(t=`${t}.`),e?(o=`{${o}}`,this.value[n].isFirstSid?t=`2.{${o} - 80}`:t+=o):t+=o}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};Qs.NAME="ObjectIdentifierValueBlock";var mh,we=class extends Tt{constructor(t={}){super(t,Qs),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};mh=we;D.ObjectIdentifier=mh;we.NAME="OBJECT IDENTIFIER";var Ao=class extends Xe(We){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let o=Z.BufferSourceConverter.toUint8Array(t);if(!Je(this,o,e,n))return-1;let s=o.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=s[a]&127,this.blockLength++,!!(s[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,s[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=Gr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let o=this.valueHexView,s=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)s[i]=o[i]|128;return s[this.blockLength-1]=o[this.blockLength-1],s.buffer}let e=xr(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",be;let n=new Uint8Array(e.byteLength);if(!t){let o=new Uint8Array(e),s=e.byteLength-1;for(let i=0;i<s;i++)n[i]=o[i]|128;n[s]=o[s]}return n.buffer}toString(){let t="";return this.isHexOnly?t=Z.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};Ao.NAME="relativeSidBlock";var ti=class extends Pt{constructor({value:t=On,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let o=e;for(;n>0;){let s=new Ao;if(o=s.fromBER(t,o,n),o===-1)return this.blockLength=0,this.error=s.error,o;this.blockLength+=s.blockLength,n-=s.blockLength,this.value.push(s)}return o}toBER(t,e){let n=[];for(let o=0;o<this.value.length;o++){let s=this.value[o].toBER(t);if(s.byteLength===0)return this.error=this.value[o].error,be;n.push(s)}return Kc(n)}fromString(t){this.value=[];let e=0,n=0,o="";do{n=t.indexOf(".",e),n===-1?o=t.substring(e):o=t.substring(e,n),e=n+1;let s=new Ao;if(s.valueDec=parseInt(o,10),isNaN(s.valueDec))return!0;this.value.push(s)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let o=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(o=`{${o}}`),t+=o}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};ti.NAME="RelativeObjectIdentifierValueBlock";var yh,ei=class extends Tt{constructor(t={}){super(t,ti),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};yh=ei;D.RelativeObjectIdentifier=yh;ei.NAME="RelativeObjectIdentifier";var gh,At=class extends Er{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};gh=At;D.Sequence=gh;At.NAME="SEQUENCE";var wh,ri=class extends Er{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};wh=ri;D.Set=wh;ri.NAME="SET";var ni=class extends Xe(Pt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=On}toJSON(){return{...super.toJSON(),value:this.value}}};ni.NAME="StringValueBlock";var oi=class extends ni{};oi.NAME="SimpleStringValueBlock";var $t=class extends Ks{constructor({...t}={}){super(t,oi)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,Z.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let o=0;o<e;o++)n[o]=t.charCodeAt(o);this.valueBlock.value=t}};$t.NAME="SIMPLE STRING";var si=class extends $t{fromBuffer(t){this.valueBlock.valueHexView=Z.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=Z.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=Z.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(Z.Convert.FromUtf8String(t)),this.valueBlock.value=t}};si.NAME="Utf8StringValueBlock";var bh,Ze=class extends si{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};bh=Ze;D.Utf8String=bh;Ze.NAME="UTF8String";var ii=class extends $t{fromBuffer(t){this.valueBlock.value=Z.Convert.ToUtf16String(t),this.valueBlock.valueHexView=Z.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(Z.Convert.FromUtf16String(t))}};ii.NAME="BmpStringValueBlock";var xh,ai=class extends ii{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};xh=ai;D.BmpString=xh;ai.NAME="BMPString";var ci=class extends $t{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let o=0;o<n.length;o+=4)n[o]=n[o+3],n[o+1]=n[o+2],n[o+2]=0,n[o+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let o=0;o<e;o++){let s=xr(t.charCodeAt(o),8),i=new Uint8Array(s);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[o*4+c+a]=i[c]}this.valueBlock.value=t}};ci.NAME="UniversalStringValueBlock";var Eh,ui=class extends ci{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};Eh=ui;D.UniversalString=Eh;ui.NAME="UniversalString";var vh,li=class extends $t{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};vh=li;D.NumericString=vh;li.NAME="NumericString";var Ah,fi=class extends $t{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Ah=fi;D.PrintableString=Ah;fi.NAME="PrintableString";var Bh,hi=class extends $t{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Bh=hi;D.TeletexString=Bh;hi.NAME="TeletexString";var kh,di=class extends $t{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};kh=di;D.VideotexString=kh;di.NAME="VideotexString";var Sh,pi=class extends $t{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};Sh=pi;D.IA5String=Sh;pi.NAME="IA5String";var Ih,mi=class extends $t{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Ih=mi;D.GraphicString=Ih;mi.NAME="GraphicString";var Rh,Bo=class extends $t{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};Rh=Bo;D.VisibleString=Rh;Bo.NAME="VisibleString";var _h,yi=class extends $t{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};_h=yi;D.GeneralString=_h;yi.NAME="GeneralString";var Th,gi=class extends $t{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Th=gi;D.CharacterString=Th;gi.NAME="CharacterString";var Nh,ko=class extends Bo{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let o=0;o<t.length;o++)this.valueBlock.valueHexView[o]=t.charCodeAt(o)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,Z.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let o=0;o<t.length;o++)n[o]=t.charCodeAt(o);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let o=parseInt(n[1],10);o>=50?this.year=1900+o:this.year=2e3+o,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=qt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=qt(this.month,2),e[2]=qt(this.day,2),e[3]=qt(this.hour,2),e[4]=qt(this.minute,2),e[5]=qt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};Nh=ko;D.UTCTime=Nh;ko.NAME="UTCTime";var Ch,wi=class extends ko{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",o="",s=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let f=new Number(t[t.length-1]);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let f=1,h=n.indexOf("+"),g="";if(h===-1&&(h=n.indexOf("-"),f=-1),h!==-1){if(g=n.substring(h+1),n=n.substring(0,h),g.length!==2&&g.length!==4)throw new Error("Wrong input string for conversion");let y=parseInt(g.substring(0,2),10);if(isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*y,g.length===4){if(y=parseInt(g.substring(2,4),10),isNaN(y.valueOf()))throw new Error("Wrong input string for conversion");c=f*y}}}let u=n.indexOf(".");if(u===-1&&(u=n.indexOf(",")),u!==-1){let f=new Number(`0${n.substring(u)}`);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");s=f.valueOf(),o=n.substring(0,u)}else o=n;switch(!0){case o.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,u!==-1)throw new Error("Wrong input string for conversion");break;case o.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=60*s;this.minute=Math.floor(f),f=60*(f-this.minute),this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case o.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=60*s;this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case o.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,u!==-1){let f=1e3*s;this.millisecond=Math.floor(f)}break;default:throw new Error("Wrong input string for conversion")}let l=i.exec(o);if(l===null)throw new Error("Wrong input string for conversion");for(let f=1;f<l.length;f++)switch(f){case 1:this.year=parseInt(l[f],10);break;case 2:this.month=parseInt(l[f],10);break;case 3:this.day=parseInt(l[f],10);break;case 4:this.hour=parseInt(l[f],10)+a;break;case 5:this.minute=parseInt(l[f],10)+c;break;case 6:this.second=parseInt(l[f],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let f=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=f.getUTCFullYear(),this.month=f.getUTCMonth(),this.day=f.getUTCDay(),this.hour=f.getUTCHours(),this.minute=f.getUTCMinutes(),this.second=f.getUTCSeconds(),this.millisecond=f.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(qt(this.year,4)),e.push(qt(this.month,2)),e.push(qt(this.day,2)),e.push(qt(this.hour,2)),e.push(qt(this.minute,2)),e.push(qt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(qt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Ch=wi;D.GeneralizedTime=Ch;wi.NAME="GeneralizedTime";var Lh,bi=class extends Ze{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Lh=bi;D.DATE=Lh;bi.NAME="DATE";var Uh,xi=class extends Ze{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Uh=xi;D.TimeOfDay=Uh;xi.NAME="TimeOfDay";var Dh,Ei=class extends Ze{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Dh=Ei;D.DateTime=Dh;Ei.NAME="DateTime";var Ph,vi=class extends Ze{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Ph=vi;D.Duration=Ph;vi.NAME="Duration";var Oh,Ai=class extends Ze{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Oh=Ai;D.TIME=Oh;Ai.NAME="TIME";function vw(r){let{result:t}=Fn(r),e=t.valueBlock.value;return{n:z(Ne(e[1].toBigInt()),"base64url"),e:z(Ne(e[2].toBigInt()),"base64url"),d:z(Ne(e[3].toBigInt()),"base64url"),p:z(Ne(e[4].toBigInt()),"base64url"),q:z(Ne(e[5].toBigInt()),"base64url"),dp:z(Ne(e[6].toBigInt()),"base64url"),dq:z(Ne(e[7].toBigInt()),"base64url"),qi:z(Ne(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function Aw(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new N("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new At({value:[new wt({value:0}),wt.fromBigInt(Ce(Y(r.n,"base64url"))),wt.fromBigInt(Ce(Y(r.e,"base64url"))),wt.fromBigInt(Ce(Y(r.d,"base64url"))),wt.fromBigInt(Ce(Y(r.p,"base64url"))),wt.fromBigInt(Ce(Y(r.q,"base64url"))),wt.fromBigInt(Ce(Y(r.dp,"base64url"))),wt.fromBigInt(Ce(Y(r.dq,"base64url"))),wt.fromBigInt(Ce(Y(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Bw(r){let{result:t}=Fn(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:z(Ne(e[0].toBigInt()),"base64url"),e:z(Ne(e[1].toBigInt()),"base64url")}}function kw(r){if(r.n==null||r.e==null)throw new N("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new At({value:[new At({value:[new we({value:"1.2.840.113549.1.1.1"}),new vr]}),new Pn({valueHex:new At({value:[wt.fromBigInt(Ce(Y(r.n,"base64url"))),wt.fromBigInt(Ce(Y(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Ne(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),o=0,s=0;for(;o<e;)n[o]=parseInt(t.slice(s,s+2),16),o+=1,s+=2;return n}function Ce(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}var Sw=16,zc=32,Gc=1e4;async function Iw(r,t){let e=Mt.get(),o=new At({value:[new wt({value:0}),new At({value:[new we({value:"1.2.840.113549.1.1.1"}),new vr]}),new Ye({valueHex:r.marshal()})]}).toBER(),s=new Uint8Array(o,0,o.byteLength),i=zr(Sw),a=await Mc(_n,t,i,{c:Gc,dkLen:zc}),c=zr(16),u=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),l=await e.subtle.encrypt({name:"AES-CBC",iv:c},u,s),f=new At({value:[new Ye({valueHex:i}),new wt({value:Gc}),new wt({value:zc}),new At({value:[new we({value:"1.2.840.113549.2.11"}),new vr]})]}),h=new At({value:[new we({value:"1.2.840.113549.1.5.13"}),new At({value:[new At({value:[new we({value:"1.2.840.113549.1.5.12"}),f]}),new At({value:[new we({value:"2.16.840.1.101.3.4.1.42"}),new Ye({valueHex:c})]})]})]}),y=new At({value:[h,new Ye({valueHex:l})]}).toBER(),p=new Uint8Array(y,0,y.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...z(p,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
8
+ `)}async function Rw(r,t){let e=Mt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=Y(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Fn(o),{iv:i,salt:a,iterations:c,keySize:u,cipherText:l}=_w(s),f=await Mc(_n,t,a,{c,dkLen:u}),h=await e.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),g=So(await e.subtle.decrypt({name:"AES-CBC",iv:i},h,l)),{result:y}=Fn(g);n=Fh(y)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=Y(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Fn(o);n=Fh(s)}else throw new N("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return jc(n)}function _w(r){let t=r.valueBlock.value[0];if(t.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=t.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=So(s.valueBlock.value[0].getValue()),a=Gc,c=zc;if(s.valueBlock.value.length===3)a=Number(s.valueBlock.value[1].toBigInt()),c=Number(s.valueBlock.value[2].toBigInt());else if(s.valueBlock.value.length===2)throw new N("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let u=t.valueBlock.value[1].valueBlock.value[1],l=u.valueBlock.value[0].toString();if(l!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(l!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(l!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(l!=="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 f=So(u.valueBlock.value[1].getValue());return{cipherText:So(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function Fh(r){return So(r.valueBlock.value[2].getValue())}function So(r){return new Uint8Array(r,0,r.byteLength)}async function Vh(r){let t=await Mt.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Hh(t);return{privateKey:e[0],publicKey:e[1]}}async function Wc(r){let e=[await Mt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await Tw(r)],n=await Hh({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Mh(r,t){let e=await Mt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Mt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function $h(r,t,e){let n=await Mt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Mt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Hh(r){if(r.privateKey==null||r.publicKey==null)throw new N("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Mt.get().subtle.exportKey("jwk",r.privateKey),Mt.get().subtle.exportKey("jwk",r.publicKey)])}async function Tw(r){return Mt.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 ki(r){if(r.kty!=="RSA")throw new N("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new N("invalid key modulus","ERR_INVALID_KEY_MODULUS");return Y(r.n,"base64url").length*8}var Ro=8192,Io=class{_key;constructor(t){this._key=t}verify(t,e){return $h(this._key,e,t)}marshal(){return Ar.jwkToPkix(this._key)}get bytes(){return _e.encode({Type:yt.RSA,Data:this.marshal()}).subarray()}equals(t){return ct(this.bytes,t.bytes)}hash(){let t=Et.digest(this.bytes);return ae(t)?t.then(({bytes:e})=>e):t.bytes}},Vn=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return zr(16)}sign(t){return Mh(this._key,t)}get public(){if(this._publicKey==null)throw new N("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Io(this._publicKey)}marshal(){return Ar.jwkToPkcs1(this._key)}get bytes(){return Ge.encode({Type:yt.RSA,Data:this.marshal()}).subarray()}equals(t){return ct(this.bytes,t.bytes)}hash(){let t=Et.digest(this.bytes);return ae(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return z(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Ar.exportToPem(this,t);if(e==="libp2p-key")return Ln(this.bytes,t);throw new N(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function jc(r){let t=Ar.pkcs1ToJwk(r);if(ki(t)>Ro)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Wc(t);return new Vn(e.privateKey,e.publicKey)}function Cw(r){let t=Ar.pkixToJwk(r);if(ki(t)>Ro)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Io(t)}async function Lw(r){if(ki(r)>Ro)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Wc(r);return new Vn(t.privateKey,t.publicKey)}async function Uw(r){if(r>Ro)throw new N("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Vh(r);return new Vn(t.privateKey,t.publicKey)}var tu={};xt(tu,{Secp256k1PrivateKey:()=>To,Secp256k1PublicKey:()=>_o,generateKeyPair:()=>jw,unmarshalSecp256k1PrivateKey:()=>zw,unmarshalSecp256k1PublicKey:()=>Gw});var Dw=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Br=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),kr=new Uint32Array(64),Zc=class extends Rn{constructor(){super(64,32,8,!1),this.A=Br[0]|0,this.B=Br[1]|0,this.C=Br[2]|0,this.D=Br[3]|0,this.E=Br[4]|0,this.F=Br[5]|0,this.G=Br[6]|0,this.H=Br[7]|0}get(){let{A:t,B:e,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[t,e,n,o,s,i,a,c]}set(t,e,n,o,s,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)kr[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let h=kr[f-15],g=kr[f-2],y=ye(h,7)^ye(h,18)^h>>>3,p=ye(g,17)^ye(g,19)^g>>>10;kr[f]=p+kr[f-7]+y+kr[f-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:u,H:l}=this;for(let f=0;f<64;f++){let h=ye(a,6)^ye(a,11)^ye(a,25),g=l+h+If(a,c,u)+Dw[f]+kr[f]|0,p=(ye(n,2)^ye(n,13)^ye(n,22))+Rf(n,o,s)|0;l=u,u=c,c=a,a=i+g|0,i=s,s=o,o=n,n=g+p|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,u=u+this.G|0,l=l+this.H|0,this.set(n,o,s,i,a,c,u,l)}roundClean(){kr.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Kh=ks(()=>new Zc);function Pw(r){let t=mo(r);Re(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:o}=t;if(e){if(!n.eql(o,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Ow,hexToBytes:Fw}=Rs,jr={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=jr;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:Ow(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=jr,e=typeof r=="string"?Fw(r):r;Tn(e);let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:o,l:s}=jr._parseInt(e.subarray(2)),{d:i,l:a}=jr._parseInt(s);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:o,s:i}},hexFromSig(r){let t=u=>Number.parseInt(u[0],16)&8?"00"+u:u,e=u=>{let l=u.toString(16);return l.length&1?`0${l}`:l},n=t(e(r.s)),o=t(e(r.r)),s=n.length/2,i=o.length/2,a=e(s),c=e(i);return`30${e(i+s+4)}02${c}${o}02${a}${n}`}},Qe=BigInt(0),ue=BigInt(1),nk=BigInt(2),qh=BigInt(3),ok=BigInt(4);function Vw(r){let t=Pw(r),{Fp:e}=t,n=t.toBytes||((y,p,m)=>{let w=p.toAffine();return Ke(Uint8Array.from([4]),e.toBytes(w.x),e.toBytes(w.y))}),o=t.fromBytes||(y=>{let p=y.subarray(1),m=e.fromBytes(p.subarray(0,e.BYTES)),w=e.fromBytes(p.subarray(e.BYTES,2*e.BYTES));return{x:m,y:w}});function s(y){let{a:p,b:m}=t,w=e.sqr(y),I=e.mul(w,y);return e.add(e.add(I,e.mul(y,p)),m)}if(!e.eql(e.sqr(t.Gy),s(t.Gx)))throw new Error("bad generator point: equation left != right");function i(y){return typeof y=="bigint"&&Qe<y&&y<t.n}function a(y){if(!i(y))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(y){let{allowedPrivateKeyLengths:p,nByteLength:m,wrapPrivateKey:w,n:I}=t;if(p&&typeof y!="bigint"){if(gr(y)&&(y=$e(y)),typeof y!="string"||!p.includes(y.length))throw new Error("Invalid key");y=y.padStart(m*2,"0")}let v;try{v=typeof y=="bigint"?y:He(pt("private key",y,m))}catch{throw new Error(`private key must be ${m} bytes, hex or bigint, not ${typeof y}`)}return w&&(v=at(v,I)),a(v),v}let u=new Map;function l(y){if(!(y instanceof f))throw new Error("ProjectivePoint expected")}class f{constructor(p,m,w){if(this.px=p,this.py=m,this.pz=w,p==null||!e.isValid(p))throw new Error("x required");if(m==null||!e.isValid(m))throw new Error("y required");if(w==null||!e.isValid(w))throw new Error("z required")}static fromAffine(p){let{x:m,y:w}=p||{};if(!p||!e.isValid(m)||!e.isValid(w))throw new Error("invalid affine point");if(p instanceof f)throw new Error("projective point not allowed");let I=v=>e.eql(v,e.ZERO);return I(m)&&I(w)?f.ZERO:new f(m,w,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(p){let m=e.invertBatch(p.map(w=>w.pz));return p.map((w,I)=>w.toAffine(m[I])).map(f.fromAffine)}static fromHex(p){let m=f.fromAffine(o(pt("pointHex",p)));return m.assertValidity(),m}static fromPrivateKey(p){return f.BASE.multiply(c(p))}_setWindowSize(p){this._WINDOW_SIZE=p,u.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:p,y:m}=this.toAffine();if(!e.isValid(p)||!e.isValid(m))throw new Error("bad point: x or y not FE");let w=e.sqr(m),I=s(p);if(!e.eql(w,I))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:p}=this.toAffine();if(e.isOdd)return!e.isOdd(p);throw new Error("Field doesn't support isOdd")}equals(p){l(p);let{px:m,py:w,pz:I}=this,{px:v,py:U,pz:S}=p,_=e.eql(e.mul(m,S),e.mul(v,I)),L=e.eql(e.mul(w,S),e.mul(U,I));return _&&L}negate(){return new f(this.px,e.neg(this.py),this.pz)}double(){let{a:p,b:m}=t,w=e.mul(m,qh),{px:I,py:v,pz:U}=this,S=e.ZERO,_=e.ZERO,L=e.ZERO,b=e.mul(I,I),C=e.mul(v,v),O=e.mul(U,U),T=e.mul(I,v);return T=e.add(T,T),L=e.mul(I,U),L=e.add(L,L),S=e.mul(p,L),_=e.mul(w,O),_=e.add(S,_),S=e.sub(C,_),_=e.add(C,_),_=e.mul(S,_),S=e.mul(T,S),L=e.mul(w,L),O=e.mul(p,O),T=e.sub(b,O),T=e.mul(p,T),T=e.add(T,L),L=e.add(b,b),b=e.add(L,b),b=e.add(b,O),b=e.mul(b,T),_=e.add(_,b),O=e.mul(v,U),O=e.add(O,O),b=e.mul(O,T),S=e.sub(S,b),L=e.mul(O,C),L=e.add(L,L),L=e.add(L,L),new f(S,_,L)}add(p){l(p);let{px:m,py:w,pz:I}=this,{px:v,py:U,pz:S}=p,_=e.ZERO,L=e.ZERO,b=e.ZERO,C=t.a,O=e.mul(t.b,qh),T=e.mul(m,v),V=e.mul(w,U),H=e.mul(I,S),X=e.add(m,w),E=e.add(v,U);X=e.mul(X,E),E=e.add(T,V),X=e.sub(X,E),E=e.add(m,I);let k=e.add(v,S);return E=e.mul(E,k),k=e.add(T,H),E=e.sub(E,k),k=e.add(w,I),_=e.add(U,S),k=e.mul(k,_),_=e.add(V,H),k=e.sub(k,_),b=e.mul(C,E),_=e.mul(O,H),b=e.add(_,b),_=e.sub(V,b),b=e.add(V,b),L=e.mul(_,b),V=e.add(T,T),V=e.add(V,T),H=e.mul(C,H),E=e.mul(O,E),V=e.add(V,H),H=e.sub(T,H),H=e.mul(C,H),E=e.add(E,H),T=e.mul(V,E),L=e.add(L,T),T=e.mul(k,E),_=e.mul(X,_),_=e.sub(_,T),T=e.mul(X,V),b=e.mul(k,b),b=e.add(b,T),new f(_,L,b)}subtract(p){return this.add(p.negate())}is0(){return this.equals(f.ZERO)}wNAF(p){return g.wNAFCached(this,u,p,m=>{let w=e.invertBatch(m.map(I=>I.pz));return m.map((I,v)=>I.toAffine(w[v])).map(f.fromAffine)})}multiplyUnsafe(p){let m=f.ZERO;if(p===Qe)return m;if(a(p),p===ue)return this;let{endo:w}=t;if(!w)return g.unsafeLadder(this,p);let{k1neg:I,k1:v,k2neg:U,k2:S}=w.splitScalar(p),_=m,L=m,b=this;for(;v>Qe||S>Qe;)v&ue&&(_=_.add(b)),S&ue&&(L=L.add(b)),b=b.double(),v>>=ue,S>>=ue;return I&&(_=_.negate()),U&&(L=L.negate()),L=new f(e.mul(L.px,w.beta),L.py,L.pz),_.add(L)}multiply(p){a(p);let m=p,w,I,{endo:v}=t;if(v){let{k1neg:U,k1:S,k2neg:_,k2:L}=v.splitScalar(m),{p:b,f:C}=this.wNAF(S),{p:O,f:T}=this.wNAF(L);b=g.constTimeNegate(U,b),O=g.constTimeNegate(_,O),O=new f(e.mul(O.px,v.beta),O.py,O.pz),w=b.add(O),I=C.add(T)}else{let{p:U,f:S}=this.wNAF(m);w=U,I=S}return f.normalizeZ([w,I])[0]}multiplyAndAddUnsafe(p,m,w){let I=f.BASE,v=(S,_)=>_===Qe||_===ue||!S.equals(I)?S.multiplyUnsafe(_):S.multiply(_),U=v(this,m).add(v(p,w));return U.is0()?void 0:U}toAffine(p){let{px:m,py:w,pz:I}=this,v=this.is0();p==null&&(p=v?e.ONE:e.inv(I));let U=e.mul(m,p),S=e.mul(w,p),_=e.mul(I,p);if(v)return{x:e.ZERO,y:e.ZERO};if(!e.eql(_,e.ONE))throw new Error("invZ was invalid");return{x:U,y:S}}isTorsionFree(){let{h:p,isTorsionFree:m}=t;if(p===ue)return!0;if(m)return m(f,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:p,clearCofactor:m}=t;return p===ue?this:m?m(f,this):this.multiplyUnsafe(t.h)}toRawBytes(p=!0){return this.assertValidity(),n(f,this,p)}toHex(p=!0){return $e(this.toRawBytes(p))}}f.BASE=new f(t.Gx,t.Gy,e.ONE),f.ZERO=new f(e.ZERO,e.ONE,e.ZERO);let h=t.nBitLength,g=Ns(f,t.endo?Math.ceil(h/2):h);return{CURVE:t,ProjectivePoint:f,normPrivateKeyToScalar:c,weierstrassEquation:s,isWithinCurveOrder:i}}function Mw(r){let t=mo(r);return Re(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function zh(r){let t=Mw(r),{Fp:e,n}=t,o=e.BYTES+1,s=2*e.BYTES+1;function i(E){return Qe<E&&E<e.ORDER}function a(E){return at(E,n)}function c(E){return _s(E,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:l,weierstrassEquation:f,isWithinCurveOrder:h}=Vw({...t,toBytes(E,k,$){let B=k.toAffine(),x=e.toBytes(B.x),P=Ke;return $?P(Uint8Array.from([k.hasEvenY()?2:3]),x):P(Uint8Array.from([4]),x,e.toBytes(B.y))},fromBytes(E){let k=E.length,$=E[0],B=E.subarray(1);if(k===o&&($===2||$===3)){let x=He(B);if(!i(x))throw new Error("Point is not on curve");let P=f(x),M;try{M=e.sqrt(P)}catch(W){let et=W instanceof Error?": "+W.message:"";throw new Error("Point is not on curve"+et)}let K=(M&ue)===ue;return($&1)===1!==K&&(M=e.neg(M)),{x,y:M}}else if(k===s&&$===4){let x=e.fromBytes(B.subarray(0,e.BYTES)),P=e.fromBytes(B.subarray(e.BYTES,2*e.BYTES));return{x,y:P}}else throw new Error(`Point of length ${k} was invalid. Expected ${o} compressed bytes or ${s} uncompressed bytes`)}}),g=E=>$e(br(E,t.nByteLength));function y(E){let k=n>>ue;return E>k}function p(E){return y(E)?a(-E):E}let m=(E,k,$)=>He(E.slice(k,$));class w{constructor(k,$,B){this.r=k,this.s=$,this.recovery=B,this.assertValidity()}static fromCompact(k){let $=t.nByteLength;return k=pt("compactSignature",k,$*2),new w(m(k,0,$),m(k,$,2*$))}static fromDER(k){let{r:$,s:B}=jr.toSig(pt("DER",k));return new w($,B)}assertValidity(){if(!h(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!h(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(k){return new w(this.r,this.s,k)}recoverPublicKey(k){let{r:$,s:B,recovery:x}=this,P=L(pt("msgHash",k));if(x==null||![0,1,2,3].includes(x))throw new Error("recovery id invalid");let M=x===2||x===3?$+t.n:$;if(M>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let K=x&1?"03":"02",j=u.fromHex(K+g(M)),W=c(M),et=a(-P*W),J=a(B*W),Q=u.BASE.multiplyAndAddUnsafe(j,et,J);if(!Q)throw new Error("point at infinify");return Q.assertValidity(),Q}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new w(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return $r(this.toDERHex())}toDERHex(){return jr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return $r(this.toCompactHex())}toCompactHex(){return g(this.r)+g(this.s)}}let I={isValidPrivateKey(E){try{return l(E),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let E=Cc(t.n);return Vf(t.randomBytes(E),t.n)},precompute(E=8,k=u.BASE){return k._setWindowSize(E),k.multiply(BigInt(3)),k}};function v(E,k=!0){return u.fromPrivateKey(E).toRawBytes(k)}function U(E){let k=gr(E),$=typeof E=="string",B=(k||$)&&E.length;return k?B===o||B===s:$?B===2*o||B===2*s:E instanceof u}function S(E,k,$=!0){if(U(E))throw new Error("first arg must be private key");if(!U(k))throw new Error("second arg must be public key");return u.fromHex(k).multiply(l(E)).toRawBytes($)}let _=t.bits2int||function(E){let k=He(E),$=E.length*8-t.nBitLength;return $>0?k>>BigInt($):k},L=t.bits2int_modN||function(E){return a(_(E))},b=po(t.nBitLength);function C(E){if(typeof E!="bigint")throw new Error("bigint expected");if(!(Qe<=E&&E<b))throw new Error(`bigint expected < 2^${t.nBitLength}`);return br(E,t.nByteLength)}function O(E,k,$=T){if(["recovered","canonical"].some(ht=>ht in $))throw new Error("sign() legacy options not supported");let{hash:B,randomBytes:x}=t,{lowS:P,prehash:M,extraEntropy:K}=$;P==null&&(P=!0),E=pt("msgHash",E),M&&(E=pt("prehashed msgHash",B(E)));let j=L(E),W=l(k),et=[C(W),C(j)];if(K!=null&&K!==!1){let ht=K===!0?x(e.BYTES):K;et.push(pt("extraEntropy",ht))}let J=Ke(...et),Q=j;function gt(ht){let kt=_(ht);if(!h(kt))return;let St=c(kt),bt=u.BASE.multiply(kt).toAffine(),Lt=a(bt.x);if(Lt===Qe)return;let Pe=a(St*a(Q+Lt*W));if(Pe===Qe)return;let Tr=(bt.x===Lt?0:2)|Number(bt.y&ue),Xn=Pe;return P&&y(Pe)&&(Xn=p(Pe),Tr^=1),new w(Lt,Xn,Tr)}return{seed:J,k2sig:gt}}let T={lowS:t.lowS,prehash:!1},V={lowS:t.lowS,prehash:!1};function H(E,k,$=T){let{seed:B,k2sig:x}=O(E,k,$),P=t;return Rc(P.hash.outputLen,P.nByteLength,P.hmac)(B,x)}u.BASE._setWindowSize(8);function X(E,k,$,B=V){let x=E;if(k=pt("msgHash",k),$=pt("publicKey",$),"strict"in B)throw new Error("options.strict was renamed to lowS");let{lowS:P,prehash:M}=B,K,j;try{if(typeof x=="string"||gr(x))try{K=w.fromDER(x)}catch(bt){if(!(bt instanceof jr.Err))throw bt;K=w.fromCompact(x)}else if(typeof x=="object"&&typeof x.r=="bigint"&&typeof x.s=="bigint"){let{r:bt,s:Lt}=x;K=new w(bt,Lt)}else throw new Error("PARSE");j=u.fromHex($)}catch(bt){if(bt.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(P&&K.hasHighS())return!1;M&&(k=t.hash(k));let{r:W,s:et}=K,J=L(k),Q=c(et),gt=a(J*Q),ht=a(W*Q),kt=u.BASE.multiplyAndAddUnsafe(j,gt,ht)?.toAffine();return kt?a(kt.x)===W:!1}return{CURVE:t,getPublicKey:v,getSharedSecret:S,sign:H,verify:X,ProjectivePoint:u,Signature:w,utils:I}}function $w(r){return{hash:r,hmac:(t,...e)=>go(r,t,Bs(...e)),randomBytes:In}}function Gh(r,t){let e=n=>zh({...r,...$w(n)});return Object.freeze({...e(t),create:e})}var Yh=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),jh=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Hw=BigInt(1),Jc=BigInt(2),Wh=(r,t)=>(r+t/Jc)/t;function Kw(r){let t=Yh,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=r*r*r%t,l=u*u*r%t,f=lt(l,e,t)*l%t,h=lt(f,e,t)*l%t,g=lt(h,Jc,t)*u%t,y=lt(g,o,t)*g%t,p=lt(y,s,t)*y%t,m=lt(p,a,t)*p%t,w=lt(m,c,t)*m%t,I=lt(w,a,t)*p%t,v=lt(I,e,t)*l%t,U=lt(v,i,t)*y%t,S=lt(U,n,t)*u%t,_=lt(S,Jc,t);if(!Xc.eql(Xc.sqr(_),r))throw new Error("Cannot find square root");return _}var Xc=Ts(Yh,void 0,void 0,{sqrt:Kw}),xe=Gh({a:BigInt(0),b:BigInt(7),Fp:Xc,n:jh,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=jh,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Hw*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=Wh(s*r,t),c=Wh(-n*r,t),u=at(r-a*e-c*o,t),l=at(-a*n-c*s,t),f=u>i,h=l>i;if(f&&(u=t-u),h&&(l=t-l),u>i||l>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:u,k2neg:h,k2:l}}}},Kh),dk=BigInt(0);var pk=xe.ProjectivePoint;function Zh(){return xe.utils.randomPrivateKey()}function Jh(r,t){let e=Et.digest(t instanceof Uint8Array?t:t.subarray());if(ae(e))return e.then(({digest:n})=>xe.sign(n,r).toDERRawBytes()).catch(n=>{throw new N(String(n),"ERR_INVALID_INPUT")});try{return xe.sign(e.digest,r).toDERRawBytes()}catch(n){throw new N(String(n),"ERR_INVALID_INPUT")}}function Xh(r,t,e){let n=Et.digest(e instanceof Uint8Array?e:e.subarray());if(ae(n))return n.then(({digest:o})=>xe.verify(t,o,r)).catch(o=>{throw new N(String(o),"ERR_INVALID_INPUT")});try{return xe.verify(t,n.digest,r)}catch(o){throw new N(String(o),"ERR_INVALID_INPUT")}}function Qh(r){return xe.ProjectivePoint.fromHex(r).toRawBytes(!0)}function td(r){try{xe.getPublicKey(r,!0)}catch(t){throw new N(String(t),"ERR_INVALID_PRIVATE_KEY")}}function Qc(r){try{xe.ProjectivePoint.fromHex(r)}catch(t){throw new N(String(t),"ERR_INVALID_PUBLIC_KEY")}}function ed(r){try{return xe.getPublicKey(r,!0)}catch(t){throw new N(String(t),"ERR_INVALID_PRIVATE_KEY")}}var _o=class{_key;constructor(t){Qc(t),this._key=t}verify(t,e){return Xh(this._key,e,t)}marshal(){return Qh(this._key)}get bytes(){return _e.encode({Type:yt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ct(this.bytes,t.bytes)}async hash(){let t=Et.digest(this.bytes),e;return ae(t)?{bytes:e}=await t:e=t.bytes,e}},To=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??ed(t),td(this._key),Qc(this._publicKey)}sign(t){return Jh(this._key,t)}get public(){return new _o(this._publicKey)}marshal(){return this._key}get bytes(){return Ge.encode({Type:yt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ct(this.bytes,t.bytes)}hash(){let t=Et.digest(this.bytes);return ae(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return z(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Ln(this.bytes,t);throw new N(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function zw(r){return new To(r)}function Gw(r){return new _o(r)}async function jw(){let r=Zh();return new To(r)}var Si={rsa:Yc,ed25519:Vc,secp256k1:tu};function Ww(r){let t=Object.keys(Si).join(" / ");return new N(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function eu(r){let t=_e.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case yt.RSA:return Si.rsa.unmarshalRsaPublicKey(e);case yt.Ed25519:return Si.ed25519.unmarshalEd25519PublicKey(e);case yt.Secp256k1:return Si.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw Ww(t.Type??"unknown")}}var Rb=oe(hn(),1);var tr="/",rd=new TextEncoder().encode(tr),Ii=rd[0],Nt=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=Y(t);else if(t instanceof Uint8Array)this._buf=t;else throw new Error("Invalid key, should be String of Uint8Array");if(e==null&&(e=!0),e&&this.clean(),this._buf.byteLength===0||this._buf[0]!==Ii)throw new Error("Invalid key")}toString(t="utf8"){return z(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(tr))}static random(){return new r(Math.random().toString().substring(2))}static asKey(t){return t instanceof Uint8Array||typeof t=="string"?new r(t):typeof t.uint8Array=="function"?new r(t.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=rd),this._buf[0]!==Ii){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Ii,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Ii;)this._buf=this._buf.subarray(0,-1)}less(t){let e=this.list(),n=t.list();for(let o=0;o<e.length;o++){if(n.length<o+1)return!1;let s=e[o],i=n[o];if(s<i)return!0;if(s>i)return!1}return e.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let t=this.namespaces();return t[t.length-1]}list(){return this.toString().split(tr).slice(1)}type(){return Yw(this.baseNamespace())}name(){return Zw(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(tr)||(t+=tr),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(tr):new r(t.slice(0,-1).join(tr))}child(t){return this.toString()===tr?t:t.toString()===tr?this:new r(this.toString()+t.toString(),!1)}isAncestorOf(t){return t.toString()===this.toString()?!1:t.toString().startsWith(this.toString())}isDecendantOf(t){return t.toString()===this.toString()?!1:this.toString().startsWith(t.toString())}isTopLevel(){return this.list().length===1}concat(...t){return r.withNamespaces([...this.namespaces(),...Jw(t.map(e=>e.namespaces()))])}};function Yw(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function Zw(r){let t=r.split(":");return t[t.length-1]}function Jw(r){return[].concat(...r)}var _b=oe(nu(),1);var nd="ERR_IPNS_EXPIRED_RECORD",Ri="ERR_UNRECOGNIZED_VALIDITY";var er="ERR_SIGNATURE_VERIFICATION";var ou="ERR_UNDEFINED_PARAMETER",od="ERR_INVALID_RECORD_DATA",sd="ERR_INVALID_VALUE",id="ERR_INVALID_EMBEDDED_KEY";var ad="ERR_RECORD_TOO_LARGE";var Ee;(function(r){let t;(function(o){o.EOL="EOL"})(t=r.ValidityType||(r.ValidityType={}));let e;(function(o){o[o.EOL=0]="EOL"})(e||(e={})),function(o){o.codec=()=>co(e)}(t=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=wn((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=>yn(o,r.codec()),r.decode=o=>mn(o,r.codec())})(Ee||(Ee={}));var Xw=["string","number","bigint","symbol"],Qw=["Function","Generator","AsyncGenerator","GeneratorFunction","AsyncGeneratorFunction","AsyncFunction","Observable","Array","Buffer","Object","RegExp","Date","Error","Map","Set","WeakMap","WeakSet","ArrayBuffer","SharedArrayBuffer","DataView","Promise","URL","HTMLElement","Int8Array","Uint8Array","Uint8ClampedArray","Int16Array","Uint16Array","Int32Array","Uint32Array","Float32Array","Float64Array","BigInt64Array","BigUint64Array"];function ud(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let t=typeof r;if(Xw.includes(t))return t;if(t==="function")return"Function";if(Array.isArray(r))return"Array";if(tb(r))return"Buffer";let e=eb(r);return e||"Object"}function tb(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function eb(r){let t=Object.prototype.toString.call(r).slice(8,-1);if(Qw.includes(t))return t}var d=class{constructor(t,e,n){this.major=t,this.majorEncoded=t<<5,this.name=e,this.terminal=n}toString(){return`Type[${this.major}].${this.name}`}compare(t){return this.major<t.major?-1:this.major>t.major?1:0}};d.uint=new d(0,"uint",!0);d.negint=new d(1,"negint",!0);d.bytes=new d(2,"bytes",!0);d.string=new d(3,"string",!0);d.array=new d(4,"array",!1);d.map=new d(5,"map",!1);d.tag=new d(6,"tag",!1);d.float=new d(7,"float",!0);d.false=new d(7,"false",!0);d.true=new d(7,"true",!0);d.null=new d(7,"null",!0);d.undefined=new d(7,"undefined",!0);d.break=new d(7,"break",!0);var A=class{constructor(t,e,n){this.type=t,this.value=e,this.encodedLength=n,this.encodedBytes=void 0,this.byteValue=void 0}toString(){return`Token[${this.type}].${this.value}`}};var Mn=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",rb=new TextDecoder,nb=new TextEncoder;function _i(r){return Mn&&globalThis.Buffer.isBuffer(r)}function No(r){return r instanceof Uint8Array?_i(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var dd=Mn?(r,t,e)=>e-t>64?globalThis.Buffer.from(r.subarray(t,e)).toString("utf8"):fd(r,t,e):(r,t,e)=>e-t>64?rb.decode(r.subarray(t,e)):fd(r,t,e),Ti=Mn?r=>r.length>64?globalThis.Buffer.from(r):ld(r):r=>r.length>64?nb.encode(r):ld(r),Le=r=>Uint8Array.from(r),$n=Mn?(r,t,e)=>_i(r)?new Uint8Array(r.subarray(t,e)):r.slice(t,e):(r,t,e)=>r.slice(t,e),pd=Mn?(r,t)=>(r=r.map(e=>e instanceof Uint8Array?e:globalThis.Buffer.from(e)),No(globalThis.Buffer.concat(r,t))):(r,t)=>{let e=new Uint8Array(t),n=0;for(let o of r)n+o.length>e.length&&(o=o.subarray(0,e.length-n)),e.set(o,n),n+=o.length;return e},md=Mn?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function yd(r,t){if(_i(r)&&_i(t))return r.compare(t);for(let e=0;e<r.length;e++)if(r[e]!==t[e])return r[e]<t[e]?-1:1;return 0}function ld(r){let t=[],e=0;for(let n=0;n<r.length;n++){let o=r.charCodeAt(n);o<128?t[e++]=o:o<2048?(t[e++]=o>>6|192,t[e++]=o&63|128):(o&64512)===55296&&n+1<r.length&&(r.charCodeAt(n+1)&64512)===56320?(o=65536+((o&1023)<<10)+(r.charCodeAt(++n)&1023),t[e++]=o>>18|240,t[e++]=o>>12&63|128,t[e++]=o>>6&63|128,t[e++]=o&63|128):(t[e++]=o>>12|224,t[e++]=o>>6&63|128,t[e++]=o&63|128)}return t}function fd(r,t,e){let n=[];for(;t<e;){let o=r[t],s=null,i=o>239?4:o>223?3:o>191?2:1;if(t+i<=e){let a,c,u,l;switch(i){case 1:o<128&&(s=o);break;case 2:a=r[t+1],(a&192)===128&&(l=(o&31)<<6|a&63,l>127&&(s=l));break;case 3:a=r[t+1],c=r[t+2],(a&192)===128&&(c&192)===128&&(l=(o&15)<<12|(a&63)<<6|c&63,l>2047&&(l<55296||l>57343)&&(s=l));break;case 4:a=r[t+1],c=r[t+2],u=r[t+3],(a&192)===128&&(c&192)===128&&(u&192)===128&&(l=(o&15)<<18|(a&63)<<12|(c&63)<<6|u&63,l>65535&&l<1114112&&(s=l))}}s===null?(s=65533,i=1):s>65535&&(s-=65536,n.push(s>>>10&1023|55296),s=56320|s&1023),n.push(s),t+=i}return su(n)}var hd=4096;function su(r){let t=r.length;if(t<=hd)return String.fromCharCode.apply(String,r);let e="",n=0;for(;n<t;)e+=String.fromCharCode.apply(String,r.slice(n,n+=hd));return e}var ob=256,Co=class{constructor(t=ob){this.chunkSize=t,this.cursor=0,this.maxCursor=-1,this.chunks=[],this._initReuseChunk=null}reset(){this.cursor=0,this.maxCursor=-1,this.chunks.length&&(this.chunks=[]),this._initReuseChunk!==null&&(this.chunks.push(this._initReuseChunk),this.maxCursor=this._initReuseChunk.length-1)}push(t){let e=this.chunks[this.chunks.length-1];if(this.cursor+t.length<=this.maxCursor+1){let o=e.length-(this.maxCursor-this.cursor)-1;e.set(t,o)}else{if(e){let o=e.length-(this.maxCursor-this.cursor)-1;o<e.length&&(this.chunks[this.chunks.length-1]=e.subarray(0,o),this.maxCursor=this.cursor-1)}t.length<64&&t.length<this.chunkSize?(e=md(this.chunkSize),this.chunks.push(e),this.maxCursor+=e.length,this._initReuseChunk===null&&(this._initReuseChunk=e),e.set(t,0)):(this.chunks.push(t),this.maxCursor+=t.length)}this.cursor+=t.length}toBytes(t=!1){let e;if(this.chunks.length===1){let n=this.chunks[0];t&&this.cursor>n.length/2?(e=this.cursor===n.length?n:n.subarray(0,this.cursor),this._initReuseChunk=null,this.chunks=[]):e=$n(n,0,this.cursor)}else e=pd(this.chunks,this.cursor);return t&&this.reset(),e}};var F="CBOR decode error:",Hn="CBOR encode error:",Lo=[];Lo[23]=1;Lo[24]=2;Lo[25]=3;Lo[26]=5;Lo[27]=9;function rr(r,t,e){if(r.length-t<e)throw new Error(`${F} not enough data for type`)}var Bt=[24,256,65536,4294967296,BigInt("18446744073709551616")];function Qt(r,t,e){rr(r,t,1);let n=r[t];if(e.strict===!0&&n<Bt[0])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);return n}function te(r,t,e){rr(r,t,2);let n=r[t]<<8|r[t+1];if(e.strict===!0&&n<Bt[1])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);return n}function ee(r,t,e){rr(r,t,4);let n=r[t]*16777216+(r[t+1]<<16)+(r[t+2]<<8)+r[t+3];if(e.strict===!0&&n<Bt[2])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);return n}function re(r,t,e){rr(r,t,8);let n=r[t]*16777216+(r[t+1]<<16)+(r[t+2]<<8)+r[t+3],o=r[t+4]*16777216+(r[t+5]<<16)+(r[t+6]<<8)+r[t+7],s=(BigInt(n)<<BigInt(32))+BigInt(o);if(e.strict===!0&&s<Bt[3])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);if(s<=Number.MAX_SAFE_INTEGER)return Number(s);if(e.allowBigInt===!0)return s;throw new Error(`${F} integers outside of the safe integer range are not supported`)}function gd(r,t,e,n){return new A(d.uint,Qt(r,t+1,n),2)}function wd(r,t,e,n){return new A(d.uint,te(r,t+1,n),3)}function bd(r,t,e,n){return new A(d.uint,ee(r,t+1,n),5)}function xd(r,t,e,n){return new A(d.uint,re(r,t+1,n),9)}function le(r,t){return Ct(r,0,t.value)}function Ct(r,t,e){if(e<Bt[0]){let n=Number(e);r.push([t|n])}else if(e<Bt[1]){let n=Number(e);r.push([t|24,n])}else if(e<Bt[2]){let n=Number(e);r.push([t|25,n>>>8,n&255])}else if(e<Bt[3]){let n=Number(e);r.push([t|26,n>>>24&255,n>>>16&255,n>>>8&255,n&255])}else{let n=BigInt(e);if(n<Bt[4]){let o=[t|27,0,0,0,0,0,0,0],s=Number(n&BigInt(4294967295)),i=Number(n>>BigInt(32)&BigInt(4294967295));o[8]=s&255,s=s>>8,o[7]=s&255,s=s>>8,o[6]=s&255,s=s>>8,o[5]=s&255,o[4]=i&255,i=i>>8,o[3]=i&255,i=i>>8,o[2]=i&255,i=i>>8,o[1]=i&255,r.push(o)}else throw new Error(`${F} encountered BigInt larger than allowable range`)}}le.encodedSize=function(t){return Ct.encodedSize(t.value)};Ct.encodedSize=function(t){return t<Bt[0]?1:t<Bt[1]?2:t<Bt[2]?3:t<Bt[3]?5:9};le.compareTokens=function(t,e){return t.value<e.value?-1:t.value>e.value?1:0};function Ed(r,t,e,n){return new A(d.negint,-1-Qt(r,t+1,n),2)}function vd(r,t,e,n){return new A(d.negint,-1-te(r,t+1,n),3)}function Ad(r,t,e,n){return new A(d.negint,-1-ee(r,t+1,n),5)}var iu=BigInt(-1),Bd=BigInt(1);function kd(r,t,e,n){let o=re(r,t+1,n);if(typeof o!="bigint"){let s=-1-o;if(s>=Number.MIN_SAFE_INTEGER)return new A(d.negint,s,9)}if(n.allowBigInt!==!0)throw new Error(`${F} integers outside of the safe integer range are not supported`);return new A(d.negint,iu-BigInt(o),9)}function Ni(r,t){let e=t.value,n=typeof e=="bigint"?e*iu-Bd:e*-1-1;Ct(r,t.type.majorEncoded,n)}Ni.encodedSize=function(t){let e=t.value,n=typeof e=="bigint"?e*iu-Bd:e*-1-1;return n<Bt[0]?1:n<Bt[1]?2:n<Bt[2]?3:n<Bt[3]?5:9};Ni.compareTokens=function(t,e){return t.value<e.value?1:t.value>e.value?-1:0};function Uo(r,t,e,n){rr(r,t,e+n);let o=$n(r,t+e,t+e+n);return new A(d.bytes,o,e+n)}function Sd(r,t,e,n){return Uo(r,t,1,e)}function Id(r,t,e,n){return Uo(r,t,2,Qt(r,t+1,n))}function Rd(r,t,e,n){return Uo(r,t,3,te(r,t+1,n))}function _d(r,t,e,n){return Uo(r,t,5,ee(r,t+1,n))}function Td(r,t,e,n){let o=re(r,t+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer bytes lengths not supported`);return Uo(r,t,9,o)}function Ci(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===d.string?Ti(r.value):r.value),r.encodedBytes}function Kn(r,t){let e=Ci(t);Ct(r,t.type.majorEncoded,e.length),r.push(e)}Kn.encodedSize=function(t){let e=Ci(t);return Ct.encodedSize(e.length)+e.length};Kn.compareTokens=function(t,e){return ib(Ci(t),Ci(e))};function ib(r,t){return r.length<t.length?-1:r.length>t.length?1:yd(r,t)}function Do(r,t,e,n,o){let s=e+n;rr(r,t,s);let i=new A(d.string,dd(r,t+e,t+s),s);return o.retainStringBytes===!0&&(i.byteValue=$n(r,t+e,t+s)),i}function Nd(r,t,e,n){return Do(r,t,1,e,n)}function Cd(r,t,e,n){return Do(r,t,2,Qt(r,t+1,n),n)}function Ld(r,t,e,n){return Do(r,t,3,te(r,t+1,n),n)}function Ud(r,t,e,n){return Do(r,t,5,ee(r,t+1,n),n)}function Dd(r,t,e,n){let o=re(r,t+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer string lengths not supported`);return Do(r,t,9,o,n)}var Pd=Kn;function qn(r,t,e,n){return new A(d.array,n,e)}function Od(r,t,e,n){return qn(r,t,1,e)}function Fd(r,t,e,n){return qn(r,t,2,Qt(r,t+1,n))}function Vd(r,t,e,n){return qn(r,t,3,te(r,t+1,n))}function Md(r,t,e,n){return qn(r,t,5,ee(r,t+1,n))}function $d(r,t,e,n){let o=re(r,t+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer array lengths not supported`);return qn(r,t,9,o)}function Hd(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${F} indefinite length items not allowed`);return qn(r,t,1,1/0)}function Li(r,t){Ct(r,d.array.majorEncoded,t.value)}Li.compareTokens=le.compareTokens;Li.encodedSize=function(t){return Ct.encodedSize(t.value)};function zn(r,t,e,n){return new A(d.map,n,e)}function Kd(r,t,e,n){return zn(r,t,1,e)}function qd(r,t,e,n){return zn(r,t,2,Qt(r,t+1,n))}function zd(r,t,e,n){return zn(r,t,3,te(r,t+1,n))}function Gd(r,t,e,n){return zn(r,t,5,ee(r,t+1,n))}function jd(r,t,e,n){let o=re(r,t+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer map lengths not supported`);return zn(r,t,9,o)}function Wd(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${F} indefinite length items not allowed`);return zn(r,t,1,1/0)}function Ui(r,t){Ct(r,d.map.majorEncoded,t.value)}Ui.compareTokens=le.compareTokens;Ui.encodedSize=function(t){return Ct.encodedSize(t.value)};function Yd(r,t,e,n){return new A(d.tag,e,1)}function Zd(r,t,e,n){return new A(d.tag,Qt(r,t+1,n),2)}function Jd(r,t,e,n){return new A(d.tag,te(r,t+1,n),3)}function Xd(r,t,e,n){return new A(d.tag,ee(r,t+1,n),5)}function Qd(r,t,e,n){return new A(d.tag,re(r,t+1,n),9)}function Di(r,t){Ct(r,d.tag.majorEncoded,t.value)}Di.compareTokens=le.compareTokens;Di.encodedSize=function(t){return Ct.encodedSize(t.value)};var hb=20,db=21,pb=22,mb=23;function tp(r,t,e,n){if(n.allowUndefined===!1)throw new Error(`${F} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new A(d.null,null,1):new A(d.undefined,void 0,1)}function ep(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${F} indefinite length items not allowed`);return new A(d.break,void 0,1)}function au(r,t,e){if(e){if(e.allowNaN===!1&&Number.isNaN(r))throw new Error(`${F} NaN values are not supported`);if(e.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${F} Infinity values are not supported`)}return new A(d.float,r,t)}function rp(r,t,e,n){return au(cu(r,t+1),3,n)}function np(r,t,e,n){return au(uu(r,t+1),5,n)}function op(r,t,e,n){return au(cp(r,t+1),9,n)}function Pi(r,t,e){let n=t.value;if(n===!1)r.push([d.float.majorEncoded|hb]);else if(n===!0)r.push([d.float.majorEncoded|db]);else if(n===null)r.push([d.float.majorEncoded|pb]);else if(n===void 0)r.push([d.float.majorEncoded|mb]);else{let o,s=!1;(!e||e.float64!==!0)&&(ip(n),o=cu(ve,1),n===o||Number.isNaN(n)?(ve[0]=249,r.push(ve.slice(0,3)),s=!0):(ap(n),o=uu(ve,1),n===o&&(ve[0]=250,r.push(ve.slice(0,5)),s=!0))),s||(yb(n),o=cp(ve,1),ve[0]=251,r.push(ve.slice(0,9)))}}Pi.encodedSize=function(t,e){let n=t.value;if(n===!1||n===!0||n===null||n===void 0)return 1;if(!e||e.float64!==!0){ip(n);let o=cu(ve,1);if(n===o||Number.isNaN(n))return 3;if(ap(n),o=uu(ve,1),n===o)return 5}return 9};var sp=new ArrayBuffer(9),fe=new DataView(sp,1),ve=new Uint8Array(sp,0);function ip(r){if(r===1/0)fe.setUint16(0,31744,!1);else if(r===-1/0)fe.setUint16(0,64512,!1);else if(Number.isNaN(r))fe.setUint16(0,32256,!1);else{fe.setFloat32(0,r);let t=fe.getUint32(0),e=(t&2139095040)>>23,n=t&8388607;if(e===255)fe.setUint16(0,31744,!1);else if(e===0)fe.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let o=e-127;o<-24?fe.setUint16(0,0):o<-14?fe.setUint16(0,(t&2147483648)>>16|1<<24+o,!1):fe.setUint16(0,(t&2147483648)>>16|o+15<<10|n>>13,!1)}}}function cu(r,t){if(r.length-t<2)throw new Error(`${F} not enough data for float16`);let e=(r[t]<<8)+r[t+1];if(e===31744)return 1/0;if(e===64512)return-1/0;if(e===32256)return NaN;let n=e>>10&31,o=e&1023,s;return n===0?s=o*2**-24:n!==31?s=(o+1024)*2**(n-25):s=o===0?1/0:NaN,e&32768?-s:s}function ap(r){fe.setFloat32(0,r,!1)}function uu(r,t){if(r.length-t<4)throw new Error(`${F} not enough data for float32`);let e=(r.byteOffset||0)+t;return new DataView(r.buffer,e,4).getFloat32(0,!1)}function yb(r){fe.setFloat64(0,r,!1)}function cp(r,t){if(r.length-t<8)throw new Error(`${F} not enough data for float64`);let e=(r.byteOffset||0)+t;return new DataView(r.buffer,e,8).getFloat64(0,!1)}Pi.compareTokens=le.compareTokens;function tt(r,t,e){throw new Error(`${F} encountered invalid minor (${e}) for major ${r[t]>>>5}`)}function Oi(r){return()=>{throw new Error(`${F} ${r}`)}}var R=[];for(let r=0;r<=23;r++)R[r]=tt;R[24]=gd;R[25]=wd;R[26]=bd;R[27]=xd;R[28]=tt;R[29]=tt;R[30]=tt;R[31]=tt;for(let r=32;r<=55;r++)R[r]=tt;R[56]=Ed;R[57]=vd;R[58]=Ad;R[59]=kd;R[60]=tt;R[61]=tt;R[62]=tt;R[63]=tt;for(let r=64;r<=87;r++)R[r]=Sd;R[88]=Id;R[89]=Rd;R[90]=_d;R[91]=Td;R[92]=tt;R[93]=tt;R[94]=tt;R[95]=Oi("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)R[r]=Nd;R[120]=Cd;R[121]=Ld;R[122]=Ud;R[123]=Dd;R[124]=tt;R[125]=tt;R[126]=tt;R[127]=Oi("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)R[r]=Od;R[152]=Fd;R[153]=Vd;R[154]=Md;R[155]=$d;R[156]=tt;R[157]=tt;R[158]=tt;R[159]=Hd;for(let r=160;r<=183;r++)R[r]=Kd;R[184]=qd;R[185]=zd;R[186]=Gd;R[187]=jd;R[188]=tt;R[189]=tt;R[190]=tt;R[191]=Wd;for(let r=192;r<=215;r++)R[r]=Yd;R[216]=Zd;R[217]=Jd;R[218]=Xd;R[219]=Qd;R[220]=tt;R[221]=tt;R[222]=tt;R[223]=tt;for(let r=224;r<=243;r++)R[r]=Oi("simple values are not supported");R[244]=tt;R[245]=tt;R[246]=tt;R[247]=tp;R[248]=Oi("simple values are not supported");R[249]=rp;R[250]=np;R[251]=op;R[252]=tt;R[253]=tt;R[254]=tt;R[255]=ep;var Ae=[];for(let r=0;r<24;r++)Ae[r]=new A(d.uint,r,1);for(let r=-1;r>=-24;r--)Ae[31-r]=new A(d.negint,r,1);Ae[64]=new A(d.bytes,new Uint8Array(0),1);Ae[96]=new A(d.string,"",1);Ae[128]=new A(d.array,0,1);Ae[160]=new A(d.map,0,1);Ae[244]=new A(d.false,!1,1);Ae[245]=new A(d.true,!0,1);Ae[246]=new A(d.null,null,1);function up(r){switch(r.type){case d.false:return Le([244]);case d.true:return Le([245]);case d.null:return Le([246]);case d.bytes:return r.value.length?void 0:Le([64]);case d.string:return r.value===""?Le([96]):void 0;case d.array:return r.value===0?Le([128]):void 0;case d.map:return r.value===0?Le([160]):void 0;case d.uint:return r.value<24?Le([Number(r.value)]):void 0;case d.negint:if(r.value>=-24)return Le([31-Number(r.value)])}}var wb={float64:!1,mapSorter:Eb,quickEncodeToken:up};function bb(){let r=[];return r[d.uint.major]=le,r[d.negint.major]=Ni,r[d.bytes.major]=Kn,r[d.string.major]=Pd,r[d.array.major]=Li,r[d.map.major]=Ui,r[d.tag.major]=Di,r[d.float.major]=Pi,r}var lp=bb(),lu=new Co,Vi=class r{constructor(t,e){this.obj=t,this.parent=e}includes(t){let e=this;do if(e.obj===t)return!0;while(e=e.parent);return!1}static createCheck(t,e){if(t&&t.includes(e))throw new Error(`${Hn} object contains circular references`);return new r(e,t)}},Sr={null:new A(d.null,null),undefined:new A(d.undefined,void 0),true:new A(d.true,!0),false:new A(d.false,!1),emptyArray:new A(d.array,0),emptyMap:new A(d.map,0)},Ir={number(r,t,e,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new A(d.float,r):r>=0?new A(d.uint,r):new A(d.negint,r)},bigint(r,t,e,n){return r>=BigInt(0)?new A(d.uint,r):new A(d.negint,r)},Uint8Array(r,t,e,n){return new A(d.bytes,r)},string(r,t,e,n){return new A(d.string,r)},boolean(r,t,e,n){return r?Sr.true:Sr.false},null(r,t,e,n){return Sr.null},undefined(r,t,e,n){return Sr.undefined},ArrayBuffer(r,t,e,n){return new A(d.bytes,new Uint8Array(r))},DataView(r,t,e,n){return new A(d.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,t,e,n){if(!r.length)return e.addBreakTokens===!0?[Sr.emptyArray,new A(d.break)]:Sr.emptyArray;n=Vi.createCheck(n,r);let o=[],s=0;for(let i of r)o[s++]=Fi(i,e,n);return e.addBreakTokens?[new A(d.array,r.length),o,new A(d.break)]:[new A(d.array,r.length),o]},Object(r,t,e,n){let o=t!=="Object",s=o?r.keys():Object.keys(r),i=o?r.size:s.length;if(!i)return e.addBreakTokens===!0?[Sr.emptyMap,new A(d.break)]:Sr.emptyMap;n=Vi.createCheck(n,r);let a=[],c=0;for(let u of s)a[c++]=[Fi(u,e,n),Fi(o?r.get(u):r[u],e,n)];return xb(a,e),e.addBreakTokens?[new A(d.map,i),a,new A(d.break)]:[new A(d.map,i),a]}};Ir.Map=Ir.Object;Ir.Buffer=Ir.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))Ir[`${r}Array`]=Ir.DataView;function Fi(r,t={},e){let n=ud(r),o=t&&t.typeEncoders&&t.typeEncoders[n]||Ir[n];if(typeof o=="function"){let i=o(r,n,t,e);if(i!=null)return i}let s=Ir[n];if(!s)throw new Error(`${Hn} unsupported type: ${n}`);return s(r,n,t,e)}function xb(r,t){t.mapSorter&&r.sort(t.mapSorter)}function Eb(r,t){let e=Array.isArray(r[0])?r[0][0]:r[0],n=Array.isArray(t[0])?t[0][0]:t[0];if(e.type!==n.type)return e.type.compare(n.type);let o=e.type.major,s=lp[o].compareTokens(e,n);return s===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),s}function fp(r,t,e,n){if(Array.isArray(t))for(let o of t)fp(r,o,e,n);else e[t.type.major](r,t,n)}function hp(r,t,e){let n=Fi(r,e);if(!Array.isArray(n)&&e.quickEncodeToken){let o=e.quickEncodeToken(n);if(o)return o;let s=t[n.type.major];if(s.encodedSize){let i=s.encodedSize(n,e),a=new Co(i);if(s(a,n,e),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return No(a.chunks[0])}}return lu.reset(),fp(lu,n,t,e),lu.toBytes(!0)}function Gn(r,t){return t=Object.assign({},wb,t),hp(r,lp,t)}var vb={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},Mi=class{constructor(t,e={}){this._pos=0,this.data=t,this.options=e}pos(){return this._pos}done(){return this._pos>=this.data.length}next(){let t=this.data[this._pos],e=Ae[t];if(e===void 0){let n=R[t];if(!n)throw new Error(`${F} no decoder for major type ${t>>>5} (byte 0x${t.toString(16).padStart(2,"0")})`);let o=t&31;e=n(this.data,this._pos,o,this.options)}return this._pos+=e.encodedLength,e}},Po=Symbol.for("DONE"),$i=Symbol.for("BREAK");function Ab(r,t,e){let n=[];for(let o=0;o<r.value;o++){let s=jn(t,e);if(s===$i){if(r.value===1/0)break;throw new Error(`${F} got unexpected break to lengthed array`)}if(s===Po)throw new Error(`${F} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=s}return n}function Bb(r,t,e){let n=e.useMaps===!0,o=n?void 0:{},s=n?new Map:void 0;for(let i=0;i<r.value;i++){let a=jn(t,e);if(a===$i){if(r.value===1/0)break;throw new Error(`${F} got unexpected break to lengthed map`)}if(a===Po)throw new Error(`${F} found map but not enough entries (got ${i} [no key], expected ${r.value})`);if(n!==!0&&typeof a!="string")throw new Error(`${F} non-string keys not supported (got ${typeof a})`);if(e.rejectDuplicateMapKeys===!0&&(n&&s.has(a)||!n&&a in o))throw new Error(`${F} found repeat map key "${a}"`);let c=jn(t,e);if(c===Po)throw new Error(`${F} found map but not enough entries (got ${i} [no value], expected ${r.value})`);n?s.set(a,c):o[a]=c}return n?s:o}function jn(r,t){if(r.done())return Po;let e=r.next();if(e.type===d.break)return $i;if(e.type.terminal)return e.value;if(e.type===d.array)return Ab(e,r,t);if(e.type===d.map)return Bb(e,r,t);if(e.type===d.tag){if(t.tags&&typeof t.tags[e.value]=="function"){let n=jn(r,t);return t.tags[e.value](n)}throw new Error(`${F} tag not supported (${e.value})`)}throw new Error("unsupported")}function fu(r,t){if(!(r instanceof Uint8Array))throw new Error(`${F} data to decode must be a Uint8Array`);t=Object.assign({},vb,t);let e=t.tokenizer||new Mi(r,t),n=jn(e,t);if(n===Po)throw new Error(`${F} did not find any content to decode`);if(n===$i)throw new Error(`${F} got unexpected break`);return[n,r.subarray(e.pos())]}function he(r,t){let[e,n]=fu(r,t);if(n.length>0)throw new Error(`${F} too many terminals, data makes no sense`);return e}var ne=oe(hn(),1);var dp=Jt("ipns:utils"),pp=Y("/ipns/"),kb=114,mp=async(r,t)=>{if(t==null||r==null){let n=new Error("one or more of the provided parameters are not defined");throw dp.error(n),(0,ne.default)(n,ou)}let e;if(t.pubKey!=null){try{e=eu(t.pubKey)}catch(o){throw dp.error(o),o}if(!(await pf(t.pubKey)).equals(r))throw(0,ne.default)(new Error("Embedded public key did not match PeerID"),id)}else r.publicKey!=null&&(e=eu(r.publicKey));if(e!=null)return e;throw(0,ne.default)(new Error("no public key is available"),ou)};var yp=r=>{let t=Y("ipns-signature:");return Ft([t,r])},Yr=r=>"signatureV1"in r?Ee.encode({value:Y(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:Y(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):Ee.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data});function Ue(r){let t=Ee.decode(r);if(t.sequence!=null&&(t.sequence=BigInt(t.sequence)),t.ttl!=null&&(t.ttl=BigInt(t.ttl)),t.signatureV2==null||t.data==null)throw(0,ne.default)(new Error("missing data or signatureV2"),er);let e=gp(t.data),n=Sb(e.Value),o=z(e.Validity);if(t.value!=null&&t.signatureV1!=null)return Ib(t),{value:n,validityType:Ee.ValidityType.EOL,validity:o,sequence:e.Sequence,ttl:e.TTL,pubKey:t.pubKey,signatureV1:t.signatureV1,signatureV2:t.signatureV2,data:t.data};if(t.signatureV2!=null)return{value:n,validityType:Ee.ValidityType.EOL,validity:o,sequence:e.Sequence,ttl:e.TTL,pubKey:t.pubKey,signatureV2:t.signatureV2,data:t.data};throw new Error("invalid record: does not include signatureV1 or signatureV2")}var hu=r=>Ft([pp,r.toBytes()]),Wn=r=>lo(r.slice(pp.length));var gp=r=>{let t=he(r);if(t.ValidityType===0)t.ValidityType=Ee.ValidityType.EOL;else throw(0,ne.default)(new Error("Unknown validity type"),Ri);return Number.isInteger(t.Sequence)&&(t.Sequence=BigInt(t.Sequence)),Number.isInteger(t.TTL)&&(t.TTL=BigInt(t.TTL)),t},Sb=r=>{if(r!=null){if(Ju(r))return`/ipns/${r.toCID().toString(lr)}`;if(r instanceof Uint8Array){let n=z(r);n.startsWith("/")&&(r=n)}let t=r.toString().trim();if(t.startsWith("/")&&t.length>1)return t;let e=ot.asCID(r);if(e!=null)return e.code===kb?`/ipns/${e.toString(lr)}`:`/ipfs/${e.toV1().toString()}`;try{return r instanceof Uint8Array?`/ipfs/${ot.decode(r).toV1().toString()}`:`/ipfs/${ot.parse(t).toV1().toString()}`}catch{}}throw(0,ne.default)(new Error("Value must be a valid content path starting with /"),sd)},Ib=r=>{if(r.data==null)throw(0,ne.default)(new Error("Record data is missing"),od);let t=gp(r.data);if(!ct(t.Value,r.value??new Uint8Array(0)))throw(0,ne.default)(new Error('Field "value" did not match between protobuf and CBOR'),er);if(!ct(t.Validity,r.validity??new Uint8Array(0)))throw(0,ne.default)(new Error('Field "validity" did not match between protobuf and CBOR'),er);if(t.ValidityType!==r.validityType)throw(0,ne.default)(new Error('Field "validityType" did not match between protobuf and CBOR'),er);if(t.Sequence!==r.sequence)throw(0,ne.default)(new Error('Field "sequence" did not match between protobuf and CBOR'),er);if(t.TTL!==r.ttl)throw(0,ne.default)(new Error('Field "ttl" did not match between protobuf and CBOR'),er)};var Z8=Jt("ipns"),J8=ie.code,X8=60*60*1e9,Tb="/ipns/",Q8=Tb.length;var Oo=oe(hn(),1),wp=oe(nu(),1);var Ki=Jt("ipns:validator"),Nb=1024*10,Cb=async(r,t)=>{let e=Ue(t),n;try{let o=yp(e.data);n=await r.verify(o,e.signatureV2)}catch{n=!1}if(!n)throw Ki.error("record signature verification failed"),(0,Oo.default)(new Error("record signature verification failed"),er);if(e.validityType===Ee.ValidityType.EOL){if(wp.default.fromString(e.validity).toDate().getTime()<Date.now())throw Ki.error("record has expired"),(0,Oo.default)(new Error("record has expired"),nd)}else if(e.validityType!=null)throw Ki.error("unrecognized validity type"),(0,Oo.default)(new Error("unrecognized validity type"),Ri);Ki("ipns record for %s is valid",e.value)};async function bp(r,t){if(t.byteLength>Nb)throw(0,Oo.default)(new Error("record too large"),ad);let e=Wn(r),n=Ue(t),o=await mp(e,n);await Cb(o,t)}async function*Fo(r){let t=/\r?\n/,e=new TextDecoder("utf8"),n="";for await(let o of r){typeof o=="string"&&(o=new TextEncoder().encode(o)),n+=e.decode(o,{stream:!0});let s=n.split(t);n=s.pop()??"";for(let i=0;i<s.length;i++)yield JSON.parse(s[i])}n+=e.decode(),n!==""&&(yield JSON.parse(n))}var pu=oe(Ep(),1);var Mo=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},mu=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},vp=r=>globalThis.DOMException===void 0?new mu(r):new DOMException(r),Ap=r=>{let t=r.reason===void 0?vp("This operation was aborted."):r.reason;return t instanceof Error?t:vp(t)};function $o(r,t){let{milliseconds:e,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout}}=t,i,c=new Promise((u,l)=>{if(typeof e!="number"||Math.sign(e)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${e}\``);if(t.signal){let{signal:h}=t;h.aborted&&l(Ap(h)),h.addEventListener("abort",()=>{l(Ap(h))})}if(e===Number.POSITIVE_INFINITY){r.then(u,l);return}let f=new Mo;i=s.setTimeout.call(void 0,()=>{if(n){try{u(n())}catch(h){l(h)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?u():o instanceof Error?l(o):(f.message=o??`Promise timed out after ${e} milliseconds`,l(f))},e),(async()=>{try{u(await r)}catch(h){l(h)}})()}).finally(()=>{c.clear()});return c.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},c}function yu(r,t,e){let n=0,o=r.length;for(;o>0;){let s=Math.trunc(o/2),i=n+s;e(r[i],t)<=0?(n=++i,o-=s+1):o=s}return n}var Ho=class{#t=[];enqueue(t,e){e={priority:0,...e};let n={priority:e.priority,run:t};if(this.size&&this.#t[this.size-1].priority>=e.priority){this.#t.push(n);return}let o=yu(this.#t,n,(s,i)=>i.priority-s.priority);this.#t.splice(o,0,n)}dequeue(){return this.#t.shift()?.run}filter(t){return this.#t.filter(e=>e.priority===t.priority).map(e=>e.run)}get size(){return this.#t.length}};var De=class extends pu.default{#t;#e;#r=0;#i;#c;#p=0;#o;#u;#n;#m;#s=0;#l;#a;#y;timeout;constructor(t){if(super(),t={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:Ho,...t},!(typeof t.intervalCap=="number"&&t.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${t.intervalCap?.toString()??""}\` (${typeof t.intervalCap})`);if(t.interval===void 0||!(Number.isFinite(t.interval)&&t.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${t.interval?.toString()??""}\` (${typeof t.interval})`);this.#t=t.carryoverConcurrencyCount,this.#e=t.intervalCap===Number.POSITIVE_INFINITY||t.interval===0,this.#i=t.intervalCap,this.#c=t.interval,this.#n=new t.queueClass,this.#m=t.queueClass,this.concurrency=t.concurrency,this.timeout=t.timeout,this.#y=t.throwOnTimeout===!0,this.#a=t.autoStart===!1}get#b(){return this.#e||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 t=Date.now();if(this.#o===void 0){let e=this.#p-t;if(e<0)this.#r=this.#t?this.#s:0;else return this.#u===void 0&&(this.#u=setTimeout(()=>{this.#v()},e)),!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 t=!this.#A;if(this.#b&&this.#x){let e=this.#n.dequeue();return e?(this.emit("active"),e(),t&&this.#g(),!0):!1}}return!1}#g(){this.#e||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.#t?this.#s:0,this.#h()}#h(){for(;this.#f(););}get concurrency(){return this.#l}set concurrency(t){if(!(typeof t=="number"&&t>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${t}\` (${typeof t})`);this.#l=t,this.#h()}async#B(t){return new Promise((e,n)=>{t.addEventListener("abort",()=>{n(t.reason)},{once:!0})})}async add(t,e={}){return e={timeout:this.timeout,throwOnTimeout:this.#y,...e},new Promise((n,o)=>{this.#n.enqueue(async()=>{this.#s++,this.#r++;try{e.signal?.throwIfAborted();let s=t({signal:e.signal});e.timeout&&(s=$o(Promise.resolve(s),{milliseconds:e.timeout})),e.signal&&(s=Promise.race([s,this.#B(e.signal)]));let i=await s;n(i),this.emit("completed",i)}catch(s){if(s instanceof Mo&&!e.throwOnTimeout){n();return}o(s),this.emit("error",s)}finally{this.#E()}},e),this.emit("add"),this.#f()})}async addAll(t,e){return Promise.all(t.map(async n=>this.add(n,e)))}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(t){this.#n.size<t||await this.#d("next",()=>this.#n.size<t)}async onIdle(){this.#s===0&&this.#n.size===0||await this.#d("idle")}async#d(t,e){return new Promise(n=>{let o=()=>{e&&!e()||(this.off(t,o),n())};this.on(t,o)})}get size(){return this.#n.size}sizeBy(t){return this.#n.filter(t).length}get pending(){return this.#s}get isPaused(){return this.#a}};function Db(r){return r[Symbol.asyncIterator]!=null}function Pb(r){if(Db(r))return(async()=>{for await(let t of r)return t})();for(let t of r)return t}var zi=Pb;var gu=Y("/ipns/");function Bp(r){return ct(r.subarray(0,gu.byteLength),gu)}var kp=r=>lo(r.slice(gu.length)),Gi=class{client;constructor(t){this.client=t}async*findProviders(t,e={}){yield*pn(this.client.getProviders(t,e),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async put(t,e,n){if(!Bp(t))return;let o=kp(t),s=Ue(e);await this.client.putIPNS(o,s,n)}async get(t,e){if(!Bp(t))throw new N("Not found","ERR_NOT_FOUND");let n=kp(t);try{let o=await this.client.getIPNS(n,e);return Yr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new N("Not found","ERR_NOT_FOUND"):o}}},ji=class{client;constructor(t){this.client=t}async findPeer(t,e={}){let n=await zi(this.client.getPeers(t,e));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new N("Not found","ERR_NOT_FOUND")}async*getClosestPeers(t,e={}){}};var zt=Jt("delegated-routing-v1-http-api-client"),Sp={concurrentRequests:4,timeout:3e4},Wi=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;constructor(t,e={}){this.started=!1,this.shutDownController=new AbortController,se(1/0,this.shutDownController.signal),this.httpQueue=new De({concurrency:e.concurrentRequests??Sp.concurrentRequests}),this.clientUrl=t instanceof URL?t:new URL(t),this.timeout=e.timeout??Sp.timeout,this.contentRouting=new Gi(this),this.peerRouting=new ji(this)}get[Qn](){return this.contentRouting}get[to](){return this.peerRouting}isStarted(){return this.started}start(){this.started=!0}stop(){this.httpQueue.clear(),this.shutDownController.abort(),this.started=!1}async*getProviders(t,e={}){zt("getProviders starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=Nr([this.shutDownController.signal,n,e.signal]);se(1/0,n,o);let s=It(),i=It();this.httpQueue.add(async()=>(s.resolve(),i.promise));try{await s.promise;let a=`${this.clientUrl}routing/v1/providers/${t.toString()}`,u=await fetch(a,{headers:{Accept:"application/x-ndjson"},signal:o});if(u.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new N("Routing response had no body","ERR_BAD_RESPONSE");if(u.headers.get("Content-Type")==="application/json"){let f=await u.json();for(let h of f.Providers){let g=this.#t(h);g!=null&&(yield g)}}else for await(let f of Fo(Es(u.body))){let h=this.#t(f);h!=null&&(yield h)}}catch(a){zt.error("getProviders errored:",a)}finally{o.clear(),i.resolve(),zt("getProviders finished: %c",t)}}async*getPeers(t,e={}){zt("getPeers starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=Nr([this.shutDownController.signal,n,e.signal]);se(1/0,n,o);let s=It(),i=It();this.httpQueue.add(async()=>(s.resolve(),i.promise));try{await s.promise;let a=`${this.clientUrl}routing/v1/peers/${t.toCID().toString()}`,u=await fetch(a,{headers:{Accept:"application/x-ndjson"},signal:o});if(u.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new N("Routing response had no body","ERR_BAD_RESPONSE");if(u.headers.get("Content-Type")==="application/json"){let f=await u.json();for(let h of f.Peers){let g=this.#t(h);g!=null&&(yield g)}}else for await(let f of Fo(Es(u.body))){let h=this.#t(f);h!=null&&(yield h)}}catch(a){zt.error("getPeers errored:",a)}finally{o.clear(),i.resolve(),zt("getPeers finished: %c",t)}}async getIPNS(t,e={}){zt("getIPNS starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=Nr([this.shutDownController.signal,n,e.signal]);se(1/0,n,o);let s=It(),i=It();this.httpQueue.add(async()=>(s.resolve(),i.promise));let a=`${this.clientUrl}routing/v1/ipns/${t.toCID().toString()}`;try{await s.promise;let u=await fetch(a,{headers:{Accept:"application/vnd.ipfs.ipns-record"},signal:o});if(zt("getIPNS GET %s %d",a,u.status),u.status===404)throw new N("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new N("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new N("GET ipns response had no body","ERR_BAD_RESPONSE");let l=await u.arrayBuffer(),f=new Uint8Array(l,0,l.byteLength);return e.validate!==!1&&await bp(hu(t),f),Ue(f)}catch(c){throw zt.error("getIPNS GET %s error:",a,c),c}finally{o.clear(),i.resolve(),zt("getIPNS finished: %c",t)}}async putIPNS(t,e,n={}){zt("putIPNS starts: %c",t);let o=AbortSignal.timeout(this.timeout),s=Nr([this.shutDownController.signal,o,n.signal]);se(1/0,o,s);let i=It(),a=It();this.httpQueue.add(async()=>(i.resolve(),a.promise));let c=`${this.clientUrl}routing/v1/ipns/${t.toCID().toString()}`;try{await i.promise;let u=Yr(e),f=await fetch(c,{method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:u,signal:s});if(zt("putIPNS PUT %s %d",c,f.status),f.status!==200)throw new N("PUT ipns response had status other than 200","ERR_BAD_RESPONSE")}catch(u){throw zt.error("putIPNS PUT %s error:",c,u.stack),u}finally{s.clear(),a.resolve(),zt("putIPNS finished: %c",t)}}#t(t){let e=[],n=t.Addrs?.map(Dr)??[];return t.Protocols!=null&&e.push(...t.Protocols),t.Protocol!=null&&(e.push(t.Protocol),delete t.Protocol),{...t,Schema:"peer",ID:xc(t.ID),Addrs:n,Protocols:e}}};function Ip(r,t={}){return new Wi(new URL(r),t)}var Rp=Y("/ipns/");function _p(r){return ct(r.subarray(0,Rp.byteLength),Rp)}var wu=class{client;constructor(t){this.client=Ip(t)}async provide(t,e){}async*findProviders(t,e){yield*pn(this.client.getProviders(t,e),n=>({id:n.ID,multiaddrs:n.Addrs,protocols:n.Protocols}))}async put(t,e,n){if(!_p(t))return;let o=Wn(t),s=Ue(e);await this.client.putIPNS(o,s,n)}async get(t,e){if(!_p(t))throw new N("Not found","ERR_NOT_FOUND");let n=Wn(t);try{let o=await this.client.getIPNS(n,e);return Yr(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new N("Not found","ERR_NOT_FOUND"):o}}async findPeer(t,e){let n=await zi(this.client.getPeers(t,e));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new N("Not found","ERR_NOT_FOUND")}async*getClosestPeers(t,e){}};function bu(r){return new wu(new URL(r))}function Yi(r){let t=[Be.A];return r==null?t:Array.isArray(r)?r.length===0?t:r:[r]}var xu=60;function Zi(r){return{Status:r.Status??0,TC:r.TC??r.flag_tc??!1,RD:r.RD??r.flag_rd??!1,RA:r.RA??r.flag_ra??!1,AD:r.AD??r.flag_ad??!1,CD:r.CD??r.flag_cd??!1,Question:(r.Question??r.questions??[]).map(t=>({name:t.name,type:Be[t.type]})),Answer:(r.Answer??r.answers??[]).map(t=>({name:t.name,type:Be[t.type],TTL:t.TTL??t.ttl??xu,data:t.data instanceof Uint8Array?z(t.data):t.data}))}}var Ob=4;function Eu(r,t={}){let e=new De({concurrency:t.queryConcurrency??Ob});return async(n,o={})=>{let s=new URLSearchParams;s.set("name",n),Yi(o.types).forEach(a=>{s.append("type",Be[a])}),o.onProgress?.(new nt("dns:query",{detail:n}));let i=await e.add(async()=>{let a=await fetch(`${r}?${s}`,{headers:{accept:"application/dns-json"},signal:o?.signal});if(a.status!==200)throw new Error(`Unexpected HTTP status: ${a.status} - ${a.statusText}`);let c=Zi(await a.json());return o.onProgress?.(new nt("dns:response",{detail:c})),c},{signal:o.signal});if(i==null)throw new Error("No DNS response received");return i}}function Tp(){return[Eu("https://cloudflare-dns.com/dns-query"),Eu("https://dns.google/resolve")]}var Lp=oe(Cp(),1);var vu=class{lru;constructor(t){this.lru=(0,Lp.default)(t)}get(t,e){let n=!0,o=[];for(let s of e){let i=this.getAnswers(t,s);if(i.length===0){n=!1;break}o.push(...i)}if(n)return Zi({answers:o})}getAnswers(t,e){let n=`${t.toLowerCase()}-${e}`,o=this.lru.get(n);if(o!=null){let s=o.filter(i=>i.expires>Date.now()).map(({expires:i,value:a})=>({...a,TTL:Math.round((i-Date.now())/1e3),type:Be[a.type]}));return s.length===0&&this.lru.remove(n),s}return[]}add(t,e){let n=`${t.toLowerCase()}-${e.type}`,o=this.lru.get(n)??[];o.push({expires:Date.now()+(e.TTL??xu)*1e3,value:e}),this.lru.set(n,o)}remove(t,e){let n=`${t.toLowerCase()}-${e}`;this.lru.remove(n)}clear(){this.lru.clear()}};function Up(r){return new vu(r)}var Fb=1e3,Ji=class{resolvers;cache;constructor(t){this.resolvers={},this.cache=Up(t.cacheSize??Fb),Object.entries(t.resolvers??{}).forEach(([e,n])=>{Array.isArray(n)||(n=[n]),e.endsWith(".")||(e=`${e}.`),this.resolvers[e]=n}),this.resolvers["."]==null&&(this.resolvers["."]=Tp())}async query(t,e={}){let n=Yi(e.types),o=e.cached!==!1?this.cache.get(t,n):void 0;if(o!=null)return e.onProgress?.(new nt("dns:cache",{detail:o})),o;let s=`${t.split(".").pop()}.`,i=(this.resolvers[s]??this.resolvers["."]).sort(()=>Math.random()>.5?-1:1),a=[];for(let c of i){if(e.signal?.aborted===!0)break;try{let u=await c(t,{...e,types:n});for(let l of u.Answer)this.cache.add(t,l);return u}catch(u){a.push(u),e.onProgress?.(new nt("dns:error",{detail:u}))}}throw a.length===1?a[0]:new AggregateError(a,`DNS lookup of ${t} ${n} failed`)}};var Be;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(Be||(Be={}));function Dp(r={}){return new Ji(r)}var Vp="/pin/",Pp="/pinned-block/",Au=lr,Op=1;function Fp(r){return r.version===0&&(r=r.toV1()),new Nt(`${Vp}${r.toString(Au)}`)}var Xi=class{datastore;blockstore;dagWalkers;constructor(t,e,n){this.datastore=t,this.blockstore=e,this.dagWalkers=n}async*add(t,e={}){let n=Fp(t);if(await this.datastore.has(n))throw new Error("Already pinned");let o=Math.round(e.depth??1/0);if(o<0)throw new Error("Depth must be greater than or equal to 0");let s=new Lr({concurrency:Op});for await(let a of this.#t(t,s,{...e,depth:o}))await this.#e(a,c=>c.pinnedBy.find(u=>ct(u,t.bytes))!=null?!1:(c.pinCount++,c.pinnedBy.push(t.bytes),!0),e),yield a;let i={depth:o,metadata:e.metadata??{}};await this.datastore.put(n,Gn(i),e)}async*#t(t,e,n){if(n.depth===-1)return;let o=this.dagWalkers[t.code];if(o==null)throw new Error(`No dag walker found for cid codec ${t.code}`);let s=await this.blockstore.get(t,n);yield t;for await(let i of o.walk(s))yield*await e.add(async()=>this.#t(i,e,{...n,depth:n.depth-1}))}async#e(t,e,n){let o=new Nt(`${Pp}${Au.encode(t.multihash.bytes)}`),s={pinCount:0,pinnedBy:[]};try{s=he(await this.datastore.get(o,n))}catch(a){if(a.code!=="ERR_NOT_FOUND")throw a}if(e(s)){if(s.pinCount===0&&await this.datastore.has(o)){await this.datastore.delete(o);return}await this.datastore.put(o,Gn(s),n),n.onProgress?.(new nt("helia:pin:add",t))}}async*rm(t,e={}){let n=Fp(t),o=await this.datastore.get(n,e),s=he(o);await this.datastore.delete(n,e);let i=new Lr({concurrency:Op});for await(let a of this.#t(t,i,{...e,depth:s.depth}))await this.#e(a,c=>(c.pinCount--,c.pinnedBy=c.pinnedBy.filter(u=>ct(u,t.bytes)),!0),{...e,depth:s.depth}),yield a}async*ls(t={}){for await(let{key:e,value:n}of this.datastore.query({prefix:Vp+(t.cid!=null?`${t.cid.toString(lr)}`:"")},t)){let o=ot.parse(e.toString().substring(5),lr),s=he(n);yield{cid:o,...s}}}async isPinned(t,e={}){let n=new Nt(`${Pp}${Au.encode(t.multihash.bytes)}`);return this.datastore.has(n,e)}};var Qi=class{log;routers;constructor(t,e){this.log=t.logger.forComponent("helia:routing"),this.routers=e.routers??[]}async start(){await ar(...this.routers)}async stop(){await cr(...this.routers)}async*findProviders(t,e={}){if(this.routers.length===0)throw new N("No content routers available","ERR_NO_ROUTERS_AVAILABLE");for await(let n of Fr(...Yn(this.routers,"findProviders").map(o=>o.findProviders(t,e))))n!=null&&(yield n)}async provide(t,e={}){if(this.routers.length===0)throw new N("No content routers available","ERR_NO_ROUTERS_AVAILABLE");await Promise.all(Yn(this.routers,"provide").map(async n=>{await n.provide(t,e)}))}async put(t,e,n){await Promise.all(Yn(this.routers,"put").map(async o=>{await o.put(t,e,n)}))}async get(t,e){return Promise.any(Yn(this.routers,"get").map(async n=>n.get(t,e)))}async findPeer(t,e){if(this.routers.length===0)throw new N("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");let n=this,o=Fr(...Yn(this.routers,"findPeer").map(s=>async function*(){try{yield await s.findPeer(t,e)}catch(i){n.log.error(i)}}()));for await(let s of o)if(s!=null)return s;throw new N("Could not find peer in routing","ERR_NOT_FOUND")}async*getClosestPeers(t,e={}){if(this.routers.length===0)throw new N("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");for await(let n of Fr(...Yn(this.routers,"getClosestPeers").map(o=>o.getClosestPeers(t,e))))n!=null&&(yield n)}};function Yn(r,t){return r.filter(e=>e[t]!=null)}var Rr={},Zn=r=>{r.addEventListener("message",t=>{Zn.dispatchEvent("message",r,t)}),r.port!=null&&r.port.addEventListener("message",t=>{Zn.dispatchEvent("message",r,t)})};Zn.addEventListener=(r,t)=>{Rr[r]==null&&(Rr[r]=[]),Rr[r].push(t)};Zn.removeEventListener=(r,t)=>{Rr[r]!=null&&(Rr[r]=Rr[r].filter(e=>e===t))};Zn.dispatchEvent=function(r,t,e){Rr[r]!=null&&Rr[r].forEach(n=>n(t,e))};var Bu=Zn;var ku="lock:worker:request-read",Su="lock:worker:release-read",Iu="lock:master:grant-read",Ru="lock:worker:request-write",_u="lock:worker:release-write",Tu="lock:master:grant-write";var Mp=(r=21)=>Math.random().toString().substring(2);var $p=(r,t,e,n,o)=>(s,i)=>{if(i.data.type!==e)return;let a={type:i.data.type,name:i.data.name,identifier:i.data.identifier};r.dispatchEvent(new MessageEvent(t,{data:{name:a.name,handler:async()=>{s.postMessage({type:o,name:a.name,identifier:a.identifier}),await new Promise(c=>{let u=l=>{if(l==null||l.data==null)return;let f={type:l.data.type,name:l.data.name,identifier:l.data.identifier};f.type===n&&f.identifier===a.identifier&&(s.removeEventListener("message",u),c())};s.addEventListener("message",u)})}}}))},Hp=(r,t,e,n)=>async()=>{let o=Mp();return globalThis.postMessage({type:t,identifier:o,name:r}),new Promise(s=>{let i=a=>{if(a==null||a.data==null)return;let c={type:a.data.type,identifier:a.data.identifier};c.type===e&&c.identifier===o&&(globalThis.removeEventListener("message",i),s(()=>{globalThis.postMessage({type:n,identifier:o,name:r})}))};globalThis.addEventListener("message",i)})},Vb={singleProcess:!1},Kp=r=>{if(r=Object.assign({},Vb,r),!!globalThis.document||r.singleProcess){let e=new EventTarget;return Bu.addEventListener("message",$p(e,"requestReadLock",ku,Su,Iu)),Bu.addEventListener("message",$p(e,"requestWriteLock",Ru,_u,Tu)),e}return{isWorker:!0,readLock:e=>Hp(e,ku,Iu,Su),writeLock:e=>Hp(e,Ru,Tu,_u)}};var Zr={},_r;async function Nu(r,t){let e,n=new Promise(o=>{e=o});return r.add(async()=>$o((async()=>{await new Promise(o=>{e(()=>{o()})})})(),{milliseconds:t.timeout})),n}var Mb=(r,t)=>{if(_r.isWorker===!0)return{readLock:_r.readLock(r,t),writeLock:_r.writeLock(r,t)};let e=new De({concurrency:1}),n;return{async readLock(){if(n!=null)return Nu(n,t);n=new De({concurrency:t.concurrency,autoStart:!1});let o=n,s=Nu(n,t);return e.add(async()=>{o.start(),await o.onIdle().then(()=>{n===o&&(n=null)})}),s},async writeLock(){return n=null,Nu(e,t)}}},$b={name:"lock",concurrency:1/0,timeout:846e5,singleProcess:!1};function Cu(r){let t=Object.assign({},$b,r);return _r==null&&(_r=Kp(t),_r.isWorker!==!0&&(_r.addEventListener("requestReadLock",e=>{Zr[e.data.name]!=null&&Zr[e.data.name].readLock().then(async n=>e.data.handler().finally(()=>{n()}))}),_r.addEventListener("requestWriteLock",async e=>{Zr[e.data.name]!=null&&Zr[e.data.name].writeLock().then(async n=>e.data.handler().finally(()=>{n()}))}))),Zr[t.name]==null&&(Zr[t.name]=Mb(t.name,t)),Zr[t.name]}var ta=class{lock;child;pins;started;constructor(t,e,n={}){this.child=t,this.pins=e,this.lock=Cu({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await ar(this.child),this.started=!0}async stop(){await cr(this.child),this.started=!1}unwrap(){return this.child}async put(t,e,n={}){let o=await this.lock.readLock();try{return await this.child.put(t,e,n)}finally{o()}}async*putMany(t,e={}){let n=await this.lock.readLock();try{yield*this.child.putMany(t,e)}finally{n()}}async get(t,e={}){let n=await this.lock.readLock();try{return await this.child.get(t,e)}finally{n()}}async*getMany(t,e={}){let n=await this.lock.readLock();try{yield*this.child.getMany(t,e)}finally{n()}}async delete(t,e={}){let n=await this.lock.writeLock();try{if(await this.pins.isPinned(t))throw new Error("CID was pinned");await this.child.delete(t,e)}finally{n()}}async*deleteMany(t,e={}){let n=await this.lock.writeLock();try{let o=this;yield*this.child.deleteMany(async function*(){for await(let s of t){if(await o.pins.isPinned(s))throw new Error("CID was pinned");yield s}}(),e)}finally{n()}}async has(t,e={}){let n=await this.lock.readLock();try{return await this.child.has(t,e)}finally{n()}}async*getAll(t={}){let e=await this.lock.readLock();try{yield*this.child.getAll(t)}finally{e()}}async createSession(t,e){let n=await this.lock.readLock();try{let o=await this.child.createSession(t,e);if(o==null)throw new N("Sessions not supported","ERR_UNSUPPORTED");return o}finally{n()}}};var zp=42;function Hb(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let t=ot.asCID(r);if(!t)return null;let e=new Uint8Array(t.bytes.byteLength+1);return e.set(t.bytes,1),[new A(d.tag,zp),new A(d.bytes,e)]}function Kb(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function qb(r){if(Number.isNaN(r))throw new Error("`NaN` is not supported by the IPLD Data Model and cannot be encoded");if(r===1/0||r===-1/0)throw new Error("`Infinity` and `-Infinity` is not supported by the IPLD Data Model and cannot be encoded");return null}var qp={float64:!0,typeEncoders:{Object:Hb,undefined:Kb,number:qb}},r6={...qp,typeEncoders:{...qp.typeEncoders}};function zb(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return ot.decode(r.subarray(1))}var Lu={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Lu.tags[zp]=zb;var n6={...Lu,tags:Lu.tags.slice()};var Gp=113;var jp=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(t){let e=this.inRecursive[this.inRecursive.length-1];e&&(e.type===d.array&&(e.elements++,e.elements!==1&&t.push([44])),e.type===d.map&&(e.elements++,e.elements!==1&&(e.elements%2===1?t.push([44]):t.push([58]))))}[d.uint.major](t,e){this.prefix(t);let n=String(e.value),o=[];for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);t.push(o)}[d.negint.major](t,e){this[d.uint.major](t,e)}[d.bytes.major](t,e){throw new Error(`${Hn} unsupported type: Uint8Array`)}[d.string.major](t,e){this.prefix(t);let n=Ti(JSON.stringify(e.value));t.push(n.length>32?No(n):n)}[d.array.major](t,e){this.prefix(t),this.inRecursive.push({type:d.array,elements:0}),t.push([91])}[d.map.major](t,e){this.prefix(t),this.inRecursive.push({type:d.map,elements:0}),t.push([123])}[d.tag.major](t,e){}[d.float.major](t,e){if(e.type.name==="break"){let i=this.inRecursive.pop();if(i){if(i.type===d.array)t.push([93]);else if(i.type===d.map)t.push([125]);else throw new Error("Unexpected recursive type; this should not happen!");return}throw new Error("Unexpected break; this should not happen!")}if(e.value===void 0)throw new Error(`${Hn} unsupported type: undefined`);if(this.prefix(t),e.type.name==="true"){t.push([116,114,117,101]);return}else if(e.type.name==="false"){t.push([102,97,108,115,101]);return}else if(e.type.name==="null"){t.push([110,117,108,108]);return}let n=String(e.value),o=[],s=!1;for(let i=0;i<n.length;i++)o[i]=n.charCodeAt(i),!s&&(o[i]===46||o[i]===101||o[i]===69)&&(s=!0);s||(o.push(46),o.push(48)),t.push(o)}};var Jr=class{constructor(t,e={}){this._pos=0,this.data=t,this.options=e,this.modeStack=["value"],this.lastToken=""}pos(){return this._pos}done(){return this._pos>=this.data.length}ch(){return this.data[this._pos]}currentMode(){return this.modeStack[this.modeStack.length-1]}skipWhitespace(){let t=this.ch();for(;t===32||t===9||t===13||t===10;)t=this.data[++this._pos]}expect(t){if(this.data.length-this._pos<t.length)throw new Error(`${F} unexpected end of input at position ${this._pos}`);for(let e=0;e<t.length;e++)if(this.data[this._pos++]!==t[e])throw new Error(`${F} unexpected token at position ${this._pos}, expected to find '${String.fromCharCode(...t)}'`)}parseNumber(){let t=this._pos,e=!1,n=!1,o=a=>{for(;!this.done();){let c=this.ch();if(a.includes(c))this._pos++;else break}};if(this.ch()===45&&(e=!0,this._pos++),this.ch()===48)if(this._pos++,this.ch()===46)this._pos++,n=!0;else return new A(d.uint,0,this._pos-t);if(o([48,49,50,51,52,53,54,55,56,57]),e&&this._pos===t+1)throw new Error(`${F} unexpected token at position ${this._pos}`);if(!this.done()&&this.ch()===46){if(n)throw new Error(`${F} unexpected token at position ${this._pos}`);n=!0,this._pos++,o([48,49,50,51,52,53,54,55,56,57])}!this.done()&&(this.ch()===101||this.ch()===69)&&(n=!0,this._pos++,!this.done()&&(this.ch()===43||this.ch()===45)&&this._pos++,o([48,49,50,51,52,53,54,55,56,57]));let s=String.fromCharCode.apply(null,this.data.subarray(t,this._pos)),i=parseFloat(s);return n?new A(d.float,i,this._pos-t):this.options.allowBigInt!==!0||Number.isSafeInteger(i)?new A(i>=0?d.uint:d.negint,i,this._pos-t):new A(i>=0?d.uint:d.negint,BigInt(s),this._pos-t)}parseString(){if(this.ch()!==34)throw new Error(`${F} unexpected character at position ${this._pos}; this shouldn't happen`);this._pos++;for(let s=this._pos,i=0;s<this.data.length&&i<65536;s++,i++){let a=this.data[s];if(a===92||a<32||a>=128)break;if(a===34){let c=String.fromCharCode.apply(null,this.data.subarray(this._pos,s));return this._pos=s+1,new A(d.string,c,i)}}let t=this._pos,e=[],n=()=>{if(this._pos+4>=this.data.length)throw new Error(`${F} unexpected end of unicode escape sequence at position ${this._pos}`);let s=0;for(let i=0;i<4;i++){let a=this.ch();if(a>=48&&a<=57)a-=48;else if(a>=97&&a<=102)a=a-97+10;else if(a>=65&&a<=70)a=a-65+10;else throw new Error(`${F} unexpected unicode escape character at position ${this._pos}`);s=s*16+a,this._pos++}return s},o=()=>{let s=this.ch(),i=null,a=s>239?4:s>223?3:s>191?2:1;if(this._pos+a>this.data.length)throw new Error(`${F} unexpected unicode sequence at position ${this._pos}`);let c,u,l,f;switch(a){case 1:s<128&&(i=s);break;case 2:c=this.data[this._pos+1],(c&192)===128&&(f=(s&31)<<6|c&63,f>127&&(i=f));break;case 3:c=this.data[this._pos+1],u=this.data[this._pos+2],(c&192)===128&&(u&192)===128&&(f=(s&15)<<12|(c&63)<<6|u&63,f>2047&&(f<55296||f>57343)&&(i=f));break;case 4:c=this.data[this._pos+1],u=this.data[this._pos+2],l=this.data[this._pos+3],(c&192)===128&&(u&192)===128&&(l&192)===128&&(f=(s&15)<<18|(c&63)<<12|(u&63)<<6|l&63,f>65535&&f<1114112&&(i=f))}i===null?(i=65533,a=1):i>65535&&(i-=65536,e.push(i>>>10&1023|55296),i=56320|i&1023),e.push(i),this._pos+=a};for(;!this.done();){let s=this.ch(),i;switch(s){case 92:if(this._pos++,this.done())throw new Error(`${F} unexpected string termination at position ${this._pos}`);switch(i=this.ch(),this._pos++,i){case 34:case 39:case 92:case 47:e.push(i);break;case 98:e.push(8);break;case 116:e.push(9);break;case 110:e.push(10);break;case 102:e.push(12);break;case 114:e.push(13);break;case 117:e.push(n());break;default:throw new Error(`${F} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new A(d.string,su(e),this._pos-t);default:if(s<32)throw new Error(`${F} invalid control character at position ${this._pos}`);s<128?(e.push(s),this._pos++):o()}}throw new Error(`${F} unexpected end of string at position ${this._pos}`)}parseValue(){switch(this.ch()){case 123:return this.modeStack.push("obj-start"),this._pos++,new A(d.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new A(d.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new A(d.null,null,4);case 102:return this.expect([102,97,108,115,101]),new A(d.false,!1,5);case 116:return this.expect([116,114,117,101]),new A(d.true,!0,4);case 45:case 48:case 49:case 50:case 51:case 52:case 53:case 54:case 55:case 56:case 57:return this.parseNumber();default:throw new Error(`${F} unexpected character at position ${this._pos}`)}}next(){switch(this.skipWhitespace(),this.currentMode()){case"value":return this.modeStack.pop(),this.parseValue();case"array-value":{if(this.modeStack.pop(),this.ch()===93)return this._pos++,this.skipWhitespace(),new A(d.break,void 0,1);if(this.ch()!==44)throw new Error(`${F} unexpected character at position ${this._pos}, was expecting array delimiter but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue()}case"array-start":return this.modeStack.pop(),this.ch()===93?(this._pos++,this.skipWhitespace(),new A(d.break,void 0,1)):(this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue());case"obj-key":if(this.ch()===125)return this.modeStack.pop(),this._pos++,this.skipWhitespace(),new A(d.break,void 0,1);if(this.ch()!==44)throw new Error(`${F} unexpected character at position ${this._pos}, was expecting object delimiter but found '${String.fromCharCode(this.ch())}'`);this._pos++,this.skipWhitespace();case"obj-start":{if(this.modeStack.pop(),this.ch()===125)return this._pos++,this.skipWhitespace(),new A(d.break,void 0,1);let t=this.parseString();if(this.skipWhitespace(),this.ch()!==58)throw new Error(`${F} unexpected character at position ${this._pos}, was expecting key/value delimiter ':' but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("obj-value"),t}case"obj-value":return this.modeStack.pop(),this.modeStack.push("obj-key"),this.skipWhitespace(),this.parseValue();default:throw new Error(`${F} unexpected parse state at position ${this._pos}; this shouldn't happen`)}}};function ea(r,t){return t=Object.assign({tokenizer:new Jr(r,t)},t),he(r,t)}var Wb={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Wb.tags[42]=ot.parse;var Yp=297;var x6=new TextDecoder;var E6=new TextEncoder;var Zb=new TextDecoder;function Uu(r,t){let e=0;for(let n=0;;n+=7){if(n>=64)throw new Error("protobuf: varint overflow");if(t>=r.length)throw new Error("protobuf: unexpected end of data");let o=r[t++];if(e+=n<28?(o&127)<<n:(o&127)*2**n,o<128)break}return[e,t]}function ra(r,t){let e;[e,t]=Uu(r,t);let n=t+e;if(e<0||n<0)throw new Error("protobuf: invalid length");if(n>r.length)throw new Error("protobuf: unexpected end of data");return[r.subarray(t,n),n]}function Zp(r,t){let e;return[e,t]=Uu(r,t),[e&7,e>>3,t]}function Jb(r){let t={},e=r.length,n=0;for(;n<e;){let o,s;if([o,s,n]=Zp(r,n),s===1){if(t.Hash)throw new Error("protobuf: (PBLink) duplicate Hash section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Hash`);if(t.Name!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Name before Hash");if(t.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Hash");[t.Hash,n]=ra(r,n)}else if(s===2){if(t.Name!==void 0)throw new Error("protobuf: (PBLink) duplicate Name section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Name`);if(t.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Name");let i;[i,n]=ra(r,n),t.Name=Zb.decode(i)}else if(s===3){if(t.Tsize!==void 0)throw new Error("protobuf: (PBLink) duplicate Tsize section");if(o!==0)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Tsize`);[t.Tsize,n]=Uu(r,n)}else throw new Error(`protobuf: (PBLink) invalid fieldNumber, expected 1, 2 or 3, got ${s}`)}if(n>e)throw new Error("protobuf: (PBLink) unexpected end of data");return t}function Jp(r){let t=r.length,e=0,n,o=!1,s;for(;e<t;){let a,c;if([a,c,e]=Zp(r,e),a!==2)throw new Error(`protobuf: (PBNode) invalid wireType, expected 2, got ${a}`);if(c===1){if(s)throw new Error("protobuf: (PBNode) duplicate Data section");[s,e]=ra(r,e),n&&(o=!0)}else if(c===2){if(o)throw new Error("protobuf: (PBNode) duplicate Links section");n||(n=[]);let u;[u,e]=ra(r,e),n.push(Jb(u))}else throw new Error(`protobuf: (PBNode) invalid fieldNumber, expected 1 or 2, got ${c}`)}if(e>t)throw new Error("protobuf: (PBNode) unexpected end of data");let i={};return s&&(i.Data=s),i.Links=n||[],i}var A6=new TextEncoder,B6=2**32,k6=2**31;var R6=new TextEncoder;function Xp(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var Qp=112;function tm(r){let t=Xp(r),e=Jp(t),n={};return e.Data&&(n.Data=e.Data),e.Links&&(n.Links=e.Links.map(o=>{let s={};try{s.Hash=ot.decode(o.Hash)}catch{}if(!s.Hash)throw new Error("Invalid Hash field found in link, expected CID");return o.Name!==void 0&&(s.Name=o.Name),o.Tsize!==void 0&&(s.Tsize=o.Tsize),s})),n}var Qb={codec:Qp,*walk(r){yield*tm(r).Links.map(e=>e.Hash)}},tx={codec:ss,*walk(){}},em=42,ex={codec:Gp,*walk(r){let t=[],e=[];e[em]=n=>{if(n[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");let o=ot.decode(n.subarray(1));return t.push(o),o},he(r,{tags:e}),yield*t}},Du=class extends Jr{tokenBuffer;constructor(t,e){super(t,e),this.tokenBuffer=[]}done(){return this.tokenBuffer.length===0&&super.done()}_next(){return this.tokenBuffer.length>0?this.tokenBuffer.pop():super.next()}next(){let t=this._next();if(t.type===d.map){let e=this._next();if(e.type===d.string&&e.value==="/"){let n=this._next();if(n.type===d.string){if(this._next().type!==d.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new A(d.tag,42,0)}if(n.type===d.map){let o=this._next();if(o.type===d.string&&o.value==="bytes"){let s=this._next();if(s.type===d.string){for(let a=0;a<2;a++)if(this._next().type!==d.break)throw new Error("Invalid encoded Bytes form");let i=fr.decode(`m${s.value}`);return new A(d.bytes,i,s.value.length)}this.tokenBuffer.push(s)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(e)}return t}},rx={codec:Yp,*walk(r){let t=[],e=[];e[em]=n=>{let o=ot.parse(n);return t.push(o),o},ea(r,{tags:e,tokenizer:new Du(r,{tags:e,allowIndefinite:!0,allowUndefined:!0,allowNaN:!0,allowInfinity:!0,allowBigInt:!0,strict:!1,rejectDuplicateMapKeys:!1})}),yield*t}},nx={codec:yl,*walk(){}};function rm(r=[]){let t={};return[Qb,tx,ex,rx,nx,...r].forEach(e=>{t[e.codec]=e}),t}var Pu=new Nt("/version"),nm=1;async function om(r){if(!await r.has(Pu)){await r.put(Pu,Y(`${nm}`));return}let t=await r.get(Pu),e=z(t);if(parseInt(e,10)!==nm)throw new Error("Unknown datastore version, a datastore migration may be required")}function sm(r=[]){let t={};return[Et,Oa,ie,...r].forEach(e=>{t[e.code]=e}),t}var nr=class{has(t,e){return Promise.reject(new Error(".has is not implemented"))}put(t,e,n){return Promise.reject(new Error(".put is not implemented"))}async*putMany(t,e){for await(let{cid:n,block:o}of t)await this.put(n,o,e),yield n}get(t,e){return Promise.reject(new Error(".get is not implemented"))}async*getMany(t,e){for await(let n of t)yield{cid:n,block:await this.get(n,e)}}delete(t,e){return Promise.reject(new Error(".delete is not implemented"))}async*deleteMany(t,e){for await(let n of t)await this.delete(n,e),yield n}async*getAll(t){throw new Error(".getAll is not implemented")}};var Jn={};xt(Jn,{abortedError:()=>cx,closeFailedError:()=>sx,deleteFailedError:()=>am,getFailedError:()=>ix,hasFailedError:()=>ax,notFoundError:()=>Ko,openFailedError:()=>ox,putFailedError:()=>im});var or=oe(hn(),1);function ox(r){return r=r??new Error("Open failed"),(0,or.default)(r,"ERR_OPEN_FAILED")}function sx(r){return r=r??new Error("Close failed"),(0,or.default)(r,"ERR_CLOSE_FAILED")}function im(r){return r=r??new Error("Put failed"),(0,or.default)(r,"ERR_PUT_FAILED")}function ix(r){return r=r??new Error("Get failed"),(0,or.default)(r,"ERR_GET_FAILED")}function am(r){return r=r??new Error("Delete failed"),(0,or.default)(r,"ERR_DELETE_FAILED")}function ax(r){return r=r??new Error("Has failed"),(0,or.default)(r,"ERR_HAS_FAILED")}function Ko(r){return r=r??new Error("Not Found"),(0,or.default)(r,"ERR_NOT_FOUND")}function cx(r){return r=r??new Error("Aborted"),(0,or.default)(r,"ERR_ABORTED")}var qo=class extends nr{data;constructor(){super(),this.data=new Map}put(t,e){return this.data.set(Rt.encode(t.multihash.bytes),e),t}get(t){let e=this.data.get(Rt.encode(t.multihash.bytes));if(e==null)throw Ko();return e}has(t){return this.data.has(Rt.encode(t.multihash.bytes))}async delete(t){this.data.delete(Rt.encode(t.multihash.bytes))}async*getAll(){for(let[t,e]of this.data.entries())yield{cid:ot.createV1(ss,Se(Rt.decode(t))),block:e}}};var u4=Jt("blockstore:core:tiered");var cm={...Jn};var na=0,oa=class extends nr{child;constructor(t){super(),this.child=t}put(t,e){return t.multihash.code===na||this.child==null?t:this.child.put(t,e)}get(t){if(t.multihash.code===na)return t.multihash.digest;if(this.child==null)throw cm.notFoundError();return this.child.get(t)}has(t){return t.multihash.code===na?!0:this.child==null?!1:this.child.has(t)}delete(t){if(t.code!==na&&this.child!=null)return this.child.delete(t)}getAll(t){return this.child!=null?this.child.getAll(t):[]}};function ux(r){return r[Symbol.asyncIterator]!=null}function um(r){return r?.then!=null}function lx(r,t){if(ux(r))return async function*(){for await(let a of r){let c=t(a);um(c)&&await c,yield a}}();let e=dn(r),{value:n,done:o}=e.next();if(o===!0)return function*(){}();if(typeof t(n)?.then=="function")return async function*(){yield n;for await(let a of e){let c=t(a);um(c)&&await c,yield a}}();let i=t;return function*(){yield n;for(let a of e)i(a),yield a}()}var Ou=lx;var sa=class r{child;hashers;started;log;logger;components;constructor(t,e={}){this.log=t.logger.forComponent(`helia:networked-storage${e.root==null?"":`:${e.root}`}`),this.logger=t.logger,this.components=t,this.child=new oa(t.blockstore),this.hashers=t.hashers??{},this.started=!1}isStarted(){return this.started}async start(){await ar(this.child,...this.components.blockBrokers),this.started=!0}async stop(){await cr(this.child,...this.components.blockBrokers),this.started=!1}unwrap(){return this.child}async put(t,e,n={}){return await this.child.has(t)?(n.onProgress?.(new nt("blocks:put:duplicate",t)),t):(n.onProgress?.(new nt("blocks:put:providers:notify",t)),await Promise.all(this.components.blockBrokers.map(async o=>o.announce?.(t,e,n))),n.onProgress?.(new nt("blocks:put:blockstore:put",t)),this.child.put(t,e,n))}async*putMany(t,e={}){let n=me(t,async({cid:s})=>{let i=await this.child.has(s);return i&&e.onProgress?.(new nt("blocks:put-many:duplicate",s)),!i}),o=Ou(n,async({cid:s,block:i})=>{e.onProgress?.(new nt("blocks:put-many:providers:notify",s)),await Promise.all(this.components.blockBrokers.map(async a=>a.announce?.(s,i,e)))});e.onProgress?.(new nt("blocks:put-many:blockstore:put-many")),yield*this.child.putMany(o,e)}async get(t,e={}){if(e.offline!==!0&&!await this.child.has(t)){e.onProgress?.(new nt("blocks:get:providers:get",t));let n=await lm(t,this.components.blockBrokers,this.hashers[t.multihash.code],{...e,log:this.log});return e.onProgress?.(new nt("blocks:get:blockstore:put",t)),await this.child.put(t,n,e),e.onProgress?.(new nt("blocks:get:providers:notify",t)),await Promise.all(this.components.blockBrokers.map(async o=>o.announce?.(t,n,e))),n}return e.onProgress?.(new nt("blocks:get:blockstore:get",t)),this.child.get(t,e)}async*getMany(t,e={}){e.onProgress?.(new nt("blocks:get-many:blockstore:get-many")),yield*this.child.getMany(Ou(t,async n=>{if(e.offline!==!0&&!await this.child.has(n)){e.onProgress?.(new nt("blocks:get-many:providers:get",n));let o=await lm(n,this.components.blockBrokers,this.hashers[n.multihash.code],{...e,log:this.log});e.onProgress?.(new nt("blocks:get-many:blockstore:put",n)),await this.child.put(n,o,e),e.onProgress?.(new nt("blocks:get-many:providers:notify",n)),await Promise.all(this.components.blockBrokers.map(async s=>s.announce?.(n,o,e)))}}))}async delete(t,e={}){e.onProgress?.(new nt("blocks:delete:blockstore:delete",t)),await this.child.delete(t,e)}async*deleteMany(t,e={}){e.onProgress?.(new nt("blocks:delete-many:blockstore:delete-many")),yield*this.child.deleteMany(async function*(){for await(let n of t)yield n}(),e)}async has(t,e={}){return this.child.has(t,e)}async*getAll(t={}){t.onProgress?.(new nt("blocks:get-all:blockstore:get-many")),yield*this.child.getAll(t)}async createSession(t,e){let n=await Promise.all(this.components.blockBrokers.map(async o=>o.createSession==null?o:o.createSession(t,e)));return new r({blockstore:this.child,blockBrokers:n,hashers:this.hashers,logger:this.logger},{root:t})}};function fx(r){return typeof r.retrieve=="function"}var hx=(r,t)=>{if(t==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 e=>{let n=await t.digest(e);if(!ct(n.digest,r.multihash.digest))throw new N("Hash of downloaded block did not match multihash from passed CID","ERR_HASH_MISMATCH")}};async function lm(r,t,e,n){let o=hx(r,e),s=new AbortController,i=Nr([s.signal,n.signal]);se(1/0,s.signal,i);let a=[];for(let c of t)fx(c)&&a.push(c);try{return await Promise.any(a.map(async c=>{try{let u=!1,l=await c.retrieve(r,{...n,signal:i,validateFn:async f=>{await o(f),u=!0}});return u||await o(l),l}catch(u){throw n.log.error("could not retrieve verified block for %c",r,u),u}}))}finally{s.abort(),i.clear()}}var ia=class{blockstore;datastore;pins;logger;routing;dagWalkers;hashers;dns;log;constructor(t){this.logger=t.logger??Af(),this.log=this.logger.forComponent("helia"),this.hashers=sm(t.hashers),this.dagWalkers=rm(t.dagWalkers),this.dns=t.dns??Dp();let e={blockstore:t.blockstore,datastore:t.datastore,hashers:this.hashers,dagWalkers:this.dagWalkers,logger:this.logger,blockBrokers:[],dns:this.dns,...t.components??{}};this.routing=e.routing=new Qi(e,{routers:(t.routers??[]).flatMap(o=>{let s=[o];return o[Qn]!=null&&s.push(o[Qn]),o[to]!=null&&s.push(o[to]),s})});let n=new sa(e);this.pins=new Xi(t.datastore,n,this.dagWalkers),this.blockstore=new ta(n,this.pins,{holdGcLock:t.holdGcLock??!0}),this.datastore=t.datastore,e.blockBrokers=t.blockBrokers.map(o=>o(e))}async start(){await om(this.datastore),await ar(this.blockstore,this.datastore,this.routing)}async stop(){await cr(this.blockstore,this.datastore,this.routing)}async gc(t={}){let e=await this.blockstore.lock.writeLock();try{let n=this,o=this.blockstore.unwrap();this.log("gc start"),await Or(o.deleteMany(async function*(){for await(let{cid:s}of o.getAll())try{if(await n.pins.isPinned(s,t))continue;yield s,t.onProgress?.(new nt("helia:gc:deleted",s))}catch(i){n.log.error("Error during gc",i),t.onProgress?.(new nt("helia:gc:error",i))}}()))}finally{e()}this.log("gc finished")}};var fm=oe(hn(),1);function aa(r){return r=r??new Error("Not Found"),(0,fm.default)(r,"ERR_NOT_FOUND")}var hm="SHARDING";function px(r){return r[Symbol.asyncIterator]!=null}function mx(r,t){return px(r)?async function*(){yield*(await Ec(r)).sort(t)}():function*(){yield*Ec(r).sort(t)}()}var ca=mx;var sr=class{put(t,e,n){return Promise.reject(new Error(".put is not implemented"))}get(t,e){return Promise.reject(new Error(".get is not implemented"))}has(t,e){return Promise.reject(new Error(".has is not implemented"))}delete(t,e){return Promise.reject(new Error(".delete is not implemented"))}async*putMany(t,e={}){for await(let{key:n,value:o}of t)await this.put(n,o,e),yield n}async*getMany(t,e={}){for await(let n of t)yield{key:n,value:await this.get(n,e)}}async*deleteMany(t,e={}){for await(let n of t)await this.delete(n,e),yield n}batch(){let t=[],e=[];return{put(n,o){t.push({key:n,value:o})},delete(n){e.push(n)},commit:async n=>{await Or(this.putMany(t,n)),t=[],await Or(this.deleteMany(e,n)),e=[]}}}async*_all(t,e){throw new Error("._all is not implemented")}async*_allKeys(t,e){throw new Error("._allKeys is not implemented")}query(t,e){let n=this._all(t,e);if(t.prefix!=null){let o=t.prefix;n=me(n,s=>s.key.toString().startsWith(o))}if(Array.isArray(t.filters)&&(n=t.filters.reduce((o,s)=>me(o,s),n)),Array.isArray(t.orders)&&(n=t.orders.reduce((o,s)=>ca(o,s),n)),t.offset!=null){let o=0,s=t.offset;n=me(n,()=>o++>=s)}return t.limit!=null&&(n=ys(n,t.limit)),n}queryKeys(t,e){let n=this._allKeys(t,e);if(t.prefix!=null){let o=t.prefix;n=me(n,s=>s.toString().startsWith(o))}if(Array.isArray(t.filters)&&(n=t.filters.reduce((o,s)=>me(o,s),n)),Array.isArray(t.orders)&&(n=t.orders.reduce((o,s)=>ca(o,s),n)),t.offset!=null){let o=t.offset,s=0;n=me(n,()=>s++>=o)}return t.limit!=null&&(n=ys(n,t.limit)),n}};var Go=class extends sr{data;constructor(){super(),this.data=new Map}put(t,e){return this.data.set(t.toString(),e),t}get(t){let e=this.data.get(t.toString());if(e==null)throw aa();return e}has(t){return this.data.has(t.toString())}delete(t){this.data.delete(t.toString())}*_all(){for(let[t,e]of this.data.entries())yield{key:new Nt(t),value:e}}*_allKeys(){for(let t of this.data.keys())yield new Nt(t)}};var hR=new Nt(hm);var BR=Jt("datastore:core:tiered");async function wx(r={}){let t=r.datastore??new Go,e=r.blockstore??new qo,n=new ia({...r,datastore:t,blockstore:e,blockBrokers:r.blockBrokers??[vc()],routers:r.routers??[bu("https://delegated-ipfs.dev")]});return r.start!==!1&&await n.start(),n}return Im(bx);})();
9
9
  /*! Bundled license information:
10
10
 
11
11
  pvtsutils/build/index.js: