@helia/http 3.0.5 → 3.0.6

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,7 +1,7 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.HeliaHttp = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
2
  "use strict";var HeliaHttp=(()=>{var bE=Object.create;var xa=Object.defineProperty;var xE=Object.getOwnPropertyDescriptor;var vE=Object.getOwnPropertyNames;var EE=Object.getPrototypeOf,AE=Object.prototype.hasOwnProperty;var yr=(r,e)=>()=>(e||r((e={exports:{}}).exports,e),e.exports),Ae=(r,e)=>{for(var t in e)xa(r,t,{get:e[t],enumerable:!0})},cg=(r,e,t,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of vE(e))!AE.call(r,o)&&o!==t&&xa(r,o,{get:()=>e[o],enumerable:!(n=xE(e,o))||n.enumerable});return r};var wn=(r,e,t)=>(t=r!=null?bE(EE(r)):{},cg(e||!r||!r.__esModule?xa(t,"default",{value:r,enumerable:!0}):t,r)),SE=r=>cg(xa({},"__esModule",{value:!0}),r);var D0=yr(di=>{(function(){var r,e,t,n,o,s,i,a;a=function(c){var l,f,u,d;return l=(c&255<<24)>>>24,f=(c&255<<16)>>>16,u=(c&65280)>>>8,d=c&255,[l,f,u,d].join(".")},i=function(c){var l,f,u,d,h,m;for(l=[],u=d=0;d<=3&&c.length!==0;u=++d){if(u>0){if(c[0]!==".")throw new Error("Invalid IP");c=c.substring(1)}m=e(c),h=m[0],f=m[1],c=c.substring(f),l.push(h)}if(c.length!==0)throw new Error("Invalid IP");switch(l.length){case 1:if(l[0]>4294967295)throw new Error("Invalid IP");return l[0]>>>0;case 2:if(l[0]>255||l[1]>16777215)throw new Error("Invalid IP");return(l[0]<<24|l[1])>>>0;case 3:if(l[0]>255||l[1]>255||l[2]>65535)throw new Error("Invalid IP");return(l[0]<<24|l[1]<<16|l[2])>>>0;case 4:if(l[0]>255||l[1]>255||l[2]>255||l[3]>255)throw new Error("Invalid IP");return(l[0]<<24|l[1]<<16|l[2]<<8|l[3])>>>0;default:throw new Error("Invalid IP")}},t=function(c){return c.charCodeAt(0)},n=t("0"),s=t("a"),o=t("A"),e=function(c){var l,f,u,d,h;for(d=0,l=10,f="9",u=0,c.length>1&&c[u]==="0"&&(c[u+1]==="x"||c[u+1]==="X"?(u+=2,l=16):"0"<=c[u+1]&&c[u+1]<="9"&&(u++,l=8,f="7")),h=u;u<c.length;){if("0"<=c[u]&&c[u]<=f)d=d*l+(t(c[u])-n)>>>0;else if(l===16)if("a"<=c[u]&&c[u]<="f")d=d*l+(10+t(c[u])-s)>>>0;else if("A"<=c[u]&&c[u]<="F")d=d*l+(10+t(c[u])-o)>>>0;else break;else break;if(d>4294967295)throw new Error("too large");u++}if(u===h)throw new Error("empty octet");return[d,u]},r=(function(){function c(l,f){var u,d,h,m;if(typeof l!="string")throw new Error("Missing `net' parameter");if(f||(m=l.split("/",2),l=m[0],f=m[1]),f||(f=32),typeof f=="string"&&f.indexOf(".")>-1){try{this.maskLong=i(f)}catch(g){throw u=g,new Error("Invalid mask: "+f)}for(d=h=32;h>=0;d=--h)if(this.maskLong===4294967295<<32-d>>>0){this.bitmask=d;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(l)&this.maskLong)>>>0}catch(g){throw u=g,new Error("Invalid net address: "+l)}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(l){return typeof l=="string"&&(l.indexOf("/")>0||l.split(".").length!==4)&&(l=new c(l)),l instanceof c?this.contains(l.base)&&this.contains(l.broadcast||l.last):(i(l)&this.maskLong)>>>0===(this.netLong&this.maskLong)>>>0},c.prototype.next=function(l){return l==null&&(l=1),new c(a(this.netLong+this.size*l),this.mask)},c.prototype.forEach=function(l){var f,u,d;for(d=i(this.first),u=i(this.last),f=0;d<=u;)l(a(d),d,f),f++,d++},c.prototype.toString=function(){return this.base+"/"+this.bitmask},c})(),di.ip2long=i,di.long2ip=a,di.Netmask=r}).call(di)});var lb=yr(($3,xp)=>{"use strict";var iI=Object.prototype.hasOwnProperty,ot="~";function Pi(){}Object.create&&(Pi.prototype=Object.create(null),new Pi().__proto__||(ot=!1));function aI(r,e,t){this.fn=r,this.context=e,this.once=t||!1}function cb(r,e,t,n,o){if(typeof t!="function")throw new TypeError("The listener must be a function");var s=new aI(t,n||r,o),i=ot?ot+e:e;return r._events[i]?r._events[i].fn?r._events[i]=[r._events[i],s]:r._events[i].push(s):(r._events[i]=s,r._eventsCount++),r}function jc(r,e){--r._eventsCount===0?r._events=new Pi:delete r._events[e]}function Qe(){this._events=new Pi,this._eventsCount=0}Qe.prototype.eventNames=function(){var e=[],t,n;if(this._eventsCount===0)return e;for(n in t=this._events)iI.call(t,n)&&e.push(ot?n.slice(1):n);return Object.getOwnPropertySymbols?e.concat(Object.getOwnPropertySymbols(t)):e};Qe.prototype.listeners=function(e){var t=ot?ot+e:e,n=this._events[t];if(!n)return[];if(n.fn)return[n.fn];for(var o=0,s=n.length,i=new Array(s);o<s;o++)i[o]=n[o].fn;return i};Qe.prototype.listenerCount=function(e){var t=ot?ot+e:e,n=this._events[t];return n?n.fn?1:n.length:0};Qe.prototype.emit=function(e,t,n,o,s,i){var a=ot?ot+e:e;if(!this._events[a])return!1;var c=this._events[a],l=arguments.length,f,u;if(c.fn){switch(c.once&&this.removeListener(e,c.fn,void 0,!0),l){case 1:return c.fn.call(c.context),!0;case 2:return c.fn.call(c.context,t),!0;case 3:return c.fn.call(c.context,t,n),!0;case 4:return c.fn.call(c.context,t,n,o),!0;case 5:return c.fn.call(c.context,t,n,o,s),!0;case 6:return c.fn.call(c.context,t,n,o,s,i),!0}for(u=1,f=new Array(l-1);u<l;u++)f[u-1]=arguments[u];c.fn.apply(c.context,f)}else{var d=c.length,h;for(u=0;u<d;u++)switch(c[u].once&&this.removeListener(e,c[u].fn,void 0,!0),l){case 1:c[u].fn.call(c[u].context);break;case 2:c[u].fn.call(c[u].context,t);break;case 3:c[u].fn.call(c[u].context,t,n);break;case 4:c[u].fn.call(c[u].context,t,n,o);break;default:if(!f)for(h=1,f=new Array(l-1);h<l;h++)f[h-1]=arguments[h];c[u].fn.apply(c[u].context,f)}}return!0};Qe.prototype.on=function(e,t,n){return cb(this,e,t,n,!1)};Qe.prototype.once=function(e,t,n){return cb(this,e,t,n,!0)};Qe.prototype.removeListener=function(e,t,n,o){var s=ot?ot+e:e;if(!this._events[s])return this;if(!t)return jc(this,s),this;var i=this._events[s];if(i.fn)i.fn===t&&(!o||i.once)&&(!n||i.context===n)&&jc(this,s);else{for(var a=0,c=[],l=i.length;a<l;a++)(i[a].fn!==t||o&&!i[a].once||n&&i[a].context!==n)&&c.push(i[a]);c.length?this._events[s]=c.length===1?c[0]:c:jc(this,s)}return this};Qe.prototype.removeAllListeners=function(e){var t;return e?(t=ot?ot+e:e,this._events[t]&&jc(this,t)):(this._events=new Pi,this._eventsCount=0),this};Qe.prototype.off=Qe.prototype.removeListener;Qe.prototype.addListener=Qe.prototype.on;Qe.prefixed=ot;Qe.EventEmitter=Qe;typeof xp<"u"&&(xp.exports=Qe)});var hb=yr((lR,db)=>{db.exports=function(r){if(!r)throw Error("hashlru must have a max value, of type number, greater than 0");var e=0,t=Object.create(null),n=Object.create(null);function o(s,i){t[s]=i,e++,e>=r&&(e=0,n=t,t=Object.create(null))}return{has:function(s){return t[s]!==void 0||n[s]!==void 0},remove:function(s){t[s]!==void 0&&(t[s]=void 0),n[s]!==void 0&&(n[s]=void 0)},get:function(s){var i=t[s];if(i!==void 0)return i;if((i=n[s])!==void 0)return o(s,i),i},set:function(s,i){t[s]!==void 0?t[s]=i:o(s,i)},clear:function(){t=Object.create(null),n=Object.create(null)}}}});var ym=yr((JO,gm)=>{var XO=(function(){typeof gm<"u"&&(gm.exports=g);var r=86400,e=3200,t=146097*e/400,n=r*t,o=1e3*n,s=864e13,i=4294967296,a=1e6,c="000000000",l=Math.trunc||function(b){var v=b-b%1;return v==0&&(b<0||b===0&&1/b!=1/0)?-0:v},f=g.prototype,u=(g.fromDate=function(b){return new g(+b)},g.fromInt64BE=D(0,1,2,3,0,4),g.fromInt64LE=D(3,2,1,0,4,0),g.fromString=function(N){var v,P=new g,N=(N+="").replace(/^\s*[+\-]?\d+/,function(E){var E=+E,A=1970+(E-1970)%400;return P.year=E-A,A}).replace(/(?:Z|([+\-]\d{2}):?(\d{2}))$/,function(C,E,A){return E<0&&(A*=-1),v=6e4*(60*+E+ +A),""}).replace(/\.\d+$/,function(C){return P.nano=+(C+c).substr(1,9),""}).split(/\D+/);if(1<N.length?N[1]--:N[1]=0,P.time=v=Date.UTC.apply(Date,N)-(v||0),isNaN(v))throw new TypeError("Invalid Date");return y(P)},g.fromTimeT=function(b){return T(b,0)},f.year=0,f.time=0,f.nano=0,f.addNano=function(b){return this.nano+=+b||0,this},f.getNano=function(){var b=y(this);return(b.time%1e3*a+ +b.nano+1e9)%1e9},f.getTimeT=function(){var v=y(this),b=Math.floor(v.time/1e3),v=v.year;return v&&(b+=v*t*r/e),b},f.getYear=function(){return this.toDate().getUTCFullYear()+this.year},f.toDate=function(){return x(y(this).time)},f.toJSON=function(){return this.toString().replace(/0{1,6}Z$/,"Z")},f.toString=function(b){var v=this,P=v.toDate(),N={H:function(){return G(P.getUTCHours())},L:function(){return j(P.getUTCMilliseconds(),3)},M:function(){return G(P.getUTCMinutes())},N:function(){return j(v.getNano(),9)},S:function(){return G(P.getUTCSeconds())},Y:function(){var C=v.getYear();return 999999<C?"+"+C:9999<C?"+"+j(C,6):0<=C?j(C,4):-999999<=C?"-"+j(-C,6):C},a:function(){return h[P.getUTCDay()]},b:function(){return d[P.getUTCMonth()]},d:function(){return G(P.getUTCDate())},e:function(){return(function(C){return(9<C?"":" ")+(0|C)})(P.getUTCDate())},m:function(){return G(P.getUTCMonth()+1)}};return(function C(E){return E.replace(/%./g,function(A){var _=A[1],w=m[_],_=N[_];return w?C(w):_?_():A})})(b||u)},f.writeInt64BE=S(0,1,2,3,0,4),f.writeInt64LE=S(3,2,1,0,4,0),"%Y-%m-%dT%H:%M:%S.%NZ"),d=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],h=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],m={"%":"%",F:"%Y-%m-%d",n:`
3
3
  `,R:"%H:%M",T:"%H:%M:%S",t:" ",X:"%T",Z:"GMT",z:"+0000"};return g;function g(b,v,P){var N=this;if(!(N instanceof g))return new g(b,v,P);N.time=+b||0,N.nano=+v||0,N.year=+P||0,y(N)}function y(b){var v,P,N,C=b.year,E=b.time,A=b.nano,w=((A<0||a<=A)&&(A-=(P=Math.floor(A/a))*a,E+=P,P=1),C%e);return(E<-s||s<E||w)&&((v=l(E/o))&&(C+=v*e,E-=v*o),(N=x(E)).setUTCFullYear(w+N.getUTCFullYear()),N=(E=+N)+(v=l((C-=w)/e))*o,v&&-s<=N&&N<=s&&(C-=v*e,E=N),P=1),P&&(b.year=C,b.time=E,b.nano=A),b}function x(b){var v=new Date(0);return v.setTime(b),v}function T(C,N){C=+C||0;var P=l((N=(N|0)*i)/n)+l(C/n),N=N%n+C%n,C=l(N/n);return C&&(P+=C,N-=C*n),new g(1e3*N,0,P*e)}function S(b,v,P,N,C,E){return function(w,_){var M=y(this);w=w||new Array(8),H(w,_|=0);var $=Math.floor(M.time/1e3),M=M.year*(t*r/e),R=l(M/i)+l($/i),M=M%i+$%i,$=Math.floor(M/i);return $&&(R+=$,M-=$*i),A(w,_+C,R),A(w,_+E,M),w};function A(w,_,R){w[_+b]=R>>24&255,w[_+v]=R>>16&255,w[_+P]=R>>8&255,w[_+N]=255&R}}function D(b,v,P,N,C,E){return function(w,_){H(w,_|=0);var R=A(w,_+C);return T(A(w,_+E),R)};function A(w,_){return 16777216*w[_+b]+(w[_+v]<<16|w[_+P]<<8|w[_+N])}}function H(b,v){if(b=b&&b.length,b==null)throw new TypeError("Invalid Buffer");if(b<v+8)throw new RangeError("Out of range")}function G(b){return(9<b?"":"0")+(0|b)}function j(b,v){return(c+(0|b)).substr(-v)}})()});var wv=yr((lq,yv)=>{"use strict";function $_(r){return r>=55296&&r<=56319}function V_(r){return r>=56320&&r<=57343}yv.exports=function(e,t,n){if(typeof t!="string")throw new Error("Input must be string");for(var o=t.length,s=0,i,a,c=0;c<o;c+=1){if(i=t.charCodeAt(c),a=t[c],$_(i)&&V_(t.charCodeAt(c+1))&&(c+=1,a+=t[c]),s+=e(a),s===n)return t.slice(0,c+1);if(s>n)return t.slice(0,c-a.length+1)}return t}});var xv=yr((uq,bv)=>{"use strict";function K_(r){return r>=55296&&r<=56319}function H_(r){return r>=56320&&r<=57343}bv.exports=function(e){if(typeof e!="string")throw new Error("Input must be string");for(var t=e.length,n=0,o=null,s=null,i=0;i<t;i++)o=e.charCodeAt(i),H_(o)?s!=null&&K_(s)?n+=1:n+=3:o<=127?n+=1:o>=128&&o<=2047?n+=2:o>=2048&&o<=65535&&(n+=3),s=o;return n}});var Ev=yr((fq,vv)=>{"use strict";var q_=wv(),z_=xv();vv.exports=q_.bind(null,z_)});var Iv=yr((dq,Sv)=>{"use strict";var G_=Ev(),W_=/[\/\?<>\\:\*\|"]/g,j_=/[\x00-\x1f\x80-\x9f]/g,Y_=/^\.+$/,Z_=/^(con|prn|aux|nul|com[0-9]|lpt[0-9])(\..*)?$/i,X_=/[\. ]+$/;function Av(r,e){if(typeof r!="string")throw new Error("Input must be string");var t=r.replace(W_,e).replace(j_,e).replace(Y_,e).replace(Z_,e).replace(X_,e);return G_(t,255)}Sv.exports=function(r,e){var t=e&&e.replacement||"",n=Av(r,t);return t===""?n:Av(n,"")}});var kv=yr(vs=>{"use strict";var Q_="[object ArrayBuffer]",Nr=class r{static isArrayBuffer(e){return Object.prototype.toString.call(e)===Q_}static toArrayBuffer(e){return this.isArrayBuffer(e)?e:e.byteLength===e.buffer.byteLength||e.byteOffset===0&&e.byteLength===e.buffer.byteLength?e.buffer:this.toUint8Array(e.buffer).slice(e.byteOffset,e.byteOffset+e.byteLength).buffer}static toUint8Array(e){return this.toView(e,Uint8Array)}static toView(e,t){if(e.constructor===t)return e;if(this.isArrayBuffer(e))return new t(e);if(this.isArrayBufferView(e))return new t(e.buffer,e.byteOffset,e.byteLength);throw new TypeError("The provided value is not of type '(ArrayBuffer or ArrayBufferView)'")}static isBufferSource(e){return this.isArrayBufferView(e)||this.isArrayBuffer(e)}static isArrayBufferView(e){return ArrayBuffer.isView(e)||e&&this.isArrayBuffer(e.buffer)}static isEqual(e,t){let n=r.toUint8Array(e),o=r.toUint8Array(t);if(n.length!==o.byteLength)return!1;for(let s=0;s<n.length;s++)if(n[s]!==o[s])return!1;return!0}static concat(...e){let t;Array.isArray(e[0])&&!(e[1]instanceof Function)||Array.isArray(e[0])&&e[1]instanceof Function?t=e[0]:e[e.length-1]instanceof Function?t=e.slice(0,e.length-1):t=e;let n=0;for(let i of t)n+=i.byteLength;let o=new Uint8Array(n),s=0;for(let i of t){let a=this.toUint8Array(i);o.set(a,s),s+=a.length}return e[e.length-1]instanceof Function?this.toView(o,e[e.length-1]):o.buffer}},Xm="string",eC=/^[0-9a-f\s]+$/i,tC=/^(?:[A-Za-z0-9+/]{4})*(?:[A-Za-z0-9+/]{2}==|[A-Za-z0-9+/]{3}=)?$/,rC=/^[a-zA-Z0-9-_]+$/,Gu=class{static fromString(e){let t=unescape(encodeURIComponent(e)),n=new Uint8Array(t.length);for(let o=0;o<t.length;o++)n[o]=t.charCodeAt(o);return n.buffer}static toString(e){let t=Nr.toUint8Array(e),n="";for(let s=0;s<t.length;s++)n+=String.fromCharCode(t[s]);return decodeURIComponent(escape(n))}},Dt=class{static toString(e,t=!1){let n=Nr.toArrayBuffer(e),o=new DataView(n),s="";for(let i=0;i<n.byteLength;i+=2){let a=o.getUint16(i,t);s+=String.fromCharCode(a)}return s}static fromString(e,t=!1){let n=new ArrayBuffer(e.length*2),o=new DataView(n);for(let s=0;s<e.length;s++)o.setUint16(s*2,e.charCodeAt(s),t);return n}},Wu=class r{static isHex(e){return typeof e===Xm&&eC.test(e)}static isBase64(e){return typeof e===Xm&&tC.test(e)}static isBase64Url(e){return typeof e===Xm&&rC.test(e)}static ToString(e,t="utf8"){let n=Nr.toUint8Array(e);switch(t.toLowerCase()){case"utf8":return this.ToUtf8String(n);case"binary":return this.ToBinary(n);case"hex":return this.ToHex(n);case"base64":return this.ToBase64(n);case"base64url":return this.ToBase64Url(n);case"utf16le":return Dt.toString(n,!0);case"utf16":case"utf16be":return Dt.toString(n);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromString(e,t="utf8"){if(!e)return new ArrayBuffer(0);switch(t.toLowerCase()){case"utf8":return this.FromUtf8String(e);case"binary":return this.FromBinary(e);case"hex":return this.FromHex(e);case"base64":return this.FromBase64(e);case"base64url":return this.FromBase64Url(e);case"utf16le":return Dt.fromString(e,!0);case"utf16":case"utf16be":return Dt.fromString(e);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToBase64(e){let t=Nr.toUint8Array(e);if(typeof btoa<"u"){let n=this.ToString(t,"binary");return btoa(n)}else return Buffer.from(t).toString("base64")}static FromBase64(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64(t))throw new TypeError("Argument 'base64Text' is not Base64 encoded");return typeof atob<"u"?this.FromBinary(atob(t)):new Uint8Array(Buffer.from(t,"base64")).buffer}static FromBase64Url(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isBase64Url(t))throw new TypeError("Argument 'base64url' is not Base64Url encoded");return this.FromBase64(this.Base64Padding(t.replace(/\-/g,"+").replace(/\_/g,"/")))}static ToBase64Url(e){return this.ToBase64(e).replace(/\+/g,"-").replace(/\//g,"_").replace(/\=/g,"")}static FromUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.FromBinary(e);case"utf8":return Gu.fromString(e);case"utf16":case"utf16be":return Dt.fromString(e);case"utf16le":case"usc2":return Dt.fromString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static ToUtf8String(e,t=r.DEFAULT_UTF8_ENCODING){switch(t){case"ascii":return this.ToBinary(e);case"utf8":return Gu.toString(e);case"utf16":case"utf16be":return Dt.toString(e);case"utf16le":case"usc2":return Dt.toString(e,!0);default:throw new Error(`Unknown type of encoding '${t}'`)}}static FromBinary(e){let t=e.length,n=new Uint8Array(t);for(let o=0;o<t;o++)n[o]=e.charCodeAt(o);return n.buffer}static ToBinary(e){let t=Nr.toUint8Array(e),n="";for(let o=0;o<t.length;o++)n+=String.fromCharCode(t[o]);return n}static ToHex(e){let t=Nr.toUint8Array(e),n="",o=t.length;for(let s=0;s<o;s++){let i=t[s];i<16&&(n+="0"),n+=i.toString(16)}return n}static FromHex(e){let t=this.formatString(e);if(!t)return new ArrayBuffer(0);if(!r.isHex(t))throw new TypeError("Argument 'hexString' is not HEX encoded");t.length%2&&(t=`0${t}`);let n=new Uint8Array(t.length/2);for(let o=0;o<t.length;o=o+2){let s=t.slice(o,o+2);n[o/2]=parseInt(s,16)}return n.buffer}static ToUtf16String(e,t=!1){return Dt.toString(e,t)}static FromUtf16String(e,t=!1){return Dt.fromString(e,t)}static Base64Padding(e){let t=4-e.length%4;if(t<4)for(let n=0;n<t;n++)e+="=";return e}static formatString(e){return e?.replace(/[\n\r\t ]/g,"")||""}};Wu.DEFAULT_UTF8_ENCODING="utf8";function nC(r,...e){let t=arguments[0];for(let n=1;n<arguments.length;n++){let o=arguments[n];for(let s in o)t[s]=o[s]}return t}function oC(...r){let e=r.map(o=>o.byteLength).reduce((o,s)=>o+s),t=new Uint8Array(e),n=0;return r.map(o=>new Uint8Array(o)).forEach(o=>{for(let s of o)t[n++]=s}),t.buffer}function sC(r,e){if(!(r&&e)||r.byteLength!==e.byteLength)return!1;let t=new Uint8Array(r),n=new Uint8Array(e);for(let o=0;o<r.byteLength;o++)if(t[o]!==n[o])return!1;return!0}vs.BufferSourceConverter=Nr;vs.Convert=Wu;vs.assign=nC;vs.combine=oC;vs.isEqual=sC});var EC={};Ae(EC,{DEFAULT_SESSION_MAX_PROVIDERS:()=>Dp,DEFAULT_SESSION_MIN_PROVIDERS:()=>Pp,InsufficientProvidersError:()=>Ri,InvalidCodecError:()=>Np,NoRoutersAvailableError:()=>dn,UnknownCodecError:()=>Oi,UnknownHashAlgorithmError:()=>Mi,createHeliaHTTP:()=>vC,heliaDefaults:()=>wE});var lg=Symbol.for("@libp2p/connection");var Vr=Symbol.for("@libp2p/content-routing");var ht=class extends Error{static name="AbortError";constructor(e="The operation was aborted"){super(e),this.name="AbortError"}};var k=class extends Error{static name="InvalidParametersError";constructor(e="Invalid parameters"){super(e),this.name="InvalidParametersError"}},ho=class extends Error{static name="InvalidPublicKeyError";constructor(e="Invalid public key"){super(e),this.name="InvalidPublicKeyError"}},Is=class extends Error{static name="InvalidPrivateKeyError";constructor(e="Invalid private key"){super(e),this.name="InvalidPrivateKeyError"}};var bn=class extends Error{static name="ConnectionClosedError";constructor(e="The connection is closed"){super(e),this.name="ConnectionClosedError"}};var ke=class extends Error{static name="NotFoundError";constructor(e="Not found"){super(e),this.name="NotFoundError"}},po=class extends Error{static name="InvalidPeerIdError";constructor(e="Invalid PeerID"){super(e),this.name="InvalidPeerIdError"}},Kr=class extends Error{static name="InvalidMultiaddrError";constructor(e="Invalid multiaddr"){super(e),this.name="InvalidMultiaddrError"}},va=class extends Error{static name="InvalidCIDError";constructor(e="Invalid CID"){super(e),this.name="InvalidCIDError"}},Hr=class extends Error{static name="InvalidMultihashError";constructor(e="Invalid Multihash"){super(e),this.name="InvalidMultihashError"}},Ea=class extends Error{static name="UnsupportedProtocolError";constructor(e="Unsupported protocol error"){super(e),this.name="UnsupportedProtocolError"}},Aa=class extends Error{static name="InvalidMessageError";constructor(e="Invalid message"){super(e),this.name="InvalidMessageError"}};var Sa=class extends Error{static name="TimeoutError";constructor(e="Timed out"){super(e),this.name="TimeoutError"}},wr=class extends Error{static name="NotStartedError";constructor(e="Not started"){super(e),this.name="NotStartedError"}};var mo=class extends Error{static name="DialError";constructor(e="Dial error"){super(e),this.name="DialError"}};var ks=class extends Error{static name="LimitedConnectionError";constructor(e="Limited connection"){super(e),this.name="LimitedConnectionError"}},Ia=class extends Error{static name="TooManyInboundProtocolStreamsError";constructor(e="Too many inbound protocol streams"){super(e),this.name="TooManyInboundProtocolStreamsError"}},ka=class extends Error{static name="TooManyOutboundProtocolStreamsError";constructor(e="Too many outbound protocol streams"){super(e),this.name="TooManyOutboundProtocolStreamsError"}},Nt=class extends Error{static name="UnsupportedKeyTypeError";constructor(e="Unsupported key type"){super(e),this.name="UnsupportedKeyTypeError"}};var _a=class extends Event{error;local;constructor(e,t,n){super("close",n),this.error=t,this.local=e}};var $f=Symbol.for("@libp2p/peer-discovery");var Ca=Symbol.for("@libp2p/peer-id");function or(r){return!!r?.[Ca]}var qr=Symbol.for("@libp2p/peer-routing");var Vf="keep-alive";function Ta(r){return r!=null&&typeof r.start=="function"&&typeof r.stop=="function"}async function sr(...r){let e=[];for(let t of r)Ta(t)&&e.push(t);await Promise.all(e.map(async t=>{t.beforeStart!=null&&await t.beforeStart()})),await Promise.all(e.map(async t=>{await t.start()})),await Promise.all(e.map(async t=>{t.afterStart!=null&&await t.afterStart()}))}async function ir(...r){let e=[];for(let t of r)Ta(t)&&e.push(t);await Promise.all(e.map(async t=>{t.beforeStop!=null&&await t.beforeStop()})),await Promise.all(e.map(async t=>{await t.stop()})),await Promise.all(e.map(async t=>{t.afterStop!=null&&await t.afterStop()}))}var DC=Symbol.for("@libp2p/transport");var _s;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(_s||(_s={}));var _e=class extends EventTarget{#e=new Map;constructor(){super()}listenerCount(e){let t=this.#e.get(e);return t==null?0:t.length}addEventListener(e,t,n){super.addEventListener(e,t,n);let o=this.#e.get(e);o==null&&(o=[],this.#e.set(e,o)),o.push({callback:t,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(e,t,n){super.removeEventListener(e.toString(),t??null,n);let o=this.#e.get(e);o!=null&&(o=o.filter(({callback:s})=>s!==t),this.#e.set(e,o))}dispatchEvent(e){let t=super.dispatchEvent(e),n=this.#e.get(e.type);return n==null||(n=n.filter(({once:o})=>!o),this.#e.set(e.type,n)),t}safeDispatchEvent(e,t={}){return this.dispatchEvent(new CustomEvent(e,t))}};var xn=Symbol.for("@libp2p/service-capabilities"),Kf=Symbol.for("@libp2p/service-dependencies");function pe(r){let e=new globalThis.AbortController;function t(){e.abort();for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",t)}for(let s of r){if(s?.aborted===!0){t();break}s?.addEventListener!=null&&s.addEventListener("abort",t)}function n(){for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",t)}let o=e.signal;return o.clear=n,o}var Y=class extends Event{type;detail;constructor(e,t){super(e),this.type=e,this.detail=t}};var Cs=class extends Error{constructor(e="An error occurred while signing a message"){super(e),this.name="SigningError"}},Ts=class extends Error{constructor(e="An error occurred while verifying a message"){super(e),this.name="VerificationError"}},Ba=class extends Error{constructor(e="Missing Web Crypto API"){super(e),this.name="WebCryptoMissingError"}};var ug={get(r=globalThis){let e=r.crypto;if(e?.subtle==null)throw new Ba("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");return e}};var Se=ug;var jf={};Ae(jf,{base58btc:()=>le,base58flickr:()=>LE});var pT=new Uint8Array(0);function fg(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function Rt(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function dg(r){return new TextEncoder().encode(r)}function hg(r){return new TextDecoder().decode(r)}function IE(r,e){if(r.length>=255)throw new TypeError("Alphabet too long");for(var t=new Uint8Array(256),n=0;n<t.length;n++)t[n]=255;for(var o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(t[i]!==255)throw new TypeError(s+" is ambiguous");t[i]=o}var a=r.length,c=r.charAt(0),l=Math.log(a)/Math.log(256),f=Math.log(256)/Math.log(a);function u(m){if(m instanceof Uint8Array||(ArrayBuffer.isView(m)?m=new Uint8Array(m.buffer,m.byteOffset,m.byteLength):Array.isArray(m)&&(m=Uint8Array.from(m))),!(m instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(m.length===0)return"";for(var g=0,y=0,x=0,T=m.length;x!==T&&m[x]===0;)x++,g++;for(var S=(T-x)*f+1>>>0,D=new Uint8Array(S);x!==T;){for(var H=m[x],G=0,j=S-1;(H!==0||G<y)&&j!==-1;j--,G++)H+=256*D[j]>>>0,D[j]=H%a>>>0,H=H/a>>>0;if(H!==0)throw new Error("Non-zero carry");y=G,x++}for(var b=S-y;b!==S&&D[b]===0;)b++;for(var v=c.repeat(g);b<S;++b)v+=r.charAt(D[b]);return v}function d(m){if(typeof m!="string")throw new TypeError("Expected String");if(m.length===0)return new Uint8Array;var g=0;if(m[g]!==" "){for(var y=0,x=0;m[g]===c;)y++,g++;for(var T=(m.length-g)*l+1>>>0,S=new Uint8Array(T);m[g];){var D=t[m.charCodeAt(g)];if(D===255)return;for(var H=0,G=T-1;(D!==0||H<x)&&G!==-1;G--,H++)D+=a*S[G]>>>0,S[G]=D%256>>>0,D=D/256>>>0;if(D!==0)throw new Error("Non-zero carry");x=H,g++}if(m[g]!==" "){for(var j=T-x;j!==T&&S[j]===0;)j++;for(var b=new Uint8Array(y+(T-j)),v=y;j!==T;)b[v++]=S[j++];return b}}}function h(m){var g=d(m);if(g)return g;throw new Error(`Non-${e} character`)}return{encode:u,decodeUnsafe:d,decode:h}}var kE=IE,_E=kE,pg=_E;var qf=class{name;prefix;baseEncode;constructor(e,t,n){this.name=e,this.prefix=t,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},zf=class{name;prefix;baseDecode;prefixCodePoint;constructor(e,t,n){this.name=e,this.prefix=t;let o=t.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return mg(this,e)}},Gf=class{decoders;constructor(e){this.decoders=e}or(e){return mg(this,e)}decode(e){let t=e[0],n=this.decoders[t];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function mg(r,e){return new Gf({...r.decoders??{[r.prefix]:r},...e.decoders??{[e.prefix]:e}})}var Wf=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,t,n,o){this.name=e,this.prefix=t,this.baseEncode=n,this.baseDecode=o,this.encoder=new qf(e,t,n),this.decoder=new zf(e,t,o)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function go({name:r,prefix:e,encode:t,decode:n}){return new Wf(r,e,t,n)}function zr({name:r,prefix:e,alphabet:t}){let{encode:n,decode:o}=pg(t,r);return go({prefix:e,name:r,encode:n,decode:s=>Rt(o(s))})}function CE(r,e,t,n){let o=r.length;for(;r[o-1]==="=";)--o;let s=new Uint8Array(o*t/8|0),i=0,a=0,c=0;for(let l=0;l<o;++l){let f=e[r[l]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<t|f,i+=t,i>=8&&(i-=8,s[c++]=255&a>>i)}if(i>=t||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function TE(r,e,t){let n=e[e.length-1]==="=",o=(1<<t)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>t;)i-=t,s+=e[o&a>>i];if(i!==0&&(s+=e[o&a<<t-i]),n)for(;(s.length*t&7)!==0;)s+="=";return s}function BE(r){let e={};for(let t=0;t<r.length;++t)e[r[t]]=t;return e}function xe({name:r,prefix:e,bitsPerChar:t,alphabet:n}){let o=BE(n);return go({prefix:e,name:r,encode(s){return TE(s,n,t)},decode(s){return CE(s,o,t,r)}})}var le=zr({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),LE=zr({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Yf={};Ae(Yf,{base32:()=>Te,base32hex:()=>RE,base32hexpad:()=>OE,base32hexpadupper:()=>UE,base32hexupper:()=>ME,base32pad:()=>DE,base32padupper:()=>NE,base32upper:()=>PE,base32z:()=>FE});var Te=xe({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),PE=xe({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),DE=xe({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),NE=xe({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),RE=xe({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),ME=xe({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),OE=xe({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),UE=xe({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),FE=xe({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Zf={};Ae(Zf,{base36:()=>ar,base36upper:()=>$E});var ar=zr({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),$E=zr({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var VE=wg,gg=128,KE=127,HE=~KE,qE=Math.pow(2,31);function wg(r,e,t){e=e||[],t=t||0;for(var n=t;r>=qE;)e[t++]=r&255|gg,r/=128;for(;r&HE;)e[t++]=r&255|gg,r>>>=7;return e[t]=r|0,wg.bytes=t-n+1,e}var zE=Xf,GE=128,yg=127;function Xf(r,n){var t=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw Xf.bytes=0,new RangeError("Could not decode varint");i=r[s++],t+=o<28?(i&yg)<<o:(i&yg)*Math.pow(2,o),o+=7}while(i>=GE);return Xf.bytes=s-n,t}var WE=Math.pow(2,7),jE=Math.pow(2,14),YE=Math.pow(2,21),ZE=Math.pow(2,28),XE=Math.pow(2,35),JE=Math.pow(2,42),QE=Math.pow(2,49),e1=Math.pow(2,56),t1=Math.pow(2,63),r1=function(r){return r<WE?1:r<jE?2:r<YE?3:r<ZE?4:r<XE?5:r<JE?6:r<QE?7:r<e1?8:r<t1?9:10},n1={encode:VE,decode:zE,encodingLength:r1},o1=n1,Bs=o1;function Ls(r,e=0){return[Bs.decode(r,e),Bs.decode.bytes]}function yo(r,e,t=0){return Bs.encode(r,e,t),e}function wo(r){return Bs.encodingLength(r)}function cr(r,e){let t=e.byteLength,n=wo(r),o=n+wo(t),s=new Uint8Array(o+t);return yo(r,s,0),yo(t,s,n),s.set(e,o),new bo(r,t,e,s)}function pt(r){let e=Rt(r),[t,n]=Ls(e),[o,s]=Ls(e.subarray(n)),i=e.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new bo(t,o,i,e)}function bg(r,e){if(r===e)return!0;{let t=e;return r.code===t.code&&r.size===t.size&&t.bytes instanceof Uint8Array&&fg(r.bytes,t.bytes)}}var bo=class{code;size;digest;bytes;constructor(e,t,n,o){this.code=e,this.size=t,this.digest=n,this.bytes=o}};function xg(r,e){let{bytes:t,version:n}=r;switch(n){case 0:return i1(t,Jf(r),e??le.encoder);default:return a1(t,Jf(r),e??Te.encoder)}}var vg=new WeakMap;function Jf(r){let e=vg.get(r);if(e==null){let t=new Map;return vg.set(r,t),t}return e}var K=class r{code;version;multihash;bytes;"/";constructor(e,t,n,o){this.code=t,this.version=e,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:e,multihash:t}=this;if(e!==Ps)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(t.code!==c1)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(t)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:e,digest:t}=this.multihash,n=cr(e,t);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(e){return r.equals(this,e)}static equals(e,t){let n=t;return n!=null&&e.code===n.code&&e.version===n.version&&bg(e.multihash,n.multihash)}toString(e){return xg(this,e)}toJSON(){return{"/":xg(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let t=e;if(t instanceof r)return t;if(t["/"]!=null&&t["/"]===t.bytes||t.asCID===t){let{version:n,code:o,multihash:s,bytes:i}=t;return new r(n,o,s,i??Eg(n,o,s.bytes))}else if(t[l1]===!0){let{version:n,multihash:o,code:s}=t,i=pt(o);return r.create(n,s,i)}else return null}static create(e,t,n){if(typeof t!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(e){case 0:{if(t!==Ps)throw new Error(`Version 0 CID must use dag-pb (code: ${Ps}) block encoding`);return new r(e,t,n,n.bytes)}case 1:{let o=Eg(e,t,n.bytes);return new r(e,t,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return r.create(0,Ps,e)}static createV1(e,t){return r.create(1,e,t)}static decode(e){let[t,n]=r.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return t}static decodeFirst(e){let t=r.inspectBytes(e),n=t.size-t.multihashSize,o=Rt(e.subarray(n,n+t.multihashSize));if(o.byteLength!==t.multihashSize)throw new Error("Incorrect length");let s=o.subarray(t.multihashSize-t.digestSize),i=new bo(t.multihashCode,t.digestSize,s,o);return[t.version===0?r.createV0(i):r.createV1(t.codec,i),e.subarray(t.size)]}static inspectBytes(e){let t=0,n=()=>{let[u,d]=Ls(e.subarray(t));return t+=d,u},o=n(),s=Ps;if(o===18?(o=0,t=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=t,a=n(),c=n(),l=t+c,f=l-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:f,size:l}}static parse(e,t){let[n,o]=s1(e,t),s=r.decode(o);if(s.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return Jf(s).set(n,e),s}};function s1(r,e){switch(r[0]){case"Q":{let t=e??le;return[le.prefix,t.decode(`${le.prefix}${r}`)]}case le.prefix:{let t=e??le;return[le.prefix,t.decode(r)]}case Te.prefix:{let t=e??Te;return[Te.prefix,t.decode(r)]}case ar.prefix:{let t=e??ar;return[ar.prefix,t.decode(r)]}default:{if(e==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],e.decode(r)]}}}function i1(r,e,t){let{prefix:n}=t;if(n!==le.prefix)throw Error(`Cannot string encode V0 in ${t.name} encoding`);let o=e.get(n);if(o==null){let s=t.encode(r).slice(1);return e.set(n,s),s}else return o}function a1(r,e,t){let{prefix:n}=t,o=e.get(n);if(o==null){let s=t.encode(r);return e.set(n,s),s}else return o}var Ps=112,c1=18;function Eg(r,e,t){let n=wo(r),o=n+wo(e),s=new Uint8Array(o+t.byteLength);return yo(r,s,0),yo(e,s,n),s.set(t,o),s}var l1=Symbol.for("@ipld/js-cid/CID");var Qf={};Ae(Qf,{identity:()=>We});var Ag=0,u1="identity",Sg=Rt;function f1(r,e){if(e?.truncate!=null&&e.truncate!==r.byteLength){if(e.truncate<0||e.truncate>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,e.truncate)}return cr(Ag,Sg(r))}var We={code:Ag,name:u1,encode:Sg,digest:f1};function X(r,e){if(r===e)return!0;if(r.byteLength!==e.byteLength)return!1;for(let t=0;t<r.byteLength;t++)if(r[t]!==e[t])return!1;return!0}function ve(r=0){return new Uint8Array(r)}function je(r=0){return new Uint8Array(r)}function Ce(r,e){e==null&&(e=r.reduce((o,s)=>o+s.length,0));let t=je(e),n=0;for(let o of r)t.set(o,n),n+=o.length;return t}var kg=Symbol.for("@achingbrain/uint8arraylist");function Ig(r,e){if(e==null||e<0)throw new RangeError("index is out of bounds");let t=0;for(let n of r){let o=t+n.byteLength;if(e<o)return{buf:n,index:e-t};t=o}throw new RangeError("index is out of bounds")}function xo(r){return!!r?.[kg]}var se=class r{bufs;length;[kg]=!0;constructor(...e){this.bufs=[],this.length=0,e.length>0&&this.appendAll(e)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...e){this.appendAll(e)}appendAll(e){let t=0;for(let n of e)if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.push(n);else if(xo(n))t+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}prepend(...e){this.prependAll(e)}prependAll(e){let t=0;for(let n of e.reverse())if(n instanceof Uint8Array)t+=n.byteLength,this.bufs.unshift(n);else if(xo(n))t+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=t}get(e){let t=Ig(this.bufs,e);return t.buf[t.index]}set(e,t){let n=Ig(this.bufs,e);n.buf[n.index]=t}write(e,t=0){if(e instanceof Uint8Array)for(let n=0;n<e.length;n++)this.set(t+n,e[n]);else if(xo(e))for(let n=0;n<e.length;n++)this.set(t+n,e.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(e){if(e=Math.trunc(e),!(Number.isNaN(e)||e<=0)){if(e===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(e>=this.bufs[0].byteLength)e-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(e),this.length-=e;break}}}slice(e,t){let{bufs:n,length:o}=this._subList(e,t);return Ce(n,o)}subarray(e,t){let{bufs:n,length:o}=this._subList(e,t);return n.length===1?n[0]:Ce(n,o)}sublist(e,t){let{bufs:n,length:o}=this._subList(e,t),s=new r;return s.length=o,s.bufs=[...n],s}_subList(e,t){if(e=e??0,t=t??this.length,e<0&&(e=this.length+e),t<0&&(t=this.length+t),e<0||t>this.length)throw new RangeError("index is out of bounds");if(e===t)return{bufs:[],length:0};if(e===0&&t===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,e>=c)continue;let l=e>=a&&e<c,f=t>a&&t<=c;if(l&&f){if(e===a&&t===c){n.push(i);break}let u=e-a;n.push(i.subarray(u,u+(t-e)));break}if(l){if(e===0){n.push(i);continue}n.push(i.subarray(e-a));continue}if(f){if(t===c){n.push(i);break}n.push(i.subarray(0,t-a));break}n.push(i)}return{bufs:n,length:t-e}}indexOf(e,t=0){if(!xo(e)&&!(e instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=e instanceof Uint8Array?e:e.subarray();if(t=Number(t??0),isNaN(t)&&(t=0),t<0&&(t=this.length+t),t<0&&(t=0),e.length===0)return t>this.length?this.length:t;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 u=0;u<s;u++)i[u]=-1;for(let u=0;u<o;u++)i[n[u]]=u;let a=i,c=this.byteLength-n.byteLength,l=n.byteLength-1,f;for(let u=t;u<=c;u+=f){f=0;for(let d=l;d>=0;d--){let h=this.get(u+d);if(n[d]!==h){f=Math.max(1,d-a[h]);break}}if(f===0)return u}return-1}getInt8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getInt8(0)}setInt8(e,t){let n=je(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,t),this.write(n,e)}getInt16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,t)}setInt16(e,t,n){let o=ve(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,t,n),this.write(o,e)}getInt32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,t)}setInt32(e,t,n){let o=ve(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,t,n),this.write(o,e)}getBigInt64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,t)}setBigInt64(e,t,n){let o=ve(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,t,n),this.write(o,e)}getUint8(e){let t=this.subarray(e,e+1);return new DataView(t.buffer,t.byteOffset,t.byteLength).getUint8(0)}setUint8(e,t){let n=je(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,t),this.write(n,e)}getUint16(e,t){let n=this.subarray(e,e+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,t)}setUint16(e,t,n){let o=ve(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,t,n),this.write(o,e)}getUint32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,t)}setUint32(e,t,n){let o=ve(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,t,n),this.write(o,e)}getBigUint64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,t)}setBigUint64(e,t,n){let o=ve(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,t,n),this.write(o,e)}getFloat32(e,t){let n=this.subarray(e,e+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,t)}setFloat32(e,t,n){let o=ve(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,t,n),this.write(o,e)}getFloat64(e,t){let n=this.subarray(e,e+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,t)}setFloat64(e,t,n){let o=ve(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,t,n),this.write(o,e)}equals(e){if(e==null||!(e instanceof r)||e.bufs.length!==this.bufs.length)return!1;for(let t=0;t<this.bufs.length;t++)if(!X(this.bufs[t],e.bufs[t]))return!1;return!0}static fromUint8Arrays(e,t){let n=new r;return n.bufs=e,t==null&&(t=e.reduce((o,s)=>o+s.byteLength,0)),n.length=t,n}};var ed={};Ae(ed,{base10:()=>d1});var d1=zr({prefix:"9",name:"base10",alphabet:"0123456789"});var td={};Ae(td,{base16:()=>h1,base16upper:()=>p1});var h1=xe({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),p1=xe({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var rd={};Ae(rd,{base2:()=>m1});var m1=xe({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var nd={};Ae(nd,{base256emoji:()=>x1});var _g=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}"),g1=_g.reduce((r,e,t)=>(r[t]=e,r),[]),y1=_g.reduce((r,e,t)=>{let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);return r[n]=t,r},[]);function w1(r){return r.reduce((e,t)=>(e+=g1[t],e),"")}function b1(r){let e=[];for(let t of r){let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);let o=y1[n];if(o==null)throw new Error(`Non-base256emoji character: ${t}`);e.push(o)}return new Uint8Array(e)}var x1=go({prefix:"\u{1F680}",name:"base256emoji",encode:w1,decode:b1});var sd={};Ae(sd,{base64:()=>Ye,base64pad:()=>v1,base64url:()=>od,base64urlpad:()=>E1});var Ye=xe({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),v1=xe({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),od=xe({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),E1=xe({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var id={};Ae(id,{base8:()=>A1});var A1=xe({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var ad={};Ae(ad,{identity:()=>S1});var S1=go({prefix:"\0",name:"identity",encode:r=>hg(r),decode:r=>dg(r)});var Pa={};Ae(Pa,{code:()=>cd,decode:()=>T1,encode:()=>C1,name:()=>_1});var I1=new TextEncoder,k1=new TextDecoder,_1="json",cd=512;function C1(r){return I1.encode(JSON.stringify(r))}function T1(r){return JSON.parse(k1.decode(r))}var Ns={};Ae(Ns,{code:()=>Ds,decode:()=>P1,encode:()=>L1,name:()=>B1});var B1="raw",Ds=85;function L1(r){return Rt(r)}function P1(r){return Rt(r)}var fd={};Ae(fd,{sha256:()=>Mt,sha512:()=>Da});var D1=20;function ud({name:r,code:e,encode:t,minDigestLength:n,maxDigestLength:o}){return new ld(r,e,t,n,o)}var ld=class{name;code;encode;minDigestLength;maxDigestLength;constructor(e,t,n,o,s){this.name=e,this.code=t,this.encode=n,this.minDigestLength=o??D1,this.maxDigestLength=s}digest(e,t){if(t?.truncate!=null){if(t.truncate<this.minDigestLength)throw new Error(`Invalid truncate option, must be greater than or equal to ${this.minDigestLength}`);if(this.maxDigestLength!=null&&t.truncate>this.maxDigestLength)throw new Error(`Invalid truncate option, must be less than or equal to ${this.maxDigestLength}`)}if(e instanceof Uint8Array){let n=this.encode(e);return n instanceof Uint8Array?Cg(n,this.code,t?.truncate):n.then(o=>Cg(o,this.code,t?.truncate))}else throw Error("Unknown type, must be binary type")}};function Cg(r,e,t){if(t!=null&&t!==r.byteLength){if(t>r.byteLength)throw new Error(`Invalid truncate option, must be less than or equal to ${r.byteLength}`);r=r.subarray(0,t)}return cr(e,r)}function Bg(r){return async e=>new Uint8Array(await crypto.subtle.digest(r,e))}var Mt=ud({name:"sha2-256",code:18,encode:Bg("SHA-256")}),Da=ud({name:"sha2-512",code:19,encode:Bg("SHA-512")});var Rs={...ad,...rd,...id,...ed,...td,...Yf,...Zf,...jf,...sd,...nd},c8={...fd,...Qf};function Pg(r,e,t,n){return{name:r,prefix:e,encoder:{name:r,prefix:e,encode:t},decoder:{decode:n}}}var Lg=Pg("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),dd=Pg("ascii","a",r=>{let e="a";for(let t=0;t<r.length;t++)e+=String.fromCharCode(r[t]);return e},r=>{r=r.substring(1);let e=je(r.length);for(let t=0;t<r.length;t++)e[t]=r.charCodeAt(t);return e}),N1={utf8:Lg,"utf-8":Lg,hex:Rs.base16,latin1:dd,ascii:dd,binary:dd,...Rs},Na=N1;function B(r,e="utf8"){let t=Na[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.decoder.decode(`${t.prefix}${r}`)}function U(r,e="utf8"){let t=Na[e];if(t==null)throw new Error(`Unsupported encoding "${e}"`);return t.encoder.encode(r).substring(1)}var R1=parseInt("11111",2),hd=parseInt("10000000",2),M1=parseInt("01111111",2),Dg={0:Ms,1:Ms,2:O1,3:$1,4:V1,5:F1,6:U1,16:Ms,22:Ms,48:Ms};function St(r,e={offset:0}){let t=r[e.offset]&R1;if(e.offset++,Dg[t]!=null)return Dg[t](r,e);throw new Error("No decoder for tag "+t)}function Os(r,e){let t=0;if((r[e.offset]&hd)===hd){let n=r[e.offset]&M1,o="0x";e.offset++;for(let s=0;s<n;s++,e.offset++)o+=r[e.offset].toString(16).padStart(2,"0");t=parseInt(o,16)}else t=r[e.offset],e.offset++;return t}function Ms(r,e){Os(r,e);let t=[];for(;!(e.offset>=r.byteLength);){let n=St(r,e);if(n===null)break;t.push(n)}return t}function O1(r,e){let t=Os(r,e),n=e.offset,o=e.offset+t,s=[];for(let i=n;i<o;i++)i===n&&r[i]===0||s.push(r[i]);return e.offset+=t,Uint8Array.from(s)}function U1(r,e){let t=Os(r,e),n=e.offset+t,o=r[e.offset];e.offset++;let s=0,i=0;o<40?(s=0,i=o):o<80?(s=1,i=o-40):(s=2,i=o-80);let a=`${s}.${i}`,c=[];for(;e.offset<n;){let l=r[e.offset];if(e.offset++,c.push(l&127),l<128){c.reverse();let f=0;for(let u=0;u<c.length;u++)f+=c[u]<<u*7;a+=`.${f}`,c=[]}}return a}function F1(r,e){return e.offset++,null}function $1(r,e){let t=Os(r,e),n=r[e.offset];e.offset++;let o=r.subarray(e.offset,e.offset+t-1);if(e.offset+=t,n!==0)throw new Error("Unused bits in bit string is unimplemented");return o}function V1(r,e){let t=Os(r,e),n=r.subarray(e.offset,e.offset+t);return e.offset+=t,n}function K1(r){let e=r.toString(16);e.length%2===1&&(e="0"+e);let t=new se;for(let n=0;n<e.length;n+=2)t.append(Uint8Array.from([parseInt(`${e[n]}${e[n+1]}`,16)]));return t}function Ra(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let e=K1(r.byteLength);return new se(Uint8Array.from([e.byteLength|hd]),e)}function rt(r){let e=new se,t=128;return(r.subarray()[0]&t)===t&&e.append(Uint8Array.from([0])),e.append(r),new se(Uint8Array.from([2]),Ra(e),e)}function Us(r){let e=Uint8Array.from([0]),t=new se(e,r);return new se(Uint8Array.from([3]),Ra(t),t)}function Ng(r){return new se(Uint8Array.from([4]),Ra(r),r)}function Ot(r,e=48){let t=new se;for(let n of r)t.append(n);return new se(Uint8Array.from([e]),Ra(t),t)}var Rg="1.2.840.10045.3.1.7",Mg="1.3.132.0.34",Og="1.3.132.0.35";async function Ug(r="P-256"){let e=await crypto.subtle.generateKey({name:"ECDSA",namedCurve:r},!0,["sign","verify"]);return{publicKey:await crypto.subtle.exportKey("jwk",e.publicKey),privateKey:await crypto.subtle.exportKey("jwk",e.privateKey)}}async function Fg(r,e,t){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["sign"]);t?.signal?.throwIfAborted();let o=await crypto.subtle.sign({name:"ECDSA",hash:{name:"SHA-256"}},n,e.subarray());return t?.signal?.throwIfAborted(),new Uint8Array(o,0,o.byteLength)}async function $g(r,e,t,n){let o=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let s=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},o,e,t.subarray());return n?.signal?.throwIfAborted(),s}var H1=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),q1=Uint8Array.from([6,5,43,129,4,0,34]),z1=Uint8Array.from([6,5,43,129,4,0,35]),Vg={ext:!0,kty:"EC",crv:"P-256"},Kg={ext:!0,kty:"EC",crv:"P-384"},Hg={ext:!0,kty:"EC",crv:"P-521"},vo=32,Eo=48,Ao=66;function qg(r){let e=St(r);return pd(e)}function pd(r){let e=r[1],t=U(e,"base64url"),n=r[2][1][0],o=1,s,i;if(e.byteLength===vo)return s=U(n.subarray(o,o+vo),"base64url"),i=U(n.subarray(o+vo),"base64url"),new En({...Vg,key_ops:["sign"],d:t,x:s,y:i});if(e.byteLength===Eo)return s=U(n.subarray(o,o+Eo),"base64url"),i=U(n.subarray(o+Eo),"base64url"),new En({...Kg,key_ops:["sign"],d:t,x:s,y:i});if(e.byteLength===Ao)return s=U(n.subarray(o,o+Ao),"base64url"),i=U(n.subarray(o+Ao),"base64url"),new En({...Hg,key_ops:["sign"],d:t,x:s,y:i});throw new k(`Private key length was wrong length, got ${e.byteLength}, expected 32, 48 or 66`)}function md(r){let e=St(r);return zg(e)}function zg(r){let e=r[1][1][0],t=1,n,o;if(e.byteLength===vo*2+1)return n=U(e.subarray(t,t+vo),"base64url"),o=U(e.subarray(t+vo),"base64url"),new vn({...Vg,key_ops:["verify"],x:n,y:o});if(e.byteLength===Eo*2+1)return n=U(e.subarray(t,t+Eo),"base64url"),o=U(e.subarray(t+Eo),"base64url"),new vn({...Kg,key_ops:["verify"],x:n,y:o});if(e.byteLength===Ao*2+1)return n=U(e.subarray(t,t+Ao),"base64url"),o=U(e.subarray(t+Ao),"base64url"),new vn({...Hg,key_ops:["verify"],x:n,y:o});throw new k(`coordinates were wrong length, got ${e.byteLength}, expected 65, 97 or 133`)}function Gg(r){return Ot([rt(Uint8Array.from([1])),Ng(B(r.d??"","base64url")),Ot([jg(r.crv)],160),Ot([Us(new se(Uint8Array.from([4]),B(r.x??"","base64url"),B(r.y??"","base64url")))],161)]).subarray()}function Wg(r){return Ot([rt(Uint8Array.from([1])),Ot([jg(r.crv)],160),Ot([Us(new se(Uint8Array.from([4]),B(r.x??"","base64url"),B(r.y??"","base64url")))],161)]).subarray()}function jg(r){if(r==="P-256")return H1;if(r==="P-384")return q1;if(r==="P-521")return z1;throw new k(`Invalid curve ${r}`)}async function Yg(r="P-256"){let e=await Ug(r);return new En(e.privateKey)}var vn=class{type="ECDSA";jwk;_raw;constructor(e){this.jwk=e}get raw(){return this._raw==null&&(this._raw=Wg(this.jwk)),this._raw}toMultihash(){return We.digest(It(this))}toCID(){return K.createV1(114,this.toMultihash())}toString(){return le.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:X(this.raw,e.raw)}async verify(e,t,n){return $g(this.jwk,t,e,n)}},En=class{type="ECDSA";jwk;publicKey;_raw;constructor(e){this.jwk=e,this.publicKey=new vn({crv:e.crv,ext:e.ext,key_ops:["verify"],kty:"EC",x:e.x,y:e.y})}get raw(){return this._raw==null&&(this._raw=Gg(this.jwk)),this._raw}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:X(this.raw,e.raw)}async sign(e,t){return Fg(this.jwk,e,t)}};function An(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function it(r,e=""){if(!Number.isSafeInteger(r)||r<0){let t=e&&`"${e}" `;throw new Error(`${t}expected integer >= 0, got ${r}`)}}function J(r,e,t=""){let n=An(r),o=r?.length,s=e!==void 0;if(!n||s&&o!==e){let i=t&&`"${t}" `,a=s?` of length ${e}`:"",c=n?`length=${o}`:`type=${typeof r}`;throw new Error(i+"expected Uint8Array"+a+", got "+c)}return r}function So(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash must wrapped by utils.createHasher");it(r.outputLen),it(r.blockLen)}function Io(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function Xg(r,e){J(r,void 0,"digestInto() output");let t=e.outputLen;if(r.length<t)throw new Error('"digestInto() output" expected to be of length >='+t)}function at(...r){for(let e=0;e<r.length;e++)r[e].fill(0)}function Sn(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Ut(r,e){return r<<32-e|r>>>e}function Ma(r,e){return r<<e|r>>>32-e>>>0}var Jg=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",G1=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function xr(r){if(J(r),Jg)return r.toHex();let e="";for(let t=0;t<r.length;t++)e+=G1[r[t]];return e}var br={_0:48,_9:57,A:65,F:70,a:97,f:102};function Zg(r){if(r>=br._0&&r<=br._9)return r-br._0;if(r>=br.A&&r<=br.F)return r-(br.A-10);if(r>=br.a&&r<=br.f)return r-(br.a-10)}function vr(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(Jg)return Uint8Array.fromHex(r);let e=r.length,t=e/2;if(e%2)throw new Error("hex string expected, got unpadded hex of length "+e);let n=new Uint8Array(t);for(let o=0,s=0;o<t;o++,s+=2){let i=Zg(r.charCodeAt(s)),a=Zg(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}var W1=async()=>{};async function Qg(r,e,t){let n=Date.now();for(let o=0;o<r;o++){t(o);let s=Date.now()-n;s>=0&&s<e||(await W1(),n+=s)}}function j1(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function gd(r,e=""){return typeof r=="string"?j1(r):J(r,void 0,e)}function ct(...r){let e=0;for(let n=0;n<r.length;n++){let o=r[n];J(o),e+=o.length}let t=new Uint8Array(e);for(let n=0,o=0;n<r.length;n++){let s=r[n];t.set(s,o),o+=s.length}return t}function ey(r,e){if(e!==void 0&&{}.toString.call(e)!=="[object Object]")throw new Error("options must be object or undefined");return Object.assign(r,e)}function Fs(r,e={}){let t=(o,s)=>r(s).update(o).digest(),n=r(void 0);return t.outputLen=n.outputLen,t.blockLen=n.blockLen,t.create=o=>r(o),Object.assign(t,e),Object.freeze(t)}function Gr(r=32){let e=typeof globalThis=="object"?globalThis.crypto:null;if(typeof e?.getRandomValues!="function")throw new Error("crypto.getRandomValues must be defined");return e.getRandomValues(new Uint8Array(r))}var yd=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function Oa(r,e,t){return r&e^~r&t}function Ua(r,e,t){return r&e^r&t^e&t}var In=class{blockLen;outputLen;padOffset;isLE;buffer;view;finished=!1;length=0;pos=0;destroyed=!1;constructor(e,t,n,o){this.blockLen=e,this.outputLen=t,this.padOffset=n,this.isLE=o,this.buffer=new Uint8Array(e),this.view=Sn(this.buffer)}update(e){Io(this),J(e);let{view:t,buffer:n,blockLen:o}=this,s=e.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=Sn(e);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(t,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Io(this),Xg(e,this),this.finished=!0;let{buffer:t,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;t[i++]=128,at(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let u=i;u<o;u++)t[u]=0;n.setBigUint64(o-8,BigInt(this.length*8),s),this.process(n,0);let a=Sn(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");let l=c/4,f=this.get();if(l>f.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)a.setUint32(4*u,f[u],s)}digest(){let{buffer:e,outputLen:t}=this;this.digestInto(e);let n=e.slice(0,t);return this.destroy(),n}_cloneInto(e){e||=new this.constructor,e.set(...this.get());let{blockLen:t,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return e.destroyed=i,e.finished=s,e.length=o,e.pos=a,o%t&&e.buffer.set(n),e}clone(){return this._cloneInto()}},Er=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var Me=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var Fa=BigInt(4294967295),ty=BigInt(32);function Y1(r,e=!1){return e?{h:Number(r&Fa),l:Number(r>>ty&Fa)}:{h:Number(r>>ty&Fa)|0,l:Number(r&Fa)|0}}function ry(r,e=!1){let t=r.length,n=new Uint32Array(t),o=new Uint32Array(t);for(let s=0;s<t;s++){let{h:i,l:a}=Y1(r[s],e);[n[s],o[s]]=[i,a]}return[n,o]}var wd=(r,e,t)=>r>>>t,bd=(r,e,t)=>r<<32-t|e>>>t,kn=(r,e,t)=>r>>>t|e<<32-t,_n=(r,e,t)=>r<<32-t|e>>>t,$s=(r,e,t)=>r<<64-t|e>>>t-32,Vs=(r,e,t)=>r>>>t-32|e<<64-t;function ur(r,e,t,n){let o=(e>>>0)+(n>>>0);return{h:r+t+(o/2**32|0)|0,l:o|0}}var ny=(r,e,t)=>(r>>>0)+(e>>>0)+(t>>>0),oy=(r,e,t,n)=>e+t+n+(r/2**32|0)|0,sy=(r,e,t,n)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0),iy=(r,e,t,n,o)=>e+t+n+o+(r/2**32|0)|0,ay=(r,e,t,n,o)=>(r>>>0)+(e>>>0)+(t>>>0)+(n>>>0)+(o>>>0),cy=(r,e,t,n,o,s)=>e+t+n+o+s+(r/2**32|0)|0;var X1=Uint32Array.from([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Wr=new Uint32Array(64),xd=class extends In{constructor(e){super(64,e,8,!1)}get(){let{A:e,B:t,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[e,t,n,o,s,i,a,c]}set(e,t,n,o,s,i,a,c){this.A=e|0,this.B=t|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=a|0,this.H=c|0}process(e,t){for(let u=0;u<16;u++,t+=4)Wr[u]=e.getUint32(t,!1);for(let u=16;u<64;u++){let d=Wr[u-15],h=Wr[u-2],m=Ut(d,7)^Ut(d,18)^d>>>3,g=Ut(h,17)^Ut(h,19)^h>>>10;Wr[u]=g+Wr[u-7]+m+Wr[u-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:l,H:f}=this;for(let u=0;u<64;u++){let d=Ut(a,6)^Ut(a,11)^Ut(a,25),h=f+d+Oa(a,c,l)+X1[u]+Wr[u]|0,g=(Ut(n,2)^Ut(n,13)^Ut(n,22))+Ua(n,o,s)|0;f=l,l=c,c=a,a=i+h|0,i=s,s=o,o=n,n=h+g|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,l=l+this.G|0,f=f+this.H|0,this.set(n,o,s,i,a,c,l,f)}roundClean(){at(Wr)}destroy(){this.set(0,0,0,0,0,0,0,0),at(this.buffer)}},vd=class extends xd{A=Er[0]|0;B=Er[1]|0;C=Er[2]|0;D=Er[3]|0;E=Er[4]|0;F=Er[5]|0;G=Er[6]|0;H=Er[7]|0;constructor(){super(32)}};var ly=ry(["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))),J1=ly[0],Q1=ly[1],jr=new Uint32Array(80),Yr=new Uint32Array(80),Ed=class extends In{constructor(e){super(128,e,16,!1)}get(){let{Ah:e,Al:t,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:l,El:f,Fh:u,Fl:d,Gh:h,Gl:m,Hh:g,Hl:y}=this;return[e,t,n,o,s,i,a,c,l,f,u,d,h,m,g,y]}set(e,t,n,o,s,i,a,c,l,f,u,d,h,m,g,y){this.Ah=e|0,this.Al=t|0,this.Bh=n|0,this.Bl=o|0,this.Ch=s|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=l|0,this.El=f|0,this.Fh=u|0,this.Fl=d|0,this.Gh=h|0,this.Gl=m|0,this.Hh=g|0,this.Hl=y|0}process(e,t){for(let S=0;S<16;S++,t+=4)jr[S]=e.getUint32(t),Yr[S]=e.getUint32(t+=4);for(let S=16;S<80;S++){let D=jr[S-15]|0,H=Yr[S-15]|0,G=kn(D,H,1)^kn(D,H,8)^wd(D,H,7),j=_n(D,H,1)^_n(D,H,8)^bd(D,H,7),b=jr[S-2]|0,v=Yr[S-2]|0,P=kn(b,v,19)^$s(b,v,61)^wd(b,v,6),N=_n(b,v,19)^Vs(b,v,61)^bd(b,v,6),C=sy(j,N,Yr[S-7],Yr[S-16]),E=iy(C,G,P,jr[S-7],jr[S-16]);jr[S]=E|0,Yr[S]=C|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:l,Dl:f,Eh:u,El:d,Fh:h,Fl:m,Gh:g,Gl:y,Hh:x,Hl:T}=this;for(let S=0;S<80;S++){let D=kn(u,d,14)^kn(u,d,18)^$s(u,d,41),H=_n(u,d,14)^_n(u,d,18)^Vs(u,d,41),G=u&h^~u&g,j=d&m^~d&y,b=ay(T,H,j,Q1[S],Yr[S]),v=cy(b,x,D,G,J1[S],jr[S]),P=b|0,N=kn(n,o,28)^$s(n,o,34)^$s(n,o,39),C=_n(n,o,28)^Vs(n,o,34)^Vs(n,o,39),E=n&s^n&a^s&a,A=o&i^o&c^i&c;x=g|0,T=y|0,g=h|0,y=m|0,h=u|0,m=d|0,{h:u,l:d}=ur(l|0,f|0,v|0,P|0),l=a|0,f=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let w=ny(P,C,A);n=oy(w,v,N,E),o=w|0}({h:n,l:o}=ur(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=ur(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=ur(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:f}=ur(this.Dh|0,this.Dl|0,l|0,f|0),{h:u,l:d}=ur(this.Eh|0,this.El|0,u|0,d|0),{h,l:m}=ur(this.Fh|0,this.Fl|0,h|0,m|0),{h:g,l:y}=ur(this.Gh|0,this.Gl|0,g|0,y|0),{h:x,l:T}=ur(this.Hh|0,this.Hl|0,x|0,T|0),this.set(n,o,s,i,a,c,l,f,u,d,h,m,g,y,x,T)}roundClean(){at(jr,Yr)}destroy(){at(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}},Ad=class extends Ed{Ah=Me[0]|0;Al=Me[1]|0;Bh=Me[2]|0;Bl=Me[3]|0;Ch=Me[4]|0;Cl=Me[5]|0;Dh=Me[6]|0;Dl=Me[7]|0;Eh=Me[8]|0;El=Me[9]|0;Fh=Me[10]|0;Fl=Me[11]|0;Gh=Me[12]|0;Gl=Me[13]|0;Hh=Me[14]|0;Hl=Me[15]|0;constructor(){super(64)}};var Zr=Fs(()=>new vd,yd(1));var Xr=Fs(()=>new Ad,yd(3));var Id=BigInt(0),Sd=BigInt(1);function Ar(r,e=""){if(typeof r!="boolean"){let t=e&&`"${e}" `;throw new Error(t+"expected boolean, got type="+typeof r)}return r}function uy(r){if(typeof r=="bigint"){if(!$a(r))throw new Error("positive bigint expected, got "+r)}else it(r);return r}function Ks(r){let e=uy(r).toString(16);return e.length&1?"0"+e:e}function fy(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?Id:BigInt("0x"+r)}function ko(r){return fy(xr(r))}function Cn(r){return fy(xr(Ka(J(r)).reverse()))}function Va(r,e){it(e),r=uy(r);let t=vr(r.toString(16).padStart(e*2,"0"));if(t.length!==e)throw new Error("number too large");return t}function kd(r,e){return Va(r,e).reverse()}function Ka(r){return Uint8Array.from(r)}var $a=r=>typeof r=="bigint"&&Id<=r;function e2(r,e,t){return $a(r)&&$a(e)&&$a(t)&&e<=r&&r<t}function Hs(r,e,t,n){if(!e2(e,t,n))throw new Error("expected valid "+r+": "+t+" <= n < "+n+", got "+e)}function _d(r){let e;for(e=0;r>Id;r>>=Sd,e+=1);return e}var qs=r=>(Sd<<BigInt(r))-Sd;function dy(r,e,t){if(it(r,"hashLen"),it(e,"qByteLen"),typeof t!="function")throw new Error("hmacFn must be a function");let n=y=>new Uint8Array(y),o=Uint8Array.of(),s=Uint8Array.of(0),i=Uint8Array.of(1),a=1e3,c=n(r),l=n(r),f=0,u=()=>{c.fill(1),l.fill(0),f=0},d=(...y)=>t(l,ct(c,...y)),h=(y=o)=>{l=d(s,y),c=d(),y.length!==0&&(l=d(i,y),c=d())},m=()=>{if(f++>=a)throw new Error("drbg: tried max amount of iterations");let y=0,x=[];for(;y<e;){c=d();let T=c.slice();x.push(T),y+=c.length}return ct(...x)};return(y,x)=>{u(),h(y);let T;for(;!(T=x(m()));)h();return u(),T}}function Jr(r,e={},t={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function n(s,i,a){let c=r[s];if(a&&c===void 0)return;let l=typeof c;if(l!==i||c===null)throw new Error(`param "${s}" is invalid: expected ${i}, got ${l}`)}let o=(s,i)=>Object.entries(s).forEach(([a,c])=>n(a,c,i));o(e,!1),o(t,!0)}function _o(r){let e=new WeakMap;return(t,...n)=>{let o=e.get(t);if(o!==void 0)return o;let s=r(t,...n);return e.set(t,s),s}}var nt=BigInt(0),Be=BigInt(1),Tn=BigInt(2),my=BigInt(3),gy=BigInt(4),yy=BigInt(5),t2=BigInt(7),wy=BigInt(8),r2=BigInt(9),by=BigInt(16);function Ee(r,e){let t=r%e;return t>=nt?t:e+t}function me(r,e,t){let n=r;for(;e-- >nt;)n*=n,n%=t;return n}function hy(r,e){if(r===nt)throw new Error("invert: expected non-zero number");if(e<=nt)throw new Error("invert: expected positive modulus, got "+e);let t=Ee(r,e),n=e,o=nt,s=Be,i=Be,a=nt;for(;t!==nt;){let l=n/t,f=n%t,u=o-i*l,d=s-a*l;n=t,t=f,o=i,s=a,i=u,a=d}if(n!==Be)throw new Error("invert: does not exist");return Ee(o,e)}function Td(r,e,t){if(!r.eql(r.sqr(e),t))throw new Error("Cannot find square root")}function xy(r,e){let t=(r.ORDER+Be)/gy,n=r.pow(e,t);return Td(r,n,e),n}function n2(r,e){let t=(r.ORDER-yy)/wy,n=r.mul(e,Tn),o=r.pow(n,t),s=r.mul(e,o),i=r.mul(r.mul(s,Tn),o),a=r.mul(s,r.sub(i,r.ONE));return Td(r,a,e),a}function o2(r){let e=Co(r),t=vy(r),n=t(e,e.neg(e.ONE)),o=t(e,n),s=t(e,e.neg(n)),i=(r+t2)/by;return(a,c)=>{let l=a.pow(c,i),f=a.mul(l,n),u=a.mul(l,o),d=a.mul(l,s),h=a.eql(a.sqr(f),c),m=a.eql(a.sqr(u),c);l=a.cmov(l,f,h),f=a.cmov(d,u,m);let g=a.eql(a.sqr(f),c),y=a.cmov(l,f,g);return Td(a,y,c),y}}function vy(r){if(r<my)throw new Error("sqrt is not defined for small field");let e=r-Be,t=0;for(;e%Tn===nt;)e/=Tn,t++;let n=Tn,o=Co(r);for(;py(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(t===1)return xy;let s=o.pow(n,e),i=(e+Be)/Tn;return function(c,l){if(c.is0(l))return l;if(py(c,l)!==1)throw new Error("Cannot find square root");let f=t,u=c.mul(c.ONE,s),d=c.pow(l,e),h=c.pow(l,i);for(;!c.eql(d,c.ONE);){if(c.is0(d))return c.ZERO;let m=1,g=c.sqr(d);for(;!c.eql(g,c.ONE);)if(m++,g=c.sqr(g),m===f)throw new Error("Cannot find square root");let y=Be<<BigInt(f-m-1),x=c.pow(u,y);f=m,u=c.sqr(x),d=c.mul(d,u),h=c.mul(h,x)}return h}}function s2(r){return r%gy===my?xy:r%wy===yy?n2:r%by===r2?o2(r):vy(r)}var Ey=(r,e)=>(Ee(r,e)&Be)===Be,i2=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Bd(r){let e={ORDER:"bigint",BYTES:"number",BITS:"number"},t=i2.reduce((n,o)=>(n[o]="function",n),e);return Jr(r,t),r}function a2(r,e,t){if(t<nt)throw new Error("invalid exponent, negatives unsupported");if(t===nt)return r.ONE;if(t===Be)return e;let n=r.ONE,o=e;for(;t>nt;)t&Be&&(n=r.mul(n,o)),o=r.sqr(o),t>>=Be;return n}function zs(r,e,t=!1){let n=new Array(e.length).fill(t?r.ZERO:void 0),o=e.reduce((i,a,c)=>r.is0(a)?i:(n[c]=i,r.mul(i,a)),r.ONE),s=r.inv(o);return e.reduceRight((i,a,c)=>r.is0(a)?i:(n[c]=r.mul(i,n[c]),r.mul(i,a)),s),n}function py(r,e){let t=(r.ORDER-Be)/Tn,n=r.pow(e,t),o=r.eql(n,r.ONE),s=r.eql(n,r.ZERO),i=r.eql(n,r.neg(r.ONE));if(!o&&!s&&!i)throw new Error("invalid Legendre symbol result");return o?1:s?0:-1}function c2(r,e){e!==void 0&&it(e);let t=e!==void 0?e:r.toString(2).length,n=Math.ceil(t/8);return{nBitLength:t,nByteLength:n}}var Cd=class{ORDER;BITS;BYTES;isLE;ZERO=nt;ONE=Be;_lengths;_sqrt;_mod;constructor(e,t={}){if(e<=nt)throw new Error("invalid field: expected ORDER > 0, got "+e);let n;this.isLE=!1,t!=null&&typeof t=="object"&&(typeof t.BITS=="number"&&(n=t.BITS),typeof t.sqrt=="function"&&(this.sqrt=t.sqrt),typeof t.isLE=="boolean"&&(this.isLE=t.isLE),t.allowedLengths&&(this._lengths=t.allowedLengths?.slice()),typeof t.modFromBytes=="boolean"&&(this._mod=t.modFromBytes));let{nBitLength:o,nByteLength:s}=c2(e,n);if(s>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=e,this.BITS=o,this.BYTES=s,this._sqrt=void 0,Object.preventExtensions(this)}create(e){return Ee(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof e);return nt<=e&&e<this.ORDER}is0(e){return e===nt}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&Be)===Be}neg(e){return Ee(-e,this.ORDER)}eql(e,t){return e===t}sqr(e){return Ee(e*e,this.ORDER)}add(e,t){return Ee(e+t,this.ORDER)}sub(e,t){return Ee(e-t,this.ORDER)}mul(e,t){return Ee(e*t,this.ORDER)}pow(e,t){return a2(this,e,t)}div(e,t){return Ee(e*hy(t,this.ORDER),this.ORDER)}sqrN(e){return e*e}addN(e,t){return e+t}subN(e,t){return e-t}mulN(e,t){return e*t}inv(e){return hy(e,this.ORDER)}sqrt(e){return this._sqrt||(this._sqrt=s2(this.ORDER)),this._sqrt(this,e)}toBytes(e){return this.isLE?kd(e,this.BYTES):Va(e,this.BYTES)}fromBytes(e,t=!1){J(e);let{_lengths:n,BYTES:o,isLE:s,ORDER:i,_mod:a}=this;if(n){if(!n.includes(e.length)||e.length>o)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+e.length);let l=new Uint8Array(o);l.set(e,s?0:l.length-e.length),e=l}if(e.length!==o)throw new Error("Field.fromBytes: expected "+o+" bytes, got "+e.length);let c=s?Cn(e):ko(e);if(a&&(c=Ee(c,i)),!t&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(e){return zs(this,e)}cmov(e,t,n){return n?t:e}};function Co(r,e={}){return new Cd(r,e)}function Ay(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let e=r.toString(2).length;return Math.ceil(e/8)}function Ld(r){let e=Ay(r);return e+Math.ceil(e/2)}function Pd(r,e,t=!1){J(r);let n=r.length,o=Ay(e),s=Ld(e);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=t?Cn(r):ko(r),a=Ee(i,e-Be)+Be;return t?kd(a,o):Va(a,o)}var To=BigInt(0),Bn=BigInt(1);function Gs(r,e){let t=e.negate();return r?t:e}function Ln(r,e){let t=zs(r.Fp,e.map(n=>n.Z));return e.map((n,o)=>r.fromAffine(n.toAffine(t[o])))}function _y(r,e){if(!Number.isSafeInteger(r)||r<=0||r>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+r)}function Dd(r,e){_y(r,e);let t=Math.ceil(e/r)+1,n=2**(r-1),o=2**r,s=qs(r),i=BigInt(r);return{windows:t,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function Sy(r,e,t){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=t,a=Number(r&o),c=r>>i;a>n&&(a-=s,c+=Bn);let l=e*n,f=l+Math.abs(a)-1,u=a===0,d=a<0,h=e%2!==0;return{nextN:c,offset:f,isZero:u,isNeg:d,isNegF:h,offsetF:l}}var Nd=new WeakMap,Cy=new WeakMap;function Rd(r){return Cy.get(r)||1}function Iy(r){if(r!==To)throw new Error("invalid wNAF")}var Bo=class{BASE;ZERO;Fn;bits;constructor(e,t){this.BASE=e.BASE,this.ZERO=e.ZERO,this.Fn=e.Fn,this.bits=t}_unsafeLadder(e,t,n=this.ZERO){let o=e;for(;t>To;)t&Bn&&(n=n.add(o)),o=o.double(),t>>=Bn;return n}precomputeWindow(e,t){let{windows:n,windowSize:o}=Dd(t,this.bits),s=[],i=e,a=i;for(let c=0;c<n;c++){a=i,s.push(a);for(let l=1;l<o;l++)a=a.add(i),s.push(a);i=a.double()}return s}wNAF(e,t,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let o=this.ZERO,s=this.BASE,i=Dd(e,this.bits);for(let a=0;a<i.windows;a++){let{nextN:c,offset:l,isZero:f,isNeg:u,isNegF:d,offsetF:h}=Sy(n,a,i);n=c,f?s=s.add(Gs(d,t[h])):o=o.add(Gs(u,t[l]))}return Iy(n),{p:o,f:s}}wNAFUnsafe(e,t,n,o=this.ZERO){let s=Dd(e,this.bits);for(let i=0;i<s.windows&&n!==To;i++){let{nextN:a,offset:c,isZero:l,isNeg:f}=Sy(n,i,s);if(n=a,!l){let u=t[c];o=o.add(f?u.negate():u)}}return Iy(n),o}getPrecomputes(e,t,n){let o=Nd.get(t);return o||(o=this.precomputeWindow(t,e),e!==1&&(typeof n=="function"&&(o=n(o)),Nd.set(t,o))),o}cached(e,t,n){let o=Rd(e);return this.wNAF(o,this.getPrecomputes(o,e,n),t)}unsafe(e,t,n,o){let s=Rd(e);return s===1?this._unsafeLadder(e,t,o):this.wNAFUnsafe(s,this.getPrecomputes(s,e,n),t,o)}createCache(e,t){_y(t,this.bits),Cy.set(e,t),Nd.delete(e)}hasCache(e){return Rd(e)!==1}};function Ty(r,e,t,n){let o=e,s=r.ZERO,i=r.ZERO;for(;t>To||n>To;)t&Bn&&(s=s.add(o)),n&Bn&&(i=i.add(o)),o=o.double(),t>>=Bn,n>>=Bn;return{p1:s,p2:i}}function ky(r,e,t){if(e){if(e.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Bd(e),e}else return Co(r,{isLE:t})}function Ha(r,e,t={},n){if(n===void 0&&(n=r==="edwards"),!e||typeof e!="object")throw new Error(`expected valid ${r} CURVE object`);for(let c of["p","n","h"]){let l=e[c];if(!(typeof l=="bigint"&&l>To))throw new Error(`CURVE.${c} must be positive bigint`)}let o=ky(e.p,t.Fp,n),s=ky(e.n,t.Fn,n),a=["Gx","Gy","a",r==="weierstrass"?"b":"d"];for(let c of a)if(!o.isValid(e[c]))throw new Error(`CURVE.${c} must be valid field element of CURVE.Fp`);return e=Object.freeze(Object.assign({},e)),{CURVE:e,Fp:o,Fn:s}}function qa(r,e){return function(n){let o=r(n);return{secretKey:o,publicKey:e(o)}}}var Qr=BigInt(0),Le=BigInt(1),Md=BigInt(2),l2=BigInt(8);function u2(r,e,t,n){let o=r.sqr(t),s=r.sqr(n),i=r.add(r.mul(e.a,o),s),a=r.add(r.ONE,r.mul(e.d,r.mul(o,s)));return r.eql(i,a)}function By(r,e={}){let t=Ha("edwards",r,e,e.FpFnLE),{Fp:n,Fn:o}=t,s=t.CURVE,{h:i}=s;Jr(e,{},{uvRatio:"function"});let a=Md<<BigInt(o.BYTES*8)-Le,c=y=>n.create(y),l=e.uvRatio||((y,x)=>{try{return{isValid:!0,value:n.sqrt(n.div(y,x))}}catch{return{isValid:!1,value:Qr}}});if(!u2(n,s,s.Gx,s.Gy))throw new Error("bad curve params: generator point");function f(y,x,T=!1){let S=T?Le:Qr;return Hs("coordinate "+y,x,S,a),x}function u(y){if(!(y instanceof m))throw new Error("EdwardsPoint expected")}let d=_o((y,x)=>{let{X:T,Y:S,Z:D}=y,H=y.is0();x==null&&(x=H?l2:n.inv(D));let G=c(T*x),j=c(S*x),b=n.mul(D,x);if(H)return{x:Qr,y:Le};if(b!==Le)throw new Error("invZ was invalid");return{x:G,y:j}}),h=_o(y=>{let{a:x,d:T}=s;if(y.is0())throw new Error("bad point: ZERO");let{X:S,Y:D,Z:H,T:G}=y,j=c(S*S),b=c(D*D),v=c(H*H),P=c(v*v),N=c(j*x),C=c(v*c(N+b)),E=c(P+c(T*c(j*b)));if(C!==E)throw new Error("bad point: equation left != right (1)");let A=c(S*D),w=c(H*G);if(A!==w)throw new Error("bad point: equation left != right (2)");return!0});class m{static BASE=new m(s.Gx,s.Gy,Le,c(s.Gx*s.Gy));static ZERO=new m(Qr,Le,Le,Qr);static Fp=n;static Fn=o;X;Y;Z;T;constructor(x,T,S,D){this.X=f("x",x),this.Y=f("y",T),this.Z=f("z",S,!0),this.T=f("t",D),Object.freeze(this)}static CURVE(){return s}static fromAffine(x){if(x instanceof m)throw new Error("extended point not allowed");let{x:T,y:S}=x||{};return f("x",T),f("y",S),new m(T,S,Le,c(T*S))}static fromBytes(x,T=!1){let S=n.BYTES,{a:D,d:H}=s;x=Ka(J(x,S,"point")),Ar(T,"zip215");let G=Ka(x),j=x[S-1];G[S-1]=j&-129;let b=Cn(G),v=T?a:n.ORDER;Hs("point.y",b,Qr,v);let P=c(b*b),N=c(P-Le),C=c(H*P-D),{isValid:E,value:A}=l(N,C);if(!E)throw new Error("bad point: invalid y coordinate");let w=(A&Le)===Le,_=(j&128)!==0;if(!T&&A===Qr&&_)throw new Error("bad point: x=0 and x_0=1");return _!==w&&(A=c(-A)),m.fromAffine({x:A,y:b})}static fromHex(x,T=!1){return m.fromBytes(vr(x),T)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(x=8,T=!0){return g.createCache(this,x),T||this.multiply(Md),this}assertValidity(){h(this)}equals(x){u(x);let{X:T,Y:S,Z:D}=this,{X:H,Y:G,Z:j}=x,b=c(T*j),v=c(H*D),P=c(S*j),N=c(G*D);return b===v&&P===N}is0(){return this.equals(m.ZERO)}negate(){return new m(c(-this.X),this.Y,this.Z,c(-this.T))}double(){let{a:x}=s,{X:T,Y:S,Z:D}=this,H=c(T*T),G=c(S*S),j=c(Md*c(D*D)),b=c(x*H),v=T+S,P=c(c(v*v)-H-G),N=b+G,C=N-j,E=b-G,A=c(P*C),w=c(N*E),_=c(P*E),R=c(C*N);return new m(A,w,R,_)}add(x){u(x);let{a:T,d:S}=s,{X:D,Y:H,Z:G,T:j}=this,{X:b,Y:v,Z:P,T:N}=x,C=c(D*b),E=c(H*v),A=c(j*S*N),w=c(G*P),_=c((D+H)*(b+v)-C-E),R=w-A,M=w+A,$=c(E-T*C),V=c(_*R),z=c(M*$),Z=c(_*$),ye=c(R*M);return new m(V,z,ye,Z)}subtract(x){return this.add(x.negate())}multiply(x){if(!o.isValidNot0(x))throw new Error("invalid scalar: expected 1 <= sc < curve.n");let{p:T,f:S}=g.cached(this,x,D=>Ln(m,D));return Ln(m,[T,S])[0]}multiplyUnsafe(x,T=m.ZERO){if(!o.isValid(x))throw new Error("invalid scalar: expected 0 <= sc < curve.n");return x===Qr?m.ZERO:this.is0()||x===Le?this:g.unsafe(this,x,S=>Ln(m,S),T)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}isTorsionFree(){return g.unsafe(this,s.n).is0()}toAffine(x){return d(this,x)}clearCofactor(){return i===Le?this:this.multiplyUnsafe(i)}toBytes(){let{x,y:T}=this.toAffine(),S=n.toBytes(T);return S[S.length-1]|=x&Le?128:0,S}toHex(){return xr(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let g=new Bo(m,o.BITS);return m.BASE.precompute(8),m}function Ly(r,e,t={}){if(typeof e!="function")throw new Error('"hash" function param is required');Jr(t,{},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:n}=t,{BASE:o,Fp:s,Fn:i}=r,a=t.randomBytes||Gr,c=t.adjustScalarBytes||(b=>b),l=t.domain||((b,v,P)=>{if(Ar(P,"phflag"),v.length||P)throw new Error("Contexts/pre-hash are not supported");return b});function f(b){return i.create(Cn(b))}function u(b){let v=S.secretKey;J(b,S.secretKey,"secretKey");let P=J(e(b),2*v,"hashedSecretKey"),N=c(P.slice(0,v)),C=P.slice(v,2*v),E=f(N);return{head:N,prefix:C,scalar:E}}function d(b){let{head:v,prefix:P,scalar:N}=u(b),C=o.multiply(N),E=C.toBytes();return{head:v,prefix:P,scalar:N,point:C,pointBytes:E}}function h(b){return d(b).pointBytes}function m(b=Uint8Array.of(),...v){let P=ct(...v);return f(e(l(P,J(b,void 0,"context"),!!n)))}function g(b,v,P={}){b=J(b,void 0,"message"),n&&(b=n(b));let{prefix:N,scalar:C,pointBytes:E}=d(v),A=m(P.context,N,b),w=o.multiply(A).toBytes(),_=m(P.context,w,E,b),R=i.create(A+_*C);if(!i.isValid(R))throw new Error("sign failed: invalid s");let M=ct(w,i.toBytes(R));return J(M,S.signature,"result")}let y={zip215:!0};function x(b,v,P,N=y){let{context:C,zip215:E}=N,A=S.signature;b=J(b,A,"signature"),v=J(v,void 0,"message"),P=J(P,S.publicKey,"publicKey"),E!==void 0&&Ar(E,"zip215"),n&&(v=n(v));let w=A/2,_=b.subarray(0,w),R=Cn(b.subarray(w,A)),M,$,V;try{M=r.fromBytes(P,E),$=r.fromBytes(_,E),V=o.multiplyUnsafe(R)}catch{return!1}if(!E&&M.isSmallOrder())return!1;let z=m(C,$.toBytes(),M.toBytes(),v);return $.add(M.multiplyUnsafe(z)).subtract(V).clearCofactor().is0()}let T=s.BYTES,S={secretKey:T,publicKey:T,signature:2*T,seed:T};function D(b=a(S.seed)){return J(b,S.seed,"seed")}function H(b){return An(b)&&b.length===i.BYTES}function G(b,v){try{return!!r.fromBytes(b,v)}catch{return!1}}let j={getExtendedPublicKey:d,randomSecretKey:D,isValidSecretKey:H,isValidPublicKey:G,toMontgomery(b){let{y:v}=r.fromBytes(b),P=S.publicKey,N=P===32;if(!N&&P!==57)throw new Error("only defined for 25519 and 448");let C=N?s.div(Le+v,Le-v):s.div(v-Le,v+Le);return s.toBytes(C)},toMontgomerySecret(b){let v=S.secretKey;J(b,v);let P=e(b.subarray(0,v));return c(P).subarray(0,v)}};return Object.freeze({keygen:qa(D,h),getPublicKey:h,sign:g,verify:x,utils:j,Point:r,lengths:S})}var f2=BigInt(1),Py=BigInt(2);var d2=BigInt(5),h2=BigInt(8),Od=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),p2={p:Od,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:h2,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function m2(r){let e=BigInt(10),t=BigInt(20),n=BigInt(40),o=BigInt(80),s=Od,a=r*r%s*r%s,c=me(a,Py,s)*a%s,l=me(c,f2,s)*r%s,f=me(l,d2,s)*l%s,u=me(f,e,s)*f%s,d=me(u,t,s)*u%s,h=me(d,n,s)*d%s,m=me(h,o,s)*h%s,g=me(m,o,s)*h%s,y=me(g,e,s)*f%s;return{pow_p_5_8:me(y,Py,s)*r%s,b2:a}}function g2(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}var Dy=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function y2(r,e){let t=Od,n=Ee(e*e*e,t),o=Ee(n*n*e,t),s=m2(r*o).pow_p_5_8,i=Ee(r*n*s,t),a=Ee(e*i*i,t),c=i,l=Ee(i*Dy,t),f=a===r,u=a===Ee(-r,t),d=a===Ee(-r*Dy,t);return f&&(i=c),(u||d)&&(i=l),Ey(i,t)&&(i=Ee(-i,t)),{isValid:f||u,value:i}}var w2=By(p2,{uvRatio:y2});function b2(r){return Ly(w2,Xr,Object.assign({adjustScalarBytes:g2},r))}var Ws=b2({});var Pn=32,mt=64,Ud=32;var Lo,Ny=(async()=>{try{return await Se.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();function Ry(){let r=Ws.utils.randomSecretKey(),e=Ws.getPublicKey(r);return{privateKey:S2(r,e),publicKey:e}}async function x2(r,e){let t;r.length===mt?t=r.subarray(0,32):t=r;let n={crv:"Ed25519",kty:"OKP",x:U(r.subarray(32),"base64url"),d:U(t,"base64url"),ext:!0,key_ops:["sign"]},o=await Se.get().subtle.importKey("jwk",n,{name:"Ed25519"},!0,["sign"]),s=await Se.get().subtle.sign({name:"Ed25519"},o,e instanceof Uint8Array?e:e.subarray());return new Uint8Array(s,0,s.byteLength)}function v2(r,e){let t=r.subarray(0,Ud);return Ws.sign(e instanceof Uint8Array?e:e.subarray(),t)}async function My(r,e){return Lo==null&&(Lo=await Ny),Lo?x2(r,e):v2(r,e)}async function E2(r,e,t){if(r.buffer instanceof ArrayBuffer){let n=await Se.get().subtle.importKey("raw",r.buffer,{name:"Ed25519"},!1,["verify"]);return await Se.get().subtle.verify({name:"Ed25519"},n,e,t instanceof Uint8Array?t:t.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function A2(r,e,t){return Ws.verify(e,t instanceof Uint8Array?t:t.subarray(),r)}async function Oy(r,e,t){return Lo==null&&(Lo=await Ny),Lo?E2(r,e,t):A2(r,e,t)}function S2(r,e){let t=new Uint8Array(mt);for(let n=0;n<Ud;n++)t[n]=r[n],t[Ud+n]=e[n];return t}function Po(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var js=class{type="Ed25519";raw;constructor(e){this.raw=No(e,Pn)}toMultihash(){return We.digest(It(this))}toCID(){return K.createV1(114,this.toMultihash())}toString(){return le.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:X(this.raw,e.raw)}verify(e,t,n){n?.signal?.throwIfAborted();let o=Oy(this.raw,t,e);return Po(o)?o.then(s=>(n?.signal?.throwIfAborted(),s)):o}},Do=class{type="Ed25519";raw;publicKey;constructor(e,t){this.raw=No(e,mt),this.publicKey=new js(t)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:X(this.raw,e.raw)}sign(e,t){t?.signal?.throwIfAborted();let n=My(this.raw,e);return Po(n)?n.then(o=>(t?.signal?.throwIfAborted(),o)):(t?.signal?.throwIfAborted(),n)}};function Fd(r){if(r.length>mt){r=No(r,mt+Pn);let n=r.subarray(0,mt),o=r.subarray(mt,r.length);return new Do(n,o)}r=No(r,mt);let e=r.subarray(0,mt),t=r.subarray(Pn);return new Do(e,t)}function $d(r){return r=No(r,Pn),new js(r)}async function Fy(){let{privateKey:r,publicKey:e}=Ry();return new Do(r,e)}function No(r,e){if(r=Uint8Array.from(r??[]),r.length!==e)throw new k(`Key must be a Uint8Array of length ${e}, got ${r.length}`);return r}var I2=Math.pow(2,7),k2=Math.pow(2,14),_2=Math.pow(2,21),Vd=Math.pow(2,28),Kd=Math.pow(2,35),Hd=Math.pow(2,42),qd=Math.pow(2,49),ie=128,Ze=127;function Pe(r){if(r<I2)return 1;if(r<k2)return 2;if(r<_2)return 3;if(r<Vd)return 4;if(r<Kd)return 5;if(r<Hd)return 6;if(r<qd)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ro(r,e,t=0){switch(Pe(r)){case 8:e[t++]=r&255|ie,r/=128;case 7:e[t++]=r&255|ie,r/=128;case 6:e[t++]=r&255|ie,r/=128;case 5:e[t++]=r&255|ie,r/=128;case 4:e[t++]=r&255|ie,r>>>=7;case 3:e[t++]=r&255|ie,r>>>=7;case 2:e[t++]=r&255|ie,r>>>=7;case 1:{e[t++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return e}function C2(r,e,t=0){switch(Pe(r)){case 8:e.set(t++,r&255|ie),r/=128;case 7:e.set(t++,r&255|ie),r/=128;case 6:e.set(t++,r&255|ie),r/=128;case 5:e.set(t++,r&255|ie),r/=128;case 4:e.set(t++,r&255|ie),r>>>=7;case 3:e.set(t++,r&255|ie),r>>>=7;case 2:e.set(t++,r&255|ie),r>>>=7;case 1:{e.set(t++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return e}function zd(r,e){let t=r[e],n=0;if(n+=t&Ze,t<ie||(t=r[e+1],n+=(t&Ze)<<7,t<ie)||(t=r[e+2],n+=(t&Ze)<<14,t<ie)||(t=r[e+3],n+=(t&Ze)<<21,t<ie)||(t=r[e+4],n+=(t&Ze)*Vd,t<ie)||(t=r[e+5],n+=(t&Ze)*Kd,t<ie)||(t=r[e+6],n+=(t&Ze)*Hd,t<ie)||(t=r[e+7],n+=(t&Ze)*qd,t<ie))return n;throw new RangeError("Could not decode varint")}function T2(r,e){let t=r.get(e),n=0;if(n+=t&Ze,t<ie||(t=r.get(e+1),n+=(t&Ze)<<7,t<ie)||(t=r.get(e+2),n+=(t&Ze)<<14,t<ie)||(t=r.get(e+3),n+=(t&Ze)<<21,t<ie)||(t=r.get(e+4),n+=(t&Ze)*Vd,t<ie)||(t=r.get(e+5),n+=(t&Ze)*Kd,t<ie)||(t=r.get(e+6),n+=(t&Ze)*Hd,t<ie)||(t=r.get(e+7),n+=(t&Ze)*qd,t<ie))return n;throw new RangeError("Could not decode varint")}function en(r,e,t=0){return e==null&&(e=je(Pe(r))),e instanceof Uint8Array?Ro(r,e,t):C2(r,e,t)}function Dn(r,e=0){return r instanceof Uint8Array?zd(r,e):T2(r,e)}var Gd=new Float32Array([-0]),tn=new Uint8Array(Gd.buffer);function $y(r,e,t){Gd[0]=r,e[t]=tn[0],e[t+1]=tn[1],e[t+2]=tn[2],e[t+3]=tn[3]}function Vy(r,e){return tn[0]=r[e],tn[1]=r[e+1],tn[2]=r[e+2],tn[3]=r[e+3],Gd[0]}var Wd=new Float64Array([-0]),Xe=new Uint8Array(Wd.buffer);function Ky(r,e,t){Wd[0]=r,e[t]=Xe[0],e[t+1]=Xe[1],e[t+2]=Xe[2],e[t+3]=Xe[3],e[t+4]=Xe[4],e[t+5]=Xe[5],e[t+6]=Xe[6],e[t+7]=Xe[7]}function Hy(r,e){return Xe[0]=r[e],Xe[1]=r[e+1],Xe[2]=r[e+2],Xe[3]=r[e+3],Xe[4]=r[e+4],Xe[5]=r[e+5],Xe[6]=r[e+6],Xe[7]=r[e+7],Wd[0]}var B2=BigInt(Number.MAX_SAFE_INTEGER),L2=BigInt(Number.MIN_SAFE_INTEGER),gt=class r{lo;hi;constructor(e,t){this.lo=e|0,this.hi=t|0}toNumber(e=!1){if(!e&&this.hi>>>31>0){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(t+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(e=!1){if(e)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let t=~this.lo+1>>>0,n=~this.hi>>>0;return t===0&&(n=n+1>>>0),-(BigInt(t)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(e=!1){return this.toBigInt(e).toString()}zzEncode(){let e=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^e)>>>0,this.lo=(this.lo<<1^e)>>>0,this}zzDecode(){let e=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^e)>>>0,this.hi=(this.hi>>>1^e)>>>0,this}length(){let e=this.lo,t=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?t===0?e<16384?e<128?1:2:e<2097152?3:4:t<16384?t<128?5:6:t<2097152?7:8:n<128?9:10}static fromBigInt(e){if(e===0n)return Nn;if(e<B2&&e>L2)return this.fromNumber(Number(e));let t=e<0n;t&&(e=-e);let n=e>>32n,o=e-(n<<32n);return t&&(n=~n|0n,o=~o|0n,++o>qy&&(o=0n,++n>qy&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(e){if(e===0)return Nn;let t=e<0;t&&(e=-e);let n=e>>>0,o=(e-n)/4294967296>>>0;return t&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new r(n,o)}static from(e){return typeof e=="number"?r.fromNumber(e):typeof e=="bigint"?r.fromBigInt(e):typeof e=="string"?r.fromBigInt(BigInt(e)):e.low!=null||e.high!=null?new r(e.low>>>0,e.high>>>0):Nn}},Nn=new gt(0,0);Nn.toBigInt=function(){return 0n};Nn.zzEncode=Nn.zzDecode=function(){return this};Nn.length=function(){return 1};var qy=4294967296n;function zy(r){let e=0,t=0;for(let n=0;n<r.length;++n)t=r.charCodeAt(n),t<128?e+=1:t<2048?e+=2:(t&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,e+=4):e+=3;return e}function Gy(r,e,t){if(t-e<1)return"";let o,s=[],i=0,a;for(;e<t;)a=r[e++],a<128?s[i++]=a:a>191&&a<224?s[i++]=(a&31)<<6|r[e++]&63:a>239&&a<365?(a=((a&7)<<18|(r[e++]&63)<<12|(r[e++]&63)<<6|r[e++]&63)-65536,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&15)<<12|(r[e++]&63)<<6|r[e++]&63,i>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,s)),i=0);return o!=null?(i>0&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))}function jd(r,e,t){let n=t,o,s;for(let i=0;i<r.length;++i)o=r.charCodeAt(i),o<128?e[t++]=o:o<2048?(e[t++]=o>>6|192,e[t++]=o&63|128):(o&64512)===55296&&((s=r.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,e[t++]=o>>18|240,e[t++]=o>>12&63|128,e[t++]=o>>6&63|128,e[t++]=o&63|128):(e[t++]=o>>12|224,e[t++]=o>>6&63|128,e[t++]=o&63|128);return t-n}function Ft(r,e){return RangeError(`index out of range: ${r.pos} + ${e??1} > ${r.len}`)}function za(r,e){return(r[e-4]|r[e-3]<<8|r[e-2]<<16|r[e-1]<<24)>>>0}var Yd=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(e){this.buf=e,this.pos=0,this.len=e.length}uint32(){let e=4294967295;if(e=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(e=(e|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(e=(e|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return e;if((this.pos+=5)>this.len)throw this.pos=this.len,Ft(this,10);return e}int32(){return this.uint32()|0}sint32(){let e=this.uint32();return e>>>1^-(e&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Ft(this,4);return za(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ft(this,4);return za(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ft(this,4);let e=Vy(this.buf,this.pos);return this.pos+=4,e}double(){if(this.pos+8>this.len)throw Ft(this,4);let e=Hy(this.buf,this.pos);return this.pos+=8,e}bytes(){let e=this.uint32(),t=this.pos,n=this.pos+e;if(n>this.len)throw Ft(this,e);return this.pos+=e,t===n?new Uint8Array(0):this.buf.subarray(t,n)}string(){let e=this.bytes();return Gy(e,0,e.length)}skip(e){if(typeof e=="number"){if(this.pos+e>this.len)throw Ft(this,e);this.pos+=e}else do if(this.pos>=this.len)throw Ft(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(e){switch(e){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(e=this.uint32()&7)!==4;)this.skipType(e);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${e} at offset ${this.pos}`)}return this}readLongVarint(){let e=new gt(0,0),t=0;if(this.len-this.pos>4){for(;t<4;++t)if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e;if(e.lo=(e.lo|(this.buf[this.pos]&127)<<28)>>>0,e.hi=(e.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return e;t=0}else{for(;t<3;++t){if(this.pos>=this.len)throw Ft(this);if(e.lo=(e.lo|(this.buf[this.pos]&127)<<t*7)>>>0,this.buf[this.pos++]<128)return e}return e.lo=(e.lo|(this.buf[this.pos++]&127)<<t*7)>>>0,e}if(this.len-this.pos>4){for(;t<5;++t)if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}else for(;t<5;++t){if(this.pos>=this.len)throw Ft(this);if(e.hi=(e.hi|(this.buf[this.pos]&127)<<t*7+3)>>>0,this.buf[this.pos++]<128)return e}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Ft(this,8);let e=za(this.buf,this.pos+=4),t=za(this.buf,this.pos+=4);return new gt(e,t)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let e=zd(this.buf,this.pos);return this.pos+=Pe(e),e}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Zd(r){return new Yd(r instanceof Uint8Array?r:r.subarray())}function Oe(r,e,t){let n=Zd(r);return e.decode(n,void 0,t)}function Xd(r){let e=r??8192,t=e>>>1,n,o=e;return function(i){if(i<1||i>t)return je(i);o+i>e&&(n=je(e),o=0);let a=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),a}}var Rn=class{fn;len;next;val;constructor(e,t,n){this.fn=e,this.len=t,this.next=void 0,this.val=n}};function Jd(){}var eh=class{head;tail;len;next;constructor(e){this.head=e.head,this.tail=e.tail,this.len=e.len,this.next=e.states}},P2=Xd();function D2(r){return globalThis.Buffer!=null?je(r):P2(r)}var Xs=class{len;head;tail;states;constructor(){this.len=0,this.head=new Rn(Jd,0,0),this.tail=this.head,this.states=null}_push(e,t,n){return this.tail=this.tail.next=new Rn(e,t,n),this.len+=t,this}uint32(e){return this.len+=(this.tail=this.tail.next=new th((e=e>>>0)<128?1:e<16384?2:e<2097152?3:e<268435456?4:5,e)).len,this}int32(e){return e<0?this._push(Ga,10,gt.fromNumber(e)):this.uint32(e)}sint32(e){return this.uint32((e<<1^e>>31)>>>0)}uint64(e){let t=gt.fromBigInt(e);return this._push(Ga,t.length(),t)}uint64Number(e){return this._push(Ro,Pe(e),e)}uint64String(e){return this.uint64(BigInt(e))}int64(e){return this.uint64(e)}int64Number(e){return this.uint64Number(e)}int64String(e){return this.uint64String(e)}sint64(e){let t=gt.fromBigInt(e).zzEncode();return this._push(Ga,t.length(),t)}sint64Number(e){let t=gt.fromNumber(e).zzEncode();return this._push(Ga,t.length(),t)}sint64String(e){return this.sint64(BigInt(e))}bool(e){return this._push(Qd,1,e?1:0)}fixed32(e){return this._push(Zs,4,e>>>0)}sfixed32(e){return this.fixed32(e)}fixed64(e){let t=gt.fromBigInt(e);return this._push(Zs,4,t.lo)._push(Zs,4,t.hi)}fixed64Number(e){let t=gt.fromNumber(e);return this._push(Zs,4,t.lo)._push(Zs,4,t.hi)}fixed64String(e){return this.fixed64(BigInt(e))}sfixed64(e){return this.fixed64(e)}sfixed64Number(e){return this.fixed64Number(e)}sfixed64String(e){return this.fixed64String(e)}float(e){return this._push($y,4,e)}double(e){return this._push(Ky,8,e)}bytes(e){let t=e.length>>>0;return t===0?this._push(Qd,1,0):this.uint32(t)._push(R2,t,e)}string(e){let t=zy(e);return t!==0?this.uint32(t)._push(jd,t,e):this._push(Qd,1,0)}fork(){return this.states=new eh(this),this.head=this.tail=new Rn(Jd,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 Rn(Jd,0,0),this.len=0),this}ldelim(){let e=this.head,t=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=e.next,this.tail=t,this.len+=n),this}finish(){let e=this.head.next,t=D2(this.len),n=0;for(;e!=null;)e.fn(e.val,t,n),n+=e.len,e=e.next;return t}};function Qd(r,e,t){e[t]=r&255}function N2(r,e,t){for(;r>127;)e[t++]=r&127|128,r>>>=7;e[t]=r}var th=class extends Rn{next;constructor(e,t){super(N2,e,t),this.next=void 0}};function Ga(r,e,t){for(;r.hi!==0;)e[t++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)e[t++]=r.lo&127|128,r.lo=r.lo>>>7;e[t++]=r.lo}function Zs(r,e,t){e[t]=r&255,e[t+1]=r>>>8&255,e[t+2]=r>>>16&255,e[t+3]=r>>>24}function R2(r,e,t){e.set(r,t)}globalThis.Buffer!=null&&(Xs.prototype.bytes=function(r){let e=r.length>>>0;return this.uint32(e),e>0&&this._push(M2,e,r),this},Xs.prototype.string=function(r){let e=globalThis.Buffer.byteLength(r);return this.uint32(e),e>0&&this._push(O2,e,r),this});function M2(r,e,t){e.set(r,t)}function O2(r,e,t){r.length<40?jd(r,e,t):e.utf8Write!=null?e.utf8Write(r,t):e.set(B(r),t)}function rh(){return new Xs}function Ue(r,e){let t=rh();return e.encode(r,t,{lengthDelimited:!1}),t.finish()}var Mo;(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"})(Mo||(Mo={}));function Wa(r,e,t,n){return{name:r,type:e,encode:t,decode:n}}function Js(r){function e(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let t=function(s,i){let a=e(s);i.int32(a)},n=function(s){let i=s.int32();return e(i)};return Wa("enum",Mo.VARINT,t,n)}function Fe(r,e){return Wa("message",Mo.LENGTH_DELIMITED,r,e)}var Mn=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"},Qs=class extends Error{code="ERR_MAX_SIZE";name="MaxSizeError"};var ue;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(ue||(ue={}));var nh;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(nh||(nh={}));(function(r){r.codec=()=>Js(nh)})(ue||(ue={}));var fr;(function(r){let e;r.codec=()=>(e==null&&(e=Fe((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),ue.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),o.lengthDelimited!==!1&&n.ldelim()},(t,n,o={})=>{let s={},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let a=t.uint32();switch(a>>>3){case 1:{s.Type=ue.codec().decode(t);break}case 2:{s.Data=t.bytes();break}default:{t.skipType(a&7);break}}}return s})),e),r.encode=t=>Ue(t,r.codec()),r.decode=(t,n)=>Oe(t,r.codec(),n)})(fr||(fr={}));var ei;(function(r){let e;r.codec=()=>(e==null&&(e=Fe((t,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),t.Type!=null&&(n.uint32(8),ue.codec().encode(t.Type,n)),t.Data!=null&&(n.uint32(18),n.bytes(t.Data)),o.lengthDelimited!==!1&&n.ldelim()},(t,n,o={})=>{let s={},i=n==null?t.len:t.pos+n;for(;t.pos<i;){let a=t.uint32();switch(a>>>3){case 1:{s.Type=ue.codec().decode(t);break}case 2:{s.Data=t.bytes();break}default:{t.skipType(a&7);break}}}return s})),e),r.encode=t=>Ue(t,r.codec()),r.decode=(t,n)=>Oe(t,r.codec(),n)})(ei||(ei={}));function $t(r){if(isNaN(r)||r<=0)throw new k("random bytes length must be a Number bigger than 0");return Gr(r)}var ri={};Ae(ri,{MAX_RSA_KEY_SIZE:()=>oh,generateRSAKeyPair:()=>hh,jwkToJWKKeyPair:()=>Xy,jwkToPkcs1:()=>V2,jwkToPkix:()=>ch,jwkToRSAPrivateKey:()=>dh,pkcs1MessageToJwk:()=>ih,pkcs1MessageToRSAPrivateKey:()=>ja,pkcs1ToJwk:()=>$2,pkcs1ToRSAPrivateKey:()=>lh,pkixMessageToJwk:()=>ah,pkixMessageToRSAPublicKey:()=>fh,pkixToJwk:()=>K2,pkixToRSAPublicKey:()=>uh});var Oo=class{type="RSA";jwk;_raw;_multihash;constructor(e,t){this.jwk=e,this._multihash=t}get raw(){return this._raw==null&&(this._raw=ri.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return K.createV1(114,this._multihash)}toString(){return le.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:X(this.raw,e.raw)}verify(e,t,n){return Zy(this.jwk,t,e,n)}},ti=class{type="RSA";jwk;_raw;publicKey;constructor(e,t){this.jwk=e,this.publicKey=t}get raw(){return this._raw==null&&(this._raw=ri.jwkToPkcs1(this.jwk)),this._raw}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:X(this.raw,e.raw)}sign(e,t){return Yy(this.jwk,e,t)}};var oh=8192,sh=18,U2=1062,F2=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function $2(r){let e=St(r);return ih(e)}function ih(r){return{n:U(r[1],"base64url"),e:U(r[2],"base64url"),d:U(r[3],"base64url"),p:U(r[4],"base64url"),q:U(r[5],"base64url"),dp:U(r[6],"base64url"),dq:U(r[7],"base64url"),qi:U(r[8],"base64url"),kty:"RSA"}}function V2(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 k("JWK was missing components");return Ot([rt(Uint8Array.from([0])),rt(B(r.n,"base64url")),rt(B(r.e,"base64url")),rt(B(r.d,"base64url")),rt(B(r.p,"base64url")),rt(B(r.q,"base64url")),rt(B(r.dp,"base64url")),rt(B(r.dq,"base64url")),rt(B(r.qi,"base64url"))]).subarray()}function K2(r){let e=St(r,{offset:0});return ah(e)}function ah(r){let e=St(r[1],{offset:0});return{kty:"RSA",n:U(e[0],"base64url"),e:U(e[1],"base64url")}}function ch(r){if(r.n==null||r.e==null)throw new k("JWK was missing components");return Ot([F2,Us(Ot([rt(B(r.n,"base64url")),rt(B(r.e,"base64url"))]))]).subarray()}function lh(r){let e=St(r);return ja(e)}function ja(r){let e=ih(r);return dh(e)}function uh(r,e){if(r.byteLength>=U2)throw new ho("Key size is too large");let t=St(r,{offset:0});return fh(t,r,e)}function fh(r,e,t){let n=ah(r);if(t==null){let o=Zr(fr.encode({Type:ue.RSA,Data:e}));t=cr(sh,o)}return new Oo(n,t)}function dh(r){if(Qy(r)>oh)throw new k("Key size is too large");let e=Xy(r),t=Zr(fr.encode({Type:ue.RSA,Data:ch(e.publicKey)})),n=cr(sh,t);return new ti(e.privateKey,new Oo(e.publicKey,n))}async function hh(r){if(r>oh)throw new k("Key size is too large");let e=await Jy(r),t=Zr(fr.encode({Type:ue.RSA,Data:ch(e.publicKey)})),n=cr(sh,t);return new ti(e.privateKey,new Oo(e.publicKey,n))}function Xy(r){if(r==null)throw new k("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function Jy(r,e){let t=await Se.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]);e?.signal?.throwIfAborted();let n=await H2(t,e);return{privateKey:n[0],publicKey:n[1]}}async function Yy(r,e,t){let n=await Se.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);t?.signal?.throwIfAborted();let o=await Se.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,e instanceof Uint8Array?e:e.subarray());return t?.signal?.throwIfAborted(),new Uint8Array(o,0,o.byteLength)}async function Zy(r,e,t,n){let o=await Se.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let s=await Se.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},o,e,t instanceof Uint8Array?t:t.subarray());return n?.signal?.throwIfAborted(),s}async function H2(r,e){if(r.privateKey==null||r.publicKey==null)throw new k("Private and public key are required");let t=await Promise.all([Se.get().subtle.exportKey("jwk",r.privateKey),Se.get().subtle.exportKey("jwk",r.publicKey)]);return e?.signal?.throwIfAborted(),t}function Qy(r){if(r.kty!=="RSA")throw new k("invalid key type");if(r.n==null)throw new k("invalid key modulus");return B(r.n,"base64url").length*8}var Ya=class{oHash;iHash;blockLen;outputLen;finished=!1;destroyed=!1;constructor(e,t){if(So(e),J(t,void 0,"key"),this.iHash=e.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let n=this.blockLen,o=new Uint8Array(n);o.set(t.length>n?e.create().update(t).digest():t);for(let s=0;s<o.length;s++)o[s]^=54;this.iHash.update(o),this.oHash=e.create();for(let s=0;s<o.length;s++)o[s]^=106;this.oHash.update(o),at(o)}update(e){return Io(this),this.iHash.update(e),this}digestInto(e){Io(this),J(e,this.outputLen,"output"),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){let e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||=Object.create(Object.getPrototypeOf(this),{});let{oHash:t,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return e=e,e.finished=o,e.destroyed=s,e.blockLen=i,e.outputLen=a,e.oHash=t._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},ni=(r,e,t)=>new Ya(r,e).update(t).digest();ni.create=(r,e)=>new Ya(r,e);var e0=(r,e)=>(r+(r>=0?e:-e)/t0)/e;function q2(r,e,t){let[[n,o],[s,i]]=e,a=e0(i*r,t),c=e0(-o*r,t),l=r-a*n-c*s,f=-a*o-c*i,u=l<Sr,d=f<Sr;u&&(l=-l),d&&(f=-f);let h=qs(Math.ceil(_d(t)/2))+Uo;if(l<Sr||l>=h||f<Sr||f>=h)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:u,k1:l,k2neg:d,k2:f}}function mh(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function ph(r,e){let t={};for(let n of Object.keys(e))t[n]=r[n]===void 0?e[n]:r[n];return Ar(t.lowS,"lowS"),Ar(t.prehash,"prehash"),t.format!==void 0&&mh(t.format),t}var gh=class extends Error{constructor(e=""){super(e)}},rn={Err:gh,_tlv:{encode:(r,e)=>{let{Err:t}=rn;if(r<0||r>256)throw new t("tlv.encode: wrong tag");if(e.length&1)throw new t("tlv.encode: unpadded data");let n=e.length/2,o=Ks(n);if(o.length/2&128)throw new t("tlv.encode: long form length too big");let s=n>127?Ks(o.length/2|128):"";return Ks(r)+s+o+e},decode(r,e){let{Err:t}=rn,n=0;if(r<0||r>256)throw new t("tlv.encode: wrong tag");if(e.length<2||e[n++]!==r)throw new t("tlv.decode: wrong tlv");let o=e[n++],s=!!(o&128),i=0;if(!s)i=o;else{let c=o&127;if(!c)throw new t("tlv.decode(long): indefinite length not supported");if(c>4)throw new t("tlv.decode(long): byte length is too big");let l=e.subarray(n,n+c);if(l.length!==c)throw new t("tlv.decode: length bytes not complete");if(l[0]===0)throw new t("tlv.decode(long): zero leftmost byte");for(let f of l)i=i<<8|f;if(n+=c,i<128)throw new t("tlv.decode(long): not minimal encoding")}let a=e.subarray(n,n+i);if(a.length!==i)throw new t("tlv.decode: wrong value length");return{v:a,l:e.subarray(n+i)}}},_int:{encode(r){let{Err:e}=rn;if(r<Sr)throw new e("integer: negative integers are not allowed");let t=Ks(r);if(Number.parseInt(t[0],16)&8&&(t="00"+t),t.length&1)throw new e("unexpected DER parsing assertion: unpadded hex");return t},decode(r){let{Err:e}=rn;if(r[0]&128)throw new e("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return ko(r)}},toSig(r){let{Err:e,_int:t,_tlv:n}=rn,o=J(r,void 0,"signature"),{v:s,l:i}=n.decode(48,o);if(i.length)throw new e("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,s),{v:l,l:f}=n.decode(2,c);if(f.length)throw new e("invalid signature: left bytes after parsing");return{r:t.decode(a),s:t.decode(l)}},hexFromSig(r){let{_tlv:e,_int:t}=rn,n=e.encode(2,t.encode(r.r)),o=e.encode(2,t.encode(r.s)),s=n+o;return e.encode(48,s)}},Sr=BigInt(0),Uo=BigInt(1),t0=BigInt(2),Za=BigInt(3),z2=BigInt(4);function r0(r,e={}){let t=Ha("weierstrass",r,e),{Fp:n,Fn:o}=t,s=t.CURVE,{h:i,n:a}=s;Jr(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});let{endo:c}=e;if(c&&(!n.is0(s.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');let l=o0(n,o);function f(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function u(C,E,A){let{x:w,y:_}=E.toAffine(),R=n.toBytes(w);if(Ar(A,"isCompressed"),A){f();let M=!n.isOdd(_);return ct(n0(M),R)}else return ct(Uint8Array.of(4),R,n.toBytes(_))}function d(C){J(C,void 0,"Point");let{publicKey:E,publicKeyUncompressed:A}=l,w=C.length,_=C[0],R=C.subarray(1);if(w===E&&(_===2||_===3)){let M=n.fromBytes(R);if(!n.isValid(M))throw new Error("bad point: is not on curve, wrong x");let $=g(M),V;try{V=n.sqrt($)}catch(ye){let he=ye instanceof Error?": "+ye.message:"";throw new Error("bad point: is not on curve, sqrt error"+he)}f();let z=n.isOdd(V);return(_&1)===1!==z&&(V=n.neg(V)),{x:M,y:V}}else if(w===A&&_===4){let M=n.BYTES,$=n.fromBytes(R.subarray(0,M)),V=n.fromBytes(R.subarray(M,M*2));if(!y($,V))throw new Error("bad point: is not on curve");return{x:$,y:V}}else throw new Error(`bad point: got length ${w}, expected compressed=${E} or uncompressed=${A}`)}let h=e.toBytes||u,m=e.fromBytes||d;function g(C){let E=n.sqr(C),A=n.mul(E,C);return n.add(n.add(A,n.mul(C,s.a)),s.b)}function y(C,E){let A=n.sqr(E),w=g(C);return n.eql(A,w)}if(!y(s.Gx,s.Gy))throw new Error("bad curve params: generator point");let x=n.mul(n.pow(s.a,Za),z2),T=n.mul(n.sqr(s.b),BigInt(27));if(n.is0(n.add(x,T)))throw new Error("bad curve params: a or b");function S(C,E,A=!1){if(!n.isValid(E)||A&&n.is0(E))throw new Error(`bad point coordinate ${C}`);return E}function D(C){if(!(C instanceof v))throw new Error("Weierstrass Point expected")}function H(C){if(!c||!c.basises)throw new Error("no endo");return q2(C,c.basises,o.ORDER)}let G=_o((C,E)=>{let{X:A,Y:w,Z:_}=C;if(n.eql(_,n.ONE))return{x:A,y:w};let R=C.is0();E==null&&(E=R?n.ONE:n.inv(_));let M=n.mul(A,E),$=n.mul(w,E),V=n.mul(_,E);if(R)return{x:n.ZERO,y:n.ZERO};if(!n.eql(V,n.ONE))throw new Error("invZ was invalid");return{x:M,y:$}}),j=_o(C=>{if(C.is0()){if(e.allowInfinityPoint&&!n.is0(C.Y))return;throw new Error("bad point: ZERO")}let{x:E,y:A}=C.toAffine();if(!n.isValid(E)||!n.isValid(A))throw new Error("bad point: x or y not field elements");if(!y(E,A))throw new Error("bad point: equation left != right");if(!C.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function b(C,E,A,w,_){return A=new v(n.mul(A.X,C),A.Y,A.Z),E=Gs(w,E),A=Gs(_,A),E.add(A)}class v{static BASE=new v(s.Gx,s.Gy,n.ONE);static ZERO=new v(n.ZERO,n.ONE,n.ZERO);static Fp=n;static Fn=o;X;Y;Z;constructor(E,A,w){this.X=S("x",E),this.Y=S("y",A,!0),this.Z=S("z",w),Object.freeze(this)}static CURVE(){return s}static fromAffine(E){let{x:A,y:w}=E||{};if(!E||!n.isValid(A)||!n.isValid(w))throw new Error("invalid affine point");if(E instanceof v)throw new Error("projective point not allowed");return n.is0(A)&&n.is0(w)?v.ZERO:new v(A,w,n.ONE)}static fromBytes(E){let A=v.fromAffine(m(J(E,void 0,"point")));return A.assertValidity(),A}static fromHex(E){return v.fromBytes(vr(E))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(E=8,A=!0){return N.createCache(this,E),A||this.multiply(Za),this}assertValidity(){j(this)}hasEvenY(){let{y:E}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(E)}equals(E){D(E);let{X:A,Y:w,Z:_}=this,{X:R,Y:M,Z:$}=E,V=n.eql(n.mul(A,$),n.mul(R,_)),z=n.eql(n.mul(w,$),n.mul(M,_));return V&&z}negate(){return new v(this.X,n.neg(this.Y),this.Z)}double(){let{a:E,b:A}=s,w=n.mul(A,Za),{X:_,Y:R,Z:M}=this,$=n.ZERO,V=n.ZERO,z=n.ZERO,Z=n.mul(_,_),ye=n.mul(R,R),he=n.mul(M,M),ne=n.mul(_,R);return ne=n.add(ne,ne),z=n.mul(_,M),z=n.add(z,z),$=n.mul(E,z),V=n.mul(w,he),V=n.add($,V),$=n.sub(ye,V),V=n.add(ye,V),V=n.mul($,V),$=n.mul(ne,$),z=n.mul(w,z),he=n.mul(E,he),ne=n.sub(Z,he),ne=n.mul(E,ne),ne=n.add(ne,z),z=n.add(Z,Z),Z=n.add(z,Z),Z=n.add(Z,he),Z=n.mul(Z,ne),V=n.add(V,Z),he=n.mul(R,M),he=n.add(he,he),Z=n.mul(he,ne),$=n.sub($,Z),z=n.mul(he,ye),z=n.add(z,z),z=n.add(z,z),new v($,V,z)}add(E){D(E);let{X:A,Y:w,Z:_}=this,{X:R,Y:M,Z:$}=E,V=n.ZERO,z=n.ZERO,Z=n.ZERO,ye=s.a,he=n.mul(s.b,Za),ne=n.mul(A,R),we=n.mul(w,M),Re=n.mul(_,$),nr=n.add(A,w),be=n.add(R,M);nr=n.mul(nr,be),be=n.add(ne,we),nr=n.sub(nr,be),be=n.add(A,_);let Ge=n.add(R,$);return be=n.mul(be,Ge),Ge=n.add(ne,Re),be=n.sub(be,Ge),Ge=n.add(w,_),V=n.add(M,$),Ge=n.mul(Ge,V),V=n.add(we,Re),Ge=n.sub(Ge,V),Z=n.mul(ye,be),V=n.mul(he,Re),Z=n.add(V,Z),V=n.sub(we,Z),Z=n.add(we,Z),z=n.mul(V,Z),we=n.add(ne,ne),we=n.add(we,ne),Re=n.mul(ye,Re),be=n.mul(he,be),we=n.add(we,Re),Re=n.sub(ne,Re),Re=n.mul(ye,Re),be=n.add(be,Re),ne=n.mul(we,be),z=n.add(z,ne),ne=n.mul(Ge,be),V=n.mul(nr,V),V=n.sub(V,ne),ne=n.mul(nr,we),Z=n.mul(Ge,Z),Z=n.add(Z,ne),new v(V,z,Z)}subtract(E){return this.add(E.negate())}is0(){return this.equals(v.ZERO)}multiply(E){let{endo:A}=e;if(!o.isValidNot0(E))throw new Error("invalid scalar: out of range");let w,_,R=M=>N.cached(this,M,$=>Ln(v,$));if(A){let{k1neg:M,k1:$,k2neg:V,k2:z}=H(E),{p:Z,f:ye}=R($),{p:he,f:ne}=R(z);_=ye.add(ne),w=b(A.beta,Z,he,M,V)}else{let{p:M,f:$}=R(E);w=M,_=$}return Ln(v,[w,_])[0]}multiplyUnsafe(E){let{endo:A}=e,w=this;if(!o.isValid(E))throw new Error("invalid scalar: out of range");if(E===Sr||w.is0())return v.ZERO;if(E===Uo)return w;if(N.hasCache(this))return this.multiply(E);if(A){let{k1neg:_,k1:R,k2neg:M,k2:$}=H(E),{p1:V,p2:z}=Ty(v,w,R,$);return b(A.beta,V,z,_,M)}else return N.unsafe(w,E)}toAffine(E){return G(this,E)}isTorsionFree(){let{isTorsionFree:E}=e;return i===Uo?!0:E?E(v,this):N.unsafe(this,a).is0()}clearCofactor(){let{clearCofactor:E}=e;return i===Uo?this:E?E(v,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(E=!0){return Ar(E,"isCompressed"),this.assertValidity(),h(v,this,E)}toHex(E=!0){return xr(this.toBytes(E))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}let P=o.BITS,N=new Bo(v,e.endo?Math.ceil(P/2):P);return v.BASE.precompute(8),v}function n0(r){return Uint8Array.of(r?2:3)}function o0(r,e){return{secretKey:e.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function G2(r,e={}){let{Fn:t}=r,n=e.randomBytes||Gr,o=Object.assign(o0(r.Fp,t),{seed:Ld(t.ORDER)});function s(h){try{let m=t.fromBytes(h);return t.isValidNot0(m)}catch{return!1}}function i(h,m){let{publicKey:g,publicKeyUncompressed:y}=o;try{let x=h.length;return m===!0&&x!==g||m===!1&&x!==y?!1:!!r.fromBytes(h)}catch{return!1}}function a(h=n(o.seed)){return Pd(J(h,o.seed,"seed"),t.ORDER)}function c(h,m=!0){return r.BASE.multiply(t.fromBytes(h)).toBytes(m)}function l(h){let{secretKey:m,publicKey:g,publicKeyUncompressed:y}=o;if(!An(h)||"_lengths"in t&&t._lengths||m===g)return;let x=J(h,void 0,"key").length;return x===g||x===y}function f(h,m,g=!0){if(l(h)===!0)throw new Error("first arg must be private key");if(l(m)===!1)throw new Error("second arg must be public key");let y=t.fromBytes(h);return r.fromBytes(m).multiply(y).toBytes(g)}let u={isValidSecretKey:s,isValidPublicKey:i,randomSecretKey:a},d=qa(a,c);return Object.freeze({getPublicKey:c,getSharedSecret:f,keygen:d,Point:r,utils:u,lengths:o})}function s0(r,e,t={}){So(e),Jr(t,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),t=Object.assign({},t);let n=t.randomBytes||Gr,o=t.hmac||((A,w)=>ni(e,A,w)),{Fp:s,Fn:i}=r,{ORDER:a,BITS:c}=i,{keygen:l,getPublicKey:f,getSharedSecret:u,utils:d,lengths:h}=G2(r,t),m={prehash:!0,lowS:typeof t.lowS=="boolean"?t.lowS:!0,format:"compact",extraEntropy:!1},g=a*t0<s.ORDER;function y(A){let w=a>>Uo;return A>w}function x(A,w){if(!i.isValidNot0(w))throw new Error(`invalid signature ${A}: out of range 1..Point.Fn.ORDER`);return w}function T(){if(g)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function S(A,w){mh(w);let _=h.signature,R=w==="compact"?_:w==="recovered"?_+1:void 0;return J(A,R)}class D{r;s;recovery;constructor(w,_,R){if(this.r=x("r",w),this.s=x("s",_),R!=null){if(T(),![0,1,2,3].includes(R))throw new Error("invalid recovery id");this.recovery=R}Object.freeze(this)}static fromBytes(w,_=m.format){S(w,_);let R;if(_==="der"){let{r:z,s:Z}=rn.toSig(J(w));return new D(z,Z)}_==="recovered"&&(R=w[0],_="compact",w=w.subarray(1));let M=h.signature/2,$=w.subarray(0,M),V=w.subarray(M,M*2);return new D(i.fromBytes($),i.fromBytes(V),R)}static fromHex(w,_){return this.fromBytes(vr(w),_)}assertRecovery(){let{recovery:w}=this;if(w==null)throw new Error("invalid recovery id: must be present");return w}addRecoveryBit(w){return new D(this.r,this.s,w)}recoverPublicKey(w){let{r:_,s:R}=this,M=this.assertRecovery(),$=M===2||M===3?_+a:_;if(!s.isValid($))throw new Error("invalid recovery id: sig.r+curve.n != R.x");let V=s.toBytes($),z=r.fromBytes(ct(n0((M&1)===0),V)),Z=i.inv($),ye=G(J(w,void 0,"msgHash")),he=i.create(-ye*Z),ne=i.create(R*Z),we=r.BASE.multiplyUnsafe(he).add(z.multiplyUnsafe(ne));if(we.is0())throw new Error("invalid recovery: point at infinify");return we.assertValidity(),we}hasHighS(){return y(this.s)}toBytes(w=m.format){if(mh(w),w==="der")return vr(rn.hexFromSig(this));let{r:_,s:R}=this,M=i.toBytes(_),$=i.toBytes(R);return w==="recovered"?(T(),ct(Uint8Array.of(this.assertRecovery()),M,$)):ct(M,$)}toHex(w){return xr(this.toBytes(w))}}let H=t.bits2int||function(w){if(w.length>8192)throw new Error("input is too large");let _=ko(w),R=w.length*8-c;return R>0?_>>BigInt(R):_},G=t.bits2int_modN||function(w){return i.create(H(w))},j=qs(c);function b(A){return Hs("num < 2^"+c,A,Sr,j),i.toBytes(A)}function v(A,w){return J(A,void 0,"message"),w?J(e(A),void 0,"prehashed message"):A}function P(A,w,_){let{lowS:R,prehash:M,extraEntropy:$}=ph(_,m);A=v(A,M);let V=G(A),z=i.fromBytes(w);if(!i.isValidNot0(z))throw new Error("invalid private key");let Z=[b(z),b(V)];if($!=null&&$!==!1){let we=$===!0?n(h.secretKey):$;Z.push(J(we,void 0,"extraEntropy"))}let ye=ct(...Z),he=V;function ne(we){let Re=H(we);if(!i.isValidNot0(Re))return;let nr=i.inv(Re),be=r.BASE.multiply(Re).toAffine(),Ge=i.create(be.x);if(Ge===Sr)return;let ba=i.create(nr*i.create(he+Ge*z));if(ba===Sr)return;let ig=(be.x===Ge?0:2)|Number(be.y&Uo),ag=ba;return R&&y(ba)&&(ag=i.neg(ba),ig^=1),new D(Ge,ag,g?void 0:ig)}return{seed:ye,k2sig:ne}}function N(A,w,_={}){let{seed:R,k2sig:M}=P(A,w,_);return dy(e.outputLen,i.BYTES,o)(R,M).toBytes(_.format)}function C(A,w,_,R={}){let{lowS:M,prehash:$,format:V}=ph(R,m);if(_=J(_,void 0,"publicKey"),w=v(w,$),!An(A)){let z=A instanceof D?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+z)}S(A,V);try{let z=D.fromBytes(A,V),Z=r.fromBytes(_);if(M&&z.hasHighS())return!1;let{r:ye,s:he}=z,ne=G(w),we=i.inv(he),Re=i.create(ne*we),nr=i.create(ye*we),be=r.BASE.multiplyUnsafe(Re).add(Z.multiplyUnsafe(nr));return be.is0()?!1:i.create(be.x)===ye}catch{return!1}}function E(A,w,_={}){let{prehash:R}=ph(_,m);return w=v(w,R),D.fromBytes(A,"recovered").recoverPublicKey(w).toBytes()}return Object.freeze({keygen:l,getPublicKey:f,getSharedSecret:u,utils:d,lengths:h,Point:r,sign:N,verify:C,recoverPublicKey:E,Signature:D,hash:e})}var wh={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},W2={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]};var i0=BigInt(2);function j2(r){let e=wh.p,t=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%e,f=l*l*r%e,u=me(f,t,e)*f%e,d=me(u,t,e)*f%e,h=me(d,i0,e)*l%e,m=me(h,o,e)*h%e,g=me(m,s,e)*m%e,y=me(g,a,e)*g%e,x=me(y,c,e)*y%e,T=me(x,a,e)*g%e,S=me(T,t,e)*f%e,D=me(S,i,e)*m%e,H=me(D,n,e)*l%e,G=me(H,i0,e);if(!yh.eql(yh.sqr(G),r))throw new Error("Cannot find square root");return G}var yh=Co(wh.p,{sqrt:j2}),Y2=r0(wh,{Fp:yh,endo:W2}),Vt=s0(Y2,Zr);var a0=32;function c0(r,e,t){let n=Mt.digest(e instanceof Uint8Array?e:e.subarray());if(Po(n))return n.then(({digest:o})=>(t?.signal?.throwIfAborted(),Vt.sign(o,r,{prehash:!1,format:"der"}))).catch(o=>{throw o.name==="AbortError"?o:new Cs(String(o))});try{return Vt.sign(n.digest,r,{prehash:!1,format:"der"})}catch(o){throw new Cs(String(o))}}function l0(r,e,t,n){let o=Mt.digest(t instanceof Uint8Array?t:t.subarray());if(Po(o))return o.then(({digest:s})=>(n?.signal?.throwIfAborted(),Vt.verify(e,s,r,{prehash:!1,format:"der"}))).catch(s=>{throw s.name==="AbortError"?s:new Ts(String(s))});try{return n?.signal?.throwIfAborted(),Vt.verify(e,o.digest,r,{prehash:!1,format:"der"})}catch(s){throw new Ts(String(s))}}var oi=class{type="secp256k1";raw;_key;constructor(e){this._key=d0(e),this.raw=u0(this._key)}toMultihash(){return We.digest(It(this))}toCID(){return K.createV1(114,this.toMultihash())}toString(){return le.encode(this.toMultihash().bytes).substring(1)}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:X(this.raw,e.raw)}verify(e,t,n){return l0(this._key,t,e,n)}},si=class{type="secp256k1";raw;publicKey;constructor(e,t){this.raw=f0(e),this.publicKey=new oi(t??h0(e))}equals(e){return e==null||!(e.raw instanceof Uint8Array)?!1:X(this.raw,e.raw)}sign(e,t){return c0(this.raw,e,t)}};function bh(r){return new si(r)}function xh(r){return new oi(r)}async function p0(){let r=Z2();return new si(r)}function u0(r){return Vt.Point.fromBytes(r).toBytes()}function f0(r){try{return Vt.getPublicKey(r,!0),r}catch(e){throw new Is(String(e))}}function d0(r){try{return Vt.Point.fromBytes(r),r}catch(e){throw new ho(String(e))}}function h0(r){try{return Vt.getPublicKey(r,!0)}catch(e){throw new Is(String(e))}}function Z2(){return Vt.utils.randomSecretKey()}async function Xa(r,e){if(r==="Ed25519")return Fy();if(r==="secp256k1")return p0();if(r==="RSA")return hh(X2(e));if(r==="ECDSA")return Yg(J2(e));throw new Nt}function nn(r,e){let{Type:t,Data:n}=fr.decode(r),o=n??new Uint8Array;switch(t){case ue.RSA:return uh(o,e);case ue.Ed25519:return $d(o);case ue.secp256k1:return xh(o);case ue.ECDSA:return md(o);default:throw new Nt}}function Ja(r){let{Type:e,Data:t}=fr.decode(r.digest),n=t??new Uint8Array;switch(e){case ue.Ed25519:return $d(n);case ue.secp256k1:return xh(n);case ue.ECDSA:return md(n);default:throw new Nt}}function It(r){return fr.encode({Type:ue[r.type],Data:r.raw})}function m0(r){let e=ei.decode(r),t=e.Data??new Uint8Array;switch(e.Type){case ue.RSA:return lh(t);case ue.Ed25519:return Fd(t);case ue.secp256k1:return bh(t);case ue.ECDSA:return qg(t);default:throw new Nt}}function g0(r){if(r.byteLength===mt)return Fd(r);if(r.byteLength===a0)return bh(r);let e=St(r),t=e[2]?.[0];if(t===Rg||t===Mg||t===Og)return pd(e);if(e.length>8)return ja(e);throw new k("Could not extract private key from raw bytes")}function On(r){return ei.encode({Type:ue[r.type],Data:r.raw})}function X2(r){return r==null?2048:parseInt(r,10)}function J2(r){if(r==="P-256"||r==null)return"P-256";if(r==="P-384")return"P-384";if(r==="P-521")return"P-521";throw new k("Unsupported curve, should be P-256, P-384 or P-521")}var ii=Uint32Array.from([1732584193,4023233417,2562383102,271733878,3285377520]),on=new Uint32Array(80),vh=class extends In{A=ii[0]|0;B=ii[1]|0;C=ii[2]|0;D=ii[3]|0;E=ii[4]|0;constructor(){super(64,20,8,!1)}get(){let{A:e,B:t,C:n,D:o,E:s}=this;return[e,t,n,o,s]}set(e,t,n,o,s){this.A=e|0,this.B=t|0,this.C=n|0,this.D=o|0,this.E=s|0}process(e,t){for(let c=0;c<16;c++,t+=4)on[c]=e.getUint32(t,!1);for(let c=16;c<80;c++)on[c]=Ma(on[c-3]^on[c-8]^on[c-14]^on[c-16],1);let{A:n,B:o,C:s,D:i,E:a}=this;for(let c=0;c<80;c++){let l,f;c<20?(l=Oa(o,s,i),f=1518500249):c<40?(l=o^s^i,f=1859775393):c<60?(l=Ua(o,s,i),f=2400959708):(l=o^s^i,f=3395469782);let u=Ma(n,5)+l+a+f+on[c]|0;a=i,i=s,s=Ma(o,30),o=n,n=u}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,this.set(n,o,s,i,a)}roundClean(){at(on)}destroy(){this.set(0,0,0,0,0),at(this.buffer)}},y0=Fs(()=>new vh);function w0(r,e,t,n){So(r);let o=ey({dkLen:32,asyncTick:10},n),{c:s,dkLen:i,asyncTick:a}=o;if(it(s,"c"),it(i,"dkLen"),it(a,"asyncTick"),s<1)throw new Error("iterations (c) must be >= 1");let c=gd(e,"password"),l=gd(t,"salt"),f=new Uint8Array(i),u=ni.create(r,c),d=u._cloneInto().update(l);return{c:s,dkLen:i,asyncTick:a,DK:f,PRF:u,PRFSalt:d}}function b0(r,e,t,n,o){return r.destroy(),e.destroy(),n&&n.destroy(),at(o),t}function x0(r,e,t,n){let{c:o,dkLen:s,DK:i,PRF:a,PRFSalt:c}=w0(r,e,t,n),l,f=new Uint8Array(4),u=Sn(f),d=new Uint8Array(a.outputLen);for(let h=1,m=0;m<s;h++,m+=a.outputLen){let g=i.subarray(m,m+a.outputLen);u.setInt32(0,h,!1),(l=c._cloneInto(l)).update(f).digestInto(d),g.set(d.subarray(0,g.length));for(let y=1;y<o;y++){a._cloneInto(l).update(d).digestInto(d);for(let x=0;x<g.length;x++)g[x]^=d[x]}}return b0(a,c,i,l,d)}async function Qa(r,e,t,n){let{c:o,dkLen:s,asyncTick:i,DK:a,PRF:c,PRFSalt:l}=w0(r,e,t,n),f,u=new Uint8Array(4),d=Sn(u),h=new Uint8Array(c.outputLen);for(let m=1,g=0;g<s;m++,g+=c.outputLen){let y=a.subarray(g,g+c.outputLen);d.setInt32(0,m,!1),(f=l._cloneInto(f)).update(u).digestInto(h),y.set(h.subarray(0,y.length)),await Qg(o-1,i,()=>{c._cloneInto(f).update(h).digestInto(h);for(let x=0;x<y.length;x++)y[x]^=h[x]})}return b0(c,l,a,f,h)}var v0={sha1:y0,"sha2-256":Zr,"sha2-512":Xr};function ai(r,e,t,n,o){if(o!=="sha1"&&o!=="sha2-256"&&o!=="sha2-512"){let a=Object.keys(v0).join(" / ");throw new k(`Hash '${o}' is unknown or not supported. Must be ${a}`)}let s=v0[o],i=x0(s,r,e,{c:t,dkLen:n});return Ye.encode(i).substring(1)}var Eh={32:16777619n,64:1099511628211n,128:309485009821345068724781371n,256:374144419156711147060143317175368453031918731002211n,512:35835915874844867368919076489095108449946327955754392558399825615420669938882575126094039892345713852759n,1024:5016456510113118655434598811035278955030765345404790744303017523831112055108147451509157692220295382716162651878526895249385292291816524375083746691371804094271873160484737966720260389217684476157468082573n},E0={32:2166136261n,64:14695981039346656037n,128:144066263297769815596495629667062367629n,256:100029257958052580907070968620625704837092796014241193945225284501741471925557n,512:9659303129496669498009435400716310466090418745672637896108374329434462657994582932197716438449813051892206539805784495328239340083876191928701583869517785n,1024:14197795064947621068722070641403218320880622795441933960878474914617582723252296732303717722150864096521202355549365628174669108571814760471015076148029755969804077320157692458563003215304957150157403644460363550505412711285966361610267868082893823963790439336411086884584107735010676915n},A0=new globalThis.TextEncoder;function Q2(r,e){let t=Eh[e],n=E0[e];for(let o=0;o<r.length;o++)n^=BigInt(r[o]),n=BigInt.asUintN(e,n*t);return n}function eA(r,e,t){if(t.length===0)throw new Error("The `utf8Buffer` option must have a length greater than zero");let n=Eh[e],o=E0[e],s=r;for(;s.length>0;){let i=A0.encodeInto(s,t);s=s.slice(i.read);for(let a=0;a<i.written;a++)o^=BigInt(t[a]),o=BigInt.asUintN(e,o*n)}return o}function Ah(r,{size:e=32,utf8Buffer:t}={}){if(!Eh[e])throw new Error("The `size` option must be one of 32, 64, 128, 256, 512, or 1024");if(typeof r=="string"){if(t)return eA(r,e,t);r=A0.encode(r)}return Q2(r,e)}var ci={hash:r=>Number(Ah(r,{size:32})),hashV:(r,e)=>tA(ci.hash(r,e))};function tA(r){let e=r.toString(16);return e.length%2===1&&(e=`0${e}`),B(e,"base16")}var Sh=64,Kt=class{fp;h;seed;constructor(e,t,n,o=2){if(o>Sh)throw new TypeError("Invalid Fingerprint Size");let s=t.hashV(e,n),i=ve(o);for(let a=0;a<i.length;a++)i[a]=s[a];i.length===0&&(i[0]=7),this.fp=i,this.h=t,this.seed=n}hash(){return this.h.hash(this.fp,this.seed)}equals(e){return e?.fp instanceof Uint8Array?X(this.fp,e.fp):!1}};function Un(r,e){return Math.floor(Math.random()*(e-r))+r}var Fn=class{contents;constructor(e){this.contents=new Array(e).fill(null)}has(e){if(!(e instanceof Kt))throw new TypeError("Invalid Fingerprint");return this.contents.some(t=>e.equals(t))}add(e){if(!(e instanceof Kt))throw new TypeError("Invalid Fingerprint");for(let t=0;t<this.contents.length;t++)if(this.contents[t]==null)return this.contents[t]=e,!0;return!0}swap(e){if(!(e instanceof Kt))throw new TypeError("Invalid Fingerprint");let t=Un(0,this.contents.length-1),n=this.contents[t];return this.contents[t]=e,n}remove(e){if(!(e instanceof Kt))throw new TypeError("Invalid Fingerprint");let t=this.contents.findIndex(n=>e.equals(n));return t>-1?(this.contents[t]=null,!0):!1}};var rA=500,li=class{bucketSize;filterSize;fingerprintSize;buckets;count;hash;seed;constructor(e){this.filterSize=e.filterSize,this.bucketSize=e.bucketSize??4,this.fingerprintSize=e.fingerprintSize??2,this.count=0,this.buckets=[],this.hash=e.hash??ci,this.seed=e.seed??Un(0,Math.pow(2,10))}add(e){typeof e=="string"&&(e=B(e));let t=new Kt(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,o=(n^t.hash())%this.filterSize;if(this.buckets[n]==null&&(this.buckets[n]=new Fn(this.bucketSize)),this.buckets[o]==null&&(this.buckets[o]=new Fn(this.bucketSize)),this.buckets[n].add(t)||this.buckets[o].add(t))return this.count++,!0;let s=[n,o],i=s[Un(0,s.length-1)];this.buckets[i]==null&&(this.buckets[i]=new Fn(this.bucketSize));for(let a=0;a<rA;a++){let c=this.buckets[i].swap(t);if(c!=null&&(i=(i^c.hash())%this.filterSize,this.buckets[i]==null&&(this.buckets[i]=new Fn(this.bucketSize)),this.buckets[i].add(c)))return this.count++,!0}return!1}has(e){typeof e=="string"&&(e=B(e));let t=new Kt(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,o=this.buckets[n]?.has(t)??!1;if(o)return o;let s=(n^t.hash())%this.filterSize;return this.buckets[s]?.has(t)??!1}remove(e){typeof e=="string"&&(e=B(e));let t=new Kt(e,this.hash,this.seed,this.fingerprintSize),n=this.hash.hash(e,this.seed)%this.filterSize,o=this.buckets[n]?.remove(t)??!1;if(o)return this.count--,o;let s=(n^t.hash())%this.filterSize,i=this.buckets[s]?.remove(t)??!1;return i&&this.count--,i}get reliable(){return Math.floor(100*(this.count/this.filterSize))<=90}},nA={1:.5,2:.84,4:.95,8:.98};function oA(r=.001){return r>.002?2:r>1e-5?4:8}function S0(r,e=.001){let t=oA(e),n=nA[t],o=Math.round(r/n),s=Math.min(Math.ceil(Math.log2(1/e)+Math.log2(2*t)),Sh);return{filterSize:o,bucketSize:t,fingerprintSize:s}}var ec=class{filterSize;bucketSize;fingerprintSize;scale;filterSeries;hash;seed;constructor(e){this.bucketSize=e.bucketSize??4,this.filterSize=e.filterSize??(1<<18)/this.bucketSize,this.fingerprintSize=e.fingerprintSize??2,this.scale=e.scale??2,this.hash=e.hash??ci,this.seed=e.seed??Un(0,Math.pow(2,10)),this.filterSeries=[new li({filterSize:this.filterSize,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed})]}add(e){if(typeof e=="string"&&(e=B(e)),this.has(e))return!0;let t=this.filterSeries.find(n=>n.reliable);if(t==null){let n=this.filterSize*Math.pow(this.scale,this.filterSeries.length);t=new li({filterSize:n,bucketSize:this.bucketSize,fingerprintSize:this.fingerprintSize,hash:this.hash,seed:this.seed}),this.filterSeries.push(t)}return t.add(e)}has(e){typeof e=="string"&&(e=B(e));for(let t=0;t<this.filterSeries.length;t++)if(this.filterSeries[t].has(e))return!0;return!1}remove(e){typeof e=="string"&&(e=B(e));for(let t=0;t<this.filterSeries.length;t++)if(this.filterSeries[t].remove(e))return!0;return!1}get count(){return this.filterSeries.reduce((e,t)=>e+t.count,0)}};function $n(r,e=.001,t){return new ec({...S0(r,e),...t??{}})}function Q(r){let e=r.getComponents(),t={},n=0;if(e[n]?.name==="ip6zone"&&(t.zone=`${e[n].value}`,n++),e[n].name==="ip4"||e[n].name==="ip6"||e[n].name==="dns"||e[n].name==="dns4"||e[n].name==="dns6"?(t.type=e[n].name,t.host=e[n].value,n++):e[n].name==="dnsaddr"&&(t.type=e[n].name,t.host=`_dnsaddr.${e[n].value}`,n++),(e[n]?.name==="tcp"||e[n]?.name==="udp")&&(t.protocol=e[n].name==="tcp"?"tcp":"udp",t.port=parseInt(`${e[n].value}`),n++),e[n]?.name==="ipcidr"&&(t.type==="ip4"?t.cidr=parseInt(`${e[n].value}`):t.type==="ip6"&&(t.cidr=`${e[n].value}`),n++),t.type==null||t.host==null)throw new k(`Multiaddr ${r} was not an IPv4, IPv6, DNS, DNS4, DNS6 or DNSADDR address`);return e[n]?.name==="tls"&&e[n+1]?.name==="sni"&&(t.sni=e[n+1].value,n+=2),t}var tc=class{index=0;input="";new(e){return this.index=0,this.input=e,this}readAtomically(e){let t=this.index,n=e();return n===void 0&&(this.index=t),n}parseWith(e){let t=e();if(this.index===this.input.length)return t}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(e){return this.readAtomically(()=>{let t=this.readChar();if(t===e)return t})}readSeparator(e,t,n){return this.readAtomically(()=>{if(!(t>0&&this.readGivenChar(e)===void 0))return n()})}readNumber(e,t,n,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",l=2**(8*o)-1;for(;;){let f=this.readAtomically(()=>{let u=this.readChar();if(u===void 0)return;let d=Number.parseInt(u,e);if(!Number.isNaN(d))return d});if(f===void 0)break;if(s*=e,s+=f,s>l||(i+=1,t!==void 0&&i>t))return}if(i!==0)return!n&&c&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let e=new Uint8Array(4);for(let t=0;t<e.length;t++){let n=this.readSeparator(".",t,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;e[t]=n}return e})}readIPv6Addr(){let e=t=>{for(let n=0;n<t.length/2;n++){let o=n*2;if(n<t.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return t[o]=i[0],t[o+1]=i[1],t[o+2]=i[2],t[o+3]=i[3],[o+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[o,!1];t[o]=s>>8,t[o+1]=s&255}return[t.length,!1]};return this.readAtomically(()=>{let t=new Uint8Array(16),[n,o]=e(t);if(n===16)return t;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=e(s.subarray(0,i));return t.set(s.subarray(0,a),16-a),t})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var I0=45,sA=15,Fo=new tc;function rc(r){if(!(r.length>sA))return Fo.new(r).parseWith(()=>Fo.readIPv4Addr())}function nc(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>I0))return Fo.new(r).parseWith(()=>Fo.readIPv6Addr())}function $o(r,e=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>I0)return;let t=Fo.new(r).parseWith(()=>Fo.readIPAddr());if(t)return e&&t.length===4?Uint8Array.from([0,0,0,0,0,0,0,0,0,0,255,255,t[0],t[1],t[2],t[3]]):t}function k0(r,e,t){let n=0;for(let o of r)if(!(n<e)){if(n>t)break;if(o!==255)return!1;n++}return!0}function _0(r,e,t,n){let o=0;for(let s of r)if(!(o<t)){if(o>n)break;if(s!==e[o])return!1;o++}return!0}function Ih(r){switch(r.length){case Vn:return r.join(".");case Kn:{let e=[];for(let t=0;t<r.length;t++)t%2===0&&e.push(r[t].toString(16).padStart(2,"0")+r[t+1].toString(16).padStart(2,"0"));return e.join(":")}default:throw new Error("Invalid ip length")}}function C0(r){let e=0;for(let[t,n]of r.entries()){if(n===255){e+=8;continue}for(;(n&128)!=0;)e++,n=n<<1;if((n&128)!=0)return-1;for(let o=t+1;o<r.length;o++)if(r[o]!=0)return-1;break}return e}function T0(r){let e="0x";for(let t of r)e+=(t>>4).toString(16)+(t&15).toString(16);return e}var Vn=4,Kn=16,a4=parseInt("0xFFFF",16),iA=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function ui(r,e){e.length===Kn&&r.length===Vn&&k0(e,0,11)&&(e=e.slice(12)),e.length===Vn&&r.length===Kn&&_0(r,iA,0,11)&&(r=r.slice(12));let t=r.length;if(t!=e.length)throw new Error("Failed to mask ip");let n=new Uint8Array(t);for(let o=0;o<t;o++)n[o]=r[o]&e[o];return n}function B0(r,e){if(typeof e=="string"&&(e=$o(e)),e==null)throw new Error("Invalid ip");if(e.length!==r.network.length)return!1;for(let t=0;t<e.length;t++)if((r.network[t]&r.mask[t])!==(e[t]&r.mask[t]))return!1;return!0}function kh(r){let[e,t]=r.split("/");if(!e||!t)throw new Error("Failed to parse given CIDR: "+r);let n=Vn,o=rc(e);if(o==null&&(n=Kn,o=nc(e),o==null))throw new Error("Failed to parse given CIDR: "+r);let s=parseInt(t,10);if(Number.isNaN(s)||String(s).length!==t.length||s<0||s>n*8)throw new Error("Failed to parse given CIDR: "+r);let i=_h(s,8*n);return{network:ui(o,i),mask:i}}function _h(r,e){if(e!==8*Vn&&e!==8*Kn)throw new Error("Invalid CIDR mask");if(r<0||r>e)throw new Error("Invalid CIDR mask");let t=e/8,n=new Uint8Array(t);for(let o=0;o<t;o++){if(r>=8){n[o]=255,r-=8;continue}n[o]=255-(255>>r),r=0}return n}var Vo=class{constructor(e,t){if(t==null)({network:this.network,mask:this.mask}=kh(e));else{let n=$o(e);if(n==null)throw new Error("Failed to parse network");t=String(t);let o=parseInt(t,10);if(Number.isNaN(o)||String(o).length!==t.length||o<0||o>n.length*8){let s=$o(t);if(s==null)throw new Error("Failed to parse mask");this.mask=s}else this.mask=_h(o,8*n.length);this.network=ui(n,this.mask)}}contains(e){return B0({network:this.network,mask:this.mask},e)}toString(){let e=C0(this.mask),t=e!==-1?String(e):T0(this.mask);return Ih(this.network)+"/"+t}};function L0(r){try{let e=Q(r);switch(e.type){case"ip4":return e.host.startsWith("169.254.");case"ip6":return e.host.toLowerCase().startsWith("fe80");default:return!1}}catch{return!1}}function P0(r){return/^127\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/i.test(r)||/^::1$/.test(r)}function fi(r){try{let e=Q(r);switch(e.type){case"ip4":case"ip6":return P0(e.host);default:return!1}}catch{return!1}}function $e(r){try{return Q(r),!0}catch{return!1}}function Ht(r){return!!rc(r)}function oc(r){return!!nc(r)}var N0=wn(D0(),1),aA=["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"],cA=aA.map(r=>new N0.Netmask(r));function Ch(r){for(let e of cA)if(e.contains(r))return!0;return!1}function lA(r){return/^::ffff:([0-9a-fA-F]{1,4}):([0-9a-fA-F]{1,4})$/.test(r)}function uA(r){let e=r.split(":");if(e.length<2)return!1;let t=e[e.length-1].padStart(4,"0"),n=e[e.length-2].padStart(4,"0"),o=`${parseInt(n.substring(0,2),16)}.${parseInt(n.substring(2),16)}.${parseInt(t.substring(0,2),16)}.${parseInt(t.substring(2),16)}`;return Ch(o)}function fA(r){return/^::ffff:([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})\.([0-9]{1,3})$/.test(r)}function dA(r){let e=r.split(":"),t=e[e.length-1];return Ch(t)}function hA(r){return/^::$/.test(r)||/^::1$/.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 Ko(r){if(Ht(r))return Ch(r);if(lA(r))return uA(r);if(fA(r))return dA(r);if(oc(r))return hA(r)}function qt(r){try{let e=Q(r);switch(e.type){case"ip4":case"ip6":return Ko(e.host)??!1;default:return e.host==="localhost"}}catch{return!1}}function ae(){let r={};return r.promise=new Promise((e,t)=>{r.resolve=e,r.reject=t}),r}var sc=class{buffer;mask;top;btm;next;constructor(e){if(!(e>0)||(e-1&e)!==0)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(e),this.mask=e-1,this.top=0,this.btm=0,this.next=null}push(e){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=e,this.top=this.top+1&this.mask,!0)}shift(){let e=this.buffer[this.btm];if(e!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,e}isEmpty(){return this.buffer[this.btm]===void 0}},Ho=class{size;hwm;head;tail;constructor(e={}){this.hwm=e.splitLimit??16,this.head=new sc(this.hwm),this.tail=this.head,this.size=0}calculateSize(e){return e?.byteLength!=null?e.byteLength:1}push(e){if(e?.value!=null&&(this.size+=this.calculateSize(e.value)),!this.head.push(e)){let t=this.head;this.head=t.next=new sc(2*this.head.buffer.length),this.head.push(e)}}shift(){let e=this.tail.shift();if(e===void 0&&this.tail.next!=null){let t=this.tail.next;this.tail.next=null,this.tail=t,e=this.tail.shift()}return e?.value!=null&&(this.size-=this.calculateSize(e.value)),e}isEmpty(){return this.head.isEmpty()}};var Th=class extends Error{type;code;constructor(e,t){super(e??"The operation was aborted"),this.type="aborted",this.code=t??"ABORT_ERR"}};function qo(r={}){return pA(t=>{let n=t.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function pA(r,e){e=e??{};let t=e.onEnd,n=new Ho,o,s,i,a=ae(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((y,x)=>{s=T=>{s=null,n.push(T);try{y(r(n))}catch(S){x(S)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=ae()})}},l=y=>s!=null?s(y):(n.push(y),o),f=y=>(n=new Ho,s!=null?s({error:y}):(n.push({error:y}),o)),u=y=>{if(i)return o;if(e?.objectMode!==!0&&y?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:y})},d=y=>i?o:(i=!0,y!=null?f(y):l({done:!0})),h=()=>(n=new Ho,d(),{done:!0}),m=y=>(d(y),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:h,throw:m,push:u,end:d,get readableLength(){return n.size},onEmpty:async y=>{let x=y?.signal;if(x?.throwIfAborted(),n.isEmpty())return;let T,S;x!=null&&(T=new Promise((D,H)=>{S=()=>{H(new Th)},x.addEventListener("abort",S)}));try{await Promise.race([a.promise,T])}finally{S!=null&&x!=null&&x?.removeEventListener("abort",S)}}},t==null)return o;let g=o;return o={[Symbol.asyncIterator](){return this},next(){return g.next()},throw(y){return g.throw(y),t!=null&&(t(y),t=void 0),{done:!0}},return(){return g.return(),t!=null&&(t(),t=void 0),{done:!0}},push:u,end(y){return g.end(y),t!=null&&(t(y),t=void 0),o},get readableLength(){return g.readableLength},onEmpty:y=>g.onEmpty(y)},o}var Bh=class extends Error{constructor(e){super(e),this.name="TimeoutError"}},Lh=class extends Error{constructor(e){super(),this.name="AbortError",this.message=e}},R0=r=>globalThis.DOMException===void 0?new Lh(r):new DOMException(r),M0=r=>{let e=r.reason===void 0?R0("This operation was aborted."):r.reason;return e instanceof Error?e:R0(e)};function Ph(r,e){let{milliseconds:t,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout}}=e,i,a,l=new Promise((f,u)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(e.signal){let{signal:h}=e;h.aborted&&u(M0(h)),a=()=>{u(M0(h))},h.addEventListener("abort",a,{once:!0})}if(t===Number.POSITIVE_INFINITY){r.then(f,u);return}let d=new Bh;i=s.setTimeout.call(void 0,()=>{if(n){try{f(n())}catch(h){u(h)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?f():o instanceof Error?u(o):(d.message=o??`Promise timed out after ${t} milliseconds`,u(d))},t),(async()=>{try{f(await r)}catch(h){u(h)}})()}).finally(()=>{l.clear(),a&&e.signal&&e.signal.removeEventListener("abort",a)});return l.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},l}var mA=r=>{let e=r.addEventListener||r.on||r.addListener,t=r.removeEventListener||r.off||r.removeListener;if(!e||!t)throw new TypeError("Emitter is not compatible");return{addListener:e.bind(r),removeListener:t.bind(r)}};function gA(r,e,t){let n,o=new Promise((s,i)=>{if(t={rejectionEvents:["error"],multiArgs:!1,rejectionMultiArgs:!1,resolveImmediately:!1,...t},!(t.count>=0&&(t.count===Number.POSITIVE_INFINITY||Number.isInteger(t.count))))throw new TypeError("The `count` option should be at least 0 or more");t.signal?.throwIfAborted();let a=[e].flat(),c=[],{addListener:l,removeListener:f}=mA(r),u=async(...h)=>{let m=t.multiArgs?h:h[0];if(t.filter)try{if(!await t.filter(m))return}catch(g){n(),i(g);return}c.push(m),t.count===c.length&&(n(),s(c))},d=(...h)=>{n(),i(t.rejectionMultiArgs?h:h[0])};n=()=>{for(let h of a)f(h,u);for(let h of t.rejectionEvents)a.includes(h)||f(h,d)};for(let h of a)l(h,u);for(let h of t.rejectionEvents)a.includes(h)||l(h,d);t.signal&&t.signal.addEventListener("abort",()=>{d(t.signal.reason)},{once:!0}),t.resolveImmediately&&s(c)});if(o.cancel=n,typeof t.timeout=="number"){let s=Ph(o,{milliseconds:t.timeout});return s.cancel=()=>{n(),s.clear()},s}return o}function zt(r,e,t){typeof t=="function"&&(t={filter:t}),t={...t,count:1,resolveImmediately:!1};let n=gA(r,e,t),o=n.then(s=>s[0]);return o.cancel=n.cancel,o}function hi(r,e){let t,n=function(){let o=function(){t=void 0,r()};clearTimeout(t),t=setTimeout(o,e)};return n.start=()=>{},n.stop=()=>{clearTimeout(t)},n}var ic=class extends Error{remainingPoints;msBeforeNext;consumedPoints;isFirstInDuration;constructor(e="Rate limit exceeded",t){super(e),this.name="RateLimitError",this.remainingPoints=t.remainingPoints,this.msBeforeNext=t.msBeforeNext,this.consumedPoints=t.consumedPoints,this.isFirstInDuration=t.isFirstInDuration}},ac=class extends Error{static name="QueueFullError";constructor(e="The queue was full"){super(e),this.name="QueueFullError"}},Hn=class extends Error{static name="UnexpectedEOFError";name="UnexpectedEOFError"};function yA(r){return r.reason}async function kt(r,e,t){if(e==null)return r;let n=t?.translateError??yA;if(e.aborted)return r.catch(()=>{}),Promise.reject(n(e));let o;try{return await Promise.race([r,new Promise((s,i)=>{o=()=>{i(n(e))},e.addEventListener("abort",o)})])}finally{o!=null&&e.removeEventListener("abort",o)}}var cc=class{deferred;signal;constructor(e){this.signal=e,this.deferred=ae(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new ht)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function wA(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var lc=class{id;fn;options;recipients;status;timeline;controller;constructor(e,t){this.id=wA(),this.status="queued",this.fn=e,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,this.controller.signal,this.onAbort=this.onAbort.bind(this)}abort(e){this.controller.abort(e)}onAbort(){this.recipients.reduce((t,n)=>t&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new ht),this.cleanup())}async join(e={}){let t=new cc(e.signal);return this.recipients.push(t),e.signal?.addEventListener("abort",this.onAbort),t.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let e=await kt(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(t=>{t.deferred.resolve(e)}),this.status="complete"}catch(e){this.recipients.forEach(t=>{t.deferred.reject(e)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(e=>{e.cleanup(),e.signal?.removeEventListener("abort",this.onAbort)})}};var Gt=class extends _e{concurrency;maxSize;queue;pending;sort;paused;constructor(e={}){super(),this.concurrency=e.concurrency??Number.POSITIVE_INFINITY,this.maxSize=e.maxSize??Number.POSITIVE_INFINITY,this.pending=0,this.paused=!1,e.metricName!=null&&e.metrics?.registerMetricGroup(e.metricName,{calculate:()=>({size:this.queue.length,running:this.pending,queued:this.queue.length-this.pending})}),this.sort=e.sort,this.queue=[],this.emitEmpty=hi(this.emitEmpty.bind(this),1),this.emitIdle=hi(this.emitIdle.bind(this),1)}emitEmpty(){this.size===0&&this.safeDispatchEvent("empty")}emitIdle(){this.running===0&&this.safeDispatchEvent("idle")}pause(){this.paused=!0}resume(){this.paused&&(this.paused=!1,this.tryToStartAnother())}tryToStartAnother(){if(this.paused)return!1;if(this.size===0)return this.emitEmpty(),this.running===0&&this.emitIdle(),!1;if(this.pending<this.concurrency){let e;for(let t of this.queue)if(t.status==="queued"){e=t;break}return e==null?!1:(this.safeDispatchEvent("active"),this.pending++,e.run().finally(()=>{for(let t=0;t<this.queue.length;t++)if(this.queue[t]===e){this.queue.splice(t,1);break}this.pending--,this.tryToStartAnother(),this.safeDispatchEvent("next")}),!0)}return!1}enqueue(e){this.queue.push(e),this.sort!=null&&this.queue.sort(this.sort)}async add(e,t){if(t?.signal?.throwIfAborted(),this.size===this.maxSize)throw new ac;let n=new lc(e,t);return this.enqueue(n),this.safeDispatchEvent("add"),this.tryToStartAnother(),n.join(t).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("failure",{detail:{job:n,error:o}}),o})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(e=>{e.abort(new ht)}),this.clear()}async onEmpty(e){this.size!==0&&await zt(this,"empty",e)}async onSizeLessThan(e,t){this.size<e||await zt(this,"next",{...t,filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await zt(this,"idle",e)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(e){e?.signal?.throwIfAborted();let t=qo({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),t.end(c)},o=c=>{c.detail!=null&&t.push(c.detail)},s=c=>{n(c.detail.error)},i=()=>{n()},a=()=>{n(new ht("Queue aborted"))};this.addEventListener("completed",o),this.addEventListener("failure",s),this.addEventListener("idle",i),e?.signal?.addEventListener("abort",a);try{yield*t}finally{this.removeEventListener("completed",o),this.removeEventListener("failure",s),this.removeEventListener("idle",i),e?.signal?.removeEventListener("abort",a),n()}}};var zo=class{movingAverage;variance;deviation;forecast;timeSpan;previousTime;constructor(e){this.timeSpan=e,this.movingAverage=0,this.variance=0,this.deviation=0,this.forecast=0}alpha(e,t){return 1-Math.exp(-(e-t)/this.timeSpan)}push(e,t=Date.now()){if(this.previousTime!=null){let n=this.alpha(t,this.previousTime),o=e-this.movingAverage,s=n*o;this.movingAverage=n*e+(1-n)*this.movingAverage,this.variance=(1-n)*(this.variance+o*s),this.deviation=Math.sqrt(this.variance),this.forecast=this.movingAverage+n*o}else this.movingAverage=e;this.previousTime=t}};var bA=1.2,xA=2,vA=5e3,EA=6e4,AA=5e3,uc=class{success;failure;next;metric;timeoutMultiplier;failureMultiplier;minTimeout;maxTimeout;constructor(e={}){let t=e.interval??AA;this.success=new zo(t),this.failure=new zo(t),this.next=new zo(t),this.failureMultiplier=e.failureMultiplier??xA,this.timeoutMultiplier=e.timeoutMultiplier??bA,this.minTimeout=e.minTimeout??vA,this.maxTimeout=e.maxTimeout??EA,e.metricName!=null&&(this.metric=e.metrics?.registerMetricGroup(e.metricName))}getTimeoutSignal(e={}){let t=Math.round(this.next.movingAverage*(e.timeoutFactor??this.timeoutMultiplier));t<this.minTimeout&&(t=this.minTimeout),t>this.maxTimeout&&(t=this.maxTimeout);let n=AbortSignal.timeout(t),o=pe([e.signal,n]);return o.start=Date.now(),o.timeout=t,o}cleanUp(e){let t=Date.now()-e.start;e.aborted?(this.failure.push(t),this.next.push(t*this.failureMultiplier),this.metric?.update({failureMovingAverage:this.failure.movingAverage,failureDeviation:this.failure.deviation,failureForecast:this.failure.forecast,failureVariance:this.failure.variance,failure:t})):(this.success.push(t),this.next.push(t),this.metric?.update({successMovingAverage:this.success.movingAverage,successDeviation:this.success.deviation,successForecast:this.success.forecast,successVariance:this.success.variance,success:t}))}};var Ve=class extends Error{static name="InvalidMultiaddrError";name="InvalidMultiaddrError"},Ir=class extends Error{static name="ValidationError";name="ValidationError"},fc=class extends Error{static name="InvalidParametersError";name="InvalidParametersError"},dc=class extends Error{static name="UnknownProtocolError";name="UnknownProtocolError"};function Nh(r){return e=>U(e,r)}function Rh(r){return e=>B(e,r)}function Go(r){return new DataView(r.buffer).getUint16(r.byteOffset).toString()}function qn(r){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,typeof r=="string"?parseInt(r):r),new Uint8Array(e)}function O0(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==16)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion address.`);let t=B(e[0],"base32"),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=qn(n);return Ce([t,o],t.length+o.length)}function U0(r){let e=r.split(":");if(e.length!==2)throw new Error(`failed to parse onion addr: ["'${e.join('", "')}'"]' does not contain a port number`);if(e[0].length!==56)throw new Error(`failed to parse onion addr: ${e[0]} not a Tor onion3 address.`);let t=Te.decode(`b${e[0]}`),n=parseInt(e[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let o=qn(n);return Ce([t,o],t.length+o.length)}function Mh(r){let e=r.subarray(0,r.length-2),t=r.subarray(r.length-2),n=U(e,"base32"),o=Go(t);return`${n}:${o}`}var Oh=function(r){r=r.toString().trim();let e=new Uint8Array(4);return r.split(/\./g).forEach((t,n)=>{let o=parseInt(t,10);if(isNaN(o)||o<0||o>255)throw new Ve("Invalid byte value in IP address");e[n]=o}),e},F0=function(r){let e=0;r=r.toString().trim();let t=r.split(":",8),n;for(n=0;n<t.length;n++){let s=Ht(t[n]),i;s&&(i=Oh(t[n]),t[n]=U(i.subarray(0,2),"base16")),i!=null&&++n<8&&t.splice(n,0,U(i.subarray(2,4),"base16"))}if(t[0]==="")for(;t.length<8;)t.unshift("0");else if(t[t.length-1]==="")for(;t.length<8;)t.push("0");else if(t.length<8){for(n=0;n<t.length&&t[n]!=="";n++);let s=[n,1];for(n=9-t.length;n>0;n--)s.push("0");t.splice.apply(t,s)}let o=new Uint8Array(e+16);for(n=0;n<t.length;n++){t[n]===""&&(t[n]="0");let s=parseInt(t[n],16);if(isNaN(s)||s<0||s>65535)throw new Ve("Invalid byte value in IP address");o[e++]=s>>8&255,o[e++]=s&255}return o},$0=function(r){if(r.byteLength!==4)throw new Ve("IPv4 address was incorrect length");let e=[];for(let t=0;t<r.byteLength;t++)e.push(r[t]);return e.join(".")},V0=function(r){if(r.byteLength!==16)throw new Ve("IPv6 address was incorrect length");let e=[];for(let n=0;n<r.byteLength;n+=2){let o=r[n],s=r[n+1],i=`${o.toString(16).padStart(2,"0")}${s.toString(16).padStart(2,"0")}`;e.push(i)}let t=e.join(":");try{let n=new URL(`http://[${t}]`);return n.hostname.substring(1,n.hostname.length-1)}catch{throw new Ve(`Invalid IPv6 address "${t}"`)}};function K0(r){try{let e=new URL(`http://[${r}]`);return e.hostname.substring(1,e.hostname.length-1)}catch{throw new Ve(`Invalid IPv6 address "${r}"`)}}var Dh=Object.values(Rs).map(r=>r.decoder),SA=(function(){let r=Dh[0].or(Dh[1]);return Dh.slice(2).forEach(e=>r=r.or(e)),r})();function H0(r){return SA.decode(r)}function q0(r){return e=>r.encoder.encode(e)}function IA(r){if(parseInt(r).toString()!==r)throw new Ir("Value must be an integer")}function kA(r){if(r<0)throw new Ir("Value must be a positive integer, or zero")}function _A(r){return e=>{if(e>r)throw new Ir(`Value must be smaller than or equal to ${r}`)}}function CA(...r){return e=>{for(let t of r)t(e)}}var pi=CA(IA,kA,_A(65535));var De=-1,Uh=class{protocolsByCode=new Map;protocolsByName=new Map;getProtocol(e){let t;if(typeof e=="string"?t=this.protocolsByName.get(e):t=this.protocolsByCode.get(e),t==null)throw new dc(`Protocol ${e} was unknown`);return t}addProtocol(e){this.protocolsByCode.set(e.code,e),this.protocolsByName.set(e.name,e),e.aliases?.forEach(t=>{this.protocolsByName.set(t,e)})}removeProtocol(e){let t=this.protocolsByCode.get(e);t!=null&&(this.protocolsByCode.delete(t.code),this.protocolsByName.delete(t.name),t.aliases?.forEach(n=>{this.protocolsByName.delete(n)}))}},_r=new Uh,HA=[{code:4,name:"ip4",size:32,valueToBytes:Oh,bytesToValue:$0,validate:r=>{if(!Ht(r))throw new Ir(`Invalid IPv4 address "${r}"`)}},{code:6,name:"tcp",size:16,valueToBytes:qn,bytesToValue:Go,validate:pi},{code:273,name:"udp",size:16,valueToBytes:qn,bytesToValue:Go,validate:pi},{code:33,name:"dccp",size:16,valueToBytes:qn,bytesToValue:Go,validate:pi},{code:41,name:"ip6",size:128,valueToBytes:F0,bytesToValue:V0,stringToValue:K0,validate:r=>{if(!oc(r))throw new Ir(`Invalid IPv6 address "${r}"`)}},{code:42,name:"ip6zone",size:De},{code:43,name:"ipcidr",size:8,bytesToValue:Nh("base10"),valueToBytes:Rh("base10")},{code:53,name:"dns",size:De},{code:54,name:"dns4",size:De},{code:55,name:"dns6",size:De},{code:56,name:"dnsaddr",size:De},{code:132,name:"sctp",size:16,valueToBytes:qn,bytesToValue:Go,validate:pi},{code:301,name:"udt"},{code:302,name:"utp"},{code:400,name:"unix",size:De,stringToValue:r=>decodeURIComponent(r),valueToString:r=>encodeURIComponent(r)},{code:421,name:"p2p",aliases:["ipfs"],size:De,bytesToValue:Nh("base58btc"),valueToBytes:r=>r.startsWith("Q")||r.startsWith("1")?Rh("base58btc")(r):K.parse(r).multihash.bytes},{code:444,name:"onion",size:96,bytesToValue:Mh,valueToBytes:O0},{code:445,name:"onion3",size:296,bytesToValue:Mh,valueToBytes:U0},{code:446,name:"garlic64",size:De},{code:447,name:"garlic32",size:De},{code:448,name:"tls"},{code:449,name:"sni",size:De},{code:454,name:"noise"},{code:460,name:"quic"},{code:461,name:"quic-v1"},{code:465,name:"webtransport"},{code:466,name:"certhash",size:De,bytesToValue:q0(od),valueToBytes:H0},{code:480,name:"http"},{code:481,name:"http-path",size:De,stringToValue:r=>`/${decodeURIComponent(r)}`,valueToString:r=>encodeURIComponent(r.substring(1))},{code:443,name:"https"},{code:477,name:"ws"},{code:478,name:"wss"},{code:479,name:"p2p-websocket-star"},{code:277,name:"p2p-stardust"},{code:275,name:"p2p-webrtc-star"},{code:276,name:"p2p-webrtc-direct"},{code:280,name:"webrtc-direct"},{code:281,name:"webrtc"},{code:290,name:"p2p-circuit"},{code:777,name:"memory",size:De}];HA.forEach(r=>{_r.addProtocol(r)});function z0(r){let e=[],t=0;for(;t<r.length;){let n=Dn(r,t),o=_r.getProtocol(n),s=Pe(n),i=qA(o,r,t+s),a=0;i>0&&o.size===De&&(a=Pe(i));let c=s+a+i,l={code:n,name:o.name,bytes:r.subarray(t,t+c)};if(i>0){let f=t+s+a,u=r.subarray(f,f+i);l.value=o.bytesToValue?.(u)??U(u)}e.push(l),t+=c}return e}function G0(r){let e=0,t=[];for(let n of r){if(n.bytes==null){let o=_r.getProtocol(n.code),s=Pe(n.code),i,a=0,c=0;n.value!=null&&(i=o.valueToBytes?.(n.value)??B(n.value),a=i.byteLength,o.size===De&&(c=Pe(a)));let l=new Uint8Array(s+c+a),f=0;Ro(n.code,l,f),f+=s,i!=null&&(o.size===De&&(Ro(a,l,f),f+=c),l.set(i,f)),n.bytes=l}t.push(n.bytes),e+=n.bytes.byteLength}return Ce(t,e)}function W0(r){if(r.charAt(0)!=="/")throw new Ve('String multiaddr must start with "/"');let e=[],t="protocol",n="",o="";for(let s=1;s<r.length;s++){let i=r.charAt(s);i!=="/"&&(t==="protocol"?o+=r.charAt(s):n+=r.charAt(s));let a=s===r.length-1;if(i==="/"||a){let c=_r.getProtocol(o);if(t==="protocol"){if(c.size==null||c.size===0){e.push({code:c.code,name:c.name}),n="",o="",t="protocol";continue}else if(a)throw new Ve(`Component ${o} was missing value`);t="value"}else if(t==="value"){let l={code:c.code,name:c.name};if(c.size!=null&&c.size!==0){if(n==="")throw new Ve(`Component ${o} was missing value`);l.value=c.stringToValue?.(n)??n}e.push(l),n="",o="",t="protocol"}}}if(o!==""&&n!=="")throw new Ve("Incomplete multiaddr");return e}function j0(r){return`/${r.flatMap(e=>{if(e.value==null)return e.name;let t=_r.getProtocol(e.code);if(t==null)throw new Ve(`Unknown protocol code ${e.code}`);return[e.name,t.valueToString?.(e.value)??e.value]}).join("/")}`}function qA(r,e,t){return r.size==null||r.size===0?0:r.size>0?r.size/8:Dn(e,t)}var zA=Symbol.for("nodejs.util.inspect.custom"),jh=Symbol.for("@multiformats/multiaddr");function GA(r){if(r==null&&(r="/"),an(r))return r.getComponents();if(r instanceof Uint8Array)return z0(r);if(typeof r=="string")return r=r.replace(/\/(\/)+/,"/").replace(/(\/)+$/,""),r===""&&(r="/"),W0(r);if(Array.isArray(r))return r;throw new Ve("Must be a string, Uint8Array, Component[], or another Multiaddr")}var yc=class r{[jh]=!0;#e;#t;#r;constructor(e="/",t={}){this.#e=GA(e),t.validate!==!1&&WA(this)}get bytes(){return this.#r==null&&(this.#r=G0(this.#e)),this.#r}toString(){return this.#t==null&&(this.#t=j0(this.#e)),this.#t}toJSON(){return this.toString()}getComponents(){return[...this.#e.map(e=>({...e}))]}encapsulate(e){let t=new r(e);return new r([...this.#e,...t.getComponents()],{validate:!1})}decapsulate(e){let t=e.toString(),n=this.toString(),o=n.lastIndexOf(t);if(o<0)throw new fc(`Address ${this.toString()} does not contain subaddress: ${t}`);return new r(n.slice(0,o),{validate:!1})}decapsulateCode(e){let t;for(let n=this.#e.length-1;n>-1;n--)if(this.#e[n].code===e){t=n;break}return new r(this.#e.slice(0,t),{validate:!1})}equals(e){return X(this.bytes,e.bytes)}[zA](){return`Multiaddr(${this.toString()})`}};function WA(r){r.getComponents().forEach(e=>{let t=_r.getProtocol(e.code);e.value!=null&&t.validate?.(e.value)})}function an(r){return!!r?.[jh]}function ee(r){return new yc(r)}var wc=class extends Error{type;code;constructor(e,t,n){super(e??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=t??"ABORT_ERR"}};async function Y0(r,e,t){if(e==null)return r;if(e.aborted)return r.catch(()=>{}),Promise.reject(new wc(t?.errorMessage,t?.errorCode,t?.errorName));let n,o=new wc(t?.errorMessage,t?.errorCode,t?.errorName);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var Yh=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=ae(),this.haveNext=ae()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let e=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=ae(),e}async throw(e){return this.ended=!0,this.error=e,e!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(e)),{done:!0,value:void 0}}async return(){let e={done:!0,value:void 0};return this.ended=!0,this.nextResult=e,this.haveNext.resolve(),e}async push(e,t){await this._push(e,t)}async end(e,t){e!=null?await this.throw(e):await this._push(void 0,t)}async _push(e,t){if(e!=null&&this.ended)throw this.error??new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;e!=null?this.nextResult={done:!1,value:e}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=ae(),await Y0(this.readNext.promise,t?.signal,t)}};function Z0(){return new Yh}function jA(r){return r[Symbol.asyncIterator]!=null}async function YA(r,e,t){try{await Promise.all(r.map(async n=>{for await(let o of n)await e.push(o,{signal:t}),t.throwIfAborted()})),await e.end(void 0,{signal:t})}catch(n){await e.end(n,{signal:t}).catch(()=>{})}}async function*ZA(r){let e=new AbortController,t=Z0();YA(r,t,e.signal).catch(()=>{});try{yield*t}finally{e.abort()}}function*XA(r){for(let e of r)yield*e}function JA(...r){let e=[];for(let t of r)jA(t)||e.push(t);return e.length===r.length?XA(e):ZA(r)}var _t=JA;var eS=4194304,bc=class extends Error{static name="UnwrappedError";name="UnwrappedError"},Xh=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Jh=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Qh=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function tS(r){return typeof r?.closeRead=="function"}function rS(r){return typeof r?.close=="function"}function Zh(r){return tS(r)?r.remoteWriteStatus!=="writable"&&r.readBufferLength===0:rS(r)?r.status!=="open":!1}function nS(r){return r?.addEventListener!=null&&r?.removeEventListener!=null&&r?.send!=null&&r?.push!=null&&r?.log!=null}function ep(r,e){let t=e?.maxBufferSize??eS,n=new se,o,s=!1;if(!nS(r))throw new k("Argument should be a Stream or a Multiaddr");let i=f=>{if(n.append(f.data),n.byteLength>t){let u=n.byteLength;n.consume(n.byteLength),o?.reject(new Error(`Read buffer overflow - ${u} > ${t}`))}o?.resolve()};r.addEventListener("message",i);let a=f=>{f.error!=null?o?.reject(f.error):o?.resolve()};r.addEventListener("close",a);let c=()=>{o?.resolve()};r.addEventListener("remoteCloseWrite",c);let l={readBuffer:n,async read(f){if(s===!0)throw new bc("Stream was unwrapped");if(Zh(r)){if(f?.bytes==null)return null;if(n.byteLength<f.bytes)throw r.log.error("closed after reading %d/%d bytes",n.byteLength,f.bytes),new Hn(`Unexpected EOF - stream closed after reading ${n.byteLength}/${f.bytes} bytes`)}let u=f?.bytes??1;for(o=Promise.withResolvers();;){if(n.byteLength>=u){o.resolve();break}if(await kt(o.promise,f?.signal),Zh(r)){if(n.byteLength===0&&f?.bytes==null)return null;break}o=Promise.withResolvers()}let d=f?.bytes??n.byteLength;if(n.byteLength<d){if(Zh(r))throw r.log.error("closed while reading %d/%d bytes",n.byteLength,d),new Hn(`Unexpected EOF - stream closed while reading ${n.byteLength}/${d} bytes`);return l.read(f)}let h=n.sublist(0,d);return n.consume(d),h},async write(f,u){if(s===!0)throw new bc("Stream was unwrapped");r.send(f)||await zt(r,"drain",{signal:u?.signal,rejectionEvents:["close"]})},unwrap(){return s||(s=!0,r.removeEventListener("message",i),r.removeEventListener("close",a),r.removeEventListener("remoteCloseWrite",c),n.byteLength>0&&(r.log("stream unwrapped with %d unread bytes",n.byteLength),r.push(n))),r}};return l}function xc(r,e={}){let t=ep(r,e);e.maxDataLength!=null&&e.maxLengthLength==null&&(e.maxLengthLength=Pe(e.maxDataLength));let n=e?.lengthDecoder??Dn,o=e?.lengthEncoder??en;return{async read(i){let a=-1,c=new se;for(;;){let f=await t.read({...i,bytes:1});if(f==null)break;c.append(f);try{a=n(c)}catch(u){if(u instanceof RangeError)continue;throw u}if(a<0)throw new Xh("Invalid message length");if(e?.maxLengthLength!=null&&c.byteLength>e.maxLengthLength)throw new Qh(`Message length length too long - ${c.byteLength} > ${e.maxLengthLength}`);if(a>-1)break}if(e?.maxDataLength!=null&&a>e.maxDataLength)throw new Jh(`Message length too long - ${a} > ${e.maxDataLength}`);let l=await t.read({...i,bytes:a});if(l==null)throw r.log.error("tried to read %d bytes but the stream closed",a),new Hn(`Unexpected EOF - tried to read ${a} bytes but the stream closed`);if(l.byteLength!==a)throw r.log.error("read %d/%d bytes before the stream closed",l.byteLength,a),new Hn(`Unexpected EOF - read ${l.byteLength}/${a} bytes before the stream closed`);return l},async write(i,a){await t.write(new se(o(i.byteLength),i),a)},async writeV(i,a){let c=new se(...i.flatMap(l=>[o(l.byteLength),l]));await t.write(c,a)},unwrap(){return t.unwrap()}}}var oS=["string","number","bigint","symbol"],sS=["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 X0(r){if(r===null)return"null";if(r===void 0)return"undefined";if(r===!0||r===!1)return"boolean";let e=typeof r;if(oS.includes(e))return e;if(e==="function")return"Function";if(Array.isArray(r))return"Array";if(iS(r))return"Buffer";let t=aS(r);return t||"Object"}function iS(r){return r&&r.constructor&&r.constructor.isBuffer&&r.constructor.isBuffer.call(null,r)}function aS(r){let e=Object.prototype.toString.call(r).slice(8,-1);if(sS.includes(e))return e}var p=class{constructor(e,t,n){this.major=e,this.majorEncoded=e<<5,this.name=t,this.terminal=n}toString(){return`Type[${this.major}].${this.name}`}compare(e){return this.major<e.major?-1:this.major>e.major?1:0}};p.uint=new p(0,"uint",!0);p.negint=new p(1,"negint",!0);p.bytes=new p(2,"bytes",!0);p.string=new p(3,"string",!0);p.array=new p(4,"array",!1);p.map=new p(5,"map",!1);p.tag=new p(6,"tag",!1);p.float=new p(7,"float",!0);p.false=new p(7,"false",!0);p.true=new p(7,"true",!0);p.null=new p(7,"null",!0);p.undefined=new p(7,"undefined",!0);p.break=new p(7,"break",!0);var I=class{constructor(e,t,n){this.type=e,this.value=t,this.encodedLength=n,this.encodedBytes=void 0,this.byteValue=void 0}toString(){return`Token[${this.type}].${this.value}`}};var Xo=globalThis.process&&!globalThis.process.browser&&globalThis.Buffer&&typeof globalThis.Buffer.isBuffer=="function",cS=new TextDecoder,lS=new TextEncoder;function vc(r){return Xo&&globalThis.Buffer.isBuffer(r)}function bi(r){return r instanceof Uint8Array?vc(r)?new Uint8Array(r.buffer,r.byteOffset,r.byteLength):r:Uint8Array.from(r)}var tw=Xo?(r,e,t)=>t-e>64?globalThis.Buffer.from(r.subarray(e,t)).toString("utf8"):Q0(r,e,t):(r,e,t)=>t-e>64?cS.decode(r.subarray(e,t)):Q0(r,e,t),Ec=Xo?r=>r.length>64?globalThis.Buffer.from(r):J0(r):r=>r.length>64?lS.encode(r):J0(r),hr=r=>Uint8Array.from(r),Jo=Xo?(r,e,t)=>vc(r)?new Uint8Array(r.subarray(e,t)):r.slice(e,t):(r,e,t)=>r.slice(e,t),rw=Xo?(r,e)=>(r=r.map(t=>t instanceof Uint8Array?t:globalThis.Buffer.from(t)),bi(globalThis.Buffer.concat(r,e))):(r,e)=>{let t=new Uint8Array(e),n=0;for(let o of r)n+o.length>t.length&&(o=o.subarray(0,t.length-n)),t.set(o,n),n+=o.length;return t},nw=Xo?r=>globalThis.Buffer.allocUnsafe(r):r=>new Uint8Array(r);function ow(r,e){if(vc(r)&&vc(e))return r.compare(e);for(let t=0;t<r.length;t++)if(r[t]!==e[t])return r[t]<e[t]?-1:1;return 0}function J0(r){let e=[],t=0;for(let n=0;n<r.length;n++){let o=r.charCodeAt(n);o<128?e[t++]=o:o<2048?(e[t++]=o>>6|192,e[t++]=o&63|128):(o&64512)===55296&&n+1<r.length&&(r.charCodeAt(n+1)&64512)===56320?(o=65536+((o&1023)<<10)+(r.charCodeAt(++n)&1023),e[t++]=o>>18|240,e[t++]=o>>12&63|128,e[t++]=o>>6&63|128,e[t++]=o&63|128):(e[t++]=o>>12|224,e[t++]=o>>6&63|128,e[t++]=o&63|128)}return e}function Q0(r,e,t){let n=[];for(;e<t;){let o=r[e],s=null,i=o>239?4:o>223?3:o>191?2:1;if(e+i<=t){let a,c,l,f;switch(i){case 1:o<128&&(s=o);break;case 2:a=r[e+1],(a&192)===128&&(f=(o&31)<<6|a&63,f>127&&(s=f));break;case 3:a=r[e+1],c=r[e+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[e+1],c=r[e+2],l=r[e+3],(a&192)===128&&(c&192)===128&&(l&192)===128&&(f=(o&15)<<18|(a&63)<<12|(c&63)<<6|l&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),e+=i}return tp(n)}var ew=4096;function tp(r){let e=r.length;if(e<=ew)return String.fromCharCode.apply(String,r);let t="",n=0;for(;n<e;)t+=String.fromCharCode.apply(String,r.slice(n,n+=ew));return t}var uS=256,xi=class{constructor(e=uS){this.chunkSize=e,this.cursor=0,this.maxCursor=-1,this.chunks=[],this._initReuseChunk=null}reset(){this.cursor=0,this.maxCursor=-1,this.chunks.length&&(this.chunks=[]),this._initReuseChunk!==null&&(this.chunks.push(this._initReuseChunk),this.maxCursor=this._initReuseChunk.length-1)}push(e){let t=this.chunks[this.chunks.length-1];if(this.cursor+e.length<=this.maxCursor+1){let o=t.length-(this.maxCursor-this.cursor)-1;t.set(e,o)}else{if(t){let o=t.length-(this.maxCursor-this.cursor)-1;o<t.length&&(this.chunks[this.chunks.length-1]=t.subarray(0,o),this.maxCursor=this.cursor-1)}e.length<64&&e.length<this.chunkSize?(t=nw(this.chunkSize),this.chunks.push(t),this.maxCursor+=t.length,this._initReuseChunk===null&&(this._initReuseChunk=t),t.set(e,0)):(this.chunks.push(e),this.maxCursor+=e.length)}this.cursor+=e.length}toBytes(e=!1){let t;if(this.chunks.length===1){let n=this.chunks[0];e&&this.cursor>n.length/2?(t=this.cursor===n.length?n:n.subarray(0,this.cursor),this._initReuseChunk=null,this.chunks=[]):t=Jo(n,0,this.cursor)}else t=rw(this.chunks,this.cursor);return e&&this.reset(),t}};var F="CBOR decode error:",Cr="CBOR encode error:",vi=[];vi[23]=1;vi[24]=2;vi[25]=3;vi[26]=5;vi[27]=9;function Tr(r,e,t){if(r.length-e<t)throw new Error(`${F} not enough data for type`)}var Ne=[24,256,65536,4294967296,BigInt("18446744073709551616")];function yt(r,e,t){Tr(r,e,1);let n=r[e];if(t.strict===!0&&n<Ne[0])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);return n}function wt(r,e,t){Tr(r,e,2);let n=r[e]<<8|r[e+1];if(t.strict===!0&&n<Ne[1])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);return n}function bt(r,e,t){Tr(r,e,4);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3];if(t.strict===!0&&n<Ne[2])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);return n}function xt(r,e,t){Tr(r,e,8);let n=r[e]*16777216+(r[e+1]<<16)+(r[e+2]<<8)+r[e+3],o=r[e+4]*16777216+(r[e+5]<<16)+(r[e+6]<<8)+r[e+7],s=(BigInt(n)<<BigInt(32))+BigInt(o);if(t.strict===!0&&s<Ne[3])throw new Error(`${F} integer encoded in more bytes than necessary (strict decode)`);if(s<=Number.MAX_SAFE_INTEGER)return Number(s);if(t.allowBigInt===!0)return s;throw new Error(`${F} integers outside of the safe integer range are not supported`)}function sw(r,e,t,n){return new I(p.uint,yt(r,e+1,n),2)}function iw(r,e,t,n){return new I(p.uint,wt(r,e+1,n),3)}function aw(r,e,t,n){return new I(p.uint,bt(r,e+1,n),5)}function cw(r,e,t,n){return new I(p.uint,xt(r,e+1,n),9)}function Ct(r,e){return Ke(r,0,e.value)}function Ke(r,e,t){if(t<Ne[0]){let n=Number(t);r.push([e|n])}else if(t<Ne[1]){let n=Number(t);r.push([e|24,n])}else if(t<Ne[2]){let n=Number(t);r.push([e|25,n>>>8,n&255])}else if(t<Ne[3]){let n=Number(t);r.push([e|26,n>>>24&255,n>>>16&255,n>>>8&255,n&255])}else{let n=BigInt(t);if(n<Ne[4]){let o=[e|27,0,0,0,0,0,0,0],s=Number(n&BigInt(4294967295)),i=Number(n>>BigInt(32)&BigInt(4294967295));o[8]=s&255,s=s>>8,o[7]=s&255,s=s>>8,o[6]=s&255,s=s>>8,o[5]=s&255,o[4]=i&255,i=i>>8,o[3]=i&255,i=i>>8,o[2]=i&255,i=i>>8,o[1]=i&255,r.push(o)}else throw new Error(`${F} encountered BigInt larger than allowable range`)}}Ct.encodedSize=function(e){return Ke.encodedSize(e.value)};Ke.encodedSize=function(e){return e<Ne[0]?1:e<Ne[1]?2:e<Ne[2]?3:e<Ne[3]?5:9};Ct.compareTokens=function(e,t){return e.value<t.value?-1:e.value>t.value?1:0};function lw(r,e,t,n){return new I(p.negint,-1-yt(r,e+1,n),2)}function uw(r,e,t,n){return new I(p.negint,-1-wt(r,e+1,n),3)}function fw(r,e,t,n){return new I(p.negint,-1-bt(r,e+1,n),5)}var rp=BigInt(-1),dw=BigInt(1);function hw(r,e,t,n){let o=xt(r,e+1,n);if(typeof o!="bigint"){let s=-1-o;if(s>=Number.MIN_SAFE_INTEGER)return new I(p.negint,s,9)}if(n.allowBigInt!==!0)throw new Error(`${F} integers outside of the safe integer range are not supported`);return new I(p.negint,rp-BigInt(o),9)}function Ac(r,e){let t=e.value,n=typeof t=="bigint"?t*rp-dw:t*-1-1;Ke(r,e.type.majorEncoded,n)}Ac.encodedSize=function(e){let t=e.value,n=typeof t=="bigint"?t*rp-dw:t*-1-1;return n<Ne[0]?1:n<Ne[1]?2:n<Ne[2]?3:n<Ne[3]?5:9};Ac.compareTokens=function(e,t){return e.value<t.value?1:e.value>t.value?-1:0};function Ei(r,e,t,n){Tr(r,e,t+n);let o=Jo(r,e+t,e+t+n);return new I(p.bytes,o,t+n)}function pw(r,e,t,n){return Ei(r,e,1,t)}function mw(r,e,t,n){return Ei(r,e,2,yt(r,e+1,n))}function gw(r,e,t,n){return Ei(r,e,3,wt(r,e+1,n))}function yw(r,e,t,n){return Ei(r,e,5,bt(r,e+1,n))}function ww(r,e,t,n){let o=xt(r,e+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer bytes lengths not supported`);return Ei(r,e,9,o)}function Sc(r){return r.encodedBytes===void 0&&(r.encodedBytes=r.type===p.string?Ec(r.value):r.value),r.encodedBytes}function Qo(r,e){let t=Sc(e);Ke(r,e.type.majorEncoded,t.length),r.push(t)}Qo.encodedSize=function(e){let t=Sc(e);return Ke.encodedSize(t.length)+t.length};Qo.compareTokens=function(e,t){return dS(Sc(e),Sc(t))};function dS(r,e){return r.length<e.length?-1:r.length>e.length?1:ow(r,e)}function Ai(r,e,t,n,o){let s=t+n;Tr(r,e,s);let i=new I(p.string,tw(r,e+t,e+s),s);return o.retainStringBytes===!0&&(i.byteValue=Jo(r,e+t,e+s)),i}function bw(r,e,t,n){return Ai(r,e,1,t,n)}function xw(r,e,t,n){return Ai(r,e,2,yt(r,e+1,n),n)}function vw(r,e,t,n){return Ai(r,e,3,wt(r,e+1,n),n)}function Ew(r,e,t,n){return Ai(r,e,5,bt(r,e+1,n),n)}function Aw(r,e,t,n){let o=xt(r,e+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer string lengths not supported`);return Ai(r,e,9,o,n)}var Sw=Qo;function es(r,e,t,n){return new I(p.array,n,t)}function Iw(r,e,t,n){return es(r,e,1,t)}function kw(r,e,t,n){return es(r,e,2,yt(r,e+1,n))}function _w(r,e,t,n){return es(r,e,3,wt(r,e+1,n))}function Cw(r,e,t,n){return es(r,e,5,bt(r,e+1,n))}function Tw(r,e,t,n){let o=xt(r,e+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer array lengths not supported`);return es(r,e,9,o)}function Bw(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${F} indefinite length items not allowed`);return es(r,e,1,1/0)}function Ic(r,e){Ke(r,p.array.majorEncoded,e.value)}Ic.compareTokens=Ct.compareTokens;Ic.encodedSize=function(e){return Ke.encodedSize(e.value)};function ts(r,e,t,n){return new I(p.map,n,t)}function Lw(r,e,t,n){return ts(r,e,1,t)}function Pw(r,e,t,n){return ts(r,e,2,yt(r,e+1,n))}function Dw(r,e,t,n){return ts(r,e,3,wt(r,e+1,n))}function Nw(r,e,t,n){return ts(r,e,5,bt(r,e+1,n))}function Rw(r,e,t,n){let o=xt(r,e+1,n);if(typeof o=="bigint")throw new Error(`${F} 64-bit integer map lengths not supported`);return ts(r,e,9,o)}function Mw(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${F} indefinite length items not allowed`);return ts(r,e,1,1/0)}function kc(r,e){Ke(r,p.map.majorEncoded,e.value)}kc.compareTokens=Ct.compareTokens;kc.encodedSize=function(e){return Ke.encodedSize(e.value)};function Ow(r,e,t,n){return new I(p.tag,t,1)}function Uw(r,e,t,n){return new I(p.tag,yt(r,e+1,n),2)}function Fw(r,e,t,n){return new I(p.tag,wt(r,e+1,n),3)}function $w(r,e,t,n){return new I(p.tag,bt(r,e+1,n),5)}function Vw(r,e,t,n){return new I(p.tag,xt(r,e+1,n),9)}function _c(r,e){Ke(r,p.tag.majorEncoded,e.value)}_c.compareTokens=Ct.compareTokens;_c.encodedSize=function(e){return Ke.encodedSize(e.value)};var wS=20,bS=21,xS=22,vS=23;function Kw(r,e,t,n){if(n.allowUndefined===!1)throw new Error(`${F} undefined values are not supported`);return n.coerceUndefinedToNull===!0?new I(p.null,null,1):new I(p.undefined,void 0,1)}function Hw(r,e,t,n){if(n.allowIndefinite===!1)throw new Error(`${F} indefinite length items not allowed`);return new I(p.break,void 0,1)}function np(r,e,t){if(t){if(t.allowNaN===!1&&Number.isNaN(r))throw new Error(`${F} NaN values are not supported`);if(t.allowInfinity===!1&&(r===1/0||r===-1/0))throw new Error(`${F} Infinity values are not supported`)}return new I(p.float,r,e)}function qw(r,e,t,n){return np(op(r,e+1),3,n)}function zw(r,e,t,n){return np(sp(r,e+1),5,n)}function Gw(r,e,t,n){return np(Zw(r,e+1),9,n)}function Cc(r,e,t){let n=e.value;if(n===!1)r.push([p.float.majorEncoded|wS]);else if(n===!0)r.push([p.float.majorEncoded|bS]);else if(n===null)r.push([p.float.majorEncoded|xS]);else if(n===void 0)r.push([p.float.majorEncoded|vS]);else{let o,s=!1;(!t||t.float64!==!0)&&(jw(n),o=op(Wt,1),n===o||Number.isNaN(n)?(Wt[0]=249,r.push(Wt.slice(0,3)),s=!0):(Yw(n),o=sp(Wt,1),n===o&&(Wt[0]=250,r.push(Wt.slice(0,5)),s=!0))),s||(ES(n),o=Zw(Wt,1),Wt[0]=251,r.push(Wt.slice(0,9)))}}Cc.encodedSize=function(e,t){let n=e.value;if(n===!1||n===!0||n===null||n===void 0)return 1;if(!t||t.float64!==!0){jw(n);let o=op(Wt,1);if(n===o||Number.isNaN(n))return 3;if(Yw(n),o=sp(Wt,1),n===o)return 5}return 9};var Ww=new ArrayBuffer(9),Tt=new DataView(Ww,1),Wt=new Uint8Array(Ww,0);function jw(r){if(r===1/0)Tt.setUint16(0,31744,!1);else if(r===-1/0)Tt.setUint16(0,64512,!1);else if(Number.isNaN(r))Tt.setUint16(0,32256,!1);else{Tt.setFloat32(0,r);let e=Tt.getUint32(0),t=(e&2139095040)>>23,n=e&8388607;if(t===255)Tt.setUint16(0,31744,!1);else if(t===0)Tt.setUint16(0,(r&2147483648)>>16|n>>13,!1);else{let o=t-127;o<-24?Tt.setUint16(0,0):o<-14?Tt.setUint16(0,(e&2147483648)>>16|1<<24+o,!1):Tt.setUint16(0,(e&2147483648)>>16|o+15<<10|n>>13,!1)}}}function op(r,e){if(r.length-e<2)throw new Error(`${F} not enough data for float16`);let t=(r[e]<<8)+r[e+1];if(t===31744)return 1/0;if(t===64512)return-1/0;if(t===32256)return NaN;let n=t>>10&31,o=t&1023,s;return n===0?s=o*2**-24:n!==31?s=(o+1024)*2**(n-25):s=o===0?1/0:NaN,t&32768?-s:s}function Yw(r){Tt.setFloat32(0,r,!1)}function sp(r,e){if(r.length-e<4)throw new Error(`${F} not enough data for float32`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,4).getFloat32(0,!1)}function ES(r){Tt.setFloat64(0,r,!1)}function Zw(r,e){if(r.length-e<8)throw new Error(`${F} not enough data for float64`);let t=(r.byteOffset||0)+e;return new DataView(r.buffer,t,8).getFloat64(0,!1)}Cc.compareTokens=Ct.compareTokens;function oe(r,e,t){throw new Error(`${F} encountered invalid minor (${t}) for major ${r[e]>>>5}`)}function Tc(r){return()=>{throw new Error(`${F} ${r}`)}}var L=[];for(let r=0;r<=23;r++)L[r]=oe;L[24]=sw;L[25]=iw;L[26]=aw;L[27]=cw;L[28]=oe;L[29]=oe;L[30]=oe;L[31]=oe;for(let r=32;r<=55;r++)L[r]=oe;L[56]=lw;L[57]=uw;L[58]=fw;L[59]=hw;L[60]=oe;L[61]=oe;L[62]=oe;L[63]=oe;for(let r=64;r<=87;r++)L[r]=pw;L[88]=mw;L[89]=gw;L[90]=yw;L[91]=ww;L[92]=oe;L[93]=oe;L[94]=oe;L[95]=Tc("indefinite length bytes/strings are not supported");for(let r=96;r<=119;r++)L[r]=bw;L[120]=xw;L[121]=vw;L[122]=Ew;L[123]=Aw;L[124]=oe;L[125]=oe;L[126]=oe;L[127]=Tc("indefinite length bytes/strings are not supported");for(let r=128;r<=151;r++)L[r]=Iw;L[152]=kw;L[153]=_w;L[154]=Cw;L[155]=Tw;L[156]=oe;L[157]=oe;L[158]=oe;L[159]=Bw;for(let r=160;r<=183;r++)L[r]=Lw;L[184]=Pw;L[185]=Dw;L[186]=Nw;L[187]=Rw;L[188]=oe;L[189]=oe;L[190]=oe;L[191]=Mw;for(let r=192;r<=215;r++)L[r]=Ow;L[216]=Uw;L[217]=Fw;L[218]=$w;L[219]=Vw;L[220]=oe;L[221]=oe;L[222]=oe;L[223]=oe;for(let r=224;r<=243;r++)L[r]=Tc("simple values are not supported");L[244]=oe;L[245]=oe;L[246]=oe;L[247]=Kw;L[248]=Tc("simple values are not supported");L[249]=qw;L[250]=zw;L[251]=Gw;L[252]=oe;L[253]=oe;L[254]=oe;L[255]=Hw;var jt=[];for(let r=0;r<24;r++)jt[r]=new I(p.uint,r,1);for(let r=-1;r>=-24;r--)jt[31-r]=new I(p.negint,r,1);jt[64]=new I(p.bytes,new Uint8Array(0),1);jt[96]=new I(p.string,"",1);jt[128]=new I(p.array,0,1);jt[160]=new I(p.map,0,1);jt[244]=new I(p.false,!1,1);jt[245]=new I(p.true,!0,1);jt[246]=new I(p.null,null,1);function Xw(r){switch(r.type){case p.false:return hr([244]);case p.true:return hr([245]);case p.null:return hr([246]);case p.bytes:return r.value.length?void 0:hr([64]);case p.string:return r.value===""?hr([96]):void 0;case p.array:return r.value===0?hr([128]):void 0;case p.map:return r.value===0?hr([160]):void 0;case p.uint:return r.value<24?hr([Number(r.value)]):void 0;case p.negint:if(r.value>=-24)return hr([31-Number(r.value)])}}var SS={float64:!1,mapSorter:_S,quickEncodeToken:Xw};function IS(){let r=[];return r[p.uint.major]=Ct,r[p.negint.major]=Ac,r[p.bytes.major]=Qo,r[p.string.major]=Sw,r[p.array.major]=Ic,r[p.map.major]=kc,r[p.tag.major]=_c,r[p.float.major]=Cc,r}var Jw=IS(),ip=new xi,Lc=class r{constructor(e,t){this.obj=e,this.parent=t}includes(e){let t=this;do if(t.obj===e)return!0;while(t=t.parent);return!1}static createCheck(e,t){if(e&&e.includes(t))throw new Error(`${Cr} object contains circular references`);return new r(t,e)}},cn={null:new I(p.null,null),undefined:new I(p.undefined,void 0),true:new I(p.true,!0),false:new I(p.false,!1),emptyArray:new I(p.array,0),emptyMap:new I(p.map,0)},ln={number(r,e,t,n){return!Number.isInteger(r)||!Number.isSafeInteger(r)?new I(p.float,r):r>=0?new I(p.uint,r):new I(p.negint,r)},bigint(r,e,t,n){return r>=BigInt(0)?new I(p.uint,r):new I(p.negint,r)},Uint8Array(r,e,t,n){return new I(p.bytes,r)},string(r,e,t,n){return new I(p.string,r)},boolean(r,e,t,n){return r?cn.true:cn.false},null(r,e,t,n){return cn.null},undefined(r,e,t,n){return cn.undefined},ArrayBuffer(r,e,t,n){return new I(p.bytes,new Uint8Array(r))},DataView(r,e,t,n){return new I(p.bytes,new Uint8Array(r.buffer,r.byteOffset,r.byteLength))},Array(r,e,t,n){if(!r.length)return t.addBreakTokens===!0?[cn.emptyArray,new I(p.break)]:cn.emptyArray;n=Lc.createCheck(n,r);let o=[],s=0;for(let i of r)o[s++]=Bc(i,t,n);return t.addBreakTokens?[new I(p.array,r.length),o,new I(p.break)]:[new I(p.array,r.length),o]},Object(r,e,t,n){let o=e!=="Object",s=o?r.keys():Object.keys(r),i=o?r.size:s.length;if(!i)return t.addBreakTokens===!0?[cn.emptyMap,new I(p.break)]:cn.emptyMap;n=Lc.createCheck(n,r);let a=[],c=0;for(let l of s)a[c++]=[Bc(l,t,n),Bc(o?r.get(l):r[l],t,n)];return kS(a,t),t.addBreakTokens?[new I(p.map,i),a,new I(p.break)]:[new I(p.map,i),a]}};ln.Map=ln.Object;ln.Buffer=ln.Uint8Array;for(let r of"Uint8Clamped Uint16 Uint32 Int8 Int16 Int32 BigUint64 BigInt64 Float32 Float64".split(" "))ln[`${r}Array`]=ln.DataView;function Bc(r,e={},t){let n=X0(r),o=e&&e.typeEncoders&&e.typeEncoders[n]||ln[n];if(typeof o=="function"){let i=o(r,n,e,t);if(i!=null)return i}let s=ln[n];if(!s)throw new Error(`${Cr} unsupported type: ${n}`);return s(r,n,e,t)}function kS(r,e){e.mapSorter&&r.sort(e.mapSorter)}function _S(r,e){let t=Array.isArray(r[0])?r[0][0]:r[0],n=Array.isArray(e[0])?e[0][0]:e[0];if(t.type!==n.type)return t.type.compare(n.type);let o=t.type.major,s=Jw[o].compareTokens(t,n);return s===0&&console.warn("WARNING: complex key types used, CBOR key sorting guarantees are gone"),s}function Qw(r,e,t,n){if(Array.isArray(e))for(let o of e)Qw(r,o,t,n);else t[e.type.major](r,e,n)}function ap(r,e,t){let n=Bc(r,t);if(!Array.isArray(n)&&t.quickEncodeToken){let o=t.quickEncodeToken(n);if(o)return o;let s=e[n.type.major];if(s.encodedSize){let i=s.encodedSize(n,t),a=new xi(i);if(s(a,n,t),a.chunks.length!==1)throw new Error(`Unexpected error: pre-calculated length for ${n} was wrong`);return bi(a.chunks[0])}}return ip.reset(),Qw(ip,n,e,t),ip.toBytes(!0)}function un(r,e){return e=Object.assign({},SS,e),ap(r,Jw,e)}var CS={strict:!1,allowIndefinite:!0,allowUndefined:!0,allowBigInt:!0},Pc=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t}pos(){return this._pos}done(){return this._pos>=this.data.length}next(){let e=this.data[this._pos],t=jt[e];if(t===void 0){let n=L[e];if(!n)throw new Error(`${F} no decoder for major type ${e>>>5} (byte 0x${e.toString(16).padStart(2,"0")})`);let o=e&31;t=n(this.data,this._pos,o,this.options)}return this._pos+=t.encodedLength,t}},Si=Symbol.for("DONE"),Dc=Symbol.for("BREAK");function TS(r,e,t){let n=[];for(let o=0;o<r.value;o++){let s=rs(e,t);if(s===Dc){if(r.value===1/0)break;throw new Error(`${F} got unexpected break to lengthed array`)}if(s===Si)throw new Error(`${F} found array but not enough entries (got ${o}, expected ${r.value})`);n[o]=s}return n}function BS(r,e,t){let n=t.useMaps===!0,o=n?void 0:{},s=n?new Map:void 0;for(let i=0;i<r.value;i++){let a=rs(e,t);if(a===Dc){if(r.value===1/0)break;throw new Error(`${F} got unexpected break to lengthed map`)}if(a===Si)throw new Error(`${F} found map but not enough entries (got ${i} [no key], expected ${r.value})`);if(n!==!0&&typeof a!="string")throw new Error(`${F} non-string keys not supported (got ${typeof a})`);if(t.rejectDuplicateMapKeys===!0&&(n&&s.has(a)||!n&&a in o))throw new Error(`${F} found repeat map key "${a}"`);let c=rs(e,t);if(c===Si)throw new Error(`${F} found map but not enough entries (got ${i} [no value], expected ${r.value})`);n?s.set(a,c):o[a]=c}return n?s:o}function rs(r,e){if(r.done())return Si;let t=r.next();if(t.type===p.break)return Dc;if(t.type.terminal)return t.value;if(t.type===p.array)return TS(t,r,e);if(t.type===p.map)return BS(t,r,e);if(t.type===p.tag){if(e.tags&&typeof e.tags[t.value]=="function"){let n=rs(r,e);return e.tags[t.value](n)}throw new Error(`${F} tag not supported (${t.value})`)}throw new Error("unsupported")}function cp(r,e){if(!(r instanceof Uint8Array))throw new Error(`${F} data to decode must be a Uint8Array`);e=Object.assign({},CS,e);let t=e.tokenizer||new Pc(r,e),n=rs(t,e);if(n===Si)throw new Error(`${F} did not find any content to decode`);if(n===Dc)throw new Error(`${F} got unexpected break`);return[n,r.subarray(t.pos())]}function vt(r,e){let[t,n]=cp(r,e);if(n.length>0)throw new Error(`${F} too many terminals, data makes no sense`);return t}var Nc=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},ns=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Rc=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},Ii=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function Mc(r){return r[Symbol.asyncIterator]!=null}function eb(r,e){if(r.byteLength>e)throw new ns("Message length too long")}var Uc=r=>{let e=Pe(r),t=je(e);return en(r,t),Uc.bytes=e,t};Uc.bytes=0;function Fc(r,e){e=e??{};let t=e.lengthEncoder??Uc,n=e?.maxDataLength??4194304;function*o(s){eb(s,n);let i=t(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return Mc(r)?(async function*(){for await(let s of r)yield*o(s)})():(function*(){for(let s of r)yield*o(s)})()}Fc.single=(r,e)=>{e=e??{};let t=e.lengthEncoder??Uc,n=e?.maxDataLength??4194304;return eb(r,n),new se(t(r.byteLength),r)};var Wn;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Wn||(Wn={}));var fp=r=>{let e=Dn(r);return fp.bytes=Pe(e),e};fp.bytes=0;function up(r,e){let t=new se,n=Wn.LENGTH,o=-1,s=e?.lengthDecoder??fp,i=e?.maxLengthLength??8,a=e?.maxDataLength??4194304;function*c(){for(;t.byteLength>0;){if(n===Wn.LENGTH)try{if(o=s(t),o<0)throw new Nc("Invalid message length");if(o>a)throw new ns("Message length too long");let l=s.bytes;t.consume(l),e?.onLength!=null&&e.onLength(o),n=Wn.DATA}catch(l){if(l instanceof RangeError){if(t.byteLength>i)throw new Rc("Message length length too long");break}throw l}if(n===Wn.DATA){if(t.byteLength<o)break;let l=t.sublist(0,o);t.consume(o),e?.onData!=null&&e.onData(l),yield l,n=Wn.LENGTH}}}return Mc(r)?(async function*(){for await(let l of r)t.append(l),yield*c();if(t.byteLength>0)throw new Ii("Unexpected end of input")})():(function*(){for(let l of r)t.append(l),yield*c();if(t.byteLength>0)throw new Ii("Unexpected end of input")})()}up.fromReader=(r,e)=>{let t=1,n=(async function*(){for(;;)try{let{done:s,value:i}=await r.next(t);if(s===!0)return;i!=null&&(yield i)}catch(s){if(s.code==="ERR_UNDER_READ")return{done:!0,value:null};throw s}finally{t=1}})();return up(n,{...e??{},onLength:s=>{t=s}})};function PS(r,e){if(typeof r=="string")return DS(r);if(typeof r=="number")return MS(r,e);throw Error(`Value provided to ms() must be a string or number. value=${JSON.stringify(r)}`)}var $c=PS;function DS(r){if(typeof r!="string"||r.length===0||r.length>100)throw Error(`Value provided to ms.parse() must be a string with length between 1 and 99. value=${JSON.stringify(r)}`);let e=/^(?<value>-?\d*\.?\d+) *(?<unit>milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|months?|mo|years?|yrs?|y)?$/i.exec(r);if(!e?.groups)return NaN;let{value:t,unit:n="ms"}=e.groups,o=parseFloat(t),s=n.toLowerCase();switch(s){case"years":case"year":case"yrs":case"yr":case"y":return o*315576e5;case"months":case"month":case"mo":return o*26298e5;case"weeks":case"week":case"w":return o*6048e5;case"days":case"day":case"d":return o*864e5;case"hours":case"hour":case"hrs":case"hr":case"h":return o*36e5;case"minutes":case"minute":case"mins":case"min":case"m":return o*6e4;case"seconds":case"second":case"secs":case"sec":case"s":return o*1e3;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return o;default:throw Error(`Unknown unit "${s}" provided to ms.parse(). value=${JSON.stringify(r)}`)}}function NS(r){let e=Math.abs(r);return e>=315576e5?`${Math.round(r/315576e5)}y`:e>=26298e5?`${Math.round(r/26298e5)}mo`:e>=6048e5?`${Math.round(r/6048e5)}w`:e>=864e5?`${Math.round(r/864e5)}d`:e>=36e5?`${Math.round(r/36e5)}h`:e>=6e4?`${Math.round(r/6e4)}m`:e>=1e3?`${Math.round(r/1e3)}s`:`${r}ms`}function RS(r){let e=Math.abs(r);return e>=315576e5?jn(r,e,315576e5,"year"):e>=26298e5?jn(r,e,26298e5,"month"):e>=6048e5?jn(r,e,6048e5,"week"):e>=864e5?jn(r,e,864e5,"day"):e>=36e5?jn(r,e,36e5,"hour"):e>=6e4?jn(r,e,6e4,"minute"):e>=1e3?jn(r,e,1e3,"second"):`${r} ms`}function MS(r,e){if(typeof r!="number"||!Number.isFinite(r))throw Error("Value provided to ms.format() must be of type number.");return e?.long?RS(r):NS(r)}function jn(r,e,t,n){let o=e>=t*1.5;return`${Math.round(r/t)} ${n}${o?"s":""}`}function dp(r){t.debug=t,t.default=t,t.coerce=c,t.disable=s,t.enable=o,t.enabled=i,t.humanize=$c,t.destroy=l,Object.keys(r).forEach(f=>{t[f]=r[f]}),t.names=[],t.skips=[],t.formatters={};function e(f){let u=0;for(let d=0;d<f.length;d++)u=(u<<5)-u+f.charCodeAt(d),u|=0;return t.colors[Math.abs(u)%t.colors.length]}t.selectColor=e;function t(f){let u,d=null,h,m;function g(...y){if(!g.enabled)return;let x=g,T=Number(new Date),S=T-(u||T);x.diff=S,x.prev=u,x.curr=T,u=T,y[0]=t.coerce(y[0]),typeof y[0]!="string"&&y.unshift("%O");let D=0;y[0]=y[0].replace(/%([a-zA-Z%])/g,(G,j)=>{if(G==="%%")return"%";D++;let b=t.formatters[j];if(typeof b=="function"){let v=y[D];G=b.call(x,v),y.splice(D,1),D--}return G}),t.formatArgs.call(x,y),(x.log||t.log).apply(x,y)}return g.namespace=f,g.useColors=t.useColors(),g.color=t.selectColor(f),g.extend=n,g.destroy=t.destroy,Object.defineProperty(g,"enabled",{enumerable:!0,configurable:!1,get:()=>d!==null?d:(h!==t.namespaces&&(h=t.namespaces,m=t.enabled(f)),m),set:y=>{d=y}}),typeof t.init=="function"&&t.init(g),g}function n(f,u){let d=t(this.namespace+(typeof u>"u"?":":u)+f);return d.log=this.log,d}function o(f){t.save(f),t.namespaces=f,t.names=[],t.skips=[];let u,d=(typeof f=="string"?f:"").split(/[\s,]+/),h=d.length;for(u=0;u<h;u++)d[u]&&(f=d[u].replace(/\*/g,".*?"),f[0]==="-"?t.skips.push(new RegExp("^"+f.substr(1)+"$")):t.names.push(new RegExp("^"+f+"$")))}function s(){let f=[...t.names.map(a),...t.skips.map(a).map(u=>"-"+u)].join(",");return t.enable(""),f}function i(f){if(f[f.length-1]==="*")return!0;let u,d;for(u=0,d=t.skips.length;u<d;u++)if(t.skips[u].test(f))return!1;for(u=0,d=t.names.length;u<d;u++)if(t.names[u].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 l(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return t.setupFormatters(t.formatters),t.enable(t.load()),t}var Vc=HS(),OS=["#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 US(){return typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs)?!0:typeof navigator<"u"&&navigator.userAgent?.toLowerCase().match(/(edge|trident)\/(\d+)/)!=null?!1:typeof document<"u"&&document.documentElement?.style?.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent?.toLowerCase().match(/firefox\/(\d+)/)!=null&&parseInt(RegExp.$1,10)>=31||typeof navigator<"u"&&navigator.userAgent?.toLowerCase().match(/applewebkit\/(\d+)/)}function FS(r){if(r[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+r[0]+(this.useColors?"%c ":" ")+"+"+$c(this.diff),!this.useColors)return;let e="color: "+this.color;r.splice(1,0,e,"color: inherit");let t=0,n=0;r[0].replace(/%[a-zA-Z%]/g,o=>{o!=="%%"&&(t++,o==="%c"&&(n=t))}),r.splice(n,0,e)}var $S=console.debug??console.log??(()=>{});function VS(r){try{r?Vc?.setItem("debug",r):Vc?.removeItem("debug")}catch{}}function KS(){let r;try{r=Vc?.getItem("debug")}catch{}return!r&&typeof globalThis.process<"u"&&"env"in globalThis.process&&(r=globalThis.process.env.DEBUG),r}function HS(){try{return localStorage}catch{}}function qS(r){r.j=function(e){try{return JSON.stringify(e)}catch(t){return"[UnexpectedJSONParseError]: "+t.message}}}var tb=dp({formatArgs:FS,save:VS,load:KS,useColors:US,setupFormatters:qS,colors:OS,storage:Vc,log:$S});var lt=tb;lt.formatters.b=r=>r==null?"undefined":le.baseEncode(r);lt.formatters.t=r=>r==null?"undefined":Te.baseEncode(r);lt.formatters.m=r=>r==null?"undefined":Ye.baseEncode(r);lt.formatters.p=r=>r==null?"undefined":r.toString();lt.formatters.c=r=>r==null?"undefined":r.toString();lt.formatters.k=r=>r==null?"undefined":r.toString();lt.formatters.a=r=>r==null?"undefined":r.toString();lt.formatters.e=r=>{if(r==null)return"undefined";let e=rb(r.message),t=rb(r.stack);return e!=null&&t!=null?t.includes(e)?t:`${e}
4
- ${t}`:t??e??r.toString()};function zS(r){let e=()=>{};return e.enabled=!1,e.color="",e.diff=0,e.log=()=>{},e.namespace=r,e.destroy=()=>!0,e.extend=()=>e,e}function fn(){return{forComponent(r){return ut(r)}}}function ut(r){let e=zS(`${r}:trace`);return lt.enabled(`${r}:trace`)&&lt.names.map(t=>t.toString()).find(t=>t.includes(":trace"))!=null&&(e=lt(`${r}:trace`)),Object.assign(lt(r),{error:lt(`${r}:error`),trace:e,newScope:t=>ut(`${r}:${t}`)})}function rb(r){if(r!=null&&(r=r.trim(),r.length!==0))return r}var os=class extends Gt{has(e){return this.find(e)!=null}find(e){return this.queue.find(t=>e.equals(t.options.peerId))}};var Kc=class extends Gt{constructor(e={}){super({...e,sort:(t,n)=>t.options.priority>n.options.priority?-1:t.options.priority<n.options.priority?1:0})}};var Hc=class{memoryStorage;points;duration;blockDuration;keyPrefix;constructor(e={}){this.points=e.points??4,this.duration=e.duration??1,this.blockDuration=e.blockDuration??0,this.keyPrefix=e.keyPrefix??"rlflx",this.memoryStorage=new hp}consume(e,t=1,n={}){let o=this.getKey(e),s=this._getKeySecDuration(n),i=this.memoryStorage.incrby(o,t,s);if(i.remainingPoints=Math.max(this.points-i.consumedPoints,0),i.consumedPoints>this.points)throw this.blockDuration>0&&i.consumedPoints<=this.points+t&&(i=this.memoryStorage.set(o,i.consumedPoints,this.blockDuration)),new ic("Rate limit exceeded",i);return i}penalty(e,t=1,n={}){let o=this.getKey(e),s=this._getKeySecDuration(n),i=this.memoryStorage.incrby(o,t,s);return i.remainingPoints=Math.max(this.points-i.consumedPoints,0),i}reward(e,t=1,n={}){let o=this.getKey(e),s=this._getKeySecDuration(n),i=this.memoryStorage.incrby(o,-t,s);return i.remainingPoints=Math.max(this.points-i.consumedPoints,0),i}block(e,t){let n=t*1e3,o=this.points+1;return this.memoryStorage.set(this.getKey(e),o,t),{remainingPoints:0,msBeforeNext:n===0?-1:n,consumedPoints:o,isFirstInDuration:!1}}set(e,t,n=0){let o=(n>=0?n:this.duration)*1e3;return this.memoryStorage.set(this.getKey(e),t,n),{remainingPoints:0,msBeforeNext:o===0?-1:o,consumedPoints:t,isFirstInDuration:!1}}get(e){let t=this.memoryStorage.get(this.getKey(e));return t!=null&&(t.remainingPoints=Math.max(this.points-t.consumedPoints,0)),t}delete(e){this.memoryStorage.delete(this.getKey(e))}_getKeySecDuration(e){return e?.customDuration!=null&&e.customDuration>=0?e.customDuration:this.duration}getKey(e){return this.keyPrefix.length>0?`${this.keyPrefix}:${e}`:e}parseKey(e){return e.substring(this.keyPrefix.length)}},hp=class{storage;constructor(){this.storage=new Map}incrby(e,t,n){let o=this.storage.get(e);if(o!=null){let s=o.expiresAt!=null?o.expiresAt.getTime()-new Date().getTime():-1;return o.expiresAt==null||s>0?(o.value+=t,{remainingPoints:0,msBeforeNext:s,consumedPoints:o.value,isFirstInDuration:!1}):this.set(e,t,n)}return this.set(e,t,n)}set(e,t,n){let o=n*1e3,s=this.storage.get(e);s!=null&&clearTimeout(s.timeoutId);let i={value:t,expiresAt:o>0?new Date(Date.now()+o):void 0};return this.storage.set(e,i),o>0&&(i.timeoutId=setTimeout(()=>{this.storage.delete(e)},o),i.timeoutId.unref!=null&&i.timeoutId.unref()),{remainingPoints:0,msBeforeNext:o===0?-1:o,consumedPoints:i.value,isFirstInDuration:!0}}get(e){let t=this.storage.get(e);if(t!=null)return{remainingPoints:0,msBeforeNext:t.expiresAt!=null?t.expiresAt.getTime()-new Date().getTime():-1,consumedPoints:t.value,isFirstInDuration:!1}}delete(e){let t=this.storage.get(e);return t!=null?(t.timeoutId!=null&&clearTimeout(t.timeoutId),this.storage.delete(e),!0):!1}};var pp=class extends Map{metric;constructor(e){super();let{name:t,metrics:n}=e;this.metric=n.registerMetric(t),this.updateComponentMetric()}set(e,t){return super.set(e,t),this.updateComponentMetric(),this}delete(e){let t=super.delete(e);return this.updateComponentMetric(),t}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function Je(r){let{name:e,metrics:t}=r,n;return t!=null?n=new pp({name:e,metrics:t}):n=new Map,n}function GS(r){return r[Symbol.asyncIterator]!=null}function WS(r){if(GS(r))return(async()=>{for await(let e of r);})();for(let e of r);}var ki=WS;function jS(r){let[e,t]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>e.next(),push:o=>{n.push(o)},next:()=>n.length>0?{done:!1,value:n.shift()}:e.next(),[t](){return this}}}var ss=jS;function YS(r){return r[Symbol.asyncIterator]!=null}function ZS(r,e){let t=0;if(YS(r))return(async function*(){for await(let c of r)yield e(c,t++)})();let n=ss(r),{value:o,done:s}=n.next();if(s===!0)return(function*(){})();let i=e(o,t++);if(typeof i.then=="function")return(async function*(){yield await i;for(let c of n)yield e(c,t++)})();let a=e;return(function*(){yield i;for(let c of n)yield a(c,t++)})()}var qc=ZS;function XS(r){return r[Symbol.asyncIterator]!=null}function JS(r,e){return XS(r)?(async function*(){let t=0;if(!(e<1)){for await(let n of r)if(yield n,t++,t===e)return}})():(function*(){let t=0;if(!(e<1)){for(let n of r)if(yield n,t++,t===e)return}})()}var zc=JS;var Et=class extends Error{static name="AbortError";name="AbortError";constructor(e="The operation was aborted",...t){super(e,...t)}};async function Gc(r,e,t,n){let o=new Et(n?.errorMessage);n?.errorCode!=null&&(o.code=n.errorCode);let s=n?.errorEvent??"error";return t?.aborted===!0?Promise.reject(o):new Promise((i,a)=>{function c(){gp(t,"abort",u),gp(r,e,l),gp(r,s,f)}let l=d=>{try{if(n?.filter?.(d)===!1)return}catch(h){c(),a(h);return}c(),i(d)},f=d=>{if(c(),d instanceof Error){a(d);return}a(d.detail??n?.error??new Error(`The "${n?.errorEvent}" event was emitted but the event had no '.detail' field. Pass an 'error' option to race-event to change this message.`))},u=()=>{c(),a(o)};mp(t,"abort",u),mp(r,e,l),mp(r,s,f)})}function mp(r,e,t){r!=null&&(nb(r)?r.addEventListener(e,t):r.addListener(e,t))}function gp(r,e,t){r!=null&&(nb(r)?r.removeEventListener(e,t):r.removeListener(e,t))}function nb(r){return typeof r.addEventListener=="function"&&typeof r.removeEventListener=="function"}var ob=Symbol.for("nodejs.util.inspect.custom"),QS=114,_i=class{type;multihash;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Ca]=!0;toString(){return this.string==null&&(this.string=le.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return K.createV1(QS,this.multihash)}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return X(this.multihash.bytes,e);if(typeof e=="string")return this.toString()===e;if(e?.toMultihash()?.bytes!=null)return X(this.multihash.bytes,e.toMultihash().bytes);throw new Error("not valid Id")}[ob](){return`PeerId(${this.toString()})`}},Ci=class extends _i{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},Ti=class extends _i{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.publicKey}},Bi=class extends _i{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.publicKey}},eI=2336,Li=class{type="url";multihash;publicKey;url;constructor(e){this.url=e.toString(),this.multihash=We.digest(B(this.url))}[ob](){return`PeerId(${this.url})`}[Ca]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return K.createV1(eI,this.toMultihash())}toJSON(){return this.toString()}equals(e){return e==null?!1:(e instanceof Uint8Array&&(e=U(e)),e.toString()===this.toString())}};var tI=114,sb=2336;function Bt(r,e){let t;if(r.charAt(0)==="1"||r.charAt(0)==="Q")t=pt(le.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return Yn(K.parse(r));if(e==null)throw new k('Please pass a multibase decoder for strings that do not start with "1" or "Q"');t=pt(e.decode(r))}return is(t)}function yp(r){if(r.type==="Ed25519")return new Ti({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Bi({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new Ci({multihash:r.toCID().multihash,publicKey:r});throw new Nt}function ib(r){return yp(r.publicKey)}function is(r){if(nI(r))return new Ci({multihash:r});if(rI(r))try{let e=Ja(r);if(e.type==="Ed25519")return new Ti({multihash:r,publicKey:e});if(e.type==="secp256k1")return new Bi({multihash:r,publicKey:e})}catch{let t=U(r.digest);return new Li(new URL(t))}throw new Hr("Supplied PeerID Multihash is invalid")}function Yn(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==tI&&r.code!==sb)throw new va("Supplied PeerID CID is invalid");if(r.code===sb){let e=U(r.multihash.digest);return new Li(new URL(e))}return is(r.multihash)}function rI(r){return r.code===We.code}function nI(r){return r.code===Mt.code}function Zn(r,e){let t={[Symbol.iterator]:()=>t,next:()=>{let n=r.next(),o=n.value;return n.done===!0||o==null?{done:!0,value:void 0}:{done:!1,value:e(o)}}};return t}function Wc(r){let e=pt(le.decode(`z${r}`));return is(e)}var Lt=class{map;constructor(e){if(this.map=new Map,e!=null)for(let[t,n]of e.entries())this.map.set(t.toString(),{key:t,value:n})}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(e){return this.map.delete(e.toString())}entries(){return Zn(this.map.entries(),e=>[e[1].key,e[1].value])}forEach(e){this.map.forEach((t,n)=>{e(t.value,t.key,this)})}get(e){return this.map.get(e.toString())?.value}has(e){return this.map.has(e.toString())}set(e,t){this.map.set(e.toString(),{key:e,value:t})}keys(){return Zn(this.map.values(),e=>e.key)}values(){return Zn(this.map.values(),e=>e.value)}get size(){return this.map.size}};var Xn=class r{set;constructor(e){if(this.set=new Set,e!=null)for(let t of e)this.set.add(t.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(e){this.set.add(e.toString())}clear(){this.set.clear()}delete(e){this.set.delete(e.toString())}entries(){return Zn(this.set.entries(),e=>{let t=Wc(e[0]);return[t,t]})}forEach(e){this.set.forEach(t=>{let n=Wc(t);e(n,n,this)})}has(e){return this.set.has(e.toString())}values(){return Zn(this.set.values(),e=>Wc(e))}intersection(e){let t=new r;for(let n of e)this.has(n)&&t.add(n);return t}difference(e){let t=new r;for(let n of this)e.has(n)||t.add(n);return t}union(e){let t=new r;for(let n of e)t.add(n);for(let n of this)t.add(n);return t}};var wp=class extends Lt{metric;constructor(e){super();let{name:t,metrics:n}=e;this.metric=n.registerMetric(t),this.updateComponentMetric()}set(e,t){return super.set(e,t),this.updateComponentMetric(),this}delete(e){let t=super.delete(e);return this.updateComponentMetric(),t}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function bp(r){let{name:e,metrics:t}=r,n;return t!=null?n=new wp({name:e,metrics:t}):n=new Lt,n}function oI(r){return r[Symbol.asyncIterator]!=null}function sI(r){if(oI(r))return(async()=>{let n=new Uint8Array(0);for await(let o of r)n=Ce([n,o],n.length+o.length);return n})();let e=[],t=0;for(let n of r)e.push(n),t+=n.byteLength;return Ce(e,t)}var ab=sI;var vp=wn(lb(),1);var Ep=class r extends Error{name="TimeoutError";constructor(e,t){super(e,t),Error.captureStackTrace?.(this,r)}},ub=r=>r.reason??new DOMException("This operation was aborted.","AbortError");function Ap(r,e){let{milliseconds:t,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout},signal:i}=e,a,c,f=new Promise((u,d)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(i?.aborted){d(ub(i));return}if(i&&(c=()=>{d(ub(i))},i.addEventListener("abort",c,{once:!0})),r.then(u,d),t===Number.POSITIVE_INFINITY)return;let h=new Ep;a=s.setTimeout.call(void 0,()=>{if(n){try{u(n())}catch(m){d(m)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?u():o instanceof Error?d(o):(h.message=o??`Promise timed out after ${t} milliseconds`,d(h))},t)}).finally(()=>{f.clear(),c&&i&&i.removeEventListener("abort",c)});return f.clear=()=>{s.clearTimeout.call(void 0,a),a=void 0},f}function Sp(r,e,t){let n=0,o=r.length;for(;o>0;){let s=Math.trunc(o/2),i=n+s;t(r[i],e)<=0?(n=++i,o-=s+1):o=s}return n}var Di=class{#e=[];enqueue(e,t){let{priority:n=0,id:o}=t??{},s={priority:n,id:o,run:e};if(this.size===0||this.#e[this.size-1].priority>=n){this.#e.push(s);return}let i=Sp(this.#e,s,(a,c)=>c.priority-a.priority);this.#e.splice(i,0,s)}setPriority(e,t){let n=this.#e.findIndex(s=>s.id===e);if(n===-1)throw new ReferenceError(`No promise function with the id "${e}" exists in the queue.`);let[o]=this.#e.splice(n,1);this.enqueue(o.run,{priority:t,id:e})}dequeue(){return this.#e.shift()?.run}filter(e){return this.#e.filter(t=>t.priority===e.priority).map(t=>t.run)}get size(){return this.#e.length}};var Jn=class extends vp.default{#e;#t;#r=0;#i;#s=!1;#f=!1;#d;#b=0;#g=0;#a;#c;#n;#x;#o=0;#h;#l;#k=1n;#p=new Map;timeout;constructor(e){if(super(),e={carryoverIntervalCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:Di,...e},!(typeof e.intervalCap=="number"&&e.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${e.intervalCap?.toString()??""}\` (${typeof e.intervalCap})`);if(e.interval===void 0||!(Number.isFinite(e.interval)&&e.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${e.interval?.toString()??""}\` (${typeof e.interval})`);if(this.#e=e.carryoverIntervalCount??e.carryoverConcurrencyCount??!1,this.#t=e.intervalCap===Number.POSITIVE_INFINITY||e.interval===0,this.#i=e.intervalCap,this.#d=e.interval,this.#n=new e.queueClass,this.#x=e.queueClass,this.concurrency=e.concurrency,e.timeout!==void 0&&!(Number.isFinite(e.timeout)&&e.timeout>0))throw new TypeError(`Expected \`timeout\` to be a positive finite number, got \`${e.timeout}\` (${typeof e.timeout})`);this.timeout=e.timeout,this.#l=e.autoStart===!1,this.#N()}get#_(){return this.#t||this.#r<this.#i}get#C(){return this.#o<this.#h}#T(){this.#o--,this.#o===0&&this.emit("pendingZero"),this.#y(),this.emit("next")}#B(){this.#S(),this.#A(),this.#c=void 0}get#L(){let e=Date.now();if(this.#a===void 0){let t=this.#b-e;if(t<0){if(this.#g>0){let n=e-this.#g;if(n<this.#d)return this.#v(this.#d-n),!0}this.#r=this.#e?this.#o:0}else return this.#v(t),!0}return!1}#v(e){this.#c===void 0&&(this.#c=setTimeout(()=>{this.#B()},e))}#E(){this.#a&&(clearInterval(this.#a),this.#a=void 0)}#P(){this.#c&&(clearTimeout(this.#c),this.#c=void 0)}#y(){if(this.#n.size===0)return this.#E(),this.emit("empty"),this.#o===0&&(this.#P(),this.emit("idle")),!1;let e=!1;if(!this.#l){let t=!this.#L;if(this.#_&&this.#C){let n=this.#n.dequeue();this.#t||(this.#r++,this.#m()),this.emit("active"),this.#g=Date.now(),n(),t&&this.#A(),e=!0}}return e}#A(){this.#t||this.#a!==void 0||(this.#a=setInterval(()=>{this.#S()},this.#d),this.#b=Date.now()+this.#d)}#S(){this.#r===0&&this.#o===0&&this.#a&&this.#E(),this.#r=this.#e?this.#o:0,this.#w(),this.#m()}#w(){for(;this.#y(););}get concurrency(){return this.#h}set concurrency(e){if(!(typeof e=="number"&&e>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${e}\` (${typeof e})`);this.#h=e,this.#w()}async#D(e){return new Promise((t,n)=>{e.addEventListener("abort",()=>{n(e.reason)},{once:!0})})}setPriority(e,t){if(typeof t!="number"||!Number.isFinite(t))throw new TypeError(`Expected \`priority\` to be a finite number, got \`${t}\` (${typeof t})`);this.#n.setPriority(e,t)}async add(e,t={}){return t.id??=(this.#k++).toString(),t={timeout:this.timeout,...t},new Promise((n,o)=>{let s=Symbol(`task-${t.id}`);this.#n.enqueue(async()=>{this.#o++,this.#p.set(s,{id:t.id,priority:t.priority??0,startTime:Date.now(),timeout:t.timeout});try{try{t.signal?.throwIfAborted()}catch(c){throw this.#t||this.#r--,this.#p.delete(s),c}let i=e({signal:t.signal});t.timeout&&(i=Ap(Promise.resolve(i),{milliseconds:t.timeout,message:`Task timed out after ${t.timeout}ms (queue has ${this.#o} running, ${this.#n.size} waiting)`})),t.signal&&(i=Promise.race([i,this.#D(t.signal)]));let a=await i;n(a),this.emit("completed",a)}catch(i){o(i),this.emit("error",i)}finally{this.#p.delete(s),queueMicrotask(()=>{this.#T()})}},t),this.emit("add"),this.#y()})}async addAll(e,t){return Promise.all(e.map(async n=>this.add(n,t)))}start(){return this.#l?(this.#l=!1,this.#w(),this):this}pause(){this.#l=!0}clear(){this.#n=new this.#x,this.#I()}async onEmpty(){this.#n.size!==0&&await this.#u("empty")}async onSizeLessThan(e){this.#n.size<e||await this.#u("next",()=>this.#n.size<e)}async onIdle(){this.#o===0&&this.#n.size===0||await this.#u("idle")}async onPendingZero(){this.#o!==0&&await this.#u("pendingZero")}async onRateLimit(){this.isRateLimited||await this.#u("rateLimit")}async onRateLimitCleared(){this.isRateLimited&&await this.#u("rateLimitCleared")}async onError(){return new Promise((e,t)=>{let n=o=>{this.off("error",n),t(o)};this.on("error",n)})}async#u(e,t){return new Promise(n=>{let o=()=>{t&&!t()||(this.off(e,o),n())};this.on(e,o)})}get size(){return this.#n.size}sizeBy(e){return this.#n.filter(e).length}get pending(){return this.#o}get isPaused(){return this.#l}#N(){this.#t||(this.on("add",()=>{this.#n.size>0&&this.#m()}),this.on("next",()=>{this.#m()}))}#m(){this.#t||this.#f||(this.#f=!0,queueMicrotask(()=>{this.#f=!1,this.#I()}))}#I(){let e=this.#s,t=!this.#t&&this.#r>=this.#i&&this.#n.size>0;t!==e&&(this.#s=t,this.emit(t?"rateLimit":"rateLimitCleared"))}get isRateLimited(){return this.#s}get isSaturated(){return this.#o===this.#h&&this.#n.size>0||this.isRateLimited&&this.#n.size>0}get runningTasks(){return[...this.#p.values()].map(e=>({...e}))}};function Yc(r){let e=[At.A];return r==null?e:Array.isArray(r)?r.length===0?e:r:[r]}var Ip=60;function Zc(r){return{Status:r.Status??0,TC:r.TC??r.flag_tc??!1,RD:r.RD??r.flag_rd??!1,RA:r.RA??r.flag_ra??!1,AD:r.AD??r.flag_ad??!1,CD:r.CD??r.flag_cd??!1,Question:(r.Question??r.questions??[]).map(e=>({name:e.name,type:At[e.type]})),Answer:(r.Answer??r.answers??[]).map(e=>({name:e.name,type:At[e.type],TTL:e.TTL??e.ttl??Ip,data:e.data instanceof Uint8Array?U(e.data):e.data}))}}var cI=4;function kp(r,e={}){let t=new Jn({concurrency:e.queryConcurrency??cI});return async(n,o={})=>{let s=new URLSearchParams;s.set("name",n),Yc(o.types).forEach(a=>{s.append("type",At[a])}),o.onProgress?.(new Y("dns:query",n));let i=await t.add(async()=>{let a=await fetch(`${r}?${s}`,{headers:{accept:"application/dns-json"},signal:o?.signal});if(a.status!==200)throw new Error(`Unexpected HTTP status: ${a.status} - ${a.statusText}`);let c=Zc(await a.json());return o.onProgress?.(new Y("dns:response",c)),c},{signal:o.signal});if(i==null)throw new Error("No DNS response received");return i}}function fb(){return[kp("https://cloudflare-dns.com/dns-query"),kp("https://dns.google/resolve")]}var pb=wn(hb(),1);var _p=class{lru;constructor(e){this.lru=(0,pb.default)(e)}get(e,t){let n=!0,o=[];for(let s of t){let i=this.getAnswers(e,s);if(i.length===0){n=!1;break}o.push(...i)}if(n)return Zc({answers:o})}getAnswers(e,t){let n=`${e.toLowerCase()}-${t}`,o=this.lru.get(n);if(o!=null){let s=o.filter(i=>i.expires>Date.now()).map(({expires:i,value:a})=>({...a,TTL:Math.round((i-Date.now())/1e3),type:At[a.type]}));return s.length===0&&this.lru.remove(n),s}return[]}add(e,t){let n=`${e.toLowerCase()}-${t.type}`,o=this.lru.get(n)??[];o.push({expires:Date.now()+(t.TTL??Ip)*1e3,value:t}),this.lru.set(n,o)}remove(e,t){let n=`${e.toLowerCase()}-${t}`;this.lru.remove(n)}clear(){this.lru.clear()}};function mb(r){return new _p(r)}var lI=1e3,Xc=class{resolvers;cache;constructor(e){this.resolvers={},this.cache=mb(e.cacheSize??lI),Object.entries(e.resolvers??{}).forEach(([t,n])=>{Array.isArray(n)||(n=[n]),t.endsWith(".")||(t=`${t}.`),this.resolvers[t]=n}),this.resolvers["."]==null&&(this.resolvers["."]=fb())}async query(e,t={}){let n=Yc(t.types),o=t.cached!==!1?this.cache.get(e,n):void 0;if(o!=null)return t.onProgress?.(new Y("dns:cache",o)),o;let s=`${e.split(".").pop()}.`,i=(this.resolvers[s]??this.resolvers["."]).sort(()=>Math.random()>.5?-1:1),a=[];for(let c of i){if(t.signal?.aborted===!0)break;try{let l=await c(e,{...t,types:n});for(let f of l.Answer)this.cache.add(e,f);return l}catch(l){a.push(l),t.onProgress?.(new Y("dns:error",l))}}throw a.length===1?a[0]:new AggregateError(a,`DNS lookup of ${e} ${n} failed`)}};var At;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(At||(At={}));function Jc(r={}){return new Xc(r)}var Br="/",gb=new TextEncoder().encode(Br),Qc=gb[0],ge=class r{_buf;constructor(e,t){if(typeof e=="string")this._buf=B(e);else if(e instanceof Uint8Array)this._buf=e;else throw new Error("Invalid key, should be String of Uint8Array");if(t==null&&(t=!0),t&&this.clean(),this._buf.byteLength===0||this._buf[0]!==Qc)throw new Error("Invalid key")}toString(e="utf8"){return U(this._buf,e)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(e){return new r(e.join(Br))}static random(){return new r(Math.random().toString().substring(2))}static asKey(e){return e instanceof Uint8Array||typeof e=="string"?new r(e):typeof e.uint8Array=="function"?new r(e.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=gb),this._buf[0]!==Qc){let e=new Uint8Array(this._buf.byteLength+1);e.fill(Qc,0,1),e.set(this._buf,1),this._buf=e}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Qc;)this._buf=this._buf.subarray(0,-1)}less(e){let t=this.list(),n=e.list();for(let o=0;o<t.length;o++){if(n.length<o+1)return!1;let s=t[o],i=n[o];if(s<i)return!0;if(s>i)return!1}return t.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let e=this.namespaces();return e[e.length-1]}list(){return this.toString().split(Br).slice(1)}type(){return uI(this.baseNamespace())}name(){return fI(this.baseNamespace())}instance(e){return new r(this.toString()+":"+e)}path(){let e=this.parent().toString();return e.endsWith(Br)||(e+=Br),e+=this.type(),new r(e)}parent(){let e=this.list();return e.length===1?new r(Br):new r(e.slice(0,-1).join(Br))}child(e){return this.toString()===Br?e:e.toString()===Br?this:new r(this.toString()+e.toString(),!1)}isAncestorOf(e){return e.toString()===this.toString()?!1:e.toString().startsWith(this.toString())}isDecendantOf(e){return e.toString()===this.toString()?!1:this.toString().startsWith(e.toString())}isTopLevel(){return this.list().length===1}concat(...e){return r.withNamespaces([...this.namespaces(),...dI(e.map(t=>t.namespaces()))])}};function uI(r){let e=r.split(":");return e.length<2?"":e.slice(0,-1).join(":")}function fI(r){let e=r.split(":");return e[e.length-1]}function dI(r){return[].concat(...r)}function el({enumerable:r=!0,configurable:e=!1}={}){return{enumerable:r,configurable:e,writable:!1}}function*hI(r,e){if(e!=null&&typeof e=="object")if(Array.isArray(e))for(let[t,n]of e.entries()){let o=[...r,t],s=K.asCID(n);s!=null?yield[o.join("/"),s]:typeof n=="object"&&(yield*Cp(n,o))}else{let t=K.asCID(e);t!=null?yield[r.join("/"),t]:yield*Cp(e,r)}}function*Cp(r,e){if(r==null||r instanceof Uint8Array)return;let t=K.asCID(r);t!=null&&(yield[e.join("/"),t]);for(let[n,o]of Object.entries(r)){let s=[...e,n];yield*hI(s,o)}}function*pI(r,e){if(Array.isArray(e))for(let[t,n]of e.entries()){let o=[...r,t];yield o.join("/"),typeof n=="object"&&K.asCID(n)==null&&(yield*Tp(n,o))}else yield*Tp(e,r)}function*Tp(r,e){if(!(r==null||typeof r!="object"))for(let[t,n]of Object.entries(r)){let o=[...e,t];yield o.join("/"),n!=null&&!(n instanceof Uint8Array)&&typeof n=="object"&&K.asCID(n)==null&&(yield*pI(o,n))}}function mI(r,e){let t=r;for(let[n,o]of e.entries()){if(t=t[o],t==null)throw new Error(`Object has no property at ${e.slice(0,n+1).map(i=>`[${JSON.stringify(i)}]`).join("")}`);let s=K.asCID(t);if(s!=null)return{value:s,remaining:e.slice(n+1).join("/")}}return{value:t}}var Bp=class{cid;bytes;value;asBlock;constructor({cid:e,bytes:t,value:n}){if(e==null||t==null||typeof n>"u")throw new Error("Missing required argument");this.cid=e,this.bytes=t,this.value=n,this.asBlock=this,Object.defineProperties(this,{cid:el(),bytes:el(),value:el(),asBlock:el()})}links(){return Cp(this.value,[])}tree(){return Tp(this.value,[])}get(e="/"){return mI(this.value,e.split("/").filter(Boolean))}};function yb({bytes:r,cid:e,value:t,codec:n}){let o=t!==void 0?t:n?.decode(r);if(o===void 0)throw new Error('Missing required argument, must either provide "value" or "codec"');return new Bp({cid:e,bytes:r,value:o})}var tl=class extends Error{static name="AlreadyPinnedError";name="AlreadyPinnedError"},Ni=class extends Error{static name="BlockPinnedError";name="BlockPinnedError"},rl=class extends Error{static name="InvalidDatastoreVersionError";name="InvalidDatastoreVersionError"},nl=class extends Error{static name="InvalidConfigurationError";name="InvalidConfigurationError"};var xb="/pin/",wb="/pinned-block/",Lp=ar,bb=1;function ol(r){return r.version===0&&(r=r.toV1()),new ge(`${xb}${r.toString(Lp)}`)}var sl=class{datastore;blockstore;getCodec;constructor(e,t,n){this.datastore=e,this.blockstore=t,this.getCodec=n}async*add(e,t={}){let n=ol(e);if(await this.datastore.has(n))throw new tl("Already pinned");let o=Math.round(t.depth??1/0);if(o<0)throw new k("Depth must be greater than or equal to 0");let s=new Gt({concurrency:bb});for await(let a of this.#e(e,s,{...t,depth:o}))await this.#t(a,c=>c.pinnedBy.find(l=>X(l,e.bytes))!=null?!1:(c.pinCount++,c.pinnedBy.push(e.bytes),!0),t),yield a;let i={depth:o,metadata:t.metadata??{}};await this.datastore.put(n,un(i),t)}async*#e(e,t,n){if(n.depth===-1)return;let o=await this.getCodec(e.code),s=await ab(this.blockstore.get(e,n)),i=yb({bytes:s,cid:e,codec:o});yield e;for(let[,a]of i.links())yield*await t.add(async()=>this.#e(a,t,{...n,depth:n.depth-1}))}async#t(e,t,n){let o=new ge(`${wb}${Lp.encode(e.multihash.bytes)}`),s={pinCount:0,pinnedBy:[]};try{s=vt(await this.datastore.get(o,n))}catch(a){if(a.name!=="NotFoundError")throw a}if(t(s)){if(s.pinCount===0&&await this.datastore.has(o)){await this.datastore.delete(o);return}await this.datastore.put(o,un(s),n),n.onProgress?.(new Y("helia:pin:add",e))}}async*rm(e,t={}){let n=ol(e),o=await this.datastore.get(n,t),s=vt(o);await this.datastore.delete(n,t);let i=new Gt({concurrency:bb});for await(let a of this.#e(e,i,{...t,depth:s.depth}))await this.#t(a,c=>(c.pinCount--,c.pinnedBy=c.pinnedBy.filter(l=>X(l,e.bytes)),!0),{...t,depth:s.depth}),yield a}async*ls(e={}){for await(let{key:t,value:n}of this.datastore.query({prefix:xb+(e.cid!=null?`${e.cid.toString(ar)}`:"")},e)){let o=K.parse(t.toString().substring(5),ar),s=vt(n);yield{cid:o,...s}}}async isPinned(e,t={}){let n=new ge(`${wb}${Lp.encode(e.multihash.bytes)}`);return this.datastore.has(n,t)}async get(e,t){let n=ol(e),o=await this.datastore.get(n,t);return vt(o)}async setMetadata(e,t,n){let o=ol(e),s=await this.datastore.get(o,n),i=vt(s);i.metadata=t??{},await this.datastore.put(o,un(i),n)}};var Pp=1,Dp=5;var Ri=class extends Error{static name="InsufficientProvidersError";constructor(e="Insufficient providers found"){super(e),this.name="InsufficientProvidersError"}},dn=class extends Error{static name="NoRoutersAvailableError";constructor(e="No routers available"){super(e),this.name="NoRoutersAvailableError"}},Mi=class extends Error{static name="UnknownHashAlgorithmError";constructor(e="Unknown hash algorithm"){super(e),this.name="UnknownHashAlgorithmError"}},Oi=class extends Error{static name="UnknownCodecError";constructor(e="Unknown codec"){super(e),this.name="UnknownCodecError"}},Np=class extends Error{static name="InvalidCodecError";constructor(e="Invalid codec"){super(e),this.name="InvalidCodecError"}};var gI=5,il=class{log;routers;providerLookupConcurrency;constructor(e,t){this.log=e.logger.forComponent("helia:routing"),this.routers=t.routers??[],this.providerLookupConcurrency=t.providerLookupConcurrency??gI,this.findProviders=e.metrics?.traceFunction("helia.routing.findProviders",this.findProviders.bind(this),{optionsIndex:1})??this.findProviders,this.provide=e.metrics?.traceFunction("helia.routing.provide",this.provide.bind(this),{optionsIndex:1})??this.provide,this.cancelReprovide=e.metrics?.traceFunction("helia.routing.cancelReprovide",this.cancelReprovide.bind(this),{optionsIndex:1})??this.cancelReprovide,this.put=e.metrics?.traceFunction("helia.routing.put",this.put.bind(this),{optionsIndex:2})??this.put,this.get=e.metrics?.traceFunction("helia.routing.get",this.get.bind(this),{optionsIndex:1})??this.get,this.findPeer=e.metrics?.traceFunction("helia.routing.findPeer",this.findPeer.bind(this),{optionsIndex:1})??this.findPeer,this.getClosestPeers=e.metrics?.traceFunction("helia.routing.getClosestPeers",this.getClosestPeers.bind(this),{optionsIndex:1})??this.getClosestPeers}async start(){await sr(...this.routers)}async stop(){await ir(...this.routers)}async*findProviders(e,t={}){if(this.routers.length===0)throw new dn("No content routers available");let n=new os({concurrency:this.providerLookupConcurrency});for await(let o of _t(n.toGenerator(),...Qn(this.routers,"findProviders").map(s=>s.findProviders(e,t))))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,t);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:t.signal}).catch(s=>{this.log.error("could not load multiaddrs for peer %p",o.id,s)})}yield o}}async provide(e,t={}){if(this.routers.length===0)throw new dn("No content routers available");await Promise.all(Qn(this.routers,"provide").map(async n=>{await n.provide(e,t)}))}async cancelReprovide(e,t={}){await Promise.all(Qn(this.routers,"cancelReprovide").map(async n=>{await n.cancelReprovide(e,t)}))}async put(e,t,n){await Promise.all(Qn(this.routers,"put").map(async o=>{await o.put(e,t,n)}))}async get(e,t){return Promise.any(Qn(this.routers,"get").map(async n=>n.get(e,t)))}async findPeer(e,t){if(this.routers.length===0)throw new dn("No peer routers available");let n=this,o=_t(...Qn(this.routers,"findPeer").map(s=>(async function*(){try{yield await s.findPeer(e,t)}catch(i){n.log.error(i)}})()));for await(let s of o)if(s!=null)return s;throw new ke("Could not find peer in routing")}async*getClosestPeers(e,t={}){if(this.routers.length===0)throw new dn("No peer routers available");for await(let n of _t(...Qn(this.routers,"getClosestPeers").map(o=>o.getClosestPeers(e,t))))n!=null&&(yield n)}};function Qn(r,e){return r.filter(t=>t[e]!=null)}var al=class extends Error{static name="QueueFullError";constructor(e="The queue was full"){super(e),this.name="QueueFullError"}};var cl=class extends Error{type;code;constructor(e,t,n){super(e??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=t??"ABORT_ERR"}};async function vb(r,e,t){if(e==null)return r;if(e.aborted)return r.catch(()=>{}),Promise.reject(new cl(t?.errorMessage,t?.errorCode,t?.errorName));let n,o=new cl(t?.errorMessage,t?.errorCode,t?.errorName);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var ll=class{deferred;signal;constructor(e){this.signal=e,this.deferred=Promise.withResolvers(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new Et)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function yI(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var ul=class{id;fn;options;recipients;status;timeline;controller;constructor(e,t){this.id=yI(),this.status="queued",this.fn=e,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,this.controller.signal,this.onAbort=this.onAbort.bind(this)}abort(e){this.controller.abort(e)}onAbort(){this.recipients.reduce((t,n)=>t&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new Et),this.cleanup())}async join(e={}){let t=new ll(e.signal);return this.recipients.push(t),e.signal?.addEventListener("abort",this.onAbort),t.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let e=await vb(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(t=>{t.deferred.resolve(e)}),this.status="complete"}catch(e){this.recipients.forEach(t=>{t.deferred.reject(e)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(e=>{e.cleanup(),e.signal?.removeEventListener("abort",this.onAbort)})}};function Rp(r,e){let t,n=function(){let o=function(){t=void 0,r()};clearTimeout(t),t=setTimeout(o,e)};return n.start=()=>{},n.stop=()=>{clearTimeout(t)},n}var Ui=class extends _e{concurrency;maxSize;queue;pending;sort;autoStart;constructor(e={}){super(),this.concurrency=e.concurrency??Number.POSITIVE_INFINITY,this.maxSize=e.maxSize??Number.POSITIVE_INFINITY,this.pending=0,this.autoStart=e.autoStart??!0,this.sort=e.sort,this.queue=[],this.emitEmpty=Rp(this.emitEmpty.bind(this),1),this.emitIdle=Rp(this.emitIdle.bind(this),1)}[Symbol.asyncIterator](){return this.toGenerator()}emitEmpty(){this.size===0&&this.safeDispatchEvent("empty")}emitIdle(){this.running===0&&this.safeDispatchEvent("idle")}tryToStartAnother(){if(this.size===0)return this.emitEmpty(),this.running===0&&this.emitIdle(),!1;if(this.pending<this.concurrency){let e;for(let t of this.queue)if(t.status==="queued"){e=t;break}return e==null?!1:(this.safeDispatchEvent("active"),this.pending++,e.run().finally(()=>{for(let t=0;t<this.queue.length;t++)if(this.queue[t]===e){this.queue.splice(t,1);break}this.pending--,this.safeDispatchEvent("next"),this.autoStart&&this.tryToStartAnother()}),!0)}return!1}enqueue(e){this.queue.push(e),this.sort!=null&&this.queue.sort(this.sort)}start(){this.autoStart===!1&&(this.autoStart=!0,this.tryToStartAnother())}pause(){this.autoStart=!1}async add(e,t){if(t?.signal?.throwIfAborted(),this.size===this.maxSize)throw new al;let n=new ul(e,t);return this.enqueue(n),this.safeDispatchEvent("add"),this.autoStart&&this.tryToStartAnother(),n.join(t).then(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("failure",{detail:{job:n,error:o}}),o})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(e=>{e.abort(new Et)}),this.clear()}async onEmpty(e){this.size!==0&&await Gc(this,"empty",e?.signal)}async onSizeLessThan(e,t){this.size<e||await Gc(this,"next",t?.signal,{filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await Gc(this,"idle",e?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(e){e?.signal?.throwIfAborted();let t=qo({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),t.end(c)},o=c=>{c.detail!=null&&t.push(c.detail.result)},s=c=>{n(c.detail.error)},i=()=>{n()},a=()=>{n(new Et("Queue aborted"))};this.addEventListener("success",o),this.addEventListener("failure",s),this.addEventListener("idle",i),e?.signal?.addEventListener("abort",a);try{yield*t}finally{this.removeEventListener("success",o),this.removeEventListener("failure",s),this.removeEventListener("idle",i),e?.signal?.removeEventListener("abort",a),n()}}};var fl="lock:worker:request-read",dl="lock:worker:abort-read-request",hl="lock:worker:release-read",pl="lock:master:grant-read",ml="lock:master:error-read",gl="lock:worker:request-write",yl="lock:worker:abort-write-request",wl="lock:worker:release-write",bl="lock:master:grant-write",xl="lock:master:error-write",vl="lock:worker:finalize",El="mortice",Eb={singleProcess:!1};var Mp=(r,e,t,n,o,s,i,a,c)=>l=>{if(l.data==null)return;let f={type:l.data.type,name:l.data.name,identifier:l.data.identifier};f.type===o&&r.safeDispatchEvent(t,{detail:{name:f.name,identifier:f.identifier,handler:async()=>{e.postMessage({type:c,name:f.name,identifier:f.identifier}),await new Promise(u=>{let d=h=>{if(h?.data==null)return;let m={type:h.data.type,name:h.data.name,identifier:h.data.identifier};m.type===a&&m.identifier===f.identifier&&(e.removeEventListener("message",d),u())};e.addEventListener("message",d)})},onError:u=>{e.postMessage({type:i,name:f.name,identifier:f.identifier,error:{message:u.message,name:u.name,stack:u.stack}})}}}),f.type===s&&r.safeDispatchEvent(n,{detail:{name:f.name,identifier:f.identifier}}),f.type===vl&&r.safeDispatchEvent("finalizeRequest",{detail:{name:f.name}})};var Ab=(r=10)=>Math.random().toString().substring(2,r+2);var Al=class{name;channel;constructor(e){this.name=e,this.channel=new BroadcastChannel(El)}readLock(e){return this.sendRequest(fl,dl,pl,ml,hl,e)}writeLock(e){return this.sendRequest(gl,yl,bl,xl,wl,e)}finalize(){this.channel.postMessage({type:vl,name:this.name}),this.channel.close()}async sendRequest(e,t,n,o,s,i){i?.signal?.throwIfAborted();let a=Ab();return this.channel.postMessage({type:e,identifier:a,name:this.name}),new Promise((c,l)=>{let f=()=>{this.channel.postMessage({type:t,identifier:a,name:this.name})};i?.signal?.addEventListener("abort",f,{once:!0});let u=d=>{if(d.data?.identifier===a&&(d.data?.type===n&&(this.channel.removeEventListener("message",u),i?.signal?.removeEventListener("abort",f),c(()=>{this.channel.postMessage({type:s,identifier:a,name:this.name})})),d.data.type===o)){this.channel.removeEventListener("message",u),i?.signal?.removeEventListener("abort",f);let h=new Error;d.data.error!=null&&(h.message=d.data.error.message,h.name=d.data.error.name,h.stack=d.data.error.stack),l(h)}};this.channel.addEventListener("message",u)})}};var Sb=r=>{if(r=Object.assign({},Eb,r),!!globalThis.document||r.singleProcess){let t=new BroadcastChannel(El),n=new _e;return t.addEventListener("message",Mp(n,t,"requestReadLock","abortReadLockRequest",fl,dl,ml,hl,pl)),t.addEventListener("message",Mp(n,t,"requestWriteLock","abortWriteLockRequest",gl,yl,xl,wl,bl)),n}return new Al(r.name)};var eo=new Map,Fi;function Ib(r){return typeof r?.readLock=="function"&&typeof r?.writeLock=="function"}function wI(r){if(Fi==null&&(Fi=Sb(r),!Ib(Fi))){let e=Fi;e.addEventListener("requestReadLock",t=>{let n=t.detail.name,o=t.detail.identifier,s=eo.get(n);if(s==null)return;let i=new AbortController,a=c=>{c.detail.name!==n||c.detail.identifier!==o||i.abort()};e.addEventListener("abortReadLockRequest",a),s.readLock({signal:i.signal}).then(async c=>{await t.detail.handler().finally(()=>{c()})}).catch(c=>{t.detail.onError(c)}).finally(()=>{e.removeEventListener("abortReadLockRequest",a)})}),e.addEventListener("requestWriteLock",t=>{let n=t.detail.name,o=t.detail.identifier,s=eo.get(n);if(s==null)return;let i=new AbortController,a=c=>{c.detail.name!==n||c.detail.identifier!==o||i.abort()};e.addEventListener("abortWriteLockRequest",a),s.writeLock({signal:i.signal}).then(async c=>{await t.detail.handler().finally(()=>{c()})}).catch(c=>{t.detail.onError(c)}).finally(()=>{e.removeEventListener("abortWriteLockRequest",a)})}),e.addEventListener("finalizeRequest",t=>{let n=t.detail.name,o=eo.get(n);o?.finalize()})}return Fi}async function Op(r,e){let t,n,o=new Promise((i,a)=>{t=i,n=a}),s=()=>{n(new Et)};return e?.signal?.addEventListener("abort",s,{once:!0}),r.add(async()=>{await new Promise(i=>{t(()=>{e?.signal?.removeEventListener("abort",s),i()})})},{signal:e?.signal}).catch(i=>{n(i)}),o}var kb=(r,e)=>{let t=eo.get(r);if(t!=null)return t;let n=wI(e);if(Ib(n))return t=n,eo.set(r,t),t;let o=new Ui({concurrency:1}),s;return t={async readLock(i){if(s!=null)return Op(s,i);s=new Ui({concurrency:e.concurrency,autoStart:!1});let a=s,c=Op(s,i);return o.add(async()=>{a.start(),await a.onIdle().then(()=>{s===a&&(s=null)})}),c},async writeLock(i){return s=null,Op(o,i)},finalize:()=>{eo.delete(r)},queue:o},eo.set(r,t),e.autoFinalize===!0&&o.addEventListener("idle",()=>{t.finalize()},{once:!0}),t};var bI={name:"lock",concurrency:1/0,singleProcess:!1,autoFinalize:!1};function $i(r){let e=Object.assign({},bI,r);return kb(e.name,e)}var Sl=class{lock;child;pins;started;constructor(e,t,n={}){this.child=e,this.pins=t,this.lock=$i({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await sr(this.child),this.started=!0}async stop(){await ir(this.child),this.started=!1}unwrap(){return this.child}async put(e,t,n={}){n?.signal?.throwIfAborted();let o=await this.lock.readLock();try{return await this.child.put(e,t,n)}finally{o()}}async*putMany(e,t={}){t?.signal?.throwIfAborted();let n=await this.lock.readLock();try{yield*this.child.putMany(e,t)}finally{n()}}async*get(e,t={}){t?.signal?.throwIfAborted();let n=await this.lock.readLock();try{yield*this.child.get(e,t)}finally{n()}}async*getMany(e,t={}){t?.signal?.throwIfAborted();let n=await this.lock.readLock();try{yield*this.child.getMany(e,t)}finally{n()}}async delete(e,t={}){t?.signal?.throwIfAborted();let n=await this.lock.writeLock();try{if(await this.pins.isPinned(e))throw new Ni("Block was pinned - please unpin and try again");await this.child.delete(e,t)}finally{n()}}async*deleteMany(e,t={}){t?.signal?.throwIfAborted();let n=await this.lock.writeLock();try{let o=this;yield*this.child.deleteMany((async function*(){for await(let s of e){if(await o.pins.isPinned(s))throw new Ni("Block was pinned - please unpin and try again");yield s}})(),t)}finally{n()}}async has(e,t={}){t?.signal?.throwIfAborted();let n=await this.lock.readLock();try{return await this.child.has(e,t)}finally{n()}}async*getAll(e={}){e?.signal?.throwIfAborted();let t=await this.lock.readLock();try{yield*this.child.getAll(e)}finally{t()}}createSession(e,t){return t?.signal?.throwIfAborted(),this.child.createSession(e,t)}};var Up=new ge("/version"),_b=1;async function Cb(r){if(!await r.has(Up)){await r.put(Up,B(`${_b}`));return}let e=await r.get(Up),t=U(e);if(parseInt(t,10)!==_b)throw new rl("Invalid datastore version, a datastore migration may be required")}var Vp={};Ae(Vp,{code:()=>$p,decode:()=>TI,decodeOptions:()=>kI,encode:()=>CI,encodeOptions:()=>SI,name:()=>_I,toByteView:()=>Bb});var Tb=42;function Bb(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}function xI(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let e=K.asCID(r);if(!e)return null;let t=new Uint8Array(e.bytes.byteLength+1);return t.set(e.bytes,1),[new I(p.tag,Tb),new I(p.bytes,t)]}function vI(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function EI(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}function AI(r){for(let e of r.keys())if(typeof e!="string"||e.length===0)throw new Error("Non-string Map keys are not supported by the IPLD Data Model and cannot be encoded");return null}var Fp={float64:!0,typeEncoders:{Map:AI,Object:xI,undefined:vI,number:EI}},SI={...Fp,typeEncoders:{...Fp.typeEncoders}};function II(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return K.decode(r.subarray(1))}var Il={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Il.tags[Tb]=II;var kI={...Il,tags:Il.tags.slice()},_I="dag-cbor",$p=113,CI=r=>un(r,Fp),TI=r=>vt(Bb(r),Il);var jp={};Ae(jp,{code:()=>Wp,decode:()=>Pb,encode:()=>Lb,format:()=>$I,name:()=>FI,parse:()=>KI,stringify:()=>$I});var Kp=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(e){let t=this.inRecursive[this.inRecursive.length-1];t&&(t.type===p.array&&(t.elements++,t.elements!==1&&e.push([44])),t.type===p.map&&(t.elements++,t.elements!==1&&(t.elements%2===1?e.push([44]):e.push([58]))))}[p.uint.major](e,t){this.prefix(e);let n=String(t.value),o=[];for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);e.push(o)}[p.negint.major](e,t){this[p.uint.major](e,t)}[p.bytes.major](e,t){throw new Error(`${Cr} unsupported type: Uint8Array`)}[p.string.major](e,t){this.prefix(e);let n=Ec(JSON.stringify(t.value));e.push(n.length>32?bi(n):n)}[p.array.major](e,t){this.prefix(e),this.inRecursive.push({type:p.array,elements:0}),e.push([91])}[p.map.major](e,t){this.prefix(e),this.inRecursive.push({type:p.map,elements:0}),e.push([123])}[p.tag.major](e,t){}[p.float.major](e,t){if(t.type.name==="break"){let i=this.inRecursive.pop();if(i){if(i.type===p.array)e.push([93]);else if(i.type===p.map)e.push([125]);else throw new Error("Unexpected recursive type; this should not happen!");return}throw new Error("Unexpected break; this should not happen!")}if(t.value===void 0)throw new Error(`${Cr} unsupported type: undefined`);if(this.prefix(e),t.type.name==="true"){e.push([116,114,117,101]);return}else if(t.type.name==="false"){e.push([102,97,108,115,101]);return}else if(t.type.name==="null"){e.push([110,117,108,108]);return}let n=String(t.value),o=[],s=!1;for(let i=0;i<n.length;i++)o[i]=n.charCodeAt(i),!s&&(o[i]===46||o[i]===101||o[i]===69)&&(s=!0);s||(o.push(46),o.push(48)),e.push(o)}};function BI(r,e){if(Array.isArray(r[0])||Array.isArray(e[0]))throw new Error(`${Cr} complex map keys are not supported`);let t=r[0],n=e[0];if(t.type!==p.string||n.type!==p.string)throw new Error(`${Cr} non-string map keys are not supported`);if(t<n)return-1;if(t>n)return 1;throw new Error(`${Cr} unexpected duplicate map keys, this is not supported`)}var LI={addBreakTokens:!0,mapSorter:BI};function Hp(r,e){return e=Object.assign({},LI,e),ap(r,new Kp,e)}var as=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t,this.modeStack=["value"],this.lastToken=""}pos(){return this._pos}done(){return this._pos>=this.data.length}ch(){return this.data[this._pos]}currentMode(){return this.modeStack[this.modeStack.length-1]}skipWhitespace(){let e=this.ch();for(;e===32||e===9||e===13||e===10;)e=this.data[++this._pos]}expect(e){if(this.data.length-this._pos<e.length)throw new Error(`${F} unexpected end of input at position ${this._pos}`);for(let t=0;t<e.length;t++)if(this.data[this._pos++]!==e[t])throw new Error(`${F} unexpected token at position ${this._pos}, expected to find '${String.fromCharCode(...e)}'`)}parseNumber(){let e=this._pos,t=!1,n=!1,o=a=>{for(;!this.done();){let c=this.ch();if(a.includes(c))this._pos++;else break}};if(this.ch()===45&&(t=!0,this._pos++),this.ch()===48)if(this._pos++,this.ch()===46)this._pos++,n=!0;else return new I(p.uint,0,this._pos-e);if(o([48,49,50,51,52,53,54,55,56,57]),t&&this._pos===e+1)throw new Error(`${F} unexpected token at position ${this._pos}`);if(!this.done()&&this.ch()===46){if(n)throw new Error(`${F} unexpected token at position ${this._pos}`);n=!0,this._pos++,o([48,49,50,51,52,53,54,55,56,57])}!this.done()&&(this.ch()===101||this.ch()===69)&&(n=!0,this._pos++,!this.done()&&(this.ch()===43||this.ch()===45)&&this._pos++,o([48,49,50,51,52,53,54,55,56,57]));let s=String.fromCharCode.apply(null,this.data.subarray(e,this._pos)),i=parseFloat(s);return n?new I(p.float,i,this._pos-e):this.options.allowBigInt!==!0||Number.isSafeInteger(i)?new I(i>=0?p.uint:p.negint,i,this._pos-e):new I(i>=0?p.uint:p.negint,BigInt(s),this._pos-e)}parseString(){if(this.ch()!==34)throw new Error(`${F} unexpected character at position ${this._pos}; this shouldn't happen`);this._pos++;for(let s=this._pos,i=0;s<this.data.length&&i<65536;s++,i++){let a=this.data[s];if(a===92||a<32||a>=128)break;if(a===34){let c=String.fromCharCode.apply(null,this.data.subarray(this._pos,s));return this._pos=s+1,new I(p.string,c,i)}}let e=this._pos,t=[],n=()=>{if(this._pos+4>=this.data.length)throw new Error(`${F} unexpected end of unicode escape sequence at position ${this._pos}`);let s=0;for(let i=0;i<4;i++){let a=this.ch();if(a>=48&&a<=57)a-=48;else if(a>=97&&a<=102)a=a-97+10;else if(a>=65&&a<=70)a=a-65+10;else throw new Error(`${F} unexpected unicode escape character at position ${this._pos}`);s=s*16+a,this._pos++}return s},o=()=>{let s=this.ch(),i=null,a=s>239?4:s>223?3:s>191?2:1;if(this._pos+a>this.data.length)throw new Error(`${F} unexpected unicode sequence at position ${this._pos}`);let c,l,f,u;switch(a){case 1:s<128&&(i=s);break;case 2:c=this.data[this._pos+1],(c&192)===128&&(u=(s&31)<<6|c&63,u>127&&(i=u));break;case 3:c=this.data[this._pos+1],l=this.data[this._pos+2],(c&192)===128&&(l&192)===128&&(u=(s&15)<<12|(c&63)<<6|l&63,u>2047&&(u<55296||u>57343)&&(i=u));break;case 4:c=this.data[this._pos+1],l=this.data[this._pos+2],f=this.data[this._pos+3],(c&192)===128&&(l&192)===128&&(f&192)===128&&(u=(s&15)<<18|(c&63)<<12|(l&63)<<6|f&63,u>65535&&u<1114112&&(i=u))}i===null?(i=65533,a=1):i>65535&&(i-=65536,t.push(i>>>10&1023|55296),i=56320|i&1023),t.push(i),this._pos+=a};for(;!this.done();){let s=this.ch(),i;switch(s){case 92:if(this._pos++,this.done())throw new Error(`${F} unexpected string termination at position ${this._pos}`);switch(i=this.ch(),this._pos++,i){case 34:case 39:case 92:case 47:t.push(i);break;case 98:t.push(8);break;case 116:t.push(9);break;case 110:t.push(10);break;case 102:t.push(12);break;case 114:t.push(13);break;case 117:t.push(n());break;default:throw new Error(`${F} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new I(p.string,tp(t),this._pos-e);default:if(s<32)throw new Error(`${F} invalid control character at position ${this._pos}`);s<128?(t.push(s),this._pos++):o()}}throw new Error(`${F} unexpected end of string at position ${this._pos}`)}parseValue(){switch(this.ch()){case 123:return this.modeStack.push("obj-start"),this._pos++,new I(p.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new I(p.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new I(p.null,null,4);case 102:return this.expect([102,97,108,115,101]),new I(p.false,!1,5);case 116:return this.expect([116,114,117,101]),new I(p.true,!0,4);case 45:case 48:case 49:case 50:case 51:case 52:case 53:case 54:case 55:case 56:case 57:return this.parseNumber();default:throw new Error(`${F} unexpected character at position ${this._pos}`)}}next(){switch(this.skipWhitespace(),this.currentMode()){case"value":return this.modeStack.pop(),this.parseValue();case"array-value":{if(this.modeStack.pop(),this.ch()===93)return this._pos++,this.skipWhitespace(),new I(p.break,void 0,1);if(this.ch()!==44)throw new Error(`${F} unexpected character at position ${this._pos}, was expecting array delimiter but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue()}case"array-start":return this.modeStack.pop(),this.ch()===93?(this._pos++,this.skipWhitespace(),new I(p.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 I(p.break,void 0,1);if(this.ch()!==44)throw new Error(`${F} unexpected character at position ${this._pos}, was expecting object delimiter but found '${String.fromCharCode(this.ch())}'`);this._pos++,this.skipWhitespace();case"obj-start":{if(this.modeStack.pop(),this.ch()===125)return this._pos++,this.skipWhitespace(),new I(p.break,void 0,1);let e=this.parseString();if(this.skipWhitespace(),this.ch()!==58)throw new Error(`${F} unexpected character at position ${this._pos}, was expecting key/value delimiter ':' but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("obj-value"),e}case"obj-value":return this.modeStack.pop(),this.modeStack.push("obj-key"),this.skipWhitespace(),this.parseValue();default:throw new Error(`${F} unexpected parse state at position ${this._pos}; this shouldn't happen`)}}};function qp(r,e){return e=Object.assign({tokenizer:new as(r,e)},e),vt(r,e)}function DI(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}function NI(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let e=K.asCID(r);if(!e)return null;let t=e.toString();return[new I(p.map,1/0,1),new I(p.string,"/",1),new I(p.string,t,t.length),new I(p.break,void 0,1)]}function kl(r){let e=Ye.encode(r).slice(1);return[new I(p.map,1/0,1),new I(p.string,"/",1),new I(p.map,1/0,1),new I(p.string,"bytes",5),new I(p.string,e,e.length),new I(p.break,void 0,1),new I(p.break,void 0,1)]}function Yt(r){return kl(new Uint8Array(r.buffer,r.byteOffset,r.byteLength))}function RI(r){return kl(new Uint8Array(r))}function MI(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function OI(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 UI={typeEncoders:{Object:NI,Buffer:kl,Uint8Array:kl,Int8Array:Yt,Uint16Array:Yt,Int16Array:Yt,Uint32Array:Yt,Int32Array:Yt,Float32Array:Yt,Float64Array:Yt,Uint8ClampedArray:Yt,BigInt64Array:Yt,BigUint64Array:Yt,DataView:Yt,ArrayBuffer:RI,undefined:MI,number:OI}},zp=class extends as{constructor(e,t){super(e,t),this.tokenBuffer=[]}done(){return this.tokenBuffer.length===0&&super.done()}_next(){return this.tokenBuffer.length>0?this.tokenBuffer.pop():super.next()}next(){let e=this._next();if(e.type===p.map){let t=this._next();if(t.type===p.string&&t.value==="/"){let n=this._next();if(n.type===p.string){if(this._next().type!==p.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new I(p.tag,42,0)}if(n.type===p.map){let o=this._next();if(o.type===p.string&&o.value==="bytes"){let s=this._next();if(s.type===p.string){for(let a=0;a<2;a++)if(this._next().type!==p.break)throw new Error("Invalid encoded Bytes form");let i=Ye.decode(`m${s.value}`);return new I(p.bytes,i,s.value.length)}this.tokenBuffer.push(s)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(t)}return e}},Gp={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Gp.tags[42]=K.parse;var FI="dag-json",Wp=297,Lb=r=>Hp(r,UI),Pb=r=>{let e=DI(r),t=Object.assign(Gp,{tokenizer:new zp(e,Gp)});return qp(e,t)},$I=r=>VI.decode(Lb(r));var VI=new TextDecoder,KI=r=>Pb(HI.encode(r)),HI=new TextEncoder;var em={};Ae(em,{code:()=>Qp,createLink:()=>Kb,createNode:()=>Vb,decode:()=>rk,encode:()=>tk,name:()=>ek,prepare:()=>Xp,validate:()=>Jp});var qI=new TextDecoder;function Yp(r,e){let t=0;for(let n=0;;n+=7){if(n>=64)throw new Error("protobuf: varint overflow");if(e>=r.length)throw new Error("protobuf: unexpected end of data");let o=r[e++];if(t+=n<28?(o&127)<<n:(o&127)*2**n,o<128)break}return[t,e]}function _l(r,e){let t;[t,e]=Yp(r,e);let n=e+t;if(t<0||n<0)throw new Error("protobuf: invalid length");if(n>r.length)throw new Error("protobuf: unexpected end of data");return[r.subarray(e,n),n]}function Db(r,e){let t;return[t,e]=Yp(r,e),[t&7,t>>3,e]}function zI(r){let e={},t=r.length,n=0;for(;n<t;){let o,s;if([o,s,n]=Db(r,n),s===1){if(e.Hash)throw new Error("protobuf: (PBLink) duplicate Hash section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Hash`);if(e.Name!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Name before Hash");if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Hash");[e.Hash,n]=_l(r,n)}else if(s===2){if(e.Name!==void 0)throw new Error("protobuf: (PBLink) duplicate Name section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Name`);if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Name");let i;[i,n]=_l(r,n),e.Name=qI.decode(i)}else if(s===3){if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) duplicate Tsize section");if(o!==0)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Tsize`);[e.Tsize,n]=Yp(r,n)}else throw new Error(`protobuf: (PBLink) invalid fieldNumber, expected 1, 2 or 3, got ${s}`)}if(n>t)throw new Error("protobuf: (PBLink) unexpected end of data");return e}function Nb(r){let e=r.length,t=0,n,o=!1,s;for(;t<e;){let a,c;if([a,c,t]=Db(r,t),a!==2)throw new Error(`protobuf: (PBNode) invalid wireType, expected 2, got ${a}`);if(c===1){if(s)throw new Error("protobuf: (PBNode) duplicate Data section");[s,t]=_l(r,t),n&&(o=!0)}else if(c===2){if(o)throw new Error("protobuf: (PBNode) duplicate Links section");n||(n=[]);let l;[l,t]=_l(r,t),n.push(zI(l))}else throw new Error(`protobuf: (PBNode) invalid fieldNumber, expected 1 or 2, got ${c}`)}if(t>e)throw new Error("protobuf: (PBNode) unexpected end of data");let i={};return s&&(i.Data=s),i.Links=n||[],i}var Mb=new TextEncoder,Rb=2**32,GI=2**31;function WI(r,e){let t=e.length;if(typeof r.Tsize=="number"){if(r.Tsize<0)throw new Error("Tsize cannot be negative");if(!Number.isSafeInteger(r.Tsize))throw new Error("Tsize too large for encoding");t=Vi(e,t,r.Tsize)-1,e[t]=24}if(typeof r.Name=="string"){let n=Mb.encode(r.Name);t-=n.length,e.set(n,t),t=Vi(e,t,n.length)-1,e[t]=18}return r.Hash&&(t-=r.Hash.length,e.set(r.Hash,t),t=Vi(e,t,r.Hash.length)-1,e[t]=10),e.length-t}function Ob(r){let e=YI(r),t=new Uint8Array(e),n=e;if(r.Data&&(n-=r.Data.length,t.set(r.Data,n),n=Vi(t,n,r.Data.length)-1,t[n]=10),r.Links)for(let o=r.Links.length-1;o>=0;o--){let s=WI(r.Links[o],t.subarray(0,n));n-=s,n=Vi(t,n,s)-1,t[n]=18}return t}function jI(r){let e=0;if(r.Hash){let t=r.Hash.length;e+=1+t+cs(t)}if(typeof r.Name=="string"){let t=Mb.encode(r.Name).length;e+=1+t+cs(t)}return typeof r.Tsize=="number"&&(e+=1+cs(r.Tsize)),e}function YI(r){let e=0;if(r.Data){let t=r.Data.length;e+=1+t+cs(t)}if(r.Links)for(let t of r.Links){let n=jI(t);e+=1+n+cs(n)}return e}function Vi(r,e,t){e-=cs(t);let n=e;for(;t>=GI;)r[e++]=t&127|128,t/=128;for(;t>=128;)r[e++]=t&127|128,t>>>=7;return r[e]=t,n}function cs(r){return r%2===0&&r++,Math.floor((ZI(r)+6)/7)}function ZI(r){let e=0;return r>=Rb&&(r=Math.floor(r/Rb),e=32),r>=65536&&(r>>>=16,e+=16),r>=256&&(r>>>=8,e+=8),e+XI[r]}var XI=[0,1,2,2,3,3,3,3,4,4,4,4,4,4,4,4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8];var JI=["Data","Links"],QI=["Hash","Name","Tsize"],Zp=new TextEncoder;function Fb(r,e){if(r===e)return 0;let t=r.Name?Zp.encode(r.Name):[],n=e.Name?Zp.encode(e.Name):[],o=t.length,s=n.length;for(let i=0,a=Math.min(o,s);i<a;++i)if(t[i]!==n[i]){o=t[i],s=n[i];break}return o<s?-1:s<o?1:0}function Ub(r,e){return!Object.keys(r).some(t=>!e.includes(t))}function $b(r){if(typeof r.asCID=="object"){let t=K.asCID(r);if(!t)throw new TypeError("Invalid DAG-PB form");return{Hash:t}}if(typeof r!="object"||Array.isArray(r))throw new TypeError("Invalid DAG-PB form");let e={};if(r.Hash){let t=K.asCID(r.Hash);try{t||(typeof r.Hash=="string"?t=K.parse(r.Hash):r.Hash instanceof Uint8Array&&(t=K.decode(r.Hash)))}catch(n){throw new TypeError(`Invalid DAG-PB form: ${n.message}`)}t&&(e.Hash=t)}if(!e.Hash)throw new TypeError("Invalid DAG-PB form");return typeof r.Name=="string"&&(e.Name=r.Name),typeof r.Tsize=="number"&&(e.Tsize=r.Tsize),e}function Xp(r){if((r instanceof Uint8Array||typeof r=="string")&&(r={Data:r}),typeof r!="object"||Array.isArray(r))throw new TypeError("Invalid DAG-PB form");let e={};if(r.Data!==void 0)if(typeof r.Data=="string")e.Data=Zp.encode(r.Data);else if(r.Data instanceof Uint8Array)e.Data=r.Data;else throw new TypeError("Invalid DAG-PB form");if(r.Links!==void 0)if(Array.isArray(r.Links))e.Links=r.Links.map($b),e.Links.sort(Fb);else throw new TypeError("Invalid DAG-PB form");else e.Links=[];return e}function Jp(r){if(!r||typeof r!="object"||Array.isArray(r)||r instanceof Uint8Array||r["/"]&&r["/"]===r.bytes)throw new TypeError("Invalid DAG-PB form");if(!Ub(r,JI))throw new TypeError("Invalid DAG-PB form (extraneous properties)");if(r.Data!==void 0&&!(r.Data instanceof Uint8Array))throw new TypeError("Invalid DAG-PB form (Data must be bytes)");if(!Array.isArray(r.Links))throw new TypeError("Invalid DAG-PB form (Links must be a list)");for(let e=0;e<r.Links.length;e++){let t=r.Links[e];if(!t||typeof t!="object"||Array.isArray(t)||t instanceof Uint8Array||t["/"]&&t["/"]===t.bytes)throw new TypeError("Invalid DAG-PB form (bad link)");if(!Ub(t,QI))throw new TypeError("Invalid DAG-PB form (extraneous properties on link)");if(t.Hash===void 0)throw new TypeError("Invalid DAG-PB form (link must have a Hash)");if(t.Hash==null||!t.Hash["/"]||t.Hash["/"]!==t.Hash.bytes)throw new TypeError("Invalid DAG-PB form (link Hash must be a CID)");if(t.Name!==void 0&&typeof t.Name!="string")throw new TypeError("Invalid DAG-PB form (link Name must be a string)");if(t.Tsize!==void 0){if(typeof t.Tsize!="number"||t.Tsize%1!==0)throw new TypeError("Invalid DAG-PB form (link Tsize must be an integer)");if(t.Tsize<0)throw new TypeError("Invalid DAG-PB form (link Tsize cannot be negative)")}if(e>0&&Fb(t,r.Links[e-1])===-1)throw new TypeError("Invalid DAG-PB form (links must be sorted by Name bytes)")}}function Vb(r,e=[]){return Xp({Data:r,Links:e})}function Kb(r,e,t){return $b({Hash:t,Name:r,Tsize:e})}function Hb(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var ek="dag-pb",Qp=112;function tk(r){Jp(r);let e={};return r.Links&&(e.Links=r.Links.map(t=>{let n={};return t.Hash&&(n.Hash=t.Hash.bytes),t.Name!==void 0&&(n.Name=t.Name),t.Tsize!==void 0&&(n.Tsize=t.Tsize),n})),r.Data&&(e.Data=r.Data),Ob(e)}function rk(r){let e=Hb(r),t=Nb(e),n={};return t.Data&&(n.Data=t.Data),t.Links&&(n.Links=t.Links.map(o=>{let s={};try{s.Hash=K.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}function ls(r){return r?.then!=null}function qb(r=[],e){let t={[Qp]:em,[Ds]:Ns,[$p]:Vp,[Wp]:jp,[cd]:Pa};return r.forEach(n=>{t[n.code]=n}),async n=>{let o=t[n];if(o==null&&e!=null){let s=e(n);ls(s)?o=await s:o=s,t[o.code]=o}if(o!=null)return o;throw new Oi(`Could not load codec for ${n}`)}}function zb(r=[],e){let t={[Mt.code]:Mt,[Da.code]:Da,[We.code]:We};return r.forEach(n=>{t[n.code]=n}),async n=>{let o=t[n];if(o==null&&e!=null){let s=e(n);ls(s)?o=await s:o=s,t[o.code]=o}if(o!=null)return o;throw new Mi(`No hasher configured for multihash code 0x${n.toString(16)}, please configure one. You can look up which hash this is at https://github.com/multiformats/multicodec/blob/master/table.csv`)}}var Pt=class r extends Error{static name="NotFoundError";static code="ERR_NOT_FOUND";name=r.name;code=r.code;constructor(e="Not Found"){super(e)}};var Lr=class{has(e,t){return Promise.reject(new Error(".has is not implemented"))}put(e,t,n){return Promise.reject(new Error(".put is not implemented"))}async*putMany(e,t){for await(let{cid:n,bytes:o}of e)await this.put(n,o,t),yield n}get(e,t){throw new Error(".get is not implemented")}async*getMany(e,t){for await(let n of e)yield{cid:n,bytes:this.get(n,t)}}delete(e,t){return Promise.reject(new Error(".delete is not implemented"))}async*deleteMany(e,t){for await(let n of e)await this.delete(n,t),yield n}async*getAll(e){throw new Error(".getAll is not implemented")}};var Cl=0,us=class extends Error{static name="IdentityHashDigestTooLongError";name="IdentityHashDigestTooLongError"},Tl=class extends Lr{child;maxDigestLength;constructor(e,t){super(),this.child=e,this.maxDigestLength=t?.maxDigestLength}put(e,t,n){if(e.multihash.code===Cl){if(this.maxDigestLength!=null&&e.multihash.digest.byteLength>this.maxDigestLength)throw new us(`Identity digest too long - ${e.multihash.digest.byteLength} > this.maxDigestLength`);return n?.signal?.throwIfAborted(),e}return this.child==null?(n?.signal?.throwIfAborted(),e):this.child.put(e,t,n)}*get(e,t){if(e.multihash.code===Cl){if(this.maxDigestLength!=null&&e.multihash.digest.byteLength>this.maxDigestLength)throw new us(`Identity digest too long - ${e.multihash.digest.byteLength} > this.maxDigestLength`);t?.signal?.throwIfAborted(),yield e.multihash.digest;return}if(this.child==null)throw t?.signal?.throwIfAborted(),new Pt;yield*this.child.get(e,t)}has(e,t){if(e.multihash.code===Cl){if(this.maxDigestLength!=null&&e.multihash.digest.byteLength>this.maxDigestLength)throw new us(`Identity digest too long - ${e.multihash.digest.byteLength} > this.maxDigestLength`);return t?.signal?.throwIfAborted(),!0}return this.child==null?(t?.signal?.throwIfAborted(),!1):this.child.has(e,t)}delete(e,t){if(e.code===Cl){if(this.maxDigestLength!=null&&e.multihash.digest.byteLength>this.maxDigestLength)throw new us(`Identity digest too long - ${e.multihash.digest.byteLength} > this.maxDigestLength`);t?.signal?.throwIfAborted();return}if(this.child!=null)return this.child.delete(e,t)}*getAll(e){this.child!=null&&(yield*this.child.getAll(e)),e?.signal?.throwIfAborted()}};function nk(r){return r[Symbol.asyncIterator]!=null}function ok(r,e){let t=0;if(nk(r))return(async function*(){for await(let c of r)await e(c,t++)&&(yield c)})();let n=ss(r),{value:o,done:s}=n.next();if(s===!0)return(function*(){})();let i=e(o,t++);if(typeof i.then=="function")return(async function*(){await i&&(yield o);for(let c of n)await e(c,t++)&&(yield c)})();let a=e;return(function*(){i===!0&&(yield o);for(let c of n)a(c,t++)&&(yield c)})()}var Zt=ok;function sk(r){return r[Symbol.asyncIterator]!=null}function Gb(r){return r?.then!=null}function ik(r,e){let t=0;if(sk(r))return(async function*(){for await(let c of r){let l=e(c,t++);Gb(l)&&await l,yield c}})();let n=ss(r),{value:o,done:s}=n.next();if(s===!0)return(function*(){})();if(typeof e(o,t++)?.then=="function")return(async function*(){yield o;for(let c of n){let l=e(c,t++);Gb(l)&&await l,yield c}})();let a=e;return(function*(){yield o;for(let c of n)a(c,t++),yield c})()}var tm=ik;var ak=128,Bl=class{child;getHasher;log;logger;components;constructor(e,t={}){this.log=e.logger.forComponent("helia:networked-storage"),this.logger=e.logger,this.components=e,this.child=new Tl(e.blockstore,{maxDigestLength:t.maxIdentityHashDigestLength??ak}),this.getHasher=e.getHasher}async put(e,t,n={}){return await this.child.has(e,n)?(n.onProgress?.(new Y("blocks:put:duplicate",e)),e):(n.onProgress?.(new Y("blocks:put:providers:notify",e)),await Promise.all(this.components.blockBrokers.map(async o=>o.announce?.(e,n))),n.onProgress?.(new Y("blocks:put:blockstore:put",e)),this.child.put(e,t,n))}async*putMany(e,t={}){let n=Zt(e,async({cid:s})=>{let i=await this.child.has(s,t);return i&&t.onProgress?.(new Y("blocks:put-many:duplicate",s)),!i}),o=tm(n,async({cid:s})=>{t.onProgress?.(new Y("blocks:put-many:providers:notify",s)),await Promise.all(this.components.blockBrokers.map(async i=>i.announce?.(s,t)))});t.onProgress?.(new Y("blocks:put-many:blockstore:put-many")),yield*this.child.putMany(o,t)}async*get(e,t={}){if(t.offline!==!0&&!await this.child.has(e,t)){let n=await this.getHasher(e.multihash.code);t.onProgress?.(new Y("blocks:get:providers:get",e));let o=await Wb(e,this.components.blockBrokers,n,{...t,log:this.log});t.onProgress?.(new Y("blocks:get:blockstore:put",e)),await this.child.put(e,o,t),t.onProgress?.(new Y("blocks:get:providers:notify",e)),await Promise.all(this.components.blockBrokers.map(async s=>s.announce?.(e,t))),yield o;return}t.onProgress?.(new Y("blocks:get:blockstore:get",e)),yield*this.child.get(e,t)}async*getMany(e,t={}){t.onProgress?.(new Y("blocks:get-many:blockstore:get-many")),yield*this.child.getMany(tm(e,async n=>{if(t.offline!==!0&&!await this.child.has(n,t)){let o=await this.getHasher(n.multihash.code);t.onProgress?.(new Y("blocks:get-many:providers:get",n));let s=await Wb(n,this.components.blockBrokers,o,{...t,log:this.log});t.onProgress?.(new Y("blocks:get-many:blockstore:put",n)),await this.child.put(n,s,t),t.onProgress?.(new Y("blocks:get-many:providers:notify",n)),await Promise.all(this.components.blockBrokers.map(async i=>i.announce?.(n,t)))}}))}async delete(e,t={}){t.onProgress?.(new Y("blocks:delete:blockstore:delete",e)),await this.child.delete(e,t)}async*deleteMany(e,t={}){t.onProgress?.(new Y("blocks:delete-many:blockstore:delete-many")),yield*this.child.deleteMany((async function*(){for await(let n of e)yield n})(),t)}async has(e,t={}){return this.child.has(e,t)}async*getAll(e={}){e.onProgress?.(new Y("blocks:get-all:blockstore:get-many")),yield*this.child.getAll(e)}},Ll=class extends Bl{started;constructor(e,t={}){super(e,t),this.started=!1}isStarted(){return this.started}async start(){await sr(this.child,...this.components.blockBrokers),this.started=!0}async stop(){await ir(this.child,...this.components.blockBrokers),this.started=!1}unwrap(){return this.child}createSession(e,t){let n=this.components.blockBrokers.map(o=>o.createSession==null?o:o.createSession(t));return new rm({blockstore:this.child,blockBrokers:n,getHasher:this.getHasher,logger:this.logger},{root:e})}},rm=class extends Bl{closeController;constructor(e,t){super(e),this.closeController=new AbortController,this.closeController.signal,this.log=e.logger.forComponent(`helia:session-storage:${t.root}`)}close(){this.closeController.abort()}async put(e,t,n={}){let o=pe([this.closeController.signal,n.signal]);try{return await super.put(e,t,{...n,signal:o})}finally{o.clear()}}async*putMany(e,t={}){let n=pe([this.closeController.signal,t.signal]);try{yield*super.putMany(e,{...t,signal:n})}finally{n.clear()}}async*get(e,t={}){let n=pe([this.closeController.signal,t.signal]);try{yield*super.get(e,{...t,signal:n})}finally{n.clear()}}async*getMany(e,t={}){let n=pe([this.closeController.signal,t.signal]);try{yield*super.getMany(e,{...t,signal:n})}finally{n.clear()}}async delete(e,t={}){let n=pe([this.closeController.signal,t.signal]);try{await super.delete(e,{...t,signal:n})}finally{n.clear()}}async*deleteMany(e,t={}){let n=pe([this.closeController.signal,t.signal]);try{yield*super.deleteMany(e,{...t,signal:n})}finally{n.clear()}}async has(e,t={}){let n=pe([this.closeController.signal,t.signal]);try{return await super.has(e,{...t,signal:n})}finally{n.clear()}}async*getAll(e={}){let t=pe([this.closeController.signal,e.signal]);try{yield*super.getAll({...e,signal:t})}finally{t.clear()}}};function ck(r){return typeof r.retrieve=="function"}var lk=(r,e)=>{if(e==null)throw new k(`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`);return async t=>{let n,o=e.digest(t);if(ls(o)?n=await o:n=o,!X(n.digest,r.multihash.digest))throw new Hr("Hash of downloaded block did not match multihash from passed CID")}};async function Wb(r,e,t,n){let o=lk(r,t),s=new AbortController,i=pe([s.signal,n.signal]);s.signal;let a=[];for(let c of e)ck(c)&&a.push(c);if(a.length===0)throw new nl(`No block brokers capable of retrieving blocks are configured, the CID ${r} cannot be fetched from the network`);try{return await Promise.any(a.map(async c=>{try{let l=!1,f=await c.retrieve(r,{...n,signal:i,validateFn:async u=>{await o(u),n.signal?.throwIfAborted(),l=!0}});return l||(await o(f),n.signal?.throwIfAborted()),f}catch(l){throw n.log.error("could not retrieve verified block for %c",r,l),l}}))}finally{s.abort(),i.clear()}}var Hi=class extends _e{initialPeerSearchComplete;requests;name;log;logger;minProviders;maxProviders;providers;evictionFilter;initialProviders;constructor(e,t){super(),this.name=t.name,this.logger=e.logger,this.log=e.logger.forComponent(this.name),this.requests=new Map,this.minProviders=t.minProviders??1,this.maxProviders=t.maxProviders??5,this.providers=[],this.evictionFilter=$n(this.maxProviders),this.initialProviders=t.providers??[]}async retrieve(e,t={}){let n=Ye.encode(e.multihash.bytes),o=this.requests.get(n);if(o!=null)return this.log("join existing request for %c",e),o;let s=ae();if(this.requests.set(n,s.promise),this.providers.length===0){let f=!1;this.initialPeerSearchComplete==null&&(f=!0,this.log=this.logger.forComponent(`${this.name}:${e}`),this.initialPeerSearchComplete=this.findProviders(e,this.minProviders,t)),await kt(this.initialPeerSearchComplete,t.signal),f&&this.log("found initial session peers for %c",e)}let i=!1,a=new Gt({concurrency:this.maxProviders});a.addEventListener("failure",f=>{this.log.error("error querying provider %o, evicting from session",f.detail.job.options.provider,f.detail.error),this.evict(f.detail.job.options.provider)}),a.addEventListener("success",f=>{i=!0,s.resolve(f.detail.result)}),a.addEventListener("idle",()=>{if(i){this.log.trace("session idle, found block");return}if(t.signal?.aborted===!0){this.log.trace("session idle, signal aborted");return}Promise.resolve().then(async()=>{this.log("no session peers had block for for %c, finding new providers",e);for(let f=0;f<this.minProviders&&this.providers.length!==0;f++){let u=this.providers[Math.floor(Math.random()*this.providers.length)];this.evict(u)}await this.findProviders(e,this.minProviders,t),this.log("found new providers re-retrieving %c",e),this.requests.delete(n),s.resolve(await this.retrieve(e,t))}).catch(f=>{this.log.error("could not find new providers for %c",e,f),s.reject(f)})});let c=f=>{a.add(async()=>this.queryProvider(e,f.detail,t),{provider:f.detail}).catch(u=>{t.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c",e,u)})};this.addEventListener("provider",c),Promise.all([...this.providers].map(async f=>a.add(async()=>this.queryProvider(e,f,t),{provider:f}))).catch(f=>{t.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c",e,f)});let l=()=>{s.reject(new ht(t.signal?.reason??"Session aborted")),a.abort()};t.signal?.addEventListener("abort",l);try{return await kt(s.promise,t.signal)}finally{this.removeEventListener("provider",c),t.signal?.removeEventListener("abort",l),a.clear(),this.requests.delete(n)}}evict(e){this.evictionFilter.add(this.toEvictionKey(e));let t=this.providers.findIndex(n=>this.equals(n,e));t!==-1&&this.providers.splice(t,1)}isEvicted(e){return this.evictionFilter.has(this.toEvictionKey(e))}hasProvider(e){return!!(this.providers.find(t=>this.equals(t,e))!=null||this.isEvicted(e))}async findProviders(e,t,n){let o=ae(),s=0;return Promise.resolve().then(async()=>{if(this.log("finding %d-%d new provider(s) for %c",t,this.maxProviders,e),this.initialProviders.length>0)for(;s<t&&this.initialProviders.length>0;){let i=this.initialProviders.pop();if(i==null)break;let a=await this.convertToProvider(i,n);if(n.signal?.aborted===!0)break;if(a!=null&&!this.hasProvider(a)&&(this.log("found %d/%d new providers",s,this.maxProviders),this.providers.push(a),this.safeDispatchEvent("provider",{detail:a}),s++,s===t&&(this.log("session is ready"),o.resolve()),this.providers.length===this.maxProviders)){this.log("found max session peers",s);break}}if(s<this.maxProviders)for await(let i of this.findNewProviders(e,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===t&&(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<t)throw new Ri(`Found ${s} of ${t} ${this.name} providers for ${e}`)}).catch(i=>{this.log.error("error searching routing for potential session peers for %c",e,i.errors??i),o.reject(i)}),o.promise}};var Pl=class{libp2p;blockstore;datastore;events;pins;logger;routing;getCodec;getHasher;dns;metrics;log;constructor(e){this.logger=e.logger??fn(),this.log=this.logger.forComponent("helia"),this.getHasher=zb(e.hashers,e.loadHasher),this.getCodec=qb(e.codecs,e.loadCodec),this.dns=e.dns??Jc(),this.metrics=e.metrics,this.libp2p=e.libp2p,this.events=new _e;let t={blockstore:e.blockstore,datastore:e.datastore,logger:this.logger,libp2p:this.libp2p,blockBrokers:[],getHasher:this.getHasher,getCodec:this.getCodec,dns:this.dns,metrics:this.metrics,...e.components??{}};this.routing=t.routing=new il(t,{routers:(e.routers??[]).flatMap(o=>{let s=[o];return o[Vr]!=null&&s.push(o[Vr]),o[qr]!=null&&s.push(o[qr]),s}),providerLookupConcurrency:e.providerLookupConcurrency});let n=new Ll(t,e);this.pins=new sl(e.datastore,n,this.getCodec),this.blockstore=new Sl(n,this.pins,{holdGcLock:e.holdGcLock??!0}),this.datastore=e.datastore,t.blockBrokers=e.blockBrokers.map(o=>o(t))}async start(){await Cb(this.datastore),await sr(this.blockstore,this.datastore,this.routing,this.libp2p),this.events.dispatchEvent(new CustomEvent("start",{detail:this}))}async stop(){await ir(this.blockstore,this.datastore,this.routing,this.libp2p),this.events.dispatchEvent(new CustomEvent("stop",{detail:this}))}async gc(e={}){let t=await this.blockstore.lock.writeLock();try{let n=this,o=this.blockstore.unwrap();this.log("gc start"),await ki(o.deleteMany((async function*(){for await(let{cid:s}of o.getAll())try{if(await n.pins.isPinned(s,e))continue;yield s,e.onProgress?.(new Y("helia:gc:deleted",s))}catch(i){n.log.error("Error during gc",i),e.onProgress?.(new Y("helia:gc:error",i))}})()))}finally{t()}this.log("gc finished")}};var uk=[6,53,56,54,55];function jb(r){return Xb("sni",r)?.value}function Yb(r){let e=Xb("tcp",r)?.value;return e==null?"":`:${e}`}function Xb(r,e){return e.find(t=>t.name===r)}function Zb(r){return r.some(({code:e})=>e===448)}function Xt(r,e){let t=Jb[r.name];if(t==null)throw new Error(`Can't interpret protocol ${r.name}`);let n=t(r,e);return r.code===41?`[${n}]`:n}var Jb={ip4:(r,e)=>r.value,ip6:(r,e)=>e.length===0?r.value:`[${r.value}]`,tcp:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");return`tcp://${Xt(t,e)}:${r.value}`},udp:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");return`udp://${Xt(t,e)}:${r.value}`},dnsaddr:(r,e)=>r.value,dns4:(r,e)=>r.value,dns6:(r,e)=>r.value,dns:(r,e)=>r.value,ipfs:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");return`${Xt(t,e)}`},p2p:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");return`${Xt(t,e)}`},http:(r,e)=>{let t=Zb(e),n=jb(e),o=Yb(e);if(t&&n!=null)return`https://${n}${o}`;let s=t?"https://":"http://",i=e.pop();if(i==null)throw new Error("Unexpected end of multiaddr");let a=Xt(i,e);return a=a?.replace("tcp://",""),`${s}${a}`},"http-path":(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");let n=Xt(t,e),o=decodeURIComponent(r.value??"");return`${n}${o}`},tls:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");return Xt(t,e)},sni:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");return Xt(t,e)},https:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");let n=Xt(t,e);return n=n?.replace("tcp://",""),`https://${n}`},ws:(r,e)=>{let t=Zb(e),n=jb(e),o=Yb(e);if(t&&n!=null)return`wss://${n}${o}`;let s=t?"wss://":"ws://",i=e.pop();if(i==null)throw new Error("Unexpected end of multiaddr");let a=Xt(i,e);return a=a?.replace("tcp://",""),`${s}${a}`},wss:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");let n=Xt(t,e);return n=n?.replace("tcp://",""),`wss://${n}`}};function Dl(r,e){let n=ee(r).getComponents(),o=n.pop();if(o==null)throw new Error("Unexpected end of multiaddr");let s=Jb[o.name];if(s==null)throw new Error(`No interpreter found for ${o.name}`);let i=s(o,n)??"";return e?.assumeHttp!==!1&&uk.includes(o.code)&&(i=i.replace(/^.*:\/\//,""),o.value==="443"?i=`https://${i}`:i=`http://${i}`),(i.startsWith("http://")||i.startsWith("https://")||i.startsWith("ws://")||i.startsWith("wss://"))&&(i=new URL(i).toString(),i.endsWith("/")&&(i=i.substring(0,i.length-1))),i}var fe=r=>({match:e=>{let t=e[0];return t==null||t.code!==r||t.value!=null?!1:e.slice(1)}}),q=(r,e)=>({match:t=>{let n=t[0];return n?.code!==r||n.value==null||e!=null&&n.value!==e?!1:t.slice(1)}}),Qb=r=>({match:e=>r.match(e)===!1?e:!1}),te=r=>({match:e=>{let t=r.match(e);return t===!1?e:t}}),et=(...r)=>({match:e=>{let t;for(let n of r){let o=n.match(e);o!==!1&&(t==null||o.length<t.length)&&(t=o)}return t??!1}}),ce=(...r)=>({match:e=>{for(let t of r){let n=t.match(e);if(n===!1)return!1;e=n}return e}});function de(...r){function e(o){if(o==null)return!1;let s=o.getComponents();for(let i of r){let a=i.match(s);if(a===!1)return!1;s=a}return s}function t(o){return e(o)!==!1}function n(o){let s=e(o);return s===!1?!1:s.length===0}return{matchers:r,matches:t,exactMatch:n}}var fk=q(421),ex=de(fk),Rl=q(54),Ml=q(55),Ol=q(56),om=q(53),dO=de(Rl,te(q(421))),hO=de(Ml,te(q(421))),pO=de(Ol,te(q(421))),tx=de(et(om,Ol,Rl,Ml),te(q(421))),rx=ce(q(4),te(q(43))),nx=ce(te(q(42)),q(41),te(q(43))),sm=et(rx,nx),to=et(sm,om,Rl,Ml,Ol),mO=de(et(sm,ce(et(om,Ol,Rl,Ml),te(q(421))))),im=de(rx),am=de(nx),gO=de(sm),cm=ce(to,q(6)),qi=ce(to,q(273)),zi=de(ce(cm,te(q(421)))),yO=de(qi),lm=ce(qi,fe(460),te(q(421))),Ul=ce(qi,fe(461),te(q(421))),dk=et(lm,Ul),wO=de(lm),ox=de(Ul),nm=et(to,cm,qi,lm,Ul),sx=et(ce(nm,fe(477),te(q(421)))),ro=de(sx),ix=et(ce(nm,fe(478),te(q(421))),ce(nm,fe(448),te(q(449)),fe(477),te(q(421)))),Gi=de(ix),ax=ce(qi,fe(280),te(q(466)),te(q(466)),te(q(421))),um=de(ax),cx=ce(Ul,fe(465),te(q(466)),te(q(466)),te(q(421))),fm=de(cx),Nl=et(sx,ix,ce(cm,te(q(421))),ce(dk,te(q(421))),ce(to,te(q(421))),ax,cx,q(421)),bO=de(Nl),hk=ce(te(Nl),fe(290),Qb(fe(281)),te(q(421))),no=de(hk),pk=et(ce(Nl,fe(290),fe(281),te(q(421))),ce(Nl,fe(281),te(q(421))),ce(fe(281),te(q(421)))),dm=de(pk),mk=et(ce(to,q(6),fe(480),te(q(421))),ce(to,fe(480),te(q(421)))),lx=de(mk),gk=ce(to,et(ce(q(6,"443"),fe(480)),ce(q(6),fe(443)),ce(q(6),fe(448),fe(480)),ce(fe(448),fe(480)),fe(448),fe(443)),te(q(421))),ux=de(gk),yk=et(ce(q(777),te(q(421)))),xO=de(yk),wk=et(ce(q(400),te(q(421)))),vO=de(wk);function hm(r,e,t){return r.filter(n=>{if(ux.matches(n)||e&&lx.matches(n))return t||tx.matches(n)?!0:qt(n)===!1;if(!e&&t){let{host:o}=Q(n);if(o==="127.0.0.1"||o==="localhost"||o.endsWith(".localhost"))return!0}return!1})}async function*Fl(r,e,t,n,o,s={}){for await(let i of e.findProviders(r,s)){let a=hm(i.multiaddrs,n,o);if(a.length===0)continue;let c=Dl(a[0]);yield new fs(c,{logger:t,transformRequestInit:s.transformRequestInit})}}async function fx(r,e,t){let{signal:n,log:o}=t??{},s=r.headers.get("content-length");if(s!=null){let c=parseInt(s,10);if(c>e)throw o?.error("content-length header (%d) is greater than the limit (%d)",c,e),r.body!=null&&await r.body.cancel().catch(l=>{o?.error("error cancelling response body after content-length check - %e",l)}),new Error(`Content-Length header (${c}) is greater than the limit (${e}).`)}let i=r.body?.getReader();if(i==null)throw new Error("Response body is not readable");let a=new se;try{for(;;){if(n?.aborted===!0)throw new Error("Response body read was aborted.");let{done:c,value:l}=await i.read();if(c)break;if(a.append(l),a.byteLength>e)throw new Error(`Response body is greater than the limit (${e}), received ${a.byteLength} bytes.`)}}finally{i.cancel().catch(c=>{o?.error("error cancelling reader - %e",c)}).finally(()=>{i.releaseLock()})}return a.subarray()}var fs=class{url;#e=0;#t=0;#r=0;#i=0;#s=new Map;log;transformRequestInit;constructor(e,{logger:t,transformRequestInit:n}){this.url=e instanceof URL?e:new URL(e),this.transformRequestInit=n,this.log=t.forComponent(`helia:trustless-gateway-block-broker:${this.url.hostname}`)}#f(e){let t=e.multihash.bytes;return Ye.encode(t)}async getRawBlock(e,{signal:t,maxSize:n=dx}={}){let o=new URL(this.url.toString());if(o.pathname=`/ipfs/${e.toString()}`,o.search="?format=raw",t?.aborted===!0)throw new Error(`Signal to fetch raw block for CID ${e} from gateway ${this.url} was aborted prior to fetch`);let s=this.#f(e),i=new AbortController,a=()=>{i.abort()};t?.addEventListener("abort",a);try{let c=this.#s.get(s);if(c==null){this.#e++;let l={signal:i.signal,headers:{Accept:"application/vnd.ipld.raw"},cache:"force-cache"},f=this.transformRequestInit!=null?await this.transformRequestInit(l):l;c=fetch(o.toString(),f).then(async u=>{if(this.log("GET %s %d",o,u.status),!u.ok)throw this.#t++,new Error(`unable to fetch raw block for CID ${e} from gateway ${this.url}`);let d=await fx(u,n,{signal:i.signal,log:this.log});return this.#i++,d}),this.#s.set(s,c)}return await c}catch{throw t?.aborted===!0?new Error(`fetching raw block for CID ${e} from gateway ${this.url} was aborted`):(this.#t++,new Error(`unable to fetch raw block for CID ${e}`))}finally{t?.removeEventListener("abort",a),this.#s.delete(s)}}reliability(){return this.#e===0?1:this.#r>0?-1/0:this.#i/(this.#e+this.#t*3)}incrementInvalidBlocks(){this.#r++}getStats(){return{attempts:this.#e,errors:this.#t,invalidBlocks:this.#r,successes:this.#i,pendingResponses:this.#s.size}}};var pm=class extends Hi{routing;allowInsecure;allowLocal;transformRequestInit;constructor(e,t){super(e,{...t,name:"helia:trustless-gateway:session"}),this.routing=e.routing,this.allowInsecure=t.allowInsecure??$l,this.allowLocal=t.allowLocal??Vl,this.transformRequestInit=t.transformRequestInit}async queryProvider(e,t,n){this.log("fetching BLOCK for %c from %s",e,t.url);let o=await t.getRawBlock(e,n);return this.log.trace("got block for %c from %s",e,t.url),await n.validateFn?.(o),o}async*findNewProviders(e,t={}){yield*Fl(e,this.routing,this.logger,this.allowInsecure,this.allowLocal,{...t,transformRequestInit:this.transformRequestInit})}toEvictionKey(e){return e.url.toString()}equals(e,t){return e.url.toString()===t.url.toString()}async convertToProvider(e,t){if(or(e))return;let n=hm(Array.isArray(e)?e:[e],this.allowInsecure,this.allowLocal);if(n.length===0)return;let o=Dl(n[0]);return new fs(o,{logger:this.logger,transformRequestInit:this.transformRequestInit})}};function hx(r,e){return new pm(r,e)}var Kl=class{allowInsecure;allowLocal;transformRequestInit;routing;log;logger;constructor(e,t={}){this.log=e.logger.forComponent("helia:trustless-gateway-block-broker"),this.logger=e.logger,this.routing=e.routing,this.allowInsecure=t.allowInsecure??$l,this.allowLocal=t.allowLocal??Vl,this.transformRequestInit=t.transformRequestInit}async retrieve(e,t={}){let n=[];for await(let o of Fl(e,this.routing,this.logger,this.allowInsecure,this.allowLocal,{...t,transformRequestInit:this.transformRequestInit})){this.log("getting block for %c from %s",e,o.url);try{let s=await o.getRawBlock(e,t);this.log.trace("got block for %c from %s",e,o.url);try{await t.validateFn?.(s)}catch(i){this.log.error("failed to validate block for %c from %s",e,o.url,i);continue}return s}catch(s){if(this.log.error("failed to get block for %c from %s",e,o.url,s),s instanceof Error?n.push(s):n.push(new Error(`Unable to fetch raw block for CID ${e} from gateway ${o.url}`)),t.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",e,o.url);break}}}throw n.length>0?new AggregateError(n,`Unable to fetch raw block for CID ${e} from any gateway`):new Error(`Unable to fetch raw block for CID ${e} from any gateway`)}createSession(e={}){return hx({logger:this.logger,routing:this.routing},{...e,allowLocal:this.allowLocal,allowInsecure:this.allowInsecure,transformRequestInit:this.transformRequestInit})}};var $l=!1,Vl=!1,dx=2097152;function mm(r={}){return e=>new Kl(e,r)}async function*Hl(r,e={}){let t=r.getReader();try{for(;;){let n=await t.read();if(n.done)return;yield n.value}}finally{e.preventCancel!==!0&&await t.cancel(),t.releaseLock()}}var Sk=wn(ym(),1);var Jt=class extends Error{static name="SignatureVerificationError";constructor(e="Record signature verification failed"){super(e),this.name="SignatureVerificationError"}},ql=class extends Error{static name="RecordExpiredError";constructor(e="Record has expired"){super(e),this.name="RecordExpiredError"}},ds=class extends Error{static name="UnsupportedValidityError";constructor(e="The validity type is unsupported"){super(e),this.name="UnsupportedValidityError"}},zl=class extends Error{static name="RecordTooLargeError";constructor(e="The record is too large"){super(e),this.name="RecordTooLargeError"}},Gl=class extends Error{static name="InvalidValueError";constructor(e="Value must be a valid content path starting with /"){super(e),this.name="InvalidValueError"}},Wl=class extends Error{static name="InvalidRecordDataError";constructor(e="Invalid record data"){super(e),this.name="InvalidRecordDataError"}},Wi=class extends Error{static name="InvalidEmbeddedPublicKeyError";constructor(e="Invalid embedded public key"){super(e),this.name="InvalidEmbeddedPublicKeyError"}};var Qt;(function(r){let e;(function(o){o.EOL="EOL"})(e=r.ValidityType||(r.ValidityType={}));let t;(function(o){o[o.EOL=0]="EOL"})(t||(t={})),(function(o){o.codec=()=>Js(t)})(e=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=Fe((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,i={})=>{let a={},c=s==null?o.len:o.pos+s;for(;o.pos<c;){let l=o.uint32();switch(l>>>3){case 1:{a.value=o.bytes();break}case 2:{a.signatureV1=o.bytes();break}case 3:{a.validityType=r.ValidityType.codec().decode(o);break}case 4:{a.validity=o.bytes();break}case 5:{a.sequence=o.uint64();break}case 6:{a.ttl=o.uint64();break}case 7:{a.pubKey=o.bytes();break}case 8:{a.signatureV2=o.bytes();break}case 9:{a.data=o.bytes();break}default:{o.skipType(l&7);break}}}return a})),n),r.encode=o=>Ue(o,r.codec()),r.decode=(o,s)=>Oe(o,r.codec(),s)})(Qt||(Qt={}));var bk=ut("ipns:utils"),px=B("/ipns/");var xk=0,vk=18;function mx(r){let e;if(r.pubKey!=null)try{e=nn(r.pubKey)}catch(t){throw bk.error(t),t}if(e!=null)return e}function gx(r){let e=B("ipns-signature:");return Ce([e,r])}function ji(r){return"signatureV1"in r?Qt.encode({value:B(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:B(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):Qt.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data})}function hn(r){let e=Qt.decode(r);if(e.sequence!=null&&(e.sequence=BigInt(e.sequence)),e.ttl!=null&&(e.ttl=BigInt(e.ttl)),e.signatureV2==null||e.data==null)throw new Jt("Missing data or signatureV2");let t=yx(e.data),n=Ek(t.Value),o=U(t.Validity);if(e.value!=null&&e.signatureV1!=null)return Ak(e),{value:n,validityType:Qt.ValidityType.EOL,validity:o,sequence:t.Sequence,ttl:t.TTL,pubKey:e.pubKey,signatureV1:e.signatureV1,signatureV2:e.signatureV2,data:e.data};if(e.signatureV2!=null)return{value:n,validityType:Qt.ValidityType.EOL,validity:o,sequence:t.Sequence,ttl:t.TTL,pubKey:e.pubKey,signatureV2:e.signatureV2,data:e.data};throw new Error("invalid record: does not include signatureV1 or signatureV2")}function Yi(r){return Ce([px,r.bytes])}function hs(r){let e=pt(r.slice(px.length));if(!jl(e,xk)&&!jl(e,vk))throw new Hr("Multihash in IPNS key was not identity or sha2-256");return e}function yx(r){let e=vt(r);if(e.ValidityType===0)e.ValidityType=Qt.ValidityType.EOL;else throw new ds("The validity type is unsupported");return Number.isInteger(e.Sequence)&&(e.Sequence=BigInt(e.Sequence)),Number.isInteger(e.TTL)&&(e.TTL=BigInt(e.TTL)),e}function Ek(r){let e=U(r).trim();if(e.startsWith("/"))return e;try{return`/ipfs/${K.decode(r).toV1().toString()}`}catch{}try{return`/ipfs/${K.parse(e).toV1().toString()}`}catch{}throw new Gl("Value must be a valid content path starting with /")}function Ak(r){if(r.data==null)throw new Wl("Record data is missing");let e=yx(r.data);if(!X(e.Value,r.value??new Uint8Array(0)))throw new Jt('Field "value" did not match between protobuf and CBOR');if(!X(e.Validity,r.validity??new Uint8Array(0)))throw new Jt('Field "validity" did not match between protobuf and CBOR');if(e.ValidityType!==r.validityType)throw new Jt('Field "validityType" did not match between protobuf and CBOR');if(e.Sequence!==r.sequence)throw new Jt('Field "sequence" did not match between protobuf and CBOR');if(e.TTL!==r.ttl)throw new Jt('Field "ttl" did not match between protobuf and CBOR')}function jl(r,e){return r.code===e}var gU=ut("ipns"),yU=300*1e9,Ik="/ipns/",wU=Ik.length;var wx=wn(ym(),1);var Yl=ut("ipns:validator"),kk=1024*10;async function _k(r,e){let t=hn(e),n;try{let o=gx(t.data);n=await r.verify(o,t.signatureV2)}catch{n=!1}if(!n)throw Yl.error("record signature verification failed"),new Jt("Record signature verification failed");if(t.validityType===Qt.ValidityType.EOL){if(wx.default.fromString(t.validity).toDate().getTime()<Date.now())throw Yl.error("record has expired"),new ql("record has expired")}else if(t.validityType!=null)throw Yl.error("the validity type is unsupported"),new ds("The validity type is unsupported");Yl("ipns record for %s is valid",t.value)}async function bx(r,e){if(e.byteLength>kk)throw new zl("The record is too large");let t=hs(r),n;jl(t,0)&&(n=Ja(t));let o=hn(e),s=mx(o)??n;if(s==null)throw new Wi("Could not extract public key from IPNS record or routing key");let i=Yi(s.toMultihash());if(!X(i,r))throw new Wi("Embedded public key did not match routing key");await _k(s,e)}var Zl=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MESSAGE_LENGTH"};async function*Zi(r,e={}){let t=/\r?\n/,n=new TextDecoder("utf8"),o="";for await(let s of r){if(typeof s=="string"&&(s=new TextEncoder().encode(s)),xo(s)&&(s=s.subarray()),o+=n.decode(s,{stream:!0}),o.length>(e?.maxMessageLength??o.length))throw new Zl("Incoming message too long");let i=o.split(t);o=i.pop()??"";for(let a=0;a<i.length;a++)yield JSON.parse(i[a])}o+=n.decode(),o!==""&&(yield JSON.parse(o))}var ps=class extends Error{static name="InvalidRequestError";constructor(e="Invalid request"){super(e),this.name="InvalidRequestError"}},er=class extends Error{static name="BadResponseError";constructor(e="Bad response"){super(e),this.name="BadResponseError"}};function Ck(r){return r[Symbol.asyncIterator]!=null}function Tk(r){if(Ck(r))return(async()=>{for await(let e of r)return e})();for(let e of r)return e}var xx=Tk;var vx=B("/ipns/");function Ex(r){return X(r.subarray(0,vx.byteLength),vx)}var Xl=class{client;constructor(e){this.client=e}async*findProviders(e,t={}){yield*qc(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async cancelReprovide(){}async put(e,t,n){if(!Ex(e))return;let o=hs(e),s=K.createV1(114,o),i=hn(t);await this.client.putIPNS(s,i,n)}async get(e,t){if(!Ex(e))throw new ke("Not found");let n=hs(e),o=K.createV1(114,n);try{let s=await this.client.getIPNS(o,t);return ji(s)}catch(s){throw s.name==="BadResponseError"?new ke("Not found"):s}}},Jl=class{client;constructor(e){this.client=e}async findPeer(e,t={}){let n=await xx(this.client.getPeers(e,t));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new ke("Not found")}async*getClosestPeers(e,t={}){}};var He=ut("delegated-routing-v1-http-api-client"),Ql={concurrentRequests:4,timeout:3e4,cacheTTL:300*1e3,cacheName:"delegated-routing-v1-cache"},eu=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;filterAddrs;filterProtocols;inFlightRequests;cacheName;cache;cacheTTL;constructor(e,t={}){this.started=!1,this.shutDownController=new AbortController,this.shutDownController.signal,this.httpQueue=new Jn({concurrency:t.concurrentRequests??Ql.concurrentRequests}),this.inFlightRequests=new Map,this.clientUrl=e instanceof URL?e:new URL(e),this.timeout=t.timeout??Ql.timeout,this.filterAddrs=t.filterAddrs,this.filterProtocols=t.filterProtocols,this.contentRouting=new Xl(this),this.peerRouting=new Jl(this),this.cacheName=t.cacheName??Ql.cacheName,this.cacheTTL=t.cacheTTL??Ql.cacheTTL}get[Vr](){return this.contentRouting}get[qr](){return this.peerRouting}isStarted(){return this.started}async start(){this.started||(this.started=!0,this.cacheTTL>0&&(this.cache=await globalThis.caches?.open(this.cacheName),this.cache!=null&&He("cache enabled with ttl %d",this.cacheTTL)))}async stop(){this.httpQueue.clear(),this.shutDownController.abort(),await globalThis.caches?.delete(this.cacheName),this.started=!1}async*getProviders(e,t={}){He("getProviders starts: %c",e);let n=AbortSignal.timeout(this.timeout),o=pe([this.shutDownController.signal,n,t.signal]);let s=ae(),i=ae();this.httpQueue.add(async()=>(s.resolve(),i.promise));try{await s.promise;let a=new URL(`${this.clientUrl}routing/v1/providers/${e.toString()}`);this.#t(a,t.filterAddrs,t.filterProtocols);let c={headers:{Accept:"application/x-ndjson"},signal:o},l=await this.#r(a.toString(),c);if(l==null)throw new er("No response received");if(!l.ok)throw l.status===404?new ke("No matching records found"):l.status===422?new ps("Request does not conform to schema or semantic constraints"):new er(`Unexpected status code: ${l.status}`);if(l.body==null)throw new er("Routing response had no body");let f=l.headers.get("Content-Type");if(f==null)throw new er("No Content-Type header received");if(f?.startsWith("application/json")){let u=await l.json();for(let d of u.Providers){let h=this.#e(d);h!=null&&(yield h)}}else if(f.includes("application/x-ndjson"))for await(let u of Zi(Hl(l.body))){let d=this.#e(u);d!=null&&(yield d)}else throw new er(`Unsupported Content-Type: ${f}`)}finally{o.clear(),i.resolve(),He("getProviders finished: %c",e)}}async*getPeers(e,t={}){He("getPeers starts: %c",e);let n=AbortSignal.timeout(this.timeout),o=pe([this.shutDownController.signal,n,t.signal]);let s=ae(),i=ae();this.httpQueue.add(async()=>(s.resolve(),i.promise));try{await s.promise;let a=new URL(`${this.clientUrl}routing/v1/peers/${e.toCID().toString()}`);this.#t(a,t.filterAddrs,t.filterProtocols);let c={headers:{Accept:"application/x-ndjson"},signal:o},l=await this.#r(a.toString(),c);if(l.status===404)throw new ke("No matching records found");if(l.status===422)throw new ps("Request does not conform to schema or semantic constraints");if(l.body==null)throw new er("Routing response had no body");if(l.headers.get("Content-Type")==="application/json"){let u=await l.json();for(let d of u.Peers){let h=this.#e(d);h!=null&&(yield h)}}else for await(let u of Zi(Hl(l.body))){let d=this.#e(u);d!=null&&(yield d)}}catch(a){He.error("getPeers errored:",a)}finally{o.clear(),i.resolve(),He("getPeers finished: %c",e)}}async getIPNS(e,t={}){He("getIPNS starts: %s",e);let n=AbortSignal.timeout(this.timeout),o=pe([this.shutDownController.signal,n,t.signal]);let s=ae(),i=ae();this.httpQueue.add(async()=>(s.resolve(),i.promise));let a=`${this.clientUrl}routing/v1/ipns/${e}`;try{await s.promise;let c={headers:{Accept:"application/vnd.ipfs.ipns-record"},signal:o},l=await this.#r(a,c);if(He("getIPNS GET %s %d",a,l.status),l.status===404)throw new ke("No matching records found");if(l.status===422)throw new ps("Request does not conform to schema or semantic constraints");if(l.body==null)throw new er("GET ipns response had no body");let f=await l.arrayBuffer(),u=new Uint8Array(f,0,f.byteLength);return t.validate!==!1&&await bx(Yi(e.multihash),u),hn(u)}catch(c){throw He.error("getIPNS GET %s error:",a,c),c}finally{o.clear(),i.resolve(),He("getIPNS finished: %s",e)}}async putIPNS(e,t,n={}){He("putIPNS starts: %c",e);let o=AbortSignal.timeout(this.timeout),s=pe([this.shutDownController.signal,o,n.signal]);let i=ae(),a=ae();this.httpQueue.add(async()=>(i.resolve(),a.promise));let c=`${this.clientUrl}routing/v1/ipns/${e}`;try{await i.promise;let l=ji(t),f={method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:l,signal:s},u=await this.#r(c,f);if(He("putIPNS PUT %s %d",c,u.status),u.status!==200)throw new er("PUT ipns response had status other than 200")}catch(l){throw He.error("putIPNS PUT %s error:",c,l.stack),l}finally{s.clear(),a.resolve(),He("putIPNS finished: %c",e)}}#e(e){try{let t=[],n=e.Addrs?.map(ee)??[];return e.Protocols!=null&&t.push(...e.Protocols),e.Protocol!=null&&(t.push(e.Protocol),delete e.Protocol),{...e,Schema:"peer",ID:Bt(e.ID),Addrs:n,Protocols:t}}catch(t){He.error("could not conform record to peer schema",t)}}#t(e,t,n){if(t!=null||this.filterAddrs!=null){let o=t?.join(",")??this.filterAddrs?.join(",")??"";o!==""&&e.searchParams.set("filter-addrs",o)}if(n!=null||this.filterProtocols!=null){let o=n?.join(",")??this.filterProtocols?.join(",")??"";o!==""&&e.searchParams.set("filter-protocols",o)}}async#r(e,t){let n=t.method??"GET",o=`${n}-${e}`;if(n==="GET"){let c=await this.cache?.match(e);if(c!=null){if(parseInt(c.headers.get("x-cache-expires")??"0",10)>Date.now())return He("returning cached response for %s",o),c;await this.cache?.delete(e)}}let s=this.inFlightRequests.get(o);if(s!=null){let c=await s;return He("deduplicating outgoing request for %s",o),c.clone()}let i=fetch(e,t).then(async c=>{if(this.cache!=null&&c.ok&&n==="GET"){let l=Date.now()+this.cacheTTL,f=new Headers(c.headers);f.set("x-cache-expires",l.toString());let u=new Response(c.clone().body,{status:c.status,statusText:c.statusText,headers:f});await this.cache.put(e,u)}return c}).finally(()=>{this.inFlightRequests.delete(o)});return this.inFlightRequests.set(o,i),await i}};function Ax(r,e={}){return new eu(new URL(r),e)}var Sx="[a-fA-F\\d:]",pn=r=>r&&r.includeBoundaries?`(?:(?<=\\s|^)(?=${Sx})|(?<=${Sx})(?=\\s|$))`:"",tr="(?: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}",Ie="[a-fA-F\\d]{1,4}",tu=`
4
+ ${t}`:t??e??r.toString()};function zS(r){let e=()=>{};return e.enabled=!1,e.color="",e.diff=0,e.log=()=>{},e.namespace=r,e.destroy=()=>!0,e.extend=()=>e,e}function fn(){return{forComponent(r){return ut(r)}}}function ut(r){let e=zS(`${r}:trace`);return lt.enabled(`${r}:trace`)&&lt.names.map(t=>t.toString()).find(t=>t.includes(":trace"))!=null&&(e=lt(`${r}:trace`)),Object.assign(lt(r),{error:lt(`${r}:error`),trace:e,newScope:t=>ut(`${r}:${t}`)})}function rb(r){if(r!=null&&(r=r.trim(),r.length!==0))return r}var os=class extends Gt{has(e){return this.find(e)!=null}find(e){return this.queue.find(t=>e.equals(t.options.peerId))}};var Kc=class extends Gt{constructor(e={}){super({...e,sort:(t,n)=>t.options.priority>n.options.priority?-1:t.options.priority<n.options.priority?1:0})}};var Hc=class{memoryStorage;points;duration;blockDuration;keyPrefix;constructor(e={}){this.points=e.points??4,this.duration=e.duration??1,this.blockDuration=e.blockDuration??0,this.keyPrefix=e.keyPrefix??"rlflx",this.memoryStorage=new hp}consume(e,t=1,n={}){let o=this.getKey(e),s=this._getKeySecDuration(n),i=this.memoryStorage.incrby(o,t,s);if(i.remainingPoints=Math.max(this.points-i.consumedPoints,0),i.consumedPoints>this.points)throw this.blockDuration>0&&i.consumedPoints<=this.points+t&&(i=this.memoryStorage.set(o,i.consumedPoints,this.blockDuration)),new ic("Rate limit exceeded",i);return i}penalty(e,t=1,n={}){let o=this.getKey(e),s=this._getKeySecDuration(n),i=this.memoryStorage.incrby(o,t,s);return i.remainingPoints=Math.max(this.points-i.consumedPoints,0),i}reward(e,t=1,n={}){let o=this.getKey(e),s=this._getKeySecDuration(n),i=this.memoryStorage.incrby(o,-t,s);return i.remainingPoints=Math.max(this.points-i.consumedPoints,0),i}block(e,t){let n=t*1e3,o=this.points+1;return this.memoryStorage.set(this.getKey(e),o,t),{remainingPoints:0,msBeforeNext:n===0?-1:n,consumedPoints:o,isFirstInDuration:!1}}set(e,t,n=0){let o=(n>=0?n:this.duration)*1e3;return this.memoryStorage.set(this.getKey(e),t,n),{remainingPoints:0,msBeforeNext:o===0?-1:o,consumedPoints:t,isFirstInDuration:!1}}get(e){let t=this.memoryStorage.get(this.getKey(e));return t!=null&&(t.remainingPoints=Math.max(this.points-t.consumedPoints,0)),t}delete(e){this.memoryStorage.delete(this.getKey(e))}_getKeySecDuration(e){return e?.customDuration!=null&&e.customDuration>=0?e.customDuration:this.duration}getKey(e){return this.keyPrefix.length>0?`${this.keyPrefix}:${e}`:e}parseKey(e){return e.substring(this.keyPrefix.length)}},hp=class{storage;constructor(){this.storage=new Map}incrby(e,t,n){let o=this.storage.get(e);if(o!=null){let s=o.expiresAt!=null?o.expiresAt.getTime()-new Date().getTime():-1;return o.expiresAt==null||s>0?(o.value+=t,{remainingPoints:0,msBeforeNext:s,consumedPoints:o.value,isFirstInDuration:!1}):this.set(e,t,n)}return this.set(e,t,n)}set(e,t,n){let o=n*1e3,s=this.storage.get(e);s!=null&&clearTimeout(s.timeoutId);let i={value:t,expiresAt:o>0?new Date(Date.now()+o):void 0};return this.storage.set(e,i),o>0&&(i.timeoutId=setTimeout(()=>{this.storage.delete(e)},o),i.timeoutId.unref!=null&&i.timeoutId.unref()),{remainingPoints:0,msBeforeNext:o===0?-1:o,consumedPoints:i.value,isFirstInDuration:!0}}get(e){let t=this.storage.get(e);if(t!=null)return{remainingPoints:0,msBeforeNext:t.expiresAt!=null?t.expiresAt.getTime()-new Date().getTime():-1,consumedPoints:t.value,isFirstInDuration:!1}}delete(e){let t=this.storage.get(e);return t!=null?(t.timeoutId!=null&&clearTimeout(t.timeoutId),this.storage.delete(e),!0):!1}};var pp=class extends Map{metric;constructor(e){super();let{name:t,metrics:n}=e;this.metric=n.registerMetric(t),this.updateComponentMetric()}set(e,t){return super.set(e,t),this.updateComponentMetric(),this}delete(e){let t=super.delete(e);return this.updateComponentMetric(),t}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function Je(r){let{name:e,metrics:t}=r,n;return t!=null?n=new pp({name:e,metrics:t}):n=new Map,n}function GS(r){return r[Symbol.asyncIterator]!=null}function WS(r){if(GS(r))return(async()=>{for await(let e of r);})();for(let e of r);}var ki=WS;function jS(r){let[e,t]=r[Symbol.asyncIterator]!=null?[r[Symbol.asyncIterator](),Symbol.asyncIterator]:[r[Symbol.iterator](),Symbol.iterator],n=[];return{peek:()=>e.next(),push:o=>{n.push(o)},next:()=>n.length>0?{done:!1,value:n.shift()}:e.next(),[t](){return this}}}var ss=jS;function YS(r){return r[Symbol.asyncIterator]!=null}function ZS(r,e){let t=0;if(YS(r))return(async function*(){for await(let c of r)yield e(c,t++)})();let n=ss(r),{value:o,done:s}=n.next();if(s===!0)return(function*(){})();let i=e(o,t++);if(typeof i.then=="function")return(async function*(){yield await i;for(let c of n)yield e(c,t++)})();let a=e;return(function*(){yield i;for(let c of n)yield a(c,t++)})()}var qc=ZS;function XS(r){return r[Symbol.asyncIterator]!=null}function JS(r,e){return XS(r)?(async function*(){let t=0;if(!(e<1)){for await(let n of r)if(yield n,t++,t===e)return}})():(function*(){let t=0;if(!(e<1)){for(let n of r)if(yield n,t++,t===e)return}})()}var zc=JS;var Et=class extends Error{static name="AbortError";name="AbortError";constructor(e="The operation was aborted",...t){super(e,...t)}};async function Gc(r,e,t,n){let o=new Et(n?.errorMessage);n?.errorCode!=null&&(o.code=n.errorCode);let s=n?.errorEvent??"error";return t?.aborted===!0?Promise.reject(o):new Promise((i,a)=>{function c(){gp(t,"abort",u),gp(r,e,l),gp(r,s,f)}let l=d=>{try{if(n?.filter?.(d)===!1)return}catch(h){c(),a(h);return}c(),i(d)},f=d=>{if(c(),d instanceof Error){a(d);return}a(d.detail??n?.error??new Error(`The "${n?.errorEvent}" event was emitted but the event had no '.detail' field. Pass an 'error' option to race-event to change this message.`))},u=()=>{c(),a(o)};mp(t,"abort",u),mp(r,e,l),mp(r,s,f)})}function mp(r,e,t){r!=null&&(nb(r)?r.addEventListener(e,t):r.addListener(e,t))}function gp(r,e,t){r!=null&&(nb(r)?r.removeEventListener(e,t):r.removeListener(e,t))}function nb(r){return typeof r.addEventListener=="function"&&typeof r.removeEventListener=="function"}var ob=Symbol.for("nodejs.util.inspect.custom"),QS=114,_i=class{type;multihash;publicKey;string;constructor(e){this.type=e.type,this.multihash=e.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Ca]=!0;toString(){return this.string==null&&(this.string=le.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return K.createV1(QS,this.multihash)}toJSON(){return this.toString()}equals(e){if(e==null)return!1;if(e instanceof Uint8Array)return X(this.multihash.bytes,e);if(typeof e=="string")return this.toString()===e;if(e?.toMultihash()?.bytes!=null)return X(this.multihash.bytes,e.toMultihash().bytes);throw new Error("not valid Id")}[ob](){return`PeerId(${this.toString()})`}},Ci=class extends _i{type="RSA";publicKey;constructor(e){super({...e,type:"RSA"}),this.publicKey=e.publicKey}},Ti=class extends _i{type="Ed25519";publicKey;constructor(e){super({...e,type:"Ed25519"}),this.publicKey=e.publicKey}},Bi=class extends _i{type="secp256k1";publicKey;constructor(e){super({...e,type:"secp256k1"}),this.publicKey=e.publicKey}},eI=2336,Li=class{type="url";multihash;publicKey;url;constructor(e){this.url=e.toString(),this.multihash=We.digest(B(this.url))}[ob](){return`PeerId(${this.url})`}[Ca]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return K.createV1(eI,this.toMultihash())}toJSON(){return this.toString()}equals(e){return e==null?!1:(e instanceof Uint8Array&&(e=U(e)),e.toString()===this.toString())}};var tI=114,sb=2336;function Bt(r,e){let t;if(r.charAt(0)==="1"||r.charAt(0)==="Q")t=pt(le.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return Yn(K.parse(r));if(e==null)throw new k('Please pass a multibase decoder for strings that do not start with "1" or "Q"');t=pt(e.decode(r))}return is(t)}function yp(r){if(r.type==="Ed25519")return new Ti({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Bi({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new Ci({multihash:r.toCID().multihash,publicKey:r});throw new Nt}function ib(r){return yp(r.publicKey)}function is(r){if(nI(r))return new Ci({multihash:r});if(rI(r))try{let e=Ja(r);if(e.type==="Ed25519")return new Ti({multihash:r,publicKey:e});if(e.type==="secp256k1")return new Bi({multihash:r,publicKey:e})}catch{let t=U(r.digest);return new Li(new URL(t))}throw new Hr("Supplied PeerID Multihash is invalid")}function Yn(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==tI&&r.code!==sb)throw new va("Supplied PeerID CID is invalid");if(r.code===sb){let e=U(r.multihash.digest);return new Li(new URL(e))}return is(r.multihash)}function rI(r){return r.code===We.code}function nI(r){return r.code===Mt.code}function Zn(r,e){let t={[Symbol.iterator]:()=>t,next:()=>{let n=r.next(),o=n.value;return n.done===!0||o==null?{done:!0,value:void 0}:{done:!1,value:e(o)}}};return t}function Wc(r){let e=pt(le.decode(`z${r}`));return is(e)}var Lt=class{map;constructor(e){if(this.map=new Map,e!=null)for(let[t,n]of e.entries())this.map.set(t.toString(),{key:t,value:n})}[Symbol.iterator](){return this.entries()}clear(){this.map.clear()}delete(e){return this.map.delete(e.toString())}entries(){return Zn(this.map.entries(),e=>[e[1].key,e[1].value])}forEach(e){this.map.forEach((t,n)=>{e(t.value,t.key,this)})}get(e){return this.map.get(e.toString())?.value}has(e){return this.map.has(e.toString())}set(e,t){this.map.set(e.toString(),{key:e,value:t})}keys(){return Zn(this.map.values(),e=>e.key)}values(){return Zn(this.map.values(),e=>e.value)}get size(){return this.map.size}};var Xn=class r{set;constructor(e){if(this.set=new Set,e!=null)for(let t of e)this.set.add(t.toString())}get size(){return this.set.size}[Symbol.iterator](){return this.values()}add(e){this.set.add(e.toString())}clear(){this.set.clear()}delete(e){this.set.delete(e.toString())}entries(){return Zn(this.set.entries(),e=>{let t=Wc(e[0]);return[t,t]})}forEach(e){this.set.forEach(t=>{let n=Wc(t);e(n,n,this)})}has(e){return this.set.has(e.toString())}values(){return Zn(this.set.values(),e=>Wc(e))}intersection(e){let t=new r;for(let n of e)this.has(n)&&t.add(n);return t}difference(e){let t=new r;for(let n of this)e.has(n)||t.add(n);return t}union(e){let t=new r;for(let n of e)t.add(n);for(let n of this)t.add(n);return t}};var wp=class extends Lt{metric;constructor(e){super();let{name:t,metrics:n}=e;this.metric=n.registerMetric(t),this.updateComponentMetric()}set(e,t){return super.set(e,t),this.updateComponentMetric(),this}delete(e){let t=super.delete(e);return this.updateComponentMetric(),t}clear(){super.clear(),this.updateComponentMetric()}updateComponentMetric(){this.metric.update(this.size)}};function bp(r){let{name:e,metrics:t}=r,n;return t!=null?n=new wp({name:e,metrics:t}):n=new Lt,n}function oI(r){return r[Symbol.asyncIterator]!=null}function sI(r){if(oI(r))return(async()=>{let n=new Uint8Array(0);for await(let o of r)n=Ce([n,o],n.length+o.length);return n})();let e=[],t=0;for(let n of r)e.push(n),t+=n.byteLength;return Ce(e,t)}var ab=sI;var vp=wn(lb(),1);var Ep=class r extends Error{name="TimeoutError";constructor(e,t){super(e,t),Error.captureStackTrace?.(this,r)}},ub=r=>r.reason??new DOMException("This operation was aborted.","AbortError");function Ap(r,e){let{milliseconds:t,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout},signal:i}=e,a,c,f=new Promise((u,d)=>{if(typeof t!="number"||Math.sign(t)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${t}\``);if(i?.aborted){d(ub(i));return}if(i&&(c=()=>{d(ub(i))},i.addEventListener("abort",c,{once:!0})),r.then(u,d),t===Number.POSITIVE_INFINITY)return;let h=new Ep;a=s.setTimeout.call(void 0,()=>{if(n){try{u(n())}catch(m){d(m)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?u():o instanceof Error?d(o):(h.message=o??`Promise timed out after ${t} milliseconds`,d(h))},t)}).finally(()=>{f.clear(),c&&i&&i.removeEventListener("abort",c)});return f.clear=()=>{s.clearTimeout.call(void 0,a),a=void 0},f}function Sp(r,e,t){let n=0,o=r.length;for(;o>0;){let s=Math.trunc(o/2),i=n+s;t(r[i],e)<=0?(n=++i,o-=s+1):o=s}return n}var Di=class{#e=[];enqueue(e,t){let{priority:n=0,id:o}=t??{},s={priority:n,id:o,run:e};if(this.size===0||this.#e[this.size-1].priority>=n){this.#e.push(s);return}let i=Sp(this.#e,s,(a,c)=>c.priority-a.priority);this.#e.splice(i,0,s)}setPriority(e,t){let n=this.#e.findIndex(s=>s.id===e);if(n===-1)throw new ReferenceError(`No promise function with the id "${e}" exists in the queue.`);let[o]=this.#e.splice(n,1);this.enqueue(o.run,{priority:t,id:e})}dequeue(){return this.#e.shift()?.run}filter(e){return this.#e.filter(t=>t.priority===e.priority).map(t=>t.run)}get size(){return this.#e.length}};var Jn=class extends vp.default{#e;#t;#r=0;#i;#s=!1;#f=!1;#d;#b=0;#g=0;#a;#c;#n;#x;#o=0;#h;#l;#k=1n;#p=new Map;timeout;constructor(e){if(super(),e={carryoverIntervalCount:!1,intervalCap:Number.POSITIVE_INFINITY,interval:0,concurrency:Number.POSITIVE_INFINITY,autoStart:!0,queueClass:Di,...e},!(typeof e.intervalCap=="number"&&e.intervalCap>=1))throw new TypeError(`Expected \`intervalCap\` to be a number from 1 and up, got \`${e.intervalCap?.toString()??""}\` (${typeof e.intervalCap})`);if(e.interval===void 0||!(Number.isFinite(e.interval)&&e.interval>=0))throw new TypeError(`Expected \`interval\` to be a finite number >= 0, got \`${e.interval?.toString()??""}\` (${typeof e.interval})`);if(this.#e=e.carryoverIntervalCount??e.carryoverConcurrencyCount??!1,this.#t=e.intervalCap===Number.POSITIVE_INFINITY||e.interval===0,this.#i=e.intervalCap,this.#d=e.interval,this.#n=new e.queueClass,this.#x=e.queueClass,this.concurrency=e.concurrency,e.timeout!==void 0&&!(Number.isFinite(e.timeout)&&e.timeout>0))throw new TypeError(`Expected \`timeout\` to be a positive finite number, got \`${e.timeout}\` (${typeof e.timeout})`);this.timeout=e.timeout,this.#l=e.autoStart===!1,this.#N()}get#_(){return this.#t||this.#r<this.#i}get#C(){return this.#o<this.#h}#T(){this.#o--,this.#o===0&&this.emit("pendingZero"),this.#y(),this.emit("next")}#B(){this.#S(),this.#A(),this.#c=void 0}get#L(){let e=Date.now();if(this.#a===void 0){let t=this.#b-e;if(t<0){if(this.#g>0){let n=e-this.#g;if(n<this.#d)return this.#v(this.#d-n),!0}this.#r=this.#e?this.#o:0}else return this.#v(t),!0}return!1}#v(e){this.#c===void 0&&(this.#c=setTimeout(()=>{this.#B()},e))}#E(){this.#a&&(clearInterval(this.#a),this.#a=void 0)}#P(){this.#c&&(clearTimeout(this.#c),this.#c=void 0)}#y(){if(this.#n.size===0)return this.#E(),this.emit("empty"),this.#o===0&&(this.#P(),this.emit("idle")),!1;let e=!1;if(!this.#l){let t=!this.#L;if(this.#_&&this.#C){let n=this.#n.dequeue();this.#t||(this.#r++,this.#m()),this.emit("active"),this.#g=Date.now(),n(),t&&this.#A(),e=!0}}return e}#A(){this.#t||this.#a!==void 0||(this.#a=setInterval(()=>{this.#S()},this.#d),this.#b=Date.now()+this.#d)}#S(){this.#r===0&&this.#o===0&&this.#a&&this.#E(),this.#r=this.#e?this.#o:0,this.#w(),this.#m()}#w(){for(;this.#y(););}get concurrency(){return this.#h}set concurrency(e){if(!(typeof e=="number"&&e>=1))throw new TypeError(`Expected \`concurrency\` to be a number from 1 and up, got \`${e}\` (${typeof e})`);this.#h=e,this.#w()}async#D(e){return new Promise((t,n)=>{e.addEventListener("abort",()=>{n(e.reason)},{once:!0})})}setPriority(e,t){if(typeof t!="number"||!Number.isFinite(t))throw new TypeError(`Expected \`priority\` to be a finite number, got \`${t}\` (${typeof t})`);this.#n.setPriority(e,t)}async add(e,t={}){return t.id??=(this.#k++).toString(),t={timeout:this.timeout,...t},new Promise((n,o)=>{let s=Symbol(`task-${t.id}`);this.#n.enqueue(async()=>{this.#o++,this.#p.set(s,{id:t.id,priority:t.priority??0,startTime:Date.now(),timeout:t.timeout});try{try{t.signal?.throwIfAborted()}catch(c){throw this.#t||this.#r--,this.#p.delete(s),c}let i=e({signal:t.signal});t.timeout&&(i=Ap(Promise.resolve(i),{milliseconds:t.timeout,message:`Task timed out after ${t.timeout}ms (queue has ${this.#o} running, ${this.#n.size} waiting)`})),t.signal&&(i=Promise.race([i,this.#D(t.signal)]));let a=await i;n(a),this.emit("completed",a)}catch(i){o(i),this.emit("error",i)}finally{this.#p.delete(s),queueMicrotask(()=>{this.#T()})}},t),this.emit("add"),this.#y()})}async addAll(e,t){return Promise.all(e.map(async n=>this.add(n,t)))}start(){return this.#l?(this.#l=!1,this.#w(),this):this}pause(){this.#l=!0}clear(){this.#n=new this.#x,this.#I()}async onEmpty(){this.#n.size!==0&&await this.#u("empty")}async onSizeLessThan(e){this.#n.size<e||await this.#u("next",()=>this.#n.size<e)}async onIdle(){this.#o===0&&this.#n.size===0||await this.#u("idle")}async onPendingZero(){this.#o!==0&&await this.#u("pendingZero")}async onRateLimit(){this.isRateLimited||await this.#u("rateLimit")}async onRateLimitCleared(){this.isRateLimited&&await this.#u("rateLimitCleared")}async onError(){return new Promise((e,t)=>{let n=o=>{this.off("error",n),t(o)};this.on("error",n)})}async#u(e,t){return new Promise(n=>{let o=()=>{t&&!t()||(this.off(e,o),n())};this.on(e,o)})}get size(){return this.#n.size}sizeBy(e){return this.#n.filter(e).length}get pending(){return this.#o}get isPaused(){return this.#l}#N(){this.#t||(this.on("add",()=>{this.#n.size>0&&this.#m()}),this.on("next",()=>{this.#m()}))}#m(){this.#t||this.#f||(this.#f=!0,queueMicrotask(()=>{this.#f=!1,this.#I()}))}#I(){let e=this.#s,t=!this.#t&&this.#r>=this.#i&&this.#n.size>0;t!==e&&(this.#s=t,this.emit(t?"rateLimit":"rateLimitCleared"))}get isRateLimited(){return this.#s}get isSaturated(){return this.#o===this.#h&&this.#n.size>0||this.isRateLimited&&this.#n.size>0}get runningTasks(){return[...this.#p.values()].map(e=>({...e}))}};function Yc(r){let e=[At.A];return r==null?e:Array.isArray(r)?r.length===0?e:r:[r]}var Ip=60;function Zc(r){return{Status:r.Status??0,TC:r.TC??r.flag_tc??!1,RD:r.RD??r.flag_rd??!1,RA:r.RA??r.flag_ra??!1,AD:r.AD??r.flag_ad??!1,CD:r.CD??r.flag_cd??!1,Question:(r.Question??r.questions??[]).map(e=>({name:e.name,type:At[e.type]})),Answer:(r.Answer??r.answers??[]).map(e=>({name:e.name,type:At[e.type],TTL:e.TTL??e.ttl??Ip,data:e.data instanceof Uint8Array?U(e.data):e.data}))}}var cI=4;function kp(r,e={}){let t=new Jn({concurrency:e.queryConcurrency??cI});return async(n,o={})=>{let s=new URLSearchParams;s.set("name",n),Yc(o.types).forEach(a=>{s.append("type",At[a])}),o.onProgress?.(new Y("dns:query",n));let i=await t.add(async()=>{let a=await fetch(`${r}?${s}`,{headers:{accept:"application/dns-json"},signal:o?.signal});if(a.status!==200)throw new Error(`Unexpected HTTP status: ${a.status} - ${a.statusText}`);let c=Zc(await a.json());return o.onProgress?.(new Y("dns:response",c)),c},{signal:o.signal});if(i==null)throw new Error("No DNS response received");return i}}function fb(){return[kp("https://cloudflare-dns.com/dns-query"),kp("https://dns.google/resolve")]}var pb=wn(hb(),1);var _p=class{lru;constructor(e){this.lru=(0,pb.default)(e)}get(e,t){let n=!0,o=[];for(let s of t){let i=this.getAnswers(e,s);if(i.length===0){n=!1;break}o.push(...i)}if(n)return Zc({answers:o})}getAnswers(e,t){let n=`${e.toLowerCase()}-${t}`,o=this.lru.get(n);if(o!=null){let s=o.filter(i=>i.expires>Date.now()).map(({expires:i,value:a})=>({...a,TTL:Math.round((i-Date.now())/1e3),type:At[a.type]}));return s.length===0&&this.lru.remove(n),s}return[]}add(e,t){let n=`${e.toLowerCase()}-${t.type}`,o=this.lru.get(n)??[];o.push({expires:Date.now()+(t.TTL??Ip)*1e3,value:t}),this.lru.set(n,o)}remove(e,t){let n=`${e.toLowerCase()}-${t}`;this.lru.remove(n)}clear(){this.lru.clear()}};function mb(r){return new _p(r)}var lI=1e3,Xc=class{resolvers;cache;constructor(e){this.resolvers={},this.cache=mb(e.cacheSize??lI),Object.entries(e.resolvers??{}).forEach(([t,n])=>{Array.isArray(n)||(n=[n]),t.endsWith(".")||(t=`${t}.`),this.resolvers[t]=n}),this.resolvers["."]==null&&(this.resolvers["."]=fb())}async query(e,t={}){let n=Yc(t.types),o=t.cached!==!1?this.cache.get(e,n):void 0;if(o!=null)return t.onProgress?.(new Y("dns:cache",o)),o;let s=`${e.split(".").pop()}.`,i=(this.resolvers[s]??this.resolvers["."]).sort(()=>Math.random()>.5?-1:1),a=[];for(let c of i){if(t.signal?.aborted===!0)break;try{let l=await c(e,{...t,types:n});for(let f of l.Answer)this.cache.add(e,f);return l}catch(l){a.push(l),t.onProgress?.(new Y("dns:error",l))}}throw a.length===1?a[0]:new AggregateError(a,`DNS lookup of ${e} ${n} failed`)}};var At;(function(r){r[r.A=1]="A",r[r.CNAME=5]="CNAME",r[r.TXT=16]="TXT",r[r.AAAA=28]="AAAA"})(At||(At={}));function Jc(r={}){return new Xc(r)}var Br="/",gb=new TextEncoder().encode(Br),Qc=gb[0],ge=class r{_buf;constructor(e,t){if(typeof e=="string")this._buf=B(e);else if(e instanceof Uint8Array)this._buf=e;else throw new Error("Invalid key, should be String of Uint8Array");if(t==null&&(t=!0),t&&this.clean(),this._buf.byteLength===0||this._buf[0]!==Qc)throw new Error("Invalid key")}toString(e="utf8"){return U(this._buf,e)}uint8Array(){return this._buf}get[Symbol.toStringTag](){return`Key(${this.toString()})`}static withNamespaces(e){return new r(e.join(Br))}static random(){return new r(Math.random().toString().substring(2))}static asKey(e){return e instanceof Uint8Array||typeof e=="string"?new r(e):typeof e.uint8Array=="function"?new r(e.uint8Array()):null}clean(){if((this._buf==null||this._buf.byteLength===0)&&(this._buf=gb),this._buf[0]!==Qc){let e=new Uint8Array(this._buf.byteLength+1);e.fill(Qc,0,1),e.set(this._buf,1),this._buf=e}for(;this._buf.byteLength>1&&this._buf[this._buf.byteLength-1]===Qc;)this._buf=this._buf.subarray(0,-1)}less(e){let t=this.list(),n=e.list();for(let o=0;o<t.length;o++){if(n.length<o+1)return!1;let s=t[o],i=n[o];if(s<i)return!0;if(s>i)return!1}return t.length<n.length}reverse(){return r.withNamespaces(this.list().slice().reverse())}namespaces(){return this.list()}baseNamespace(){let e=this.namespaces();return e[e.length-1]}list(){return this.toString().split(Br).slice(1)}type(){return uI(this.baseNamespace())}name(){return fI(this.baseNamespace())}instance(e){return new r(this.toString()+":"+e)}path(){let e=this.parent().toString();return e.endsWith(Br)||(e+=Br),e+=this.type(),new r(e)}parent(){let e=this.list();return e.length===1?new r(Br):new r(e.slice(0,-1).join(Br))}child(e){return this.toString()===Br?e:e.toString()===Br?this:new r(this.toString()+e.toString(),!1)}isAncestorOf(e){return e.toString()===this.toString()?!1:e.toString().startsWith(this.toString())}isDecendantOf(e){return e.toString()===this.toString()?!1:this.toString().startsWith(e.toString())}isTopLevel(){return this.list().length===1}concat(...e){return r.withNamespaces([...this.namespaces(),...dI(e.map(t=>t.namespaces()))])}};function uI(r){let e=r.split(":");return e.length<2?"":e.slice(0,-1).join(":")}function fI(r){let e=r.split(":");return e[e.length-1]}function dI(r){return[].concat(...r)}function el({enumerable:r=!0,configurable:e=!1}={}){return{enumerable:r,configurable:e,writable:!1}}function*hI(r,e){if(e!=null&&typeof e=="object")if(Array.isArray(e))for(let[t,n]of e.entries()){let o=[...r,t],s=K.asCID(n);s!=null?yield[o.join("/"),s]:typeof n=="object"&&(yield*Cp(n,o))}else{let t=K.asCID(e);t!=null?yield[r.join("/"),t]:yield*Cp(e,r)}}function*Cp(r,e){if(r==null||r instanceof Uint8Array)return;let t=K.asCID(r);t!=null&&(yield[e.join("/"),t]);for(let[n,o]of Object.entries(r)){let s=[...e,n];yield*hI(s,o)}}function*pI(r,e){if(Array.isArray(e))for(let[t,n]of e.entries()){let o=[...r,t];yield o.join("/"),typeof n=="object"&&K.asCID(n)==null&&(yield*Tp(n,o))}else yield*Tp(e,r)}function*Tp(r,e){if(!(r==null||typeof r!="object"))for(let[t,n]of Object.entries(r)){let o=[...e,t];yield o.join("/"),n!=null&&!(n instanceof Uint8Array)&&typeof n=="object"&&K.asCID(n)==null&&(yield*pI(o,n))}}function mI(r,e){let t=r;for(let[n,o]of e.entries()){if(t=t[o],t==null)throw new Error(`Object has no property at ${e.slice(0,n+1).map(i=>`[${JSON.stringify(i)}]`).join("")}`);let s=K.asCID(t);if(s!=null)return{value:s,remaining:e.slice(n+1).join("/")}}return{value:t}}var Bp=class{cid;bytes;value;asBlock;constructor({cid:e,bytes:t,value:n}){if(e==null||t==null||typeof n>"u")throw new Error("Missing required argument");this.cid=e,this.bytes=t,this.value=n,this.asBlock=this,Object.defineProperties(this,{cid:el(),bytes:el(),value:el(),asBlock:el()})}links(){return Cp(this.value,[])}tree(){return Tp(this.value,[])}get(e="/"){return mI(this.value,e.split("/").filter(Boolean))}};function yb({bytes:r,cid:e,value:t,codec:n}){let o=t!==void 0?t:n?.decode(r);if(o===void 0)throw new Error('Missing required argument, must either provide "value" or "codec"');return new Bp({cid:e,bytes:r,value:o})}var tl=class extends Error{static name="AlreadyPinnedError";name="AlreadyPinnedError"},Ni=class extends Error{static name="BlockPinnedError";name="BlockPinnedError"},rl=class extends Error{static name="InvalidDatastoreVersionError";name="InvalidDatastoreVersionError"},nl=class extends Error{static name="InvalidConfigurationError";name="InvalidConfigurationError"};var xb="/pin/",wb="/pinned-block/",Lp=ar,bb=1;function ol(r){return r.version===0&&(r=r.toV1()),new ge(`${xb}${r.toString(Lp)}`)}var sl=class{datastore;blockstore;getCodec;constructor(e,t,n){this.datastore=e,this.blockstore=t,this.getCodec=n}async*add(e,t={}){let n=ol(e);if(await this.datastore.has(n))throw new tl("Already pinned");let o=Math.round(t.depth??1/0);if(o<0)throw new k("Depth must be greater than or equal to 0");let s=new Gt({concurrency:bb});for await(let a of this.#e(e,s,{...t,depth:o}))await this.#t(a,c=>c.pinnedBy.find(l=>X(l,e.bytes))!=null?!1:(c.pinCount++,c.pinnedBy.push(e.bytes),!0),t),yield a;let i={depth:o,metadata:t.metadata??{}};await this.datastore.put(n,un(i),t)}async*#e(e,t,n){if(n.depth===-1)return;let o=await this.getCodec(e.code),s=await ab(this.blockstore.get(e,n)),i=yb({bytes:s,cid:e,codec:o});yield e;for(let[,a]of i.links())yield*await t.add(async()=>this.#e(a,t,{...n,depth:n.depth-1}))}async#t(e,t,n){let o=new ge(`${wb}${Lp.encode(e.multihash.bytes)}`),s={pinCount:0,pinnedBy:[]};try{s=vt(await this.datastore.get(o,n))}catch(a){if(a.name!=="NotFoundError")throw a}if(t(s)){if(s.pinCount===0&&await this.datastore.has(o)){await this.datastore.delete(o);return}await this.datastore.put(o,un(s),n),n.onProgress?.(new Y("helia:pin:add",e))}}async*rm(e,t={}){let n=ol(e),o=await this.datastore.get(n,t),s=vt(o);await this.datastore.delete(n,t);let i=new Gt({concurrency:bb});for await(let a of this.#e(e,i,{...t,depth:s.depth}))await this.#t(a,c=>(c.pinCount--,c.pinnedBy=c.pinnedBy.filter(l=>X(l,e.bytes)),!0),{...t,depth:s.depth}),yield a}async*ls(e={}){for await(let{key:t,value:n}of this.datastore.query({prefix:xb+(e.cid!=null?`${e.cid.toString(ar)}`:"")},e)){let o=K.parse(t.toString().substring(5),ar),s=vt(n);yield{cid:o,...s}}}async isPinned(e,t={}){let n=new ge(`${wb}${Lp.encode(e.multihash.bytes)}`);return this.datastore.has(n,t)}async get(e,t){let n=ol(e),o=await this.datastore.get(n,t);return vt(o)}async setMetadata(e,t,n){let o=ol(e),s=await this.datastore.get(o,n),i=vt(s);i.metadata=t??{},await this.datastore.put(o,un(i),n)}};var Pp=1,Dp=5;var Ri=class extends Error{static name="InsufficientProvidersError";constructor(e="Insufficient providers found"){super(e),this.name="InsufficientProvidersError"}},dn=class extends Error{static name="NoRoutersAvailableError";constructor(e="No routers available"){super(e),this.name="NoRoutersAvailableError"}},Mi=class extends Error{static name="UnknownHashAlgorithmError";constructor(e="Unknown hash algorithm"){super(e),this.name="UnknownHashAlgorithmError"}},Oi=class extends Error{static name="UnknownCodecError";constructor(e="Unknown codec"){super(e),this.name="UnknownCodecError"}},Np=class extends Error{static name="InvalidCodecError";constructor(e="Invalid codec"){super(e),this.name="InvalidCodecError"}};var gI=5,il=class{log;routers;providerLookupConcurrency;constructor(e,t){this.log=e.logger.forComponent("helia:routing"),this.routers=t.routers??[],this.providerLookupConcurrency=t.providerLookupConcurrency??gI,this.findProviders=e.metrics?.traceFunction("helia.routing.findProviders",this.findProviders.bind(this),{optionsIndex:1})??this.findProviders,this.provide=e.metrics?.traceFunction("helia.routing.provide",this.provide.bind(this),{optionsIndex:1})??this.provide,this.cancelReprovide=e.metrics?.traceFunction("helia.routing.cancelReprovide",this.cancelReprovide.bind(this),{optionsIndex:1})??this.cancelReprovide,this.put=e.metrics?.traceFunction("helia.routing.put",this.put.bind(this),{optionsIndex:2})??this.put,this.get=e.metrics?.traceFunction("helia.routing.get",this.get.bind(this),{optionsIndex:1})??this.get,this.findPeer=e.metrics?.traceFunction("helia.routing.findPeer",this.findPeer.bind(this),{optionsIndex:1})??this.findPeer,this.getClosestPeers=e.metrics?.traceFunction("helia.routing.getClosestPeers",this.getClosestPeers.bind(this),{optionsIndex:1})??this.getClosestPeers}async start(){await sr(...this.routers)}async stop(){await ir(...this.routers)}async*findProviders(e,t={}){if(this.routers.length===0)throw new dn("No content routers available");let n=new os({concurrency:this.providerLookupConcurrency});for await(let o of _t(n.toGenerator(),...Qn(this.routers,"findProviders").map(s=>s.findProviders(e,t))))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,t);return s.multiaddrs.length===0?null:s}catch(s){return this.log.error("could not load multiaddrs for peer %p - %e",o.id,s),null}},{peerId:o.id,signal:t.signal}).catch(s=>{this.log.error("could not load multiaddrs for peer %p - %e",o.id,s)})}yield o}}async provide(e,t={}){if(this.routers.length===0)throw new dn("No content routers available");await Promise.all(Qn(this.routers,"provide").map(async n=>{await n.provide(e,t)}))}async cancelReprovide(e,t={}){await Promise.all(Qn(this.routers,"cancelReprovide").map(async n=>{await n.cancelReprovide(e,t)}))}async put(e,t,n){await Promise.all(Qn(this.routers,"put").map(async o=>{await o.put(e,t,n)}))}async get(e,t){return Promise.any(Qn(this.routers,"get").map(async n=>n.get(e,t)))}async findPeer(e,t){if(this.routers.length===0)throw new dn("No peer routers available");let n=this,o=_t(...Qn(this.routers,"findPeer").map(s=>(async function*(){try{yield await s.findPeer(e,t)}catch(i){n.log.error(i)}})()));for await(let s of o)if(s!=null)return s;throw new ke("Could not find peer in routing")}async*getClosestPeers(e,t={}){if(this.routers.length===0)throw new dn("No peer routers available");for await(let n of _t(...Qn(this.routers,"getClosestPeers").map(o=>o.getClosestPeers(e,t))))n!=null&&(yield n)}};function Qn(r,e){return r.filter(t=>t[e]!=null)}var al=class extends Error{static name="QueueFullError";constructor(e="The queue was full"){super(e),this.name="QueueFullError"}};var cl=class extends Error{type;code;constructor(e,t,n){super(e??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=t??"ABORT_ERR"}};async function vb(r,e,t){if(e==null)return r;if(e.aborted)return r.catch(()=>{}),Promise.reject(new cl(t?.errorMessage,t?.errorCode,t?.errorName));let n,o=new cl(t?.errorMessage,t?.errorCode,t?.errorName);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var ll=class{deferred;signal;constructor(e){this.signal=e,this.deferred=Promise.withResolvers(),this.onAbort=this.onAbort.bind(this),this.signal?.addEventListener("abort",this.onAbort)}onAbort(){this.deferred.reject(this.signal?.reason??new Et)}cleanup(){this.signal?.removeEventListener("abort",this.onAbort)}};function yI(){return`${parseInt(String(Math.random()*1e9),10).toString()}${Date.now()}`}var ul=class{id;fn;options;recipients;status;timeline;controller;constructor(e,t){this.id=yI(),this.status="queued",this.fn=e,this.options=t,this.recipients=[],this.timeline={created:Date.now()},this.controller=new AbortController,this.controller.signal,this.onAbort=this.onAbort.bind(this)}abort(e){this.controller.abort(e)}onAbort(){this.recipients.reduce((t,n)=>t&&n.signal?.aborted===!0,!0)&&(this.controller.abort(new Et),this.cleanup())}async join(e={}){let t=new ll(e.signal);return this.recipients.push(t),e.signal?.addEventListener("abort",this.onAbort),t.deferred.promise}async run(){this.status="running",this.timeline.started=Date.now();try{this.controller.signal.throwIfAborted();let e=await vb(this.fn({...this.options??{},signal:this.controller.signal}),this.controller.signal);this.recipients.forEach(t=>{t.deferred.resolve(e)}),this.status="complete"}catch(e){this.recipients.forEach(t=>{t.deferred.reject(e)}),this.status="errored"}finally{this.timeline.finished=Date.now(),this.cleanup()}}cleanup(){this.recipients.forEach(e=>{e.cleanup(),e.signal?.removeEventListener("abort",this.onAbort)})}};function Rp(r,e){let t,n=function(){let o=function(){t=void 0,r()};clearTimeout(t),t=setTimeout(o,e)};return n.start=()=>{},n.stop=()=>{clearTimeout(t)},n}var Ui=class extends _e{concurrency;maxSize;queue;pending;sort;autoStart;constructor(e={}){super(),this.concurrency=e.concurrency??Number.POSITIVE_INFINITY,this.maxSize=e.maxSize??Number.POSITIVE_INFINITY,this.pending=0,this.autoStart=e.autoStart??!0,this.sort=e.sort,this.queue=[],this.emitEmpty=Rp(this.emitEmpty.bind(this),1),this.emitIdle=Rp(this.emitIdle.bind(this),1)}[Symbol.asyncIterator](){return this.toGenerator()}emitEmpty(){this.size===0&&this.safeDispatchEvent("empty")}emitIdle(){this.running===0&&this.safeDispatchEvent("idle")}tryToStartAnother(){if(this.size===0)return this.emitEmpty(),this.running===0&&this.emitIdle(),!1;if(this.pending<this.concurrency){let e;for(let t of this.queue)if(t.status==="queued"){e=t;break}return e==null?!1:(this.safeDispatchEvent("active"),this.pending++,e.run().finally(()=>{for(let t=0;t<this.queue.length;t++)if(this.queue[t]===e){this.queue.splice(t,1);break}this.pending--,this.safeDispatchEvent("next"),this.autoStart&&this.tryToStartAnother()}),!0)}return!1}enqueue(e){this.queue.push(e),this.sort!=null&&this.queue.sort(this.sort)}start(){this.autoStart===!1&&(this.autoStart=!0,this.tryToStartAnother())}pause(){this.autoStart=!1}async add(e,t){if(t?.signal?.throwIfAborted(),this.size===this.maxSize)throw new al;let n=new ul(e,t);return this.enqueue(n),this.safeDispatchEvent("add"),this.autoStart&&this.tryToStartAnother(),n.join(t).then(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("failure",{detail:{job:n,error:o}}),o})}clear(){this.queue.splice(0,this.queue.length)}abort(){this.queue.forEach(e=>{e.abort(new Et)}),this.clear()}async onEmpty(e){this.size!==0&&await Gc(this,"empty",e?.signal)}async onSizeLessThan(e,t){this.size<e||await Gc(this,"next",t?.signal,{filter:()=>this.size<e})}async onIdle(e){this.pending===0&&this.size===0||await Gc(this,"idle",e?.signal)}get size(){return this.queue.length}get queued(){return this.queue.length-this.pending}get running(){return this.pending}async*toGenerator(e){e?.signal?.throwIfAborted();let t=qo({objectMode:!0}),n=c=>{c!=null?this.abort():this.clear(),t.end(c)},o=c=>{c.detail!=null&&t.push(c.detail.result)},s=c=>{n(c.detail.error)},i=()=>{n()},a=()=>{n(new Et("Queue aborted"))};this.addEventListener("success",o),this.addEventListener("failure",s),this.addEventListener("idle",i),e?.signal?.addEventListener("abort",a);try{yield*t}finally{this.removeEventListener("success",o),this.removeEventListener("failure",s),this.removeEventListener("idle",i),e?.signal?.removeEventListener("abort",a),n()}}};var fl="lock:worker:request-read",dl="lock:worker:abort-read-request",hl="lock:worker:release-read",pl="lock:master:grant-read",ml="lock:master:error-read",gl="lock:worker:request-write",yl="lock:worker:abort-write-request",wl="lock:worker:release-write",bl="lock:master:grant-write",xl="lock:master:error-write",vl="lock:worker:finalize",El="mortice",Eb={singleProcess:!1};var Mp=(r,e,t,n,o,s,i,a,c)=>l=>{if(l.data==null)return;let f={type:l.data.type,name:l.data.name,identifier:l.data.identifier};f.type===o&&r.safeDispatchEvent(t,{detail:{name:f.name,identifier:f.identifier,handler:async()=>{e.postMessage({type:c,name:f.name,identifier:f.identifier}),await new Promise(u=>{let d=h=>{if(h?.data==null)return;let m={type:h.data.type,name:h.data.name,identifier:h.data.identifier};m.type===a&&m.identifier===f.identifier&&(e.removeEventListener("message",d),u())};e.addEventListener("message",d)})},onError:u=>{e.postMessage({type:i,name:f.name,identifier:f.identifier,error:{message:u.message,name:u.name,stack:u.stack}})}}}),f.type===s&&r.safeDispatchEvent(n,{detail:{name:f.name,identifier:f.identifier}}),f.type===vl&&r.safeDispatchEvent("finalizeRequest",{detail:{name:f.name}})};var Ab=(r=10)=>Math.random().toString().substring(2,r+2);var Al=class{name;channel;constructor(e){this.name=e,this.channel=new BroadcastChannel(El)}readLock(e){return this.sendRequest(fl,dl,pl,ml,hl,e)}writeLock(e){return this.sendRequest(gl,yl,bl,xl,wl,e)}finalize(){this.channel.postMessage({type:vl,name:this.name}),this.channel.close()}async sendRequest(e,t,n,o,s,i){i?.signal?.throwIfAborted();let a=Ab();return this.channel.postMessage({type:e,identifier:a,name:this.name}),new Promise((c,l)=>{let f=()=>{this.channel.postMessage({type:t,identifier:a,name:this.name})};i?.signal?.addEventListener("abort",f,{once:!0});let u=d=>{if(d.data?.identifier===a&&(d.data?.type===n&&(this.channel.removeEventListener("message",u),i?.signal?.removeEventListener("abort",f),c(()=>{this.channel.postMessage({type:s,identifier:a,name:this.name})})),d.data.type===o)){this.channel.removeEventListener("message",u),i?.signal?.removeEventListener("abort",f);let h=new Error;d.data.error!=null&&(h.message=d.data.error.message,h.name=d.data.error.name,h.stack=d.data.error.stack),l(h)}};this.channel.addEventListener("message",u)})}};var Sb=r=>{if(r=Object.assign({},Eb,r),!!globalThis.document||r.singleProcess){let t=new BroadcastChannel(El),n=new _e;return t.addEventListener("message",Mp(n,t,"requestReadLock","abortReadLockRequest",fl,dl,ml,hl,pl)),t.addEventListener("message",Mp(n,t,"requestWriteLock","abortWriteLockRequest",gl,yl,xl,wl,bl)),n}return new Al(r.name)};var eo=new Map,Fi;function Ib(r){return typeof r?.readLock=="function"&&typeof r?.writeLock=="function"}function wI(r){if(Fi==null&&(Fi=Sb(r),!Ib(Fi))){let e=Fi;e.addEventListener("requestReadLock",t=>{let n=t.detail.name,o=t.detail.identifier,s=eo.get(n);if(s==null)return;let i=new AbortController,a=c=>{c.detail.name!==n||c.detail.identifier!==o||i.abort()};e.addEventListener("abortReadLockRequest",a),s.readLock({signal:i.signal}).then(async c=>{await t.detail.handler().finally(()=>{c()})}).catch(c=>{t.detail.onError(c)}).finally(()=>{e.removeEventListener("abortReadLockRequest",a)})}),e.addEventListener("requestWriteLock",t=>{let n=t.detail.name,o=t.detail.identifier,s=eo.get(n);if(s==null)return;let i=new AbortController,a=c=>{c.detail.name!==n||c.detail.identifier!==o||i.abort()};e.addEventListener("abortWriteLockRequest",a),s.writeLock({signal:i.signal}).then(async c=>{await t.detail.handler().finally(()=>{c()})}).catch(c=>{t.detail.onError(c)}).finally(()=>{e.removeEventListener("abortWriteLockRequest",a)})}),e.addEventListener("finalizeRequest",t=>{let n=t.detail.name,o=eo.get(n);o?.finalize()})}return Fi}async function Op(r,e){let t,n,o=new Promise((i,a)=>{t=i,n=a}),s=()=>{n(new Et)};return e?.signal?.addEventListener("abort",s,{once:!0}),r.add(async()=>{await new Promise(i=>{t(()=>{e?.signal?.removeEventListener("abort",s),i()})})},{signal:e?.signal}).catch(i=>{n(i)}),o}var kb=(r,e)=>{let t=eo.get(r);if(t!=null)return t;let n=wI(e);if(Ib(n))return t=n,eo.set(r,t),t;let o=new Ui({concurrency:1}),s;return t={async readLock(i){if(s!=null)return Op(s,i);s=new Ui({concurrency:e.concurrency,autoStart:!1});let a=s,c=Op(s,i);return o.add(async()=>{a.start(),await a.onIdle().then(()=>{s===a&&(s=null)})}),c},async writeLock(i){return s=null,Op(o,i)},finalize:()=>{eo.delete(r)},queue:o},eo.set(r,t),e.autoFinalize===!0&&o.addEventListener("idle",()=>{t.finalize()},{once:!0}),t};var bI={name:"lock",concurrency:1/0,singleProcess:!1,autoFinalize:!1};function $i(r){let e=Object.assign({},bI,r);return kb(e.name,e)}var Sl=class{lock;child;pins;started;constructor(e,t,n={}){this.child=e,this.pins=t,this.lock=$i({singleProcess:n.holdGcLock}),this.started=!1}isStarted(){return this.started}async start(){await sr(this.child),this.started=!0}async stop(){await ir(this.child),this.started=!1}unwrap(){return this.child}async put(e,t,n={}){n?.signal?.throwIfAborted();let o=await this.lock.readLock();try{return await this.child.put(e,t,n)}finally{o()}}async*putMany(e,t={}){t?.signal?.throwIfAborted();let n=await this.lock.readLock();try{yield*this.child.putMany(e,t)}finally{n()}}async*get(e,t={}){t?.signal?.throwIfAborted();let n=await this.lock.readLock();try{yield*this.child.get(e,t)}finally{n()}}async*getMany(e,t={}){t?.signal?.throwIfAborted();let n=await this.lock.readLock();try{yield*this.child.getMany(e,t)}finally{n()}}async delete(e,t={}){t?.signal?.throwIfAborted();let n=await this.lock.writeLock();try{if(await this.pins.isPinned(e))throw new Ni("Block was pinned - please unpin and try again");await this.child.delete(e,t)}finally{n()}}async*deleteMany(e,t={}){t?.signal?.throwIfAborted();let n=await this.lock.writeLock();try{let o=this;yield*this.child.deleteMany((async function*(){for await(let s of e){if(await o.pins.isPinned(s))throw new Ni("Block was pinned - please unpin and try again");yield s}})(),t)}finally{n()}}async has(e,t={}){t?.signal?.throwIfAborted();let n=await this.lock.readLock();try{return await this.child.has(e,t)}finally{n()}}async*getAll(e={}){e?.signal?.throwIfAborted();let t=await this.lock.readLock();try{yield*this.child.getAll(e)}finally{t()}}createSession(e,t){return t?.signal?.throwIfAborted(),this.child.createSession(e,t)}};var Up=new ge("/version"),_b=1;async function Cb(r){if(!await r.has(Up)){await r.put(Up,B(`${_b}`));return}let e=await r.get(Up),t=U(e);if(parseInt(t,10)!==_b)throw new rl("Invalid datastore version, a datastore migration may be required")}var Vp={};Ae(Vp,{code:()=>$p,decode:()=>TI,decodeOptions:()=>kI,encode:()=>CI,encodeOptions:()=>SI,name:()=>_I,toByteView:()=>Bb});var Tb=42;function Bb(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}function xI(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let e=K.asCID(r);if(!e)return null;let t=new Uint8Array(e.bytes.byteLength+1);return t.set(e.bytes,1),[new I(p.tag,Tb),new I(p.bytes,t)]}function vI(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function EI(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}function AI(r){for(let e of r.keys())if(typeof e!="string"||e.length===0)throw new Error("Non-string Map keys are not supported by the IPLD Data Model and cannot be encoded");return null}var Fp={float64:!0,typeEncoders:{Map:AI,Object:xI,undefined:vI,number:EI}},SI={...Fp,typeEncoders:{...Fp.typeEncoders}};function II(r){if(r[0]!==0)throw new Error("Invalid CID for CBOR tag 42; expected leading 0x00");return K.decode(r.subarray(1))}var Il={allowIndefinite:!1,coerceUndefinedToNull:!0,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Il.tags[Tb]=II;var kI={...Il,tags:Il.tags.slice()},_I="dag-cbor",$p=113,CI=r=>un(r,Fp),TI=r=>vt(Bb(r),Il);var jp={};Ae(jp,{code:()=>Wp,decode:()=>Pb,encode:()=>Lb,format:()=>$I,name:()=>FI,parse:()=>KI,stringify:()=>$I});var Kp=class extends Array{constructor(){super(),this.inRecursive=[]}prefix(e){let t=this.inRecursive[this.inRecursive.length-1];t&&(t.type===p.array&&(t.elements++,t.elements!==1&&e.push([44])),t.type===p.map&&(t.elements++,t.elements!==1&&(t.elements%2===1?e.push([44]):e.push([58]))))}[p.uint.major](e,t){this.prefix(e);let n=String(t.value),o=[];for(let s=0;s<n.length;s++)o[s]=n.charCodeAt(s);e.push(o)}[p.negint.major](e,t){this[p.uint.major](e,t)}[p.bytes.major](e,t){throw new Error(`${Cr} unsupported type: Uint8Array`)}[p.string.major](e,t){this.prefix(e);let n=Ec(JSON.stringify(t.value));e.push(n.length>32?bi(n):n)}[p.array.major](e,t){this.prefix(e),this.inRecursive.push({type:p.array,elements:0}),e.push([91])}[p.map.major](e,t){this.prefix(e),this.inRecursive.push({type:p.map,elements:0}),e.push([123])}[p.tag.major](e,t){}[p.float.major](e,t){if(t.type.name==="break"){let i=this.inRecursive.pop();if(i){if(i.type===p.array)e.push([93]);else if(i.type===p.map)e.push([125]);else throw new Error("Unexpected recursive type; this should not happen!");return}throw new Error("Unexpected break; this should not happen!")}if(t.value===void 0)throw new Error(`${Cr} unsupported type: undefined`);if(this.prefix(e),t.type.name==="true"){e.push([116,114,117,101]);return}else if(t.type.name==="false"){e.push([102,97,108,115,101]);return}else if(t.type.name==="null"){e.push([110,117,108,108]);return}let n=String(t.value),o=[],s=!1;for(let i=0;i<n.length;i++)o[i]=n.charCodeAt(i),!s&&(o[i]===46||o[i]===101||o[i]===69)&&(s=!0);s||(o.push(46),o.push(48)),e.push(o)}};function BI(r,e){if(Array.isArray(r[0])||Array.isArray(e[0]))throw new Error(`${Cr} complex map keys are not supported`);let t=r[0],n=e[0];if(t.type!==p.string||n.type!==p.string)throw new Error(`${Cr} non-string map keys are not supported`);if(t<n)return-1;if(t>n)return 1;throw new Error(`${Cr} unexpected duplicate map keys, this is not supported`)}var LI={addBreakTokens:!0,mapSorter:BI};function Hp(r,e){return e=Object.assign({},LI,e),ap(r,new Kp,e)}var as=class{constructor(e,t={}){this._pos=0,this.data=e,this.options=t,this.modeStack=["value"],this.lastToken=""}pos(){return this._pos}done(){return this._pos>=this.data.length}ch(){return this.data[this._pos]}currentMode(){return this.modeStack[this.modeStack.length-1]}skipWhitespace(){let e=this.ch();for(;e===32||e===9||e===13||e===10;)e=this.data[++this._pos]}expect(e){if(this.data.length-this._pos<e.length)throw new Error(`${F} unexpected end of input at position ${this._pos}`);for(let t=0;t<e.length;t++)if(this.data[this._pos++]!==e[t])throw new Error(`${F} unexpected token at position ${this._pos}, expected to find '${String.fromCharCode(...e)}'`)}parseNumber(){let e=this._pos,t=!1,n=!1,o=a=>{for(;!this.done();){let c=this.ch();if(a.includes(c))this._pos++;else break}};if(this.ch()===45&&(t=!0,this._pos++),this.ch()===48)if(this._pos++,this.ch()===46)this._pos++,n=!0;else return new I(p.uint,0,this._pos-e);if(o([48,49,50,51,52,53,54,55,56,57]),t&&this._pos===e+1)throw new Error(`${F} unexpected token at position ${this._pos}`);if(!this.done()&&this.ch()===46){if(n)throw new Error(`${F} unexpected token at position ${this._pos}`);n=!0,this._pos++,o([48,49,50,51,52,53,54,55,56,57])}!this.done()&&(this.ch()===101||this.ch()===69)&&(n=!0,this._pos++,!this.done()&&(this.ch()===43||this.ch()===45)&&this._pos++,o([48,49,50,51,52,53,54,55,56,57]));let s=String.fromCharCode.apply(null,this.data.subarray(e,this._pos)),i=parseFloat(s);return n?new I(p.float,i,this._pos-e):this.options.allowBigInt!==!0||Number.isSafeInteger(i)?new I(i>=0?p.uint:p.negint,i,this._pos-e):new I(i>=0?p.uint:p.negint,BigInt(s),this._pos-e)}parseString(){if(this.ch()!==34)throw new Error(`${F} unexpected character at position ${this._pos}; this shouldn't happen`);this._pos++;for(let s=this._pos,i=0;s<this.data.length&&i<65536;s++,i++){let a=this.data[s];if(a===92||a<32||a>=128)break;if(a===34){let c=String.fromCharCode.apply(null,this.data.subarray(this._pos,s));return this._pos=s+1,new I(p.string,c,i)}}let e=this._pos,t=[],n=()=>{if(this._pos+4>=this.data.length)throw new Error(`${F} unexpected end of unicode escape sequence at position ${this._pos}`);let s=0;for(let i=0;i<4;i++){let a=this.ch();if(a>=48&&a<=57)a-=48;else if(a>=97&&a<=102)a=a-97+10;else if(a>=65&&a<=70)a=a-65+10;else throw new Error(`${F} unexpected unicode escape character at position ${this._pos}`);s=s*16+a,this._pos++}return s},o=()=>{let s=this.ch(),i=null,a=s>239?4:s>223?3:s>191?2:1;if(this._pos+a>this.data.length)throw new Error(`${F} unexpected unicode sequence at position ${this._pos}`);let c,l,f,u;switch(a){case 1:s<128&&(i=s);break;case 2:c=this.data[this._pos+1],(c&192)===128&&(u=(s&31)<<6|c&63,u>127&&(i=u));break;case 3:c=this.data[this._pos+1],l=this.data[this._pos+2],(c&192)===128&&(l&192)===128&&(u=(s&15)<<12|(c&63)<<6|l&63,u>2047&&(u<55296||u>57343)&&(i=u));break;case 4:c=this.data[this._pos+1],l=this.data[this._pos+2],f=this.data[this._pos+3],(c&192)===128&&(l&192)===128&&(f&192)===128&&(u=(s&15)<<18|(c&63)<<12|(l&63)<<6|f&63,u>65535&&u<1114112&&(i=u))}i===null?(i=65533,a=1):i>65535&&(i-=65536,t.push(i>>>10&1023|55296),i=56320|i&1023),t.push(i),this._pos+=a};for(;!this.done();){let s=this.ch(),i;switch(s){case 92:if(this._pos++,this.done())throw new Error(`${F} unexpected string termination at position ${this._pos}`);switch(i=this.ch(),this._pos++,i){case 34:case 39:case 92:case 47:t.push(i);break;case 98:t.push(8);break;case 116:t.push(9);break;case 110:t.push(10);break;case 102:t.push(12);break;case 114:t.push(13);break;case 117:t.push(n());break;default:throw new Error(`${F} unexpected string escape character at position ${this._pos}`)}break;case 34:return this._pos++,new I(p.string,tp(t),this._pos-e);default:if(s<32)throw new Error(`${F} invalid control character at position ${this._pos}`);s<128?(t.push(s),this._pos++):o()}}throw new Error(`${F} unexpected end of string at position ${this._pos}`)}parseValue(){switch(this.ch()){case 123:return this.modeStack.push("obj-start"),this._pos++,new I(p.map,1/0,1);case 91:return this.modeStack.push("array-start"),this._pos++,new I(p.array,1/0,1);case 34:return this.parseString();case 110:return this.expect([110,117,108,108]),new I(p.null,null,4);case 102:return this.expect([102,97,108,115,101]),new I(p.false,!1,5);case 116:return this.expect([116,114,117,101]),new I(p.true,!0,4);case 45:case 48:case 49:case 50:case 51:case 52:case 53:case 54:case 55:case 56:case 57:return this.parseNumber();default:throw new Error(`${F} unexpected character at position ${this._pos}`)}}next(){switch(this.skipWhitespace(),this.currentMode()){case"value":return this.modeStack.pop(),this.parseValue();case"array-value":{if(this.modeStack.pop(),this.ch()===93)return this._pos++,this.skipWhitespace(),new I(p.break,void 0,1);if(this.ch()!==44)throw new Error(`${F} unexpected character at position ${this._pos}, was expecting array delimiter but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("array-value"),this.skipWhitespace(),this.parseValue()}case"array-start":return this.modeStack.pop(),this.ch()===93?(this._pos++,this.skipWhitespace(),new I(p.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 I(p.break,void 0,1);if(this.ch()!==44)throw new Error(`${F} unexpected character at position ${this._pos}, was expecting object delimiter but found '${String.fromCharCode(this.ch())}'`);this._pos++,this.skipWhitespace();case"obj-start":{if(this.modeStack.pop(),this.ch()===125)return this._pos++,this.skipWhitespace(),new I(p.break,void 0,1);let e=this.parseString();if(this.skipWhitespace(),this.ch()!==58)throw new Error(`${F} unexpected character at position ${this._pos}, was expecting key/value delimiter ':' but found '${String.fromCharCode(this.ch())}'`);return this._pos++,this.modeStack.push("obj-value"),e}case"obj-value":return this.modeStack.pop(),this.modeStack.push("obj-key"),this.skipWhitespace(),this.parseValue();default:throw new Error(`${F} unexpected parse state at position ${this._pos}; this shouldn't happen`)}}};function qp(r,e){return e=Object.assign({tokenizer:new as(r,e)},e),vt(r,e)}function DI(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}function NI(r){if(r.asCID!==r&&r["/"]!==r.bytes)return null;let e=K.asCID(r);if(!e)return null;let t=e.toString();return[new I(p.map,1/0,1),new I(p.string,"/",1),new I(p.string,t,t.length),new I(p.break,void 0,1)]}function kl(r){let e=Ye.encode(r).slice(1);return[new I(p.map,1/0,1),new I(p.string,"/",1),new I(p.map,1/0,1),new I(p.string,"bytes",5),new I(p.string,e,e.length),new I(p.break,void 0,1),new I(p.break,void 0,1)]}function Yt(r){return kl(new Uint8Array(r.buffer,r.byteOffset,r.byteLength))}function RI(r){return kl(new Uint8Array(r))}function MI(){throw new Error("`undefined` is not supported by the IPLD Data Model and cannot be encoded")}function OI(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 UI={typeEncoders:{Object:NI,Buffer:kl,Uint8Array:kl,Int8Array:Yt,Uint16Array:Yt,Int16Array:Yt,Uint32Array:Yt,Int32Array:Yt,Float32Array:Yt,Float64Array:Yt,Uint8ClampedArray:Yt,BigInt64Array:Yt,BigUint64Array:Yt,DataView:Yt,ArrayBuffer:RI,undefined:MI,number:OI}},zp=class extends as{constructor(e,t){super(e,t),this.tokenBuffer=[]}done(){return this.tokenBuffer.length===0&&super.done()}_next(){return this.tokenBuffer.length>0?this.tokenBuffer.pop():super.next()}next(){let e=this._next();if(e.type===p.map){let t=this._next();if(t.type===p.string&&t.value==="/"){let n=this._next();if(n.type===p.string){if(this._next().type!==p.break)throw new Error("Invalid encoded CID form");return this.tokenBuffer.push(n),new I(p.tag,42,0)}if(n.type===p.map){let o=this._next();if(o.type===p.string&&o.value==="bytes"){let s=this._next();if(s.type===p.string){for(let a=0;a<2;a++)if(this._next().type!==p.break)throw new Error("Invalid encoded Bytes form");let i=Ye.decode(`m${s.value}`);return new I(p.bytes,i,s.value.length)}this.tokenBuffer.push(s)}this.tokenBuffer.push(o)}this.tokenBuffer.push(n)}this.tokenBuffer.push(t)}return e}},Gp={allowIndefinite:!1,allowUndefined:!1,allowNaN:!1,allowInfinity:!1,allowBigInt:!0,strict:!0,useMaps:!1,rejectDuplicateMapKeys:!0,tags:[]};Gp.tags[42]=K.parse;var FI="dag-json",Wp=297,Lb=r=>Hp(r,UI),Pb=r=>{let e=DI(r),t=Object.assign(Gp,{tokenizer:new zp(e,Gp)});return qp(e,t)},$I=r=>VI.decode(Lb(r));var VI=new TextDecoder,KI=r=>Pb(HI.encode(r)),HI=new TextEncoder;var em={};Ae(em,{code:()=>Qp,createLink:()=>Kb,createNode:()=>Vb,decode:()=>rk,encode:()=>tk,name:()=>ek,prepare:()=>Xp,validate:()=>Jp});var qI=new TextDecoder;function Yp(r,e){let t=0;for(let n=0;;n+=7){if(n>=64)throw new Error("protobuf: varint overflow");if(e>=r.length)throw new Error("protobuf: unexpected end of data");let o=r[e++];if(t+=n<28?(o&127)<<n:(o&127)*2**n,o<128)break}return[t,e]}function _l(r,e){let t;[t,e]=Yp(r,e);let n=e+t;if(t<0||n<0)throw new Error("protobuf: invalid length");if(n>r.length)throw new Error("protobuf: unexpected end of data");return[r.subarray(e,n),n]}function Db(r,e){let t;return[t,e]=Yp(r,e),[t&7,t>>3,e]}function zI(r){let e={},t=r.length,n=0;for(;n<t;){let o,s;if([o,s,n]=Db(r,n),s===1){if(e.Hash)throw new Error("protobuf: (PBLink) duplicate Hash section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Hash`);if(e.Name!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Name before Hash");if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Hash");[e.Hash,n]=_l(r,n)}else if(s===2){if(e.Name!==void 0)throw new Error("protobuf: (PBLink) duplicate Name section");if(o!==2)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Name`);if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) invalid order, found Tsize before Name");let i;[i,n]=_l(r,n),e.Name=qI.decode(i)}else if(s===3){if(e.Tsize!==void 0)throw new Error("protobuf: (PBLink) duplicate Tsize section");if(o!==0)throw new Error(`protobuf: (PBLink) wrong wireType (${o}) for Tsize`);[e.Tsize,n]=Yp(r,n)}else throw new Error(`protobuf: (PBLink) invalid fieldNumber, expected 1, 2 or 3, got ${s}`)}if(n>t)throw new Error("protobuf: (PBLink) unexpected end of data");return e}function Nb(r){let e=r.length,t=0,n,o=!1,s;for(;t<e;){let a,c;if([a,c,t]=Db(r,t),a!==2)throw new Error(`protobuf: (PBNode) invalid wireType, expected 2, got ${a}`);if(c===1){if(s)throw new Error("protobuf: (PBNode) duplicate Data section");[s,t]=_l(r,t),n&&(o=!0)}else if(c===2){if(o)throw new Error("protobuf: (PBNode) duplicate Links section");n||(n=[]);let l;[l,t]=_l(r,t),n.push(zI(l))}else throw new Error(`protobuf: (PBNode) invalid fieldNumber, expected 1 or 2, got ${c}`)}if(t>e)throw new Error("protobuf: (PBNode) unexpected end of data");let i={};return s&&(i.Data=s),i.Links=n||[],i}var Mb=new TextEncoder,Rb=2**32,GI=2**31;function WI(r,e){let t=e.length;if(typeof r.Tsize=="number"){if(r.Tsize<0)throw new Error("Tsize cannot be negative");if(!Number.isSafeInteger(r.Tsize))throw new Error("Tsize too large for encoding");t=Vi(e,t,r.Tsize)-1,e[t]=24}if(typeof r.Name=="string"){let n=Mb.encode(r.Name);t-=n.length,e.set(n,t),t=Vi(e,t,n.length)-1,e[t]=18}return r.Hash&&(t-=r.Hash.length,e.set(r.Hash,t),t=Vi(e,t,r.Hash.length)-1,e[t]=10),e.length-t}function Ob(r){let e=YI(r),t=new Uint8Array(e),n=e;if(r.Data&&(n-=r.Data.length,t.set(r.Data,n),n=Vi(t,n,r.Data.length)-1,t[n]=10),r.Links)for(let o=r.Links.length-1;o>=0;o--){let s=WI(r.Links[o],t.subarray(0,n));n-=s,n=Vi(t,n,s)-1,t[n]=18}return t}function jI(r){let e=0;if(r.Hash){let t=r.Hash.length;e+=1+t+cs(t)}if(typeof r.Name=="string"){let t=Mb.encode(r.Name).length;e+=1+t+cs(t)}return typeof r.Tsize=="number"&&(e+=1+cs(r.Tsize)),e}function YI(r){let e=0;if(r.Data){let t=r.Data.length;e+=1+t+cs(t)}if(r.Links)for(let t of r.Links){let n=jI(t);e+=1+n+cs(n)}return e}function Vi(r,e,t){e-=cs(t);let n=e;for(;t>=GI;)r[e++]=t&127|128,t/=128;for(;t>=128;)r[e++]=t&127|128,t>>>=7;return r[e]=t,n}function cs(r){return r%2===0&&r++,Math.floor((ZI(r)+6)/7)}function ZI(r){let e=0;return r>=Rb&&(r=Math.floor(r/Rb),e=32),r>=65536&&(r>>>=16,e+=16),r>=256&&(r>>>=8,e+=8),e+XI[r]}var XI=[0,1,2,2,3,3,3,3,4,4,4,4,4,4,4,4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8];var JI=["Data","Links"],QI=["Hash","Name","Tsize"],Zp=new TextEncoder;function Fb(r,e){if(r===e)return 0;let t=r.Name?Zp.encode(r.Name):[],n=e.Name?Zp.encode(e.Name):[],o=t.length,s=n.length;for(let i=0,a=Math.min(o,s);i<a;++i)if(t[i]!==n[i]){o=t[i],s=n[i];break}return o<s?-1:s<o?1:0}function Ub(r,e){return!Object.keys(r).some(t=>!e.includes(t))}function $b(r){if(typeof r.asCID=="object"){let t=K.asCID(r);if(!t)throw new TypeError("Invalid DAG-PB form");return{Hash:t}}if(typeof r!="object"||Array.isArray(r))throw new TypeError("Invalid DAG-PB form");let e={};if(r.Hash){let t=K.asCID(r.Hash);try{t||(typeof r.Hash=="string"?t=K.parse(r.Hash):r.Hash instanceof Uint8Array&&(t=K.decode(r.Hash)))}catch(n){throw new TypeError(`Invalid DAG-PB form: ${n.message}`)}t&&(e.Hash=t)}if(!e.Hash)throw new TypeError("Invalid DAG-PB form");return typeof r.Name=="string"&&(e.Name=r.Name),typeof r.Tsize=="number"&&(e.Tsize=r.Tsize),e}function Xp(r){if((r instanceof Uint8Array||typeof r=="string")&&(r={Data:r}),typeof r!="object"||Array.isArray(r))throw new TypeError("Invalid DAG-PB form");let e={};if(r.Data!==void 0)if(typeof r.Data=="string")e.Data=Zp.encode(r.Data);else if(r.Data instanceof Uint8Array)e.Data=r.Data;else throw new TypeError("Invalid DAG-PB form");if(r.Links!==void 0)if(Array.isArray(r.Links))e.Links=r.Links.map($b),e.Links.sort(Fb);else throw new TypeError("Invalid DAG-PB form");else e.Links=[];return e}function Jp(r){if(!r||typeof r!="object"||Array.isArray(r)||r instanceof Uint8Array||r["/"]&&r["/"]===r.bytes)throw new TypeError("Invalid DAG-PB form");if(!Ub(r,JI))throw new TypeError("Invalid DAG-PB form (extraneous properties)");if(r.Data!==void 0&&!(r.Data instanceof Uint8Array))throw new TypeError("Invalid DAG-PB form (Data must be bytes)");if(!Array.isArray(r.Links))throw new TypeError("Invalid DAG-PB form (Links must be a list)");for(let e=0;e<r.Links.length;e++){let t=r.Links[e];if(!t||typeof t!="object"||Array.isArray(t)||t instanceof Uint8Array||t["/"]&&t["/"]===t.bytes)throw new TypeError("Invalid DAG-PB form (bad link)");if(!Ub(t,QI))throw new TypeError("Invalid DAG-PB form (extraneous properties on link)");if(t.Hash===void 0)throw new TypeError("Invalid DAG-PB form (link must have a Hash)");if(t.Hash==null||!t.Hash["/"]||t.Hash["/"]!==t.Hash.bytes)throw new TypeError("Invalid DAG-PB form (link Hash must be a CID)");if(t.Name!==void 0&&typeof t.Name!="string")throw new TypeError("Invalid DAG-PB form (link Name must be a string)");if(t.Tsize!==void 0){if(typeof t.Tsize!="number"||t.Tsize%1!==0)throw new TypeError("Invalid DAG-PB form (link Tsize must be an integer)");if(t.Tsize<0)throw new TypeError("Invalid DAG-PB form (link Tsize cannot be negative)")}if(e>0&&Fb(t,r.Links[e-1])===-1)throw new TypeError("Invalid DAG-PB form (links must be sorted by Name bytes)")}}function Vb(r,e=[]){return Xp({Data:r,Links:e})}function Kb(r,e,t){return $b({Hash:t,Name:r,Tsize:e})}function Hb(r){return r instanceof ArrayBuffer?new Uint8Array(r,0,r.byteLength):r}var ek="dag-pb",Qp=112;function tk(r){Jp(r);let e={};return r.Links&&(e.Links=r.Links.map(t=>{let n={};return t.Hash&&(n.Hash=t.Hash.bytes),t.Name!==void 0&&(n.Name=t.Name),t.Tsize!==void 0&&(n.Tsize=t.Tsize),n})),r.Data&&(e.Data=r.Data),Ob(e)}function rk(r){let e=Hb(r),t=Nb(e),n={};return t.Data&&(n.Data=t.Data),t.Links&&(n.Links=t.Links.map(o=>{let s={};try{s.Hash=K.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}function ls(r){return r?.then!=null}function qb(r=[],e){let t={[Qp]:em,[Ds]:Ns,[$p]:Vp,[Wp]:jp,[cd]:Pa};return r.forEach(n=>{t[n.code]=n}),async n=>{let o=t[n];if(o==null&&e!=null){let s=e(n);ls(s)?o=await s:o=s,t[o.code]=o}if(o!=null)return o;throw new Oi(`Could not load codec for ${n}`)}}function zb(r=[],e){let t={[Mt.code]:Mt,[Da.code]:Da,[We.code]:We};return r.forEach(n=>{t[n.code]=n}),async n=>{let o=t[n];if(o==null&&e!=null){let s=e(n);ls(s)?o=await s:o=s,t[o.code]=o}if(o!=null)return o;throw new Mi(`No hasher configured for multihash code 0x${n.toString(16)}, please configure one. You can look up which hash this is at https://github.com/multiformats/multicodec/blob/master/table.csv`)}}var Pt=class r extends Error{static name="NotFoundError";static code="ERR_NOT_FOUND";name=r.name;code=r.code;constructor(e="Not Found"){super(e)}};var Lr=class{has(e,t){return Promise.reject(new Error(".has is not implemented"))}put(e,t,n){return Promise.reject(new Error(".put is not implemented"))}async*putMany(e,t){for await(let{cid:n,bytes:o}of e)await this.put(n,o,t),yield n}get(e,t){throw new Error(".get is not implemented")}async*getMany(e,t){for await(let n of e)yield{cid:n,bytes:this.get(n,t)}}delete(e,t){return Promise.reject(new Error(".delete is not implemented"))}async*deleteMany(e,t){for await(let n of e)await this.delete(n,t),yield n}async*getAll(e){throw new Error(".getAll is not implemented")}};var Cl=0,us=class extends Error{static name="IdentityHashDigestTooLongError";name="IdentityHashDigestTooLongError"},Tl=class extends Lr{child;maxDigestLength;constructor(e,t){super(),this.child=e,this.maxDigestLength=t?.maxDigestLength}put(e,t,n){if(e.multihash.code===Cl){if(this.maxDigestLength!=null&&e.multihash.digest.byteLength>this.maxDigestLength)throw new us(`Identity digest too long - ${e.multihash.digest.byteLength} > this.maxDigestLength`);return n?.signal?.throwIfAborted(),e}return this.child==null?(n?.signal?.throwIfAborted(),e):this.child.put(e,t,n)}*get(e,t){if(e.multihash.code===Cl){if(this.maxDigestLength!=null&&e.multihash.digest.byteLength>this.maxDigestLength)throw new us(`Identity digest too long - ${e.multihash.digest.byteLength} > this.maxDigestLength`);t?.signal?.throwIfAborted(),yield e.multihash.digest;return}if(this.child==null)throw t?.signal?.throwIfAborted(),new Pt;yield*this.child.get(e,t)}has(e,t){if(e.multihash.code===Cl){if(this.maxDigestLength!=null&&e.multihash.digest.byteLength>this.maxDigestLength)throw new us(`Identity digest too long - ${e.multihash.digest.byteLength} > this.maxDigestLength`);return t?.signal?.throwIfAborted(),!0}return this.child==null?(t?.signal?.throwIfAborted(),!1):this.child.has(e,t)}delete(e,t){if(e.code===Cl){if(this.maxDigestLength!=null&&e.multihash.digest.byteLength>this.maxDigestLength)throw new us(`Identity digest too long - ${e.multihash.digest.byteLength} > this.maxDigestLength`);t?.signal?.throwIfAborted();return}if(this.child!=null)return this.child.delete(e,t)}*getAll(e){this.child!=null&&(yield*this.child.getAll(e)),e?.signal?.throwIfAborted()}};function nk(r){return r[Symbol.asyncIterator]!=null}function ok(r,e){let t=0;if(nk(r))return(async function*(){for await(let c of r)await e(c,t++)&&(yield c)})();let n=ss(r),{value:o,done:s}=n.next();if(s===!0)return(function*(){})();let i=e(o,t++);if(typeof i.then=="function")return(async function*(){await i&&(yield o);for(let c of n)await e(c,t++)&&(yield c)})();let a=e;return(function*(){i===!0&&(yield o);for(let c of n)a(c,t++)&&(yield c)})()}var Zt=ok;function sk(r){return r[Symbol.asyncIterator]!=null}function Gb(r){return r?.then!=null}function ik(r,e){let t=0;if(sk(r))return(async function*(){for await(let c of r){let l=e(c,t++);Gb(l)&&await l,yield c}})();let n=ss(r),{value:o,done:s}=n.next();if(s===!0)return(function*(){})();if(typeof e(o,t++)?.then=="function")return(async function*(){yield o;for(let c of n){let l=e(c,t++);Gb(l)&&await l,yield c}})();let a=e;return(function*(){yield o;for(let c of n)a(c,t++),yield c})()}var tm=ik;var ak=128,Bl=class{child;getHasher;log;logger;components;constructor(e,t={}){this.log=e.logger.forComponent("helia:networked-storage"),this.logger=e.logger,this.components=e,this.child=new Tl(e.blockstore,{maxDigestLength:t.maxIdentityHashDigestLength??ak}),this.getHasher=e.getHasher}async put(e,t,n={}){return await this.child.has(e,n)?(n.onProgress?.(new Y("blocks:put:duplicate",e)),e):(n.onProgress?.(new Y("blocks:put:providers:notify",e)),await Promise.all(this.components.blockBrokers.map(async o=>o.announce?.(e,n))),n.onProgress?.(new Y("blocks:put:blockstore:put",e)),this.child.put(e,t,n))}async*putMany(e,t={}){let n=Zt(e,async({cid:s})=>{let i=await this.child.has(s,t);return i&&t.onProgress?.(new Y("blocks:put-many:duplicate",s)),!i}),o=tm(n,async({cid:s})=>{t.onProgress?.(new Y("blocks:put-many:providers:notify",s)),await Promise.all(this.components.blockBrokers.map(async i=>i.announce?.(s,t)))});t.onProgress?.(new Y("blocks:put-many:blockstore:put-many")),yield*this.child.putMany(o,t)}async*get(e,t={}){if(t.offline!==!0&&!await this.child.has(e,t)){let n=await this.getHasher(e.multihash.code);t.onProgress?.(new Y("blocks:get:providers:get",e));let o=await Wb(e,this.components.blockBrokers,n,{...t,log:this.log});t.onProgress?.(new Y("blocks:get:blockstore:put",e)),await this.child.put(e,o,t),t.onProgress?.(new Y("blocks:get:providers:notify",e)),await Promise.all(this.components.blockBrokers.map(async s=>s.announce?.(e,t))),yield o;return}t.onProgress?.(new Y("blocks:get:blockstore:get",e)),yield*this.child.get(e,t)}async*getMany(e,t={}){t.onProgress?.(new Y("blocks:get-many:blockstore:get-many")),yield*this.child.getMany(tm(e,async n=>{if(t.offline!==!0&&!await this.child.has(n,t)){let o=await this.getHasher(n.multihash.code);t.onProgress?.(new Y("blocks:get-many:providers:get",n));let s=await Wb(n,this.components.blockBrokers,o,{...t,log:this.log});t.onProgress?.(new Y("blocks:get-many:blockstore:put",n)),await this.child.put(n,s,t),t.onProgress?.(new Y("blocks:get-many:providers:notify",n)),await Promise.all(this.components.blockBrokers.map(async i=>i.announce?.(n,t)))}}))}async delete(e,t={}){t.onProgress?.(new Y("blocks:delete:blockstore:delete",e)),await this.child.delete(e,t)}async*deleteMany(e,t={}){t.onProgress?.(new Y("blocks:delete-many:blockstore:delete-many")),yield*this.child.deleteMany((async function*(){for await(let n of e)yield n})(),t)}async has(e,t={}){return this.child.has(e,t)}async*getAll(e={}){e.onProgress?.(new Y("blocks:get-all:blockstore:get-many")),yield*this.child.getAll(e)}},Ll=class extends Bl{started;constructor(e,t={}){super(e,t),this.started=!1}isStarted(){return this.started}async start(){await sr(this.child,...this.components.blockBrokers),this.started=!0}async stop(){await ir(this.child,...this.components.blockBrokers),this.started=!1}unwrap(){return this.child}createSession(e,t){let n=this.components.blockBrokers.map(o=>o.createSession==null?o:o.createSession(t));return new rm({blockstore:this.child,blockBrokers:n,getHasher:this.getHasher,logger:this.logger},{root:e})}},rm=class extends Bl{closeController;constructor(e,t){super(e),this.closeController=new AbortController,this.closeController.signal,this.log=e.logger.forComponent(`helia:session-storage:${t.root}`)}close(){this.closeController.abort()}async put(e,t,n={}){let o=pe([this.closeController.signal,n.signal]);try{return await super.put(e,t,{...n,signal:o})}finally{o.clear()}}async*putMany(e,t={}){let n=pe([this.closeController.signal,t.signal]);try{yield*super.putMany(e,{...t,signal:n})}finally{n.clear()}}async*get(e,t={}){let n=pe([this.closeController.signal,t.signal]);try{yield*super.get(e,{...t,signal:n})}finally{n.clear()}}async*getMany(e,t={}){let n=pe([this.closeController.signal,t.signal]);try{yield*super.getMany(e,{...t,signal:n})}finally{n.clear()}}async delete(e,t={}){let n=pe([this.closeController.signal,t.signal]);try{await super.delete(e,{...t,signal:n})}finally{n.clear()}}async*deleteMany(e,t={}){let n=pe([this.closeController.signal,t.signal]);try{yield*super.deleteMany(e,{...t,signal:n})}finally{n.clear()}}async has(e,t={}){let n=pe([this.closeController.signal,t.signal]);try{return await super.has(e,{...t,signal:n})}finally{n.clear()}}async*getAll(e={}){let t=pe([this.closeController.signal,e.signal]);try{yield*super.getAll({...e,signal:t})}finally{t.clear()}}};function ck(r){return typeof r.retrieve=="function"}var lk=(r,e)=>{if(e==null)throw new k(`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`);return async t=>{let n,o=e.digest(t);if(ls(o)?n=await o:n=o,!X(n.digest,r.multihash.digest))throw new Hr("Hash of downloaded block did not match multihash from passed CID")}};async function Wb(r,e,t,n){let o=lk(r,t),s=new AbortController,i=pe([s.signal,n.signal]);s.signal;let a=[];for(let c of e)ck(c)&&a.push(c);if(a.length===0)throw new nl(`No block brokers capable of retrieving blocks are configured, the CID ${r} cannot be fetched from the network`);try{return await Promise.any(a.map(async c=>{try{let l=!1,f=await c.retrieve(r,{...n,signal:i,validateFn:async u=>{await o(u),n.signal?.throwIfAborted(),l=!0}});return l||(await o(f),n.signal?.throwIfAborted()),f}catch(l){throw n.log.error("could not retrieve verified block for %c - %e",r,l),l}}))}finally{s.abort(),i.clear()}}var Hi=class extends _e{initialPeerSearchComplete;requests;name;log;logger;minProviders;maxProviders;providers;evictionFilter;initialProviders;constructor(e,t){super(),this.name=t.name,this.logger=e.logger,this.log=e.logger.forComponent(this.name),this.requests=new Map,this.minProviders=t.minProviders??1,this.maxProviders=t.maxProviders??5,this.providers=[],this.evictionFilter=$n(this.maxProviders),this.initialProviders=t.providers??[]}async retrieve(e,t={}){let n=Ye.encode(e.multihash.bytes),o=this.requests.get(n);if(o!=null)return this.log("join existing request for %c",e),o;let s=ae();if(this.requests.set(n,s.promise),this.providers.length===0){let f=!1;this.initialPeerSearchComplete==null&&(f=!0,this.log=this.logger.forComponent(`${this.name}:${e}`),this.initialPeerSearchComplete=this.findProviders(e,this.minProviders,t)),await kt(this.initialPeerSearchComplete,t.signal),f&&this.log("found initial session peers for %c",e)}let i=!1,a=new Gt({concurrency:this.maxProviders});a.addEventListener("failure",f=>{this.log.error("error querying provider %o, evicting from session",f.detail.job.options.provider,f.detail.error),this.evict(f.detail.job.options.provider)}),a.addEventListener("success",f=>{i=!0,s.resolve(f.detail.result)}),a.addEventListener("idle",()=>{if(i){this.log.trace("session idle, found block");return}if(t.signal?.aborted===!0){this.log.trace("session idle, signal aborted");return}Promise.resolve().then(async()=>{this.log("no session peers had block for for %c, finding new providers",e);for(let f=0;f<this.minProviders&&this.providers.length!==0;f++){let u=this.providers[Math.floor(Math.random()*this.providers.length)];this.evict(u)}await this.findProviders(e,this.minProviders,t),this.log("found new providers re-retrieving %c",e),this.requests.delete(n),s.resolve(await this.retrieve(e,t))}).catch(f=>{this.log.error("could not find new providers for %c - %e",e,f),s.reject(f)})});let c=f=>{a.add(async()=>this.queryProvider(e,f.detail,t),{provider:f.detail}).catch(u=>{t.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c - %e",e,u)})};this.addEventListener("provider",c),Promise.all([...this.providers].map(async f=>a.add(async()=>this.queryProvider(e,f,t),{provider:f}))).catch(f=>{t.signal?.aborted!==!0&&this.log.error("error retrieving session block for %c - %e",e,f)});let l=()=>{s.reject(new ht(t.signal?.reason??"Session aborted")),a.abort()};t.signal?.addEventListener("abort",l);try{return await kt(s.promise,t.signal)}finally{this.removeEventListener("provider",c),t.signal?.removeEventListener("abort",l),a.clear(),this.requests.delete(n)}}evict(e){this.evictionFilter.add(this.toEvictionKey(e));let t=this.providers.findIndex(n=>this.equals(n,e));t!==-1&&this.providers.splice(t,1)}isEvicted(e){return this.evictionFilter.has(this.toEvictionKey(e))}hasProvider(e){return!!(this.providers.find(t=>this.equals(t,e))!=null||this.isEvicted(e))}async findProviders(e,t,n){let o=ae(),s=0;return Promise.resolve().then(async()=>{if(this.log("finding %d-%d new provider(s) for %c",t,this.maxProviders,e),this.initialProviders.length>0)for(;s<t&&this.initialProviders.length>0;){let i=this.initialProviders.pop();if(i==null)break;let a=await this.convertToProvider(i,n);if(n.signal?.aborted===!0)break;if(a!=null&&!this.hasProvider(a)&&(this.log("found %d/%d new providers",s,this.maxProviders),this.providers.push(a),this.safeDispatchEvent("provider",{detail:a}),s++,s===t&&(this.log("session is ready"),o.resolve()),this.providers.length===this.maxProviders)){this.log("found max session peers",s);break}}if(s<this.maxProviders)for await(let i of this.findNewProviders(e,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===t&&(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<t)throw new Ri(`Found ${s} of ${t} ${this.name} providers for ${e}`)}).catch(i=>{this.log.error("error searching routing for potential session peers for %c - %e",e,i),o.reject(i)}),o.promise}};var Pl=class{libp2p;blockstore;datastore;events;pins;logger;routing;getCodec;getHasher;dns;metrics;log;constructor(e){this.logger=e.logger??fn(),this.log=this.logger.forComponent("helia"),this.getHasher=zb(e.hashers,e.loadHasher),this.getCodec=qb(e.codecs,e.loadCodec),this.dns=e.dns??Jc(),this.metrics=e.metrics,this.libp2p=e.libp2p,this.events=new _e;let t={blockstore:e.blockstore,datastore:e.datastore,logger:this.logger,libp2p:this.libp2p,blockBrokers:[],getHasher:this.getHasher,getCodec:this.getCodec,dns:this.dns,metrics:this.metrics,...e.components??{}};this.routing=t.routing=new il(t,{routers:(e.routers??[]).flatMap(o=>{let s=[o];return o[Vr]!=null&&s.push(o[Vr]),o[qr]!=null&&s.push(o[qr]),s}),providerLookupConcurrency:e.providerLookupConcurrency});let n=new Ll(t,e);this.pins=new sl(e.datastore,n,this.getCodec),this.blockstore=new Sl(n,this.pins,{holdGcLock:e.holdGcLock??!0}),this.datastore=e.datastore,t.blockBrokers=e.blockBrokers.map(o=>o(t))}async start(){await Cb(this.datastore),await sr(this.blockstore,this.datastore,this.routing,this.libp2p),this.events.dispatchEvent(new CustomEvent("start",{detail:this}))}async stop(){await ir(this.blockstore,this.datastore,this.routing,this.libp2p),this.events.dispatchEvent(new CustomEvent("stop",{detail:this}))}async gc(e={}){let t=await this.blockstore.lock.writeLock();try{let n=this,o=this.blockstore.unwrap();this.log("gc start"),await ki(o.deleteMany((async function*(){for await(let{cid:s}of o.getAll())try{if(await n.pins.isPinned(s,e))continue;yield s,e.onProgress?.(new Y("helia:gc:deleted",s))}catch(i){n.log.error("error during gc - %e",i),e.onProgress?.(new Y("helia:gc:error",i))}})()))}finally{t()}this.log("gc finished")}};var uk=[6,53,56,54,55];function jb(r){return Xb("sni",r)?.value}function Yb(r){let e=Xb("tcp",r)?.value;return e==null?"":`:${e}`}function Xb(r,e){return e.find(t=>t.name===r)}function Zb(r){return r.some(({code:e})=>e===448)}function Xt(r,e){let t=Jb[r.name];if(t==null)throw new Error(`Can't interpret protocol ${r.name}`);let n=t(r,e);return r.code===41?`[${n}]`:n}var Jb={ip4:(r,e)=>r.value,ip6:(r,e)=>e.length===0?r.value:`[${r.value}]`,tcp:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");return`tcp://${Xt(t,e)}:${r.value}`},udp:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");return`udp://${Xt(t,e)}:${r.value}`},dnsaddr:(r,e)=>r.value,dns4:(r,e)=>r.value,dns6:(r,e)=>r.value,dns:(r,e)=>r.value,ipfs:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");return`${Xt(t,e)}`},p2p:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");return`${Xt(t,e)}`},http:(r,e)=>{let t=Zb(e),n=jb(e),o=Yb(e);if(t&&n!=null)return`https://${n}${o}`;let s=t?"https://":"http://",i=e.pop();if(i==null)throw new Error("Unexpected end of multiaddr");let a=Xt(i,e);return a=a?.replace("tcp://",""),`${s}${a}`},"http-path":(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");let n=Xt(t,e),o=decodeURIComponent(r.value??"");return`${n}${o}`},tls:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");return Xt(t,e)},sni:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");return Xt(t,e)},https:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");let n=Xt(t,e);return n=n?.replace("tcp://",""),`https://${n}`},ws:(r,e)=>{let t=Zb(e),n=jb(e),o=Yb(e);if(t&&n!=null)return`wss://${n}${o}`;let s=t?"wss://":"ws://",i=e.pop();if(i==null)throw new Error("Unexpected end of multiaddr");let a=Xt(i,e);return a=a?.replace("tcp://",""),`${s}${a}`},wss:(r,e)=>{let t=e.pop();if(t==null)throw new Error("Unexpected end of multiaddr");let n=Xt(t,e);return n=n?.replace("tcp://",""),`wss://${n}`}};function Dl(r,e){let n=ee(r).getComponents(),o=n.pop();if(o==null)throw new Error("Unexpected end of multiaddr");let s=Jb[o.name];if(s==null)throw new Error(`No interpreter found for ${o.name}`);let i=s(o,n)??"";return e?.assumeHttp!==!1&&uk.includes(o.code)&&(i=i.replace(/^.*:\/\//,""),o.value==="443"?i=`https://${i}`:i=`http://${i}`),(i.startsWith("http://")||i.startsWith("https://")||i.startsWith("ws://")||i.startsWith("wss://"))&&(i=new URL(i).toString(),i.endsWith("/")&&(i=i.substring(0,i.length-1))),i}var fe=r=>({match:e=>{let t=e[0];return t==null||t.code!==r||t.value!=null?!1:e.slice(1)}}),q=(r,e)=>({match:t=>{let n=t[0];return n?.code!==r||n.value==null||e!=null&&n.value!==e?!1:t.slice(1)}}),Qb=r=>({match:e=>r.match(e)===!1?e:!1}),te=r=>({match:e=>{let t=r.match(e);return t===!1?e:t}}),et=(...r)=>({match:e=>{let t;for(let n of r){let o=n.match(e);o!==!1&&(t==null||o.length<t.length)&&(t=o)}return t??!1}}),ce=(...r)=>({match:e=>{for(let t of r){let n=t.match(e);if(n===!1)return!1;e=n}return e}});function de(...r){function e(o){if(o==null)return!1;let s=o.getComponents();for(let i of r){let a=i.match(s);if(a===!1)return!1;s=a}return s}function t(o){return e(o)!==!1}function n(o){let s=e(o);return s===!1?!1:s.length===0}return{matchers:r,matches:t,exactMatch:n}}var fk=q(421),ex=de(fk),Rl=q(54),Ml=q(55),Ol=q(56),om=q(53),dO=de(Rl,te(q(421))),hO=de(Ml,te(q(421))),pO=de(Ol,te(q(421))),tx=de(et(om,Ol,Rl,Ml),te(q(421))),rx=ce(q(4),te(q(43))),nx=ce(te(q(42)),q(41),te(q(43))),sm=et(rx,nx),to=et(sm,om,Rl,Ml,Ol),mO=de(et(sm,ce(et(om,Ol,Rl,Ml),te(q(421))))),im=de(rx),am=de(nx),gO=de(sm),cm=ce(to,q(6)),qi=ce(to,q(273)),zi=de(ce(cm,te(q(421)))),yO=de(qi),lm=ce(qi,fe(460),te(q(421))),Ul=ce(qi,fe(461),te(q(421))),dk=et(lm,Ul),wO=de(lm),ox=de(Ul),nm=et(to,cm,qi,lm,Ul),sx=et(ce(nm,fe(477),te(q(421)))),ro=de(sx),ix=et(ce(nm,fe(478),te(q(421))),ce(nm,fe(448),te(q(449)),fe(477),te(q(421)))),Gi=de(ix),ax=ce(qi,fe(280),te(q(466)),te(q(466)),te(q(421))),um=de(ax),cx=ce(Ul,fe(465),te(q(466)),te(q(466)),te(q(421))),fm=de(cx),Nl=et(sx,ix,ce(cm,te(q(421))),ce(dk,te(q(421))),ce(to,te(q(421))),ax,cx,q(421)),bO=de(Nl),hk=ce(te(Nl),fe(290),Qb(fe(281)),te(q(421))),no=de(hk),pk=et(ce(Nl,fe(290),fe(281),te(q(421))),ce(Nl,fe(281),te(q(421))),ce(fe(281),te(q(421)))),dm=de(pk),mk=et(ce(to,q(6),fe(480),te(q(421))),ce(to,fe(480),te(q(421)))),lx=de(mk),gk=ce(to,et(ce(q(6,"443"),fe(480)),ce(q(6),fe(443)),ce(q(6),fe(448),fe(480)),ce(fe(448),fe(480)),fe(448),fe(443)),te(q(421))),ux=de(gk),yk=et(ce(q(777),te(q(421)))),xO=de(yk),wk=et(ce(q(400),te(q(421)))),vO=de(wk);function hm(r,e,t){return r.filter(n=>{if(ux.matches(n)||e&&lx.matches(n))return t||tx.matches(n)?!0:qt(n)===!1;if(!e&&t){let{host:o}=Q(n);if(o==="127.0.0.1"||o==="localhost"||o.endsWith(".localhost"))return!0}return!1})}async function*Fl(r,e,t,n,o,s={}){for await(let i of e.findProviders(r,s)){let a=hm(i.multiaddrs,n,o);if(a.length===0)continue;let c=Dl(a[0]);yield new fs(c,{logger:t,transformRequestInit:s.transformRequestInit})}}async function fx(r,e,t){let{signal:n,log:o}=t??{},s=r.headers.get("content-length");if(s!=null){let c=parseInt(s,10);if(c>e)throw o?.error("content-length header (%d) is greater than the limit (%d)",c,e),r.body!=null&&await r.body.cancel().catch(l=>{o?.error("error cancelling response body after content-length check - %e",l)}),new Error(`Content-Length header (${c}) is greater than the limit (${e}).`)}let i=r.body?.getReader();if(i==null)throw new Error("Response body is not readable");let a=new se;try{for(;;){if(n?.aborted===!0)throw new Error("Response body read was aborted.");let{done:c,value:l}=await i.read();if(c)break;if(a.append(l),a.byteLength>e)throw new Error(`Response body is greater than the limit (${e}), received ${a.byteLength} bytes.`)}}finally{i.cancel().catch(c=>{o?.error("error cancelling reader - %e",c)}).finally(()=>{i.releaseLock()})}return a.subarray()}var fs=class{url;#e=0;#t=0;#r=0;#i=0;#s=new Map;log;transformRequestInit;constructor(e,{logger:t,transformRequestInit:n}){this.url=e instanceof URL?e:new URL(e),this.transformRequestInit=n,this.log=t.forComponent(`helia:trustless-gateway-block-broker:${this.url.hostname}`)}#f(e){let t=e.multihash.bytes;return Ye.encode(t)}async getRawBlock(e,{signal:t,maxSize:n=dx}={}){let o=new URL(this.url.toString());if(o.pathname=`/ipfs/${e.toString()}`,o.search="?format=raw",t?.aborted===!0)throw new Error(`Signal to fetch raw block for CID ${e} from gateway ${this.url} was aborted prior to fetch`);let s=this.#f(e),i=new AbortController,a=()=>{i.abort()};t?.addEventListener("abort",a);try{let c=this.#s.get(s);if(c==null){this.#e++;let l={signal:i.signal,headers:{Accept:"application/vnd.ipld.raw"},cache:"force-cache"},f=this.transformRequestInit!=null?await this.transformRequestInit(l):l;c=fetch(o.toString(),f).then(async u=>{if(this.log("GET %s %d",o,u.status),!u.ok)throw this.#t++,new Error(`unable to fetch raw block for CID ${e} from gateway ${this.url}`);let d=await fx(u,n,{signal:i.signal,log:this.log});return this.#i++,d}),this.#s.set(s,c)}return await c}catch{throw t?.aborted===!0?new Error(`fetching raw block for CID ${e} from gateway ${this.url} was aborted`):(this.#t++,new Error(`unable to fetch raw block for CID ${e}`))}finally{t?.removeEventListener("abort",a),this.#s.delete(s)}}reliability(){return this.#e===0?1:this.#r>0?-1/0:this.#i/(this.#e+this.#t*3)}incrementInvalidBlocks(){this.#r++}getStats(){return{attempts:this.#e,errors:this.#t,invalidBlocks:this.#r,successes:this.#i,pendingResponses:this.#s.size}}};var pm=class extends Hi{routing;allowInsecure;allowLocal;transformRequestInit;constructor(e,t){super(e,{...t,name:"helia:trustless-gateway:session"}),this.routing=e.routing,this.allowInsecure=t.allowInsecure??$l,this.allowLocal=t.allowLocal??Vl,this.transformRequestInit=t.transformRequestInit}async queryProvider(e,t,n){this.log("fetching BLOCK for %c from %s",e,t.url);let o=await t.getRawBlock(e,n);return this.log.trace("got block for %c from %s",e,t.url),await n.validateFn?.(o),o}async*findNewProviders(e,t={}){yield*Fl(e,this.routing,this.logger,this.allowInsecure,this.allowLocal,{...t,transformRequestInit:this.transformRequestInit})}toEvictionKey(e){return e.url.toString()}equals(e,t){return e.url.toString()===t.url.toString()}async convertToProvider(e,t){if(or(e))return;let n=hm(Array.isArray(e)?e:[e],this.allowInsecure,this.allowLocal);if(n.length===0)return;let o=Dl(n[0]);return new fs(o,{logger:this.logger,transformRequestInit:this.transformRequestInit})}};function hx(r,e){return new pm(r,e)}var Kl=class{allowInsecure;allowLocal;transformRequestInit;routing;log;logger;constructor(e,t={}){this.log=e.logger.forComponent("helia:trustless-gateway-block-broker"),this.logger=e.logger,this.routing=e.routing,this.allowInsecure=t.allowInsecure??$l,this.allowLocal=t.allowLocal??Vl,this.transformRequestInit=t.transformRequestInit}async retrieve(e,t={}){let n=[];for await(let o of Fl(e,this.routing,this.logger,this.allowInsecure,this.allowLocal,{...t,transformRequestInit:this.transformRequestInit})){this.log("getting block for %c from %s",e,o.url);try{let s=await o.getRawBlock(e,t);this.log.trace("got block for %c from %s",e,o.url);try{await t.validateFn?.(s)}catch(i){this.log.error("failed to validate block for %c from %s - %e",e,o.url,i);continue}return s}catch(s){if(this.log.error("failed to get block for %c from %s - %e",e,o.url,s),s instanceof Error?n.push(s):n.push(new Error(`Unable to fetch raw block for CID ${e} from gateway ${o.url}`)),t.signal?.aborted===!0){this.log.trace("request aborted while fetching raw block for CID %c from gateway %s",e,o.url);break}}}throw n.length>0?new AggregateError(n,`Unable to fetch raw block for CID ${e} from any gateway`):new Error(`Unable to fetch raw block for CID ${e} from any gateway`)}createSession(e={}){return hx({logger:this.logger,routing:this.routing},{...e,allowLocal:this.allowLocal,allowInsecure:this.allowInsecure,transformRequestInit:this.transformRequestInit})}};var $l=!1,Vl=!1,dx=2097152;function mm(r={}){return e=>new Kl(e,r)}async function*Hl(r,e={}){let t=r.getReader();try{for(;;){let n=await t.read();if(n.done)return;yield n.value}}finally{e.preventCancel!==!0&&await t.cancel(),t.releaseLock()}}var Sk=wn(ym(),1);var Jt=class extends Error{static name="SignatureVerificationError";constructor(e="Record signature verification failed"){super(e),this.name="SignatureVerificationError"}},ql=class extends Error{static name="RecordExpiredError";constructor(e="Record has expired"){super(e),this.name="RecordExpiredError"}},ds=class extends Error{static name="UnsupportedValidityError";constructor(e="The validity type is unsupported"){super(e),this.name="UnsupportedValidityError"}},zl=class extends Error{static name="RecordTooLargeError";constructor(e="The record is too large"){super(e),this.name="RecordTooLargeError"}},Gl=class extends Error{static name="InvalidValueError";constructor(e="Value must be a valid content path starting with /"){super(e),this.name="InvalidValueError"}},Wl=class extends Error{static name="InvalidRecordDataError";constructor(e="Invalid record data"){super(e),this.name="InvalidRecordDataError"}},Wi=class extends Error{static name="InvalidEmbeddedPublicKeyError";constructor(e="Invalid embedded public key"){super(e),this.name="InvalidEmbeddedPublicKeyError"}};var Qt;(function(r){let e;(function(o){o.EOL="EOL"})(e=r.ValidityType||(r.ValidityType={}));let t;(function(o){o[o.EOL=0]="EOL"})(t||(t={})),(function(o){o.codec=()=>Js(t)})(e=r.ValidityType||(r.ValidityType={}));let n;r.codec=()=>(n==null&&(n=Fe((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,i={})=>{let a={},c=s==null?o.len:o.pos+s;for(;o.pos<c;){let l=o.uint32();switch(l>>>3){case 1:{a.value=o.bytes();break}case 2:{a.signatureV1=o.bytes();break}case 3:{a.validityType=r.ValidityType.codec().decode(o);break}case 4:{a.validity=o.bytes();break}case 5:{a.sequence=o.uint64();break}case 6:{a.ttl=o.uint64();break}case 7:{a.pubKey=o.bytes();break}case 8:{a.signatureV2=o.bytes();break}case 9:{a.data=o.bytes();break}default:{o.skipType(l&7);break}}}return a})),n),r.encode=o=>Ue(o,r.codec()),r.decode=(o,s)=>Oe(o,r.codec(),s)})(Qt||(Qt={}));var bk=ut("ipns:utils"),px=B("/ipns/");var xk=0,vk=18;function mx(r){let e;if(r.pubKey!=null)try{e=nn(r.pubKey)}catch(t){throw bk.error(t),t}if(e!=null)return e}function gx(r){let e=B("ipns-signature:");return Ce([e,r])}function ji(r){return"signatureV1"in r?Qt.encode({value:B(r.value),signatureV1:r.signatureV1,validityType:r.validityType,validity:B(r.validity),sequence:r.sequence,ttl:r.ttl,pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data}):Qt.encode({pubKey:r.pubKey,signatureV2:r.signatureV2,data:r.data})}function hn(r){let e=Qt.decode(r);if(e.sequence!=null&&(e.sequence=BigInt(e.sequence)),e.ttl!=null&&(e.ttl=BigInt(e.ttl)),e.signatureV2==null||e.data==null)throw new Jt("Missing data or signatureV2");let t=yx(e.data),n=Ek(t.Value),o=U(t.Validity);if(e.value!=null&&e.signatureV1!=null)return Ak(e),{value:n,validityType:Qt.ValidityType.EOL,validity:o,sequence:t.Sequence,ttl:t.TTL,pubKey:e.pubKey,signatureV1:e.signatureV1,signatureV2:e.signatureV2,data:e.data};if(e.signatureV2!=null)return{value:n,validityType:Qt.ValidityType.EOL,validity:o,sequence:t.Sequence,ttl:t.TTL,pubKey:e.pubKey,signatureV2:e.signatureV2,data:e.data};throw new Error("invalid record: does not include signatureV1 or signatureV2")}function Yi(r){return Ce([px,r.bytes])}function hs(r){let e=pt(r.slice(px.length));if(!jl(e,xk)&&!jl(e,vk))throw new Hr("Multihash in IPNS key was not identity or sha2-256");return e}function yx(r){let e=vt(r);if(e.ValidityType===0)e.ValidityType=Qt.ValidityType.EOL;else throw new ds("The validity type is unsupported");return Number.isInteger(e.Sequence)&&(e.Sequence=BigInt(e.Sequence)),Number.isInteger(e.TTL)&&(e.TTL=BigInt(e.TTL)),e}function Ek(r){let e=U(r).trim();if(e.startsWith("/"))return e;try{return`/ipfs/${K.decode(r).toV1().toString()}`}catch{}try{return`/ipfs/${K.parse(e).toV1().toString()}`}catch{}throw new Gl("Value must be a valid content path starting with /")}function Ak(r){if(r.data==null)throw new Wl("Record data is missing");let e=yx(r.data);if(!X(e.Value,r.value??new Uint8Array(0)))throw new Jt('Field "value" did not match between protobuf and CBOR');if(!X(e.Validity,r.validity??new Uint8Array(0)))throw new Jt('Field "validity" did not match between protobuf and CBOR');if(e.ValidityType!==r.validityType)throw new Jt('Field "validityType" did not match between protobuf and CBOR');if(e.Sequence!==r.sequence)throw new Jt('Field "sequence" did not match between protobuf and CBOR');if(e.TTL!==r.ttl)throw new Jt('Field "ttl" did not match between protobuf and CBOR')}function jl(r,e){return r.code===e}var gU=ut("ipns"),yU=300*1e9,Ik="/ipns/",wU=Ik.length;var wx=wn(ym(),1);var Yl=ut("ipns:validator"),kk=1024*10;async function _k(r,e){let t=hn(e),n;try{let o=gx(t.data);n=await r.verify(o,t.signatureV2)}catch{n=!1}if(!n)throw Yl.error("record signature verification failed"),new Jt("Record signature verification failed");if(t.validityType===Qt.ValidityType.EOL){if(wx.default.fromString(t.validity).toDate().getTime()<Date.now())throw Yl.error("record has expired"),new ql("record has expired")}else if(t.validityType!=null)throw Yl.error("the validity type is unsupported"),new ds("The validity type is unsupported");Yl("ipns record for %s is valid",t.value)}async function bx(r,e){if(e.byteLength>kk)throw new zl("The record is too large");let t=hs(r),n;jl(t,0)&&(n=Ja(t));let o=hn(e),s=mx(o)??n;if(s==null)throw new Wi("Could not extract public key from IPNS record or routing key");let i=Yi(s.toMultihash());if(!X(i,r))throw new Wi("Embedded public key did not match routing key");await _k(s,e)}var Zl=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MESSAGE_LENGTH"};async function*Zi(r,e={}){let t=/\r?\n/,n=new TextDecoder("utf8"),o="";for await(let s of r){if(typeof s=="string"&&(s=new TextEncoder().encode(s)),xo(s)&&(s=s.subarray()),o+=n.decode(s,{stream:!0}),o.length>(e?.maxMessageLength??o.length))throw new Zl("Incoming message too long");let i=o.split(t);o=i.pop()??"";for(let a=0;a<i.length;a++)yield JSON.parse(i[a])}o+=n.decode(),o!==""&&(yield JSON.parse(o))}var ps=class extends Error{static name="InvalidRequestError";constructor(e="Invalid request"){super(e),this.name="InvalidRequestError"}},er=class extends Error{static name="BadResponseError";constructor(e="Bad response"){super(e),this.name="BadResponseError"}};function Ck(r){return r[Symbol.asyncIterator]!=null}function Tk(r){if(Ck(r))return(async()=>{for await(let e of r)return e})();for(let e of r)return e}var xx=Tk;var vx=B("/ipns/");function Ex(r){return X(r.subarray(0,vx.byteLength),vx)}var Xl=class{client;constructor(e){this.client=e}async*findProviders(e,t={}){yield*qc(this.client.getProviders(e,t),n=>({id:n.ID,multiaddrs:n.Addrs??[]}))}async provide(){}async cancelReprovide(){}async put(e,t,n){if(!Ex(e))return;let o=hs(e),s=K.createV1(114,o),i=hn(t);await this.client.putIPNS(s,i,n)}async get(e,t){if(!Ex(e))throw new ke("Not found");let n=hs(e),o=K.createV1(114,n);try{let s=await this.client.getIPNS(o,t);return ji(s)}catch(s){throw s.name==="BadResponseError"?new ke("Not found"):s}}},Jl=class{client;constructor(e){this.client=e}async findPeer(e,t={}){let n=await xx(this.client.getPeers(e,t));if(n!=null)return{id:n.ID,multiaddrs:n.Addrs??[]};throw new ke("Not found")}async*getClosestPeers(e,t={}){}};var He=ut("delegated-routing-v1-http-api-client"),Ql={concurrentRequests:4,timeout:3e4,cacheTTL:300*1e3,cacheName:"delegated-routing-v1-cache"},eu=class{started;httpQueue;shutDownController;clientUrl;timeout;contentRouting;peerRouting;filterAddrs;filterProtocols;inFlightRequests;cacheName;cache;cacheTTL;constructor(e,t={}){this.started=!1,this.shutDownController=new AbortController,this.shutDownController.signal,this.httpQueue=new Jn({concurrency:t.concurrentRequests??Ql.concurrentRequests}),this.inFlightRequests=new Map,this.clientUrl=e instanceof URL?e:new URL(e),this.timeout=t.timeout??Ql.timeout,this.filterAddrs=t.filterAddrs,this.filterProtocols=t.filterProtocols,this.contentRouting=new Xl(this),this.peerRouting=new Jl(this),this.cacheName=t.cacheName??Ql.cacheName,this.cacheTTL=t.cacheTTL??Ql.cacheTTL}get[Vr](){return this.contentRouting}get[qr](){return this.peerRouting}isStarted(){return this.started}async start(){this.started||(this.started=!0,this.cacheTTL>0&&(this.cache=await globalThis.caches?.open(this.cacheName),this.cache!=null&&He("cache enabled with ttl %d",this.cacheTTL)))}async stop(){this.httpQueue.clear(),this.shutDownController.abort(),await globalThis.caches?.delete(this.cacheName),this.started=!1}async*getProviders(e,t={}){He("getProviders starts: %c",e);let n=AbortSignal.timeout(this.timeout),o=pe([this.shutDownController.signal,n,t.signal]);let s=ae(),i=ae();this.httpQueue.add(async()=>(s.resolve(),i.promise));try{await s.promise;let a=new URL(`${this.clientUrl}routing/v1/providers/${e.toString()}`);this.#t(a,t.filterAddrs,t.filterProtocols);let c={headers:{Accept:"application/x-ndjson"},signal:o},l=await this.#r(a.toString(),c);if(l==null)throw new er("No response received");if(!l.ok)throw l.status===404?new ke("No matching records found"):l.status===422?new ps("Request does not conform to schema or semantic constraints"):new er(`Unexpected status code: ${l.status}`);if(l.body==null)throw new er("Routing response had no body");let f=l.headers.get("Content-Type");if(f==null)throw new er("No Content-Type header received");if(f?.startsWith("application/json")){let u=await l.json();for(let d of u.Providers){let h=this.#e(d);h!=null&&(yield h)}}else if(f.includes("application/x-ndjson"))for await(let u of Zi(Hl(l.body))){let d=this.#e(u);d!=null&&(yield d)}else throw new er(`Unsupported Content-Type: ${f}`)}finally{o.clear(),i.resolve(),He("getProviders finished: %c",e)}}async*getPeers(e,t={}){He("getPeers starts: %c",e);let n=AbortSignal.timeout(this.timeout),o=pe([this.shutDownController.signal,n,t.signal]);let s=ae(),i=ae();this.httpQueue.add(async()=>(s.resolve(),i.promise));try{await s.promise;let a=new URL(`${this.clientUrl}routing/v1/peers/${e.toCID().toString()}`);this.#t(a,t.filterAddrs,t.filterProtocols);let c={headers:{Accept:"application/x-ndjson"},signal:o},l=await this.#r(a.toString(),c);if(l.status===404)throw new ke("No matching records found");if(l.status===422)throw new ps("Request does not conform to schema or semantic constraints");if(l.body==null)throw new er("Routing response had no body");if(l.headers.get("Content-Type")==="application/json"){let u=await l.json();for(let d of u.Peers){let h=this.#e(d);h!=null&&(yield h)}}else for await(let u of Zi(Hl(l.body))){let d=this.#e(u);d!=null&&(yield d)}}catch(a){He.error("getPeers errored:",a)}finally{o.clear(),i.resolve(),He("getPeers finished: %c",e)}}async getIPNS(e,t={}){He("getIPNS starts: %s",e);let n=AbortSignal.timeout(this.timeout),o=pe([this.shutDownController.signal,n,t.signal]);let s=ae(),i=ae();this.httpQueue.add(async()=>(s.resolve(),i.promise));let a=`${this.clientUrl}routing/v1/ipns/${e}`;try{await s.promise;let c={headers:{Accept:"application/vnd.ipfs.ipns-record"},signal:o},l=await this.#r(a,c);if(He("getIPNS GET %s %d",a,l.status),l.status===404)throw new ke("No matching records found");if(l.status===422)throw new ps("Request does not conform to schema or semantic constraints");if(l.body==null)throw new er("GET ipns response had no body");let f=await l.arrayBuffer(),u=new Uint8Array(f,0,f.byteLength);return t.validate!==!1&&await bx(Yi(e.multihash),u),hn(u)}catch(c){throw He.error("getIPNS GET %s error:",a,c),c}finally{o.clear(),i.resolve(),He("getIPNS finished: %s",e)}}async putIPNS(e,t,n={}){He("putIPNS starts: %c",e);let o=AbortSignal.timeout(this.timeout),s=pe([this.shutDownController.signal,o,n.signal]);let i=ae(),a=ae();this.httpQueue.add(async()=>(i.resolve(),a.promise));let c=`${this.clientUrl}routing/v1/ipns/${e}`;try{await i.promise;let l=ji(t),f={method:"PUT",headers:{"Content-Type":"application/vnd.ipfs.ipns-record"},body:l,signal:s},u=await this.#r(c,f);if(He("putIPNS PUT %s %d",c,u.status),u.status!==200)throw new er("PUT ipns response had status other than 200")}catch(l){throw He.error("putIPNS PUT %s error:",c,l.stack),l}finally{s.clear(),a.resolve(),He("putIPNS finished: %c",e)}}#e(e){try{let t=[],n=e.Addrs?.map(ee)??[];return e.Protocols!=null&&t.push(...e.Protocols),e.Protocol!=null&&(t.push(e.Protocol),delete e.Protocol),{...e,Schema:"peer",ID:Bt(e.ID),Addrs:n,Protocols:t}}catch(t){He.error("could not conform record to peer schema",t)}}#t(e,t,n){if(t!=null||this.filterAddrs!=null){let o=t?.join(",")??this.filterAddrs?.join(",")??"";o!==""&&e.searchParams.set("filter-addrs",o)}if(n!=null||this.filterProtocols!=null){let o=n?.join(",")??this.filterProtocols?.join(",")??"";o!==""&&e.searchParams.set("filter-protocols",o)}}async#r(e,t){let n=t.method??"GET",o=`${n}-${e}`;if(n==="GET"){let c=await this.cache?.match(e);if(c!=null){if(parseInt(c.headers.get("x-cache-expires")??"0",10)>Date.now())return He("returning cached response for %s",o),c;await this.cache?.delete(e)}}let s=this.inFlightRequests.get(o);if(s!=null){let c=await s;return He("deduplicating outgoing request for %s",o),c.clone()}let i=fetch(e,t).then(async c=>{if(this.cache!=null&&c.ok&&n==="GET"){let l=Date.now()+this.cacheTTL,f=new Headers(c.headers);f.set("x-cache-expires",l.toString());let u=new Response(c.clone().body,{status:c.status,statusText:c.statusText,headers:f});await this.cache.put(e,u)}return c}).finally(()=>{this.inFlightRequests.delete(o)});return this.inFlightRequests.set(o,i),await i}};function Ax(r,e={}){return new eu(new URL(r),e)}var Sx="[a-fA-F\\d:]",pn=r=>r&&r.includeBoundaries?`(?:(?<=\\s|^)(?=${Sx})|(?<=${Sx})(?=\\s|$))`:"",tr="(?: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}",Ie="[a-fA-F\\d]{1,4}",tu=`
5
5
  (?:
6
6
  (?:${Ie}:){7}(?:${Ie}|:)| // 1:2:3:4:5:6:7:: 1:2:3:4:5:6:7:8
7
7
  (?:${Ie}:){6}(?:${tr}|:${Ie}|:)| // 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