@helia/http 1.0.9-5fab3a3 → 1.0.9-6952f05

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 tm=Object.create;var Qo=Object.defineProperty;var em=Object.getOwnPropertyDescriptor;var rm=Object.getOwnPropertyNames;var nm=Object.getPrototypeOf,om=Object.prototype.hasOwnProperty;var ye=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),vt=(r,t)=>{for(var e in t)Qo(r,e,{get:t[e],enumerable:!0})},yl=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of rm(t))!om.call(r,o)&&o!==e&&Qo(r,o,{get:()=>t[o],enumerable:!(n=em(t,o))||n.enumerable});return r};var Xt=(r,t,e)=>(e=r!=null?tm(nm(r)):{},yl(t||!r||!r.__esModule?Qo(e,"default",{value:r,enumerable:!0}):e,r)),sm=r=>yl(Qo({},"__esModule",{value:!0}),r);var on=ye((aE,kl)=>{"use strict";function Bl(r,t){for(let e in t)Object.defineProperty(r,e,{value:t[e],enumerable:!0,configurable:!0});return r}function gm(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 Bl(r,e)}catch{e.message=r.message,e.stack=r.stack;let o=function(){};return o.prototype=Object.create(Object.getPrototypeOf(r)),Bl(new o,e)}}kl.exports=gm});var Lf=ye(Cn=>{"use strict";var zy="[object ArrayBuffer]",Qe=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===zy}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}},Cc="string",jy=/^[0-9a-f]+$/i,Gy=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Wy=/^[a-zA-Z0-9-_]+$/,Rs=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=Qe.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return decodeURIComponent(escape(n))}},fe=class{static toString(t,e=!1){let n=Qe.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}},_s=class r{static isHex(t){return typeof t===Cc&&jy.test(t)}static isBase64(t){return typeof t===Cc&&Gy.test(t)}static isBase64Url(t){return typeof t===Cc&&Wy.test(t)}static ToString(t,e="utf8"){let n=Qe.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 fe.toString(n,!0);case"utf16":case"utf16be":return fe.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 fe.fromString(t,!0);case"utf16":case"utf16be":return fe.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Qe.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 Rs.fromString(t);case"utf16":case"utf16be":return fe.fromString(t);case"utf16le":case"usc2":return fe.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 Rs.toString(t);case"utf16":case"utf16be":return fe.toString(t);case"utf16le":case"usc2":return fe.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=Qe.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return n}static ToHex(t){let e=Qe.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 fe.toString(t,e)}static FromUtf16String(t,e=!1){return fe.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,"")||""}};_s.DEFAULT_UTF8_ENCODING="utf8";function Yy(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 Zy(...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 Jy(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}Cn.BufferSourceConverter=Qe;Cn.Convert=_s;Cn.assign=Yy;Cn.combine=Zy;Cn.isEqual=Jy});var Fh=ye((No,wi)=>{(function(r,t){"use strict";var e={version:"3.0.0",x86:{},x64:{},inputValidation:!0};function n(h){if(!Array.isArray(h)&&!ArrayBuffer.isView(h))return!1;for(var p=0;p<h.length;p++)if(!Number.isInteger(h[p])||h[p]<0||h[p]>255)return!1;return!0}function o(h,p){return(h&65535)*p+(((h>>>16)*p&65535)<<16)}function s(h,p){return h<<p|h>>>32-p}function i(h){return h^=h>>>16,h=o(h,2246822507),h^=h>>>13,h=o(h,3266489909),h^=h>>>16,h}function a(h,p){h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535],p=[p[0]>>>16,p[0]&65535,p[1]>>>16,p[1]&65535];var d=[0,0,0,0];return d[3]+=h[3]+p[3],d[2]+=d[3]>>>16,d[3]&=65535,d[2]+=h[2]+p[2],d[1]+=d[2]>>>16,d[2]&=65535,d[1]+=h[1]+p[1],d[0]+=d[1]>>>16,d[1]&=65535,d[0]+=h[0]+p[0],d[0]&=65535,[d[0]<<16|d[1],d[2]<<16|d[3]]}function c(h,p){h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535],p=[p[0]>>>16,p[0]&65535,p[1]>>>16,p[1]&65535];var d=[0,0,0,0];return d[3]+=h[3]*p[3],d[2]+=d[3]>>>16,d[3]&=65535,d[2]+=h[2]*p[3],d[1]+=d[2]>>>16,d[2]&=65535,d[2]+=h[3]*p[2],d[1]+=d[2]>>>16,d[2]&=65535,d[1]+=h[1]*p[3],d[0]+=d[1]>>>16,d[1]&=65535,d[1]+=h[2]*p[2],d[0]+=d[1]>>>16,d[1]&=65535,d[1]+=h[3]*p[1],d[0]+=d[1]>>>16,d[1]&=65535,d[0]+=h[0]*p[3]+h[1]*p[2]+h[2]*p[1]+h[3]*p[0],d[0]&=65535,[d[0]<<16|d[1],d[2]<<16|d[3]]}function u(h,p){return p%=64,p===32?[h[1],h[0]]:p<32?[h[0]<<p|h[1]>>>32-p,h[1]<<p|h[0]>>>32-p]:(p-=32,[h[1]<<p|h[0]>>>32-p,h[0]<<p|h[1]>>>32-p])}function f(h,p){return p%=64,p===0?h:p<32?[h[0]<<p|h[1]>>>32-p,h[1]<<p]:[h[1]<<p-32,0]}function l(h,p){return[h[0]^p[0],h[1]^p[1]]}function m(h){return h=l(h,[0,h[0]>>>1]),h=c(h,[4283543511,3981806797]),h=l(h,[0,h[0]>>>1]),h=c(h,[3301882366,444984403]),h=l(h,[0,h[0]>>>1]),h}e.x86.hash32=function(h,p){if(e.inputValidation&&!n(h))return t;p=p||0;for(var d=h.length%4,w=h.length-d,g=p,x=0,b=3432918353,B=461845907,A=0;A<w;A=A+4)x=h[A]|h[A+1]<<8|h[A+2]<<16|h[A+3]<<24,x=o(x,b),x=s(x,15),x=o(x,B),g^=x,g=s(g,13),g=o(g,5)+3864292196;switch(x=0,d){case 3:x^=h[A+2]<<16;case 2:x^=h[A+1]<<8;case 1:x^=h[A],x=o(x,b),x=s(x,15),x=o(x,B),g^=x}return g^=h.length,g=i(g),g>>>0},e.x86.hash128=function(h,p){if(e.inputValidation&&!n(h))return t;p=p||0;for(var d=h.length%16,w=h.length-d,g=p,x=p,b=p,B=p,A=0,I=0,v=0,E=0,U=597399067,P=2869860233,N=951274213,M=2716044179,C=0;C<w;C=C+16)A=h[C]|h[C+1]<<8|h[C+2]<<16|h[C+3]<<24,I=h[C+4]|h[C+5]<<8|h[C+6]<<16|h[C+7]<<24,v=h[C+8]|h[C+9]<<8|h[C+10]<<16|h[C+11]<<24,E=h[C+12]|h[C+13]<<8|h[C+14]<<16|h[C+15]<<24,A=o(A,U),A=s(A,15),A=o(A,P),g^=A,g=s(g,19),g+=x,g=o(g,5)+1444728091,I=o(I,P),I=s(I,16),I=o(I,N),x^=I,x=s(x,17),x+=b,x=o(x,5)+197830471,v=o(v,N),v=s(v,17),v=o(v,M),b^=v,b=s(b,15),b+=B,b=o(b,5)+2530024501,E=o(E,M),E=s(E,18),E=o(E,U),B^=E,B=s(B,13),B+=g,B=o(B,5)+850148119;switch(A=0,I=0,v=0,E=0,d){case 15:E^=h[C+14]<<16;case 14:E^=h[C+13]<<8;case 13:E^=h[C+12],E=o(E,M),E=s(E,18),E=o(E,U),B^=E;case 12:v^=h[C+11]<<24;case 11:v^=h[C+10]<<16;case 10:v^=h[C+9]<<8;case 9:v^=h[C+8],v=o(v,N),v=s(v,17),v=o(v,M),b^=v;case 8:I^=h[C+7]<<24;case 7:I^=h[C+6]<<16;case 6:I^=h[C+5]<<8;case 5:I^=h[C+4],I=o(I,P),I=s(I,16),I=o(I,N),x^=I;case 4:A^=h[C+3]<<24;case 3:A^=h[C+2]<<16;case 2:A^=h[C+1]<<8;case 1:A^=h[C],A=o(A,U),A=s(A,15),A=o(A,P),g^=A}return g^=h.length,x^=h.length,b^=h.length,B^=h.length,g+=x,g+=b,g+=B,x+=g,b+=g,B+=g,g=i(g),x=i(x),b=i(b),B=i(B),g+=x,g+=b,g+=B,x+=g,b+=g,B+=g,("00000000"+(g>>>0).toString(16)).slice(-8)+("00000000"+(x>>>0).toString(16)).slice(-8)+("00000000"+(b>>>0).toString(16)).slice(-8)+("00000000"+(B>>>0).toString(16)).slice(-8)},e.x64.hash128=function(h,p){if(e.inputValidation&&!n(h))return t;p=p||0;for(var d=h.length%16,w=h.length-d,g=[0,p],x=[0,p],b=[0,0],B=[0,0],A=[2277735313,289559509],I=[1291169091,658871167],v=0;v<w;v=v+16)b=[h[v+4]|h[v+5]<<8|h[v+6]<<16|h[v+7]<<24,h[v]|h[v+1]<<8|h[v+2]<<16|h[v+3]<<24],B=[h[v+12]|h[v+13]<<8|h[v+14]<<16|h[v+15]<<24,h[v+8]|h[v+9]<<8|h[v+10]<<16|h[v+11]<<24],b=c(b,A),b=u(b,31),b=c(b,I),g=l(g,b),g=u(g,27),g=a(g,x),g=a(c(g,[0,5]),[0,1390208809]),B=c(B,I),B=u(B,33),B=c(B,A),x=l(x,B),x=u(x,31),x=a(x,g),x=a(c(x,[0,5]),[0,944331445]);switch(b=[0,0],B=[0,0],d){case 15:B=l(B,f([0,h[v+14]],48));case 14:B=l(B,f([0,h[v+13]],40));case 13:B=l(B,f([0,h[v+12]],32));case 12:B=l(B,f([0,h[v+11]],24));case 11:B=l(B,f([0,h[v+10]],16));case 10:B=l(B,f([0,h[v+9]],8));case 9:B=l(B,[0,h[v+8]]),B=c(B,I),B=u(B,33),B=c(B,A),x=l(x,B);case 8:b=l(b,f([0,h[v+7]],56));case 7:b=l(b,f([0,h[v+6]],48));case 6:b=l(b,f([0,h[v+5]],40));case 5:b=l(b,f([0,h[v+4]],32));case 4:b=l(b,f([0,h[v+3]],24));case 3:b=l(b,f([0,h[v+2]],16));case 2:b=l(b,f([0,h[v+1]],8));case 1:b=l(b,[0,h[v]]),b=c(b,A),b=u(b,31),b=c(b,I),g=l(g,b)}return g=l(g,[0,h.length]),x=l(x,[0,h.length]),g=a(g,x),x=a(x,g),g=m(g),x=m(x),g=a(g,x),x=a(x,g),("00000000"+(g[0]>>>0).toString(16)).slice(-8)+("00000000"+(g[1]>>>0).toString(16)).slice(-8)+("00000000"+(x[0]>>>0).toString(16)).slice(-8)+("00000000"+(x[1]>>>0).toString(16)).slice(-8)},typeof No<"u"?(typeof wi<"u"&&wi.exports&&(No=wi.exports=e),No.murmurHash3=e):typeof define=="function"&&define.amd?define([],function(){return e}):(e._murmurHash3=r.murmurHash3,e.noConflict=function(){return r.murmurHash3=e._murmurHash3,e._murmurHash3=t,e.noConflict=t,e},r.murmurHash3=e)})(No)});var Mh=ye((t8,Vh)=>{Vh.exports=Fh()});var Hh=ye((e8,$h)=>{var Pn=1e3,On=Pn*60,Fn=On*60,Zr=Fn*24,Cw=Zr*7,Nw=Zr*365.25;$h.exports=function(r,t){t=t||{};var e=typeof r;if(e==="string"&&r.length>0)return Lw(r);if(e==="number"&&isFinite(r))return t.long?Dw(r):Uw(r);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(r))};function Lw(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*Nw;case"weeks":case"week":case"w":return e*Cw;case"days":case"day":case"d":return e*Zr;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*On;case"seconds":case"second":case"secs":case"sec":case"s":return e*Pn;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return e;default:return}}}}function Uw(r){var t=Math.abs(r);return t>=Zr?Math.round(r/Zr)+"d":t>=Fn?Math.round(r/Fn)+"h":t>=On?Math.round(r/On)+"m":t>=Pn?Math.round(r/Pn)+"s":r+"ms"}function Dw(r){var t=Math.abs(r);return t>=Zr?bi(r,t,Zr,"day"):t>=Fn?bi(r,t,Fn,"hour"):t>=On?bi(r,t,On,"minute"):t>=Pn?bi(r,t,Pn,"second"):r+" ms"}function bi(r,t,e,n){var o=t>=e*1.5;return Math.round(r/e)+" "+n+(o?"s":"")}});var qh=ye((r8,Kh)=>{function Pw(r){e.debug=e,e.default=e,e.coerce=c,e.disable=s,e.enable=o,e.enabled=i,e.humanize=Hh(),e.destroy=u,Object.keys(r).forEach(f=>{e[f]=r[f]}),e.names=[],e.skips=[],e.formatters={};function t(f){let l=0;for(let m=0;m<f.length;m++)l=(l<<5)-l+f.charCodeAt(m),l|=0;return e.colors[Math.abs(l)%e.colors.length]}e.selectColor=t;function e(f){let l,m=null,h,p;function d(...w){if(!d.enabled)return;let g=d,x=Number(new Date),b=x-(l||x);g.diff=b,g.prev=l,g.curr=x,l=x,w[0]=e.coerce(w[0]),typeof w[0]!="string"&&w.unshift("%O");let B=0;w[0]=w[0].replace(/%([a-zA-Z%])/g,(I,v)=>{if(I==="%%")return"%";B++;let E=e.formatters[v];if(typeof E=="function"){let U=w[B];I=E.call(g,U),w.splice(B,1),B--}return I}),e.formatArgs.call(g,w),(g.log||e.log).apply(g,w)}return d.namespace=f,d.useColors=e.useColors(),d.color=e.selectColor(f),d.extend=n,d.destroy=e.destroy,Object.defineProperty(d,"enabled",{enumerable:!0,configurable:!1,get:()=>m!==null?m:(h!==e.namespaces&&(h=e.namespaces,p=e.enabled(f)),p),set:w=>{m=w}}),typeof e.init=="function"&&e.init(d),d}function n(f,l){let m=e(this.namespace+(typeof l>"u"?":":l)+f);return m.log=this.log,m}function o(f){e.save(f),e.namespaces=f,e.names=[],e.skips=[];let l,m=(typeof f=="string"?f:"").split(/[\s,]+/),h=m.length;for(l=0;l<h;l++)m[l]&&(f=m[l].replace(/\*/g,".*?"),f[0]==="-"?e.skips.push(new RegExp("^"+f.slice(1)+"$")):e.names.push(new RegExp("^"+f+"$")))}function s(){let f=[...e.names.map(a),...e.skips.map(a).map(l=>"-"+l)].join(",");return e.enable(""),f}function i(f){if(f[f.length-1]==="*")return!0;let l,m;for(l=0,m=e.skips.length;l<m;l++)if(e.skips[l].test(f))return!1;for(l=0,m=e.names.length;l<m;l++)if(e.names[l].test(f))return!0;return!1}function a(f){return f.toString().substring(2,f.toString().length-2).replace(/\.\*\?$/,"*")}function c(f){return f instanceof Error?f.stack||f.message:f}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}Kh.exports=Pw});var zh=ye((ee,xi)=>{ee.formatArgs=Fw;ee.save=Vw;ee.load=Mw;ee.useColors=Ow;ee.storage=$w();ee.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`."))}})();ee.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 Ow(){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 Fw(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+xi.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)}ee.log=console.debug||console.log||(()=>{});function Vw(r){try{r?ee.storage.setItem("debug",r):ee.storage.removeItem("debug")}catch{}}function Mw(){let r;try{r=ee.storage.getItem("debug")}catch{}return!r&&typeof process<"u"&&"env"in process&&(r=process.env.DEBUG),r}function $w(){try{return localStorage}catch{}}xi.exports=qh()(ee);var{formatters:Hw}=xi.exports;Hw.j=function(r){try{return JSON.stringify(r)}catch(t){return"[UnexpectedJSONParseError]: "+t.message}}});var Wh=ye((a8,jc)=>{"use strict";var qw=Object.prototype.hasOwnProperty,zt="~";function Lo(){}Object.create&&(Lo.prototype=Object.create(null),new Lo().__proto__||(zt=!1));function zw(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function Gh(r,t,e,n,o){if(typeof e!="function")throw new TypeError("The listener must be a function");var s=new zw(e,n||r,o),i=zt?zt+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 Ei(r,t){--r._eventsCount===0?r._events=new Lo:delete r._events[t]}function $t(){this._events=new Lo,this._eventsCount=0}$t.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)qw.call(e,n)&&t.push(zt?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};$t.prototype.listeners=function(t){var e=zt?zt+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};$t.prototype.listenerCount=function(t){var e=zt?zt+t:t,n=this._events[e];return n?n.fn?1:n.length:0};$t.prototype.emit=function(t,e,n,o,s,i){var a=zt?zt+t:t;if(!this._events[a])return!1;var c=this._events[a],u=arguments.length,f,l;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(l=1,f=new Array(u-1);l<u;l++)f[l-1]=arguments[l];c.fn.apply(c.context,f)}else{var m=c.length,h;for(l=0;l<m;l++)switch(c[l].once&&this.removeListener(t,c[l].fn,void 0,!0),u){case 1:c[l].fn.call(c[l].context);break;case 2:c[l].fn.call(c[l].context,e);break;case 3:c[l].fn.call(c[l].context,e,n);break;case 4:c[l].fn.call(c[l].context,e,n,o);break;default:if(!f)for(h=1,f=new Array(u-1);h<u;h++)f[h-1]=arguments[h];c[l].fn.apply(c[l].context,f)}}return!0};$t.prototype.on=function(t,e,n){return Gh(this,t,e,n,!1)};$t.prototype.once=function(t,e,n){return Gh(this,t,e,n,!0)};$t.prototype.removeListener=function(t,e,n,o){var s=zt?zt+t:t;if(!this._events[s])return this;if(!e)return Ei(this,s),this;var i=this._events[s];if(i.fn)i.fn===e&&(!o||i.once)&&(!n||i.context===n)&&Ei(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:Ei(this,s)}return this};$t.prototype.removeAllListeners=function(t){var e;return t?(e=zt?zt+t:t,this._events[e]&&Ei(this,e)):(this._events=new Lo,this._eventsCount=0),this};$t.prototype.off=$t.prototype.removeListener;$t.prototype.addListener=$t.prototype.on;$t.prefixed=zt;$t.EventEmitter=$t;typeof jc<"u"&&(jc.exports=$t)});var Qh=ye((T8,Xh)=>{Xh.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 Mp=ye(jo=>{(function(){var r,t,e,n,o,s,i,a;a=function(c){var u,f,l,m;return u=(c&255<<24)>>>24,f=(c&255<<16)>>>16,l=(c&65280)>>>8,m=c&255,[u,f,l,m].join(".")},i=function(c){var u,f,l,m,h,p;for(u=[],l=m=0;m<=3&&c.length!==0;l=++m){if(l>0){if(c[0]!==".")throw new Error("Invalid IP");c=c.substring(1)}p=t(c),h=p[0],f=p[1],c=c.substring(f),u.push(h)}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,f,l,m,h;for(m=0,u=10,f="9",l=0,c.length>1&&c[l]==="0"&&(c[l+1]==="x"||c[l+1]==="X"?(l+=2,u=16):"0"<=c[l+1]&&c[l+1]<="9"&&(l++,u=8,f="7")),h=l;l<c.length;){if("0"<=c[l]&&c[l]<=f)m=m*u+(e(c[l])-n)>>>0;else if(u===16)if("a"<=c[l]&&c[l]<="f")m=m*u+(10+e(c[l])-s)>>>0;else if("A"<=c[l]&&c[l]<="F")m=m*u+(10+e(c[l])-o)>>>0;else break;else break;if(m>4294967295)throw new Error("too large");l++}if(l===h)throw new Error("empty octet");return[m,l]},r=function(){function c(u,f){var l,m,h,p;if(typeof u!="string")throw new Error("Missing `net' parameter");if(f||(p=u.split("/",2),u=p[0],f=p[1]),f||(f=32),typeof f=="string"&&f.indexOf(".")>-1){try{this.maskLong=i(f)}catch(d){throw l=d,new Error("Invalid mask: "+f)}for(m=h=32;h>=0;m=--h)if(this.maskLong===4294967295<<32-m>>>0){this.bitmask=m;break}}else if(f||f===0)this.bitmask=parseInt(f,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(d){throw l=d,new Error("Invalid net address: "+u)}if(!(this.bitmask<=32))throw new Error("Invalid mask for ip4: "+f);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 f,l,m;for(m=i(this.first),l=i(this.last),f=0;m<=l;)u(a(m),m,f),f++,m++},c.prototype.toString=function(){return this.base+"/"+this.bitmask},c}(),jo.ip2long=i,jo.long2ip=a,jo.Netmask=r}).call(jo)});var ju=ye((P4,zu)=>{var D4=function(){typeof zu<"u"&&(zu.exports=d);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(E){var U=E-E%1;return U==0&&(E<0||E===0&&1/E!=1/0)?-0:U},f=d.prototype,l=(d.fromDate=function(E){return new d(+E)},d.fromInt64BE=B(0,1,2,3,0,4),d.fromInt64LE=B(3,2,1,0,4,0),d.fromString=function(N){var U,P=new d,N=(N+="").replace(/^\s*[+\-]?\d+/,function(C){var C=+C,X=1970+(C-1970)%400;return P.year=C-X,X}).replace(/(?:Z|([+\-]\d{2}):?(\d{2}))$/,function(M,C,X){return C<0&&(X*=-1),U=6e4*(60*+C+ +X),""}).replace(/\.\d+$/,function(M){return P.nano=+(M+c).substr(1,9),""}).split(/\D+/);if(1<N.length?N[1]--:N[1]=0,P.time=U=Date.UTC.apply(Date,N)-(U||0),isNaN(U))throw new TypeError("Invalid Date");return w(P)},d.fromTimeT=function(E){return x(E,0)},f.year=0,f.time=0,f.nano=0,f.addNano=function(E){return this.nano+=+E||0,this},f.getNano=function(){var E=w(this);return(E.time%1e3*a+ +E.nano+1e9)%1e9},f.getTimeT=function(){var U=w(this),E=Math.floor(U.time/1e3),U=U.year;return U&&(E+=U*e*r/t),E},f.getYear=function(){return this.toDate().getUTCFullYear()+this.year},f.toDate=function(){return g(w(this).time)},f.toJSON=function(){return this.toString().replace(/0{1,6}Z$/,"Z")},f.toString=function(E){var U=this,P=U.toDate(),N={H:function(){return I(P.getUTCHours())},L:function(){return v(P.getUTCMilliseconds(),3)},M:function(){return I(P.getUTCMinutes())},N:function(){return v(U.getNano(),9)},S:function(){return I(P.getUTCSeconds())},Y:function(){var M=U.getYear();return 999999<M?"+"+M:9999<M?"+"+v(M,6):0<=M?v(M,4):-999999<=M?"-"+v(-M,6):M},a:function(){return h[P.getUTCDay()]},b:function(){return m[P.getUTCMonth()]},d:function(){return I(P.getUTCDate())},e:function(){return function(M){return(9<M?"":" ")+(0|M)}(P.getUTCDate())},m:function(){return I(P.getUTCMonth()+1)}};return function M(C){return C.replace(/%./g,function(X){var T=X[1],S=p[T],T=N[T];return S?M(S):T?T():X})}(E||l)},f.writeInt64BE=b(0,1,2,3,0,4),f.writeInt64LE=b(3,2,1,0,4,0),"%Y-%m-%dT%H:%M:%S.%NZ"),m=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],h=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],p={"%":"%",F:"%Y-%m-%d",n:`
3
- `,R:"%H:%M",T:"%H:%M:%S",t:" ",X:"%T",Z:"GMT",z:"+0000"};return d;function d(E,U,P){var N=this;if(!(N instanceof d))return new d(E,U,P);N.time=+E||0,N.nano=+U||0,N.year=+P||0,w(N)}function w(E){var U,P,N,M=E.year,C=E.time,X=E.nano,S=((X<0||a<=X)&&(X-=(P=Math.floor(X/a))*a,C+=P,P=1),M%t);return(C<-s||s<C||S)&&((U=u(C/o))&&(M+=U*t,C-=U*o),(N=g(C)).setUTCFullYear(S+N.getUTCFullYear()),N=(C=+N)+(U=u((M-=S)/t))*o,U&&-s<=N&&N<=s&&(M-=U*t,C=N),P=1),P&&(E.year=M,E.time=C,E.nano=X),E}function g(E){var U=new Date(0);return U.setTime(E),U}function x(M,N){M=+M||0;var P=u((N=(N|0)*i)/n)+u(M/n),N=N%n+M%n,M=u(N/n);return M&&(P+=M,N-=M*n),new d(1e3*N,0,P*t)}function b(E,U,P,N,M,C){return function(S,T){var _=w(this);S=S||new Array(8),A(S,T|=0);var k=Math.floor(_.time/1e3),_=_.year*(e*r/t),H=u(_/i)+u(k/i),_=_%i+k%i,k=Math.floor(_/i);return k&&(H+=k,_-=k*i),X(S,T+M,H),X(S,T+C,_),S};function X(S,T,H){S[T+E]=H>>24&255,S[T+U]=H>>16&255,S[T+P]=H>>8&255,S[T+N]=255&H}}function B(E,U,P,N,M,C){return function(S,T){A(S,T|=0);var H=X(S,T+M);return x(X(S,T+C),H)};function X(S,T){return 16777216*S[T+E]+(S[T+U]<<16|S[T+P]<<8|S[T+N])}}function A(E,U){if(E=E&&E.length,E==null)throw new TypeError("Invalid Buffer");if(E<U+8)throw new RangeError("Out of range")}function I(E){return(9<E?"":"0")+(0|E)}function v(E,U){return(c+(0|E)).substr(-U)}}()});var g1={};vt(g1,{DEFAULT_SESSION_MAX_PROVIDERS:()=>Fp,DEFAULT_SESSION_MIN_PROVIDERS:()=>Op,createHeliaHTTP:()=>m1});var ro=Symbol.for("@libp2p/content-routing");var no=Symbol.for("@libp2p/peer-id");function wl(r){return r!=null&&!!r[no]}var oo=Symbol.for("@libp2p/peer-routing");var dr=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"},D=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var ft=(r,...t)=>{try{[...t]}catch{}};var en=class extends EventTarget{#t=new Map;constructor(){super(),ft(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 im(t,e))}},va=class extends Event{detail;constructor(t,e){super(t,e),this.detail=e?.detail}},im=globalThis.CustomEvent??va;function bl(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function pr(...r){let t=[];for(let e of r)bl(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 mr(...r){let t=[];for(let e of r)bl(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 Ht(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 St(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var ts=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}},rn=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new ts(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 ts(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 Aa=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Fr(r={}){return am(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 am(r,t){t=t??{};let e=t.onEnd,n=new rn,o,s,i,a=St(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((w,g)=>{s=x=>{s=null,n.push(x);try{w(r(n))}catch(b){g(b)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=St()})}},u=w=>s!=null?s(w):(n.push(w),o),f=w=>(n=new rn,s!=null?s({error:w}):(n.push({error:w}),o)),l=w=>{if(i)return o;if(t?.objectMode!==!0&&w?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return u({done:!1,value:w})},m=w=>i?o:(i=!0,w!=null?f(w):u({done:!0})),h=()=>(n=new rn,m(),{done:!0}),p=w=>(m(w),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:h,throw:p,push:l,end:m,get readableLength(){return n.size},onEmpty:async w=>{let g=w?.signal;if(g?.throwIfAborted(),n.isEmpty())return;let x,b;g!=null&&(x=new Promise((B,A)=>{b=()=>{A(new Aa)},g.addEventListener("abort",b)}));try{await Promise.race([a.promise,x])}finally{b!=null&&g!=null&&g?.removeEventListener("abort",b)}}},e==null)return o;let d=o;return o={[Symbol.asyncIterator](){return this},next(){return d.next()},throw(w){return d.throw(w),e!=null&&(e(w),e=void 0),{done:!0}},return(){return d.return(),e!=null&&(e(),e=void 0),{done:!0}},push:l,end(w){return d.end(w),e!=null&&(e(w),e=void 0),o},get readableLength(){return d.readableLength},onEmpty:w=>d.onEmpty(w)},o}var Ba=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 es(r,t,e,n){let o=new Ba(n?.errorMessage,n?.errorCode);return e?.aborted===!0?Promise.reject(o):new Promise((s,i)=>{function a(){e?.removeEventListener("abort",f),r.removeEventListener(t,c),n?.errorEvent!=null&&r.removeEventListener(n.errorEvent,u)}let c=l=>{try{if(n?.filter?.(l)===!1)return}catch(m){a(),i(m);return}a(),s(l)},u=l=>{a(),i(l.detail)},f=()=>{a(),i(o)};e?.addEventListener("abort",f),r.addEventListener(t,c),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,u)})}var rs=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 xl(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new rs(e?.errorMessage,e?.errorCode));let n,o=new rs(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 ns=class{deferred;signal;constructor(t){this.signal=t,this.deferred=St(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new dr)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function cm(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var os=class{id;fn;options;recipients;status;timeline;controller;constructor(t,e){this.id=cm(),this.status="queued",this.fn=t,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,ft(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 dr),this.cleanup())}async join(t={}){let e=new ns(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 xl(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.cleanup(),t.signal?.removeEventListener("abort",this.onAbort)})}};var qe=class extends en{concurrency;queue;pending;sort;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.sort=t.sort,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){this.queue.push(t),this.sort!=null&&this.queue.sort(this.sort)}async add(t,e){e?.signal?.throwIfAborted();let n=new os(t,e);return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),n.join(e).then(o=>(this.safeDispatchEvent("completed",{detail:o}),this.safeDispatchEvent("success",{detail:{job:n,result:o}}),o)).catch(o=>{if(n.status==="queued"){for(let s=0;s<this.queue.length;s++)if(this.queue[s]===n){this.queue.splice(s,1);break}}throw this.safeDispatchEvent("error",{detail:o}),this.safeDispatchEvent("failure",{detail:{job:n,error:o}}),o})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(t=>{t.abort(new dr)}),this.clear()}async onEmpty(t){this.size!==0&&await es(this,"empty",t?.signal)}async onSizeLessThan(t,e){this.size<t||await es(this,"next",e?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await es(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=Fr({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 D("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 ss=class extends qe{has(t){return this.find(t)!=null}find(t){return this.queue.find(e=>t.equals(e.options.peerId))}};function um(r){return r[Symbol.asyncIterator]!=null}function lm(r){if(um(r))return(async()=>{for await(let t of r);})();for(let t of r);}var Vr=lm;function we(r=0){return new Uint8Array(r)}function jt(r=0){return new Uint8Array(r)}var fm=Math.pow(2,7),hm=Math.pow(2,14),dm=Math.pow(2,21),ka=Math.pow(2,28),Sa=Math.pow(2,35),Ia=Math.pow(2,42),Ra=Math.pow(2,49),st=128,Ft=127;function Gt(r){if(r<fm)return 1;if(r<hm)return 2;if(r<dm)return 3;if(r<ka)return 4;if(r<Sa)return 5;if(r<Ia)return 6;if(r<Ra)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function _a(r,t,e=0){switch(Gt(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 pm(r,t,e=0){switch(Gt(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 Ta(r,t){let e=r[t],n=0;if(n+=e&Ft,e<st||(e=r[t+1],n+=(e&Ft)<<7,e<st)||(e=r[t+2],n+=(e&Ft)<<14,e<st)||(e=r[t+3],n+=(e&Ft)<<21,e<st)||(e=r[t+4],n+=(e&Ft)*ka,e<st)||(e=r[t+5],n+=(e&Ft)*Sa,e<st)||(e=r[t+6],n+=(e&Ft)*Ia,e<st)||(e=r[t+7],n+=(e&Ft)*Ra,e<st))return n;throw new RangeError("Could not decode varint")}function mm(r,t){let e=r.get(t),n=0;if(n+=e&Ft,e<st||(e=r.get(t+1),n+=(e&Ft)<<7,e<st)||(e=r.get(t+2),n+=(e&Ft)<<14,e<st)||(e=r.get(t+3),n+=(e&Ft)<<21,e<st)||(e=r.get(t+4),n+=(e&Ft)*ka,e<st)||(e=r.get(t+5),n+=(e&Ft)*Sa,e<st)||(e=r.get(t+6),n+=(e&Ft)*Ia,e<st)||(e=r.get(t+7),n+=(e&Ft)*Ra,e<st))return n;throw new RangeError("Could not decode varint")}function nn(r,t,e=0){return t==null&&(t=jt(Gt(r))),t instanceof Uint8Array?_a(r,t,e):pm(r,t,e)}function Mr(r,t=0){return r instanceof Uint8Array?Ta(r,t):mm(r,t)}function It(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=jt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}function it(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 Al=Symbol.for("@achingbrain/uint8arraylist");function vl(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let o=e+n.byteLength;if(t<o)return{buf:n,index:t-e};e=o}throw new RangeError("index is out of bounds")}function is(r){return!!r?.[Al]}var as=class r{bufs;length;[Al]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(is(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(is(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=vl(this.bufs,t);return e.buf[e.index]}set(t,e){let n=vl(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(is(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:o}=this._subList(t,e);return It(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:It(n,o)}sublist(t,e){let{bufs:n,length:o}=this._subList(t,e),s=new r;return s.length=o,s.bufs=[...n],s}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],o=0;for(let s=0;s<this.bufs.length;s++){let i=this.bufs[s],a=o,c=a+i.byteLength;if(o=c,t>=c)continue;let u=t>=a&&t<c,f=e>a&&e<=c;if(u&&f){if(t===a&&e===c){n.push(i);break}let l=t-a;n.push(i.subarray(l,l+(e-t)));break}if(u){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(f){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!is(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let s=256,i=new Int32Array(s);for(let l=0;l<s;l++)i[l]=-1;for(let l=0;l<o;l++)i[n[l]]=l;let a=i,c=this.byteLength-n.byteLength,u=n.byteLength-1,f;for(let l=e;l<=c;l+=f){f=0;for(let m=u;m>=0;m--){let h=this.get(l+m);if(n[m]!==h){f=Math.max(1,m-a[h]);break}}if(f===0)return l}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=jt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let o=we(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,e,n),this.write(o,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let o=we(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,e,n),this.write(o,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let o=we(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,e,n),this.write(o,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=jt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let o=we(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,e,n),this.write(o,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let o=we(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,e,n),this.write(o,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let o=we(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,e,n),this.write(o,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let o=we(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,e,n),this.write(o,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let o=we(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,e,n),this.write(o,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!it(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((o,s)=>o+s.byteLength,0)),n.length=e,n}};function ym(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 sn=ym;function wm(r){return r[Symbol.asyncIterator]!=null}function bm(r,t){let e=0;if(wm(r))return async function*(){for await(let c of r)yield t(c,e++)}();let n=sn(r),{value:o,done:s}=n.next();if(s===!0)return function*(){}();let i=t(o,e++);if(typeof i.then=="function")return async function*(){yield await i;for await(let c of n)yield t(c,e++)}();let a=t;return function*(){yield i;for(let c of n)yield a(c,e++)}()}var an=bm;function xm(r){return r[Symbol.asyncIterator]!=null}function Em(...r){let t=[];for(let e of r)xm(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Fr({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 $r=Em;function vm(r){return r[Symbol.asyncIterator]!=null}function Am(r,t){return vm(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 cs=Am;var nt=class extends Event{constructor(t,e){super(t),this.detail=e}};var Ca=new Float32Array([-0]),gr=new Uint8Array(Ca.buffer);function Sl(r,t,e){Ca[0]=r,t[e]=gr[0],t[e+1]=gr[1],t[e+2]=gr[2],t[e+3]=gr[3]}function Il(r,t){return gr[0]=r[t],gr[1]=r[t+1],gr[2]=r[t+2],gr[3]=r[t+3],Ca[0]}var Na=new Float64Array([-0]),Vt=new Uint8Array(Na.buffer);function Rl(r,t,e){Na[0]=r,t[e]=Vt[0],t[e+1]=Vt[1],t[e+2]=Vt[2],t[e+3]=Vt[3],t[e+4]=Vt[4],t[e+5]=Vt[5],t[e+6]=Vt[6],t[e+7]=Vt[7]}function _l(r,t){return Vt[0]=r[t],Vt[1]=r[t+1],Vt[2]=r[t+2],Vt[3]=r[t+3],Vt[4]=r[t+4],Vt[5]=r[t+5],Vt[6]=r[t+6],Vt[7]=r[t+7],Na[0]}var Bm=BigInt(Number.MAX_SAFE_INTEGER),km=BigInt(Number.MIN_SAFE_INTEGER),Qt=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 Hr;if(t<Bm&&t>km)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>Tl&&(o=0n,++n>Tl&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Hr;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):Hr}},Hr=new Qt(0,0);Hr.toBigInt=function(){return 0n};Hr.zzEncode=Hr.zzDecode=function(){return this};Hr.length=function(){return 1};var Tl=4294967296n;function Cl(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 Nl(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 La(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 be(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function us(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Ua=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,be(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 be(this,4);return us(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw be(this,4);return us(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw be(this,4);let t=Il(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw be(this,4);let t=_l(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 be(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Nl(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw be(this,t);this.pos+=t}else do if(this.pos>=this.len)throw be(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 Qt(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 be(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 be(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 be(this,8);let t=us(this.buf,this.pos+=4),e=us(this.buf,this.pos+=4);return new Qt(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=Ta(this.buf,this.pos);return this.pos+=Gt(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 Da(r){return new Ua(r instanceof Uint8Array?r:r.subarray())}function cn(r,t,e){let n=Da(r);return t.decode(n,void 0,e)}var Ma={};vt(Ma,{base10:()=>Cm});var SE=new Uint8Array(0);function Ul(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 ze(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 Dl(r){return new TextEncoder().encode(r)}function Pl(r){return new TextDecoder().decode(r)}function Sm(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),f=Math.log(256)/Math.log(a);function l(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var d=0,w=0,g=0,x=p.length;g!==x&&p[g]===0;)g++,d++;for(var b=(x-g)*f+1>>>0,B=new Uint8Array(b);g!==x;){for(var A=p[g],I=0,v=b-1;(A!==0||I<w)&&v!==-1;v--,I++)A+=256*B[v]>>>0,B[v]=A%a>>>0,A=A/a>>>0;if(A!==0)throw new Error("Non-zero carry");w=I,g++}for(var E=b-w;E!==b&&B[E]===0;)E++;for(var U=c.repeat(d);E<b;++E)U+=r.charAt(B[E]);return U}function m(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var d=0;if(p[d]!==" "){for(var w=0,g=0;p[d]===c;)w++,d++;for(var x=(p.length-d)*u+1>>>0,b=new Uint8Array(x);p[d];){var B=e[p.charCodeAt(d)];if(B===255)return;for(var A=0,I=x-1;(B!==0||A<g)&&I!==-1;I--,A++)B+=a*b[I]>>>0,b[I]=B%256>>>0,B=B/256>>>0;if(B!==0)throw new Error("Non-zero carry");g=A,d++}if(p[d]!==" "){for(var v=x-g;v!==x&&b[v]===0;)v++;for(var E=new Uint8Array(w+(x-v)),U=w;v!==x;)E[U++]=b[v++];return E}}}function h(p){var d=m(p);if(d)return d;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:m,decode:h}}var Im=Sm,Rm=Im,Fl=Rm;var Pa=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")}},Oa=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 Vl(this,t)}},Fa=class{decoders;constructor(t){this.decoders=t}or(t){return Vl(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 Vl(r,t){return new Fa({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Va=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 Pa(t,e,n),this.decoder=new Oa(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function un({name:r,prefix:t,encode:e,decode:n}){return new Va(r,t,e,n)}function yr({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Fl(e,r);return un({prefix:t,name:r,encode:n,decode:s=>ze(o(s))})}function _m(r,t,e,n){let o={};for(let f=0;f<t.length;++f)o[t[f]]=f;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 f=0;f<s;++f){let l=o[r[f]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|l,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 Tm(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 pt({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return un({prefix:t,name:r,encode(o){return Tm(o,n,e)},decode(o){return _m(o,n,e,r)}})}var Cm=yr({prefix:"9",name:"base10",alphabet:"0123456789"});var $a={};vt($a,{base16:()=>Nm,base16upper:()=>Lm});var Nm=pt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Lm=pt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ha={};vt(Ha,{base2:()=>Um});var Um=pt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ka={};vt(Ka,{base256emoji:()=>Vm});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}"),Dm=Ml.reduce((r,t,e)=>(r[e]=t,r),[]),Pm=Ml.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Om(r){return r.reduce((t,e)=>(t+=Dm[e],t),"")}function Fm(r){let t=[];for(let e of r){let n=Pm[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Vm=un({prefix:"\u{1F680}",name:"base256emoji",encode:Om,decode:Fm});var qa={};vt(qa,{base32:()=>Nt,base32hex:()=>Hm,base32hexpad:()=>qm,base32hexpadupper:()=>zm,base32hexupper:()=>Km,base32pad:()=>Mm,base32padupper:()=>$m,base32upper:()=>$l,base32z:()=>jm});var Nt=pt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),$l=pt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Mm=pt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),$m=pt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Hm=pt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Km=pt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),qm=pt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),zm=pt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),jm=pt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var za={};vt(za,{base36:()=>wr,base36upper:()=>Gm});var wr=yr({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Gm=yr({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ja={};vt(ja,{base58btc:()=>ht,base58flickr:()=>Wm});var ht=yr({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Wm=yr({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Wa={};vt(Wa,{base64:()=>ue,base64pad:()=>Ym,base64url:()=>Ga,base64urlpad:()=>Zm});var ue=pt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Ym=pt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Ga=pt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Zm=pt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ya={};vt(Ya,{base8:()=>Jm});var Jm=pt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Za={};vt(Za,{identity:()=>Xm});var Xm=un({prefix:"\0",name:"identity",encode:r=>Pl(r),decode:r=>Dl(r)});var HE=new TextEncoder,KE=new TextDecoder;var Hl=512;var ls=85;var Qa={};vt(Qa,{identity:()=>Wt});var Qm=jl,ql=128,tg=127,eg=~tg,rg=Math.pow(2,31);function jl(r,t,e){t=t||[],e=e||0;for(var n=e;r>=rg;)t[e++]=r&255|ql,r/=128;for(;r&eg;)t[e++]=r&255|ql,r>>>=7;return t[e]=r|0,jl.bytes=e-n+1,t}var ng=Xa,og=128,zl=127;function Xa(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw Xa.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&zl)<<o:(i&zl)*Math.pow(2,o),o+=7}while(i>=og);return Xa.bytes=s-n,e}var sg=Math.pow(2,7),ig=Math.pow(2,14),ag=Math.pow(2,21),cg=Math.pow(2,28),ug=Math.pow(2,35),lg=Math.pow(2,42),fg=Math.pow(2,49),hg=Math.pow(2,56),dg=Math.pow(2,63),pg=function(r){return r<sg?1:r<ig?2:r<ag?3:r<cg?4:r<ug?5:r<lg?6:r<fg?7:r<hg?8:r<dg?9:10},mg={encode:Qm,decode:ng,encodingLength:pg},gg=mg,so=gg;function io(r,t=0){return[so.decode(r,t),so.decode.bytes]}function ln(r,t,e=0){return so.encode(r,t,e),t}function fn(r){return so.encodingLength(r)}function Ce(r,t){let e=t.byteLength,n=fn(r),o=n+fn(e),s=new Uint8Array(o+e);return ln(r,s,0),ln(e,s,n),s.set(t,o),new hn(r,e,t,s)}function Ne(r){let t=ze(r),[e,n]=io(t),[o,s]=io(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new hn(e,o,i,t)}function Gl(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Ul(r.bytes,e.bytes)}}var hn=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};var Wl=0,yg="identity",Yl=ze;function wg(r){return Ce(Wl,Yl(r))}var Wt={code:Wl,name:yg,encode:Yl,digest:wg};var nc={};vt(nc,{sha256:()=>At,sha512:()=>rc});function ec({name:r,code:t,encode:e}){return new tc(r,t,e)}var tc=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?Ce(this.code,e):e.then(n=>Ce(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Jl(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var At=ec({name:"sha2-256",code:18,encode:Jl("SHA-256")}),rc=ec({name:"sha2-512",code:19,encode:Jl("SHA-512")});function Xl(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return xg(e,oc(r),t??ht.encoder);default:return Eg(e,oc(r),t??Nt.encoder)}}var Ql=new WeakMap;function oc(r){let t=Ql.get(r);if(t==null){let e=new Map;return Ql.set(r,e),e}return t}var tt=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!==ao)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==vg)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=Ce(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&&Gl(t.multihash,n.multihash)}toString(t){return Xl(this,t)}toJSON(){return{"/":Xl(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??tf(n,o,s.bytes))}else if(e[Ag]===!0){let{version:n,multihash:o,code:s}=e,i=Ne(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!==ao)throw new Error(`Version 0 CID must use dag-pb (code: ${ao}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=tf(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,ao,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=ze(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 hn(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[l,m]=io(t.subarray(e));return e+=m,l},o=n(),s=ao;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,f=u-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:f,size:u}}static parse(t,e){let[n,o]=bg(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 oc(s).set(n,t),s}};function bg(r,t){switch(r[0]){case"Q":{let e=t??ht;return[ht.prefix,e.decode(`${ht.prefix}${r}`)]}case ht.prefix:{let e=t??ht;return[ht.prefix,e.decode(r)]}case Nt.prefix:{let e=t??Nt;return[Nt.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 xg(r,t,e){let{prefix:n}=e;if(n!==ht.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 Eg(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 ao=112,vg=18;function tf(r,t,e){let n=fn(r),o=n+fn(t),s=new Uint8Array(o+e.byteLength);return ln(r,s,0),ln(t,s,n),s.set(e,o),s}var Ag=Symbol.for("@ipld/js-cid/CID");var br={...Za,...Ha,...Ya,...Ma,...$a,...qa,...za,...ja,...Wa,...Ka},lv={...nc,...Qa};function rf(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var ef=rf("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),sc=rf("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=jt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Bg={utf8:ef,"utf-8":ef,hex:br.base16,latin1:sc,ascii:sc,binary:sc,...br},hs=Bg;function q(r,t="utf8"){let e=hs[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function ic(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return jt(i);o+i>t&&(n=jt(t),o=0);let a=n.subarray(o,o+=i);return o&7&&(o=(o|7)+1),a}}var Kr=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function ac(){}var uc=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},kg=ic();function Sg(r){return globalThis.Buffer!=null?jt(r):kg(r)}var uo=class{len;head;tail;states;constructor(){this.len=0,this.head=new Kr(ac,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Kr(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new lc((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(ds,10,Qt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Qt.fromBigInt(t);return this._push(ds,e.length(),e)}uint64Number(t){return this._push(_a,Gt(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=Qt.fromBigInt(t).zzEncode();return this._push(ds,e.length(),e)}sint64Number(t){let e=Qt.fromNumber(t).zzEncode();return this._push(ds,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(cc,1,t?1:0)}fixed32(t){return this._push(co,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Qt.fromBigInt(t);return this._push(co,4,e.lo)._push(co,4,e.hi)}fixed64Number(t){let e=Qt.fromNumber(t);return this._push(co,4,e.lo)._push(co,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(Sl,4,t)}double(t){return this._push(Rl,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(cc,1,0):this.uint32(e)._push(Rg,e,t)}string(t){let e=Cl(t);return e!==0?this.uint32(e)._push(La,e,t):this._push(cc,1,0)}fork(){return this.states=new uc(this),this.head=this.tail=new Kr(ac,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Kr(ac,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=Sg(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function cc(r,t,e){t[e]=r&255}function Ig(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var lc=class extends Kr{next;constructor(t,e){super(Ig,t,e),this.next=void 0}};function ds(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 co(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 Rg(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(uo.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(_g,t,r),this},uo.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Tg,t,r),this});function _g(r,t,e){t.set(r,e)}function Tg(r,t,e){r.length<40?La(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(q(r),e)}function fc(){return new uo}function dn(r,t){let e=fc();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var pn;(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"})(pn||(pn={}));function ps(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function lo(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 ps("enum",pn.VARINT,e,n)}function mn(r,t){return ps("message",pn.LENGTH_DELIMITED,r,t)}var Cg=Symbol.for("nodejs.util.inspect.custom"),nf=Object.values(br).map(r=>r.decoder).reduce((r,t)=>r.or(t),br.identity.decoder),of=114,hc=36,dc=37,fo=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()})`}[no]=!0;toString(){return this.string==null&&(this.string=ht.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return tt.createV1(of,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return it(this.multihash.bytes,t);if(typeof t=="string")return pc(t).equals(this);if(t?.multihash?.bytes!=null)return it(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[Cg](){return`PeerId(${this.toString()})`}},gn=class extends fo{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},yn=class extends fo{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},wn=class extends fo{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function pc(r,t){if(t=t??nf,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Ne(ht.decode(`z${r}`));return r.startsWith("12D")?new yn({multihash:e}):r.startsWith("16U")?new wn({multihash:e}):new gn({multihash:e})}return ho(nf.decode(r))}function ho(r){try{let t=Ne(r);if(t.code===Wt.code){if(t.digest.length===hc)return new yn({multihash:t});if(t.digest.length===dc)return new wn({multihash:t})}if(t.code===At.code)return new gn({multihash:t})}catch{return Ng(tt.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function Ng(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==of)throw new Error("Supplied PeerID CID is invalid");let t=r.multihash;if(t.code===At.code)return new gn({multihash:r.multihash});if(t.code===Wt.code){if(t.digest.length===hc)return new yn({multihash:r.multihash});if(t.digest.length===dc)return new wn({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function sf(r,t){return r.length===hc?new yn({multihash:Ce(Wt.code,r),privateKey:t}):r.length===dc?new wn({multihash:Ce(Wt.code,r),privateKey:t}):new gn({multihash:await At.digest(r),publicKey:r,privateKey:t})}var Kt={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 _c={};vt(_c,{Ed25519PrivateKey:()=>Gr,Ed25519PublicKey:()=>yo,generateKeyPair:()=>Hy,generateKeyPairFromSeed:()=>Nf,unmarshalEd25519PrivateKey:()=>My,unmarshalEd25519PublicKey:()=>$y});function le(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function bn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Lg(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function xn(r,...t){if(!Lg(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 ms(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");bn(r.outputLen),bn(r.blockLen)}function En(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 af(r,t){xn(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var gs=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var An=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),xe=(r,t)=>r<<32-t|r>>>t;var r2=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Ug=async()=>{};async function cf(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 Ug(),n+=s)}}function uf(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function xr(r){return typeof r=="string"&&(r=uf(r)),xn(r),r}function mc(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];xn(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 vn=class{clone(){return this._cloneInto()}},Dg={}.toString;function lf(r,t){if(t!==void 0&&Dg.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function ys(r){let t=n=>r().update(xr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Bn(r=32){if(gs&&typeof gs.getRandomValues=="function")return gs.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Pg(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 ff=(r,t,e)=>r&t^~r&e,hf=(r,t,e)=>r&t^r&e^t&e,kn=class extends vn{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=An(this.buffer)}update(t){En(this);let{view:e,buffer:n,blockLen:o}=this;t=xr(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=An(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){En(this),af(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 l=i;l<o;l++)e[l]=0;Pg(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=An(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=c/4,f=this.get();if(u>f.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<u;l++)a.setUint32(4*l,f[l],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 ws=BigInt(4294967295),gc=BigInt(32);function df(r,t=!1){return t?{h:Number(r&ws),l:Number(r>>gc&ws)}:{h:Number(r>>gc&ws)|0,l:Number(r&ws)|0}}function Og(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}=df(r[o],t);[e[o],n[o]]=[s,i]}return[e,n]}var Fg=(r,t)=>BigInt(r>>>0)<<gc|BigInt(t>>>0),Vg=(r,t,e)=>r>>>e,Mg=(r,t,e)=>r<<32-e|t>>>e,$g=(r,t,e)=>r>>>e|t<<32-e,Hg=(r,t,e)=>r<<32-e|t>>>e,Kg=(r,t,e)=>r<<64-e|t>>>e-32,qg=(r,t,e)=>r>>>e-32|t<<64-e,zg=(r,t)=>t,jg=(r,t)=>r,Gg=(r,t,e)=>r<<e|t>>>32-e,Wg=(r,t,e)=>t<<e|r>>>32-e,Yg=(r,t,e)=>t<<e-32|r>>>64-e,Zg=(r,t,e)=>r<<e-32|t>>>64-e;function Jg(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var Xg=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Qg=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,ty=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),ey=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,ry=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),ny=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var oy={fromBig:df,split:Og,toBig:Fg,shrSH:Vg,shrSL:Mg,rotrSH:$g,rotrSL:Hg,rotrBH:Kg,rotrBL:qg,rotr32H:zg,rotr32L:jg,rotlSH:Gg,rotlSL:Wg,rotlBH:Yg,rotlBL:Zg,add:Jg,add3L:Xg,add3H:Qg,add4L:ty,add4H:ey,add5H:ny,add5L:ry},z=oy;var[sy,iy]=z.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))),Er=new Uint32Array(80),vr=new Uint32Array(80),yc=class extends kn{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:f,Fh:l,Fl:m,Gh:h,Gl:p,Hh:d,Hl:w}=this;return[t,e,n,o,s,i,a,c,u,f,l,m,h,p,d,w]}set(t,e,n,o,s,i,a,c,u,f,l,m,h,p,d,w){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=f|0,this.Fh=l|0,this.Fl=m|0,this.Gh=h|0,this.Gl=p|0,this.Hh=d|0,this.Hl=w|0}process(t,e){for(let b=0;b<16;b++,e+=4)Er[b]=t.getUint32(e),vr[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let B=Er[b-15]|0,A=vr[b-15]|0,I=z.rotrSH(B,A,1)^z.rotrSH(B,A,8)^z.shrSH(B,A,7),v=z.rotrSL(B,A,1)^z.rotrSL(B,A,8)^z.shrSL(B,A,7),E=Er[b-2]|0,U=vr[b-2]|0,P=z.rotrSH(E,U,19)^z.rotrBH(E,U,61)^z.shrSH(E,U,6),N=z.rotrSL(E,U,19)^z.rotrBL(E,U,61)^z.shrSL(E,U,6),M=z.add4L(v,N,vr[b-7],vr[b-16]),C=z.add4H(M,I,P,Er[b-7],Er[b-16]);Er[b]=C|0,vr[b]=M|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:u,Dl:f,Eh:l,El:m,Fh:h,Fl:p,Gh:d,Gl:w,Hh:g,Hl:x}=this;for(let b=0;b<80;b++){let B=z.rotrSH(l,m,14)^z.rotrSH(l,m,18)^z.rotrBH(l,m,41),A=z.rotrSL(l,m,14)^z.rotrSL(l,m,18)^z.rotrBL(l,m,41),I=l&h^~l&d,v=m&p^~m&w,E=z.add5L(x,A,v,iy[b],vr[b]),U=z.add5H(E,g,B,I,sy[b],Er[b]),P=E|0,N=z.rotrSH(n,o,28)^z.rotrBH(n,o,34)^z.rotrBH(n,o,39),M=z.rotrSL(n,o,28)^z.rotrBL(n,o,34)^z.rotrBL(n,o,39),C=n&s^n&a^s&a,X=o&i^o&c^i&c;g=d|0,x=w|0,d=h|0,w=p|0,h=l|0,p=m|0,{h:l,l:m}=z.add(u|0,f|0,U|0,P|0),u=a|0,f=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let S=z.add3L(P,M,X);n=z.add3H(S,U,N,C),o=S|0}({h:n,l:o}=z.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=z.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=z.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l:f}=z.add(this.Dh|0,this.Dl|0,u|0,f|0),{h:l,l:m}=z.add(this.Eh|0,this.El|0,l|0,m|0),{h,l:p}=z.add(this.Fh|0,this.Fl|0,h|0,p|0),{h:d,l:w}=z.add(this.Gh|0,this.Gl|0,d|0,w|0),{h:g,l:x}=z.add(this.Hh|0,this.Hl|0,g|0,x|0),this.set(n,o,s,i,a,c,u,f,l,m,h,p,d,w,g,x)}roundClean(){Er.fill(0),vr.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 po=ys(()=>new yc);var xs={};vt(xs,{abytes:()=>Sn,bitGet:()=>dy,bitLen:()=>hy,bitMask:()=>mo,bitSet:()=>py,bytesToHex:()=>We,bytesToNumberBE:()=>Ye,bytesToNumberLE:()=>Br,concatBytes:()=>Ze,createHmacDrbg:()=>xc,ensureBytes:()=>mt,equalBytes:()=>ly,hexToBytes:()=>qr,hexToNumber:()=>bc,isBytes:()=>Ar,numberToBytesBE:()=>kr,numberToBytesLE:()=>zr,numberToHexUnpadded:()=>yf,numberToVarBytesBE:()=>uy,utf8ToBytes:()=>fy,validateObject:()=>Le});var gf=BigInt(0),bs=BigInt(1),ay=BigInt(2);function Ar(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function Sn(r){if(!Ar(r))throw new Error("Uint8Array expected")}var cy=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function We(r){Sn(r);let t="";for(let e=0;e<r.length;e++)t+=cy[r[e]];return t}function yf(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function bc(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Ge={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function pf(r){if(r>=Ge._0&&r<=Ge._9)return r-Ge._0;if(r>=Ge._A&&r<=Ge._F)return r-(Ge._A-10);if(r>=Ge._a&&r<=Ge._f)return r-(Ge._a-10)}function qr(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=pf(r.charCodeAt(s)),a=pf(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 Ye(r){return bc(We(r))}function Br(r){return Sn(r),bc(We(Uint8Array.from(r).reverse()))}function kr(r,t){return qr(r.toString(16).padStart(t*2,"0"))}function zr(r,t){return kr(r,t).reverse()}function uy(r){return qr(yf(r))}function mt(r,t,e){let n;if(typeof t=="string")try{n=qr(t)}catch(s){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${s}`)}else if(Ar(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 Ze(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Sn(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 ly(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 fy(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function hy(r){let t;for(t=0;r>gf;r>>=bs,t+=1);return t}function dy(r,t){return r>>BigInt(t)&bs}function py(r,t,e){return r|(e?bs:gf)<<BigInt(t)}var mo=r=>(ay<<BigInt(r-1))-bs,wc=r=>new Uint8Array(r),mf=r=>Uint8Array.from(r);function xc(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=wc(r),o=wc(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>e(o,n,...l),c=(l=wc())=>{o=a(mf([0]),l),n=a(),l.length!==0&&(o=a(mf([1]),l),n=a())},u=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,m=[];for(;l<t;){n=a();let h=n.slice();m.push(h),l+=n.length}return Ze(...m)};return(l,m)=>{i(),c(l);let h;for(;!(h=m(u()));)c();return i(),h}}var my={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"||Ar(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 Le(r,t,e={}){let n=(o,s,i)=>{let a=my[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 Bt=BigInt(0),ut=BigInt(1),jr=BigInt(2),gy=BigInt(3),Ec=BigInt(4),wf=BigInt(5),bf=BigInt(8),yy=BigInt(9),wy=BigInt(16);function at(r,t){let e=r%t;return e>=Bt?e:t+e}function by(r,t,e){if(e<=Bt||t<Bt)throw new Error("Expected power/modulo > 0");if(e===ut)return Bt;let n=ut;for(;t>Bt;)t&ut&&(n=n*r%e),r=r*r%e,t>>=ut;return n}function lt(r,t,e){let n=r;for(;t-- >Bt;)n*=n,n%=e;return n}function Es(r,t){if(r===Bt||t<=Bt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=at(r,t),n=t,o=Bt,s=ut,i=ut,a=Bt;for(;e!==Bt;){let u=n/e,f=n%e,l=o-i*u,m=s-a*u;n=e,e=f,o=i,s=a,i=l,a=m}if(n!==ut)throw new Error("invert: does not exist");return at(o,t)}function xy(r){let t=(r-ut)/jr,e,n,o;for(e=r-ut,n=0;e%jr===Bt;e/=jr,n++);for(o=jr;o<r&&by(o,t,r)!==r-ut;o++);if(n===1){let i=(r+ut)/Ec;return function(c,u){let f=c.pow(u,i);if(!c.eql(c.sqr(f),u))throw new Error("Cannot find square root");return f}}let s=(e+ut)/jr;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let u=n,f=a.pow(a.mul(a.ONE,o),e),l=a.pow(c,s),m=a.pow(c,e);for(;!a.eql(m,a.ONE);){if(a.eql(m,a.ZERO))return a.ZERO;let h=1;for(let d=a.sqr(m);h<u&&!a.eql(d,a.ONE);h++)d=a.sqr(d);let p=a.pow(f,ut<<BigInt(u-h-1));f=a.sqr(p),l=a.mul(l,p),m=a.mul(m,f),u=h}return l}}function Ey(r){if(r%Ec===gy){let t=(r+ut)/Ec;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%bf===wf){let t=(r-wf)/bf;return function(n,o){let s=n.mul(o,jr),i=n.pow(s,t),a=n.mul(o,i),c=n.mul(n.mul(a,jr),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%wy,xy(r)}var xf=(r,t)=>(at(r,t)&ut)===ut,vy=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function vc(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=vy.reduce((n,o)=>(n[o]="function",n),t);return Le(r,e)}function Ay(r,t,e){if(e<Bt)throw new Error("Expected power > 0");if(e===Bt)return r.ONE;if(e===ut)return t;let n=r.ONE,o=t;for(;e>Bt;)e&ut&&(n=r.mul(n,o)),o=r.sqr(o),e>>=ut;return n}function By(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 Ac(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function vs(r,t,e=!1,n={}){if(r<=Bt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:o,nByteLength:s}=Ac(r,t);if(s>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Ey(r),a=Object.freeze({ORDER:r,BITS:o,BYTES:s,MASK:mo(o),ZERO:Bt,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 Bt<=c&&c<r},is0:c=>c===Bt,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)=>Ay(a,c,u),div:(c,u)=>at(c*Es(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>Es(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>By(a,c),cmov:(c,u,f)=>f?u:c,toBytes:c=>e?zr(c,s):kr(c,s),fromBytes:c=>{if(c.length!==s)throw new Error(`Fp.fromBytes: expected ${s}, got ${c.length}`);return e?Br(c):Ye(c)}});return Object.freeze(a)}function Ef(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 Bc(r){let t=Ef(r);return t+Math.ceil(t/2)}function vf(r,t,e=!1){let n=r.length,o=Ef(t),s=Bc(t);if(n<16||n<s||n>1024)throw new Error(`expected ${s}-1024 bytes of input, got ${n}`);let i=e?Ye(r):Br(r),a=at(i,t-ut)+ut;return e?zr(a,o):kr(a,o)}var Sy=BigInt(0),kc=BigInt(1);function As(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>Sy;)s&kc&&(i=i.add(a)),a=a.double(),s>>=kc;return i},precomputeWindow(o,s){let{windows:i,windowSize:a}=n(s),c=[],u=o,f=u;for(let l=0;l<i;l++){f=u,c.push(f);for(let m=1;m<a;m++)f=f.add(u),c.push(f);u=f.double()}return c},wNAF(o,s,i){let{windows:a,windowSize:c}=n(o),u=r.ZERO,f=r.BASE,l=BigInt(2**o-1),m=2**o,h=BigInt(o);for(let p=0;p<a;p++){let d=p*c,w=Number(i&l);i>>=h,w>c&&(w-=m,i+=kc);let g=d,x=d+Math.abs(w)-1,b=p%2!==0,B=w<0;w===0?f=f.add(e(b,s[g])):u=u.add(e(B,s[x]))}return{p:u,f}},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 go(r){return vc(r.Fp),Le(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Ac(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ee=BigInt(0),te=BigInt(1),Bs=BigInt(2),Iy=BigInt(8),Ry={zip215:!0};function _y(r){let t=go(r);return Le(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Af(r){let t=_y(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,u=Bs<<BigInt(a*8)-te,f=e.create,l=t.uvRatio||((_,k)=>{try{return{isValid:!0,value:e.sqrt(_*e.inv(k))}}catch{return{isValid:!1,value:Ee}}}),m=t.adjustScalarBytes||(_=>_),h=t.domain||((_,k,F)=>{if(k.length||F)throw new Error("Contexts/pre-hash are not supported");return _}),p=_=>typeof _=="bigint"&&Ee<_,d=(_,k)=>p(_)&&p(k)&&_<k,w=_=>_===Ee||d(_,u);function g(_,k){if(d(_,k))return _;throw new Error(`Expected valid scalar < ${k}, got ${typeof _} ${_}`)}function x(_){return _===Ee?_:g(_,n)}let b=new Map;function B(_){if(!(_ instanceof A))throw new Error("ExtendedPoint expected")}class A{constructor(k,F,$,K){if(this.ex=k,this.ey=F,this.ez=$,this.et=K,!w(k))throw new Error("x required");if(!w(F))throw new Error("y required");if(!w($))throw new Error("z required");if(!w(K))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(k){if(k instanceof A)throw new Error("extended point not allowed");let{x:F,y:$}=k||{};if(!w(F)||!w($))throw new Error("invalid affine point");return new A(F,$,te,f(F*$))}static normalizeZ(k){let F=e.invertBatch(k.map($=>$.ez));return k.map(($,K)=>$.toAffine(F[K])).map(A.fromAffine)}_setWindowSize(k){this._WINDOW_SIZE=k,b.delete(this)}assertValidity(){let{a:k,d:F}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:$,ey:K,ez:W,et:Y}=this,rt=f($*$),J=f(K*K),Q=f(W*W),wt=f(Q*Q),dt=f(rt*k),Tt=f(Q*f(dt+J)),Ct=f(wt+f(F*f(rt*J)));if(Tt!==Ct)throw new Error("bad point: equation left != right (1)");let Et=f($*K),Ot=f(W*Y);if(Et!==Ot)throw new Error("bad point: equation left != right (2)")}equals(k){B(k);let{ex:F,ey:$,ez:K}=this,{ex:W,ey:Y,ez:rt}=k,J=f(F*rt),Q=f(W*K),wt=f($*rt),dt=f(Y*K);return J===Q&&wt===dt}is0(){return this.equals(A.ZERO)}negate(){return new A(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:k}=t,{ex:F,ey:$,ez:K}=this,W=f(F*F),Y=f($*$),rt=f(Bs*f(K*K)),J=f(k*W),Q=F+$,wt=f(f(Q*Q)-W-Y),dt=J+Y,Tt=dt-rt,Ct=J-Y,Et=f(wt*Tt),Ot=f(dt*Ct),Ke=f(wt*Ct),Or=f(Tt*dt);return new A(Et,Ot,Or,Ke)}add(k){B(k);let{a:F,d:$}=t,{ex:K,ey:W,ez:Y,et:rt}=this,{ex:J,ey:Q,ez:wt,et:dt}=k;if(F===BigInt(-1)){let ll=f((W-K)*(Q+J)),fl=f((W+K)*(Q-J)),Ea=f(fl-ll);if(Ea===Ee)return this.double();let hl=f(Y*Bs*dt),dl=f(rt*Bs*wt),pl=dl+hl,ml=fl+ll,gl=dl-hl,Z0=f(pl*Ea),J0=f(ml*gl),X0=f(pl*gl),Q0=f(Ea*ml);return new A(Z0,J0,Q0,X0)}let Tt=f(K*J),Ct=f(W*Q),Et=f(rt*$*dt),Ot=f(Y*wt),Ke=f((K+W)*(J+Q)-Tt-Ct),Or=Ot-Et,eo=Ot+Et,ul=f(Ct-F*Tt),j0=f(Ke*Or),G0=f(eo*ul),W0=f(Ke*ul),Y0=f(Or*eo);return new A(j0,G0,Y0,W0)}subtract(k){return this.add(k.negate())}wNAF(k){return E.wNAFCached(this,b,k,A.normalizeZ)}multiply(k){let{p:F,f:$}=this.wNAF(g(k,n));return A.normalizeZ([F,$])[0]}multiplyUnsafe(k){let F=x(k);return F===Ee?v:this.equals(v)||F===te?this:this.equals(I)?this.wNAF(F).p:E.unsafeLadder(this,F)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return E.unsafeLadder(this,n).is0()}toAffine(k){let{ex:F,ey:$,ez:K}=this,W=this.is0();k==null&&(k=W?Iy:e.inv(K));let Y=f(F*k),rt=f($*k),J=f(K*k);if(W)return{x:Ee,y:te};if(J!==te)throw new Error("invZ was invalid");return{x:Y,y:rt}}clearCofactor(){let{h:k}=t;return k===te?this:this.multiplyUnsafe(k)}static fromHex(k,F=!1){let{d:$,a:K}=t,W=e.BYTES;k=mt("pointHex",k,W);let Y=k.slice(),rt=k[W-1];Y[W-1]=rt&-129;let J=Br(Y);J===Ee||(F?g(J,u):g(J,e.ORDER));let Q=f(J*J),wt=f(Q-te),dt=f($*Q-K),{isValid:Tt,value:Ct}=l(wt,dt);if(!Tt)throw new Error("Point.fromHex: invalid y coordinate");let Et=(Ct&te)===te,Ot=(rt&128)!==0;if(!F&&Ct===Ee&&Ot)throw new Error("Point.fromHex: x=0 and x_0=1");return Ot!==Et&&(Ct=f(-Ct)),A.fromAffine({x:Ct,y:J})}static fromPrivateKey(k){return N(k).point}toRawBytes(){let{x:k,y:F}=this.toAffine(),$=zr(F,e.BYTES);return $[$.length-1]|=k&te?128:0,$}toHex(){return We(this.toRawBytes())}}A.BASE=new A(t.Gx,t.Gy,te,f(t.Gx*t.Gy)),A.ZERO=new A(Ee,te,te,Ee);let{BASE:I,ZERO:v}=A,E=As(A,a*8);function U(_){return at(_,n)}function P(_){return U(Br(_))}function N(_){let k=a;_=mt("private key",_,k);let F=mt("hashed private key",s(_),2*k),$=m(F.slice(0,k)),K=F.slice(k,2*k),W=P($),Y=I.multiply(W),rt=Y.toRawBytes();return{head:$,prefix:K,scalar:W,point:Y,pointBytes:rt}}function M(_){return N(_).pointBytes}function C(_=new Uint8Array,...k){let F=Ze(...k);return P(s(h(F,mt("context",_),!!o)))}function X(_,k,F={}){_=mt("message",_),o&&(_=o(_));let{prefix:$,scalar:K,pointBytes:W}=N(k),Y=C(F.context,$,_),rt=I.multiply(Y).toRawBytes(),J=C(F.context,rt,W,_),Q=U(Y+J*K);x(Q);let wt=Ze(rt,zr(Q,e.BYTES));return mt("result",wt,a*2)}let S=Ry;function T(_,k,F,$=S){let{context:K,zip215:W}=$,Y=e.BYTES;_=mt("signature",_,2*Y),k=mt("message",k),o&&(k=o(k));let rt=Br(_.slice(Y,2*Y)),J,Q,wt;try{J=A.fromHex(F,W),Q=A.fromHex(_.slice(0,Y),W),wt=I.multiplyUnsafe(rt)}catch{return!1}if(!W&&J.isSmallOrder())return!1;let dt=C(K,Q.toRawBytes(),J.toRawBytes(),k);return Q.add(J.multiplyUnsafe(dt)).subtract(wt).clearCofactor().equals(A.ZERO)}return I._setWindowSize(8),{CURVE:t,getPublicKey:M,sign:X,verify:T,ExtendedPoint:A,utils:{getExtendedPublicKey:N,randomPrivateKey:()=>i(e.BYTES),precompute(_=8,k=A.BASE){return k._setWindowSize(_),k.multiply(BigInt(3)),k}}}}var Sc=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Bf=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),k2=BigInt(0),Ty=BigInt(1),kf=BigInt(2),S2=BigInt(3),Cy=BigInt(5),Ny=BigInt(8);function Ly(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=Sc,a=r*r%s*r%s,c=lt(a,kf,s)*a%s,u=lt(c,Ty,s)*r%s,f=lt(u,Cy,s)*u%s,l=lt(f,t,s)*f%s,m=lt(l,e,s)*l%s,h=lt(m,n,s)*m%s,p=lt(h,o,s)*h%s,d=lt(p,o,s)*h%s,w=lt(d,t,s)*f%s;return{pow_p_5_8:lt(w,kf,s)*r%s,b2:a}}function Uy(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Dy(r,t){let e=Sc,n=at(t*t*t,e),o=at(n*n*t,e),s=Ly(r*o).pow_p_5_8,i=at(r*n*s,e),a=at(t*i*i,e),c=i,u=at(i*Bf,e),f=a===r,l=a===at(-r,e),m=a===at(-r*Bf,e);return f&&(i=c),(l||m)&&(i=u),xf(i,e)&&(i=at(-i,e)),{isValid:f||l,value:i}}var Py=vs(Sc,void 0,!0),Oy={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Py,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Ny,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:po,randomBytes:Bn,adjustScalarBytes:Uy,uvRatio:Dy},In=Af(Oy);var Rn=32,Je=64,ks=32;function Sf(){let r=In.utils.randomPrivateKey(),t=In.getPublicKey(r);return{privateKey:Tf(r,t),publicKey:t}}function If(r){if(r.length!==ks)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=In.getPublicKey(t);return{privateKey:Tf(t,e),publicKey:e}}function Rf(r,t){let e=r.subarray(0,ks);return In.sign(t instanceof Uint8Array?t:t.subarray(),e)}function _f(r,t,e){return In.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Tf(r,t){let e=new Uint8Array(Je);for(let n=0;n<ks;n++)e[n]=r[n],e[ks+n]=t[n];return e}var Ic={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Cf(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=Kt.get();e*=8;async function c(l,m){let h=a.getRandomValues(new Uint8Array(s)),p=a.getRandomValues(new Uint8Array(n)),d={name:t,iv:p};typeof m=="string"&&(m=q(m));let w;if(m.length===0){w=await a.subtle.importKey("jwk",Ic,{name:"AES-GCM"},!0,["encrypt"]);try{let x={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},b=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(x,b,{name:t,length:e},!0,["encrypt"])}catch{w=await a.subtle.importKey("jwk",Ic,{name:"AES-GCM"},!0,["encrypt"])}}else{let x={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},b=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(x,b,{name:t,length:e},!0,["encrypt"])}let g=await a.subtle.encrypt(d,w,l);return It([h,d.iv,new Uint8Array(g)])}async function u(l,m){let h=l.subarray(0,s),p=l.subarray(s,s+n),d=l.subarray(s+n),w={name:t,iv:p};typeof m=="string"&&(m=q(m));let g;if(m.length===0)try{let b={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},B=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(b,B,{name:t,length:e},!0,["decrypt"])}catch{g=await a.subtle.importKey("jwk",Ic,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},B=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(b,B,{name:t,length:e},!0,["decrypt"])}let x=await a.subtle.decrypt(w,g,d);return new Uint8Array(x)}return{encrypt:c,decrypt:u}}async function _n(r,t){let n=await Cf().encrypt(r,t);return ue.encode(n)}var gt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(gt||(gt={}));var Rc;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Rc||(Rc={}));(function(r){r.codec=()=>lo(Rc)})(gt||(gt={}));var Ue;(function(r){let t;r.codec=()=>(t==null&&(t=mn((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),gt.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=gt.codec().decode(e);break;case 2:o.Data=e.bytes();break;default:e.skipType(i&7);break}}return o})),t),r.encode=e=>dn(e,r.codec()),r.decode=e=>cn(e,r.codec())})(Ue||(Ue={}));var Xe;(function(r){let t;r.codec=()=>(t==null&&(t=mn((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),gt.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=gt.codec().decode(e);break;case 2:o.Data=e.bytes();break;default:e.skipType(i&7);break}}return o})),t),r.encode=e=>dn(e,r.codec()),r.decode=e=>cn(e,r.codec())})(Xe||(Xe={}));var yo=class{_key;constructor(t){this._key=Tn(t,Rn)}verify(t,e){return _f(this._key,e,t)}marshal(){return this._key}get bytes(){return Ue.encode({Type:gt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return le(t)?t.then(({bytes:e})=>e):t.bytes}},Gr=class{_key;_publicKey;constructor(t,e){this._key=Tn(t,Je),this._publicKey=Tn(e,Rn)}sign(t){return Rf(this._key,t)}get public(){return new yo(this._publicKey)}marshal(){return this._key}get bytes(){return Xe.encode({Type:gt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return le(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=Wt.digest(this.public.bytes);return ht.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return _n(this.bytes,t);throw new D(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function My(r){if(r.length>Je){r=Tn(r,Je+Rn);let n=r.subarray(0,Je),o=r.subarray(Je,r.length);return new Gr(n,o)}r=Tn(r,Je);let t=r.subarray(0,Je),e=r.subarray(Rn);return new Gr(t,e)}function $y(r){return r=Tn(r,Rn),new yo(r)}async function Hy(){let{privateKey:r,publicKey:t}=Sf();return new Gr(r,t)}async function Nf(r){let{privateKey:t,publicKey:e}=If(r);return new Gr(t,e)}function Tn(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new D(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}function j(r,t="utf8"){let e=hs[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Vc={};vt(Vc,{MAX_RSA_KEY_SIZE:()=>_o,RsaPrivateKey:()=>Dn,RsaPublicKey:()=>Ro,fromJwk:()=>mw,generateKeyPair:()=>gw,unmarshalRsaPrivateKey:()=>Oc,unmarshalRsaPublicKey:()=>pw});function De(r){if(isNaN(r)||r<=0)throw new D("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return Bn(r)}var _r={};vt(_r,{exportToPem:()=>uw,importFromPem:()=>lw,jwkToPkcs1:()=>sw,jwkToPkix:()=>aw,pkcs1ToJwk:()=>ow,pkixToJwk:()=>iw});var Is=class extends vn{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,ms(t);let n=xr(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 En(this),this.iHash.update(t),this}digestInto(t){En(this),xn(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()}},wo=(r,t,e)=>new Is(r,t).update(e).digest();wo.create=(r,t)=>new Is(r,t);function Ky(r,t,e,n){ms(r);let o=lf({dkLen:32,asyncTick:10},n),{c:s,dkLen:i,asyncTick:a}=o;if(bn(s),bn(i),bn(a),s<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=xr(t),u=xr(e),f=new Uint8Array(i),l=wo.create(r,c),m=l._cloneInto().update(u);return{c:s,dkLen:i,asyncTick:a,DK:f,PRF:l,PRFSalt:m}}function qy(r,t,e,n,o){return r.destroy(),t.destroy(),n&&n.destroy(),o.fill(0),e}async function Tc(r,t,e,n){let{c:o,dkLen:s,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=Ky(r,t,e,n),f,l=new Uint8Array(4),m=An(l),h=new Uint8Array(c.outputLen);for(let p=1,d=0;d<s;p++,d+=c.outputLen){let w=a.subarray(d,d+c.outputLen);m.setInt32(0,p,!1),(f=u._cloneInto(f)).update(l).digestInto(h),w.set(h.subarray(0,w.length)),await cf(o-1,i,()=>{c._cloneInto(f).update(h).digestInto(h);for(let g=0;g<w.length;g++)w[g]^=h[g]})}return qy(c,u,a,f,h)}var Z=Xt(Lf());function Wr(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 Sr(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 f=a-1;f>=0;f--){let l=Math.pow(2,f*t);u[s-f-1]=Math.floor(o/l),o-=u[s-f-1]*l}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Ts(...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 Nc(){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=Wr(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,Wr(s,8)-n}function Uf(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=Sr(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=Sr(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 Df(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 Yt(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 eA=Math.log(2);function Cs(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Lc(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 nr(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 xo=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Lc(this.items)}},bo=[new Uint8Array([1])],Pf="0123456789";var Ln="",Ae=new ArrayBuffer(0),Uc=new Uint8Array(0),Eo="EndOfContent",Ff="OCTET STRING",Vf="BIT STRING";function or(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):Uc}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(!nr(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",Ae)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Z.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var tr=class{constructor({blockLength:t=0,error:e=Ln,warnings:n=[],valueBeforeDecode:o=Uc}={}){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)}}};tr.NAME="baseBlock";var Mt=class extends tr{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'")}};Mt.NAME="valueBlock";var Ns=class extends or(tr){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):Uc,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",Ae}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=Sr(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(!nr(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),f=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===f){f+=255;let m=new Uint8Array(f);for(let h=0;h<u.length;h++)m[h]=u[h];u=this.valueHexView=new Uint8Array(f)}}this.blockLength=c+1,u[c-1]=s[c]&127;let l=new Uint8Array(c);for(let m=0;m<c;m++)l[m]=u[m];u=this.valueHexView=new Uint8Array(c),u.set(l),this.blockLength<=9?this.tagNumber=Wr(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}}};Ns.NAME="identificationBlock";var Ls=class extends tr{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(!nr(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=Wr(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=Sr(this.length,8);if(o.byteLength>127)return this.error="Too big length",Ae;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}}};Ls.NAME="lengthBlock";var O={},Lt=class extends tr{constructor({name:t=Ln,optional:e=!1,primitiveSchema:n,...o}={},s){super(o),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Ns(o),this.lenBlock=new Ls(o),this.valueBlock=s?new s(o):new Mt(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 xo;e||Mf(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?Ae: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 Df(e,n)}};Lt.NAME="BaseBlock";function Mf(r){if(r instanceof O.Constructed)for(let t of r.valueBlock.value)Mf(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Us=class extends Lt{constructor({value:t=Ln,...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}'`}};Us.NAME="BaseStringBlock";var Ds=class extends or(Mt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Ds.NAME="PrimitiveValueBlock";var $f,Ps=class extends Lt{constructor(t={}){super(t,Ds),this.idBlock.isConstructed=!1}};$f=Ps;O.Primitive=$f;Ps.NAME="PRIMITIVE";function Qy(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 mi(r,t=0,e=r.length){let n=t,o=new Lt({},Mt),s=new tr;if(!nr(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=Lt;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=O.EndOfContent;break;case 1:c=O.Boolean;break;case 2:c=O.Integer;break;case 3:c=O.BitString;break;case 4:c=O.OctetString;break;case 5:c=O.Null;break;case 6:c=O.ObjectIdentifier;break;case 10:c=O.Enumerated;break;case 12:c=O.Utf8String;break;case 13:c=O.RelativeObjectIdentifier;break;case 14:c=O.TIME;break;case 15:return o.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:o};case 16:c=O.Sequence;break;case 17:c=O.Set;break;case 18:c=O.NumericString;break;case 19:c=O.PrintableString;break;case 20:c=O.TeletexString;break;case 21:c=O.VideotexString;break;case 22:c=O.IA5String;break;case 23:c=O.UTCTime;break;case 24:c=O.GeneralizedTime;break;case 25:c=O.GraphicString;break;case 26:c=O.VisibleString;break;case 27:c=O.GeneralString;break;case 28:c=O.UniversalString;break;case 29:c=O.CharacterString;break;case 30:c=O.BmpString;break;case 31:c=O.DATE;break;case 32:c=O.TimeOfDay;break;case 33:c=O.DateTime;break;case 34:c=O.Duration;break;default:{let u=o.idBlock.isConstructed?new O.Constructed:new O.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?O.Constructed:O.Primitive}return o=Qy(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 Un(r){if(!r.byteLength){let t=new Lt({},Mt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return mi(Z.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function tw(r,t){return r?1:t}var Pe=class extends Mt{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(!nr(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(;tw(this.isIndefiniteForm,n)>0;){let i=mi(o,s,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(s=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===Eo)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Eo?this.value.pop():this.warnings.push("No EndOfContent block encoded")),s}toBER(t,e){let n=e||new xo;for(let o=0;o<this.value.length;o++)this.value[o].toBER(t,n);return e?Ae:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Pe.NAME="ConstructedValueBlock";var Hf,Ir=class extends Lt{constructor(t={}){super(t,Pe),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(`
2
+ "use strict";var HeliaHttp=(()=>{var nm=Object.create;var Qo=Object.defineProperty;var om=Object.getOwnPropertyDescriptor;var sm=Object.getOwnPropertyNames;var im=Object.getPrototypeOf,am=Object.prototype.hasOwnProperty;var ye=(r,t)=>()=>(t||r((t={exports:{}}).exports,t),t.exports),vt=(r,t)=>{for(var e in t)Qo(r,e,{get:t[e],enumerable:!0})},bl=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of sm(t))!am.call(r,o)&&o!==e&&Qo(r,o,{get:()=>t[o],enumerable:!(n=om(t,o))||n.enumerable});return r};var Xt=(r,t,e)=>(e=r!=null?nm(im(r)):{},bl(t||!r||!r.__esModule?Qo(e,"default",{value:r,enumerable:!0}):e,r)),cm=r=>bl(Qo({},"__esModule",{value:!0}),r);var sn=ye((uE,Il)=>{"use strict";function Sl(r,t){for(let e in t)Object.defineProperty(r,e,{value:t[e],enumerable:!0,configurable:!0});return r}function bm(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 Sl(r,e)}catch{e.message=r.message,e.stack=r.stack;let o=function(){};return o.prototype=Object.create(Object.getPrototypeOf(r)),Sl(new o,e)}}Il.exports=bm});var Pf=ye(Nn=>{"use strict";var Gy="[object ArrayBuffer]",Qe=class r{static isArrayBuffer(t){return Object.prototype.toString.call(t)===Gy}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}},Lc="string",Wy=/^[0-9a-f]+$/i,Yy=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,Zy=/^[a-zA-Z0-9-_]+$/,Rs=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=Qe.toUint8Array(t),n="";for(let s=0;s<e.length;s++)n+=String.fromCharCode(e[s]);return decodeURIComponent(escape(n))}},fe=class{static toString(t,e=!1){let n=Qe.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}},_s=class r{static isHex(t){return typeof t===Lc&&Wy.test(t)}static isBase64(t){return typeof t===Lc&&Yy.test(t)}static isBase64Url(t){return typeof t===Lc&&Zy.test(t)}static ToString(t,e="utf8"){let n=Qe.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 fe.toString(n,!0);case"utf16":case"utf16be":return fe.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 fe.fromString(t,!0);case"utf16":case"utf16be":return fe.fromString(t);default:throw new Error(`Unknown type of encoding '${e}'`)}}static ToBase64(t){let e=Qe.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 Rs.fromString(t);case"utf16":case"utf16be":return fe.fromString(t);case"utf16le":case"usc2":return fe.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 Rs.toString(t);case"utf16":case"utf16be":return fe.toString(t);case"utf16le":case"usc2":return fe.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=Qe.toUint8Array(t),n="";for(let o=0;o<e.length;o++)n+=String.fromCharCode(e[o]);return n}static ToHex(t){let e=Qe.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 fe.toString(t,e)}static FromUtf16String(t,e=!1){return fe.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,"")||""}};_s.DEFAULT_UTF8_ENCODING="utf8";function Jy(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 Xy(...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 Qy(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}Nn.BufferSourceConverter=Qe;Nn.Convert=_s;Nn.assign=Jy;Nn.combine=Xy;Nn.isEqual=Qy});var $h=ye((No,wi)=>{(function(r,t){"use strict";var e={version:"3.0.0",x86:{},x64:{},inputValidation:!0};function n(h){if(!Array.isArray(h)&&!ArrayBuffer.isView(h))return!1;for(var p=0;p<h.length;p++)if(!Number.isInteger(h[p])||h[p]<0||h[p]>255)return!1;return!0}function o(h,p){return(h&65535)*p+(((h>>>16)*p&65535)<<16)}function s(h,p){return h<<p|h>>>32-p}function i(h){return h^=h>>>16,h=o(h,2246822507),h^=h>>>13,h=o(h,3266489909),h^=h>>>16,h}function a(h,p){h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535],p=[p[0]>>>16,p[0]&65535,p[1]>>>16,p[1]&65535];var d=[0,0,0,0];return d[3]+=h[3]+p[3],d[2]+=d[3]>>>16,d[3]&=65535,d[2]+=h[2]+p[2],d[1]+=d[2]>>>16,d[2]&=65535,d[1]+=h[1]+p[1],d[0]+=d[1]>>>16,d[1]&=65535,d[0]+=h[0]+p[0],d[0]&=65535,[d[0]<<16|d[1],d[2]<<16|d[3]]}function c(h,p){h=[h[0]>>>16,h[0]&65535,h[1]>>>16,h[1]&65535],p=[p[0]>>>16,p[0]&65535,p[1]>>>16,p[1]&65535];var d=[0,0,0,0];return d[3]+=h[3]*p[3],d[2]+=d[3]>>>16,d[3]&=65535,d[2]+=h[2]*p[3],d[1]+=d[2]>>>16,d[2]&=65535,d[2]+=h[3]*p[2],d[1]+=d[2]>>>16,d[2]&=65535,d[1]+=h[1]*p[3],d[0]+=d[1]>>>16,d[1]&=65535,d[1]+=h[2]*p[2],d[0]+=d[1]>>>16,d[1]&=65535,d[1]+=h[3]*p[1],d[0]+=d[1]>>>16,d[1]&=65535,d[0]+=h[0]*p[3]+h[1]*p[2]+h[2]*p[1]+h[3]*p[0],d[0]&=65535,[d[0]<<16|d[1],d[2]<<16|d[3]]}function u(h,p){return p%=64,p===32?[h[1],h[0]]:p<32?[h[0]<<p|h[1]>>>32-p,h[1]<<p|h[0]>>>32-p]:(p-=32,[h[1]<<p|h[0]>>>32-p,h[0]<<p|h[1]>>>32-p])}function f(h,p){return p%=64,p===0?h:p<32?[h[0]<<p|h[1]>>>32-p,h[1]<<p]:[h[1]<<p-32,0]}function l(h,p){return[h[0]^p[0],h[1]^p[1]]}function m(h){return h=l(h,[0,h[0]>>>1]),h=c(h,[4283543511,3981806797]),h=l(h,[0,h[0]>>>1]),h=c(h,[3301882366,444984403]),h=l(h,[0,h[0]>>>1]),h}e.x86.hash32=function(h,p){if(e.inputValidation&&!n(h))return t;p=p||0;for(var d=h.length%4,w=h.length-d,g=p,x=0,b=3432918353,B=461845907,A=0;A<w;A=A+4)x=h[A]|h[A+1]<<8|h[A+2]<<16|h[A+3]<<24,x=o(x,b),x=s(x,15),x=o(x,B),g^=x,g=s(g,13),g=o(g,5)+3864292196;switch(x=0,d){case 3:x^=h[A+2]<<16;case 2:x^=h[A+1]<<8;case 1:x^=h[A],x=o(x,b),x=s(x,15),x=o(x,B),g^=x}return g^=h.length,g=i(g),g>>>0},e.x86.hash128=function(h,p){if(e.inputValidation&&!n(h))return t;p=p||0;for(var d=h.length%16,w=h.length-d,g=p,x=p,b=p,B=p,A=0,I=0,v=0,E=0,U=597399067,P=2869860233,N=951274213,M=2716044179,C=0;C<w;C=C+16)A=h[C]|h[C+1]<<8|h[C+2]<<16|h[C+3]<<24,I=h[C+4]|h[C+5]<<8|h[C+6]<<16|h[C+7]<<24,v=h[C+8]|h[C+9]<<8|h[C+10]<<16|h[C+11]<<24,E=h[C+12]|h[C+13]<<8|h[C+14]<<16|h[C+15]<<24,A=o(A,U),A=s(A,15),A=o(A,P),g^=A,g=s(g,19),g+=x,g=o(g,5)+1444728091,I=o(I,P),I=s(I,16),I=o(I,N),x^=I,x=s(x,17),x+=b,x=o(x,5)+197830471,v=o(v,N),v=s(v,17),v=o(v,M),b^=v,b=s(b,15),b+=B,b=o(b,5)+2530024501,E=o(E,M),E=s(E,18),E=o(E,U),B^=E,B=s(B,13),B+=g,B=o(B,5)+850148119;switch(A=0,I=0,v=0,E=0,d){case 15:E^=h[C+14]<<16;case 14:E^=h[C+13]<<8;case 13:E^=h[C+12],E=o(E,M),E=s(E,18),E=o(E,U),B^=E;case 12:v^=h[C+11]<<24;case 11:v^=h[C+10]<<16;case 10:v^=h[C+9]<<8;case 9:v^=h[C+8],v=o(v,N),v=s(v,17),v=o(v,M),b^=v;case 8:I^=h[C+7]<<24;case 7:I^=h[C+6]<<16;case 6:I^=h[C+5]<<8;case 5:I^=h[C+4],I=o(I,P),I=s(I,16),I=o(I,N),x^=I;case 4:A^=h[C+3]<<24;case 3:A^=h[C+2]<<16;case 2:A^=h[C+1]<<8;case 1:A^=h[C],A=o(A,U),A=s(A,15),A=o(A,P),g^=A}return g^=h.length,x^=h.length,b^=h.length,B^=h.length,g+=x,g+=b,g+=B,x+=g,b+=g,B+=g,g=i(g),x=i(x),b=i(b),B=i(B),g+=x,g+=b,g+=B,x+=g,b+=g,B+=g,("00000000"+(g>>>0).toString(16)).slice(-8)+("00000000"+(x>>>0).toString(16)).slice(-8)+("00000000"+(b>>>0).toString(16)).slice(-8)+("00000000"+(B>>>0).toString(16)).slice(-8)},e.x64.hash128=function(h,p){if(e.inputValidation&&!n(h))return t;p=p||0;for(var d=h.length%16,w=h.length-d,g=[0,p],x=[0,p],b=[0,0],B=[0,0],A=[2277735313,289559509],I=[1291169091,658871167],v=0;v<w;v=v+16)b=[h[v+4]|h[v+5]<<8|h[v+6]<<16|h[v+7]<<24,h[v]|h[v+1]<<8|h[v+2]<<16|h[v+3]<<24],B=[h[v+12]|h[v+13]<<8|h[v+14]<<16|h[v+15]<<24,h[v+8]|h[v+9]<<8|h[v+10]<<16|h[v+11]<<24],b=c(b,A),b=u(b,31),b=c(b,I),g=l(g,b),g=u(g,27),g=a(g,x),g=a(c(g,[0,5]),[0,1390208809]),B=c(B,I),B=u(B,33),B=c(B,A),x=l(x,B),x=u(x,31),x=a(x,g),x=a(c(x,[0,5]),[0,944331445]);switch(b=[0,0],B=[0,0],d){case 15:B=l(B,f([0,h[v+14]],48));case 14:B=l(B,f([0,h[v+13]],40));case 13:B=l(B,f([0,h[v+12]],32));case 12:B=l(B,f([0,h[v+11]],24));case 11:B=l(B,f([0,h[v+10]],16));case 10:B=l(B,f([0,h[v+9]],8));case 9:B=l(B,[0,h[v+8]]),B=c(B,I),B=u(B,33),B=c(B,A),x=l(x,B);case 8:b=l(b,f([0,h[v+7]],56));case 7:b=l(b,f([0,h[v+6]],48));case 6:b=l(b,f([0,h[v+5]],40));case 5:b=l(b,f([0,h[v+4]],32));case 4:b=l(b,f([0,h[v+3]],24));case 3:b=l(b,f([0,h[v+2]],16));case 2:b=l(b,f([0,h[v+1]],8));case 1:b=l(b,[0,h[v]]),b=c(b,A),b=u(b,31),b=c(b,I),g=l(g,b)}return g=l(g,[0,h.length]),x=l(x,[0,h.length]),g=a(g,x),x=a(x,g),g=m(g),x=m(x),g=a(g,x),x=a(x,g),("00000000"+(g[0]>>>0).toString(16)).slice(-8)+("00000000"+(g[1]>>>0).toString(16)).slice(-8)+("00000000"+(x[0]>>>0).toString(16)).slice(-8)+("00000000"+(x[1]>>>0).toString(16)).slice(-8)},typeof No<"u"?(typeof wi<"u"&&wi.exports&&(No=wi.exports=e),No.murmurHash3=e):typeof define=="function"&&define.amd?define([],function(){return e}):(e._murmurHash3=r.murmurHash3,e.noConflict=function(){return r.murmurHash3=e._murmurHash3,e._murmurHash3=t,e.noConflict=t,e},r.murmurHash3=e)})(No)});var Kh=ye((o8,Hh)=>{Hh.exports=$h()});var zh=ye((s8,qh)=>{var On=1e3,Fn=On*60,Vn=Fn*60,Zr=Vn*24,Lw=Zr*7,Uw=Zr*365.25;qh.exports=function(r,t){t=t||{};var e=typeof r;if(e==="string"&&r.length>0)return Dw(r);if(e==="number"&&isFinite(r))return t.long?Ow(r):Pw(r);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(r))};function Dw(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*Uw;case"weeks":case"week":case"w":return e*Lw;case"days":case"day":case"d":return e*Zr;case"hours":case"hour":case"hrs":case"hr":case"h":return e*Vn;case"minutes":case"minute":case"mins":case"min":case"m":return e*Fn;case"seconds":case"second":case"secs":case"sec":case"s":return e*On;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return e;default:return}}}}function Pw(r){var t=Math.abs(r);return t>=Zr?Math.round(r/Zr)+"d":t>=Vn?Math.round(r/Vn)+"h":t>=Fn?Math.round(r/Fn)+"m":t>=On?Math.round(r/On)+"s":r+"ms"}function Ow(r){var t=Math.abs(r);return t>=Zr?bi(r,t,Zr,"day"):t>=Vn?bi(r,t,Vn,"hour"):t>=Fn?bi(r,t,Fn,"minute"):t>=On?bi(r,t,On,"second"):r+" ms"}function bi(r,t,e,n){var o=t>=e*1.5;return Math.round(r/e)+" "+n+(o?"s":"")}});var Gh=ye((i8,jh)=>{function Fw(r){e.debug=e,e.default=e,e.coerce=c,e.disable=s,e.enable=o,e.enabled=i,e.humanize=zh(),e.destroy=u,Object.keys(r).forEach(f=>{e[f]=r[f]}),e.names=[],e.skips=[],e.formatters={};function t(f){let l=0;for(let m=0;m<f.length;m++)l=(l<<5)-l+f.charCodeAt(m),l|=0;return e.colors[Math.abs(l)%e.colors.length]}e.selectColor=t;function e(f){let l,m=null,h,p;function d(...w){if(!d.enabled)return;let g=d,x=Number(new Date),b=x-(l||x);g.diff=b,g.prev=l,g.curr=x,l=x,w[0]=e.coerce(w[0]),typeof w[0]!="string"&&w.unshift("%O");let B=0;w[0]=w[0].replace(/%([a-zA-Z%])/g,(I,v)=>{if(I==="%%")return"%";B++;let E=e.formatters[v];if(typeof E=="function"){let U=w[B];I=E.call(g,U),w.splice(B,1),B--}return I}),e.formatArgs.call(g,w),(g.log||e.log).apply(g,w)}return d.namespace=f,d.useColors=e.useColors(),d.color=e.selectColor(f),d.extend=n,d.destroy=e.destroy,Object.defineProperty(d,"enabled",{enumerable:!0,configurable:!1,get:()=>m!==null?m:(h!==e.namespaces&&(h=e.namespaces,p=e.enabled(f)),p),set:w=>{m=w}}),typeof e.init=="function"&&e.init(d),d}function n(f,l){let m=e(this.namespace+(typeof l>"u"?":":l)+f);return m.log=this.log,m}function o(f){e.save(f),e.namespaces=f,e.names=[],e.skips=[];let l,m=(typeof f=="string"?f:"").split(/[\s,]+/),h=m.length;for(l=0;l<h;l++)m[l]&&(f=m[l].replace(/\*/g,".*?"),f[0]==="-"?e.skips.push(new RegExp("^"+f.slice(1)+"$")):e.names.push(new RegExp("^"+f+"$")))}function s(){let f=[...e.names.map(a),...e.skips.map(a).map(l=>"-"+l)].join(",");return e.enable(""),f}function i(f){if(f[f.length-1]==="*")return!0;let l,m;for(l=0,m=e.skips.length;l<m;l++)if(e.skips[l].test(f))return!1;for(l=0,m=e.names.length;l<m;l++)if(e.names[l].test(f))return!0;return!1}function a(f){return f.toString().substring(2,f.toString().length-2).replace(/\.\*\?$/,"*")}function c(f){return f instanceof Error?f.stack||f.message:f}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}jh.exports=Fw});var Wh=ye((ee,xi)=>{ee.formatArgs=Mw;ee.save=$w;ee.load=Hw;ee.useColors=Vw;ee.storage=Kw();ee.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`."))}})();ee.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 Vw(){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 Mw(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+xi.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)}ee.log=console.debug||console.log||(()=>{});function $w(r){try{r?ee.storage.setItem("debug",r):ee.storage.removeItem("debug")}catch{}}function Hw(){let r;try{r=ee.storage.getItem("debug")}catch{}return!r&&typeof process<"u"&&"env"in process&&(r=process.env.DEBUG),r}function Kw(){try{return localStorage}catch{}}xi.exports=Gh()(ee);var{formatters:qw}=xi.exports;qw.j=function(r){try{return JSON.stringify(r)}catch(t){return"[UnexpectedJSONParseError]: "+t.message}}});var Jh=ye((f8,Wc)=>{"use strict";var jw=Object.prototype.hasOwnProperty,jt="~";function Lo(){}Object.create&&(Lo.prototype=Object.create(null),new Lo().__proto__||(jt=!1));function Gw(r,t,e){this.fn=r,this.context=t,this.once=e||!1}function Zh(r,t,e,n,o){if(typeof e!="function")throw new TypeError("The listener must be a function");var s=new Gw(e,n||r,o),i=jt?jt+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 Ei(r,t){--r._eventsCount===0?r._events=new Lo:delete r._events[t]}function $t(){this._events=new Lo,this._eventsCount=0}$t.prototype.eventNames=function(){var t=[],e,n;if(this._eventsCount===0)return t;for(n in e=this._events)jw.call(e,n)&&t.push(jt?n.slice(1):n);return Object.getOwnPropertySymbols?t.concat(Object.getOwnPropertySymbols(e)):t};$t.prototype.listeners=function(t){var e=jt?jt+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};$t.prototype.listenerCount=function(t){var e=jt?jt+t:t,n=this._events[e];return n?n.fn?1:n.length:0};$t.prototype.emit=function(t,e,n,o,s,i){var a=jt?jt+t:t;if(!this._events[a])return!1;var c=this._events[a],u=arguments.length,f,l;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(l=1,f=new Array(u-1);l<u;l++)f[l-1]=arguments[l];c.fn.apply(c.context,f)}else{var m=c.length,h;for(l=0;l<m;l++)switch(c[l].once&&this.removeListener(t,c[l].fn,void 0,!0),u){case 1:c[l].fn.call(c[l].context);break;case 2:c[l].fn.call(c[l].context,e);break;case 3:c[l].fn.call(c[l].context,e,n);break;case 4:c[l].fn.call(c[l].context,e,n,o);break;default:if(!f)for(h=1,f=new Array(u-1);h<u;h++)f[h-1]=arguments[h];c[l].fn.apply(c[l].context,f)}}return!0};$t.prototype.on=function(t,e,n){return Zh(this,t,e,n,!1)};$t.prototype.once=function(t,e,n){return Zh(this,t,e,n,!0)};$t.prototype.removeListener=function(t,e,n,o){var s=jt?jt+t:t;if(!this._events[s])return this;if(!e)return Ei(this,s),this;var i=this._events[s];if(i.fn)i.fn===e&&(!o||i.once)&&(!n||i.context===n)&&Ei(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:Ei(this,s)}return this};$t.prototype.removeAllListeners=function(t){var e;return t?(e=jt?jt+t:t,this._events[e]&&Ei(this,e)):(this._events=new Lo,this._eventsCount=0),this};$t.prototype.off=$t.prototype.removeListener;$t.prototype.addListener=$t.prototype.on;$t.prefixed=jt;$t.EventEmitter=$t;typeof Wc<"u"&&(Wc.exports=$t)});var rd=ye((U8,ed)=>{ed.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 Kp=ye(jo=>{(function(){var r,t,e,n,o,s,i,a;a=function(c){var u,f,l,m;return u=(c&255<<24)>>>24,f=(c&255<<16)>>>16,l=(c&65280)>>>8,m=c&255,[u,f,l,m].join(".")},i=function(c){var u,f,l,m,h,p;for(u=[],l=m=0;m<=3&&c.length!==0;l=++m){if(l>0){if(c[0]!==".")throw new Error("Invalid IP");c=c.substring(1)}p=t(c),h=p[0],f=p[1],c=c.substring(f),u.push(h)}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,f,l,m,h;for(m=0,u=10,f="9",l=0,c.length>1&&c[l]==="0"&&(c[l+1]==="x"||c[l+1]==="X"?(l+=2,u=16):"0"<=c[l+1]&&c[l+1]<="9"&&(l++,u=8,f="7")),h=l;l<c.length;){if("0"<=c[l]&&c[l]<=f)m=m*u+(e(c[l])-n)>>>0;else if(u===16)if("a"<=c[l]&&c[l]<="f")m=m*u+(10+e(c[l])-s)>>>0;else if("A"<=c[l]&&c[l]<="F")m=m*u+(10+e(c[l])-o)>>>0;else break;else break;if(m>4294967295)throw new Error("too large");l++}if(l===h)throw new Error("empty octet");return[m,l]},r=function(){function c(u,f){var l,m,h,p;if(typeof u!="string")throw new Error("Missing `net' parameter");if(f||(p=u.split("/",2),u=p[0],f=p[1]),f||(f=32),typeof f=="string"&&f.indexOf(".")>-1){try{this.maskLong=i(f)}catch(d){throw l=d,new Error("Invalid mask: "+f)}for(m=h=32;h>=0;m=--h)if(this.maskLong===4294967295<<32-m>>>0){this.bitmask=m;break}}else if(f||f===0)this.bitmask=parseInt(f,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(d){throw l=d,new Error("Invalid net address: "+u)}if(!(this.bitmask<=32))throw new Error("Invalid mask for ip4: "+f);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 f,l,m;for(m=i(this.first),l=i(this.last),f=0;m<=l;)u(a(m),m,f),f++,m++},c.prototype.toString=function(){return this.base+"/"+this.bitmask},c}(),jo.ip2long=i,jo.long2ip=a,jo.Netmask=r}).call(jo)});var Wu=ye((M4,Gu)=>{var V4=function(){typeof Gu<"u"&&(Gu.exports=d);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(E){var U=E-E%1;return U==0&&(E<0||E===0&&1/E!=1/0)?-0:U},f=d.prototype,l=(d.fromDate=function(E){return new d(+E)},d.fromInt64BE=B(0,1,2,3,0,4),d.fromInt64LE=B(3,2,1,0,4,0),d.fromString=function(N){var U,P=new d,N=(N+="").replace(/^\s*[+\-]?\d+/,function(C){var C=+C,X=1970+(C-1970)%400;return P.year=C-X,X}).replace(/(?:Z|([+\-]\d{2}):?(\d{2}))$/,function(M,C,X){return C<0&&(X*=-1),U=6e4*(60*+C+ +X),""}).replace(/\.\d+$/,function(M){return P.nano=+(M+c).substr(1,9),""}).split(/\D+/);if(1<N.length?N[1]--:N[1]=0,P.time=U=Date.UTC.apply(Date,N)-(U||0),isNaN(U))throw new TypeError("Invalid Date");return w(P)},d.fromTimeT=function(E){return x(E,0)},f.year=0,f.time=0,f.nano=0,f.addNano=function(E){return this.nano+=+E||0,this},f.getNano=function(){var E=w(this);return(E.time%1e3*a+ +E.nano+1e9)%1e9},f.getTimeT=function(){var U=w(this),E=Math.floor(U.time/1e3),U=U.year;return U&&(E+=U*e*r/t),E},f.getYear=function(){return this.toDate().getUTCFullYear()+this.year},f.toDate=function(){return g(w(this).time)},f.toJSON=function(){return this.toString().replace(/0{1,6}Z$/,"Z")},f.toString=function(E){var U=this,P=U.toDate(),N={H:function(){return I(P.getUTCHours())},L:function(){return v(P.getUTCMilliseconds(),3)},M:function(){return I(P.getUTCMinutes())},N:function(){return v(U.getNano(),9)},S:function(){return I(P.getUTCSeconds())},Y:function(){var M=U.getYear();return 999999<M?"+"+M:9999<M?"+"+v(M,6):0<=M?v(M,4):-999999<=M?"-"+v(-M,6):M},a:function(){return h[P.getUTCDay()]},b:function(){return m[P.getUTCMonth()]},d:function(){return I(P.getUTCDate())},e:function(){return function(M){return(9<M?"":" ")+(0|M)}(P.getUTCDate())},m:function(){return I(P.getUTCMonth()+1)}};return function M(C){return C.replace(/%./g,function(X){var T=X[1],S=p[T],T=N[T];return S?M(S):T?T():X})}(E||l)},f.writeInt64BE=b(0,1,2,3,0,4),f.writeInt64LE=b(3,2,1,0,4,0),"%Y-%m-%dT%H:%M:%S.%NZ"),m=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],h=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],p={"%":"%",F:"%Y-%m-%d",n:`
3
+ `,R:"%H:%M",T:"%H:%M:%S",t:" ",X:"%T",Z:"GMT",z:"+0000"};return d;function d(E,U,P){var N=this;if(!(N instanceof d))return new d(E,U,P);N.time=+E||0,N.nano=+U||0,N.year=+P||0,w(N)}function w(E){var U,P,N,M=E.year,C=E.time,X=E.nano,S=((X<0||a<=X)&&(X-=(P=Math.floor(X/a))*a,C+=P,P=1),M%t);return(C<-s||s<C||S)&&((U=u(C/o))&&(M+=U*t,C-=U*o),(N=g(C)).setUTCFullYear(S+N.getUTCFullYear()),N=(C=+N)+(U=u((M-=S)/t))*o,U&&-s<=N&&N<=s&&(M-=U*t,C=N),P=1),P&&(E.year=M,E.time=C,E.nano=X),E}function g(E){var U=new Date(0);return U.setTime(E),U}function x(M,N){M=+M||0;var P=u((N=(N|0)*i)/n)+u(M/n),N=N%n+M%n,M=u(N/n);return M&&(P+=M,N-=M*n),new d(1e3*N,0,P*t)}function b(E,U,P,N,M,C){return function(S,T){var _=w(this);S=S||new Array(8),A(S,T|=0);var k=Math.floor(_.time/1e3),_=_.year*(e*r/t),H=u(_/i)+u(k/i),_=_%i+k%i,k=Math.floor(_/i);return k&&(H+=k,_-=k*i),X(S,T+M,H),X(S,T+C,_),S};function X(S,T,H){S[T+E]=H>>24&255,S[T+U]=H>>16&255,S[T+P]=H>>8&255,S[T+N]=255&H}}function B(E,U,P,N,M,C){return function(S,T){A(S,T|=0);var H=X(S,T+M);return x(X(S,T+C),H)};function X(S,T){return 16777216*S[T+E]+(S[T+U]<<16|S[T+P]<<8|S[T+N])}}function A(E,U){if(E=E&&E.length,E==null)throw new TypeError("Invalid Buffer");if(E<U+8)throw new RangeError("Out of range")}function I(E){return(9<E?"":"0")+(0|E)}function v(E,U){return(c+(0|E)).substr(-U)}}()});var w1={};vt(w1,{DEFAULT_SESSION_MAX_PROVIDERS:()=>$p,DEFAULT_SESSION_MIN_PROVIDERS:()=>Mp,createHeliaHTTP:()=>y1});var no=Symbol.for("@libp2p/content-routing");var en=Symbol.for("@libp2p/peer-id");function xl(r){return r!=null&&!!r[en]}var oo=Symbol.for("@libp2p/peer-routing");var dr=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"},D=class extends Error{code;props;constructor(t,e,n){super(t),this.code=e,this.name=n?.name??"CodeError",this.props=n??{}}};var ft=(r,...t)=>{try{[...t]}catch{}};var rn=class extends EventTarget{#t=new Map;constructor(){super(),ft(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 um(t,e))}},va=class extends Event{detail;constructor(t,e){super(t,e),this.detail=e?.detail}},um=globalThis.CustomEvent??va;function El(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function pr(...r){let t=[];for(let e of r)El(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 mr(...r){let t=[];for(let e of r)El(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 Ht(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 St(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var ts=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}},nn=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new ts(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 ts(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 Aa=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Fr(r={}){return lm(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 lm(r,t){t=t??{};let e=t.onEnd,n=new nn,o,s,i,a=St(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((w,g)=>{s=x=>{s=null,n.push(x);try{w(r(n))}catch(b){g(b)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=St()})}},u=w=>s!=null?s(w):(n.push(w),o),f=w=>(n=new nn,s!=null?s({error:w}):(n.push({error:w}),o)),l=w=>{if(i)return o;if(t?.objectMode!==!0&&w?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return u({done:!1,value:w})},m=w=>i?o:(i=!0,w!=null?f(w):u({done:!0})),h=()=>(n=new nn,m(),{done:!0}),p=w=>(m(w),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:h,throw:p,push:l,end:m,get readableLength(){return n.size},onEmpty:async w=>{let g=w?.signal;if(g?.throwIfAborted(),n.isEmpty())return;let x,b;g!=null&&(x=new Promise((B,A)=>{b=()=>{A(new Aa)},g.addEventListener("abort",b)}));try{await Promise.race([a.promise,x])}finally{b!=null&&g!=null&&g?.removeEventListener("abort",b)}}},e==null)return o;let d=o;return o={[Symbol.asyncIterator](){return this},next(){return d.next()},throw(w){return d.throw(w),e!=null&&(e(w),e=void 0),{done:!0}},return(){return d.return(),e!=null&&(e(),e=void 0),{done:!0}},push:l,end(w){return d.end(w),e!=null&&(e(w),e=void 0),o},get readableLength(){return d.readableLength},onEmpty:w=>d.onEmpty(w)},o}var Ba=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 es(r,t,e,n){let o=new Ba(n?.errorMessage,n?.errorCode);return e?.aborted===!0?Promise.reject(o):new Promise((s,i)=>{function a(){e?.removeEventListener("abort",f),r.removeEventListener(t,c),n?.errorEvent!=null&&r.removeEventListener(n.errorEvent,u)}let c=l=>{try{if(n?.filter?.(l)===!1)return}catch(m){a(),i(m);return}a(),s(l)},u=l=>{a(),i(l.detail)},f=()=>{a(),i(o)};e?.addEventListener("abort",f),r.addEventListener(t,c),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,u)})}var rs=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 vl(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new rs(e?.errorMessage,e?.errorCode));let n,o=new rs(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 ns=class{deferred;signal;constructor(t){this.signal=t,this.deferred=St(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new dr)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function fm(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var os=class{id;fn;options;recipients;status;timeline;controller;constructor(t,e){this.id=fm(),this.status="queued",this.fn=t,this.options=e,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,ft(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 dr),this.cleanup())}async join(t={}){let e=new ns(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 vl(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.cleanup(),t.signal?.removeEventListener("abort",this.onAbort)})}};var qe=class extends rn{concurrency;queue;pending;sort;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.sort=t.sort,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){this.queue.push(t),this.sort!=null&&this.queue.sort(this.sort)}async add(t,e){e?.signal?.throwIfAborted();let n=new os(t,e);return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),n.join(e).then(o=>(this.safeDispatchEvent("completed",{detail:o}),this.safeDispatchEvent("success",{detail:{job:n,result:o}}),o)).catch(o=>{if(n.status==="queued"){for(let s=0;s<this.queue.length;s++)if(this.queue[s]===n){this.queue.splice(s,1);break}}throw this.safeDispatchEvent("error",{detail:o}),this.safeDispatchEvent("failure",{detail:{job:n,error:o}}),o})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(t=>{t.abort(new dr)}),this.clear()}async onEmpty(t){this.size!==0&&await es(this,"empty",t?.signal)}async onSizeLessThan(t,e){this.size<t||await es(this,"next",e?.signal,{filter:()=>this.size<t})}async onIdle(t){this.pending===0&&this.size===0||await es(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=Fr({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 D("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 ss=class extends qe{has(t){return this.find(t)!=null}find(t){return this.queue.find(e=>t.equals(e.options.peerId))}};function hm(r){return r[Symbol.asyncIterator]!=null}function dm(r){if(hm(r))return(async()=>{for await(let t of r);})();for(let t of r);}var Vr=dm;function we(r=0){return new Uint8Array(r)}function Gt(r=0){return new Uint8Array(r)}var pm=Math.pow(2,7),mm=Math.pow(2,14),gm=Math.pow(2,21),ka=Math.pow(2,28),Sa=Math.pow(2,35),Ia=Math.pow(2,42),Ra=Math.pow(2,49),st=128,Ft=127;function Wt(r){if(r<pm)return 1;if(r<mm)return 2;if(r<gm)return 3;if(r<ka)return 4;if(r<Sa)return 5;if(r<Ia)return 6;if(r<Ra)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function _a(r,t,e=0){switch(Wt(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 ym(r,t,e=0){switch(Wt(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 Ta(r,t){let e=r[t],n=0;if(n+=e&Ft,e<st||(e=r[t+1],n+=(e&Ft)<<7,e<st)||(e=r[t+2],n+=(e&Ft)<<14,e<st)||(e=r[t+3],n+=(e&Ft)<<21,e<st)||(e=r[t+4],n+=(e&Ft)*ka,e<st)||(e=r[t+5],n+=(e&Ft)*Sa,e<st)||(e=r[t+6],n+=(e&Ft)*Ia,e<st)||(e=r[t+7],n+=(e&Ft)*Ra,e<st))return n;throw new RangeError("Could not decode varint")}function wm(r,t){let e=r.get(t),n=0;if(n+=e&Ft,e<st||(e=r.get(t+1),n+=(e&Ft)<<7,e<st)||(e=r.get(t+2),n+=(e&Ft)<<14,e<st)||(e=r.get(t+3),n+=(e&Ft)<<21,e<st)||(e=r.get(t+4),n+=(e&Ft)*ka,e<st)||(e=r.get(t+5),n+=(e&Ft)*Sa,e<st)||(e=r.get(t+6),n+=(e&Ft)*Ia,e<st)||(e=r.get(t+7),n+=(e&Ft)*Ra,e<st))return n;throw new RangeError("Could not decode varint")}function on(r,t,e=0){return t==null&&(t=Gt(Wt(r))),t instanceof Uint8Array?_a(r,t,e):ym(r,t,e)}function Mr(r,t=0){return r instanceof Uint8Array?Ta(r,t):wm(r,t)}function It(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=Gt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}function it(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 kl=Symbol.for("@achingbrain/uint8arraylist");function Bl(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let o=e+n.byteLength;if(t<o)return{buf:n,index:t-e};e=o}throw new RangeError("index is out of bounds")}function is(r){return!!r?.[kl]}var as=class r{bufs;length;[kl]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(is(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(is(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=Bl(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Bl(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(is(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:o}=this._subList(t,e);return It(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:It(n,o)}sublist(t,e){let{bufs:n,length:o}=this._subList(t,e),s=new r;return s.length=o,s.bufs=[...n],s}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],o=0;for(let s=0;s<this.bufs.length;s++){let i=this.bufs[s],a=o,c=a+i.byteLength;if(o=c,t>=c)continue;let u=t>=a&&t<c,f=e>a&&e<=c;if(u&&f){if(t===a&&e===c){n.push(i);break}let l=t-a;n.push(i.subarray(l,l+(e-t)));break}if(u){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(f){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!is(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let s=256,i=new Int32Array(s);for(let l=0;l<s;l++)i[l]=-1;for(let l=0;l<o;l++)i[n[l]]=l;let a=i,c=this.byteLength-n.byteLength,u=n.byteLength-1,f;for(let l=e;l<=c;l+=f){f=0;for(let m=u;m>=0;m--){let h=this.get(l+m);if(n[m]!==h){f=Math.max(1,m-a[h]);break}}if(f===0)return l}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=Gt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let o=we(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,e,n),this.write(o,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let o=we(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,e,n),this.write(o,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let o=we(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,e,n),this.write(o,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=Gt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let o=we(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,e,n),this.write(o,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let o=we(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,e,n),this.write(o,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let o=we(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,e,n),this.write(o,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let o=we(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,e,n),this.write(o,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let o=we(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,e,n),this.write(o,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!it(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((o,s)=>o+s.byteLength,0)),n.length=e,n}};function xm(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 an=xm;function Em(r){return r[Symbol.asyncIterator]!=null}function vm(r,t){let e=0;if(Em(r))return async function*(){for await(let c of r)yield t(c,e++)}();let n=an(r),{value:o,done:s}=n.next();if(s===!0)return function*(){}();let i=t(o,e++);if(typeof i.then=="function")return async function*(){yield await i;for await(let c of n)yield t(c,e++)}();let a=t;return function*(){yield i;for(let c of n)yield a(c,e++)}()}var cn=vm;function Am(r){return r[Symbol.asyncIterator]!=null}function Bm(...r){let t=[];for(let e of r)Am(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Fr({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 $r=Bm;function km(r){return r[Symbol.asyncIterator]!=null}function Sm(r,t){return km(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 cs=Sm;var nt=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};var Ca=new Float32Array([-0]),gr=new Uint8Array(Ca.buffer);function Rl(r,t,e){Ca[0]=r,t[e]=gr[0],t[e+1]=gr[1],t[e+2]=gr[2],t[e+3]=gr[3]}function _l(r,t){return gr[0]=r[t],gr[1]=r[t+1],gr[2]=r[t+2],gr[3]=r[t+3],Ca[0]}var Na=new Float64Array([-0]),Vt=new Uint8Array(Na.buffer);function Tl(r,t,e){Na[0]=r,t[e]=Vt[0],t[e+1]=Vt[1],t[e+2]=Vt[2],t[e+3]=Vt[3],t[e+4]=Vt[4],t[e+5]=Vt[5],t[e+6]=Vt[6],t[e+7]=Vt[7]}function Cl(r,t){return Vt[0]=r[t],Vt[1]=r[t+1],Vt[2]=r[t+2],Vt[3]=r[t+3],Vt[4]=r[t+4],Vt[5]=r[t+5],Vt[6]=r[t+6],Vt[7]=r[t+7],Na[0]}var Im=BigInt(Number.MAX_SAFE_INTEGER),Rm=BigInt(Number.MIN_SAFE_INTEGER),Qt=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 Hr;if(t<Im&&t>Rm)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>Nl&&(o=0n,++n>Nl&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Hr;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):Hr}},Hr=new Qt(0,0);Hr.toBigInt=function(){return 0n};Hr.zzEncode=Hr.zzDecode=function(){return this};Hr.length=function(){return 1};var Nl=4294967296n;function Ll(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 Ul(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 La(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 be(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function us(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Ua=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,be(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 be(this,4);return us(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw be(this,4);return us(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw be(this,4);let t=_l(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw be(this,4);let t=Cl(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 be(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ul(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw be(this,t);this.pos+=t}else do if(this.pos>=this.len)throw be(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 Qt(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 be(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 be(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 be(this,8);let t=us(this.buf,this.pos+=4),e=us(this.buf,this.pos+=4);return new Qt(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=Ta(this.buf,this.pos);return this.pos+=Wt(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 Da(r){return new Ua(r instanceof Uint8Array?r:r.subarray())}function un(r,t,e){let n=Da(r);return t.decode(n,void 0,e)}var Ma={};vt(Ma,{base10:()=>Um});var RE=new Uint8Array(0);function Pl(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 ze(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Ol(r){return new TextEncoder().encode(r)}function Fl(r){return new TextDecoder().decode(r)}function _m(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),f=Math.log(256)/Math.log(a);function l(p){if(p instanceof Uint8Array||(ArrayBuffer.isView(p)?p=new Uint8Array(p.buffer,p.byteOffset,p.byteLength):Array.isArray(p)&&(p=Uint8Array.from(p))),!(p instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(p.length===0)return"";for(var d=0,w=0,g=0,x=p.length;g!==x&&p[g]===0;)g++,d++;for(var b=(x-g)*f+1>>>0,B=new Uint8Array(b);g!==x;){for(var A=p[g],I=0,v=b-1;(A!==0||I<w)&&v!==-1;v--,I++)A+=256*B[v]>>>0,B[v]=A%a>>>0,A=A/a>>>0;if(A!==0)throw new Error("Non-zero carry");w=I,g++}for(var E=b-w;E!==b&&B[E]===0;)E++;for(var U=c.repeat(d);E<b;++E)U+=r.charAt(B[E]);return U}function m(p){if(typeof p!="string")throw new TypeError("Expected String");if(p.length===0)return new Uint8Array;var d=0;if(p[d]!==" "){for(var w=0,g=0;p[d]===c;)w++,d++;for(var x=(p.length-d)*u+1>>>0,b=new Uint8Array(x);p[d];){var B=e[p.charCodeAt(d)];if(B===255)return;for(var A=0,I=x-1;(B!==0||A<g)&&I!==-1;I--,A++)B+=a*b[I]>>>0,b[I]=B%256>>>0,B=B/256>>>0;if(B!==0)throw new Error("Non-zero carry");g=A,d++}if(p[d]!==" "){for(var v=x-g;v!==x&&b[v]===0;)v++;for(var E=new Uint8Array(w+(x-v)),U=w;v!==x;)E[U++]=b[v++];return E}}}function h(p){var d=m(p);if(d)return d;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:m,decode:h}}var Tm=_m,Cm=Tm,Ml=Cm;var Pa=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")}},Oa=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 $l(this,t)}},Fa=class{decoders;constructor(t){this.decoders=t}or(t){return $l(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 $l(r,t){return new Fa({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Va=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 Pa(t,e,n),this.decoder=new Oa(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function ln({name:r,prefix:t,encode:e,decode:n}){return new Va(r,t,e,n)}function yr({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Ml(e,r);return ln({prefix:t,name:r,encode:n,decode:s=>ze(o(s))})}function Nm(r,t,e,n){let o={};for(let f=0;f<t.length;++f)o[t[f]]=f;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 f=0;f<s;++f){let l=o[r[f]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|l,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 Lm(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 pt({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return ln({prefix:t,name:r,encode(o){return Lm(o,n,e)},decode(o){return Nm(o,n,e,r)}})}var Um=yr({prefix:"9",name:"base10",alphabet:"0123456789"});var $a={};vt($a,{base16:()=>Dm,base16upper:()=>Pm});var Dm=pt({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Pm=pt({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ha={};vt(Ha,{base2:()=>Om});var Om=pt({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ka={};vt(Ka,{base256emoji:()=>Hm});var Hl=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}"),Fm=Hl.reduce((r,t,e)=>(r[e]=t,r),[]),Vm=Hl.reduce((r,t,e)=>(r[t.codePointAt(0)]=e,r),[]);function Mm(r){return r.reduce((t,e)=>(t+=Fm[e],t),"")}function $m(r){let t=[];for(let e of r){let n=Vm[e.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${e}`);t.push(n)}return new Uint8Array(t)}var Hm=ln({prefix:"\u{1F680}",name:"base256emoji",encode:Mm,decode:$m});var qa={};vt(qa,{base32:()=>Nt,base32hex:()=>zm,base32hexpad:()=>Gm,base32hexpadupper:()=>Wm,base32hexupper:()=>jm,base32pad:()=>Km,base32padupper:()=>qm,base32upper:()=>Kl,base32z:()=>Ym});var Nt=pt({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Kl=pt({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Km=pt({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),qm=pt({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),zm=pt({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),jm=pt({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Gm=pt({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Wm=pt({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Ym=pt({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var za={};vt(za,{base36:()=>wr,base36upper:()=>Zm});var wr=yr({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Zm=yr({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ja={};vt(ja,{base58btc:()=>ht,base58flickr:()=>Jm});var ht=yr({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Jm=yr({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Wa={};vt(Wa,{base64:()=>ue,base64pad:()=>Xm,base64url:()=>Ga,base64urlpad:()=>Qm});var ue=pt({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Xm=pt({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Ga=pt({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Qm=pt({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ya={};vt(Ya,{base8:()=>tg});var tg=pt({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Za={};vt(Za,{identity:()=>eg});var eg=ln({prefix:"\0",name:"identity",encode:r=>Fl(r),decode:r=>Ol(r)});var qE=new TextEncoder,zE=new TextDecoder;var ql=512;var ls=85;var Qa={};vt(Qa,{identity:()=>Kt});var rg=Wl,jl=128,ng=127,og=~ng,sg=Math.pow(2,31);function Wl(r,t,e){t=t||[],e=e||0;for(var n=e;r>=sg;)t[e++]=r&255|jl,r/=128;for(;r&og;)t[e++]=r&255|jl,r>>>=7;return t[e]=r|0,Wl.bytes=e-n+1,t}var ig=Xa,ag=128,Gl=127;function Xa(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw Xa.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&Gl)<<o:(i&Gl)*Math.pow(2,o),o+=7}while(i>=ag);return Xa.bytes=s-n,e}var cg=Math.pow(2,7),ug=Math.pow(2,14),lg=Math.pow(2,21),fg=Math.pow(2,28),hg=Math.pow(2,35),dg=Math.pow(2,42),pg=Math.pow(2,49),mg=Math.pow(2,56),gg=Math.pow(2,63),yg=function(r){return r<cg?1:r<ug?2:r<lg?3:r<fg?4:r<hg?5:r<dg?6:r<pg?7:r<mg?8:r<gg?9:10},wg={encode:rg,decode:ig,encodingLength:yg},bg=wg,so=bg;function io(r,t=0){return[so.decode(r,t),so.decode.bytes]}function fn(r,t,e=0){return so.encode(r,t,e),t}function hn(r){return so.encodingLength(r)}function Ce(r,t){let e=t.byteLength,n=hn(r),o=n+hn(e),s=new Uint8Array(o+e);return fn(r,s,0),fn(e,s,n),s.set(t,o),new dn(r,e,t,s)}function Ne(r){let t=ze(r),[e,n]=io(t),[o,s]=io(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new dn(e,o,i,t)}function Yl(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Pl(r.bytes,e.bytes)}}var dn=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};var Zl=0,xg="identity",Jl=ze;function Eg(r){return Ce(Zl,Jl(r))}var Kt={code:Zl,name:xg,encode:Jl,digest:Eg};var nc={};vt(nc,{sha256:()=>At,sha512:()=>rc});function ec({name:r,code:t,encode:e}){return new tc(r,t,e)}var tc=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?Ce(this.code,e):e.then(n=>Ce(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Ql(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var At=ec({name:"sha2-256",code:18,encode:Ql("SHA-256")}),rc=ec({name:"sha2-512",code:19,encode:Ql("SHA-512")});function tf(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Ag(e,oc(r),t??ht.encoder);default:return Bg(e,oc(r),t??Nt.encoder)}}var ef=new WeakMap;function oc(r){let t=ef.get(r);if(t==null){let e=new Map;return ef.set(r,e),e}return t}var Q=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!==ao)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==kg)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=Ce(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&&Yl(t.multihash,n.multihash)}toString(t){return tf(this,t)}toJSON(){return{"/":tf(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??rf(n,o,s.bytes))}else if(e[Sg]===!0){let{version:n,multihash:o,code:s}=e,i=Ne(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!==ao)throw new Error(`Version 0 CID must use dag-pb (code: ${ao}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=rf(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,ao,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=ze(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 dn(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[l,m]=io(t.subarray(e));return e+=m,l},o=n(),s=ao;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,f=u-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:f,size:u}}static parse(t,e){let[n,o]=vg(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 oc(s).set(n,t),s}};function vg(r,t){switch(r[0]){case"Q":{let e=t??ht;return[ht.prefix,e.decode(`${ht.prefix}${r}`)]}case ht.prefix:{let e=t??ht;return[ht.prefix,e.decode(r)]}case Nt.prefix:{let e=t??Nt;return[Nt.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 Ag(r,t,e){let{prefix:n}=e;if(n!==ht.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 Bg(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 ao=112,kg=18;function rf(r,t,e){let n=hn(r),o=n+hn(t),s=new Uint8Array(o+e.byteLength);return fn(r,s,0),fn(t,s,n),s.set(e,o),s}var Sg=Symbol.for("@ipld/js-cid/CID");var br={...Za,...Ha,...Ya,...Ma,...$a,...qa,...za,...ja,...Wa,...Ka},hv={...nc,...Qa};function of(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var nf=of("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),sc=of("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=Gt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Ig={utf8:nf,"utf-8":nf,hex:br.base16,latin1:sc,ascii:sc,binary:sc,...br},hs=Ig;function q(r,t="utf8"){let e=hs[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function ic(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return Gt(i);o+i>t&&(n=Gt(t),o=0);let a=n.subarray(o,o+=i);return o&7&&(o=(o|7)+1),a}}var Kr=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function ac(){}var uc=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Rg=ic();function _g(r){return globalThis.Buffer!=null?Gt(r):Rg(r)}var uo=class{len;head;tail;states;constructor(){this.len=0,this.head=new Kr(ac,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Kr(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new lc((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(ds,10,Qt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Qt.fromBigInt(t);return this._push(ds,e.length(),e)}uint64Number(t){return this._push(_a,Wt(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=Qt.fromBigInt(t).zzEncode();return this._push(ds,e.length(),e)}sint64Number(t){let e=Qt.fromNumber(t).zzEncode();return this._push(ds,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(cc,1,t?1:0)}fixed32(t){return this._push(co,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Qt.fromBigInt(t);return this._push(co,4,e.lo)._push(co,4,e.hi)}fixed64Number(t){let e=Qt.fromNumber(t);return this._push(co,4,e.lo)._push(co,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(Rl,4,t)}double(t){return this._push(Tl,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(cc,1,0):this.uint32(e)._push(Cg,e,t)}string(t){let e=Ll(t);return e!==0?this.uint32(e)._push(La,e,t):this._push(cc,1,0)}fork(){return this.states=new uc(this),this.head=this.tail=new Kr(ac,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Kr(ac,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=_g(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function cc(r,t,e){t[e]=r&255}function Tg(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var lc=class extends Kr{next;constructor(t,e){super(Tg,t,e),this.next=void 0}};function ds(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 co(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 Cg(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(uo.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Ng,t,r),this},uo.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Lg,t,r),this});function Ng(r,t,e){t.set(r,e)}function Lg(r,t,e){r.length<40?La(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(q(r),e)}function fc(){return new uo}function pn(r,t){let e=fc();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var mn;(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"})(mn||(mn={}));function ps(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function lo(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 ps("enum",mn.VARINT,e,n)}function gn(r,t){return ps("message",mn.LENGTH_DELIMITED,r,t)}function z(r,t="utf8"){let e=hs[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var af=Symbol.for("nodejs.util.inspect.custom"),sf=Object.values(br).map(r=>r.decoder).reduce((r,t)=>r.or(t),br.identity.decoder),cf=114,pc=36,mc=37,fo=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()})`}[en]=!0;toString(){return this.string==null&&(this.string=ht.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return Q.createV1(cf,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return it(this.multihash.bytes,t);if(typeof t=="string")return gc(t).equals(this);if(t?.multihash?.bytes!=null)return it(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[af](){return`PeerId(${this.toString()})`}},yn=class extends fo{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},wn=class extends fo{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},bn=class extends fo{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}},hc=2336,dc=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Kt.digest(q(this.url))}[af](){return`PeerId(${this.url})`}[en]=!0;toString(){return this.toCID().toString()}toCID(){return Q.createV1(hc,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=z(t)),t.toString()===this.toString())}};function gc(r,t){if(t=t??sf,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Ne(ht.decode(`z${r}`));return r.startsWith("12D")?new wn({multihash:e}):r.startsWith("16U")?new bn({multihash:e}):new yn({multihash:e})}return ho(sf.decode(r))}function ho(r){try{let t=Ne(r);if(t.code===Kt.code){if(t.digest.length===pc)return new wn({multihash:t});if(t.digest.length===mc)return new bn({multihash:t})}if(t.code===At.code)return new yn({multihash:t})}catch{return Ug(Q.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function Ug(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==cf&&r.code!==hc)throw new Error("Supplied PeerID CID is invalid");if(r.code===hc){let e=z(r.multihash.digest);return new dc(new URL(e))}let t=r.multihash;if(t.code===At.code)return new yn({multihash:r.multihash});if(t.code===Kt.code){if(t.digest.length===pc)return new wn({multihash:r.multihash});if(t.digest.length===mc)return new bn({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function uf(r,t){return r.length===pc?new wn({multihash:Ce(Kt.code,r),privateKey:t}):r.length===mc?new bn({multihash:Ce(Kt.code,r),privateKey:t}):new yn({multihash:await At.digest(r),publicKey:r,privateKey:t})}var qt={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 Cc={};vt(Cc,{Ed25519PrivateKey:()=>Gr,Ed25519PublicKey:()=>yo,generateKeyPair:()=>qy,generateKeyPairFromSeed:()=>Df,unmarshalEd25519PrivateKey:()=>Hy,unmarshalEd25519PublicKey:()=>Ky});function le(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function xn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`positive integer expected, not ${r}`)}function Dg(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function En(r,...t){if(!Dg(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 ms(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");xn(r.outputLen),xn(r.blockLen)}function vn(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 lf(r,t){En(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var gs=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;var Bn=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),xe=(r,t)=>r<<32-t|r>>>t;var c2=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;var Pg=async()=>{};async function ff(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 Pg(),n+=s)}}function hf(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function xr(r){return typeof r=="string"&&(r=hf(r)),En(r),r}function yc(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];En(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 An=class{clone(){return this._cloneInto()}},Og={}.toString;function df(r,t){if(t!==void 0&&Og.call(t)!=="[object Object]")throw new Error("Options should be object or undefined");return Object.assign(r,t)}function ys(r){let t=n=>r().update(xr(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function kn(r=32){if(gs&&typeof gs.getRandomValues=="function")return gs.getRandomValues(new Uint8Array(r));throw new Error("crypto.getRandomValues must be defined")}function Fg(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 pf=(r,t,e)=>r&t^~r&e,mf=(r,t,e)=>r&t^r&e^t&e,Sn=class extends An{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=Bn(this.buffer)}update(t){vn(this);let{view:e,buffer:n,blockLen:o}=this;t=xr(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=Bn(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){vn(this),lf(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 l=i;l<o;l++)e[l]=0;Fg(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=Bn(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=c/4,f=this.get();if(u>f.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<u;l++)a.setUint32(4*l,f[l],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 ws=BigInt(4294967295),wc=BigInt(32);function gf(r,t=!1){return t?{h:Number(r&ws),l:Number(r>>wc&ws)}:{h:Number(r>>wc&ws)|0,l:Number(r&ws)|0}}function Vg(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}=gf(r[o],t);[e[o],n[o]]=[s,i]}return[e,n]}var Mg=(r,t)=>BigInt(r>>>0)<<wc|BigInt(t>>>0),$g=(r,t,e)=>r>>>e,Hg=(r,t,e)=>r<<32-e|t>>>e,Kg=(r,t,e)=>r>>>e|t<<32-e,qg=(r,t,e)=>r<<32-e|t>>>e,zg=(r,t,e)=>r<<64-e|t>>>e-32,jg=(r,t,e)=>r>>>e-32|t<<64-e,Gg=(r,t)=>t,Wg=(r,t)=>r,Yg=(r,t,e)=>r<<e|t>>>32-e,Zg=(r,t,e)=>t<<e|r>>>32-e,Jg=(r,t,e)=>t<<e-32|r>>>64-e,Xg=(r,t,e)=>r<<e-32|t>>>64-e;function Qg(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var ty=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),ey=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,ry=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),ny=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,oy=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),sy=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var iy={fromBig:gf,split:Vg,toBig:Mg,shrSH:$g,shrSL:Hg,rotrSH:Kg,rotrSL:qg,rotrBH:zg,rotrBL:jg,rotr32H:Gg,rotr32L:Wg,rotlSH:Yg,rotlSL:Zg,rotlBH:Jg,rotlBL:Xg,add:Qg,add3L:ty,add3H:ey,add4L:ry,add4H:ny,add5H:sy,add5L:oy},j=iy;var[ay,cy]=j.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))),Er=new Uint32Array(80),vr=new Uint32Array(80),bc=class extends Sn{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:f,Fh:l,Fl:m,Gh:h,Gl:p,Hh:d,Hl:w}=this;return[t,e,n,o,s,i,a,c,u,f,l,m,h,p,d,w]}set(t,e,n,o,s,i,a,c,u,f,l,m,h,p,d,w){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=f|0,this.Fh=l|0,this.Fl=m|0,this.Gh=h|0,this.Gl=p|0,this.Hh=d|0,this.Hl=w|0}process(t,e){for(let b=0;b<16;b++,e+=4)Er[b]=t.getUint32(e),vr[b]=t.getUint32(e+=4);for(let b=16;b<80;b++){let B=Er[b-15]|0,A=vr[b-15]|0,I=j.rotrSH(B,A,1)^j.rotrSH(B,A,8)^j.shrSH(B,A,7),v=j.rotrSL(B,A,1)^j.rotrSL(B,A,8)^j.shrSL(B,A,7),E=Er[b-2]|0,U=vr[b-2]|0,P=j.rotrSH(E,U,19)^j.rotrBH(E,U,61)^j.shrSH(E,U,6),N=j.rotrSL(E,U,19)^j.rotrBL(E,U,61)^j.shrSL(E,U,6),M=j.add4L(v,N,vr[b-7],vr[b-16]),C=j.add4H(M,I,P,Er[b-7],Er[b-16]);Er[b]=C|0,vr[b]=M|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:u,Dl:f,Eh:l,El:m,Fh:h,Fl:p,Gh:d,Gl:w,Hh:g,Hl:x}=this;for(let b=0;b<80;b++){let B=j.rotrSH(l,m,14)^j.rotrSH(l,m,18)^j.rotrBH(l,m,41),A=j.rotrSL(l,m,14)^j.rotrSL(l,m,18)^j.rotrBL(l,m,41),I=l&h^~l&d,v=m&p^~m&w,E=j.add5L(x,A,v,cy[b],vr[b]),U=j.add5H(E,g,B,I,ay[b],Er[b]),P=E|0,N=j.rotrSH(n,o,28)^j.rotrBH(n,o,34)^j.rotrBH(n,o,39),M=j.rotrSL(n,o,28)^j.rotrBL(n,o,34)^j.rotrBL(n,o,39),C=n&s^n&a^s&a,X=o&i^o&c^i&c;g=d|0,x=w|0,d=h|0,w=p|0,h=l|0,p=m|0,{h:l,l:m}=j.add(u|0,f|0,U|0,P|0),u=a|0,f=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let S=j.add3L(P,M,X);n=j.add3H(S,U,N,C),o=S|0}({h:n,l:o}=j.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=j.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=j.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l:f}=j.add(this.Dh|0,this.Dl|0,u|0,f|0),{h:l,l:m}=j.add(this.Eh|0,this.El|0,l|0,m|0),{h,l:p}=j.add(this.Fh|0,this.Fl|0,h|0,p|0),{h:d,l:w}=j.add(this.Gh|0,this.Gl|0,d|0,w|0),{h:g,l:x}=j.add(this.Hh|0,this.Hl|0,g|0,x|0),this.set(n,o,s,i,a,c,u,f,l,m,h,p,d,w,g,x)}roundClean(){Er.fill(0),vr.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 po=ys(()=>new bc);var xs={};vt(xs,{abytes:()=>In,bitGet:()=>my,bitLen:()=>py,bitMask:()=>mo,bitSet:()=>gy,bytesToHex:()=>We,bytesToNumberBE:()=>Ye,bytesToNumberLE:()=>Br,concatBytes:()=>Ze,createHmacDrbg:()=>vc,ensureBytes:()=>mt,equalBytes:()=>hy,hexToBytes:()=>qr,hexToNumber:()=>Ec,isBytes:()=>Ar,numberToBytesBE:()=>kr,numberToBytesLE:()=>zr,numberToHexUnpadded:()=>xf,numberToVarBytesBE:()=>fy,utf8ToBytes:()=>dy,validateObject:()=>Le});var bf=BigInt(0),bs=BigInt(1),uy=BigInt(2);function Ar(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}function In(r){if(!Ar(r))throw new Error("Uint8Array expected")}var ly=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function We(r){In(r);let t="";for(let e=0;e<r.length;e++)t+=ly[r[e]];return t}function xf(r){let t=r.toString(16);return t.length&1?`0${t}`:t}function Ec(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return BigInt(r===""?"0":`0x${r}`)}var Ge={_0:48,_9:57,_A:65,_F:70,_a:97,_f:102};function yf(r){if(r>=Ge._0&&r<=Ge._9)return r-Ge._0;if(r>=Ge._A&&r<=Ge._F)return r-(Ge._A-10);if(r>=Ge._a&&r<=Ge._f)return r-(Ge._a-10)}function qr(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=yf(r.charCodeAt(s)),a=yf(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 Ye(r){return Ec(We(r))}function Br(r){return In(r),Ec(We(Uint8Array.from(r).reverse()))}function kr(r,t){return qr(r.toString(16).padStart(t*2,"0"))}function zr(r,t){return kr(r,t).reverse()}function fy(r){return qr(xf(r))}function mt(r,t,e){let n;if(typeof t=="string")try{n=qr(t)}catch(s){throw new Error(`${r} must be valid hex string, got "${t}". Cause: ${s}`)}else if(Ar(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 Ze(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];In(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 hy(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 dy(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function py(r){let t;for(t=0;r>bf;r>>=bs,t+=1);return t}function my(r,t){return r>>BigInt(t)&bs}function gy(r,t,e){return r|(e?bs:bf)<<BigInt(t)}var mo=r=>(uy<<BigInt(r-1))-bs,xc=r=>new Uint8Array(r),wf=r=>Uint8Array.from(r);function vc(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=xc(r),o=xc(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>e(o,n,...l),c=(l=xc())=>{o=a(wf([0]),l),n=a(),l.length!==0&&(o=a(wf([1]),l),n=a())},u=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,m=[];for(;l<t;){n=a();let h=n.slice();m.push(h),l+=n.length}return Ze(...m)};return(l,m)=>{i(),c(l);let h;for(;!(h=m(u()));)c();return i(),h}}var yy={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"||Ar(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 Le(r,t,e={}){let n=(o,s,i)=>{let a=yy[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 Bt=BigInt(0),ut=BigInt(1),jr=BigInt(2),wy=BigInt(3),Ac=BigInt(4),Ef=BigInt(5),vf=BigInt(8),by=BigInt(9),xy=BigInt(16);function at(r,t){let e=r%t;return e>=Bt?e:t+e}function Ey(r,t,e){if(e<=Bt||t<Bt)throw new Error("Expected power/modulo > 0");if(e===ut)return Bt;let n=ut;for(;t>Bt;)t&ut&&(n=n*r%e),r=r*r%e,t>>=ut;return n}function lt(r,t,e){let n=r;for(;t-- >Bt;)n*=n,n%=e;return n}function Es(r,t){if(r===Bt||t<=Bt)throw new Error(`invert: expected positive integers, got n=${r} mod=${t}`);let e=at(r,t),n=t,o=Bt,s=ut,i=ut,a=Bt;for(;e!==Bt;){let u=n/e,f=n%e,l=o-i*u,m=s-a*u;n=e,e=f,o=i,s=a,i=l,a=m}if(n!==ut)throw new Error("invert: does not exist");return at(o,t)}function vy(r){let t=(r-ut)/jr,e,n,o;for(e=r-ut,n=0;e%jr===Bt;e/=jr,n++);for(o=jr;o<r&&Ey(o,t,r)!==r-ut;o++);if(n===1){let i=(r+ut)/Ac;return function(c,u){let f=c.pow(u,i);if(!c.eql(c.sqr(f),u))throw new Error("Cannot find square root");return f}}let s=(e+ut)/jr;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let u=n,f=a.pow(a.mul(a.ONE,o),e),l=a.pow(c,s),m=a.pow(c,e);for(;!a.eql(m,a.ONE);){if(a.eql(m,a.ZERO))return a.ZERO;let h=1;for(let d=a.sqr(m);h<u&&!a.eql(d,a.ONE);h++)d=a.sqr(d);let p=a.pow(f,ut<<BigInt(u-h-1));f=a.sqr(p),l=a.mul(l,p),m=a.mul(m,f),u=h}return l}}function Ay(r){if(r%Ac===wy){let t=(r+ut)/Ac;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%vf===Ef){let t=(r-Ef)/vf;return function(n,o){let s=n.mul(o,jr),i=n.pow(s,t),a=n.mul(o,i),c=n.mul(n.mul(a,jr),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%xy,vy(r)}var Af=(r,t)=>(at(r,t)&ut)===ut,By=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Bc(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=By.reduce((n,o)=>(n[o]="function",n),t);return Le(r,e)}function ky(r,t,e){if(e<Bt)throw new Error("Expected power > 0");if(e===Bt)return r.ONE;if(e===ut)return t;let n=r.ONE,o=t;for(;e>Bt;)e&ut&&(n=r.mul(n,o)),o=r.sqr(o),e>>=ut;return n}function Sy(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 kc(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function vs(r,t,e=!1,n={}){if(r<=Bt)throw new Error(`Expected Field ORDER > 0, got ${r}`);let{nBitLength:o,nByteLength:s}=kc(r,t);if(s>2048)throw new Error("Field lengths over 2048 bytes are not supported");let i=Ay(r),a=Object.freeze({ORDER:r,BITS:o,BYTES:s,MASK:mo(o),ZERO:Bt,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 Bt<=c&&c<r},is0:c=>c===Bt,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)=>ky(a,c,u),div:(c,u)=>at(c*Es(u,r),r),sqrN:c=>c*c,addN:(c,u)=>c+u,subN:(c,u)=>c-u,mulN:(c,u)=>c*u,inv:c=>Es(c,r),sqrt:n.sqrt||(c=>i(a,c)),invertBatch:c=>Sy(a,c),cmov:(c,u,f)=>f?u:c,toBytes:c=>e?zr(c,s):kr(c,s),fromBytes:c=>{if(c.length!==s)throw new Error(`Fp.fromBytes: expected ${s}, got ${c.length}`);return e?Br(c):Ye(c)}});return Object.freeze(a)}function Bf(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 Sc(r){let t=Bf(r);return t+Math.ceil(t/2)}function kf(r,t,e=!1){let n=r.length,o=Bf(t),s=Sc(t);if(n<16||n<s||n>1024)throw new Error(`expected ${s}-1024 bytes of input, got ${n}`);let i=e?Ye(r):Br(r),a=at(i,t-ut)+ut;return e?zr(a,o):kr(a,o)}var Ry=BigInt(0),Ic=BigInt(1);function As(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>Ry;)s&Ic&&(i=i.add(a)),a=a.double(),s>>=Ic;return i},precomputeWindow(o,s){let{windows:i,windowSize:a}=n(s),c=[],u=o,f=u;for(let l=0;l<i;l++){f=u,c.push(f);for(let m=1;m<a;m++)f=f.add(u),c.push(f);u=f.double()}return c},wNAF(o,s,i){let{windows:a,windowSize:c}=n(o),u=r.ZERO,f=r.BASE,l=BigInt(2**o-1),m=2**o,h=BigInt(o);for(let p=0;p<a;p++){let d=p*c,w=Number(i&l);i>>=h,w>c&&(w-=m,i+=Ic);let g=d,x=d+Math.abs(w)-1,b=p%2!==0,B=w<0;w===0?f=f.add(e(b,s[g])):u=u.add(e(B,s[x]))}return{p:u,f}},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 go(r){return Bc(r.Fp),Le(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...kc(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ee=BigInt(0),te=BigInt(1),Bs=BigInt(2),_y=BigInt(8),Ty={zip215:!0};function Cy(r){let t=go(r);return Le(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Sf(r){let t=Cy(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,u=Bs<<BigInt(a*8)-te,f=e.create,l=t.uvRatio||((_,k)=>{try{return{isValid:!0,value:e.sqrt(_*e.inv(k))}}catch{return{isValid:!1,value:Ee}}}),m=t.adjustScalarBytes||(_=>_),h=t.domain||((_,k,F)=>{if(k.length||F)throw new Error("Contexts/pre-hash are not supported");return _}),p=_=>typeof _=="bigint"&&Ee<_,d=(_,k)=>p(_)&&p(k)&&_<k,w=_=>_===Ee||d(_,u);function g(_,k){if(d(_,k))return _;throw new Error(`Expected valid scalar < ${k}, got ${typeof _} ${_}`)}function x(_){return _===Ee?_:g(_,n)}let b=new Map;function B(_){if(!(_ instanceof A))throw new Error("ExtendedPoint expected")}class A{constructor(k,F,$,K){if(this.ex=k,this.ey=F,this.ez=$,this.et=K,!w(k))throw new Error("x required");if(!w(F))throw new Error("y required");if(!w($))throw new Error("z required");if(!w(K))throw new Error("t required")}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(k){if(k instanceof A)throw new Error("extended point not allowed");let{x:F,y:$}=k||{};if(!w(F)||!w($))throw new Error("invalid affine point");return new A(F,$,te,f(F*$))}static normalizeZ(k){let F=e.invertBatch(k.map($=>$.ez));return k.map(($,K)=>$.toAffine(F[K])).map(A.fromAffine)}_setWindowSize(k){this._WINDOW_SIZE=k,b.delete(this)}assertValidity(){let{a:k,d:F}=t;if(this.is0())throw new Error("bad point: ZERO");let{ex:$,ey:K,ez:W,et:Y}=this,rt=f($*$),J=f(K*K),tt=f(W*W),wt=f(tt*tt),dt=f(rt*k),Tt=f(tt*f(dt+J)),Ct=f(wt+f(F*f(rt*J)));if(Tt!==Ct)throw new Error("bad point: equation left != right (1)");let Et=f($*K),Ot=f(W*Y);if(Et!==Ot)throw new Error("bad point: equation left != right (2)")}equals(k){B(k);let{ex:F,ey:$,ez:K}=this,{ex:W,ey:Y,ez:rt}=k,J=f(F*rt),tt=f(W*K),wt=f($*rt),dt=f(Y*K);return J===tt&&wt===dt}is0(){return this.equals(A.ZERO)}negate(){return new A(f(-this.ex),this.ey,this.ez,f(-this.et))}double(){let{a:k}=t,{ex:F,ey:$,ez:K}=this,W=f(F*F),Y=f($*$),rt=f(Bs*f(K*K)),J=f(k*W),tt=F+$,wt=f(f(tt*tt)-W-Y),dt=J+Y,Tt=dt-rt,Ct=J-Y,Et=f(wt*Tt),Ot=f(dt*Ct),Ke=f(wt*Ct),Or=f(Tt*dt);return new A(Et,Ot,Or,Ke)}add(k){B(k);let{a:F,d:$}=t,{ex:K,ey:W,ez:Y,et:rt}=this,{ex:J,ey:tt,ez:wt,et:dt}=k;if(F===BigInt(-1)){let hl=f((W-K)*(tt+J)),dl=f((W+K)*(tt-J)),Ea=f(dl-hl);if(Ea===Ee)return this.double();let pl=f(Y*Bs*dt),ml=f(rt*Bs*wt),gl=ml+pl,yl=dl+hl,wl=ml-pl,Q0=f(gl*Ea),tm=f(yl*wl),em=f(gl*wl),rm=f(Ea*yl);return new A(Q0,tm,rm,em)}let Tt=f(K*J),Ct=f(W*tt),Et=f(rt*$*dt),Ot=f(Y*wt),Ke=f((K+W)*(J+tt)-Tt-Ct),Or=Ot-Et,ro=Ot+Et,fl=f(Ct-F*Tt),Y0=f(Ke*Or),Z0=f(ro*fl),J0=f(Ke*fl),X0=f(Or*ro);return new A(Y0,Z0,X0,J0)}subtract(k){return this.add(k.negate())}wNAF(k){return E.wNAFCached(this,b,k,A.normalizeZ)}multiply(k){let{p:F,f:$}=this.wNAF(g(k,n));return A.normalizeZ([F,$])[0]}multiplyUnsafe(k){let F=x(k);return F===Ee?v:this.equals(v)||F===te?this:this.equals(I)?this.wNAF(F).p:E.unsafeLadder(this,F)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return E.unsafeLadder(this,n).is0()}toAffine(k){let{ex:F,ey:$,ez:K}=this,W=this.is0();k==null&&(k=W?_y:e.inv(K));let Y=f(F*k),rt=f($*k),J=f(K*k);if(W)return{x:Ee,y:te};if(J!==te)throw new Error("invZ was invalid");return{x:Y,y:rt}}clearCofactor(){let{h:k}=t;return k===te?this:this.multiplyUnsafe(k)}static fromHex(k,F=!1){let{d:$,a:K}=t,W=e.BYTES;k=mt("pointHex",k,W);let Y=k.slice(),rt=k[W-1];Y[W-1]=rt&-129;let J=Br(Y);J===Ee||(F?g(J,u):g(J,e.ORDER));let tt=f(J*J),wt=f(tt-te),dt=f($*tt-K),{isValid:Tt,value:Ct}=l(wt,dt);if(!Tt)throw new Error("Point.fromHex: invalid y coordinate");let Et=(Ct&te)===te,Ot=(rt&128)!==0;if(!F&&Ct===Ee&&Ot)throw new Error("Point.fromHex: x=0 and x_0=1");return Ot!==Et&&(Ct=f(-Ct)),A.fromAffine({x:Ct,y:J})}static fromPrivateKey(k){return N(k).point}toRawBytes(){let{x:k,y:F}=this.toAffine(),$=zr(F,e.BYTES);return $[$.length-1]|=k&te?128:0,$}toHex(){return We(this.toRawBytes())}}A.BASE=new A(t.Gx,t.Gy,te,f(t.Gx*t.Gy)),A.ZERO=new A(Ee,te,te,Ee);let{BASE:I,ZERO:v}=A,E=As(A,a*8);function U(_){return at(_,n)}function P(_){return U(Br(_))}function N(_){let k=a;_=mt("private key",_,k);let F=mt("hashed private key",s(_),2*k),$=m(F.slice(0,k)),K=F.slice(k,2*k),W=P($),Y=I.multiply(W),rt=Y.toRawBytes();return{head:$,prefix:K,scalar:W,point:Y,pointBytes:rt}}function M(_){return N(_).pointBytes}function C(_=new Uint8Array,...k){let F=Ze(...k);return P(s(h(F,mt("context",_),!!o)))}function X(_,k,F={}){_=mt("message",_),o&&(_=o(_));let{prefix:$,scalar:K,pointBytes:W}=N(k),Y=C(F.context,$,_),rt=I.multiply(Y).toRawBytes(),J=C(F.context,rt,W,_),tt=U(Y+J*K);x(tt);let wt=Ze(rt,zr(tt,e.BYTES));return mt("result",wt,a*2)}let S=Ty;function T(_,k,F,$=S){let{context:K,zip215:W}=$,Y=e.BYTES;_=mt("signature",_,2*Y),k=mt("message",k),o&&(k=o(k));let rt=Br(_.slice(Y,2*Y)),J,tt,wt;try{J=A.fromHex(F,W),tt=A.fromHex(_.slice(0,Y),W),wt=I.multiplyUnsafe(rt)}catch{return!1}if(!W&&J.isSmallOrder())return!1;let dt=C(K,tt.toRawBytes(),J.toRawBytes(),k);return tt.add(J.multiplyUnsafe(dt)).subtract(wt).clearCofactor().equals(A.ZERO)}return I._setWindowSize(8),{CURVE:t,getPublicKey:M,sign:X,verify:T,ExtendedPoint:A,utils:{getExtendedPublicKey:N,randomPrivateKey:()=>i(e.BYTES),precompute(_=8,k=A.BASE){return k._setWindowSize(_),k.multiply(BigInt(3)),k}}}}var Rc=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),If=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),C2=BigInt(0),Ny=BigInt(1),Rf=BigInt(2),N2=BigInt(3),Ly=BigInt(5),Uy=BigInt(8);function Dy(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=Rc,a=r*r%s*r%s,c=lt(a,Rf,s)*a%s,u=lt(c,Ny,s)*r%s,f=lt(u,Ly,s)*u%s,l=lt(f,t,s)*f%s,m=lt(l,e,s)*l%s,h=lt(m,n,s)*m%s,p=lt(h,o,s)*h%s,d=lt(p,o,s)*h%s,w=lt(d,t,s)*f%s;return{pow_p_5_8:lt(w,Rf,s)*r%s,b2:a}}function Py(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Oy(r,t){let e=Rc,n=at(t*t*t,e),o=at(n*n*t,e),s=Dy(r*o).pow_p_5_8,i=at(r*n*s,e),a=at(t*i*i,e),c=i,u=at(i*If,e),f=a===r,l=a===at(-r,e),m=a===at(-r*If,e);return f&&(i=c),(l||m)&&(i=u),Af(i,e)&&(i=at(-i,e)),{isValid:f||l,value:i}}var Fy=vs(Rc,void 0,!0),Vy={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Fy,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Uy,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:po,randomBytes:kn,adjustScalarBytes:Py,uvRatio:Oy},Rn=Sf(Vy);var _n=32,Je=64,ks=32;function _f(){let r=Rn.utils.randomPrivateKey(),t=Rn.getPublicKey(r);return{privateKey:Lf(r,t),publicKey:t}}function Tf(r){if(r.length!==ks)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=Rn.getPublicKey(t);return{privateKey:Lf(t,e),publicKey:e}}function Cf(r,t){let e=r.subarray(0,ks);return Rn.sign(t instanceof Uint8Array?t:t.subarray(),e)}function Nf(r,t,e){return Rn.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}function Lf(r,t){let e=new Uint8Array(Je);for(let n=0;n<ks;n++)e[n]=r[n],e[ks+n]=t[n];return e}var _c={alg:"A128GCM",ext:!0,k:"scm9jmO_4BJAgdwWGVulLg",key_ops:["encrypt","decrypt"],kty:"oct"};function Uf(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=qt.get();e*=8;async function c(l,m){let h=a.getRandomValues(new Uint8Array(s)),p=a.getRandomValues(new Uint8Array(n)),d={name:t,iv:p};typeof m=="string"&&(m=q(m));let w;if(m.length===0){w=await a.subtle.importKey("jwk",_c,{name:"AES-GCM"},!0,["encrypt"]);try{let x={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},b=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(x,b,{name:t,length:e},!0,["encrypt"])}catch{w=await a.subtle.importKey("jwk",_c,{name:"AES-GCM"},!0,["encrypt"])}}else{let x={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},b=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);w=await a.subtle.deriveKey(x,b,{name:t,length:e},!0,["encrypt"])}let g=await a.subtle.encrypt(d,w,l);return It([h,d.iv,new Uint8Array(g)])}async function u(l,m){let h=l.subarray(0,s),p=l.subarray(s,s+n),d=l.subarray(s+n),w={name:t,iv:p};typeof m=="string"&&(m=q(m));let g;if(m.length===0)try{let b={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},B=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(b,B,{name:t,length:e},!0,["decrypt"])}catch{g=await a.subtle.importKey("jwk",_c,{name:"AES-GCM"},!0,["decrypt"])}else{let b={name:"PBKDF2",salt:h,iterations:i,hash:{name:o}},B=await a.subtle.importKey("raw",m,{name:"PBKDF2"},!1,["deriveKey"]);g=await a.subtle.deriveKey(b,B,{name:t,length:e},!0,["decrypt"])}let x=await a.subtle.decrypt(w,g,d);return new Uint8Array(x)}return{encrypt:c,decrypt:u}}async function Tn(r,t){let n=await Uf().encrypt(r,t);return ue.encode(n)}var gt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.Secp256k1="Secp256k1"})(gt||(gt={}));var Tc;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.Secp256k1=2]="Secp256k1"})(Tc||(Tc={}));(function(r){r.codec=()=>lo(Tc)})(gt||(gt={}));var Ue;(function(r){let t;r.codec=()=>(t==null&&(t=gn((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),gt.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=gt.codec().decode(e);break;case 2:o.Data=e.bytes();break;default:e.skipType(i&7);break}}return o})),t),r.encode=e=>pn(e,r.codec()),r.decode=e=>un(e,r.codec())})(Ue||(Ue={}));var Xe;(function(r){let t;r.codec=()=>(t==null&&(t=gn((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),gt.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=gt.codec().decode(e);break;case 2:o.Data=e.bytes();break;default:e.skipType(i&7);break}}return o})),t),r.encode=e=>pn(e,r.codec()),r.decode=e=>un(e,r.codec())})(Xe||(Xe={}));var yo=class{_key;constructor(t){this._key=Cn(t,_n)}verify(t,e){return Nf(this._key,e,t)}marshal(){return this._key}get bytes(){return Ue.encode({Type:gt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return le(t)?t.then(({bytes:e})=>e):t.bytes}},Gr=class{_key;_publicKey;constructor(t,e){this._key=Cn(t,Je),this._publicKey=Cn(e,_n)}sign(t){return Cf(this._key,t)}get public(){return new yo(this._publicKey)}marshal(){return this._key}get bytes(){return Xe.encode({Type:gt.Ed25519,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return le(t)?{bytes:e}=await t:e=t.bytes,e}async id(){let t=Kt.digest(this.public.bytes);return ht.encode(t.bytes).substring(1)}async export(t,e="libp2p-key"){if(e==="libp2p-key")return Tn(this.bytes,t);throw new D(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Hy(r){if(r.length>Je){r=Cn(r,Je+_n);let n=r.subarray(0,Je),o=r.subarray(Je,r.length);return new Gr(n,o)}r=Cn(r,Je);let t=r.subarray(0,Je),e=r.subarray(_n);return new Gr(t,e)}function Ky(r){return r=Cn(r,_n),new yo(r)}async function qy(){let{privateKey:r,publicKey:t}=_f();return new Gr(r,t)}async function Df(r){let{privateKey:t,publicKey:e}=Tf(r);return new Gr(t,e)}function Cn(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new D(`Key must be a Uint8Array of length ${t}, got ${r.length}`,"ERR_INVALID_KEY_TYPE");return r}var $c={};vt($c,{MAX_RSA_KEY_SIZE:()=>_o,RsaPrivateKey:()=>Pn,RsaPublicKey:()=>Ro,fromJwk:()=>yw,generateKeyPair:()=>ww,unmarshalRsaPrivateKey:()=>Vc,unmarshalRsaPublicKey:()=>gw});function De(r){if(isNaN(r)||r<=0)throw new D("random bytes length must be a Number bigger than 0","ERR_INVALID_LENGTH");return kn(r)}var _r={};vt(_r,{exportToPem:()=>fw,importFromPem:()=>hw,jwkToPkcs1:()=>aw,jwkToPkix:()=>uw,pkcs1ToJwk:()=>iw,pkixToJwk:()=>cw});var Is=class extends An{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,ms(t);let n=xr(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 vn(this),this.iHash.update(t),this}digestInto(t){vn(this),En(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()}},wo=(r,t,e)=>new Is(r,t).update(e).digest();wo.create=(r,t)=>new Is(r,t);function zy(r,t,e,n){ms(r);let o=df({dkLen:32,asyncTick:10},n),{c:s,dkLen:i,asyncTick:a}=o;if(xn(s),xn(i),xn(a),s<1)throw new Error("PBKDF2: iterations (c) should be >= 1");let c=xr(t),u=xr(e),f=new Uint8Array(i),l=wo.create(r,c),m=l._cloneInto().update(u);return{c:s,dkLen:i,asyncTick:a,DK:f,PRF:l,PRFSalt:m}}function jy(r,t,e,n,o){return r.destroy(),t.destroy(),n&&n.destroy(),o.fill(0),e}async function Nc(r,t,e,n){let{c:o,dkLen:s,asyncTick:i,DK:a,PRF:c,PRFSalt:u}=zy(r,t,e,n),f,l=new Uint8Array(4),m=Bn(l),h=new Uint8Array(c.outputLen);for(let p=1,d=0;d<s;p++,d+=c.outputLen){let w=a.subarray(d,d+c.outputLen);m.setInt32(0,p,!1),(f=u._cloneInto(f)).update(l).digestInto(h),w.set(h.subarray(0,w.length)),await ff(o-1,i,()=>{c._cloneInto(f).update(h).digestInto(h);for(let g=0;g<w.length;g++)w[g]^=h[g]})}return jy(c,u,a,f,h)}var Z=Xt(Pf());function Wr(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 Sr(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 f=a-1;f>=0;f--){let l=Math.pow(2,f*t);u[s-f-1]=Math.floor(o/l),o-=u[s-f-1]*l}return c}i*=Math.pow(2,t)}return new ArrayBuffer(0)}function Ts(...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 Uc(){let r=new Uint8Array(this.valueHex);if(this.valueHex.byteLength>=2){let a=r[0]===255&&r[1]&128,c=r[0]===0&&(r[1]&128)===0;(a||c)&&this.warnings.push("Needlessly long format")}let 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=Wr(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,Wr(s,8)-n}function Of(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=Sr(i,8,n),c=new Uint8Array(a);return c[0]|=128,a}let o=Sr(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 Ff(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 Yt(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 sA=Math.log(2);function Cs(){if(typeof BigInt>"u")throw new Error("BigInt is not defined. Your environment doesn't implement BigInt.")}function Dc(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 nr(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 xo=class{constructor(){this.items=[]}write(t){this.items.push(t)}final(){return Dc(this.items)}},bo=[new Uint8Array([1])],Vf="0123456789";var Un="",Ae=new ArrayBuffer(0),Pc=new Uint8Array(0),Eo="EndOfContent",$f="OCTET STRING",Hf="BIT STRING";function or(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):Pc}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(!nr(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",Ae)}toJSON(){return{...super.toJSON(),isHexOnly:this.isHexOnly,valueHex:Z.Convert.ToHex(this.valueHexView)}}},t.NAME="hexBlock",t}var tr=class{constructor({blockLength:t=0,error:e=Un,warnings:n=[],valueBeforeDecode:o=Pc}={}){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)}}};tr.NAME="baseBlock";var Mt=class extends tr{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'")}};Mt.NAME="valueBlock";var Ns=class extends or(tr){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):Pc,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",Ae}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=Sr(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(!nr(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),f=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===f){f+=255;let m=new Uint8Array(f);for(let h=0;h<u.length;h++)m[h]=u[h];u=this.valueHexView=new Uint8Array(f)}}this.blockLength=c+1,u[c-1]=s[c]&127;let l=new Uint8Array(c);for(let m=0;m<c;m++)l[m]=u[m];u=this.valueHexView=new Uint8Array(c),u.set(l),this.blockLength<=9?this.tagNumber=Wr(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}}};Ns.NAME="identificationBlock";var Ls=class extends tr{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(!nr(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=Wr(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=Sr(this.length,8);if(o.byteLength>127)return this.error="Too big length",Ae;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}}};Ls.NAME="lengthBlock";var O={},Lt=class extends tr{constructor({name:t=Un,optional:e=!1,primitiveSchema:n,...o}={},s){super(o),this.name=t,this.optional=e,n&&(this.primitiveSchema=n),this.idBlock=new Ns(o),this.lenBlock=new Ls(o),this.valueBlock=s?new s(o):new Mt(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 xo;e||Kf(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?Ae: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 Ff(e,n)}};Lt.NAME="BaseBlock";function Kf(r){if(r instanceof O.Constructed)for(let t of r.valueBlock.value)Kf(t)&&(r.lenBlock.isIndefiniteForm=!0);return!!r.lenBlock.isIndefiniteForm}var Us=class extends Lt{constructor({value:t=Un,...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}'`}};Us.NAME="BaseStringBlock";var Ds=class extends or(Mt){constructor({isHexOnly:t=!0,...e}={}){super(e),this.isHexOnly=t}};Ds.NAME="PrimitiveValueBlock";var qf,Ps=class extends Lt{constructor(t={}){super(t,Ds),this.idBlock.isConstructed=!1}};qf=Ps;O.Primitive=qf;Ps.NAME="PRIMITIVE";function ew(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 mi(r,t=0,e=r.length){let n=t,o=new Lt({},Mt),s=new tr;if(!nr(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=Lt;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=O.EndOfContent;break;case 1:c=O.Boolean;break;case 2:c=O.Integer;break;case 3:c=O.BitString;break;case 4:c=O.OctetString;break;case 5:c=O.Null;break;case 6:c=O.ObjectIdentifier;break;case 10:c=O.Enumerated;break;case 12:c=O.Utf8String;break;case 13:c=O.RelativeObjectIdentifier;break;case 14:c=O.TIME;break;case 15:return o.error="[UNIVERSAL 15] is reserved by ASN.1 standard",{offset:-1,result:o};case 16:c=O.Sequence;break;case 17:c=O.Set;break;case 18:c=O.NumericString;break;case 19:c=O.PrintableString;break;case 20:c=O.TeletexString;break;case 21:c=O.VideotexString;break;case 22:c=O.IA5String;break;case 23:c=O.UTCTime;break;case 24:c=O.GeneralizedTime;break;case 25:c=O.GraphicString;break;case 26:c=O.VisibleString;break;case 27:c=O.GeneralString;break;case 28:c=O.UniversalString;break;case 29:c=O.CharacterString;break;case 30:c=O.BmpString;break;case 31:c=O.DATE;break;case 32:c=O.TimeOfDay;break;case 33:c=O.DateTime;break;case 34:c=O.Duration;break;default:{let u=o.idBlock.isConstructed?new O.Constructed:new O.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?O.Constructed:O.Primitive}return o=ew(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 Dn(r){if(!r.byteLength){let t=new Lt({},Mt);return t.error="Input buffer has zero length",{offset:-1,result:t}}return mi(Z.BufferSourceConverter.toUint8Array(r).slice(),0,r.byteLength)}function rw(r,t){return r?1:t}var Pe=class extends Mt{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(!nr(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(;rw(this.isIndefiniteForm,n)>0;){let i=mi(o,s,n);if(i.offset===-1)return this.error=i.result.error,this.warnings.concat(i.result.warnings),-1;if(s=i.offset,this.blockLength+=i.result.blockLength,n-=i.result.blockLength,this.value.push(i.result),this.isIndefiniteForm&&i.result.constructor.NAME===Eo)break}return this.isIndefiniteForm&&(this.value[this.value.length-1].constructor.NAME===Eo?this.value.pop():this.warnings.push("No EndOfContent block encoded")),s}toBER(t,e){let n=e||new xo;for(let o=0;o<this.value.length;o++)this.value[o].toBER(t,n);return e?Ae:n.final()}toJSON(){let t={...super.toJSON(),isIndefiniteForm:this.isIndefiniteForm,value:[]};for(let e of this.value)t.value.push(e.toJSON());return t}};Pe.NAME="ConstructedValueBlock";var zf,Ir=class extends Lt{constructor(t={}){super(t,Pe),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
5
  `));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
6
6
  ${t.join(`
7
- `)}`:`${e} :`}};Hf=Ir;O.Constructed=Hf;Ir.NAME="CONSTRUCTED";var Os=class extends Mt{fromBER(t,e,n){return e}toBER(t){return Ae}};Os.override="EndOfContentValueBlock";var Kf,Fs=class extends Lt{constructor(t={}){super(t,Os),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};Kf=Fs;O.EndOfContent=Kf;Fs.NAME=Eo;var qf,Rr=class extends Lt{constructor(t={}){super(t,Mt),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}`}};qf=Rr;O.Null=qf;Rr.NAME="NULL";var Vs=class extends or(Mt){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 nr(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,Nc.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Vs.NAME="BooleanValueBlock";var zf,Ms=class extends Lt{constructor(t={}){super(t,Vs),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}`}};zf=Ms;O.Boolean=zf;Ms.NAME="BOOLEAN";var $s=class extends or(Pe){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=Pe.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===Eo){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==Ff)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?Pe.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};$s.NAME="OctetStringValueBlock";var jf,er=class r extends Lt{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},$s),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=mi(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?Ir.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)}};jf=er;O.OctetString=jf;er.NAME=Ff;var Hs=class extends or(Pe){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=Pe.prototype.fromBER.call(this,t,e,n),o===-1)return o;for(let a of this.value){let c=a.constructor.NAME;if(c===Eo){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Vf)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(!nr(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=mi(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 Pe.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Ae;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}}};Hs.NAME="BitStringValueBlock";var Gf,Nn=class extends Lt{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},Hs),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 Ir.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)}`}}};Gf=Nn;O.BitString=Gf;Nn.NAME=Vf;var Wf;function ew(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,f=c<i?i:c,l=0;for(let m=f;m>=0;m--,l++){switch(!0){case l<a.length:u=s[i-l]+a[c-l]+e[0];break;default:u=s[i-l]+e[0]}switch(e[0]=u/10,!0){case l>=s.length:s=Ts(new Uint8Array([u%10]),s);break;default:s[i-l]=u%10}}return e[0]>0&&(s=Ts(e,s)),s}function Of(r){if(r>=bo.length)for(let t=bo.length;t<=r;t++){let e=new Uint8Array([0]),n=bo[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=Ts(e,n)),bo.push(n)}return bo[r]}function rw(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,f=0;for(let l=c;l>=0;l--,f++)switch(u=s[i-f]-a[c-f]-e,!0){case u<0:e=1,s[i-f]=u+10;break;default:e=0,s[i-f]=u}if(e>0)for(let l=i-c+1;l>=0;l--,f++)if(u=s[i-f]-e,u<0)e=1,s[i-f]=u+10;else{e=0,s[i-f]=u;break}return s.slice()}var vo=class extends or(Mt){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=Nc.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Uf(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=rw(Of(n),e),i="-";break;default:e=ew(e,Of(n))}n++,o>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Pf.charAt(e[c]));return a===!1&&(i+=Pf.charAt(0)),i}};Wf=vo;vo.NAME="IntegerValueBlock";Object.defineProperty(Wf.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Yf,bt=class r extends Lt{constructor(t={}){super(t,vo),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Cs(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Cs();let e=BigInt(t),n=new xo,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,f=Z.BufferSourceConverter.toUint8Array(Z.Convert.FromHex(u.toString(16)));f[0]|=128,n.write(f)}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()}`}};Yf=bt;O.Integer=Yf;bt.NAME="INTEGER";var Zf,Ks=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Zf=Ks;O.Enumerated=Zf;Ks.NAME="ENUMERATED";var Ao=class extends or(Mt){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(!nr(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=Wr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Cs();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=Sr(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ae;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}}};Ao.NAME="sidBlock";var qs=class extends Mt{constructor({value:t=Ln,...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.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,Ae;e.push(o)}return Lc(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 Ao;if(o>Number.MAX_SAFE_INTEGER){Cs();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 Jf,ve=class extends Lt{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()}}};Jf=ve;O.ObjectIdentifier=Jf;ve.NAME="OBJECT IDENTIFIER";var Bo=class extends or(tr){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(!nr(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=Wr(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=Sr(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ae;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}}};Bo.NAME="relativeSidBlock";var zs=class extends Mt{constructor({value:t=Ln,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let o=e;for(;n>0;){let s=new Bo;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,Ae;n.push(s)}return Lc(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 Bo;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}};zs.NAME="RelativeObjectIdentifierValueBlock";var Xf,js=class extends Lt{constructor(t={}){super(t,zs),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()}}};Xf=js;O.RelativeObjectIdentifier=Xf;js.NAME="RelativeObjectIdentifier";var Qf,Rt=class extends Ir{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};Qf=Rt;O.Sequence=Qf;Rt.NAME="SEQUENCE";var th,Gs=class extends Ir{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};th=Gs;O.Set=th;Gs.NAME="SET";var Ws=class extends or(Mt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Ln}toJSON(){return{...super.toJSON(),value:this.value}}};Ws.NAME="StringValueBlock";var Ys=class extends Ws{};Ys.NAME="SimpleStringValueBlock";var qt=class extends Us{constructor({...t}={}){super(t,Ys)}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}};qt.NAME="SIMPLE STRING";var Zs=class extends qt{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}};Zs.NAME="Utf8StringValueBlock";var eh,rr=class extends Zs{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};eh=rr;O.Utf8String=eh;rr.NAME="UTF8String";var Js=class extends qt{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))}};Js.NAME="BmpStringValueBlock";var rh,Xs=class extends Js{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};rh=Xs;O.BmpString=rh;Xs.NAME="BMPString";var Qs=class extends qt{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=Sr(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}};Qs.NAME="UniversalStringValueBlock";var nh,ti=class extends Qs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};nh=ti;O.UniversalString=nh;ti.NAME="UniversalString";var oh,ei=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};oh=ei;O.NumericString=oh;ei.NAME="NumericString";var sh,ri=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};sh=ri;O.PrintableString=sh;ri.NAME="PrintableString";var ih,ni=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};ih=ni;O.TeletexString=ih;ni.NAME="TeletexString";var ah,oi=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};ah=oi;O.VideotexString=ah;oi.NAME="VideotexString";var ch,si=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};ch=si;O.IA5String=ch;si.NAME="IA5String";var uh,ii=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};uh=ii;O.GraphicString=uh;ii.NAME="GraphicString";var lh,ko=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};lh=ko;O.VisibleString=lh;ko.NAME="VisibleString";var fh,ai=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};fh=ai;O.GeneralString=fh;ai.NAME="GeneralString";var hh,ci=class extends qt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};hh=ci;O.CharacterString=hh;ci.NAME="CharacterString";var dh,So=class extends ko{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]=Yt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Yt(this.month,2),e[2]=Yt(this.day,2),e[3]=Yt(this.hour,2),e[4]=Yt(this.minute,2),e[5]=Yt(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}}};dh=So;O.UTCTime=dh;So.NAME="UTCTime";var ph,ui=class extends So{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 l=new Number(t[t.length-1]);if(isNaN(l.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 l=1,m=n.indexOf("+"),h="";if(m===-1&&(m=n.indexOf("-"),l=-1),m!==-1){if(h=n.substring(m+1),n=n.substring(0,m),h.length!==2&&h.length!==4)throw new Error("Wrong input string for conversion");let p=parseInt(h.substring(0,2),10);if(isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*p,h.length===4){if(p=parseInt(h.substring(2,4),10),isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");c=l*p}}}let u=n.indexOf(".");if(u===-1&&(u=n.indexOf(",")),u!==-1){let l=new Number(`0${n.substring(u)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");s=l.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 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,u!==-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,u!==-1){let l=1e3*s;this.millisecond=Math.floor(l)}break;default:throw new Error("Wrong input string for conversion")}let f=i.exec(o);if(f===null)throw new Error("Wrong input string for conversion");for(let l=1;l<f.length;l++)switch(l){case 1:this.year=parseInt(f[l],10);break;case 2:this.month=parseInt(f[l],10);break;case 3:this.day=parseInt(f[l],10);break;case 4:this.hour=parseInt(f[l],10)+a;break;case 5:this.minute=parseInt(f[l],10)+c;break;case 6:this.second=parseInt(f[l],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!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(t="iso"){if(t==="iso"){let e=[];return e.push(Yt(this.year,4)),e.push(Yt(this.month,2)),e.push(Yt(this.day,2)),e.push(Yt(this.hour,2)),e.push(Yt(this.minute,2)),e.push(Yt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Yt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};ph=ui;O.GeneralizedTime=ph;ui.NAME="GeneralizedTime";var mh,li=class extends rr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};mh=li;O.DATE=mh;li.NAME="DATE";var gh,fi=class extends rr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};gh=fi;O.TimeOfDay=gh;fi.NAME="TimeOfDay";var yh,hi=class extends rr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};yh=hi;O.DateTime=yh;hi.NAME="DateTime";var wh,di=class extends rr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};wh=di;O.Duration=wh;di.NAME="Duration";var bh,pi=class extends rr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};bh=pi;O.TIME=bh;pi.NAME="TIME";function ow(r){let{result:t}=Un(r),e=t.valueBlock.value;return{n:j(Oe(e[1].toBigInt()),"base64url"),e:j(Oe(e[2].toBigInt()),"base64url"),d:j(Oe(e[3].toBigInt()),"base64url"),p:j(Oe(e[4].toBigInt()),"base64url"),q:j(Oe(e[5].toBigInt()),"base64url"),dp:j(Oe(e[6].toBigInt()),"base64url"),dq:j(Oe(e[7].toBigInt()),"base64url"),qi:j(Oe(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function sw(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 D("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new Rt({value:[new bt({value:0}),bt.fromBigInt(Fe(q(r.n,"base64url"))),bt.fromBigInt(Fe(q(r.e,"base64url"))),bt.fromBigInt(Fe(q(r.d,"base64url"))),bt.fromBigInt(Fe(q(r.p,"base64url"))),bt.fromBigInt(Fe(q(r.q,"base64url"))),bt.fromBigInt(Fe(q(r.dp,"base64url"))),bt.fromBigInt(Fe(q(r.dq,"base64url"))),bt.fromBigInt(Fe(q(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function iw(r){let{result:t}=Un(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:j(Oe(e[0].toBigInt()),"base64url"),e:j(Oe(e[1].toBigInt()),"base64url")}}function aw(r){if(r.n==null||r.e==null)throw new D("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new Rt({value:[new Rt({value:[new ve({value:"1.2.840.113549.1.1.1"}),new Rr]}),new Nn({valueHex:new Rt({value:[bt.fromBigInt(Fe(q(r.n,"base64url"))),bt.fromBigInt(Fe(q(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Oe(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 Fe(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 cw=16,Dc=32,Pc=1e4;async function uw(r,t){let e=Kt.get(),o=new Rt({value:[new bt({value:0}),new Rt({value:[new ve({value:"1.2.840.113549.1.1.1"}),new Rr]}),new er({valueHex:r.marshal()})]}).toBER(),s=new Uint8Array(o,0,o.byteLength),i=De(cw),a=await Tc(po,t,i,{c:Pc,dkLen:Dc}),c=De(16),u=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),f=await e.subtle.encrypt({name:"AES-CBC",iv:c},u,s),l=new Rt({value:[new er({valueHex:i}),new bt({value:Pc}),new bt({value:Dc}),new Rt({value:[new ve({value:"1.2.840.113549.2.11"}),new Rr]})]}),m=new Rt({value:[new ve({value:"1.2.840.113549.1.5.13"}),new Rt({value:[new Rt({value:[new ve({value:"1.2.840.113549.1.5.12"}),l]}),new Rt({value:[new ve({value:"2.16.840.1.101.3.4.1.42"}),new er({valueHex:c})]})]})]}),p=new Rt({value:[m,new er({valueHex:f})]}).toBER(),d=new Uint8Array(p,0,p.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...j(d,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
8
- `)}async function lw(r,t){let e=Kt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=q(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Un(o),{iv:i,salt:a,iterations:c,keySize:u,cipherText:f}=fw(s),l=await Tc(po,t,a,{c,dkLen:u}),m=await e.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),h=Io(await e.subtle.decrypt({name:"AES-CBC",iv:i},m,f)),{result:p}=Un(h);n=xh(p)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=q(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Un(o);n=xh(s)}else throw new D("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Oc(n)}function fw(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new D("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 D("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let s=n.valueBlock.value[1],i=Io(s.valueBlock.value[0].getValue()),a=Pc,c=Dc;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 D("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],f=u.valueBlock.value[0].toString();if(f!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(f!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new D("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=Io(u.valueBlock.value[1].getValue());return{cipherText:Io(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:l}}function xh(r){return Io(r.valueBlock.value[2].getValue())}function Io(r){return new Uint8Array(r,0,r.byteLength)}async function Eh(r){let t=await Kt.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 Bh(t);return{privateKey:e[0],publicKey:e[1]}}async function Fc(r){let e=[await Kt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await hw(r)],n=await Bh({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function vh(r,t){let e=await Kt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Kt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Ah(r,t,e){let n=await Kt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Kt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Bh(r){if(r.privateKey==null||r.publicKey==null)throw new D("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Kt.get().subtle.exportKey("jwk",r.privateKey),Kt.get().subtle.exportKey("jwk",r.publicKey)])}async function hw(r){return Kt.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 gi(r){if(r.kty!=="RSA")throw new D("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new D("invalid key modulus","ERR_INVALID_KEY_MODULUS");return q(r.n,"base64url").length*8}var _o=8192,Ro=class{_key;constructor(t){this._key=t}verify(t,e){return Ah(this._key,e,t)}marshal(){return _r.jwkToPkix(this._key)}get bytes(){return Ue.encode({Type:gt.RSA,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return le(t)?t.then(({bytes:e})=>e):t.bytes}},Dn=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return De(16)}sign(t){return vh(this._key,t)}get public(){if(this._publicKey==null)throw new D("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Ro(this._publicKey)}marshal(){return _r.jwkToPkcs1(this._key)}get bytes(){return Xe.encode({Type:gt.RSA,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return le(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return j(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return _r.exportToPem(this,t);if(e==="libp2p-key")return _n(this.bytes,t);throw new D(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Oc(r){let t=_r.pkcs1ToJwk(r);if(gi(t)>_o)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Fc(t);return new Dn(e.privateKey,e.publicKey)}function pw(r){let t=_r.pkixToJwk(r);if(gi(t)>_o)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Ro(t)}async function mw(r){if(gi(r)>_o)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Fc(r);return new Dn(t.privateKey,t.publicKey)}async function gw(r){if(r>_o)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Eh(r);return new Dn(t.privateKey,t.publicKey)}var qc={};vt(qc,{Secp256k1PrivateKey:()=>Co,Secp256k1PublicKey:()=>To,generateKeyPair:()=>_w,unmarshalSecp256k1PrivateKey:()=>Iw,unmarshalSecp256k1PublicKey:()=>Rw});var yw=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]),Tr=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Cr=new Uint32Array(64),Mc=class extends kn{constructor(){super(64,32,8,!1),this.A=Tr[0]|0,this.B=Tr[1]|0,this.C=Tr[2]|0,this.D=Tr[3]|0,this.E=Tr[4]|0,this.F=Tr[5]|0,this.G=Tr[6]|0,this.H=Tr[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 l=0;l<16;l++,e+=4)Cr[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let m=Cr[l-15],h=Cr[l-2],p=xe(m,7)^xe(m,18)^m>>>3,d=xe(h,17)^xe(h,19)^h>>>10;Cr[l]=d+Cr[l-7]+p+Cr[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:u,H:f}=this;for(let l=0;l<64;l++){let m=xe(a,6)^xe(a,11)^xe(a,25),h=f+m+ff(a,c,u)+yw[l]+Cr[l]|0,d=(xe(n,2)^xe(n,13)^xe(n,22))+hf(n,o,s)|0;f=u,u=c,c=a,a=i+h|0,i=s,s=o,o=n,n=h+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,u=u+this.G|0,f=f+this.H|0,this.set(n,o,s,i,a,c,u,f)}roundClean(){Cr.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var kh=ys(()=>new Mc);function ww(r){let t=go(r);Le(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:bw,hexToBytes:xw}=xs,Yr={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=Yr;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:bw(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=Yr,e=typeof r=="string"?xw(r):r;Sn(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}=Yr._parseInt(e.subarray(2)),{d:i,l:a}=Yr._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 f=u.toString(16);return f.length&1?`0${f}`:f},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}`}},sr=BigInt(0),he=BigInt(1),IA=BigInt(2),Sh=BigInt(3),RA=BigInt(4);function Ew(r){let t=ww(r),{Fp:e}=t,n=t.toBytes||((p,d,w)=>{let g=d.toAffine();return Ze(Uint8Array.from([4]),e.toBytes(g.x),e.toBytes(g.y))}),o=t.fromBytes||(p=>{let d=p.subarray(1),w=e.fromBytes(d.subarray(0,e.BYTES)),g=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:w,y:g}});function s(p){let{a:d,b:w}=t,g=e.sqr(p),x=e.mul(g,p);return e.add(e.add(x,e.mul(p,d)),w)}if(!e.eql(e.sqr(t.Gy),s(t.Gx)))throw new Error("bad generator point: equation left != right");function i(p){return typeof p=="bigint"&&sr<p&&p<t.n}function a(p){if(!i(p))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(p){let{allowedPrivateKeyLengths:d,nByteLength:w,wrapPrivateKey:g,n:x}=t;if(d&&typeof p!="bigint"){if(Ar(p)&&(p=We(p)),typeof p!="string"||!d.includes(p.length))throw new Error("Invalid key");p=p.padStart(w*2,"0")}let b;try{b=typeof p=="bigint"?p:Ye(mt("private key",p,w))}catch{throw new Error(`private key must be ${w} bytes, hex or bigint, not ${typeof p}`)}return g&&(b=at(b,x)),a(b),b}let u=new Map;function f(p){if(!(p instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(d,w,g){if(this.px=d,this.py=w,this.pz=g,d==null||!e.isValid(d))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(g==null||!e.isValid(g))throw new Error("z required")}static fromAffine(d){let{x:w,y:g}=d||{};if(!d||!e.isValid(w)||!e.isValid(g))throw new Error("invalid affine point");if(d instanceof l)throw new Error("projective point not allowed");let x=b=>e.eql(b,e.ZERO);return x(w)&&x(g)?l.ZERO:new l(w,g,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let w=e.invertBatch(d.map(g=>g.pz));return d.map((g,x)=>g.toAffine(w[x])).map(l.fromAffine)}static fromHex(d){let w=l.fromAffine(o(mt("pointHex",d)));return w.assertValidity(),w}static fromPrivateKey(d){return l.BASE.multiply(c(d))}_setWindowSize(d){this._WINDOW_SIZE=d,u.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:d,y:w}=this.toAffine();if(!e.isValid(d)||!e.isValid(w))throw new Error("bad point: x or y not FE");let g=e.sqr(w),x=s(d);if(!e.eql(g,x))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(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:w,py:g,pz:x}=this,{px:b,py:B,pz:A}=d,I=e.eql(e.mul(w,A),e.mul(b,x)),v=e.eql(e.mul(g,A),e.mul(B,x));return I&&v}negate(){return new l(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:w}=t,g=e.mul(w,Sh),{px:x,py:b,pz:B}=this,A=e.ZERO,I=e.ZERO,v=e.ZERO,E=e.mul(x,x),U=e.mul(b,b),P=e.mul(B,B),N=e.mul(x,b);return N=e.add(N,N),v=e.mul(x,B),v=e.add(v,v),A=e.mul(d,v),I=e.mul(g,P),I=e.add(A,I),A=e.sub(U,I),I=e.add(U,I),I=e.mul(A,I),A=e.mul(N,A),v=e.mul(g,v),P=e.mul(d,P),N=e.sub(E,P),N=e.mul(d,N),N=e.add(N,v),v=e.add(E,E),E=e.add(v,E),E=e.add(E,P),E=e.mul(E,N),I=e.add(I,E),P=e.mul(b,B),P=e.add(P,P),E=e.mul(P,N),A=e.sub(A,E),v=e.mul(P,U),v=e.add(v,v),v=e.add(v,v),new l(A,I,v)}add(d){f(d);let{px:w,py:g,pz:x}=this,{px:b,py:B,pz:A}=d,I=e.ZERO,v=e.ZERO,E=e.ZERO,U=t.a,P=e.mul(t.b,Sh),N=e.mul(w,b),M=e.mul(g,B),C=e.mul(x,A),X=e.add(w,g),S=e.add(b,B);X=e.mul(X,S),S=e.add(N,M),X=e.sub(X,S),S=e.add(w,x);let T=e.add(b,A);return S=e.mul(S,T),T=e.add(N,C),S=e.sub(S,T),T=e.add(g,x),I=e.add(B,A),T=e.mul(T,I),I=e.add(M,C),T=e.sub(T,I),E=e.mul(U,S),I=e.mul(P,C),E=e.add(I,E),I=e.sub(M,E),E=e.add(M,E),v=e.mul(I,E),M=e.add(N,N),M=e.add(M,N),C=e.mul(U,C),S=e.mul(P,S),M=e.add(M,C),C=e.sub(N,C),C=e.mul(U,C),S=e.add(S,C),N=e.mul(M,S),v=e.add(v,N),N=e.mul(T,S),I=e.mul(X,I),I=e.sub(I,N),N=e.mul(X,M),E=e.mul(T,E),E=e.add(E,N),new l(I,v,E)}subtract(d){return this.add(d.negate())}is0(){return this.equals(l.ZERO)}wNAF(d){return h.wNAFCached(this,u,d,w=>{let g=e.invertBatch(w.map(x=>x.pz));return w.map((x,b)=>x.toAffine(g[b])).map(l.fromAffine)})}multiplyUnsafe(d){let w=l.ZERO;if(d===sr)return w;if(a(d),d===he)return this;let{endo:g}=t;if(!g)return h.unsafeLadder(this,d);let{k1neg:x,k1:b,k2neg:B,k2:A}=g.splitScalar(d),I=w,v=w,E=this;for(;b>sr||A>sr;)b&he&&(I=I.add(E)),A&he&&(v=v.add(E)),E=E.double(),b>>=he,A>>=he;return x&&(I=I.negate()),B&&(v=v.negate()),v=new l(e.mul(v.px,g.beta),v.py,v.pz),I.add(v)}multiply(d){a(d);let w=d,g,x,{endo:b}=t;if(b){let{k1neg:B,k1:A,k2neg:I,k2:v}=b.splitScalar(w),{p:E,f:U}=this.wNAF(A),{p:P,f:N}=this.wNAF(v);E=h.constTimeNegate(B,E),P=h.constTimeNegate(I,P),P=new l(e.mul(P.px,b.beta),P.py,P.pz),g=E.add(P),x=U.add(N)}else{let{p:B,f:A}=this.wNAF(w);g=B,x=A}return l.normalizeZ([g,x])[0]}multiplyAndAddUnsafe(d,w,g){let x=l.BASE,b=(A,I)=>I===sr||I===he||!A.equals(x)?A.multiplyUnsafe(I):A.multiply(I),B=b(this,w).add(b(d,g));return B.is0()?void 0:B}toAffine(d){let{px:w,py:g,pz:x}=this,b=this.is0();d==null&&(d=b?e.ONE:e.inv(x));let B=e.mul(w,d),A=e.mul(g,d),I=e.mul(x,d);if(b)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:B,y:A}}isTorsionFree(){let{h:d,isTorsionFree:w}=t;if(d===he)return!0;if(w)return w(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:w}=t;return d===he?this:w?w(l,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return this.assertValidity(),n(l,this,d)}toHex(d=!0){return We(this.toRawBytes(d))}}l.BASE=new l(t.Gx,t.Gy,e.ONE),l.ZERO=new l(e.ZERO,e.ONE,e.ZERO);let m=t.nBitLength,h=As(l,t.endo?Math.ceil(m/2):m);return{CURVE:t,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:s,isWithinCurveOrder:i}}function vw(r){let t=go(r);return Le(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Ih(r){let t=vw(r),{Fp:e,n}=t,o=e.BYTES+1,s=2*e.BYTES+1;function i(S){return sr<S&&S<e.ORDER}function a(S){return at(S,n)}function c(S){return Es(S,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:m}=Ew({...t,toBytes(S,T,H){let _=T.toAffine(),k=e.toBytes(_.x),F=Ze;return H?F(Uint8Array.from([T.hasEvenY()?2:3]),k):F(Uint8Array.from([4]),k,e.toBytes(_.y))},fromBytes(S){let T=S.length,H=S[0],_=S.subarray(1);if(T===o&&(H===2||H===3)){let k=Ye(_);if(!i(k))throw new Error("Point is not on curve");let F=l(k),$;try{$=e.sqrt(F)}catch(Y){let rt=Y instanceof Error?": "+Y.message:"";throw new Error("Point is not on curve"+rt)}let K=($&he)===he;return(H&1)===1!==K&&($=e.neg($)),{x:k,y:$}}else if(T===s&&H===4){let k=e.fromBytes(_.subarray(0,e.BYTES)),F=e.fromBytes(_.subarray(e.BYTES,2*e.BYTES));return{x:k,y:F}}else throw new Error(`Point of length ${T} was invalid. Expected ${o} compressed bytes or ${s} uncompressed bytes`)}}),h=S=>We(kr(S,t.nByteLength));function p(S){let T=n>>he;return S>T}function d(S){return p(S)?a(-S):S}let w=(S,T,H)=>Ye(S.slice(T,H));class g{constructor(T,H,_){this.r=T,this.s=H,this.recovery=_,this.assertValidity()}static fromCompact(T){let H=t.nByteLength;return T=mt("compactSignature",T,H*2),new g(w(T,0,H),w(T,H,2*H))}static fromDER(T){let{r:H,s:_}=Yr.toSig(mt("DER",T));return new g(H,_)}assertValidity(){if(!m(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!m(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(T){return new g(this.r,this.s,T)}recoverPublicKey(T){let{r:H,s:_,recovery:k}=this,F=v(mt("msgHash",T));if(k==null||![0,1,2,3].includes(k))throw new Error("recovery id invalid");let $=k===2||k===3?H+t.n:H;if($>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let K=k&1?"03":"02",W=u.fromHex(K+h($)),Y=c($),rt=a(-F*Y),J=a(_*Y),Q=u.BASE.multiplyAndAddUnsafe(W,rt,J);if(!Q)throw new Error("point at infinify");return Q.assertValidity(),Q}hasHighS(){return p(this.s)}normalizeS(){return this.hasHighS()?new g(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return qr(this.toDERHex())}toDERHex(){return Yr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return qr(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let x={isValidPrivateKey(S){try{return f(S),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let S=Bc(t.n);return vf(t.randomBytes(S),t.n)},precompute(S=8,T=u.BASE){return T._setWindowSize(S),T.multiply(BigInt(3)),T}};function b(S,T=!0){return u.fromPrivateKey(S).toRawBytes(T)}function B(S){let T=Ar(S),H=typeof S=="string",_=(T||H)&&S.length;return T?_===o||_===s:H?_===2*o||_===2*s:S instanceof u}function A(S,T,H=!0){if(B(S))throw new Error("first arg must be private key");if(!B(T))throw new Error("second arg must be public key");return u.fromHex(T).multiply(f(S)).toRawBytes(H)}let I=t.bits2int||function(S){let T=Ye(S),H=S.length*8-t.nBitLength;return H>0?T>>BigInt(H):T},v=t.bits2int_modN||function(S){return a(I(S))},E=mo(t.nBitLength);function U(S){if(typeof S!="bigint")throw new Error("bigint expected");if(!(sr<=S&&S<E))throw new Error(`bigint expected < 2^${t.nBitLength}`);return kr(S,t.nByteLength)}function P(S,T,H=N){if(["recovered","canonical"].some(dt=>dt in H))throw new Error("sign() legacy options not supported");let{hash:_,randomBytes:k}=t,{lowS:F,prehash:$,extraEntropy:K}=H;F==null&&(F=!0),S=mt("msgHash",S),$&&(S=mt("prehashed msgHash",_(S)));let W=v(S),Y=f(T),rt=[U(Y),U(W)];if(K!=null&&K!==!1){let dt=K===!0?k(e.BYTES):K;rt.push(mt("extraEntropy",dt))}let J=Ze(...rt),Q=W;function wt(dt){let Tt=I(dt);if(!m(Tt))return;let Ct=c(Tt),Et=u.BASE.multiply(Tt).toAffine(),Ot=a(Et.x);if(Ot===sr)return;let Ke=a(Ct*a(Q+Ot*Y));if(Ke===sr)return;let Or=(Et.x===Ot?0:2)|Number(Et.y&he),eo=Ke;return F&&p(Ke)&&(eo=d(Ke),Or^=1),new g(Ot,eo,Or)}return{seed:J,k2sig:wt}}let N={lowS:t.lowS,prehash:!1},M={lowS:t.lowS,prehash:!1};function C(S,T,H=N){let{seed:_,k2sig:k}=P(S,T,H),F=t;return xc(F.hash.outputLen,F.nByteLength,F.hmac)(_,k)}u.BASE._setWindowSize(8);function X(S,T,H,_=M){let k=S;if(T=mt("msgHash",T),H=mt("publicKey",H),"strict"in _)throw new Error("options.strict was renamed to lowS");let{lowS:F,prehash:$}=_,K,W;try{if(typeof k=="string"||Ar(k))try{K=g.fromDER(k)}catch(Et){if(!(Et instanceof Yr.Err))throw Et;K=g.fromCompact(k)}else if(typeof k=="object"&&typeof k.r=="bigint"&&typeof k.s=="bigint"){let{r:Et,s:Ot}=k;K=new g(Et,Ot)}else throw new Error("PARSE");W=u.fromHex(H)}catch(Et){if(Et.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(F&&K.hasHighS())return!1;$&&(T=t.hash(T));let{r:Y,s:rt}=K,J=v(T),Q=c(rt),wt=a(J*Q),dt=a(Y*Q),Tt=u.BASE.multiplyAndAddUnsafe(W,wt,dt)?.toAffine();return Tt?a(Tt.x)===Y:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:A,sign:C,verify:X,ProjectivePoint:u,Signature:g,utils:x}}function Aw(r){return{hash:r,hmac:(t,...e)=>wo(r,t,mc(...e)),randomBytes:Bn}}function Rh(r,t){let e=n=>Ih({...r,...Aw(n)});return Object.freeze({...e(t),create:e})}var Ch=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),_h=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Bw=BigInt(1),$c=BigInt(2),Th=(r,t)=>(r+t/$c)/t;function kw(r){let t=Ch,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,f=u*u*r%t,l=lt(f,e,t)*f%t,m=lt(l,e,t)*f%t,h=lt(m,$c,t)*u%t,p=lt(h,o,t)*h%t,d=lt(p,s,t)*p%t,w=lt(d,a,t)*d%t,g=lt(w,c,t)*w%t,x=lt(g,a,t)*d%t,b=lt(x,e,t)*f%t,B=lt(b,i,t)*p%t,A=lt(B,n,t)*u%t,I=lt(A,$c,t);if(!Hc.eql(Hc.sqr(I),r))throw new Error("Cannot find square root");return I}var Hc=vs(Ch,void 0,void 0,{sqrt:kw}),Be=Rh({a:BigInt(0),b:BigInt(7),Fp:Hc,n:_h,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=_h,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Bw*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=Th(s*r,t),c=Th(-n*r,t),u=at(r-a*e-c*o,t),f=at(-a*n-c*s,t),l=u>i,m=f>i;if(l&&(u=t-u),m&&(f=t-f),u>i||f>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:u,k2neg:m,k2:f}}}},kh),OA=BigInt(0);var FA=Be.ProjectivePoint;function Nh(){return Be.utils.randomPrivateKey()}function Lh(r,t){let e=At.digest(t instanceof Uint8Array?t:t.subarray());if(le(e))return e.then(({digest:n})=>Be.sign(n,r).toDERRawBytes()).catch(n=>{throw new D(String(n),"ERR_INVALID_INPUT")});try{return Be.sign(e.digest,r).toDERRawBytes()}catch(n){throw new D(String(n),"ERR_INVALID_INPUT")}}function Uh(r,t,e){let n=At.digest(e instanceof Uint8Array?e:e.subarray());if(le(n))return n.then(({digest:o})=>Be.verify(t,o,r)).catch(o=>{throw new D(String(o),"ERR_INVALID_INPUT")});try{return Be.verify(t,n.digest,r)}catch(o){throw new D(String(o),"ERR_INVALID_INPUT")}}function Dh(r){return Be.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ph(r){try{Be.getPublicKey(r,!0)}catch(t){throw new D(String(t),"ERR_INVALID_PRIVATE_KEY")}}function Kc(r){try{Be.ProjectivePoint.fromHex(r)}catch(t){throw new D(String(t),"ERR_INVALID_PUBLIC_KEY")}}function Oh(r){try{return Be.getPublicKey(r,!0)}catch(t){throw new D(String(t),"ERR_INVALID_PRIVATE_KEY")}}var To=class{_key;constructor(t){Kc(t),this._key=t}verify(t,e){return Uh(this._key,e,t)}marshal(){return Dh(this._key)}get bytes(){return Ue.encode({Type:gt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return le(t)?{bytes:e}=await t:e=t.bytes,e}},Co=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??Oh(t),Ph(this._key),Kc(this._publicKey)}sign(t){return Lh(this._key,t)}get public(){return new To(this._publicKey)}marshal(){return this._key}get bytes(){return Xe.encode({Type:gt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return le(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return j(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return _n(this.bytes,t);throw new D(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function Iw(r){return new Co(r)}function Rw(r){return new To(r)}async function _w(){let r=Nh();return new Co(r)}var yi={rsa:Vc,ed25519:_c,secp256k1:qc};function Tw(r){let t=Object.keys(yi).join(" / ");return new D(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function zc(r){let t=Ue.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case gt.RSA:return yi.rsa.unmarshalRsaPublicKey(e);case gt.Ed25519:return yi.ed25519.unmarshalEd25519PublicKey(e);case gt.Secp256k1:return yi.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw Tw(t.Type??"unknown")}}var re=Xt(zh(),1);re.default.formatters.b=r=>r==null?"undefined":ht.baseEncode(r);re.default.formatters.t=r=>r==null?"undefined":Nt.baseEncode(r);re.default.formatters.m=r=>r==null?"undefined":ue.baseEncode(r);re.default.formatters.p=r=>r==null?"undefined":r.toString();re.default.formatters.c=r=>r==null?"undefined":r.toString();re.default.formatters.k=r=>r==null?"undefined":r.toString();re.default.formatters.a=r=>r==null?"undefined":r.toString();function Kw(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 jh(){return{forComponent(r){return ne(r)}}}function ne(r){let t=Kw(`${r}:trace`);return re.default.enabled(`${r}:trace`)&&re.default.names.map(e=>e.toString()).find(e=>e.includes(":trace"))!=null&&(t=(0,re.default)(`${r}:trace`)),Object.assign((0,re.default)(r),{error:(0,re.default)(`${r}:error`),trace:t})}var Gc=Xt(Wh(),1);var Uo=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},Wc=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},Yh=r=>globalThis.DOMException===void 0?new Wc(r):new DOMException(r),Zh=r=>{let t=r.reason===void 0?Yh("This operation was aborted."):r.reason;return t instanceof Error?t:Yh(t)};function Do(r,t){let{milliseconds:e,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout}}=t,i,c=new Promise((u,f)=>{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:m}=t;m.aborted&&f(Zh(m)),m.addEventListener("abort",()=>{f(Zh(m))})}if(e===Number.POSITIVE_INFINITY){r.then(u,f);return}let l=new Uo;i=s.setTimeout.call(void 0,()=>{if(n){try{u(n())}catch(m){f(m)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?u():o instanceof Error?f(o):(l.message=o??`Promise timed out after ${e} milliseconds`,f(l))},e),(async()=>{try{u(await r)}catch(m){f(m)}})()}).finally(()=>{c.clear()});return c.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},c}function Yc(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 Po=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=Yc(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 Ve=class extends Gc.default{#t;#e;#r=0;#o;#a;#u=0;#s;#l;#n;#m;#i=0;#f;#c;#g;timeout;constructor(t){if(super(),t={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:Po,...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.#o=t.intervalCap,this.#a=t.interval,this.#n=new t.queueClass,this.#m=t.queueClass,this.concurrency=t.concurrency,this.timeout=t.timeout,this.#g=t.throwOnTimeout===!0,this.#c=t.autoStart===!1}get#b(){return this.#e||this.#r<this.#o}get#x(){return this.#i<this.#f}#E(){this.#i--,this.#h(),this.emit("next")}#v(){this.#w(),this.#y(),this.#l=void 0}get#A(){let t=Date.now();if(this.#s===void 0){let e=this.#u-t;if(e<0)this.#r=this.#t?this.#i:0;else return this.#l===void 0&&(this.#l=setTimeout(()=>{this.#v()},e)),!0}return!1}#h(){if(this.#n.size===0)return this.#s&&clearInterval(this.#s),this.#s=void 0,this.emit("empty"),this.#i===0&&this.emit("idle"),!1;if(!this.#c){let t=!this.#A;if(this.#b&&this.#x){let e=this.#n.dequeue();return e?(this.emit("active"),e(),t&&this.#y(),!0):!1}}return!1}#y(){this.#e||this.#s!==void 0||(this.#s=setInterval(()=>{this.#w()},this.#a),this.#u=Date.now()+this.#a)}#w(){this.#r===0&&this.#i===0&&this.#s&&(clearInterval(this.#s),this.#s=void 0),this.#r=this.#t?this.#i:0,this.#d()}#d(){for(;this.#h(););}get concurrency(){return this.#f}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.#f=t,this.#d()}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.#g,...e},new Promise((n,o)=>{this.#n.enqueue(async()=>{this.#i++,this.#r++;try{e.signal?.throwIfAborted();let s=t({signal:e.signal});e.timeout&&(s=Do(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 Uo&&!e.throwOnTimeout){n();return}o(s),this.emit("error",s)}finally{this.#E()}},e),this.emit("add"),this.#h()})}async addAll(t,e){return Promise.all(t.map(async n=>this.add(n,e)))}start(){return this.#c?(this.#c=!1,this.#d(),this):this}pause(){this.#c=!0}clear(){this.#n=new this.#m}async onEmpty(){this.#n.size!==0&&await this.#p("empty")}async onSizeLessThan(t){this.#n.size<t||await this.#p("next",()=>this.#n.size<t)}async onIdle(){this.#i===0&&this.#n.size===0||await this.#p("idle")}async#p(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.#i}get isPaused(){return this.#c}};function vi(r){let t=[ke.A];return r==null?t:Array.isArray(r)?r.length===0?t:r:[r]}var Zc=60;function Ai(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:ke[t.type]})),Answer:(r.Answer??r.answers??[]).map(t=>({name:t.name,type:ke[t.type],TTL:t.TTL??t.ttl??Zc,data:t.data instanceof Uint8Array?j(t.data):t.data}))}}var jw=4;function Jc(r,t={}){let e=new Ve({concurrency:t.queryConcurrency??jw});return async(n,o={})=>{let s=new URLSearchParams;s.set("name",n),vi(o.types).forEach(a=>{s.append("type",ke[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=Ai(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 Jh(){return[Jc("https://cloudflare-dns.com/dns-query"),Jc("https://dns.google/resolve")]}var td=Xt(Qh(),1);var Xc=class{lru;constructor(t){this.lru=(0,td.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 Ai({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:ke[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??Zc)*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 ed(r){return new Xc(r)}var Gw=1e3,Bi=class{resolvers;cache;constructor(t){this.resolvers={},this.cache=ed(t.cacheSize??Gw),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["."]=Jh())}async query(t,e={}){let n=vi(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 f of u.Answer)this.cache.add(t,f);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 ke;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(ke||(ke={}));function rd(r={}){return new Bi(r)}var Ww=["string","number","bigint","symbol"],Yw=["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 nd(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let t=typeof r;if(Ww.includes(t))return t;if(t==="function")return"Function";if(Array.isArray(r))return"Array";if(Zw(r))return"Buffer";let e=Jw(r);return e||"Object"}function Zw(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function Jw(r){let t=Object.prototype.toString.call(r).slice(8,-1);if(Yw.includes(t))return t}var y=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}};y.uint=new y(0,"uint",!0);y.negint=new y(1,"negint",!0);y.bytes=new y(2,"bytes",!0);y.string=new y(3,"string",!0);y.array=new y(4,"array",!1);y.map=new y(5,"map",!1);y.tag=new y(6,"tag",!1);y.float=new y(7,"float",!0);y.false=new y(7,"false",!0);y.true=new y(7,"true",!0);y.null=new y(7,"null",!0);y.undefined=new y(7,"undefined",!0);y.break=new y(7,"break",!0);var R=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 Vn=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",Xw=new TextDecoder,Qw=new TextEncoder;function ki(r){return Vn&&globalThis.Buffer.isBuffer(r)}function Oo(r){return r instanceof Uint8Array?ki(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var ad=Vn?(r,t,e)=>e-t>64?globalThis.Buffer.from(r.subarray(t,e)).toString("utf8"):sd(r,t,e):(r,t,e)=>e-t>64?Xw.decode(r.subarray(t,e)):sd(r,t,e),Si=Vn?r=>r.length>64?globalThis.Buffer.from(r):od(r):r=>r.length>64?Qw.encode(r):od(r),Me=r=>Uint8Array.from(r),Mn=Vn?(r,t,e)=>ki(r)?new Uint8Array(r.subarray(t,e)):r.slice(t,e):(r,t,e)=>r.slice(t,e),cd=Vn?(r,t)=>(r=r.map(e=>e instanceof Uint8Array?e:globalThis.Buffer.from(e)),Oo(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},ud=Vn?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function ld(r,t){if(ki(r)&&ki(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 od(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 sd(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,f;switch(i){case 1:o<128&&(s=o);break;case 2:a=r[t+1],(a&192)===128&&(f=(o&31)<<6|a&63,f>127&&(s=f));break;case 3:a=r[t+1],c=r[t+2],(a&192)===128&&(c&192)===128&&(f=(o&15)<<12|(a&63)<<6|c&63,f>2047&&(f<55296||f>57343)&&(s=f));break;case 4:a=r[t+1],c=r[t+2],u=r[t+3],(a&192)===128&&(c&192)===128&&(u&192)===128&&(f=(o&15)<<18|(a&63)<<12|(c&63)<<6|u&63,f>65535&&f<1114112&&(s=f))}}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 Qc(n)}var id=4096;function Qc(r){let t=r.length;if(t<=id)return String.fromCharCode.apply(String,r);let e="",n=0;for(;n<t;)e+=String.fromCharCode.apply(String,r.slice(n,n+=id));return e}var tb=256,Fo=class{constructor(t=tb){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=ud(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=Mn(n,0,this.cursor)}else e=cd(this.chunks,this.cursor);return t&&this.reset(),e}};var V="CBOR decode error:",$n="CBOR encode error:",Vo=[];Vo[23]=1;Vo[24]=2;Vo[25]=3;Vo[26]=5;Vo[27]=9;function ir(r,t,e){if(r.length-t<e)throw new Error(`${V} not enough data for type`)}var _t=[24,256,65536,4294967296,BigInt("18446744073709551616")];function oe(r,t,e){ir(r,t,1);let n=r[t];if(e.strict===!0&&n<_t[0])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function se(r,t,e){ir(r,t,2);let n=r[t]<<8|r[t+1];if(e.strict===!0&&n<_t[1])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function ie(r,t,e){ir(r,t,4);let n=r[t]*16777216+(r[t+1]<<16)+(r[t+2]<<8)+r[t+3];if(e.strict===!0&&n<_t[2])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function ae(r,t,e){ir(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<_t[3])throw new Error(`${V} 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(`${V} integers outside of the safe integer range are not supported`)}function fd(r,t,e,n){return new R(y.uint,oe(r,t+1,n),2)}function hd(r,t,e,n){return new R(y.uint,se(r,t+1,n),3)}function dd(r,t,e,n){return new R(y.uint,ie(r,t+1,n),5)}function pd(r,t,e,n){return new R(y.uint,ae(r,t+1,n),9)}function de(r,t){return Ut(r,0,t.value)}function Ut(r,t,e){if(e<_t[0]){let n=Number(e);r.push([t|n])}else if(e<_t[1]){let n=Number(e);r.push([t|24,n])}else if(e<_t[2]){let n=Number(e);r.push([t|25,n>>>8,n&255])}else if(e<_t[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<_t[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(`${V} encountered BigInt larger than allowable range`)}}de.encodedSize=function(t){return Ut.encodedSize(t.value)};Ut.encodedSize=function(t){return t<_t[0]?1:t<_t[1]?2:t<_t[2]?3:t<_t[3]?5:9};de.compareTokens=function(t,e){return t.value<e.value?-1:t.value>e.value?1:0};function md(r,t,e,n){return new R(y.negint,-1-oe(r,t+1,n),2)}function gd(r,t,e,n){return new R(y.negint,-1-se(r,t+1,n),3)}function yd(r,t,e,n){return new R(y.negint,-1-ie(r,t+1,n),5)}var tu=BigInt(-1),wd=BigInt(1);function bd(r,t,e,n){let o=ae(r,t+1,n);if(typeof o!="bigint"){let s=-1-o;if(s>=Number.MIN_SAFE_INTEGER)return new R(y.negint,s,9)}if(n.allowBigInt!==!0)throw new Error(`${V} integers outside of the safe integer range are not supported`);return new R(y.negint,tu-BigInt(o),9)}function Ii(r,t){let e=t.value,n=typeof e=="bigint"?e*tu-wd:e*-1-1;Ut(r,t.type.majorEncoded,n)}Ii.encodedSize=function(t){let e=t.value,n=typeof e=="bigint"?e*tu-wd:e*-1-1;return n<_t[0]?1:n<_t[1]?2:n<_t[2]?3:n<_t[3]?5:9};Ii.compareTokens=function(t,e){return t.value<e.value?1:t.value>e.value?-1:0};function Mo(r,t,e,n){ir(r,t,e+n);let o=Mn(r,t+e,t+e+n);return new R(y.bytes,o,e+n)}function xd(r,t,e,n){return Mo(r,t,1,e)}function Ed(r,t,e,n){return Mo(r,t,2,oe(r,t+1,n))}function vd(r,t,e,n){return Mo(r,t,3,se(r,t+1,n))}function Ad(r,t,e,n){return Mo(r,t,5,ie(r,t+1,n))}function Bd(r,t,e,n){let o=ae(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer bytes lengths not supported`);return Mo(r,t,9,o)}function Ri(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===y.string?Si(r.value):r.value),r.encodedBytes}function Hn(r,t){let e=Ri(t);Ut(r,t.type.majorEncoded,e.length),r.push(e)}Hn.encodedSize=function(t){let e=Ri(t);return Ut.encodedSize(e.length)+e.length};Hn.compareTokens=function(t,e){return rb(Ri(t),Ri(e))};function rb(r,t){return r.length<t.length?-1:r.length>t.length?1:ld(r,t)}function $o(r,t,e,n,o){let s=e+n;ir(r,t,s);let i=new R(y.string,ad(r,t+e,t+s),s);return o.retainStringBytes===!0&&(i.byteValue=Mn(r,t+e,t+s)),i}function kd(r,t,e,n){return $o(r,t,1,e,n)}function Sd(r,t,e,n){return $o(r,t,2,oe(r,t+1,n),n)}function Id(r,t,e,n){return $o(r,t,3,se(r,t+1,n),n)}function Rd(r,t,e,n){return $o(r,t,5,ie(r,t+1,n),n)}function _d(r,t,e,n){let o=ae(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer string lengths not supported`);return $o(r,t,9,o,n)}var Td=Hn;function Kn(r,t,e,n){return new R(y.array,n,e)}function Cd(r,t,e,n){return Kn(r,t,1,e)}function Nd(r,t,e,n){return Kn(r,t,2,oe(r,t+1,n))}function Ld(r,t,e,n){return Kn(r,t,3,se(r,t+1,n))}function Ud(r,t,e,n){return Kn(r,t,5,ie(r,t+1,n))}function Dd(r,t,e,n){let o=ae(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer array lengths not supported`);return Kn(r,t,9,o)}function Pd(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return Kn(r,t,1,1/0)}function _i(r,t){Ut(r,y.array.majorEncoded,t.value)}_i.compareTokens=de.compareTokens;_i.encodedSize=function(t){return Ut.encodedSize(t.value)};function qn(r,t,e,n){return new R(y.map,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,oe(r,t+1,n))}function Vd(r,t,e,n){return qn(r,t,3,se(r,t+1,n))}function Md(r,t,e,n){return qn(r,t,5,ie(r,t+1,n))}function $d(r,t,e,n){let o=ae(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer map lengths not supported`);return qn(r,t,9,o)}function Hd(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return qn(r,t,1,1/0)}function Ti(r,t){Ut(r,y.map.majorEncoded,t.value)}Ti.compareTokens=de.compareTokens;Ti.encodedSize=function(t){return Ut.encodedSize(t.value)};function Kd(r,t,e,n){return new R(y.tag,e,1)}function qd(r,t,e,n){return new R(y.tag,oe(r,t+1,n),2)}function zd(r,t,e,n){return new R(y.tag,se(r,t+1,n),3)}function jd(r,t,e,n){return new R(y.tag,ie(r,t+1,n),5)}function Gd(r,t,e,n){return new R(y.tag,ae(r,t+1,n),9)}function Ci(r,t){Ut(r,y.tag.majorEncoded,t.value)}Ci.compareTokens=de.compareTokens;Ci.encodedSize=function(t){return Ut.encodedSize(t.value)};var cb=20,ub=21,lb=22,fb=23;function Wd(r,t,e,n){if(n.allowUndefined===!1)throw new Error(`${V} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new R(y.null,null,1):new R(y.undefined,void 0,1)}function Yd(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return new R(y.break,void 0,1)}function eu(r,t,e){if(e){if(e.allowNaN===!1&&Number.isNaN(r))throw new Error(`${V} NaN values are not supported`);if(e.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${V} Infinity values are not supported`)}return new R(y.float,r,t)}function Zd(r,t,e,n){return eu(ru(r,t+1),3,n)}function Jd(r,t,e,n){return eu(nu(r,t+1),5,n)}function Xd(r,t,e,n){return eu(rp(r,t+1),9,n)}function Ni(r,t,e){let n=t.value;if(n===!1)r.push([y.float.majorEncoded|cb]);else if(n===!0)r.push([y.float.majorEncoded|ub]);else if(n===null)r.push([y.float.majorEncoded|lb]);else if(n===void 0)r.push([y.float.majorEncoded|fb]);else{let o,s=!1;(!e||e.float64!==!0)&&(tp(n),o=ru(Se,1),n===o||Number.isNaN(n)?(Se[0]=249,r.push(Se.slice(0,3)),s=!0):(ep(n),o=nu(Se,1),n===o&&(Se[0]=250,r.push(Se.slice(0,5)),s=!0))),s||(hb(n),o=rp(Se,1),Se[0]=251,r.push(Se.slice(0,9)))}}Ni.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){tp(n);let o=ru(Se,1);if(n===o||Number.isNaN(n))return 3;if(ep(n),o=nu(Se,1),n===o)return 5}return 9};var Qd=new ArrayBuffer(9),pe=new DataView(Qd,1),Se=new Uint8Array(Qd,0);function tp(r){if(r===1/0)pe.setUint16(0,31744,!1);else if(r===-1/0)pe.setUint16(0,64512,!1);else if(Number.isNaN(r))pe.setUint16(0,32256,!1);else{pe.setFloat32(0,r);let t=pe.getUint32(0),e=(t&2139095040)>>23,n=t&8388607;if(e===255)pe.setUint16(0,31744,!1);else if(e===0)pe.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let o=e-127;o<-24?pe.setUint16(0,0):o<-14?pe.setUint16(0,(t&2147483648)>>16|1<<24+o,!1):pe.setUint16(0,(t&2147483648)>>16|o+15<<10|n>>13,!1)}}}function ru(r,t){if(r.length-t<2)throw new Error(`${V} 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 ep(r){pe.setFloat32(0,r,!1)}function nu(r,t){if(r.length-t<4)throw new Error(`${V} not enough data for float32`);let e=(r.byteOffset||0)+t;return new DataView(r.buffer,e,4).getFloat32(0,!1)}function hb(r){pe.setFloat64(0,r,!1)}function rp(r,t){if(r.length-t<8)throw new Error(`${V} not enough data for float64`);let e=(r.byteOffset||0)+t;return new DataView(r.buffer,e,8).getFloat64(0,!1)}Ni.compareTokens=de.compareTokens;function et(r,t,e){throw new Error(`${V} encountered invalid minor (${e}) for major ${r[t]>>>5}`)}function Li(r){return()=>{throw new Error(`${V} ${r}`)}}var L=[];for(let r=0;r<=23;r++)L[r]=et;L[24]=fd;L[25]=hd;L[26]=dd;L[27]=pd;L[28]=et;L[29]=et;L[30]=et;L[31]=et;for(let r=32;r<=55;r++)L[r]=et;L[56]=md;L[57]=gd;L[58]=yd;L[59]=bd;L[60]=et;L[61]=et;L[62]=et;L[63]=et;for(let r=64;r<=87;r++)L[r]=xd;L[88]=Ed;L[89]=vd;L[90]=Ad;L[91]=Bd;L[92]=et;L[93]=et;L[94]=et;L[95]=Li("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)L[r]=kd;L[120]=Sd;L[121]=Id;L[122]=Rd;L[123]=_d;L[124]=et;L[125]=et;L[126]=et;L[127]=Li("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)L[r]=Cd;L[152]=Nd;L[153]=Ld;L[154]=Ud;L[155]=Dd;L[156]=et;L[157]=et;L[158]=et;L[159]=Pd;for(let r=160;r<=183;r++)L[r]=Od;L[184]=Fd;L[185]=Vd;L[186]=Md;L[187]=$d;L[188]=et;L[189]=et;L[190]=et;L[191]=Hd;for(let r=192;r<=215;r++)L[r]=Kd;L[216]=qd;L[217]=zd;L[218]=jd;L[219]=Gd;L[220]=et;L[221]=et;L[222]=et;L[223]=et;for(let r=224;r<=243;r++)L[r]=Li("simple values are not supported");L[244]=et;L[245]=et;L[246]=et;L[247]=Wd;L[248]=Li("simple values are not supported");L[249]=Zd;L[250]=Jd;L[251]=Xd;L[252]=et;L[253]=et;L[254]=et;L[255]=Yd;var Ie=[];for(let r=0;r<24;r++)Ie[r]=new R(y.uint,r,1);for(let r=-1;r>=-24;r--)Ie[31-r]=new R(y.negint,r,1);Ie[64]=new R(y.bytes,new Uint8Array(0),1);Ie[96]=new R(y.string,"",1);Ie[128]=new R(y.array,0,1);Ie[160]=new R(y.map,0,1);Ie[244]=new R(y.false,!1,1);Ie[245]=new R(y.true,!0,1);Ie[246]=new R(y.null,null,1);function np(r){switch(r.type){case y.false:return Me([244]);case y.true:return Me([245]);case y.null:return Me([246]);case y.bytes:return r.value.length?void 0:Me([64]);case y.string:return r.value===""?Me([96]):void 0;case y.array:return r.value===0?Me([128]):void 0;case y.map:return r.value===0?Me([160]):void 0;case y.uint:return r.value<24?Me([Number(r.value)]):void 0;case y.negint:if(r.value>=-24)return Me([31-Number(r.value)])}}var pb={float64:!1,mapSorter:yb,quickEncodeToken:np};function mb(){let r=[];return r[y.uint.major]=de,r[y.negint.major]=Ii,r[y.bytes.major]=Hn,r[y.string.major]=Td,r[y.array.major]=_i,r[y.map.major]=Ti,r[y.tag.major]=Ci,r[y.float.major]=Ni,r}var op=mb(),ou=new Fo,Di=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(`${$n} object contains circular references`);return new r(e,t)}},Nr={null:new R(y.null,null),undefined:new R(y.undefined,void 0),true:new R(y.true,!0),false:new R(y.false,!1),emptyArray:new R(y.array,0),emptyMap:new R(y.map,0)},Lr={number(r,t,e,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new R(y.float,r):r>=0?new R(y.uint,r):new R(y.negint,r)},bigint(r,t,e,n){return r>=BigInt(0)?new R(y.uint,r):new R(y.negint,r)},Uint8Array(r,t,e,n){return new R(y.bytes,r)},string(r,t,e,n){return new R(y.string,r)},boolean(r,t,e,n){return r?Nr.true:Nr.false},null(r,t,e,n){return Nr.null},undefined(r,t,e,n){return Nr.undefined},ArrayBuffer(r,t,e,n){return new R(y.bytes,new Uint8Array(r))},DataView(r,t,e,n){return new R(y.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,t,e,n){if(!r.length)return e.addBreakTokens===!0?[Nr.emptyArray,new R(y.break)]:Nr.emptyArray;n=Di.createCheck(n,r);let o=[],s=0;for(let i of r)o[s++]=Ui(i,e,n);return e.addBreakTokens?[new R(y.array,r.length),o,new R(y.break)]:[new R(y.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?[Nr.emptyMap,new R(y.break)]:Nr.emptyMap;n=Di.createCheck(n,r);let a=[],c=0;for(let u of s)a[c++]=[Ui(u,e,n),Ui(o?r.get(u):r[u],e,n)];return gb(a,e),e.addBreakTokens?[new R(y.map,i),a,new R(y.break)]:[new R(y.map,i),a]}};Lr.Map=Lr.Object;Lr.Buffer=Lr.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))Lr[`${r}Array`]=Lr.DataView;function Ui(r,t={},e){let n=nd(r),o=t&&t.typeEncoders&&t.typeEncoders[n]||Lr[n];if(typeof o=="function"){let i=o(r,n,t,e);if(i!=null)return i}let s=Lr[n];if(!s)throw new Error(`${$n} unsupported type: ${n}`);return s(r,n,t,e)}function gb(r,t){t.mapSorter&&r.sort(t.mapSorter)}function yb(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=op[o].compareTokens(e,n);return s===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),s}function sp(r,t,e,n){if(Array.isArray(t))for(let o of t)sp(r,o,e,n);else e[t.type.major](r,t,n)}function ip(r,t,e){let n=Ui(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 Fo(i);if(s(a,n,e),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return Oo(a.chunks[0])}}return ou.reset(),sp(ou,n,t,e),ou.toBytes(!0)}function zn(r,t){return t=Object.assign({},pb,t),ip(r,op,t)}var wb={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},Pi=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=Ie[t];if(e===void 0){let n=L[t];if(!n)throw new Error(`${V} 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}},Ho=Symbol.for("DONE"),Oi=Symbol.for("BREAK");function bb(r,t,e){let n=[];for(let o=0;o<r.value;o++){let s=jn(t,e);if(s===Oi){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed array`)}if(s===Ho)throw new Error(`${V} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=s}return n}function xb(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===Oi){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed map`)}if(a===Ho)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(e.rejectDuplicateMapKeys===!0&&(n&&s.has(a)||!n&&a in o))throw new Error(`${V} found repeat map key "${a}"`);let c=jn(t,e);if(c===Ho)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 jn(r,t){if(r.done())return Ho;let e=r.next();if(e.type===y.break)return Oi;if(e.type.terminal)return e.value;if(e.type===y.array)return bb(e,r,t);if(e.type===y.map)return xb(e,r,t);if(e.type===y.tag){if(t.tags&&typeof t.tags[e.value]=="function"){let n=jn(r,t);return t.tags[e.value](n)}throw new Error(`${V} tag not supported (${e.value})`)}throw new Error("unsupported")}function su(r,t){if(!(r instanceof Uint8Array))throw new Error(`${V} data to decode must be a Uint8Array`);t=Object.assign({},wb,t);let e=t.tokenizer||new Pi(r,t),n=jn(e,t);if(n===Ho)throw new Error(`${V} did not find any content to decode`);if(n===Oi)throw new Error(`${V} got unexpected break`);return[n,r.subarray(e.pos())]}function me(r,t){let[e,n]=su(r,t);if(n.length>0)throw new Error(`${V} too many terminals, data makes no sense`);return e}var ar="/",ap=new TextEncoder().encode(ar),Vi=ap[0],Dt=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=q(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]!==Vi)throw new Error("Invalid key")}toString(t="utf8"){return j(this._buf,t)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(t){return new r(t.join(ar))}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=ap),this._buf[0]!==Vi){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Vi,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Vi;)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(ar).slice(1)}type(){return Eb(this.baseNamespace())}name(){return vb(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(ar)||(t+=ar),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(ar):new r(t.slice(0,-1).join(ar))}child(t){return this.toString()===ar?t:t.toString()===ar?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(),...Ab(t.map(e=>e.namespaces()))])}};function Eb(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function vb(r){let t=r.split(":");return t[t.length-1]}function Ab(r){return[].concat(...r)}var fp="/pin/",cp="/pinned-block/",iu=wr,up=1;function lp(r){return r.version===0&&(r=r.toV1()),new Dt(`${fp}${r.toString(iu)}`)}var Mi=class{datastore;blockstore;dagWalkers;constructor(t,e,n){this.datastore=t,this.blockstore=e,this.dagWalkers=n}async*add(t,e={}){let n=lp(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 qe({concurrency:up});for await(let a of this.#t(t,s,{...e,depth:o}))await this.#e(a,c=>c.pinnedBy.find(u=>it(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,zn(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 Dt(`${cp}${iu.encode(t.multihash.bytes)}`),s={pinCount:0,pinnedBy:[]};try{s=me(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,zn(s),n),n.onProgress?.(new nt("helia:pin:add",t))}}async*rm(t,e={}){let n=lp(t),o=await this.datastore.get(n,e),s=me(o);await this.datastore.delete(n,e);let i=new qe({concurrency:up});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=>it(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:fp+(t.cid!=null?`${t.cid.toString(wr)}`:"")},t)){let o=tt.parse(e.toString().substring(5),wr),s=me(n);yield{cid:o,...s}}}async isPinned(t,e={}){let n=new Dt(`${cp}${iu.encode(t.multihash.bytes)}`);return this.datastore.has(n,e)}};var Bb=5,$i=class{log;routers;providerLookupConcurrency;constructor(t,e){this.log=t.logger.forComponent("helia:routing"),this.routers=e.routers??[],this.providerLookupConcurrency=e.providerLookupConcurrency??Bb}async start(){await pr(...this.routers)}async stop(){await mr(...this.routers)}async*findProviders(t,e={}){if(this.routers.length===0)throw new D("No content routers available","ERR_NO_ROUTERS_AVAILABLE");let n=new ss({concurrency:this.providerLookupConcurrency});n.addEventListener("error",()=>{});for await(let o of $r(n.toGenerator(),...Gn(this.routers,"findProviders").map(s=>s.findProviders(t,e))))if(o!=null){if(o.multiaddrs.length===0){if(n.find(o.id)!=null)continue;n.add(async()=>{try{let s=await this.findPeer(o.id,e);return s.multiaddrs.length===0?null:s}catch(s){return this.log.error("could not load multiaddrs for peer %p",o.id,s),null}},{peerId:o.id,signal:e.signal}).catch(s=>{this.log.error("could not load multiaddrs for peer %p",o.id,s)})}yield o}}async provide(t,e={}){if(this.routers.length===0)throw new D("No content routers available","ERR_NO_ROUTERS_AVAILABLE");await Promise.all(Gn(this.routers,"provide").map(async n=>{await n.provide(t,e)}))}async put(t,e,n){await Promise.all(Gn(this.routers,"put").map(async o=>{await o.put(t,e,n)}))}async get(t,e){return Promise.any(Gn(this.routers,"get").map(async n=>n.get(t,e)))}async findPeer(t,e){if(this.routers.length===0)throw new D("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");let n=this,o=$r(...Gn(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 D("Could not find peer in routing","ERR_NOT_FOUND")}async*getClosestPeers(t,e={}){if(this.routers.length===0)throw new D("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");for await(let n of $r(...Gn(this.routers,"getClosestPeers").map(o=>o.getClosestPeers(t,e))))n!=null&&(yield n)}};function Gn(r,t){return r.filter(e=>e[t]!=null)}var Ur={},Wn=r=>{r.addEventListener("message",t=>{Wn.dispatchEvent("message",r,t)}),r.port!=null&&r.port.addEventListener("message",t=>{Wn.dispatchEvent("message",r,t)})};Wn.addEventListener=(r,t)=>{Ur[r]==null&&(Ur[r]=[]),Ur[r].push(t)};Wn.removeEventListener=(r,t)=>{Ur[r]!=null&&(Ur[r]=Ur[r].filter(e=>e===t))};Wn.dispatchEvent=function(r,t,e){Ur[r]!=null&&Ur[r].forEach(n=>n(t,e))};var au=Wn;var cu="lock:worker:request-read",uu="lock:worker:release-read",lu="lock:master:grant-read",fu="lock:worker:request-write",hu="lock:worker:release-write",du="lock:master:grant-write";var hp=(r=21)=>Math.random().toString().substring(2);var dp=(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=f=>{if(f==null||f.data==null)return;let l={type:f.data.type,name:f.data.name,identifier:f.data.identifier};l.type===n&&l.identifier===a.identifier&&(s.removeEventListener("message",u),c())};s.addEventListener("message",u)})}}}))},pp=(r,t,e,n)=>async()=>{let o=hp();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)})},kb={singleProcess:!1},mp=r=>{if(r=Object.assign({},kb,r),!!globalThis.document||r.singleProcess){let e=new EventTarget;return au.addEventListener("message",dp(e,"requestReadLock",cu,uu,lu)),au.addEventListener("message",dp(e,"requestWriteLock",fu,hu,du)),e}return{isWorker:!0,readLock:e=>pp(e,cu,lu,uu),writeLock:e=>pp(e,fu,du,hu)}};var Xr={},Dr;async function pu(r,t){let e,n=new Promise(o=>{e=o});return r.add(async()=>Do((async()=>{await new Promise(o=>{e(()=>{o()})})})(),{milliseconds:t.timeout})),n}var Sb=(r,t)=>{if(Dr.isWorker===!0)return{readLock:Dr.readLock(r,t),writeLock:Dr.writeLock(r,t)};let e=new Ve({concurrency:1}),n;return{async readLock(){if(n!=null)return pu(n,t);n=new Ve({concurrency:t.concurrency,autoStart:!1});let o=n,s=pu(n,t);return e.add(async()=>{o.start(),await o.onIdle().then(()=>{n===o&&(n=null)})}),s},async writeLock(){return n=null,pu(e,t)}}},Ib={name:"lock",concurrency:1/0,timeout:846e5,singleProcess:!1};function mu(r){let t=Object.assign({},Ib,r);return Dr==null&&(Dr=mp(t),Dr.isWorker!==!0&&(Dr.addEventListener("requestReadLock",e=>{Xr[e.data.name]!=null&&Xr[e.data.name].readLock().then(async n=>e.data.handler().finally(()=>{n()}))}),Dr.addEventListener("requestWriteLock",async e=>{Xr[e.data.name]!=null&&Xr[e.data.name].writeLock().then(async n=>e.data.handler().finally(()=>{n()}))}))),Xr[t.name]==null&&(Xr[t.name]=Sb(t.name,t)),Xr[t.name]}var Hi=class{lock;child;pins;started;constructor(t,e,n={}){this.child=t,this.pins=e,this.lock=mu({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await pr(this.child),this.started=!0}async stop(){await mr(this.child),this.started=!1}unwrap(){return this.child}async put(t,e,n={}){n?.signal?.throwIfAborted();let o=await this.lock.readLock();try{return await this.child.put(t,e,n)}finally{o()}}async*putMany(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{yield*this.child.putMany(t,e)}finally{n()}}async get(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{return await this.child.get(t,e)}finally{n()}}async*getMany(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{yield*this.child.getMany(t,e)}finally{n()}}async delete(t,e={}){e?.signal?.throwIfAborted();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={}){e?.signal?.throwIfAborted();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={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{return await this.child.has(t,e)}finally{n()}}async*getAll(t={}){t?.signal?.throwIfAborted();let e=await this.lock.readLock();try{yield*this.child.getAll(t)}finally{e()}}createSession(t,e){return e?.signal?.throwIfAborted(),this.child.createSession(t,e)}};var yp=42;function Rb(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let t=tt.asCID(r);if(!t)return null;let e=new Uint8Array(t.bytes.byteLength+1);return e.set(t.bytes,1),[new R(y.tag,yp),new R(y.bytes,e)]}function _b(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function Tb(r){if(Number.isNaN(r))throw new Error("`NaN` is not supported by the IPLD Data Model and cannot be encoded");if(r===1/0||r===-1/0)throw new Error("`Infinity` and `-Infinity` is not supported by the IPLD Data Model and cannot be encoded");return null}var gp={float64:!0,typeEncoders:{Object:Rb,undefined:_b,number:Tb}},mk={...gp,typeEncoders:{...gp.typeEncoders}};function Cb(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return tt.decode(r.subarray(1))}var gu={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};gu.tags[yp]=Cb;var gk={...gu,tags:gu.tags.slice()};var wp=113;var bp=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(t){let e=this.inRecursive[this.inRecursive.length-1];e&&(e.type===y.array&&(e.elements++,e.elements!==1&&t.push([44])),e.type===y.map&&(e.elements++,e.elements!==1&&(e.elements%2===1?t.push([44]):t.push([58]))))}[y.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)}[y.negint.major](t,e){this[y.uint.major](t,e)}[y.bytes.major](t,e){throw new Error(`${$n} unsupported type: Uint8Array`)}[y.string.major](t,e){this.prefix(t);let n=Si(JSON.stringify(e.value));t.push(n.length>32?Oo(n):n)}[y.array.major](t,e){this.prefix(t),this.inRecursive.push({type:y.array,elements:0}),t.push([91])}[y.map.major](t,e){this.prefix(t),this.inRecursive.push({type:y.map,elements:0}),t.push([123])}[y.tag.major](t,e){}[y.float.major](t,e){if(e.type.name==="break"){let i=this.inRecursive.pop();if(i){if(i.type===y.array)t.push([93]);else if(i.type===y.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(`${$n} 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 Qr=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(`${V} 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(`${V} 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 R(y.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(`${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(t,this._pos)),i=parseFloat(s);return n?new R(y.float,i,this._pos-t):this.options.allowBigInt!==!0||Number.isSafeInteger(i)?new R(i>=0?y.uint:y.negint,i,this._pos-t):new R(i>=0?y.uint:y.negint,BigInt(s),this._pos-t)}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 R(y.string,c,i)}}let t=this._pos,e=[],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,u,f,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],u=this.data[this._pos+2],(c&192)===128&&(u&192)===128&&(l=(s&15)<<12|(c&63)<<6|u&63,l>2047&&(l<55296||l>57343)&&(i=l));break;case 4:c=this.data[this._pos+1],u=this.data[this._pos+2],f=this.data[this._pos+3],(c&192)===128&&(u&192)===128&&(f&192)===128&&(l=(s&15)<<18|(c&63)<<12|(u&63)<<6|f&63,l>65535&&l<1114112&&(i=l))}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(`${V} 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(`${V} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new R(y.string,Qc(e),this._pos-t);default:if(s<32)throw new Error(`${V} invalid control character at position ${this._pos}`);s<128?(e.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 R(y.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new R(y.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new R(y.null,null,4);case 102:return this.expect([102,97,108,115,101]),new R(y.false,!1,5);case 116:return this.expect([116,114,117,101]),new R(y.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 R(y.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 R(y.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 R(y.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 R(y.break,void 0,1);let t=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"),t}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 Ki(r,t){return t=Object.assign({tokenizer:new Qr(r,t)},t),me(r,t)}var Ub={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Ub.tags[42]=tt.parse;var Ep=297;var Lk=new TextDecoder;var Uk=new TextEncoder;var Pb=new TextDecoder;function yu(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 qi(r,t){let e;[e,t]=yu(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 vp(r,t){let e;return[e,t]=yu(r,t),[e&7,e>>3,t]}function Ob(r){let t={},e=r.length,n=0;for(;n<e;){let o,s;if([o,s,n]=vp(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]=qi(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]=qi(r,n),t.Name=Pb.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]=yu(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 Ap(r){let t=r.length,e=0,n,o=!1,s;for(;e<t;){let a,c;if([a,c,e]=vp(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]=qi(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]=qi(r,e),n.push(Ob(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 Pk=new TextEncoder,Ok=2**32,Fk=2**31;var $k=new TextEncoder;function Bp(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var kp=112;function Sp(r){let t=Bp(r),e=Ap(t),n={};return e.Data&&(n.Data=e.Data),e.Links&&(n.Links=e.Links.map(o=>{let s={};try{s.Hash=tt.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 Vb={codec:kp,*walk(r){yield*Sp(r).Links.map(e=>e.Hash)}},Mb={codec:ls,*walk(){}},Ip=42,$b={codec:wp,*walk(r){let t=[],e=[];e[Ip]=n=>{if(n[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");let o=tt.decode(n.subarray(1));return t.push(o),o},me(r,{tags:e}),yield*t}},wu=class extends Qr{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===y.map){let e=this._next();if(e.type===y.string&&e.value==="/"){let n=this._next();if(n.type===y.string){if(this._next().type!==y.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new R(y.tag,42,0)}if(n.type===y.map){let o=this._next();if(o.type===y.string&&o.value==="bytes"){let s=this._next();if(s.type===y.string){for(let a=0;a<2;a++)if(this._next().type!==y.break)throw new Error("Invalid encoded Bytes form");let i=ue.decode(`m${s.value}`);return new R(y.bytes,i,s.value.length)}this.tokenBuffer.push(s)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(e)}return t}},Hb={codec:Ep,*walk(r){let t=[],e=[];e[Ip]=n=>{let o=tt.parse(n);return t.push(o),o},Ki(r,{tags:e,tokenizer:new wu(r,{tags:e,allowIndefinite:!0,allowUndefined:!0,allowNaN:!0,allowInfinity:!0,allowBigInt:!0,strict:!1,rejectDuplicateMapKeys:!1})}),yield*t}},Kb={codec:Hl,*walk(){}};function Rp(r=[]){let t={};return[Vb,Mb,$b,Hb,Kb,...r].forEach(e=>{t[e.codec]=e}),t}var bu=new Dt("/version"),_p=1;async function Tp(r){if(!await r.has(bu)){await r.put(bu,q(`${_p}`));return}let t=await r.get(bu),e=j(t);if(parseInt(e,10)!==_p)throw new Error("Unknown datastore version, a datastore migration may be required")}function Cp(r=[]){let t={};return[At,rc,Wt,...r].forEach(e=>{t[e.code]=e}),t}var cr=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 Yn={};vt(Yn,{abortedError:()=>Wb,closeFailedError:()=>zb,deleteFailedError:()=>Lp,getFailedError:()=>jb,hasFailedError:()=>Gb,notFoundError:()=>Ko,openFailedError:()=>qb,putFailedError:()=>Np});var ur=Xt(on(),1);function qb(r){return r=r??new Error("Open failed"),(0,ur.default)(r,"ERR_OPEN_FAILED")}function zb(r){return r=r??new Error("Close failed"),(0,ur.default)(r,"ERR_CLOSE_FAILED")}function Np(r){return r=r??new Error("Put failed"),(0,ur.default)(r,"ERR_PUT_FAILED")}function jb(r){return r=r??new Error("Get failed"),(0,ur.default)(r,"ERR_GET_FAILED")}function Lp(r){return r=r??new Error("Delete failed"),(0,ur.default)(r,"ERR_DELETE_FAILED")}function Gb(r){return r=r??new Error("Has failed"),(0,ur.default)(r,"ERR_HAS_FAILED")}function Ko(r){return r=r??new Error("Not Found"),(0,ur.default)(r,"ERR_NOT_FOUND")}function Wb(r){return r=r??new Error("Aborted"),(0,ur.default)(r,"ERR_ABORTED")}var qo=class extends cr{data;constructor(){super(),this.data=new Map}put(t,e){return this.data.set(Nt.encode(t.multihash.bytes),e),t}get(t){let e=this.data.get(Nt.encode(t.multihash.bytes));if(e==null)throw Ko();return e}has(t){return this.data.has(Nt.encode(t.multihash.bytes))}async delete(t){this.data.delete(Nt.encode(t.multihash.bytes))}async*getAll(){for(let[t,e]of this.data.entries())yield{cid:tt.createV1(ls,Ne(Nt.decode(t))),block:e}}};function Yb(r){return r[Symbol.asyncIterator]!=null}function Zb(r,t){let e=0;if(Yb(r))return async function*(){for await(let c of r)await t(c,e++)&&(yield c)}();let n=sn(r),{value:o,done:s}=n.next();if(s===!0)return function*(){}();let i=t(o,e++);if(typeof i.then=="function")return async function*(){await i&&(yield o);for await(let c of n)await t(c,e++)&&(yield c)}();let a=t;return function*(){i===!0&&(yield o);for(let c of n)a(c,e++)&&(yield c)}()}var Re=Zb;var BS=ne("blockstore:core:tiered");var Up={...Yn};var zi=0,ji=class extends cr{child;constructor(t){super(),this.child=t}put(t,e){return t.multihash.code===zi||this.child==null?t:this.child.put(t,e)}get(t){if(t.multihash.code===zi)return t.multihash.digest;if(this.child==null)throw Up.notFoundError();return this.child.get(t)}has(t){return t.multihash.code===zi?!0:this.child==null?!1:this.child.has(t)}delete(t){if(t.code!==zi&&this.child!=null)return this.child.delete(t)}getAll(t){return this.child!=null?this.child.getAll(t):[]}};function Jb(r){return r[Symbol.asyncIterator]!=null}function Dp(r){return r?.then!=null}function Xb(r,t){let e=0;if(Jb(r))return async function*(){for await(let c of r){let u=t(c,e++);Dp(u)&&await u,yield c}}();let n=sn(r),{value:o,done:s}=n.next();if(s===!0)return function*(){}();if(typeof t(o,e++)?.then=="function")return async function*(){yield o;for await(let c of n){let u=t(c,e++);Dp(u)&&await u,yield c}}();let a=t;return function*(){yield o;for(let c of n)a(c,e++),yield c}()}var xu=Xb;var Gi=class{child;hashers;log;logger;components;constructor(t){this.log=t.logger.forComponent("helia:networked-storage"),this.logger=t.logger,this.components=t,this.child=new ji(t.blockstore),this.hashers=t.hashers??{}}async put(t,e,n={}){return await this.child.has(t,n)?(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=Re(t,async({cid:s})=>{let i=await this.child.has(s,e);return i&&e.onProgress?.(new nt("blocks:put-many:duplicate",s)),!i}),o=xu(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)){e.onProgress?.(new nt("blocks:get:providers:get",t));let n=await Pp(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(xu(t,async n=>{if(e.offline!==!0&&!await this.child.has(n,e)){e.onProgress?.(new nt("blocks:get-many:providers:get",n));let o=await Pp(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)}},Wi=class extends Gi{started;constructor(t){super(t),this.started=!1}isStarted(){return this.started}async start(){await pr(this.child,...this.components.blockBrokers),this.started=!0}async stop(){await mr(this.child,...this.components.blockBrokers),this.started=!1}unwrap(){return this.child}createSession(t,e){let n=this.components.blockBrokers.map(o=>o.createSession==null?o:o.createSession(e));return new Eu({blockstore:this.child,blockBrokers:n,hashers:this.hashers,logger:this.logger},{root:t})}},Eu=class extends Gi{closeController;constructor(t,e){super(t),this.closeController=new AbortController,ft(1/0,this.closeController.signal),this.log=t.logger.forComponent(`helia:session-storage:${e.root}`)}close(){this.closeController.abort()}async put(t,e,n={}){let o=Ht([this.closeController.signal,n.signal]);ft(1/0,o);try{return await super.put(t,e,{...n,signal:o})}finally{o.clear()}}async*putMany(t,e={}){let n=Ht([this.closeController.signal,e.signal]);ft(1/0,n);try{yield*super.putMany(t,{...e,signal:n})}finally{n.clear()}}async get(t,e={}){let n=Ht([this.closeController.signal,e.signal]);ft(1/0,n);try{return await super.get(t,{...e,signal:n})}finally{n.clear()}}async*getMany(t,e={}){let n=Ht([this.closeController.signal,e.signal]);ft(1/0,n);try{yield*super.getMany(t,{...e,signal:n})}finally{n.clear()}}async delete(t,e={}){let n=Ht([this.closeController.signal,e.signal]);ft(1/0,n);try{await super.delete(t,{...e,signal:n})}finally{n.clear()}}async*deleteMany(t,e={}){let n=Ht([this.closeController.signal,e.signal]);ft(1/0,n);try{yield*super.deleteMany(t,{...e,signal:n})}finally{n.clear()}}async has(t,e={}){let n=Ht([this.closeController.signal,e.signal]);ft(1/0,n);try{return await super.has(t,{...e,signal:n})}finally{n.clear()}}async*getAll(t={}){let e=Ht([this.closeController.signal,t.signal]);ft(1/0,e);try{yield*super.getAll({...t,signal:e})}finally{e.clear()}}};function Qb(r){return typeof r.retrieve=="function"}var tx=(r,t)=>{if(t==null)throw new D(`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(!it(n.digest,r.multihash.digest))throw new D("Hash of downloaded block did not match multihash from passed CID","ERR_HASH_MISMATCH")}};async function Pp(r,t,e,n){let o=tx(r,e),s=new AbortController,i=Ht([s.signal,n.signal]);ft(1/0,s.signal,i);let a=[];for(let c of t)Qb(c)&&a.push(c);try{return await Promise.any(a.map(async c=>{try{let u=!1,f=await c.retrieve(r,{...n,signal:i,validateFn:async l=>{await o(l),u=!0}});return u||await o(f),f}catch(u){throw n.log.error("could not retrieve verified block for %c",r,u),u}}))}finally{s.abort(),i.clear()}}var Op=1,Fp=5;var vu=Xt(Mh(),1);var ex=Math.LN2*Math.LN2,Yi=class r{static create(t,e=.005){let n=rx(t,e);return new r(n)}seeds;bits;buffer;constructor(t={}){t.seeds!=null?this.seeds=t.seeds:this.seeds=nx(t.hashes??8),this.bits=t.bits??1024,this.buffer=we(Math.ceil(this.bits/8))}add(t){typeof t=="string"&&(t=q(t));for(let e=0;e<this.seeds.length;e++){let o=vu.default.x86.hash32(t,this.seeds[e])%this.bits;this.setbit(o)}}has(t){typeof t=="string"&&(t=q(t));for(let e=0;e<this.seeds.length;e++){let o=vu.default.x86.hash32(t,this.seeds[e])%this.bits;if(!this.getbit(o))return!1}return!0}clear(){this.buffer.fill(0)}setbit(t){let e=0,n=t;for(;n>7;)e++,n-=8;let o=this.buffer[e];o|=1<<n,this.buffer[e]=o}getbit(t){let e=0,n=t;for(;n>7;)e++,n-=8;return(this.buffer[e]&1<<n)!==0}};function rx(r,t=.005){let e=Math.round(-1*r*Math.log(t)/ex),n=Math.round(e/r*Math.LN2);return{bits:e,hashes:n}}function nx(r){let t,e,n=[];for(let o=0;o<r;o++)for(t=new as(De(4)),n[o]=t.getUint32(0,!0),e=0;e<o;e++)if(n[o]===n[e]){o--;break}return n}var zo=class extends en{intialPeerSearchComplete;requests;name;log;logger;minProviders;maxProviders;providers;evictionFilter;constructor(t,e){super(),ft(1/0,this),this.name=e.name,this.logger=t.logger,this.log=t.logger.forComponent(this.name),this.requests=new Map,this.minProviders=e.minProviders??1,this.maxProviders=e.maxProviders??5,this.providers=[],this.evictionFilter=Yi.create(this.maxProviders)}async retrieve(t,e={}){let n=ue.encode(t.multihash.bytes),o=this.requests.get(n);if(o!=null)return this.log("join existing request for %c",t),o;let s=St();if(this.requests.set(n,s.promise),this.providers.length===0){let u=!1;this.intialPeerSearchComplete==null&&(u=!0,this.log=this.logger.forComponent(`${this.name}:${t}`),this.intialPeerSearchComplete=this.findProviders(t,this.minProviders,e)),await this.intialPeerSearchComplete,u&&this.log("found initial session peers for %c",t)}let i=!1,a=new qe({concurrency:this.maxProviders});a.addEventListener("error",()=>{}),a.addEventListener("failure",u=>{this.log.error("error querying provider %o, evicting from session",u.detail.job.options.provider,u.detail.error),this.evict(u.detail.job.options.provider)}),a.addEventListener("success",u=>{i=!0,s.resolve(u.detail.result)}),a.addEventListener("idle",()=>{i||e.signal?.aborted===!0||Promise.resolve().then(async()=>{this.log("no session peers had block for for %c, finding new providers",t);for(let u=0;u<this.minProviders&&this.providers.length!==0;u++){let f=this.providers[Math.floor(Math.random()*this.providers.length)];this.evict(f)}await this.findProviders(t,this.minProviders,e),this.log("found new providers re-retrieving %c",t),this.requests.delete(n),s.resolve(await this.retrieve(t,e))}).catch(u=>{this.log.error("could not find new providers for %c",t,u),s.reject(u)})});let c=u=>{a.add(async()=>this.queryProvider(t,u.detail,e),{provider:u.detail}).catch(f=>{e.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c",t,f)})};this.addEventListener("provider",c),Promise.all([...this.providers].map(async u=>a.add(async()=>this.queryProvider(t,u,e),{provider:u}))).catch(u=>{e.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c",t,u)});try{return await s.promise}finally{this.removeEventListener("provider",c),a.clear(),this.requests.delete(n)}}evict(t){this.evictionFilter.add(this.toEvictionKey(t));let e=this.providers.findIndex(n=>this.equals(n,t));e!==-1&&this.providers.splice(e,1)}isEvicted(t){return this.evictionFilter.has(this.toEvictionKey(t))}hasProvider(t){return!!(this.providers.find(e=>this.equals(e,t))!=null||this.isEvicted(t))}async findProviders(t,e,n){let o=St(),s=0;return Promise.resolve().then(async()=>{this.log("finding %d-%d new provider(s) for %c",e,this.maxProviders,t);for await(let i of this.findNewProviders(t,n)){if(s===this.maxProviders||n.signal?.aborted===!0)break;if(!this.hasProvider(i)&&(this.log("found %d/%d new providers",s,this.maxProviders),this.providers.push(i),this.safeDispatchEvent("provider",{detail:i}),s++,s===e&&(this.log("session is ready"),o.resolve()),this.providers.length===this.maxProviders)){this.log("found max session peers",s);break}}if(this.log("found %d/%d new session peers",s,this.maxProviders),s<e)throw new D(`Found ${s} of ${e} ${this.name} providers for ${t}`,"ERR_INSUFFICIENT_PROVIDERS_FOUND")}).catch(i=>{this.log.error("error searching routing for potential session peers for %c",t,i.errors??i),o.reject(i)}),o.promise}};var Zi=class{blockstore;datastore;pins;logger;routing;dagWalkers;hashers;dns;metrics;log;constructor(t){this.logger=t.logger??jh(),this.log=this.logger.forComponent("helia"),this.hashers=Cp(t.hashers),this.dagWalkers=Rp(t.dagWalkers),this.dns=t.dns??rd(),this.metrics=t.metrics;let e={blockstore:t.blockstore,datastore:t.datastore,hashers:this.hashers,dagWalkers:this.dagWalkers,logger:this.logger,blockBrokers:[],dns:this.dns,metrics:this.metrics,...t.components??{}};this.routing=e.routing=new $i(e,{routers:(t.routers??[]).flatMap(o=>{let s=[o];return o[ro]!=null&&s.push(o[ro]),o[oo]!=null&&s.push(o[oo]),s}),providerLookupConcurrency:t.providerLookupConcurrency});let n=new Wi(e);this.pins=new Mi(t.datastore,n,this.dagWalkers),this.blockstore=new Hi(n,this.pins,{holdGcLock:t.holdGcLock??!0}),this.datastore=t.datastore,e.blockBrokers=t.blockBrokers.map(o=>o(e))}async start(){await Tp(this.datastore),await pr(this.blockstore,this.datastore,this.routing)}async stop(){await mr(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 Vr(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 Ji=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 f=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let m=Number.parseInt(l,t);if(!Number.isNaN(m))return m});if(f===void 0)break;if(s*=t,s+=f,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 Vp=45,ox=15,Zn=new Ji;function Au(r){if(!(r.length>ox))return Zn.new(r).parseWith(()=>Zn.readIPv4Addr())}function Bu(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Vp))return Zn.new(r).parseWith(()=>Zn.readIPv6Addr())}function Xi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Vp))return Zn.new(r).parseWith(()=>Zn.readIPAddr())}function Jn(r){return!!Au(r)}function Xn(r){return!!Bu(r)}function Qi(r){return!!Xi(r)}var $p=Xt(Mp(),1),sx=["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"],ix=sx.map(r=>new $p.Netmask(r));function ax(r){for(let t of ix)if(t.contains(r))return!0;return!1}function cx(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 Hp(r){return Jn(r)?ax(r):Xn(r)?cx(r):void 0}var LI=parseInt("0xFFFF",16),UI=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var zp=Jn,dx=Xn,ku=function(r){let t=0;if(r=r.toString().trim(),zp(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(dx(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=zp(e[n]),i;s&&(i=ku(e[n]),e[n]=j(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,j(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")},jp=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 Qn={},Su={},mx=[[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"],[481,-1,"http-path"],[777,-1,"memory"]];mx.forEach(r=>{let t=gx(...r);Su[t.code]=t,Qn[t.name]=t});function gx(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function G(r){if(typeof r=="number"){if(Su[r]!=null)return Su[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(Qn[r]!=null)return Qn[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var m6=G("ip4"),g6=G("ip6"),y6=G("ipcidr");function Tu(r,t){switch(G(r).code){case 4:case 41:return wx(t);case 42:return _u(t);case 6:case 273:case 33:case 132:return Yp(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return _u(t);case 421:return vx(t);case 444:return Wp(t);case 445:return Wp(t);case 466:return Ex(t);case 481:return globalThis.encodeURIComponent(_u(t));default:return j(t,"base16")}}function Cu(r,t){switch(G(r).code){case 4:return Gp(t);case 41:return Gp(t);case 42:return Ru(t);case 6:case 273:case 33:case 132:return Nu(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ru(t);case 421:return bx(t);case 444:return Ax(t);case 445:return Bx(t);case 466:return xx(t);case 481:return Ru(globalThis.decodeURIComponent(t));default:return q(t,"base16")}}var Iu=Object.values(br).map(r=>r.decoder),yx=function(){let r=Iu[0].or(Iu[1]);return Iu.slice(2).forEach(t=>r=r.or(t)),r}();function Gp(r){if(!Qi(r))throw new Error("invalid ip address");return ku(r)}function wx(r){let t=jp(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!Qi(t))throw new Error("invalid ip address");return t}function Nu(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Yp(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Ru(r){let t=q(r),e=Uint8Array.from(nn(t.length));return It([e,t],e.length+t.length)}function _u(r){let t=Mr(r);if(r=r.slice(Gt(t)),r.length!==t)throw new Error("inconsistent lengths");return j(r)}function bx(r){let t;r[0]==="Q"||r[0]==="1"?t=Ne(ht.decode(`z${r}`)).bytes:t=tt.parse(r).multihash.bytes;let e=Uint8Array.from(nn(t.length));return It([e,t],e.length+t.length)}function xx(r){let t=yx.decode(r),e=Uint8Array.from(nn(t.length));return It([e,t],e.length+t.length)}function Ex(r){let t=Mr(r),e=r.slice(Gt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+j(e,"base64url")}function vx(r){let t=Mr(r),e=r.slice(Gt(t));if(e.length!==t)throw new Error("inconsistent lengths");return j(e,"base58btc")}function Ax(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=Nt.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=Nu(n);return It([e,o],e.length+o.length)}function Bx(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=Nt.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=Nu(n);return It([e,o],e.length+o.length)}function Wp(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=j(t,"base32"),o=Yp(e);return`${n}:${o}`}function Zp(r){r=Lu(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 Xp("invalid address: "+r);if(a.path===!0){n=Lu(o.slice(s).join("/")),t.push([a.code,Cu(a.code,n)]),e.push([a.code,n]);break}let c=Cu(a.code,o[s]);t.push([a.code,c]),e.push([a.code,Tu(a.code,c)])}return{string:Jp(e),bytes:Du(t),tuples:t,stringTuples:e,path:n}}function Uu(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=Mr(r,o),i=Gt(s),a=G(s),c=kx(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 Xp("Invalid address Uint8Array: "+j(r,"base16"));t.push([s,u]);let f=Tu(s,u);if(e.push([s,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(r),string:Jp(e),tuples:t,stringTuples:e,path:n}}function Jp(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}),Lu(t.join("/"))}function Du(r){return It(r.map(t=>{let e=G(t[0]),n=Uint8Array.from(nn(e.code));return t.length>1&&t[1]!=null&&(n=It([n,t[1]])),n}))}function kx(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Mr(t instanceof Uint8Array?t:Uint8Array.from(t));return e+Gt(e)}}function Lu(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function Xp(r){return new Error("Error parsing address: "+r)}var Sx=Symbol.for("nodejs.util.inspect.custom"),Pu=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Ix=[G("dns").code,G("dns4").code,G("dns6").code,G("dnsaddr").code],ta=class r{bytes;#t;#e;#r;#o;[Pu]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Uu(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Zp(t)}else if(t0(t))e=Uu(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.#o=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"),f=G("dns6"),l=G("ip6zone");for(let[h,p]of this.stringTuples())h===l.code&&(s=`%${p??""}`),Ix.includes(h)&&(e=i.name,o=443,n=`${p??""}${s}`,t=h===f.code?6:4),(h===i.code||h===a.code)&&(e=G(h).name,o=parseInt(p??"")),(h===c.code||h===u.code)&&(e=G(h).name,n=`${p??""}${s}`,t=h===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(Du(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===Qn.p2p.code&&t.push([n,o]),n===Qn["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?j(ht.decode(`z${n}`),"base58btc"):j(tt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#o}equals(t){return it(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=Qp.get(e.name);if(n==null)throw new D(`no available resolver for ${e.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,t)).map(s=>lr(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)}[Sx](){return`Multiaddr(${this.#t})`}};var Qp=new Map;function t0(r){return!!r?.[Pu]}function lr(r){return new ta(r)}var Rx=r=>r.toString().split("/").slice(1),Go=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),ot=r=>({match:t=>Go(e=>e===r).match(t),pattern:r}),na=()=>({match:r=>Go(t=>typeof t=="string").match(r),pattern:"{string}"}),oa=()=>({match:r=>Go(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),Pt=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{ht.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),ea=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Ga.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),kt=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),ge=(...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(", ")})`}),ct=(...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 yt(...r){function t(o){let s=Rx(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 Fu=ct(ot("dns4"),na()),Vu=ct(ot("dns6"),na()),Mu=ct(ot("dnsaddr"),na()),e0=ct(ot("dns"),na()),j6=yt(Fu),G6=yt(Vu),W6=yt(Mu),r0=yt(ge(e0,Mu,Fu,Vu)),n0=ct(ot("ip4"),Go(Jn)),o0=ct(ot("ip6"),Go(Xn)),s0=ge(n0,o0),$e=ge(s0,e0,Fu,Vu,Mu),Y6=yt($e),Z6=yt(n0),J6=yt(o0),X6=yt(s0),$u=ct($e,ot("tcp"),oa()),Wo=ct($e,ot("udp"),oa()),Q6=yt($u),t4=yt(Wo),Hu=ct(Wo,ot("quic")),sa=ct(Wo,ot("quic-v1")),_x=ge(Hu,sa),e4=yt(Hu),r4=yt(sa),Ou=ge($e,$u,Wo,Hu,sa),i0=ge(ct(Ou,ot("ws"),kt(Pt()))),n4=yt(i0),a0=ge(ct(Ou,ot("wss"),kt(Pt())),ct(Ou,ot("tls"),ot("ws"),kt(Pt()))),o4=yt(a0),c0=ct(Wo,ot("webrtc-direct"),kt(ea()),kt(ea()),kt(Pt())),s4=yt(c0),u0=ct(sa,ot("webtransport"),kt(ea()),kt(ea()),kt(Pt())),i4=yt(u0),ra=ge(i0,a0,ct($u,kt(Pt())),ct(_x,kt(Pt())),ct($e,kt(Pt())),c0,u0,Pt()),a4=yt(ra),Tx=ct(ra,ot("p2p-circuit"),Pt()),c4=yt(Tx),Cx=ge(ct(ra,ot("p2p-circuit"),ot("webrtc"),kt(Pt())),ct(ra,ot("webrtc"),kt(Pt())),ot("webrtc")),u4=yt(Cx),Nx=ge(ct($e,ot("tcp"),oa(),ot("http"),kt(Pt())),ct($e,ot("http"),kt(Pt()))),l0=yt(Nx),Lx=ge(ct($e,ot("tcp"),ge(ct(ot("443"),ot("http")),ct(oa(),ot("https"))),kt(Pt())),ct($e,ot("tls"),ot("http"),kt(Pt())),ct($e,ot("https"),kt(Pt()))),f0=yt(Lx);var Ux=[G("tcp").code,G("dns").code,G("dnsaddr").code,G("dns4").code,G("dns6").code];function h0(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 d0(r){return r.some(([t,e])=>t===G("tls").code)}function Zt(r,t,e){let n=p0[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 p0={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://${Zt(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://${Zt(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`${Zt(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`${Zt(e[0],e[1]??"",t)}/p2p/${r}`},http:(r,t)=>{let e=d0(t),n=h0(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=Zt(s[0],s[1]??"",t);return i=i.replace("tcp://",""),`${o}${i}`},"http-path":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");let n=Zt(e[0],e[1]??"",t),o=decodeURIComponent(r);return`${n}/${o}`},tls:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return Zt(e[0],e[1]??"",t)},sni:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return Zt(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=Zt(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`https://${n}`},ws:(r,t)=>{let e=d0(t),n=h0(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=Zt(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=Zt(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`${Zt(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`${Zt(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`${Zt(e[0],e[1]??"",t)}/p2p-webrtc-direct`}};function m0(r,t){let n=lr(r).stringTuples(),o=n.pop();if(o===void 0)throw new Error("Unexpected end of multiaddr");let s=G(o[0]),i=p0[s.name];if(i==null)throw new Error(`No interpreter found for ${s.name}`);let a=i(o[1]??"",n);return t?.assumeHttp!==!1&&Ux.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 ia=class{url;#t=0;#e=0;#r=0;#o=0;#a=new Map;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}`)}#u(t){let e=t.multihash.bytes;return ue.encode(e)}async getRawBlock(t,e){let n=new URL(this.url.toString());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`);let o=this.#u(t),s=new AbortController,i=()=>{s.abort()};e?.addEventListener("abort",i);try{let a=this.#a.get(o);return a==null&&(this.#t++,a=fetch(n.toString(),{signal:s.signal,headers:{Accept:"application/vnd.ipld.raw"},cache:"force-cache"}).then(async c=>{if(this.log("GET %s %d",n,c.status),!c.ok)throw this.#e++,new Error(`unable to fetch raw block for CID ${t} from gateway ${this.url}`);return this.#o++,new Uint8Array(await c.arrayBuffer())}),this.#a.set(o,a)),await a}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}`))}finally{e?.removeEventListener("abort",i),this.#a.delete(o)}}reliability(){return this.#t===0?1:this.#r>0?-1/0:this.#o/(this.#t+this.#e*3)}incrementInvalidBlocks(){this.#r++}getStats(){return{attempts:this.#t,errors:this.#e,invalidBlocks:this.#r,successes:this.#o,pendingResponses:this.#a.size}}};function Dx(r,t,e){return r.filter(n=>f0.matches(n)||t&&l0.matches(n)?e||r0.matches(n)?!0:Hp(n.toOptions().host)===!1:!1)}async function*aa(r,t,e,n,o,s){for await(let i of t.findProviders(r,s)){let a=Dx(i.multiaddrs,n,o);if(a.length===0)continue;let c=m0(a[0]);yield new ia(c,e)}}var Ku=class extends zo{routing;allowInsecure;allowLocal;constructor(t,e){super(t,{...e,name:"helia:trustless-gateway:session"}),this.routing=t.routing,this.allowInsecure=e.allowInsecure??ca,this.allowLocal=e.allowLocal??ua}async queryProvider(t,e,n){this.log("fetching BLOCK for %c from %s",t,e.url);let o=await e.getRawBlock(t,n.signal);return this.log.trace("got block for %c from %s",t,e.url),await n.validateFn?.(o),o}async*findNewProviders(t,e={}){yield*aa(t,this.routing,this.logger,this.allowInsecure,this.allowLocal,e)}toEvictionKey(t){return t.url.toString()}equals(t,e){return t.url.toString()===e.url.toString()}};function g0(r,t){return new Ku(r,t)}var la=class{allowInsecure;allowLocal;routing;log;logger;constructor(t,e={}){this.log=t.logger.forComponent("helia:trustless-gateway-block-broker"),this.logger=t.logger,this.routing=t.routing,this.allowInsecure=e.allowInsecure??ca,this.allowLocal=e.allowLocal??ua}async retrieve(t,e={}){let n=[];for await(let o of aa(t,this.routing,this.logger,this.allowInsecure,this.allowLocal,e)){this.log("getting block for %c from %s",t,o.url);try{let s=await o.getRawBlock(t,e.signal);this.log.trace("got block for %c from %s",t,o.url);try{await e.validateFn?.(s)}catch(i){this.log.error("failed to validate block for %c from %s",t,o.url,i);continue}return s}catch(s){if(this.log.error("failed to get block for %c from %s",t,o.url,s),s instanceof Error?n.push(s):n.push(new Error(`Unable to fetch raw block for CID ${t} from gateway ${o.url}`)),e.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",t,o.url);break}}}throw n.length>0?new AggregateError(n,`Unable to fetch raw block for CID ${t} from any gateway`):new Error(`Unable to fetch raw block for CID ${t} from any gateway`)}createSession(t={}){return g0({logger:this.logger,routing:this.routing},t)}};var ca=!1,ua=!1;function qu(r={}){return t=>new la(t,r)}async function*fa(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 Vx=Xt(on(),1);var Mx=Xt(ju(),1);var y0="ERR_IPNS_EXPIRED_RECORD",ha="ERR_UNRECOGNIZED_VALIDITY";var fr="ERR_SIGNATURE_VERIFICATION";var Gu="ERR_UNDEFINED_PARAMETER",w0="ERR_INVALID_RECORD_DATA",b0="ERR_INVALID_VALUE",x0="ERR_INVALID_EMBEDDED_KEY";var E0="ERR_RECORD_TOO_LARGE";var _e;(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=()=>lo(e)}(t=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=mn((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=>dn(o,r.codec()),r.decode=o=>cn(o,r.codec())})(_e||(_e={}));var ce=Xt(on(),1);var A0=ne("ipns:utils"),B0=q("/ipns/"),Px=114,k0=async(r,t)=>{if(t==null||r==null){let n=new Error("one or more of the provided parameters are not defined");throw A0.error(n),(0,ce.default)(n,Gu)}let e;if(t.pubKey!=null){try{e=zc(t.pubKey)}catch(o){throw A0.error(o),o}if(!(await sf(t.pubKey)).equals(r))throw(0,ce.default)(new Error("Embedded public key did not match PeerID"),x0)}else r.publicKey!=null&&(e=zc(r.publicKey));if(e!=null)return e;throw(0,ce.default)(new Error("no public key is available"),Gu)};var S0=r=>{let t=q("ipns-signature:");return It([t,r])},tn=r=>"signatureV1"in r?_e.encode({value:q(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:q(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):_e.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data});function He(r){let t=_e.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,ce.default)(new Error("missing data or signatureV2"),fr);let e=I0(t.data),n=Ox(e.Value),o=j(e.Validity);if(t.value!=null&&t.signatureV1!=null)return Fx(t),{value:n,validityType:_e.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:_e.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 Wu=r=>It([B0,r.toBytes()]),to=r=>ho(r.slice(B0.length));var I0=r=>{let t=me(r);if(t.ValidityType===0)t.ValidityType=_e.ValidityType.EOL;else throw(0,ce.default)(new Error("Unknown validity type"),ha);return Number.isInteger(t.Sequence)&&(t.Sequence=BigInt(t.Sequence)),Number.isInteger(t.TTL)&&(t.TTL=BigInt(t.TTL)),t},Ox=r=>{if(r!=null){if(wl(r))return`/ipns/${r.toCID().toString(wr)}`;if(r instanceof Uint8Array){let n=j(r);n.startsWith("/")&&(r=n)}let t=r.toString().trim();if(t.startsWith("/")&&t.length>1)return t;let e=tt.asCID(r);if(e!=null)return e.code===Px?`/ipns/${e.toString(wr)}`:`/ipfs/${e.toV1().toString()}`;try{return r instanceof Uint8Array?`/ipfs/${tt.decode(r).toV1().toString()}`:`/ipfs/${tt.parse(t).toV1().toString()}`}catch{}}throw(0,ce.default)(new Error("Value must be a valid content path starting with /"),b0)},Fx=r=>{if(r.data==null)throw(0,ce.default)(new Error("Record data is missing"),w0);let t=I0(r.data);if(!it(t.Value,r.value??new Uint8Array(0)))throw(0,ce.default)(new Error('Field "value" did not match between protobuf and CBOR'),fr);if(!it(t.Validity,r.validity??new Uint8Array(0)))throw(0,ce.default)(new Error('Field "validity" did not match between protobuf and CBOR'),fr);if(t.ValidityType!==r.validityType)throw(0,ce.default)(new Error('Field "validityType" did not match between protobuf and CBOR'),fr);if(t.Sequence!==r.sequence)throw(0,ce.default)(new Error('Field "sequence" did not match between protobuf and CBOR'),fr);if(t.TTL!==r.ttl)throw(0,ce.default)(new Error('Field "ttl" did not match between protobuf and CBOR'),fr)};var n3=ne("ipns"),o3=Wt.code,s3=60*60*1e9,$x="/ipns/",i3=$x.length;var Yo=Xt(on(),1),R0=Xt(ju(),1);var da=ne("ipns:validator"),Hx=1024*10,Kx=async(r,t)=>{let e=He(t),n;try{let o=S0(e.data);n=await r.verify(o,e.signatureV2)}catch{n=!1}if(!n)throw da.error("record signature verification failed"),(0,Yo.default)(new Error("record signature verification failed"),fr);if(e.validityType===_e.ValidityType.EOL){if(R0.default.fromString(e.validity).toDate().getTime()<Date.now())throw da.error("record has expired"),(0,Yo.default)(new Error("record has expired"),y0)}else if(e.validityType!=null)throw da.error("unrecognized validity type"),(0,Yo.default)(new Error("unrecognized validity type"),ha);da("ipns record for %s is valid",e.value)};async function _0(r,t){if(t.byteLength>Hx)throw(0,Yo.default)(new Error("record too large"),E0);let e=to(r),n=He(t),o=await k0(e,n);await Kx(o,t)}async function*Zo(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))}function qx(r){return r[Symbol.asyncIterator]!=null}function zx(r){if(qx(r))return(async()=>{for await(let t of r)return t})();for(let t of r)return t}var pa=zx;var Yu=q("/ipns/");function T0(r){return it(r.subarray(0,Yu.byteLength),Yu)}var C0=r=>ho(r.slice(Yu.length)),ma=class{client;constructor(t){this.client=t}async*findProviders(t,e={}){yield*an(this.client.getProviders(t,e),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async put(t,e,n){if(!T0(t))return;let o=C0(t),s=He(e);await this.client.putIPNS(o,s,n)}async get(t,e){if(!T0(t))throw new D("Not found","ERR_NOT_FOUND");let n=C0(t);try{let o=await this.client.getIPNS(n,e);return tn(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new D("Not found","ERR_NOT_FOUND"):o}}},ga=class{client;constructor(t){this.client=t}async findPeer(t,e={}){let n=await pa(this.client.getPeers(t,e));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new D("Not found","ERR_NOT_FOUND")}async*getClosestPeers(t,e={}){}};var Jt=ne("delegated-routing-v1-http-api-client"),N0={concurrentRequests:4,timeout:3e4},ya=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;constructor(t,e={}){this.started=!1,this.shutDownController=new AbortController,ft(1/0,this.shutDownController.signal),this.httpQueue=new Ve({concurrency:e.concurrentRequests??N0.concurrentRequests}),this.clientUrl=t instanceof URL?t:new URL(t),this.timeout=e.timeout??N0.timeout,this.contentRouting=new ma(this),this.peerRouting=new ga(this)}get[ro](){return this.contentRouting}get[oo](){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={}){Jt("getProviders starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=Ht([this.shutDownController.signal,n,e.signal]);ft(1/0,n,o);let s=St(),i=St();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 D("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new D("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new D("Routing response had no body","ERR_BAD_RESPONSE");if(u.headers.get("Content-Type")==="application/json"){let l=await u.json();for(let m of l.Providers){let h=this.#t(m);h!=null&&(yield h)}}else for await(let l of Zo(fa(u.body))){let m=this.#t(l);m!=null&&(yield m)}}catch(a){Jt.error("getProviders errored:",a)}finally{o.clear(),i.resolve(),Jt("getProviders finished: %c",t)}}async*getPeers(t,e={}){Jt("getPeers starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=Ht([this.shutDownController.signal,n,e.signal]);ft(1/0,n,o);let s=St(),i=St();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 D("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new D("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new D("Routing response had no body","ERR_BAD_RESPONSE");if(u.headers.get("Content-Type")==="application/json"){let l=await u.json();for(let m of l.Peers){let h=this.#t(m);h!=null&&(yield h)}}else for await(let l of Zo(fa(u.body))){let m=this.#t(l);m!=null&&(yield m)}}catch(a){Jt.error("getPeers errored:",a)}finally{o.clear(),i.resolve(),Jt("getPeers finished: %c",t)}}async getIPNS(t,e={}){Jt("getIPNS starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=Ht([this.shutDownController.signal,n,e.signal]);ft(1/0,n,o);let s=St(),i=St();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(Jt("getIPNS GET %s %d",a,u.status),u.status===404)throw new D("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new D("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new D("GET ipns response had no body","ERR_BAD_RESPONSE");let f=await u.arrayBuffer(),l=new Uint8Array(f,0,f.byteLength);return e.validate!==!1&&await _0(Wu(t),l),He(l)}catch(c){throw Jt.error("getIPNS GET %s error:",a,c),c}finally{o.clear(),i.resolve(),Jt("getIPNS finished: %c",t)}}async putIPNS(t,e,n={}){Jt("putIPNS starts: %c",t);let o=AbortSignal.timeout(this.timeout),s=Ht([this.shutDownController.signal,o,n.signal]);ft(1/0,o,s);let i=St(),a=St();this.httpQueue.add(async()=>(i.resolve(),a.promise));let c=`${this.clientUrl}routing/v1/ipns/${t.toCID().toString()}`;try{await i.promise;let u=tn(e),l=await fetch(c,{method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:u,signal:s});if(Jt("putIPNS PUT %s %d",c,l.status),l.status!==200)throw new D("PUT ipns response had status other than 200","ERR_BAD_RESPONSE")}catch(u){throw Jt.error("putIPNS PUT %s error:",c,u.stack),u}finally{s.clear(),a.resolve(),Jt("putIPNS finished: %c",t)}}#t(t){let e=[],n=t.Addrs?.map(lr)??[];return t.Protocols!=null&&e.push(...t.Protocols),t.Protocol!=null&&(e.push(t.Protocol),delete t.Protocol),{...t,Schema:"peer",ID:pc(t.ID),Addrs:n,Protocols:e}}};function L0(r,t={}){return new ya(new URL(r),t)}var U0=q("/ipns/");function D0(r){return it(r.subarray(0,U0.byteLength),U0)}var Zu=class{client;constructor(t){this.client=L0(t)}async provide(t,e){}async*findProviders(t,e){yield*an(this.client.getProviders(t,e),n=>({id:n.ID,multiaddrs:n.Addrs,protocols:n.Protocols}))}async put(t,e,n){if(!D0(t))return;let o=to(t),s=He(e);await this.client.putIPNS(o,s,n)}async get(t,e){if(!D0(t))throw new D("Not found","ERR_NOT_FOUND");let n=to(t);try{let o=await this.client.getIPNS(n,e);return tn(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new D("Not found","ERR_NOT_FOUND"):o}}async findPeer(t,e){let n=await pa(this.client.getPeers(t,e));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new D("Not found","ERR_NOT_FOUND")}async*getClosestPeers(t,e){}};function Ju(r){return new Zu(new URL(r))}var P0="[a-fA-F\\d:]",Pr=r=>r&&r.includeBoundaries?`(?:(?<=\\s|^)(?=${P0})|(?<=${P0})(?=\\s|$))`:"",Te="(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}",xt="[a-fA-F\\d]{1,4}",wa=`
7
+ `)}`:`${e} :`}};zf=Ir;O.Constructed=zf;Ir.NAME="CONSTRUCTED";var Os=class extends Mt{fromBER(t,e,n){return e}toBER(t){return Ae}};Os.override="EndOfContentValueBlock";var jf,Fs=class extends Lt{constructor(t={}){super(t,Os),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};jf=Fs;O.EndOfContent=jf;Fs.NAME=Eo;var Gf,Rr=class extends Lt{constructor(t={}){super(t,Mt),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}`}};Gf=Rr;O.Null=Gf;Rr.NAME="NULL";var Vs=class extends or(Mt){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 nr(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,Uc.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};Vs.NAME="BooleanValueBlock";var Wf,Ms=class extends Lt{constructor(t={}){super(t,Vs),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}`}};Wf=Ms;O.Boolean=Wf;Ms.NAME="BOOLEAN";var $s=class extends or(Pe){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=Pe.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===Eo){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==$f)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?Pe.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};$s.NAME="OctetStringValueBlock";var Yf,er=class r extends Lt{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},$s),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=mi(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?Ir.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)}};Yf=er;O.OctetString=Yf;er.NAME=$f;var Hs=class extends or(Pe){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=Pe.prototype.fromBER.call(this,t,e,n),o===-1)return o;for(let a of this.value){let c=a.constructor.NAME;if(c===Eo){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==Hf)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(!nr(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=mi(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 Pe.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return Ae;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}}};Hs.NAME="BitStringValueBlock";var Zf,Ln=class extends Lt{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},Hs),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 Ir.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)}`}}};Zf=Ln;O.BitString=Zf;Ln.NAME=Hf;var Jf;function nw(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,f=c<i?i:c,l=0;for(let m=f;m>=0;m--,l++){switch(!0){case l<a.length:u=s[i-l]+a[c-l]+e[0];break;default:u=s[i-l]+e[0]}switch(e[0]=u/10,!0){case l>=s.length:s=Ts(new Uint8Array([u%10]),s);break;default:s[i-l]=u%10}}return e[0]>0&&(s=Ts(e,s)),s}function Mf(r){if(r>=bo.length)for(let t=bo.length;t<=r;t++){let e=new Uint8Array([0]),n=bo[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=Ts(e,n)),bo.push(n)}return bo[r]}function ow(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,f=0;for(let l=c;l>=0;l--,f++)switch(u=s[i-f]-a[c-f]-e,!0){case u<0:e=1,s[i-f]=u+10;break;default:e=0,s[i-f]=u}if(e>0)for(let l=i-c+1;l>=0;l--,f++)if(u=s[i-f]-e,u<0)e=1,s[i-f]=u+10;else{e=0,s[i-f]=u;break}return s.slice()}var vo=class extends or(Mt){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=Uc.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Of(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=ow(Mf(n),e),i="-";break;default:e=nw(e,Mf(n))}n++,o>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=Vf.charAt(e[c]));return a===!1&&(i+=Vf.charAt(0)),i}};Jf=vo;vo.NAME="IntegerValueBlock";Object.defineProperty(Jf.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var Xf,bt=class r extends Lt{constructor(t={}){super(t,vo),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Cs(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Cs();let e=BigInt(t),n=new xo,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,f=Z.BufferSourceConverter.toUint8Array(Z.Convert.FromHex(u.toString(16)));f[0]|=128,n.write(f)}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()}`}};Xf=bt;O.Integer=Xf;bt.NAME="INTEGER";var Qf,Ks=class extends bt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};Qf=Ks;O.Enumerated=Qf;Ks.NAME="ENUMERATED";var Ao=class extends or(Mt){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(!nr(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=Wr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Cs();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=Sr(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ae;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}}};Ao.NAME="sidBlock";var qs=class extends Mt{constructor({value:t=Un,...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.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,Ae;e.push(o)}return Dc(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 Ao;if(o>Number.MAX_SAFE_INTEGER){Cs();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 th,ve=class extends Lt{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()}}};th=ve;O.ObjectIdentifier=th;ve.NAME="OBJECT IDENTIFIER";var Bo=class extends or(tr){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(!nr(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=Wr(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=Sr(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",Ae;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}}};Bo.NAME="relativeSidBlock";var zs=class extends Mt{constructor({value:t=Un,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let o=e;for(;n>0;){let s=new Bo;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,Ae;n.push(s)}return Dc(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 Bo;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}};zs.NAME="RelativeObjectIdentifierValueBlock";var eh,js=class extends Lt{constructor(t={}){super(t,zs),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()}}};eh=js;O.RelativeObjectIdentifier=eh;js.NAME="RelativeObjectIdentifier";var rh,Rt=class extends Ir{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};rh=Rt;O.Sequence=rh;Rt.NAME="SEQUENCE";var nh,Gs=class extends Ir{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};nh=Gs;O.Set=nh;Gs.NAME="SET";var Ws=class extends or(Mt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Un}toJSON(){return{...super.toJSON(),value:this.value}}};Ws.NAME="StringValueBlock";var Ys=class extends Ws{};Ys.NAME="SimpleStringValueBlock";var zt=class extends Us{constructor({...t}={}){super(t,Ys)}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}};zt.NAME="SIMPLE STRING";var Zs=class extends zt{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}};Zs.NAME="Utf8StringValueBlock";var oh,rr=class extends Zs{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};oh=rr;O.Utf8String=oh;rr.NAME="UTF8String";var Js=class extends zt{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))}};Js.NAME="BmpStringValueBlock";var sh,Xs=class extends Js{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};sh=Xs;O.BmpString=sh;Xs.NAME="BMPString";var Qs=class extends zt{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=Sr(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}};Qs.NAME="UniversalStringValueBlock";var ih,ti=class extends Qs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};ih=ti;O.UniversalString=ih;ti.NAME="UniversalString";var ah,ei=class extends zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};ah=ei;O.NumericString=ah;ei.NAME="NumericString";var ch,ri=class extends zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};ch=ri;O.PrintableString=ch;ri.NAME="PrintableString";var uh,ni=class extends zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};uh=ni;O.TeletexString=uh;ni.NAME="TeletexString";var lh,oi=class extends zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};lh=oi;O.VideotexString=lh;oi.NAME="VideotexString";var fh,si=class extends zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};fh=si;O.IA5String=fh;si.NAME="IA5String";var hh,ii=class extends zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};hh=ii;O.GraphicString=hh;ii.NAME="GraphicString";var dh,ko=class extends zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};dh=ko;O.VisibleString=dh;ko.NAME="VisibleString";var ph,ai=class extends zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};ph=ai;O.GeneralString=ph;ai.NAME="GeneralString";var mh,ci=class extends zt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};mh=ci;O.CharacterString=mh;ci.NAME="CharacterString";var gh,So=class extends ko{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]=Yt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Yt(this.month,2),e[2]=Yt(this.day,2),e[3]=Yt(this.hour,2),e[4]=Yt(this.minute,2),e[5]=Yt(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}}};gh=So;O.UTCTime=gh;So.NAME="UTCTime";var yh,ui=class extends So{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 l=new Number(t[t.length-1]);if(isNaN(l.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 l=1,m=n.indexOf("+"),h="";if(m===-1&&(m=n.indexOf("-"),l=-1),m!==-1){if(h=n.substring(m+1),n=n.substring(0,m),h.length!==2&&h.length!==4)throw new Error("Wrong input string for conversion");let p=parseInt(h.substring(0,2),10);if(isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");if(a=l*p,h.length===4){if(p=parseInt(h.substring(2,4),10),isNaN(p.valueOf()))throw new Error("Wrong input string for conversion");c=l*p}}}let u=n.indexOf(".");if(u===-1&&(u=n.indexOf(",")),u!==-1){let l=new Number(`0${n.substring(u)}`);if(isNaN(l.valueOf()))throw new Error("Wrong input string for conversion");s=l.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 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,u!==-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,u!==-1){let l=1e3*s;this.millisecond=Math.floor(l)}break;default:throw new Error("Wrong input string for conversion")}let f=i.exec(o);if(f===null)throw new Error("Wrong input string for conversion");for(let l=1;l<f.length;l++)switch(l){case 1:this.year=parseInt(f[l],10);break;case 2:this.month=parseInt(f[l],10);break;case 3:this.day=parseInt(f[l],10);break;case 4:this.hour=parseInt(f[l],10)+a;break;case 5:this.minute=parseInt(f[l],10)+c;break;case 6:this.second=parseInt(f[l],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!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(t="iso"){if(t==="iso"){let e=[];return e.push(Yt(this.year,4)),e.push(Yt(this.month,2)),e.push(Yt(this.day,2)),e.push(Yt(this.hour,2)),e.push(Yt(this.minute,2)),e.push(Yt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Yt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};yh=ui;O.GeneralizedTime=yh;ui.NAME="GeneralizedTime";var wh,li=class extends rr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};wh=li;O.DATE=wh;li.NAME="DATE";var bh,fi=class extends rr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};bh=fi;O.TimeOfDay=bh;fi.NAME="TimeOfDay";var xh,hi=class extends rr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};xh=hi;O.DateTime=xh;hi.NAME="DateTime";var Eh,di=class extends rr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Eh=di;O.Duration=Eh;di.NAME="Duration";var vh,pi=class extends rr{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};vh=pi;O.TIME=vh;pi.NAME="TIME";function iw(r){let{result:t}=Dn(r),e=t.valueBlock.value;return{n:z(Oe(e[1].toBigInt()),"base64url"),e:z(Oe(e[2].toBigInt()),"base64url"),d:z(Oe(e[3].toBigInt()),"base64url"),p:z(Oe(e[4].toBigInt()),"base64url"),q:z(Oe(e[5].toBigInt()),"base64url"),dp:z(Oe(e[6].toBigInt()),"base64url"),dq:z(Oe(e[7].toBigInt()),"base64url"),qi:z(Oe(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 D("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new Rt({value:[new bt({value:0}),bt.fromBigInt(Fe(q(r.n,"base64url"))),bt.fromBigInt(Fe(q(r.e,"base64url"))),bt.fromBigInt(Fe(q(r.d,"base64url"))),bt.fromBigInt(Fe(q(r.p,"base64url"))),bt.fromBigInt(Fe(q(r.q,"base64url"))),bt.fromBigInt(Fe(q(r.dp,"base64url"))),bt.fromBigInt(Fe(q(r.dq,"base64url"))),bt.fromBigInt(Fe(q(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function cw(r){let{result:t}=Dn(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:z(Oe(e[0].toBigInt()),"base64url"),e:z(Oe(e[1].toBigInt()),"base64url")}}function uw(r){if(r.n==null||r.e==null)throw new D("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new Rt({value:[new Rt({value:[new ve({value:"1.2.840.113549.1.1.1"}),new Rr]}),new Ln({valueHex:new Rt({value:[bt.fromBigInt(Fe(q(r.n,"base64url"))),bt.fromBigInt(Fe(q(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function Oe(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 Fe(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 lw=16,Oc=32,Fc=1e4;async function fw(r,t){let e=qt.get(),o=new Rt({value:[new bt({value:0}),new Rt({value:[new ve({value:"1.2.840.113549.1.1.1"}),new Rr]}),new er({valueHex:r.marshal()})]}).toBER(),s=new Uint8Array(o,0,o.byteLength),i=De(lw),a=await Nc(po,t,i,{c:Fc,dkLen:Oc}),c=De(16),u=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),f=await e.subtle.encrypt({name:"AES-CBC",iv:c},u,s),l=new Rt({value:[new er({valueHex:i}),new bt({value:Fc}),new bt({value:Oc}),new Rt({value:[new ve({value:"1.2.840.113549.2.11"}),new Rr]})]}),m=new Rt({value:[new ve({value:"1.2.840.113549.1.5.13"}),new Rt({value:[new Rt({value:[new ve({value:"1.2.840.113549.1.5.12"}),l]}),new Rt({value:[new ve({value:"2.16.840.1.101.3.4.1.42"}),new er({valueHex:c})]})]})]}),p=new Rt({value:[m,new er({valueHex:f})]}).toBER(),d=new Uint8Array(p,0,p.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...z(d,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
8
+ `)}async function hw(r,t){let e=qt.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let o=q(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Dn(o),{iv:i,salt:a,iterations:c,keySize:u,cipherText:f}=dw(s),l=await Nc(po,t,a,{c,dkLen:u}),m=await e.subtle.importKey("raw",l,"AES-CBC",!1,["decrypt"]),h=Io(await e.subtle.decrypt({name:"AES-CBC",iv:i},m,f)),{result:p}=Dn(h);n=Ah(p)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let o=q(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:s}=Dn(o);n=Ah(s)}else throw new D("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return Vc(n)}function dw(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new D("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 D("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let s=n.valueBlock.value[1],i=Io(s.valueBlock.value[0].getValue()),a=Fc,c=Oc;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 D("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],f=u.valueBlock.value[0].toString();if(f!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(f!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(f!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new D("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let l=Io(u.valueBlock.value[1].getValue());return{cipherText:Io(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:l}}function Ah(r){return Io(r.valueBlock.value[2].getValue())}function Io(r){return new Uint8Array(r,0,r.byteLength)}async function Bh(r){let t=await qt.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 Ih(t);return{privateKey:e[0],publicKey:e[1]}}async function Mc(r){let e=[await qt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await pw(r)],n=await Ih({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function kh(r,t){let e=await qt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await qt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Sh(r,t,e){let n=await qt.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return qt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Ih(r){if(r.privateKey==null||r.publicKey==null)throw new D("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([qt.get().subtle.exportKey("jwk",r.privateKey),qt.get().subtle.exportKey("jwk",r.publicKey)])}async function pw(r){return qt.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 gi(r){if(r.kty!=="RSA")throw new D("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new D("invalid key modulus","ERR_INVALID_KEY_MODULUS");return q(r.n,"base64url").length*8}var _o=8192,Ro=class{_key;constructor(t){this._key=t}verify(t,e){return Sh(this._key,e,t)}marshal(){return _r.jwkToPkix(this._key)}get bytes(){return Ue.encode({Type:gt.RSA,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return le(t)?t.then(({bytes:e})=>e):t.bytes}},Pn=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return De(16)}sign(t){return kh(this._key,t)}get public(){if(this._publicKey==null)throw new D("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new Ro(this._publicKey)}marshal(){return _r.jwkToPkcs1(this._key)}get bytes(){return Xe.encode({Type:gt.RSA,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return le(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 _r.exportToPem(this,t);if(e==="libp2p-key")return Tn(this.bytes,t);throw new D(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function Vc(r){let t=_r.pkcs1ToJwk(r);if(gi(t)>_o)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Mc(t);return new Pn(e.privateKey,e.publicKey)}function gw(r){let t=_r.pkixToJwk(r);if(gi(t)>_o)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new Ro(t)}async function yw(r){if(gi(r)>_o)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Mc(r);return new Pn(t.privateKey,t.publicKey)}async function ww(r){if(r>_o)throw new D("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Bh(r);return new Pn(t.privateKey,t.publicKey)}var jc={};vt(jc,{Secp256k1PrivateKey:()=>Co,Secp256k1PublicKey:()=>To,generateKeyPair:()=>Cw,unmarshalSecp256k1PrivateKey:()=>_w,unmarshalSecp256k1PublicKey:()=>Tw});var bw=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]),Tr=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Cr=new Uint32Array(64),Hc=class extends Sn{constructor(){super(64,32,8,!1),this.A=Tr[0]|0,this.B=Tr[1]|0,this.C=Tr[2]|0,this.D=Tr[3]|0,this.E=Tr[4]|0,this.F=Tr[5]|0,this.G=Tr[6]|0,this.H=Tr[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 l=0;l<16;l++,e+=4)Cr[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let m=Cr[l-15],h=Cr[l-2],p=xe(m,7)^xe(m,18)^m>>>3,d=xe(h,17)^xe(h,19)^h>>>10;Cr[l]=d+Cr[l-7]+p+Cr[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:u,H:f}=this;for(let l=0;l<64;l++){let m=xe(a,6)^xe(a,11)^xe(a,25),h=f+m+pf(a,c,u)+bw[l]+Cr[l]|0,d=(xe(n,2)^xe(n,13)^xe(n,22))+mf(n,o,s)|0;f=u,u=c,c=a,a=i+h|0,i=s,s=o,o=n,n=h+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,u=u+this.G|0,f=f+this.H|0,this.set(n,o,s,i,a,c,u,f)}roundClean(){Cr.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Rh=ys(()=>new Hc);function xw(r){let t=go(r);Le(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:Ew,hexToBytes:vw}=xs,Yr={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=Yr;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:Ew(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=Yr,e=typeof r=="string"?vw(r):r;In(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}=Yr._parseInt(e.subarray(2)),{d:i,l:a}=Yr._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 f=u.toString(16);return f.length&1?`0${f}`:f},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}`}},sr=BigInt(0),he=BigInt(1),CA=BigInt(2),_h=BigInt(3),NA=BigInt(4);function Aw(r){let t=xw(r),{Fp:e}=t,n=t.toBytes||((p,d,w)=>{let g=d.toAffine();return Ze(Uint8Array.from([4]),e.toBytes(g.x),e.toBytes(g.y))}),o=t.fromBytes||(p=>{let d=p.subarray(1),w=e.fromBytes(d.subarray(0,e.BYTES)),g=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:w,y:g}});function s(p){let{a:d,b:w}=t,g=e.sqr(p),x=e.mul(g,p);return e.add(e.add(x,e.mul(p,d)),w)}if(!e.eql(e.sqr(t.Gy),s(t.Gx)))throw new Error("bad generator point: equation left != right");function i(p){return typeof p=="bigint"&&sr<p&&p<t.n}function a(p){if(!i(p))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(p){let{allowedPrivateKeyLengths:d,nByteLength:w,wrapPrivateKey:g,n:x}=t;if(d&&typeof p!="bigint"){if(Ar(p)&&(p=We(p)),typeof p!="string"||!d.includes(p.length))throw new Error("Invalid key");p=p.padStart(w*2,"0")}let b;try{b=typeof p=="bigint"?p:Ye(mt("private key",p,w))}catch{throw new Error(`private key must be ${w} bytes, hex or bigint, not ${typeof p}`)}return g&&(b=at(b,x)),a(b),b}let u=new Map;function f(p){if(!(p instanceof l))throw new Error("ProjectivePoint expected")}class l{constructor(d,w,g){if(this.px=d,this.py=w,this.pz=g,d==null||!e.isValid(d))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(g==null||!e.isValid(g))throw new Error("z required")}static fromAffine(d){let{x:w,y:g}=d||{};if(!d||!e.isValid(w)||!e.isValid(g))throw new Error("invalid affine point");if(d instanceof l)throw new Error("projective point not allowed");let x=b=>e.eql(b,e.ZERO);return x(w)&&x(g)?l.ZERO:new l(w,g,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let w=e.invertBatch(d.map(g=>g.pz));return d.map((g,x)=>g.toAffine(w[x])).map(l.fromAffine)}static fromHex(d){let w=l.fromAffine(o(mt("pointHex",d)));return w.assertValidity(),w}static fromPrivateKey(d){return l.BASE.multiply(c(d))}_setWindowSize(d){this._WINDOW_SIZE=d,u.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:d,y:w}=this.toAffine();if(!e.isValid(d)||!e.isValid(w))throw new Error("bad point: x or y not FE");let g=e.sqr(w),x=s(d);if(!e.eql(g,x))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(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){f(d);let{px:w,py:g,pz:x}=this,{px:b,py:B,pz:A}=d,I=e.eql(e.mul(w,A),e.mul(b,x)),v=e.eql(e.mul(g,A),e.mul(B,x));return I&&v}negate(){return new l(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:w}=t,g=e.mul(w,_h),{px:x,py:b,pz:B}=this,A=e.ZERO,I=e.ZERO,v=e.ZERO,E=e.mul(x,x),U=e.mul(b,b),P=e.mul(B,B),N=e.mul(x,b);return N=e.add(N,N),v=e.mul(x,B),v=e.add(v,v),A=e.mul(d,v),I=e.mul(g,P),I=e.add(A,I),A=e.sub(U,I),I=e.add(U,I),I=e.mul(A,I),A=e.mul(N,A),v=e.mul(g,v),P=e.mul(d,P),N=e.sub(E,P),N=e.mul(d,N),N=e.add(N,v),v=e.add(E,E),E=e.add(v,E),E=e.add(E,P),E=e.mul(E,N),I=e.add(I,E),P=e.mul(b,B),P=e.add(P,P),E=e.mul(P,N),A=e.sub(A,E),v=e.mul(P,U),v=e.add(v,v),v=e.add(v,v),new l(A,I,v)}add(d){f(d);let{px:w,py:g,pz:x}=this,{px:b,py:B,pz:A}=d,I=e.ZERO,v=e.ZERO,E=e.ZERO,U=t.a,P=e.mul(t.b,_h),N=e.mul(w,b),M=e.mul(g,B),C=e.mul(x,A),X=e.add(w,g),S=e.add(b,B);X=e.mul(X,S),S=e.add(N,M),X=e.sub(X,S),S=e.add(w,x);let T=e.add(b,A);return S=e.mul(S,T),T=e.add(N,C),S=e.sub(S,T),T=e.add(g,x),I=e.add(B,A),T=e.mul(T,I),I=e.add(M,C),T=e.sub(T,I),E=e.mul(U,S),I=e.mul(P,C),E=e.add(I,E),I=e.sub(M,E),E=e.add(M,E),v=e.mul(I,E),M=e.add(N,N),M=e.add(M,N),C=e.mul(U,C),S=e.mul(P,S),M=e.add(M,C),C=e.sub(N,C),C=e.mul(U,C),S=e.add(S,C),N=e.mul(M,S),v=e.add(v,N),N=e.mul(T,S),I=e.mul(X,I),I=e.sub(I,N),N=e.mul(X,M),E=e.mul(T,E),E=e.add(E,N),new l(I,v,E)}subtract(d){return this.add(d.negate())}is0(){return this.equals(l.ZERO)}wNAF(d){return h.wNAFCached(this,u,d,w=>{let g=e.invertBatch(w.map(x=>x.pz));return w.map((x,b)=>x.toAffine(g[b])).map(l.fromAffine)})}multiplyUnsafe(d){let w=l.ZERO;if(d===sr)return w;if(a(d),d===he)return this;let{endo:g}=t;if(!g)return h.unsafeLadder(this,d);let{k1neg:x,k1:b,k2neg:B,k2:A}=g.splitScalar(d),I=w,v=w,E=this;for(;b>sr||A>sr;)b&he&&(I=I.add(E)),A&he&&(v=v.add(E)),E=E.double(),b>>=he,A>>=he;return x&&(I=I.negate()),B&&(v=v.negate()),v=new l(e.mul(v.px,g.beta),v.py,v.pz),I.add(v)}multiply(d){a(d);let w=d,g,x,{endo:b}=t;if(b){let{k1neg:B,k1:A,k2neg:I,k2:v}=b.splitScalar(w),{p:E,f:U}=this.wNAF(A),{p:P,f:N}=this.wNAF(v);E=h.constTimeNegate(B,E),P=h.constTimeNegate(I,P),P=new l(e.mul(P.px,b.beta),P.py,P.pz),g=E.add(P),x=U.add(N)}else{let{p:B,f:A}=this.wNAF(w);g=B,x=A}return l.normalizeZ([g,x])[0]}multiplyAndAddUnsafe(d,w,g){let x=l.BASE,b=(A,I)=>I===sr||I===he||!A.equals(x)?A.multiplyUnsafe(I):A.multiply(I),B=b(this,w).add(b(d,g));return B.is0()?void 0:B}toAffine(d){let{px:w,py:g,pz:x}=this,b=this.is0();d==null&&(d=b?e.ONE:e.inv(x));let B=e.mul(w,d),A=e.mul(g,d),I=e.mul(x,d);if(b)return{x:e.ZERO,y:e.ZERO};if(!e.eql(I,e.ONE))throw new Error("invZ was invalid");return{x:B,y:A}}isTorsionFree(){let{h:d,isTorsionFree:w}=t;if(d===he)return!0;if(w)return w(l,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:w}=t;return d===he?this:w?w(l,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return this.assertValidity(),n(l,this,d)}toHex(d=!0){return We(this.toRawBytes(d))}}l.BASE=new l(t.Gx,t.Gy,e.ONE),l.ZERO=new l(e.ZERO,e.ONE,e.ZERO);let m=t.nBitLength,h=As(l,t.endo?Math.ceil(m/2):m);return{CURVE:t,ProjectivePoint:l,normPrivateKeyToScalar:c,weierstrassEquation:s,isWithinCurveOrder:i}}function Bw(r){let t=go(r);return Le(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Th(r){let t=Bw(r),{Fp:e,n}=t,o=e.BYTES+1,s=2*e.BYTES+1;function i(S){return sr<S&&S<e.ORDER}function a(S){return at(S,n)}function c(S){return Es(S,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:f,weierstrassEquation:l,isWithinCurveOrder:m}=Aw({...t,toBytes(S,T,H){let _=T.toAffine(),k=e.toBytes(_.x),F=Ze;return H?F(Uint8Array.from([T.hasEvenY()?2:3]),k):F(Uint8Array.from([4]),k,e.toBytes(_.y))},fromBytes(S){let T=S.length,H=S[0],_=S.subarray(1);if(T===o&&(H===2||H===3)){let k=Ye(_);if(!i(k))throw new Error("Point is not on curve");let F=l(k),$;try{$=e.sqrt(F)}catch(Y){let rt=Y instanceof Error?": "+Y.message:"";throw new Error("Point is not on curve"+rt)}let K=($&he)===he;return(H&1)===1!==K&&($=e.neg($)),{x:k,y:$}}else if(T===s&&H===4){let k=e.fromBytes(_.subarray(0,e.BYTES)),F=e.fromBytes(_.subarray(e.BYTES,2*e.BYTES));return{x:k,y:F}}else throw new Error(`Point of length ${T} was invalid. Expected ${o} compressed bytes or ${s} uncompressed bytes`)}}),h=S=>We(kr(S,t.nByteLength));function p(S){let T=n>>he;return S>T}function d(S){return p(S)?a(-S):S}let w=(S,T,H)=>Ye(S.slice(T,H));class g{constructor(T,H,_){this.r=T,this.s=H,this.recovery=_,this.assertValidity()}static fromCompact(T){let H=t.nByteLength;return T=mt("compactSignature",T,H*2),new g(w(T,0,H),w(T,H,2*H))}static fromDER(T){let{r:H,s:_}=Yr.toSig(mt("DER",T));return new g(H,_)}assertValidity(){if(!m(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!m(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(T){return new g(this.r,this.s,T)}recoverPublicKey(T){let{r:H,s:_,recovery:k}=this,F=v(mt("msgHash",T));if(k==null||![0,1,2,3].includes(k))throw new Error("recovery id invalid");let $=k===2||k===3?H+t.n:H;if($>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let K=k&1?"03":"02",W=u.fromHex(K+h($)),Y=c($),rt=a(-F*Y),J=a(_*Y),tt=u.BASE.multiplyAndAddUnsafe(W,rt,J);if(!tt)throw new Error("point at infinify");return tt.assertValidity(),tt}hasHighS(){return p(this.s)}normalizeS(){return this.hasHighS()?new g(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return qr(this.toDERHex())}toDERHex(){return Yr.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return qr(this.toCompactHex())}toCompactHex(){return h(this.r)+h(this.s)}}let x={isValidPrivateKey(S){try{return f(S),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let S=Sc(t.n);return kf(t.randomBytes(S),t.n)},precompute(S=8,T=u.BASE){return T._setWindowSize(S),T.multiply(BigInt(3)),T}};function b(S,T=!0){return u.fromPrivateKey(S).toRawBytes(T)}function B(S){let T=Ar(S),H=typeof S=="string",_=(T||H)&&S.length;return T?_===o||_===s:H?_===2*o||_===2*s:S instanceof u}function A(S,T,H=!0){if(B(S))throw new Error("first arg must be private key");if(!B(T))throw new Error("second arg must be public key");return u.fromHex(T).multiply(f(S)).toRawBytes(H)}let I=t.bits2int||function(S){let T=Ye(S),H=S.length*8-t.nBitLength;return H>0?T>>BigInt(H):T},v=t.bits2int_modN||function(S){return a(I(S))},E=mo(t.nBitLength);function U(S){if(typeof S!="bigint")throw new Error("bigint expected");if(!(sr<=S&&S<E))throw new Error(`bigint expected < 2^${t.nBitLength}`);return kr(S,t.nByteLength)}function P(S,T,H=N){if(["recovered","canonical"].some(dt=>dt in H))throw new Error("sign() legacy options not supported");let{hash:_,randomBytes:k}=t,{lowS:F,prehash:$,extraEntropy:K}=H;F==null&&(F=!0),S=mt("msgHash",S),$&&(S=mt("prehashed msgHash",_(S)));let W=v(S),Y=f(T),rt=[U(Y),U(W)];if(K!=null&&K!==!1){let dt=K===!0?k(e.BYTES):K;rt.push(mt("extraEntropy",dt))}let J=Ze(...rt),tt=W;function wt(dt){let Tt=I(dt);if(!m(Tt))return;let Ct=c(Tt),Et=u.BASE.multiply(Tt).toAffine(),Ot=a(Et.x);if(Ot===sr)return;let Ke=a(Ct*a(tt+Ot*Y));if(Ke===sr)return;let Or=(Et.x===Ot?0:2)|Number(Et.y&he),ro=Ke;return F&&p(Ke)&&(ro=d(Ke),Or^=1),new g(Ot,ro,Or)}return{seed:J,k2sig:wt}}let N={lowS:t.lowS,prehash:!1},M={lowS:t.lowS,prehash:!1};function C(S,T,H=N){let{seed:_,k2sig:k}=P(S,T,H),F=t;return vc(F.hash.outputLen,F.nByteLength,F.hmac)(_,k)}u.BASE._setWindowSize(8);function X(S,T,H,_=M){let k=S;if(T=mt("msgHash",T),H=mt("publicKey",H),"strict"in _)throw new Error("options.strict was renamed to lowS");let{lowS:F,prehash:$}=_,K,W;try{if(typeof k=="string"||Ar(k))try{K=g.fromDER(k)}catch(Et){if(!(Et instanceof Yr.Err))throw Et;K=g.fromCompact(k)}else if(typeof k=="object"&&typeof k.r=="bigint"&&typeof k.s=="bigint"){let{r:Et,s:Ot}=k;K=new g(Et,Ot)}else throw new Error("PARSE");W=u.fromHex(H)}catch(Et){if(Et.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(F&&K.hasHighS())return!1;$&&(T=t.hash(T));let{r:Y,s:rt}=K,J=v(T),tt=c(rt),wt=a(J*tt),dt=a(Y*tt),Tt=u.BASE.multiplyAndAddUnsafe(W,wt,dt)?.toAffine();return Tt?a(Tt.x)===Y:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:A,sign:C,verify:X,ProjectivePoint:u,Signature:g,utils:x}}function kw(r){return{hash:r,hmac:(t,...e)=>wo(r,t,yc(...e)),randomBytes:kn}}function Ch(r,t){let e=n=>Th({...r,...kw(n)});return Object.freeze({...e(t),create:e})}var Uh=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Nh=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Sw=BigInt(1),Kc=BigInt(2),Lh=(r,t)=>(r+t/Kc)/t;function Iw(r){let t=Uh,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,f=u*u*r%t,l=lt(f,e,t)*f%t,m=lt(l,e,t)*f%t,h=lt(m,Kc,t)*u%t,p=lt(h,o,t)*h%t,d=lt(p,s,t)*p%t,w=lt(d,a,t)*d%t,g=lt(w,c,t)*w%t,x=lt(g,a,t)*d%t,b=lt(x,e,t)*f%t,B=lt(b,i,t)*p%t,A=lt(B,n,t)*u%t,I=lt(A,Kc,t);if(!qc.eql(qc.sqr(I),r))throw new Error("Cannot find square root");return I}var qc=vs(Uh,void 0,void 0,{sqrt:Iw}),Be=Ch({a:BigInt(0),b:BigInt(7),Fp:qc,n:Nh,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Nh,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Sw*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=Lh(s*r,t),c=Lh(-n*r,t),u=at(r-a*e-c*o,t),f=at(-a*n-c*s,t),l=u>i,m=f>i;if(l&&(u=t-u),m&&(f=t-f),u>i||f>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:u,k2neg:m,k2:f}}}},Rh),$A=BigInt(0);var HA=Be.ProjectivePoint;function Dh(){return Be.utils.randomPrivateKey()}function Ph(r,t){let e=At.digest(t instanceof Uint8Array?t:t.subarray());if(le(e))return e.then(({digest:n})=>Be.sign(n,r).toDERRawBytes()).catch(n=>{throw new D(String(n),"ERR_INVALID_INPUT")});try{return Be.sign(e.digest,r).toDERRawBytes()}catch(n){throw new D(String(n),"ERR_INVALID_INPUT")}}function Oh(r,t,e){let n=At.digest(e instanceof Uint8Array?e:e.subarray());if(le(n))return n.then(({digest:o})=>Be.verify(t,o,r)).catch(o=>{throw new D(String(o),"ERR_INVALID_INPUT")});try{return Be.verify(t,n.digest,r)}catch(o){throw new D(String(o),"ERR_INVALID_INPUT")}}function Fh(r){return Be.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Vh(r){try{Be.getPublicKey(r,!0)}catch(t){throw new D(String(t),"ERR_INVALID_PRIVATE_KEY")}}function zc(r){try{Be.ProjectivePoint.fromHex(r)}catch(t){throw new D(String(t),"ERR_INVALID_PUBLIC_KEY")}}function Mh(r){try{return Be.getPublicKey(r,!0)}catch(t){throw new D(String(t),"ERR_INVALID_PRIVATE_KEY")}}var To=class{_key;constructor(t){zc(t),this._key=t}verify(t,e){return Oh(this._key,e,t)}marshal(){return Fh(this._key)}get bytes(){return Ue.encode({Type:gt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return le(t)?{bytes:e}=await t:e=t.bytes,e}},Co=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??Mh(t),Vh(this._key),zc(this._publicKey)}sign(t){return Ph(this._key,t)}get public(){return new To(this._publicKey)}marshal(){return this._key}get bytes(){return Xe.encode({Type:gt.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return it(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return le(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 Tn(this.bytes,t);throw new D(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function _w(r){return new Co(r)}function Tw(r){return new To(r)}async function Cw(){let r=Dh();return new Co(r)}var yi={rsa:$c,ed25519:Cc,secp256k1:jc};function Nw(r){let t=Object.keys(yi).join(" / ");return new D(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function Gc(r){let t=Ue.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case gt.RSA:return yi.rsa.unmarshalRsaPublicKey(e);case gt.Ed25519:return yi.ed25519.unmarshalEd25519PublicKey(e);case gt.Secp256k1:return yi.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw Nw(t.Type??"unknown")}}var re=Xt(Wh(),1);re.default.formatters.b=r=>r==null?"undefined":ht.baseEncode(r);re.default.formatters.t=r=>r==null?"undefined":Nt.baseEncode(r);re.default.formatters.m=r=>r==null?"undefined":ue.baseEncode(r);re.default.formatters.p=r=>r==null?"undefined":r.toString();re.default.formatters.c=r=>r==null?"undefined":r.toString();re.default.formatters.k=r=>r==null?"undefined":r.toString();re.default.formatters.a=r=>r==null?"undefined":r.toString();function zw(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 Yh(){return{forComponent(r){return ne(r)}}}function ne(r){let t=zw(`${r}:trace`);return re.default.enabled(`${r}:trace`)&&re.default.names.map(e=>e.toString()).find(e=>e.includes(":trace"))!=null&&(t=(0,re.default)(`${r}:trace`)),Object.assign((0,re.default)(r),{error:(0,re.default)(`${r}:error`),trace:t})}var Yc=Xt(Jh(),1);var Uo=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},Zc=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},Xh=r=>globalThis.DOMException===void 0?new Zc(r):new DOMException(r),Qh=r=>{let t=r.reason===void 0?Xh("This operation was aborted."):r.reason;return t instanceof Error?t:Xh(t)};function Do(r,t){let{milliseconds:e,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout}}=t,i,c=new Promise((u,f)=>{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:m}=t;m.aborted&&f(Qh(m)),m.addEventListener("abort",()=>{f(Qh(m))})}if(e===Number.POSITIVE_INFINITY){r.then(u,f);return}let l=new Uo;i=s.setTimeout.call(void 0,()=>{if(n){try{u(n())}catch(m){f(m)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?u():o instanceof Error?f(o):(l.message=o??`Promise timed out after ${e} milliseconds`,f(l))},e),(async()=>{try{u(await r)}catch(m){f(m)}})()}).finally(()=>{c.clear()});return c.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},c}function Jc(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 Po=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=Jc(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 Ve=class extends Yc.default{#t;#e;#r=0;#o;#a;#u=0;#s;#l;#n;#m;#i=0;#f;#c;#g;timeout;constructor(t){if(super(),t={carryoverConcurrencyCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:Po,...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.#o=t.intervalCap,this.#a=t.interval,this.#n=new t.queueClass,this.#m=t.queueClass,this.concurrency=t.concurrency,this.timeout=t.timeout,this.#g=t.throwOnTimeout===!0,this.#c=t.autoStart===!1}get#b(){return this.#e||this.#r<this.#o}get#x(){return this.#i<this.#f}#E(){this.#i--,this.#h(),this.emit("next")}#v(){this.#w(),this.#y(),this.#l=void 0}get#A(){let t=Date.now();if(this.#s===void 0){let e=this.#u-t;if(e<0)this.#r=this.#t?this.#i:0;else return this.#l===void 0&&(this.#l=setTimeout(()=>{this.#v()},e)),!0}return!1}#h(){if(this.#n.size===0)return this.#s&&clearInterval(this.#s),this.#s=void 0,this.emit("empty"),this.#i===0&&this.emit("idle"),!1;if(!this.#c){let t=!this.#A;if(this.#b&&this.#x){let e=this.#n.dequeue();return e?(this.emit("active"),e(),t&&this.#y(),!0):!1}}return!1}#y(){this.#e||this.#s!==void 0||(this.#s=setInterval(()=>{this.#w()},this.#a),this.#u=Date.now()+this.#a)}#w(){this.#r===0&&this.#i===0&&this.#s&&(clearInterval(this.#s),this.#s=void 0),this.#r=this.#t?this.#i:0,this.#d()}#d(){for(;this.#h(););}get concurrency(){return this.#f}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.#f=t,this.#d()}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.#g,...e},new Promise((n,o)=>{this.#n.enqueue(async()=>{this.#i++,this.#r++;try{e.signal?.throwIfAborted();let s=t({signal:e.signal});e.timeout&&(s=Do(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 Uo&&!e.throwOnTimeout){n();return}o(s),this.emit("error",s)}finally{this.#E()}},e),this.emit("add"),this.#h()})}async addAll(t,e){return Promise.all(t.map(async n=>this.add(n,e)))}start(){return this.#c?(this.#c=!1,this.#d(),this):this}pause(){this.#c=!0}clear(){this.#n=new this.#m}async onEmpty(){this.#n.size!==0&&await this.#p("empty")}async onSizeLessThan(t){this.#n.size<t||await this.#p("next",()=>this.#n.size<t)}async onIdle(){this.#i===0&&this.#n.size===0||await this.#p("idle")}async#p(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.#i}get isPaused(){return this.#c}};function vi(r){let t=[ke.A];return r==null?t:Array.isArray(r)?r.length===0?t:r:[r]}var Xc=60;function Ai(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:ke[t.type]})),Answer:(r.Answer??r.answers??[]).map(t=>({name:t.name,type:ke[t.type],TTL:t.TTL??t.ttl??Xc,data:t.data instanceof Uint8Array?z(t.data):t.data}))}}var Ww=4;function Qc(r,t={}){let e=new Ve({concurrency:t.queryConcurrency??Ww});return async(n,o={})=>{let s=new URLSearchParams;s.set("name",n),vi(o.types).forEach(a=>{s.append("type",ke[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=Ai(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 td(){return[Qc("https://cloudflare-dns.com/dns-query"),Qc("https://dns.google/resolve")]}var nd=Xt(rd(),1);var tu=class{lru;constructor(t){this.lru=(0,nd.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 Ai({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:ke[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??Xc)*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 od(r){return new tu(r)}var Yw=1e3,Bi=class{resolvers;cache;constructor(t){this.resolvers={},this.cache=od(t.cacheSize??Yw),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["."]=td())}async query(t,e={}){let n=vi(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 f of u.Answer)this.cache.add(t,f);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 ke;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(ke||(ke={}));function sd(r={}){return new Bi(r)}var Zw=["string","number","bigint","symbol"],Jw=["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 id(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let t=typeof r;if(Zw.includes(t))return t;if(t==="function")return"Function";if(Array.isArray(r))return"Array";if(Xw(r))return"Buffer";let e=Qw(r);return e||"Object"}function Xw(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function Qw(r){let t=Object.prototype.toString.call(r).slice(8,-1);if(Jw.includes(t))return t}var y=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}};y.uint=new y(0,"uint",!0);y.negint=new y(1,"negint",!0);y.bytes=new y(2,"bytes",!0);y.string=new y(3,"string",!0);y.array=new y(4,"array",!1);y.map=new y(5,"map",!1);y.tag=new y(6,"tag",!1);y.float=new y(7,"float",!0);y.false=new y(7,"false",!0);y.true=new y(7,"true",!0);y.null=new y(7,"null",!0);y.undefined=new y(7,"undefined",!0);y.break=new y(7,"break",!0);var R=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",tb=new TextDecoder,eb=new TextEncoder;function ki(r){return Mn&&globalThis.Buffer.isBuffer(r)}function Oo(r){return r instanceof Uint8Array?ki(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var ld=Mn?(r,t,e)=>e-t>64?globalThis.Buffer.from(r.subarray(t,e)).toString("utf8"):cd(r,t,e):(r,t,e)=>e-t>64?tb.decode(r.subarray(t,e)):cd(r,t,e),Si=Mn?r=>r.length>64?globalThis.Buffer.from(r):ad(r):r=>r.length>64?eb.encode(r):ad(r),Me=r=>Uint8Array.from(r),$n=Mn?(r,t,e)=>ki(r)?new Uint8Array(r.subarray(t,e)):r.slice(t,e):(r,t,e)=>r.slice(t,e),fd=Mn?(r,t)=>(r=r.map(e=>e instanceof Uint8Array?e:globalThis.Buffer.from(e)),Oo(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},hd=Mn?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function dd(r,t){if(ki(r)&&ki(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 ad(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 cd(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,f;switch(i){case 1:o<128&&(s=o);break;case 2:a=r[t+1],(a&192)===128&&(f=(o&31)<<6|a&63,f>127&&(s=f));break;case 3:a=r[t+1],c=r[t+2],(a&192)===128&&(c&192)===128&&(f=(o&15)<<12|(a&63)<<6|c&63,f>2047&&(f<55296||f>57343)&&(s=f));break;case 4:a=r[t+1],c=r[t+2],u=r[t+3],(a&192)===128&&(c&192)===128&&(u&192)===128&&(f=(o&15)<<18|(a&63)<<12|(c&63)<<6|u&63,f>65535&&f<1114112&&(s=f))}}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 eu(n)}var ud=4096;function eu(r){let t=r.length;if(t<=ud)return String.fromCharCode.apply(String,r);let e="",n=0;for(;n<t;)e+=String.fromCharCode.apply(String,r.slice(n,n+=ud));return e}var rb=256,Fo=class{constructor(t=rb){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=hd(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=fd(this.chunks,this.cursor);return t&&this.reset(),e}};var V="CBOR decode error:",Hn="CBOR encode error:",Vo=[];Vo[23]=1;Vo[24]=2;Vo[25]=3;Vo[26]=5;Vo[27]=9;function ir(r,t,e){if(r.length-t<e)throw new Error(`${V} not enough data for type`)}var _t=[24,256,65536,4294967296,BigInt("18446744073709551616")];function oe(r,t,e){ir(r,t,1);let n=r[t];if(e.strict===!0&&n<_t[0])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function se(r,t,e){ir(r,t,2);let n=r[t]<<8|r[t+1];if(e.strict===!0&&n<_t[1])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function ie(r,t,e){ir(r,t,4);let n=r[t]*16777216+(r[t+1]<<16)+(r[t+2]<<8)+r[t+3];if(e.strict===!0&&n<_t[2])throw new Error(`${V} integer encoded in more bytes than necessary (strict decode)`);return n}function ae(r,t,e){ir(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<_t[3])throw new Error(`${V} 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(`${V} integers outside of the safe integer range are not supported`)}function pd(r,t,e,n){return new R(y.uint,oe(r,t+1,n),2)}function md(r,t,e,n){return new R(y.uint,se(r,t+1,n),3)}function gd(r,t,e,n){return new R(y.uint,ie(r,t+1,n),5)}function yd(r,t,e,n){return new R(y.uint,ae(r,t+1,n),9)}function de(r,t){return Ut(r,0,t.value)}function Ut(r,t,e){if(e<_t[0]){let n=Number(e);r.push([t|n])}else if(e<_t[1]){let n=Number(e);r.push([t|24,n])}else if(e<_t[2]){let n=Number(e);r.push([t|25,n>>>8,n&255])}else if(e<_t[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<_t[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(`${V} encountered BigInt larger than allowable range`)}}de.encodedSize=function(t){return Ut.encodedSize(t.value)};Ut.encodedSize=function(t){return t<_t[0]?1:t<_t[1]?2:t<_t[2]?3:t<_t[3]?5:9};de.compareTokens=function(t,e){return t.value<e.value?-1:t.value>e.value?1:0};function wd(r,t,e,n){return new R(y.negint,-1-oe(r,t+1,n),2)}function bd(r,t,e,n){return new R(y.negint,-1-se(r,t+1,n),3)}function xd(r,t,e,n){return new R(y.negint,-1-ie(r,t+1,n),5)}var ru=BigInt(-1),Ed=BigInt(1);function vd(r,t,e,n){let o=ae(r,t+1,n);if(typeof o!="bigint"){let s=-1-o;if(s>=Number.MIN_SAFE_INTEGER)return new R(y.negint,s,9)}if(n.allowBigInt!==!0)throw new Error(`${V} integers outside of the safe integer range are not supported`);return new R(y.negint,ru-BigInt(o),9)}function Ii(r,t){let e=t.value,n=typeof e=="bigint"?e*ru-Ed:e*-1-1;Ut(r,t.type.majorEncoded,n)}Ii.encodedSize=function(t){let e=t.value,n=typeof e=="bigint"?e*ru-Ed:e*-1-1;return n<_t[0]?1:n<_t[1]?2:n<_t[2]?3:n<_t[3]?5:9};Ii.compareTokens=function(t,e){return t.value<e.value?1:t.value>e.value?-1:0};function Mo(r,t,e,n){ir(r,t,e+n);let o=$n(r,t+e,t+e+n);return new R(y.bytes,o,e+n)}function Ad(r,t,e,n){return Mo(r,t,1,e)}function Bd(r,t,e,n){return Mo(r,t,2,oe(r,t+1,n))}function kd(r,t,e,n){return Mo(r,t,3,se(r,t+1,n))}function Sd(r,t,e,n){return Mo(r,t,5,ie(r,t+1,n))}function Id(r,t,e,n){let o=ae(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer bytes lengths not supported`);return Mo(r,t,9,o)}function Ri(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===y.string?Si(r.value):r.value),r.encodedBytes}function Kn(r,t){let e=Ri(t);Ut(r,t.type.majorEncoded,e.length),r.push(e)}Kn.encodedSize=function(t){let e=Ri(t);return Ut.encodedSize(e.length)+e.length};Kn.compareTokens=function(t,e){return ob(Ri(t),Ri(e))};function ob(r,t){return r.length<t.length?-1:r.length>t.length?1:dd(r,t)}function $o(r,t,e,n,o){let s=e+n;ir(r,t,s);let i=new R(y.string,ld(r,t+e,t+s),s);return o.retainStringBytes===!0&&(i.byteValue=$n(r,t+e,t+s)),i}function Rd(r,t,e,n){return $o(r,t,1,e,n)}function _d(r,t,e,n){return $o(r,t,2,oe(r,t+1,n),n)}function Td(r,t,e,n){return $o(r,t,3,se(r,t+1,n),n)}function Cd(r,t,e,n){return $o(r,t,5,ie(r,t+1,n),n)}function Nd(r,t,e,n){let o=ae(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer string lengths not supported`);return $o(r,t,9,o,n)}var Ld=Kn;function qn(r,t,e,n){return new R(y.array,n,e)}function Ud(r,t,e,n){return qn(r,t,1,e)}function Dd(r,t,e,n){return qn(r,t,2,oe(r,t+1,n))}function Pd(r,t,e,n){return qn(r,t,3,se(r,t+1,n))}function Od(r,t,e,n){return qn(r,t,5,ie(r,t+1,n))}function Fd(r,t,e,n){let o=ae(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer array lengths not supported`);return qn(r,t,9,o)}function Vd(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return qn(r,t,1,1/0)}function _i(r,t){Ut(r,y.array.majorEncoded,t.value)}_i.compareTokens=de.compareTokens;_i.encodedSize=function(t){return Ut.encodedSize(t.value)};function zn(r,t,e,n){return new R(y.map,n,e)}function Md(r,t,e,n){return zn(r,t,1,e)}function $d(r,t,e,n){return zn(r,t,2,oe(r,t+1,n))}function Hd(r,t,e,n){return zn(r,t,3,se(r,t+1,n))}function Kd(r,t,e,n){return zn(r,t,5,ie(r,t+1,n))}function qd(r,t,e,n){let o=ae(r,t+1,n);if(typeof o=="bigint")throw new Error(`${V} 64-bit integer map lengths not supported`);return zn(r,t,9,o)}function zd(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return zn(r,t,1,1/0)}function Ti(r,t){Ut(r,y.map.majorEncoded,t.value)}Ti.compareTokens=de.compareTokens;Ti.encodedSize=function(t){return Ut.encodedSize(t.value)};function jd(r,t,e,n){return new R(y.tag,e,1)}function Gd(r,t,e,n){return new R(y.tag,oe(r,t+1,n),2)}function Wd(r,t,e,n){return new R(y.tag,se(r,t+1,n),3)}function Yd(r,t,e,n){return new R(y.tag,ie(r,t+1,n),5)}function Zd(r,t,e,n){return new R(y.tag,ae(r,t+1,n),9)}function Ci(r,t){Ut(r,y.tag.majorEncoded,t.value)}Ci.compareTokens=de.compareTokens;Ci.encodedSize=function(t){return Ut.encodedSize(t.value)};var lb=20,fb=21,hb=22,db=23;function Jd(r,t,e,n){if(n.allowUndefined===!1)throw new Error(`${V} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new R(y.null,null,1):new R(y.undefined,void 0,1)}function Xd(r,t,e,n){if(n.allowIndefinite===!1)throw new Error(`${V} indefinite length items not allowed`);return new R(y.break,void 0,1)}function nu(r,t,e){if(e){if(e.allowNaN===!1&&Number.isNaN(r))throw new Error(`${V} NaN values are not supported`);if(e.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${V} Infinity values are not supported`)}return new R(y.float,r,t)}function Qd(r,t,e,n){return nu(ou(r,t+1),3,n)}function tp(r,t,e,n){return nu(su(r,t+1),5,n)}function ep(r,t,e,n){return nu(sp(r,t+1),9,n)}function Ni(r,t,e){let n=t.value;if(n===!1)r.push([y.float.majorEncoded|lb]);else if(n===!0)r.push([y.float.majorEncoded|fb]);else if(n===null)r.push([y.float.majorEncoded|hb]);else if(n===void 0)r.push([y.float.majorEncoded|db]);else{let o,s=!1;(!e||e.float64!==!0)&&(np(n),o=ou(Se,1),n===o||Number.isNaN(n)?(Se[0]=249,r.push(Se.slice(0,3)),s=!0):(op(n),o=su(Se,1),n===o&&(Se[0]=250,r.push(Se.slice(0,5)),s=!0))),s||(pb(n),o=sp(Se,1),Se[0]=251,r.push(Se.slice(0,9)))}}Ni.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){np(n);let o=ou(Se,1);if(n===o||Number.isNaN(n))return 3;if(op(n),o=su(Se,1),n===o)return 5}return 9};var rp=new ArrayBuffer(9),pe=new DataView(rp,1),Se=new Uint8Array(rp,0);function np(r){if(r===1/0)pe.setUint16(0,31744,!1);else if(r===-1/0)pe.setUint16(0,64512,!1);else if(Number.isNaN(r))pe.setUint16(0,32256,!1);else{pe.setFloat32(0,r);let t=pe.getUint32(0),e=(t&2139095040)>>23,n=t&8388607;if(e===255)pe.setUint16(0,31744,!1);else if(e===0)pe.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let o=e-127;o<-24?pe.setUint16(0,0):o<-14?pe.setUint16(0,(t&2147483648)>>16|1<<24+o,!1):pe.setUint16(0,(t&2147483648)>>16|o+15<<10|n>>13,!1)}}}function ou(r,t){if(r.length-t<2)throw new Error(`${V} 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 op(r){pe.setFloat32(0,r,!1)}function su(r,t){if(r.length-t<4)throw new Error(`${V} not enough data for float32`);let e=(r.byteOffset||0)+t;return new DataView(r.buffer,e,4).getFloat32(0,!1)}function pb(r){pe.setFloat64(0,r,!1)}function sp(r,t){if(r.length-t<8)throw new Error(`${V} not enough data for float64`);let e=(r.byteOffset||0)+t;return new DataView(r.buffer,e,8).getFloat64(0,!1)}Ni.compareTokens=de.compareTokens;function et(r,t,e){throw new Error(`${V} encountered invalid minor (${e}) for major ${r[t]>>>5}`)}function Li(r){return()=>{throw new Error(`${V} ${r}`)}}var L=[];for(let r=0;r<=23;r++)L[r]=et;L[24]=pd;L[25]=md;L[26]=gd;L[27]=yd;L[28]=et;L[29]=et;L[30]=et;L[31]=et;for(let r=32;r<=55;r++)L[r]=et;L[56]=wd;L[57]=bd;L[58]=xd;L[59]=vd;L[60]=et;L[61]=et;L[62]=et;L[63]=et;for(let r=64;r<=87;r++)L[r]=Ad;L[88]=Bd;L[89]=kd;L[90]=Sd;L[91]=Id;L[92]=et;L[93]=et;L[94]=et;L[95]=Li("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)L[r]=Rd;L[120]=_d;L[121]=Td;L[122]=Cd;L[123]=Nd;L[124]=et;L[125]=et;L[126]=et;L[127]=Li("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)L[r]=Ud;L[152]=Dd;L[153]=Pd;L[154]=Od;L[155]=Fd;L[156]=et;L[157]=et;L[158]=et;L[159]=Vd;for(let r=160;r<=183;r++)L[r]=Md;L[184]=$d;L[185]=Hd;L[186]=Kd;L[187]=qd;L[188]=et;L[189]=et;L[190]=et;L[191]=zd;for(let r=192;r<=215;r++)L[r]=jd;L[216]=Gd;L[217]=Wd;L[218]=Yd;L[219]=Zd;L[220]=et;L[221]=et;L[222]=et;L[223]=et;for(let r=224;r<=243;r++)L[r]=Li("simple values are not supported");L[244]=et;L[245]=et;L[246]=et;L[247]=Jd;L[248]=Li("simple values are not supported");L[249]=Qd;L[250]=tp;L[251]=ep;L[252]=et;L[253]=et;L[254]=et;L[255]=Xd;var Ie=[];for(let r=0;r<24;r++)Ie[r]=new R(y.uint,r,1);for(let r=-1;r>=-24;r--)Ie[31-r]=new R(y.negint,r,1);Ie[64]=new R(y.bytes,new Uint8Array(0),1);Ie[96]=new R(y.string,"",1);Ie[128]=new R(y.array,0,1);Ie[160]=new R(y.map,0,1);Ie[244]=new R(y.false,!1,1);Ie[245]=new R(y.true,!0,1);Ie[246]=new R(y.null,null,1);function ip(r){switch(r.type){case y.false:return Me([244]);case y.true:return Me([245]);case y.null:return Me([246]);case y.bytes:return r.value.length?void 0:Me([64]);case y.string:return r.value===""?Me([96]):void 0;case y.array:return r.value===0?Me([128]):void 0;case y.map:return r.value===0?Me([160]):void 0;case y.uint:return r.value<24?Me([Number(r.value)]):void 0;case y.negint:if(r.value>=-24)return Me([31-Number(r.value)])}}var gb={float64:!1,mapSorter:bb,quickEncodeToken:ip};function yb(){let r=[];return r[y.uint.major]=de,r[y.negint.major]=Ii,r[y.bytes.major]=Kn,r[y.string.major]=Ld,r[y.array.major]=_i,r[y.map.major]=Ti,r[y.tag.major]=Ci,r[y.float.major]=Ni,r}var ap=yb(),iu=new Fo,Di=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)}},Nr={null:new R(y.null,null),undefined:new R(y.undefined,void 0),true:new R(y.true,!0),false:new R(y.false,!1),emptyArray:new R(y.array,0),emptyMap:new R(y.map,0)},Lr={number(r,t,e,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new R(y.float,r):r>=0?new R(y.uint,r):new R(y.negint,r)},bigint(r,t,e,n){return r>=BigInt(0)?new R(y.uint,r):new R(y.negint,r)},Uint8Array(r,t,e,n){return new R(y.bytes,r)},string(r,t,e,n){return new R(y.string,r)},boolean(r,t,e,n){return r?Nr.true:Nr.false},null(r,t,e,n){return Nr.null},undefined(r,t,e,n){return Nr.undefined},ArrayBuffer(r,t,e,n){return new R(y.bytes,new Uint8Array(r))},DataView(r,t,e,n){return new R(y.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,t,e,n){if(!r.length)return e.addBreakTokens===!0?[Nr.emptyArray,new R(y.break)]:Nr.emptyArray;n=Di.createCheck(n,r);let o=[],s=0;for(let i of r)o[s++]=Ui(i,e,n);return e.addBreakTokens?[new R(y.array,r.length),o,new R(y.break)]:[new R(y.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?[Nr.emptyMap,new R(y.break)]:Nr.emptyMap;n=Di.createCheck(n,r);let a=[],c=0;for(let u of s)a[c++]=[Ui(u,e,n),Ui(o?r.get(u):r[u],e,n)];return wb(a,e),e.addBreakTokens?[new R(y.map,i),a,new R(y.break)]:[new R(y.map,i),a]}};Lr.Map=Lr.Object;Lr.Buffer=Lr.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))Lr[`${r}Array`]=Lr.DataView;function Ui(r,t={},e){let n=id(r),o=t&&t.typeEncoders&&t.typeEncoders[n]||Lr[n];if(typeof o=="function"){let i=o(r,n,t,e);if(i!=null)return i}let s=Lr[n];if(!s)throw new Error(`${Hn} unsupported type: ${n}`);return s(r,n,t,e)}function wb(r,t){t.mapSorter&&r.sort(t.mapSorter)}function bb(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=ap[o].compareTokens(e,n);return s===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),s}function cp(r,t,e,n){if(Array.isArray(t))for(let o of t)cp(r,o,e,n);else e[t.type.major](r,t,n)}function up(r,t,e){let n=Ui(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 Fo(i);if(s(a,n,e),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return Oo(a.chunks[0])}}return iu.reset(),cp(iu,n,t,e),iu.toBytes(!0)}function jn(r,t){return t=Object.assign({},gb,t),up(r,ap,t)}var xb={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},Pi=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=Ie[t];if(e===void 0){let n=L[t];if(!n)throw new Error(`${V} 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}},Ho=Symbol.for("DONE"),Oi=Symbol.for("BREAK");function Eb(r,t,e){let n=[];for(let o=0;o<r.value;o++){let s=Gn(t,e);if(s===Oi){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed array`)}if(s===Ho)throw new Error(`${V} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=s}return n}function vb(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=Gn(t,e);if(a===Oi){if(r.value===1/0)break;throw new Error(`${V} got unexpected break to lengthed map`)}if(a===Ho)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(e.rejectDuplicateMapKeys===!0&&(n&&s.has(a)||!n&&a in o))throw new Error(`${V} found repeat map key "${a}"`);let c=Gn(t,e);if(c===Ho)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 Gn(r,t){if(r.done())return Ho;let e=r.next();if(e.type===y.break)return Oi;if(e.type.terminal)return e.value;if(e.type===y.array)return Eb(e,r,t);if(e.type===y.map)return vb(e,r,t);if(e.type===y.tag){if(t.tags&&typeof t.tags[e.value]=="function"){let n=Gn(r,t);return t.tags[e.value](n)}throw new Error(`${V} tag not supported (${e.value})`)}throw new Error("unsupported")}function au(r,t){if(!(r instanceof Uint8Array))throw new Error(`${V} data to decode must be a Uint8Array`);t=Object.assign({},xb,t);let e=t.tokenizer||new Pi(r,t),n=Gn(e,t);if(n===Ho)throw new Error(`${V} did not find any content to decode`);if(n===Oi)throw new Error(`${V} got unexpected break`);return[n,r.subarray(e.pos())]}function me(r,t){let[e,n]=au(r,t);if(n.length>0)throw new Error(`${V} too many terminals, data makes no sense`);return e}var ar="/",lp=new TextEncoder().encode(ar),Vi=lp[0],Dt=class r{_buf;constructor(t,e){if(typeof t=="string")this._buf=q(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]!==Vi)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(ar))}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=lp),this._buf[0]!==Vi){let t=new Uint8Array(this._buf.byteLength+1);t.fill(Vi,0,1),t.set(this._buf,1),this._buf=t}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Vi;)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(ar).slice(1)}type(){return Ab(this.baseNamespace())}name(){return Bb(this.baseNamespace())}instance(t){return new r(this.toString()+":"+t)}path(){let t=this.parent().toString();return t.endsWith(ar)||(t+=ar),t+=this.type(),new r(t)}parent(){let t=this.list();return t.length===1?new r(ar):new r(t.slice(0,-1).join(ar))}child(t){return this.toString()===ar?t:t.toString()===ar?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(),...kb(t.map(e=>e.namespaces()))])}};function Ab(r){let t=r.split(":");return t.length<2?"":t.slice(0,-1).join(":")}function Bb(r){let t=r.split(":");return t[t.length-1]}function kb(r){return[].concat(...r)}var pp="/pin/",fp="/pinned-block/",cu=wr,hp=1;function dp(r){return r.version===0&&(r=r.toV1()),new Dt(`${pp}${r.toString(cu)}`)}var Mi=class{datastore;blockstore;dagWalkers;constructor(t,e,n){this.datastore=t,this.blockstore=e,this.dagWalkers=n}async*add(t,e={}){let n=dp(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 qe({concurrency:hp});for await(let a of this.#t(t,s,{...e,depth:o}))await this.#e(a,c=>c.pinnedBy.find(u=>it(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,jn(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 Dt(`${fp}${cu.encode(t.multihash.bytes)}`),s={pinCount:0,pinnedBy:[]};try{s=me(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,jn(s),n),n.onProgress?.(new nt("helia:pin:add",t))}}async*rm(t,e={}){let n=dp(t),o=await this.datastore.get(n,e),s=me(o);await this.datastore.delete(n,e);let i=new qe({concurrency:hp});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=>it(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:pp+(t.cid!=null?`${t.cid.toString(wr)}`:"")},t)){let o=Q.parse(e.toString().substring(5),wr),s=me(n);yield{cid:o,...s}}}async isPinned(t,e={}){let n=new Dt(`${fp}${cu.encode(t.multihash.bytes)}`);return this.datastore.has(n,e)}};var Sb=5,$i=class{log;routers;providerLookupConcurrency;constructor(t,e){this.log=t.logger.forComponent("helia:routing"),this.routers=e.routers??[],this.providerLookupConcurrency=e.providerLookupConcurrency??Sb}async start(){await pr(...this.routers)}async stop(){await mr(...this.routers)}async*findProviders(t,e={}){if(this.routers.length===0)throw new D("No content routers available","ERR_NO_ROUTERS_AVAILABLE");let n=new ss({concurrency:this.providerLookupConcurrency});n.addEventListener("error",()=>{});for await(let o of $r(n.toGenerator(),...Wn(this.routers,"findProviders").map(s=>s.findProviders(t,e))))if(o!=null){if(o.multiaddrs.length===0){if(n.find(o.id)!=null)continue;n.add(async()=>{try{let s=await this.findPeer(o.id,e);return s.multiaddrs.length===0?null:s}catch(s){return this.log.error("could not load multiaddrs for peer %p",o.id,s),null}},{peerId:o.id,signal:e.signal}).catch(s=>{this.log.error("could not load multiaddrs for peer %p",o.id,s)})}yield o}}async provide(t,e={}){if(this.routers.length===0)throw new D("No content routers available","ERR_NO_ROUTERS_AVAILABLE");await Promise.all(Wn(this.routers,"provide").map(async n=>{await n.provide(t,e)}))}async put(t,e,n){await Promise.all(Wn(this.routers,"put").map(async o=>{await o.put(t,e,n)}))}async get(t,e){return Promise.any(Wn(this.routers,"get").map(async n=>n.get(t,e)))}async findPeer(t,e){if(this.routers.length===0)throw new D("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");let n=this,o=$r(...Wn(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 D("Could not find peer in routing","ERR_NOT_FOUND")}async*getClosestPeers(t,e={}){if(this.routers.length===0)throw new D("No peer routers available","ERR_NO_ROUTERS_AVAILABLE");for await(let n of $r(...Wn(this.routers,"getClosestPeers").map(o=>o.getClosestPeers(t,e))))n!=null&&(yield n)}};function Wn(r,t){return r.filter(e=>e[t]!=null)}var Ur={},Yn=r=>{r.addEventListener("message",t=>{Yn.dispatchEvent("message",r,t)}),r.port!=null&&r.port.addEventListener("message",t=>{Yn.dispatchEvent("message",r,t)})};Yn.addEventListener=(r,t)=>{Ur[r]==null&&(Ur[r]=[]),Ur[r].push(t)};Yn.removeEventListener=(r,t)=>{Ur[r]!=null&&(Ur[r]=Ur[r].filter(e=>e===t))};Yn.dispatchEvent=function(r,t,e){Ur[r]!=null&&Ur[r].forEach(n=>n(t,e))};var uu=Yn;var lu="lock:worker:request-read",fu="lock:worker:release-read",hu="lock:master:grant-read",du="lock:worker:request-write",pu="lock:worker:release-write",mu="lock:master:grant-write";var mp=(r=21)=>Math.random().toString().substring(2);var gp=(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=f=>{if(f==null||f.data==null)return;let l={type:f.data.type,name:f.data.name,identifier:f.data.identifier};l.type===n&&l.identifier===a.identifier&&(s.removeEventListener("message",u),c())};s.addEventListener("message",u)})}}}))},yp=(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)})},Ib={singleProcess:!1},wp=r=>{if(r=Object.assign({},Ib,r),!!globalThis.document||r.singleProcess){let e=new EventTarget;return uu.addEventListener("message",gp(e,"requestReadLock",lu,fu,hu)),uu.addEventListener("message",gp(e,"requestWriteLock",du,pu,mu)),e}return{isWorker:!0,readLock:e=>yp(e,lu,hu,fu),writeLock:e=>yp(e,du,mu,pu)}};var Xr={},Dr;async function gu(r,t){let e,n=new Promise(o=>{e=o});return r.add(async()=>Do((async()=>{await new Promise(o=>{e(()=>{o()})})})(),{milliseconds:t.timeout})),n}var Rb=(r,t)=>{if(Dr.isWorker===!0)return{readLock:Dr.readLock(r,t),writeLock:Dr.writeLock(r,t)};let e=new Ve({concurrency:1}),n;return{async readLock(){if(n!=null)return gu(n,t);n=new Ve({concurrency:t.concurrency,autoStart:!1});let o=n,s=gu(n,t);return e.add(async()=>{o.start(),await o.onIdle().then(()=>{n===o&&(n=null)})}),s},async writeLock(){return n=null,gu(e,t)}}},_b={name:"lock",concurrency:1/0,timeout:846e5,singleProcess:!1};function yu(r){let t=Object.assign({},_b,r);return Dr==null&&(Dr=wp(t),Dr.isWorker!==!0&&(Dr.addEventListener("requestReadLock",e=>{Xr[e.data.name]!=null&&Xr[e.data.name].readLock().then(async n=>e.data.handler().finally(()=>{n()}))}),Dr.addEventListener("requestWriteLock",async e=>{Xr[e.data.name]!=null&&Xr[e.data.name].writeLock().then(async n=>e.data.handler().finally(()=>{n()}))}))),Xr[t.name]==null&&(Xr[t.name]=Rb(t.name,t)),Xr[t.name]}var Hi=class{lock;child;pins;started;constructor(t,e,n={}){this.child=t,this.pins=e,this.lock=yu({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await pr(this.child),this.started=!0}async stop(){await mr(this.child),this.started=!1}unwrap(){return this.child}async put(t,e,n={}){n?.signal?.throwIfAborted();let o=await this.lock.readLock();try{return await this.child.put(t,e,n)}finally{o()}}async*putMany(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{yield*this.child.putMany(t,e)}finally{n()}}async get(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{return await this.child.get(t,e)}finally{n()}}async*getMany(t,e={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{yield*this.child.getMany(t,e)}finally{n()}}async delete(t,e={}){e?.signal?.throwIfAborted();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={}){e?.signal?.throwIfAborted();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={}){e?.signal?.throwIfAborted();let n=await this.lock.readLock();try{return await this.child.has(t,e)}finally{n()}}async*getAll(t={}){t?.signal?.throwIfAborted();let e=await this.lock.readLock();try{yield*this.child.getAll(t)}finally{e()}}createSession(t,e){return e?.signal?.throwIfAborted(),this.child.createSession(t,e)}};var xp=42;function Tb(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let t=Q.asCID(r);if(!t)return null;let e=new Uint8Array(t.bytes.byteLength+1);return e.set(t.bytes,1),[new R(y.tag,xp),new R(y.bytes,e)]}function Cb(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function Nb(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 bp={float64:!0,typeEncoders:{Object:Tb,undefined:Cb,number:Nb}},bk={...bp,typeEncoders:{...bp.typeEncoders}};function Lb(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return Q.decode(r.subarray(1))}var wu={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};wu.tags[xp]=Lb;var xk={...wu,tags:wu.tags.slice()};var Ep=113;var vp=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(t){let e=this.inRecursive[this.inRecursive.length-1];e&&(e.type===y.array&&(e.elements++,e.elements!==1&&t.push([44])),e.type===y.map&&(e.elements++,e.elements!==1&&(e.elements%2===1?t.push([44]):t.push([58]))))}[y.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)}[y.negint.major](t,e){this[y.uint.major](t,e)}[y.bytes.major](t,e){throw new Error(`${Hn} unsupported type: Uint8Array`)}[y.string.major](t,e){this.prefix(t);let n=Si(JSON.stringify(e.value));t.push(n.length>32?Oo(n):n)}[y.array.major](t,e){this.prefix(t),this.inRecursive.push({type:y.array,elements:0}),t.push([91])}[y.map.major](t,e){this.prefix(t),this.inRecursive.push({type:y.map,elements:0}),t.push([123])}[y.tag.major](t,e){}[y.float.major](t,e){if(e.type.name==="break"){let i=this.inRecursive.pop();if(i){if(i.type===y.array)t.push([93]);else if(i.type===y.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 Qr=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(`${V} 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(`${V} 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 R(y.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(`${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(t,this._pos)),i=parseFloat(s);return n?new R(y.float,i,this._pos-t):this.options.allowBigInt!==!0||Number.isSafeInteger(i)?new R(i>=0?y.uint:y.negint,i,this._pos-t):new R(i>=0?y.uint:y.negint,BigInt(s),this._pos-t)}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 R(y.string,c,i)}}let t=this._pos,e=[],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,u,f,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],u=this.data[this._pos+2],(c&192)===128&&(u&192)===128&&(l=(s&15)<<12|(c&63)<<6|u&63,l>2047&&(l<55296||l>57343)&&(i=l));break;case 4:c=this.data[this._pos+1],u=this.data[this._pos+2],f=this.data[this._pos+3],(c&192)===128&&(u&192)===128&&(f&192)===128&&(l=(s&15)<<18|(c&63)<<12|(u&63)<<6|f&63,l>65535&&l<1114112&&(i=l))}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(`${V} 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(`${V} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new R(y.string,eu(e),this._pos-t);default:if(s<32)throw new Error(`${V} invalid control character at position ${this._pos}`);s<128?(e.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 R(y.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new R(y.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new R(y.null,null,4);case 102:return this.expect([102,97,108,115,101]),new R(y.false,!1,5);case 116:return this.expect([116,114,117,101]),new R(y.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 R(y.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 R(y.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 R(y.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 R(y.break,void 0,1);let t=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"),t}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 Ki(r,t){return t=Object.assign({tokenizer:new Qr(r,t)},t),me(r,t)}var Pb={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Pb.tags[42]=Q.parse;var Bp=297;var Ok=new TextDecoder;var Fk=new TextEncoder;var Fb=new TextDecoder;function bu(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 qi(r,t){let e;[e,t]=bu(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 kp(r,t){let e;return[e,t]=bu(r,t),[e&7,e>>3,t]}function Vb(r){let t={},e=r.length,n=0;for(;n<e;){let o,s;if([o,s,n]=kp(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]=qi(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]=qi(r,n),t.Name=Fb.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]=bu(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 Sp(r){let t=r.length,e=0,n,o=!1,s;for(;e<t;){let a,c;if([a,c,e]=kp(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]=qi(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]=qi(r,e),n.push(Vb(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 Mk=new TextEncoder,$k=2**32,Hk=2**31;var zk=new TextEncoder;function Ip(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var Rp=112;function _p(r){let t=Ip(r),e=Sp(t),n={};return e.Data&&(n.Data=e.Data),e.Links&&(n.Links=e.Links.map(o=>{let s={};try{s.Hash=Q.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 $b={codec:Rp,*walk(r){yield*_p(r).Links.map(e=>e.Hash)}},Hb={codec:ls,*walk(){}},Tp=42,Kb={codec:Ep,*walk(r){let t=[],e=[];e[Tp]=n=>{if(n[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");let o=Q.decode(n.subarray(1));return t.push(o),o},me(r,{tags:e}),yield*t}},xu=class extends Qr{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===y.map){let e=this._next();if(e.type===y.string&&e.value==="/"){let n=this._next();if(n.type===y.string){if(this._next().type!==y.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new R(y.tag,42,0)}if(n.type===y.map){let o=this._next();if(o.type===y.string&&o.value==="bytes"){let s=this._next();if(s.type===y.string){for(let a=0;a<2;a++)if(this._next().type!==y.break)throw new Error("Invalid encoded Bytes form");let i=ue.decode(`m${s.value}`);return new R(y.bytes,i,s.value.length)}this.tokenBuffer.push(s)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(e)}return t}},qb={codec:Bp,*walk(r){let t=[],e=[];e[Tp]=n=>{let o=Q.parse(n);return t.push(o),o},Ki(r,{tags:e,tokenizer:new xu(r,{tags:e,allowIndefinite:!0,allowUndefined:!0,allowNaN:!0,allowInfinity:!0,allowBigInt:!0,strict:!1,rejectDuplicateMapKeys:!1})}),yield*t}},zb={codec:ql,*walk(){}};function Cp(r=[]){let t={};return[$b,Hb,Kb,qb,zb,...r].forEach(e=>{t[e.codec]=e}),t}var Eu=new Dt("/version"),Np=1;async function Lp(r){if(!await r.has(Eu)){await r.put(Eu,q(`${Np}`));return}let t=await r.get(Eu),e=z(t);if(parseInt(e,10)!==Np)throw new Error("Unknown datastore version, a datastore migration may be required")}function Up(r=[]){let t={};return[At,rc,Kt,...r].forEach(e=>{t[e.code]=e}),t}var cr=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 Zn={};vt(Zn,{abortedError:()=>Zb,closeFailedError:()=>Gb,deleteFailedError:()=>Pp,getFailedError:()=>Wb,hasFailedError:()=>Yb,notFoundError:()=>Ko,openFailedError:()=>jb,putFailedError:()=>Dp});var ur=Xt(sn(),1);function jb(r){return r=r??new Error("Open failed"),(0,ur.default)(r,"ERR_OPEN_FAILED")}function Gb(r){return r=r??new Error("Close failed"),(0,ur.default)(r,"ERR_CLOSE_FAILED")}function Dp(r){return r=r??new Error("Put failed"),(0,ur.default)(r,"ERR_PUT_FAILED")}function Wb(r){return r=r??new Error("Get failed"),(0,ur.default)(r,"ERR_GET_FAILED")}function Pp(r){return r=r??new Error("Delete failed"),(0,ur.default)(r,"ERR_DELETE_FAILED")}function Yb(r){return r=r??new Error("Has failed"),(0,ur.default)(r,"ERR_HAS_FAILED")}function Ko(r){return r=r??new Error("Not Found"),(0,ur.default)(r,"ERR_NOT_FOUND")}function Zb(r){return r=r??new Error("Aborted"),(0,ur.default)(r,"ERR_ABORTED")}var qo=class extends cr{data;constructor(){super(),this.data=new Map}put(t,e){return this.data.set(Nt.encode(t.multihash.bytes),e),t}get(t){let e=this.data.get(Nt.encode(t.multihash.bytes));if(e==null)throw Ko();return e}has(t){return this.data.has(Nt.encode(t.multihash.bytes))}async delete(t){this.data.delete(Nt.encode(t.multihash.bytes))}async*getAll(){for(let[t,e]of this.data.entries())yield{cid:Q.createV1(ls,Ne(Nt.decode(t))),block:e}}};function Jb(r){return r[Symbol.asyncIterator]!=null}function Xb(r,t){let e=0;if(Jb(r))return async function*(){for await(let c of r)await t(c,e++)&&(yield c)}();let n=an(r),{value:o,done:s}=n.next();if(s===!0)return function*(){}();let i=t(o,e++);if(typeof i.then=="function")return async function*(){await i&&(yield o);for await(let c of n)await t(c,e++)&&(yield c)}();let a=t;return function*(){i===!0&&(yield o);for(let c of n)a(c,e++)&&(yield c)}()}var Re=Xb;var RS=ne("blockstore:core:tiered");var Op={...Zn};var zi=0,ji=class extends cr{child;constructor(t){super(),this.child=t}put(t,e){return t.multihash.code===zi||this.child==null?t:this.child.put(t,e)}get(t){if(t.multihash.code===zi)return t.multihash.digest;if(this.child==null)throw Op.notFoundError();return this.child.get(t)}has(t){return t.multihash.code===zi?!0:this.child==null?!1:this.child.has(t)}delete(t){if(t.code!==zi&&this.child!=null)return this.child.delete(t)}getAll(t){return this.child!=null?this.child.getAll(t):[]}};function Qb(r){return r[Symbol.asyncIterator]!=null}function Fp(r){return r?.then!=null}function tx(r,t){let e=0;if(Qb(r))return async function*(){for await(let c of r){let u=t(c,e++);Fp(u)&&await u,yield c}}();let n=an(r),{value:o,done:s}=n.next();if(s===!0)return function*(){}();if(typeof t(o,e++)?.then=="function")return async function*(){yield o;for await(let c of n){let u=t(c,e++);Fp(u)&&await u,yield c}}();let a=t;return function*(){yield o;for(let c of n)a(c,e++),yield c}()}var vu=tx;var Gi=class{child;hashers;log;logger;components;constructor(t){this.log=t.logger.forComponent("helia:networked-storage"),this.logger=t.logger,this.components=t,this.child=new ji(t.blockstore),this.hashers=t.hashers??{}}async put(t,e,n={}){return await this.child.has(t,n)?(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=Re(t,async({cid:s})=>{let i=await this.child.has(s,e);return i&&e.onProgress?.(new nt("blocks:put-many:duplicate",s)),!i}),o=vu(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)){e.onProgress?.(new nt("blocks:get:providers:get",t));let n=await Vp(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(vu(t,async n=>{if(e.offline!==!0&&!await this.child.has(n,e)){e.onProgress?.(new nt("blocks:get-many:providers:get",n));let o=await Vp(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)}},Wi=class extends Gi{started;constructor(t){super(t),this.started=!1}isStarted(){return this.started}async start(){await pr(this.child,...this.components.blockBrokers),this.started=!0}async stop(){await mr(this.child,...this.components.blockBrokers),this.started=!1}unwrap(){return this.child}createSession(t,e){let n=this.components.blockBrokers.map(o=>o.createSession==null?o:o.createSession(e));return new Au({blockstore:this.child,blockBrokers:n,hashers:this.hashers,logger:this.logger},{root:t})}},Au=class extends Gi{closeController;constructor(t,e){super(t),this.closeController=new AbortController,ft(1/0,this.closeController.signal),this.log=t.logger.forComponent(`helia:session-storage:${e.root}`)}close(){this.closeController.abort()}async put(t,e,n={}){let o=Ht([this.closeController.signal,n.signal]);ft(1/0,o);try{return await super.put(t,e,{...n,signal:o})}finally{o.clear()}}async*putMany(t,e={}){let n=Ht([this.closeController.signal,e.signal]);ft(1/0,n);try{yield*super.putMany(t,{...e,signal:n})}finally{n.clear()}}async get(t,e={}){let n=Ht([this.closeController.signal,e.signal]);ft(1/0,n);try{return await super.get(t,{...e,signal:n})}finally{n.clear()}}async*getMany(t,e={}){let n=Ht([this.closeController.signal,e.signal]);ft(1/0,n);try{yield*super.getMany(t,{...e,signal:n})}finally{n.clear()}}async delete(t,e={}){let n=Ht([this.closeController.signal,e.signal]);ft(1/0,n);try{await super.delete(t,{...e,signal:n})}finally{n.clear()}}async*deleteMany(t,e={}){let n=Ht([this.closeController.signal,e.signal]);ft(1/0,n);try{yield*super.deleteMany(t,{...e,signal:n})}finally{n.clear()}}async has(t,e={}){let n=Ht([this.closeController.signal,e.signal]);ft(1/0,n);try{return await super.has(t,{...e,signal:n})}finally{n.clear()}}async*getAll(t={}){let e=Ht([this.closeController.signal,t.signal]);ft(1/0,e);try{yield*super.getAll({...t,signal:e})}finally{e.clear()}}};function ex(r){return typeof r.retrieve=="function"}var rx=(r,t)=>{if(t==null)throw new D(`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(!it(n.digest,r.multihash.digest))throw new D("Hash of downloaded block did not match multihash from passed CID","ERR_HASH_MISMATCH")}};async function Vp(r,t,e,n){let o=rx(r,e),s=new AbortController,i=Ht([s.signal,n.signal]);ft(1/0,s.signal,i);let a=[];for(let c of t)ex(c)&&a.push(c);try{return await Promise.any(a.map(async c=>{try{let u=!1,f=await c.retrieve(r,{...n,signal:i,validateFn:async l=>{await o(l),u=!0}});return u||await o(f),f}catch(u){throw n.log.error("could not retrieve verified block for %c",r,u),u}}))}finally{s.abort(),i.clear()}}var Mp=1,$p=5;var Bu=Xt(Kh(),1);var nx=Math.LN2*Math.LN2,Yi=class r{static create(t,e=.005){let n=ox(t,e);return new r(n)}seeds;bits;buffer;constructor(t={}){t.seeds!=null?this.seeds=t.seeds:this.seeds=sx(t.hashes??8),this.bits=t.bits??1024,this.buffer=we(Math.ceil(this.bits/8))}add(t){typeof t=="string"&&(t=q(t));for(let e=0;e<this.seeds.length;e++){let o=Bu.default.x86.hash32(t,this.seeds[e])%this.bits;this.setbit(o)}}has(t){typeof t=="string"&&(t=q(t));for(let e=0;e<this.seeds.length;e++){let o=Bu.default.x86.hash32(t,this.seeds[e])%this.bits;if(!this.getbit(o))return!1}return!0}clear(){this.buffer.fill(0)}setbit(t){let e=0,n=t;for(;n>7;)e++,n-=8;let o=this.buffer[e];o|=1<<n,this.buffer[e]=o}getbit(t){let e=0,n=t;for(;n>7;)e++,n-=8;return(this.buffer[e]&1<<n)!==0}};function ox(r,t=.005){let e=Math.round(-1*r*Math.log(t)/nx),n=Math.round(e/r*Math.LN2);return{bits:e,hashes:n}}function sx(r){let t,e,n=[];for(let o=0;o<r;o++)for(t=new as(De(4)),n[o]=t.getUint32(0,!0),e=0;e<o;e++)if(n[o]===n[e]){o--;break}return n}var zo=class extends rn{intialPeerSearchComplete;requests;name;log;logger;minProviders;maxProviders;providers;evictionFilter;constructor(t,e){super(),ft(1/0,this),this.name=e.name,this.logger=t.logger,this.log=t.logger.forComponent(this.name),this.requests=new Map,this.minProviders=e.minProviders??1,this.maxProviders=e.maxProviders??5,this.providers=[],this.evictionFilter=Yi.create(this.maxProviders)}async retrieve(t,e={}){let n=ue.encode(t.multihash.bytes),o=this.requests.get(n);if(o!=null)return this.log("join existing request for %c",t),o;let s=St();if(this.requests.set(n,s.promise),this.providers.length===0){let u=!1;this.intialPeerSearchComplete==null&&(u=!0,this.log=this.logger.forComponent(`${this.name}:${t}`),this.intialPeerSearchComplete=this.findProviders(t,this.minProviders,e)),await this.intialPeerSearchComplete,u&&this.log("found initial session peers for %c",t)}let i=!1,a=new qe({concurrency:this.maxProviders});a.addEventListener("error",()=>{}),a.addEventListener("failure",u=>{this.log.error("error querying provider %o, evicting from session",u.detail.job.options.provider,u.detail.error),this.evict(u.detail.job.options.provider)}),a.addEventListener("success",u=>{i=!0,s.resolve(u.detail.result)}),a.addEventListener("idle",()=>{i||e.signal?.aborted===!0||Promise.resolve().then(async()=>{this.log("no session peers had block for for %c, finding new providers",t);for(let u=0;u<this.minProviders&&this.providers.length!==0;u++){let f=this.providers[Math.floor(Math.random()*this.providers.length)];this.evict(f)}await this.findProviders(t,this.minProviders,e),this.log("found new providers re-retrieving %c",t),this.requests.delete(n),s.resolve(await this.retrieve(t,e))}).catch(u=>{this.log.error("could not find new providers for %c",t,u),s.reject(u)})});let c=u=>{a.add(async()=>this.queryProvider(t,u.detail,e),{provider:u.detail}).catch(f=>{e.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c",t,f)})};this.addEventListener("provider",c),Promise.all([...this.providers].map(async u=>a.add(async()=>this.queryProvider(t,u,e),{provider:u}))).catch(u=>{e.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c",t,u)});try{return await s.promise}finally{this.removeEventListener("provider",c),a.clear(),this.requests.delete(n)}}evict(t){this.evictionFilter.add(this.toEvictionKey(t));let e=this.providers.findIndex(n=>this.equals(n,t));e!==-1&&this.providers.splice(e,1)}isEvicted(t){return this.evictionFilter.has(this.toEvictionKey(t))}hasProvider(t){return!!(this.providers.find(e=>this.equals(e,t))!=null||this.isEvicted(t))}async findProviders(t,e,n){let o=St(),s=0;return Promise.resolve().then(async()=>{this.log("finding %d-%d new provider(s) for %c",e,this.maxProviders,t);for await(let i of this.findNewProviders(t,n)){if(s===this.maxProviders||n.signal?.aborted===!0)break;if(!this.hasProvider(i)&&(this.log("found %d/%d new providers",s,this.maxProviders),this.providers.push(i),this.safeDispatchEvent("provider",{detail:i}),s++,s===e&&(this.log("session is ready"),o.resolve()),this.providers.length===this.maxProviders)){this.log("found max session peers",s);break}}if(this.log("found %d/%d new session peers",s,this.maxProviders),s<e)throw new D(`Found ${s} of ${e} ${this.name} providers for ${t}`,"ERR_INSUFFICIENT_PROVIDERS_FOUND")}).catch(i=>{this.log.error("error searching routing for potential session peers for %c",t,i.errors??i),o.reject(i)}),o.promise}};var Zi=class{blockstore;datastore;pins;logger;routing;dagWalkers;hashers;dns;metrics;log;constructor(t){this.logger=t.logger??Yh(),this.log=this.logger.forComponent("helia"),this.hashers=Up(t.hashers),this.dagWalkers=Cp(t.dagWalkers),this.dns=t.dns??sd(),this.metrics=t.metrics;let e={blockstore:t.blockstore,datastore:t.datastore,hashers:this.hashers,dagWalkers:this.dagWalkers,logger:this.logger,blockBrokers:[],dns:this.dns,metrics:this.metrics,...t.components??{}};this.routing=e.routing=new $i(e,{routers:(t.routers??[]).flatMap(o=>{let s=[o];return o[no]!=null&&s.push(o[no]),o[oo]!=null&&s.push(o[oo]),s}),providerLookupConcurrency:t.providerLookupConcurrency});let n=new Wi(e);this.pins=new Mi(t.datastore,n,this.dagWalkers),this.blockstore=new Hi(n,this.pins,{holdGcLock:t.holdGcLock??!0}),this.datastore=t.datastore,e.blockBrokers=t.blockBrokers.map(o=>o(e))}async start(){await Lp(this.datastore),await pr(this.blockstore,this.datastore,this.routing)}async stop(){await mr(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 Vr(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 Ji=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 f=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let m=Number.parseInt(l,t);if(!Number.isNaN(m))return m});if(f===void 0)break;if(s*=t,s+=f,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 Hp=45,ix=15,Jn=new Ji;function ku(r){if(!(r.length>ix))return Jn.new(r).parseWith(()=>Jn.readIPv4Addr())}function Su(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Hp))return Jn.new(r).parseWith(()=>Jn.readIPv6Addr())}function Xi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Hp))return Jn.new(r).parseWith(()=>Jn.readIPAddr())}function Xn(r){return!!ku(r)}function Qn(r){return!!Su(r)}function Qi(r){return!!Xi(r)}var qp=Xt(Kp(),1),ax=["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"],cx=ax.map(r=>new qp.Netmask(r));function ux(r){for(let t of cx)if(t.contains(r))return!0;return!1}function lx(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 zp(r){return Xn(r)?ux(r):Qn(r)?lx(r):void 0}var OI=parseInt("0xFFFF",16),FI=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Wp=Xn,mx=Qn,Iu=function(r){let t=0;if(r=r.toString().trim(),Wp(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(mx(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=Wp(e[n]),i;s&&(i=Iu(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")},Yp=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 to={},Ru={},yx=[[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"],[481,-1,"http-path"],[777,-1,"memory"]];yx.forEach(r=>{let t=wx(...r);Ru[t.code]=t,to[t.name]=t});function wx(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function G(r){if(typeof r=="number"){if(Ru[r]!=null)return Ru[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(to[r]!=null)return to[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var b6=G("ip4"),x6=G("ip6"),E6=G("ipcidr");function Nu(r,t){switch(G(r).code){case 4:case 41:return xx(t);case 42:return Cu(t);case 6:case 273:case 33:case 132:return Xp(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Cu(t);case 421:return Bx(t);case 444:return Jp(t);case 445:return Jp(t);case 466:return Ax(t);case 481:return globalThis.encodeURIComponent(Cu(t));default:return z(t,"base16")}}function Lu(r,t){switch(G(r).code){case 4:return Zp(t);case 41:return Zp(t);case 42:return Tu(t);case 6:case 273:case 33:case 132:return Uu(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Tu(t);case 421:return Ex(t);case 444:return kx(t);case 445:return Sx(t);case 466:return vx(t);case 481:return Tu(globalThis.decodeURIComponent(t));default:return q(t,"base16")}}var _u=Object.values(br).map(r=>r.decoder),bx=function(){let r=_u[0].or(_u[1]);return _u.slice(2).forEach(t=>r=r.or(t)),r}();function Zp(r){if(!Qi(r))throw new Error("invalid ip address");return Iu(r)}function xx(r){let t=Yp(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!Qi(t))throw new Error("invalid ip address");return t}function Uu(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Xp(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Tu(r){let t=q(r),e=Uint8Array.from(on(t.length));return It([e,t],e.length+t.length)}function Cu(r){let t=Mr(r);if(r=r.slice(Wt(t)),r.length!==t)throw new Error("inconsistent lengths");return z(r)}function Ex(r){let t;r[0]==="Q"||r[0]==="1"?t=Ne(ht.decode(`z${r}`)).bytes:t=Q.parse(r).multihash.bytes;let e=Uint8Array.from(on(t.length));return It([e,t],e.length+t.length)}function vx(r){let t=bx.decode(r),e=Uint8Array.from(on(t.length));return It([e,t],e.length+t.length)}function Ax(r){let t=Mr(r),e=r.slice(Wt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+z(e,"base64url")}function Bx(r){let t=Mr(r),e=r.slice(Wt(t));if(e.length!==t)throw new Error("inconsistent lengths");return z(e,"base58btc")}function kx(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=Nt.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=Uu(n);return It([e,o],e.length+o.length)}function Sx(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=Nt.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=Uu(n);return It([e,o],e.length+o.length)}function Jp(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=z(t,"base32"),o=Xp(e);return`${n}:${o}`}function Qp(r){r=Du(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 e0("invalid address: "+r);if(a.path===!0){n=Du(o.slice(s).join("/")),t.push([a.code,Lu(a.code,n)]),e.push([a.code,n]);break}let c=Lu(a.code,o[s]);t.push([a.code,c]),e.push([a.code,Nu(a.code,c)])}return{string:t0(e),bytes:Ou(t),tuples:t,stringTuples:e,path:n}}function Pu(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=Mr(r,o),i=Wt(s),a=G(s),c=Ix(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 e0("Invalid address Uint8Array: "+z(r,"base16"));t.push([s,u]);let f=Nu(s,u);if(e.push([s,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(r),string:t0(e),tuples:t,stringTuples:e,path:n}}function t0(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}),Du(t.join("/"))}function Ou(r){return It(r.map(t=>{let e=G(t[0]),n=Uint8Array.from(on(e.code));return t.length>1&&t[1]!=null&&(n=It([n,t[1]])),n}))}function Ix(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Mr(t instanceof Uint8Array?t:Uint8Array.from(t));return e+Wt(e)}}function Du(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function e0(r){return new Error("Error parsing address: "+r)}var Rx=Symbol.for("nodejs.util.inspect.custom"),Fu=Symbol.for("@multiformats/js-multiaddr/multiaddr"),_x=[G("dns").code,G("dns4").code,G("dns6").code,G("dnsaddr").code],ta=class r{bytes;#t;#e;#r;#o;[Fu]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Pu(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Qp(t)}else if(n0(t))e=Pu(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.#o=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"),f=G("dns6"),l=G("ip6zone");for(let[h,p]of this.stringTuples())h===l.code&&(s=`%${p??""}`),_x.includes(h)&&(e=i.name,o=443,n=`${p??""}${s}`,t=h===f.code?6:4),(h===i.code||h===a.code)&&(e=G(h).name,o=parseInt(p??"")),(h===c.code||h===u.code)&&(e=G(h).name,n=`${p??""}${s}`,t=h===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(Ou(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===to.p2p.code&&t.push([n,o]),n===to["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?z(ht.decode(`z${n}`),"base58btc"):z(Q.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#o}equals(t){return it(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=r0.get(e.name);if(n==null)throw new D(`no available resolver for ${e.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,t)).map(s=>lr(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)}[Rx](){return`Multiaddr(${this.#t})`}};var r0=new Map;function n0(r){return!!r?.[Fu]}function lr(r){return new ta(r)}var Tx=r=>r.toString().split("/").slice(1),Go=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),ot=r=>({match:t=>Go(e=>e===r).match(t),pattern:r}),na=()=>({match:r=>Go(t=>typeof t=="string").match(r),pattern:"{string}"}),oa=()=>({match:r=>Go(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),Pt=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{ht.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),ea=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Ga.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),kt=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),ge=(...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(", ")})`}),ct=(...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 yt(...r){function t(o){let s=Tx(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 Mu=ct(ot("dns4"),na()),$u=ct(ot("dns6"),na()),Hu=ct(ot("dnsaddr"),na()),o0=ct(ot("dns"),na()),Z6=yt(Mu),J6=yt($u),X6=yt(Hu),s0=yt(ge(o0,Hu,Mu,$u)),i0=ct(ot("ip4"),Go(Xn)),a0=ct(ot("ip6"),Go(Qn)),c0=ge(i0,a0),$e=ge(c0,o0,Mu,$u,Hu),Q6=yt($e),t4=yt(i0),e4=yt(a0),r4=yt(c0),Ku=ct($e,ot("tcp"),oa()),Wo=ct($e,ot("udp"),oa()),n4=yt(Ku),o4=yt(Wo),qu=ct(Wo,ot("quic")),sa=ct(Wo,ot("quic-v1")),Cx=ge(qu,sa),s4=yt(qu),i4=yt(sa),Vu=ge($e,Ku,Wo,qu,sa),u0=ge(ct(Vu,ot("ws"),kt(Pt()))),a4=yt(u0),l0=ge(ct(Vu,ot("wss"),kt(Pt())),ct(Vu,ot("tls"),ot("ws"),kt(Pt()))),c4=yt(l0),f0=ct(Wo,ot("webrtc-direct"),kt(ea()),kt(ea()),kt(Pt())),u4=yt(f0),h0=ct(sa,ot("webtransport"),kt(ea()),kt(ea()),kt(Pt())),l4=yt(h0),ra=ge(u0,l0,ct(Ku,kt(Pt())),ct(Cx,kt(Pt())),ct($e,kt(Pt())),f0,h0,Pt()),f4=yt(ra),Nx=ct(ra,ot("p2p-circuit"),Pt()),h4=yt(Nx),Lx=ge(ct(ra,ot("p2p-circuit"),ot("webrtc"),kt(Pt())),ct(ra,ot("webrtc"),kt(Pt())),ot("webrtc")),d4=yt(Lx),Ux=ge(ct($e,ot("tcp"),oa(),ot("http"),kt(Pt())),ct($e,ot("http"),kt(Pt()))),d0=yt(Ux),Dx=ge(ct($e,ot("tcp"),ge(ct(ot("443"),ot("http")),ct(oa(),ot("https"))),kt(Pt())),ct($e,ot("tls"),ot("http"),kt(Pt())),ct($e,ot("https"),kt(Pt()))),p0=yt(Dx);var Px=[G("tcp").code,G("dns").code,G("dnsaddr").code,G("dns4").code,G("dns6").code];function m0(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 g0(r){return r.some(([t,e])=>t===G("tls").code)}function Zt(r,t,e){let n=y0[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 y0={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://${Zt(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://${Zt(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`${Zt(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`${Zt(e[0],e[1]??"",t)}/p2p/${r}`},http:(r,t)=>{let e=g0(t),n=m0(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=Zt(s[0],s[1]??"",t);return i=i.replace("tcp://",""),`${o}${i}`},"http-path":(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");let n=Zt(e[0],e[1]??"",t),o=decodeURIComponent(r);return`${n}/${o}`},tls:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return Zt(e[0],e[1]??"",t)},sni:(r,t)=>{let e=t.pop();if(e===void 0)throw new Error("Unexpected end of multiaddr");return Zt(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=Zt(e[0],e[1]??"",t);return n=n.replace("tcp://",""),`https://${n}`},ws:(r,t)=>{let e=g0(t),n=m0(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=Zt(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=Zt(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`${Zt(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`${Zt(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`${Zt(e[0],e[1]??"",t)}/p2p-webrtc-direct`}};function w0(r,t){let n=lr(r).stringTuples(),o=n.pop();if(o===void 0)throw new Error("Unexpected end of multiaddr");let s=G(o[0]),i=y0[s.name];if(i==null)throw new Error(`No interpreter found for ${s.name}`);let a=i(o[1]??"",n);return t?.assumeHttp!==!1&&Px.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 ia=class{url;#t=0;#e=0;#r=0;#o=0;#a=new Map;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}`)}#u(t){let e=t.multihash.bytes;return ue.encode(e)}async getRawBlock(t,e){let n=new URL(this.url.toString());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`);let o=this.#u(t),s=new AbortController,i=()=>{s.abort()};e?.addEventListener("abort",i);try{let a=this.#a.get(o);return a==null&&(this.#t++,a=fetch(n.toString(),{signal:s.signal,headers:{Accept:"application/vnd.ipld.raw"},cache:"force-cache"}).then(async c=>{if(this.log("GET %s %d",n,c.status),!c.ok)throw this.#e++,new Error(`unable to fetch raw block for CID ${t} from gateway ${this.url}`);return this.#o++,new Uint8Array(await c.arrayBuffer())}),this.#a.set(o,a)),await a}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}`))}finally{e?.removeEventListener("abort",i),this.#a.delete(o)}}reliability(){return this.#t===0?1:this.#r>0?-1/0:this.#o/(this.#t+this.#e*3)}incrementInvalidBlocks(){this.#r++}getStats(){return{attempts:this.#t,errors:this.#e,invalidBlocks:this.#r,successes:this.#o,pendingResponses:this.#a.size}}};function Ox(r,t,e){return r.filter(n=>p0.matches(n)||t&&d0.matches(n)?e||s0.matches(n)?!0:zp(n.toOptions().host)===!1:!1)}async function*aa(r,t,e,n,o,s){for await(let i of t.findProviders(r,s)){let a=Ox(i.multiaddrs,n,o);if(a.length===0)continue;let c=w0(a[0]);yield new ia(c,e)}}var zu=class extends zo{routing;allowInsecure;allowLocal;constructor(t,e){super(t,{...e,name:"helia:trustless-gateway:session"}),this.routing=t.routing,this.allowInsecure=e.allowInsecure??ca,this.allowLocal=e.allowLocal??ua}async queryProvider(t,e,n){this.log("fetching BLOCK for %c from %s",t,e.url);let o=await e.getRawBlock(t,n.signal);return this.log.trace("got block for %c from %s",t,e.url),await n.validateFn?.(o),o}async*findNewProviders(t,e={}){yield*aa(t,this.routing,this.logger,this.allowInsecure,this.allowLocal,e)}toEvictionKey(t){return t.url.toString()}equals(t,e){return t.url.toString()===e.url.toString()}};function b0(r,t){return new zu(r,t)}var la=class{allowInsecure;allowLocal;routing;log;logger;constructor(t,e={}){this.log=t.logger.forComponent("helia:trustless-gateway-block-broker"),this.logger=t.logger,this.routing=t.routing,this.allowInsecure=e.allowInsecure??ca,this.allowLocal=e.allowLocal??ua}async retrieve(t,e={}){let n=[];for await(let o of aa(t,this.routing,this.logger,this.allowInsecure,this.allowLocal,e)){this.log("getting block for %c from %s",t,o.url);try{let s=await o.getRawBlock(t,e.signal);this.log.trace("got block for %c from %s",t,o.url);try{await e.validateFn?.(s)}catch(i){this.log.error("failed to validate block for %c from %s",t,o.url,i);continue}return s}catch(s){if(this.log.error("failed to get block for %c from %s",t,o.url,s),s instanceof Error?n.push(s):n.push(new Error(`Unable to fetch raw block for CID ${t} from gateway ${o.url}`)),e.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",t,o.url);break}}}throw n.length>0?new AggregateError(n,`Unable to fetch raw block for CID ${t} from any gateway`):new Error(`Unable to fetch raw block for CID ${t} from any gateway`)}createSession(t={}){return b0({logger:this.logger,routing:this.routing},{...t,allowLocal:this.allowLocal,allowInsecure:this.allowInsecure})}};var ca=!1,ua=!1;function ju(r={}){return t=>new la(t,r)}async function*fa(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 $x=Xt(sn(),1);var Hx=Xt(Wu(),1);var x0="ERR_IPNS_EXPIRED_RECORD",ha="ERR_UNRECOGNIZED_VALIDITY";var fr="ERR_SIGNATURE_VERIFICATION";var Yu="ERR_UNDEFINED_PARAMETER",E0="ERR_INVALID_RECORD_DATA",v0="ERR_INVALID_VALUE",A0="ERR_INVALID_EMBEDDED_KEY";var B0="ERR_RECORD_TOO_LARGE";var _e;(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=()=>lo(e)}(t=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=gn((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=>pn(o,r.codec()),r.decode=o=>un(o,r.codec())})(_e||(_e={}));var ce=Xt(sn(),1);var S0=ne("ipns:utils"),I0=q("/ipns/"),Fx=114,R0=async(r,t)=>{if(t==null||r==null){let n=new Error("one or more of the provided parameters are not defined");throw S0.error(n),(0,ce.default)(n,Yu)}let e;if(t.pubKey!=null){try{e=Gc(t.pubKey)}catch(o){throw S0.error(o),o}if(!(await uf(t.pubKey)).equals(r))throw(0,ce.default)(new Error("Embedded public key did not match PeerID"),A0)}else r.publicKey!=null&&(e=Gc(r.publicKey));if(e!=null)return e;throw(0,ce.default)(new Error("no public key is available"),Yu)};var _0=r=>{let t=q("ipns-signature:");return It([t,r])},tn=r=>"signatureV1"in r?_e.encode({value:q(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:q(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):_e.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data});function He(r){let t=_e.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,ce.default)(new Error("missing data or signatureV2"),fr);let e=T0(t.data),n=Vx(e.Value),o=z(e.Validity);if(t.value!=null&&t.signatureV1!=null)return Mx(t),{value:n,validityType:_e.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:_e.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 Zu=r=>It([I0,r.toBytes()]),eo=r=>ho(r.slice(I0.length));var T0=r=>{let t=me(r);if(t.ValidityType===0)t.ValidityType=_e.ValidityType.EOL;else throw(0,ce.default)(new Error("Unknown validity type"),ha);return Number.isInteger(t.Sequence)&&(t.Sequence=BigInt(t.Sequence)),Number.isInteger(t.TTL)&&(t.TTL=BigInt(t.TTL)),t},Vx=r=>{if(r!=null){if(xl(r))return`/ipns/${r.toCID().toString(wr)}`;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=Q.asCID(r);if(e!=null)return e.code===Fx?`/ipns/${e.toString(wr)}`:`/ipfs/${e.toV1().toString()}`;try{return r instanceof Uint8Array?`/ipfs/${Q.decode(r).toV1().toString()}`:`/ipfs/${Q.parse(t).toV1().toString()}`}catch{}}throw(0,ce.default)(new Error("Value must be a valid content path starting with /"),v0)},Mx=r=>{if(r.data==null)throw(0,ce.default)(new Error("Record data is missing"),E0);let t=T0(r.data);if(!it(t.Value,r.value??new Uint8Array(0)))throw(0,ce.default)(new Error('Field "value" did not match between protobuf and CBOR'),fr);if(!it(t.Validity,r.validity??new Uint8Array(0)))throw(0,ce.default)(new Error('Field "validity" did not match between protobuf and CBOR'),fr);if(t.ValidityType!==r.validityType)throw(0,ce.default)(new Error('Field "validityType" did not match between protobuf and CBOR'),fr);if(t.Sequence!==r.sequence)throw(0,ce.default)(new Error('Field "sequence" did not match between protobuf and CBOR'),fr);if(t.TTL!==r.ttl)throw(0,ce.default)(new Error('Field "ttl" did not match between protobuf and CBOR'),fr)};var a3=ne("ipns"),c3=Kt.code,u3=60*60*1e9,Kx="/ipns/",l3=Kx.length;var Yo=Xt(sn(),1),C0=Xt(Wu(),1);var da=ne("ipns:validator"),qx=1024*10,zx=async(r,t)=>{let e=He(t),n;try{let o=_0(e.data);n=await r.verify(o,e.signatureV2)}catch{n=!1}if(!n)throw da.error("record signature verification failed"),(0,Yo.default)(new Error("record signature verification failed"),fr);if(e.validityType===_e.ValidityType.EOL){if(C0.default.fromString(e.validity).toDate().getTime()<Date.now())throw da.error("record has expired"),(0,Yo.default)(new Error("record has expired"),x0)}else if(e.validityType!=null)throw da.error("unrecognized validity type"),(0,Yo.default)(new Error("unrecognized validity type"),ha);da("ipns record for %s is valid",e.value)};async function N0(r,t){if(t.byteLength>qx)throw(0,Yo.default)(new Error("record too large"),B0);let e=eo(r),n=He(t),o=await R0(e,n);await zx(o,t)}async function*Zo(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))}function jx(r){return r[Symbol.asyncIterator]!=null}function Gx(r){if(jx(r))return(async()=>{for await(let t of r)return t})();for(let t of r)return t}var pa=Gx;var Ju=q("/ipns/");function L0(r){return it(r.subarray(0,Ju.byteLength),Ju)}var U0=r=>ho(r.slice(Ju.length)),ma=class{client;constructor(t){this.client=t}async*findProviders(t,e={}){yield*cn(this.client.getProviders(t,e),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async put(t,e,n){if(!L0(t))return;let o=U0(t),s=He(e);await this.client.putIPNS(o,s,n)}async get(t,e){if(!L0(t))throw new D("Not found","ERR_NOT_FOUND");let n=U0(t);try{let o=await this.client.getIPNS(n,e);return tn(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new D("Not found","ERR_NOT_FOUND"):o}}},ga=class{client;constructor(t){this.client=t}async findPeer(t,e={}){let n=await pa(this.client.getPeers(t,e));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new D("Not found","ERR_NOT_FOUND")}async*getClosestPeers(t,e={}){}};var Jt=ne("delegated-routing-v1-http-api-client"),D0={concurrentRequests:4,timeout:3e4},ya=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;constructor(t,e={}){this.started=!1,this.shutDownController=new AbortController,ft(1/0,this.shutDownController.signal),this.httpQueue=new Ve({concurrency:e.concurrentRequests??D0.concurrentRequests}),this.clientUrl=t instanceof URL?t:new URL(t),this.timeout=e.timeout??D0.timeout,this.contentRouting=new ma(this),this.peerRouting=new ga(this)}get[no](){return this.contentRouting}get[oo](){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={}){Jt("getProviders starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=Ht([this.shutDownController.signal,n,e.signal]);ft(1/0,n,o);let s=St(),i=St();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 D("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new D("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new D("Routing response had no body","ERR_BAD_RESPONSE");if(u.headers.get("Content-Type")==="application/json"){let l=await u.json();for(let m of l.Providers){let h=this.#t(m);h!=null&&(yield h)}}else for await(let l of Zo(fa(u.body))){let m=this.#t(l);m!=null&&(yield m)}}catch(a){Jt.error("getProviders errored:",a)}finally{o.clear(),i.resolve(),Jt("getProviders finished: %c",t)}}async*getPeers(t,e={}){Jt("getPeers starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=Ht([this.shutDownController.signal,n,e.signal]);ft(1/0,n,o);let s=St(),i=St();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 D("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new D("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new D("Routing response had no body","ERR_BAD_RESPONSE");if(u.headers.get("Content-Type")==="application/json"){let l=await u.json();for(let m of l.Peers){let h=this.#t(m);h!=null&&(yield h)}}else for await(let l of Zo(fa(u.body))){let m=this.#t(l);m!=null&&(yield m)}}catch(a){Jt.error("getPeers errored:",a)}finally{o.clear(),i.resolve(),Jt("getPeers finished: %c",t)}}async getIPNS(t,e={}){Jt("getIPNS starts: %c",t);let n=AbortSignal.timeout(this.timeout),o=Ht([this.shutDownController.signal,n,e.signal]);ft(1/0,n,o);let s=St(),i=St();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(Jt("getIPNS GET %s %d",a,u.status),u.status===404)throw new D("No matching records found.","ERR_NOT_FOUND");if(u.status===422)throw new D("Request does not conform to schema or semantic constraints.","ERR_INVALID_REQUEST");if(u.body==null)throw new D("GET ipns response had no body","ERR_BAD_RESPONSE");let f=await u.arrayBuffer(),l=new Uint8Array(f,0,f.byteLength);return e.validate!==!1&&await N0(Zu(t),l),He(l)}catch(c){throw Jt.error("getIPNS GET %s error:",a,c),c}finally{o.clear(),i.resolve(),Jt("getIPNS finished: %c",t)}}async putIPNS(t,e,n={}){Jt("putIPNS starts: %c",t);let o=AbortSignal.timeout(this.timeout),s=Ht([this.shutDownController.signal,o,n.signal]);ft(1/0,o,s);let i=St(),a=St();this.httpQueue.add(async()=>(i.resolve(),a.promise));let c=`${this.clientUrl}routing/v1/ipns/${t.toCID().toString()}`;try{await i.promise;let u=tn(e),l=await fetch(c,{method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:u,signal:s});if(Jt("putIPNS PUT %s %d",c,l.status),l.status!==200)throw new D("PUT ipns response had status other than 200","ERR_BAD_RESPONSE")}catch(u){throw Jt.error("putIPNS PUT %s error:",c,u.stack),u}finally{s.clear(),a.resolve(),Jt("putIPNS finished: %c",t)}}#t(t){let e=[],n=t.Addrs?.map(lr)??[];return t.Protocols!=null&&e.push(...t.Protocols),t.Protocol!=null&&(e.push(t.Protocol),delete t.Protocol),{...t,Schema:"peer",ID:gc(t.ID),Addrs:n,Protocols:e}}};function P0(r,t={}){return new ya(new URL(r),t)}var O0=q("/ipns/");function F0(r){return it(r.subarray(0,O0.byteLength),O0)}var Xu=class{client;constructor(t){this.client=P0(t)}async provide(t,e){}async*findProviders(t,e){yield*cn(this.client.getProviders(t,e),n=>({id:n.ID,multiaddrs:n.Addrs,protocols:n.Protocols}))}async put(t,e,n){if(!F0(t))return;let o=eo(t),s=He(e);await this.client.putIPNS(o,s,n)}async get(t,e){if(!F0(t))throw new D("Not found","ERR_NOT_FOUND");let n=eo(t);try{let o=await this.client.getIPNS(n,e);return tn(o)}catch(o){throw o.code==="ERR_BAD_RESPONSE"?new D("Not found","ERR_NOT_FOUND"):o}}async findPeer(t,e){let n=await pa(this.client.getPeers(t,e));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new D("Not found","ERR_NOT_FOUND")}async*getClosestPeers(t,e){}};function Qu(r){return new Xu(new URL(r))}var V0="[a-fA-F\\d:]",Pr=r=>r&&r.includeBoundaries?`(?:(?<=\\s|^)(?=${V0})|(?<=${V0})(?=\\s|$))`:"",Te="(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}",xt="[a-fA-F\\d]{1,4}",wa=`
9
9
  (?:
10
10
  (?:${xt}:){7}(?:${xt}|:)| // 1:2:3:4:5:6:7:: 1:2:3:4:5:6:7:8
11
11
  (?:${xt}:){6}(?:${Te}|:${xt}|:)| // 1:2:3:4:5:6:: 1:2:3:4:5:6::8 1:2:3:4:5:6::8 1:2:3:4:5:6::1.2.3.4
@@ -16,7 +16,7 @@ ${t.join(`
16
16
  (?:${xt}:){1}(?:(?::${xt}){0,4}:${Te}|(?::${xt}){1,6}|:)| // 1:: 1::3:4:5:6:7:8 1::8 1::3:4:5:6:7:1.2.3.4
17
17
  (?::(?:(?::${xt}){0,5}:${Te}|(?::${xt}){1,7}|:)) // ::2:3:4:5:6:7:8 ::2:3:4:5:6:7:8 ::8 ::1.2.3.4
18
18
  )(?:%[0-9a-zA-Z]{1,})? // %eth0 %1
19
- `.replace(/\s*\/\/.*$/gm,"").replace(/\n/g,"").trim(),jx=new RegExp(`(?:^${Te}$)|(?:^${wa}$)`),Gx=new RegExp(`^${Te}$`),Wx=new RegExp(`^${wa}$`),Xu=r=>r&&r.exact?jx:new RegExp(`(?:${Pr(r)}${Te}${Pr(r)})|(?:${Pr(r)}${wa}${Pr(r)})`,"g");Xu.v4=r=>r&&r.exact?Gx:new RegExp(`${Pr(r)}${Te}${Pr(r)}`,"g");Xu.v6=r=>r&&r.exact?Wx:new RegExp(`${Pr(r)}${wa}${Pr(r)}`,"g");var Qu=Xu;function tl(r){let t=(...e)=>r(...e);return Object.defineProperty(t,"name",{value:`functionTimeout(${r.name||"<anonymous>"})`,configurable:!0}),t}function O0(){return!1}var{toString:Yx}=Object.prototype;function el(r){return Yx.call(r)==="[object RegExp]"}var F0={global:"g",ignoreCase:"i",multiline:"m",dotAll:"s",sticky:"y",unicode:"u"};function rl(r,t={}){if(!el(r))throw new TypeError("Expected a RegExp instance");let e=Object.keys(F0).map(o=>(typeof t[o]=="boolean"?t[o]:r[o])?F0[o]:"").join(""),n=new RegExp(t.source||r.source,e);return n.lastIndex=typeof t.lastIndex=="number"?t.lastIndex:r.lastIndex,n}function nl(r,t,{timeout:e}={}){try{return tl(()=>rl(r).test(t),{timeout:e})()}catch(n){if(O0(n))return!1;throw n}}var Zx=15,Jx=45,V0={timeout:400};function ol(r){return r.length>Jx?!1:nl(Qu.v6({exact:!0}),r,V0)}function M0(r){return r.length>Zx?!1:nl(Qu.v4({exact:!0}),r,V0)}var $0={http:"80",https:"443",ws:"80",wss:"443"},Xx=["http","https","ws","wss"];function H0(r,t){t=t??{};let e=t.defaultDnsType??"dns4",{scheme:n,hostname:o,port:s}=Qx(r),a="/"+[t1(o,e),e1(s,n),r1(n)].filter(c=>!!c).reduce((c,u)=>c.concat(u),[]).join("/");return lr(a)}function Qx(r){let[t]=r.split(":");Xx.includes(t)||(r="http"+r.substring(t.length));let{protocol:e,hostname:n,port:o}=new URL(r);if(o==null||o===""){let s=n1(t);s!=null&&(o=s),s==null&&e==="http:"&&(o="80")}return{scheme:t,hostname:n,port:o}}function t1(r,t){if(!(r==null||r==="")){if(M0(r))return["ip4",r];if(ol(r))return["ip6",r];if(r[0]==="["){let e=r.substring(1,r.length-1);if(ol(e))return["ip6",e]}return[t,r]}}function e1(r,t){if(!(r==null||r===""))return t==="udp"?["udp",r]:["tcp",r]}function r1(r){if(r.match(/^tcp$|^udp$/)==null)return[r]}function n1(r){if(!(r==null||r===""||$0[r]==null))return $0[r]}var o1=["https://trustless-gateway.link","https://4everland.io"],s1=2336,i1=Symbol.for("nodejs.util.inspect.custom"),sl=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Wt.digest(q(this.url))}[i1](){return`PeerId(${this.url})`}[no]=!0;toString(){return this.toCID().toString()}toCID(){return tt.createV1(s1,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=j(t)),t.toString()===this.toString())}};function a1(r){return r=r.toString(),{id:new sl(new URL(r)),multiaddrs:[H0(r)]}}var il=class{gateways;constructor(t={}){this.gateways=(t.gateways??o1).map(e=>a1(e))}async*findProviders(t,e){yield*this.gateways.toSorted(()=>Math.random()>.5?1:-1).map(n=>({...n,protocols:["transport-ipfs-gateway-http"]}))}};function al(r={}){return new il(r)}var K0=Xt(on(),1);function ba(r){return r=r??new Error("Not Found"),(0,K0.default)(r,"ERR_NOT_FOUND")}var q0="SHARDING";function u1(r){return r[Symbol.asyncIterator]!=null}function l1(r){if(u1(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 cl=l1;function f1(r){return r[Symbol.asyncIterator]!=null}function h1(r,t){return f1(r)?async function*(){yield*(await cl(r)).sort(t)}():function*(){yield*cl(r).sort(t)}()}var xa=h1;var hr=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 Vr(this.putMany(t,n)),t=[],await Vr(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=Re(n,s=>s.key.toString().startsWith(o))}if(Array.isArray(t.filters)&&(n=t.filters.reduce((o,s)=>Re(o,s),n)),Array.isArray(t.orders)&&(n=t.orders.reduce((o,s)=>xa(o,s),n)),t.offset!=null){let o=0,s=t.offset;n=Re(n,()=>o++>=s)}return t.limit!=null&&(n=cs(n,t.limit)),n}queryKeys(t,e){let n=this._allKeys(t,e);if(t.prefix!=null){let o=t.prefix;n=Re(n,s=>s.toString().startsWith(o))}if(Array.isArray(t.filters)&&(n=t.filters.reduce((o,s)=>Re(o,s),n)),Array.isArray(t.orders)&&(n=t.orders.reduce((o,s)=>xa(o,s),n)),t.offset!=null){let o=t.offset,s=0;n=Re(n,()=>s++>=o)}return t.limit!=null&&(n=cs(n,t.limit)),n}};var Xo=class extends hr{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 ba();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 Dt(t),value:e}}*_allKeys(){for(let t of this.data.keys())yield new Dt(t)}};var ZR=new Dt(q0);var c_=ne("datastore:core:tiered");async function m1(r={}){let t=r.datastore??new Xo,e=r.blockstore??new qo,n=new Zi({...r,datastore:t,blockstore:e,blockBrokers:r.blockBrokers??[qu()],routers:r.routers??[Ju("https://delegated-ipfs.dev"),al()]});return r.start!==!1&&await n.start(),n}return sm(g1);})();
19
+ `.replace(/\s*\/\/.*$/gm,"").replace(/\n/g,"").trim(),Wx=new RegExp(`(?:^${Te}$)|(?:^${wa}$)`),Yx=new RegExp(`^${Te}$`),Zx=new RegExp(`^${wa}$`),tl=r=>r&&r.exact?Wx:new RegExp(`(?:${Pr(r)}${Te}${Pr(r)})|(?:${Pr(r)}${wa}${Pr(r)})`,"g");tl.v4=r=>r&&r.exact?Yx:new RegExp(`${Pr(r)}${Te}${Pr(r)}`,"g");tl.v6=r=>r&&r.exact?Zx:new RegExp(`${Pr(r)}${wa}${Pr(r)}`,"g");var el=tl;function rl(r){let t=(...e)=>r(...e);return Object.defineProperty(t,"name",{value:`functionTimeout(${r.name||"<anonymous>"})`,configurable:!0}),t}function M0(){return!1}var{toString:Jx}=Object.prototype;function nl(r){return Jx.call(r)==="[object RegExp]"}var $0={global:"g",ignoreCase:"i",multiline:"m",dotAll:"s",sticky:"y",unicode:"u"};function ol(r,t={}){if(!nl(r))throw new TypeError("Expected a RegExp instance");let e=Object.keys($0).map(o=>(typeof t[o]=="boolean"?t[o]:r[o])?$0[o]:"").join(""),n=new RegExp(t.source||r.source,e);return n.lastIndex=typeof t.lastIndex=="number"?t.lastIndex:r.lastIndex,n}function sl(r,t,{timeout:e}={}){try{return rl(()=>ol(r).test(t),{timeout:e})()}catch(n){if(M0(n))return!1;throw n}}var Xx=15,Qx=45,H0={timeout:400};function il(r){return r.length>Qx?!1:sl(el.v6({exact:!0}),r,H0)}function K0(r){return r.length>Xx?!1:sl(el.v4({exact:!0}),r,H0)}var q0={http:"80",https:"443",ws:"80",wss:"443"},t1=["http","https","ws","wss"];function z0(r,t){t=t??{};let e=t.defaultDnsType??"dns4",{scheme:n,hostname:o,port:s}=e1(r),a="/"+[r1(o,e),n1(s,n),o1(n)].filter(c=>!!c).reduce((c,u)=>c.concat(u),[]).join("/");return lr(a)}function e1(r){let[t]=r.split(":");t1.includes(t)||(r="http"+r.substring(t.length));let{protocol:e,hostname:n,port:o}=new URL(r);if(o==null||o===""){let s=s1(t);s!=null&&(o=s),s==null&&e==="http:"&&(o="80")}return{scheme:t,hostname:n,port:o}}function r1(r,t){if(!(r==null||r==="")){if(K0(r))return["ip4",r];if(il(r))return["ip6",r];if(r[0]==="["){let e=r.substring(1,r.length-1);if(il(e))return["ip6",e]}return[t,r]}}function n1(r,t){if(!(r==null||r===""))return t==="udp"?["udp",r]:["tcp",r]}function o1(r){if(r.match(/^tcp$|^udp$/)==null)return[r]}function s1(r){if(!(r==null||r===""||q0[r]==null))return q0[r]}var i1=["https://trustless-gateway.link","https://4everland.io"],a1=2336,c1=Symbol.for("nodejs.util.inspect.custom"),al=class{type="url";multihash;privateKey;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Kt.digest(q(this.url))}[c1](){return`PeerId(${this.url})`}[en]=!0;toString(){return this.toCID().toString()}toCID(){return Q.createV1(a1,this.multihash)}toBytes(){return this.toCID().bytes}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=z(t)),t.toString()===this.toString())}};function u1(r){return r=r.toString(),{id:new al(new URL(r)),multiaddrs:[z0(r)]}}var cl=class{gateways;constructor(t={}){this.gateways=(t.gateways??i1).map(e=>u1(e))}async*findProviders(t,e){yield*this.gateways.toSorted(()=>Math.random()>.5?1:-1).map(n=>({...n,protocols:["transport-ipfs-gateway-http"]}))}};function ul(r={}){return new cl(r)}var j0=Xt(sn(),1);function ba(r){return r=r??new Error("Not Found"),(0,j0.default)(r,"ERR_NOT_FOUND")}var G0="SHARDING";function f1(r){return r[Symbol.asyncIterator]!=null}function h1(r){if(f1(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 ll=h1;function d1(r){return r[Symbol.asyncIterator]!=null}function p1(r,t){return d1(r)?async function*(){yield*(await ll(r)).sort(t)}():function*(){yield*ll(r).sort(t)}()}var xa=p1;var hr=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 Vr(this.putMany(t,n)),t=[],await Vr(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=Re(n,s=>s.key.toString().startsWith(o))}if(Array.isArray(t.filters)&&(n=t.filters.reduce((o,s)=>Re(o,s),n)),Array.isArray(t.orders)&&(n=t.orders.reduce((o,s)=>xa(o,s),n)),t.offset!=null){let o=0,s=t.offset;n=Re(n,()=>o++>=s)}return t.limit!=null&&(n=cs(n,t.limit)),n}queryKeys(t,e){let n=this._allKeys(t,e);if(t.prefix!=null){let o=t.prefix;n=Re(n,s=>s.toString().startsWith(o))}if(Array.isArray(t.filters)&&(n=t.filters.reduce((o,s)=>Re(o,s),n)),Array.isArray(t.orders)&&(n=t.orders.reduce((o,s)=>xa(o,s),n)),t.offset!=null){let o=t.offset,s=0;n=Re(n,()=>s++>=o)}return t.limit!=null&&(n=cs(n,t.limit)),n}};var Xo=class extends hr{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 ba();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 Dt(t),value:e}}*_allKeys(){for(let t of this.data.keys())yield new Dt(t)}};var t_=new Dt(G0);var h_=ne("datastore:core:tiered");async function y1(r={}){let t=r.datastore??new Xo,e=r.blockstore??new qo,n=new Zi({...r,datastore:t,blockstore:e,blockBrokers:r.blockBrokers??[ju()],routers:r.routers??[Qu("https://delegated-ipfs.dev"),ul()]});return r.start!==!1&&await n.start(),n}return cm(w1);})();
20
20
  /*! Bundled license information:
21
21
 
22
22
  pvtsutils/build/index.js: