@libp2p/tcp 8.0.7 → 8.0.8-c88de8e1

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.Libp2PTcp = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PTcp=(()=>{var fn=Object.create;var Me=Object.defineProperty;var hn=Object.getOwnPropertyDescriptor;var mn=Object.getOwnPropertyNames;var gn=Object.getPrototypeOf,wn=Object.prototype.hasOwnProperty;var X=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,r)=>(typeof require<"u"?require:e)[r]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var M=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),k=(t,e)=>{for(var r in e)Me(t,r,{get:e[r],enumerable:!0})},Qt=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of mn(e))!wn.call(t,o)&&o!==r&&Me(t,o,{get:()=>e[o],enumerable:!(n=hn(e,o))||n.enumerable});return t};var ne=(t,e,r)=>(r=t!=null?fn(gn(t)):{},Qt(e||!t||!t.__esModule?Me(r,"default",{value:t,enumerable:!0}):r,t)),bn=t=>Qt(Me({},"__esModule",{value:!0}),t);var er=M((Zs,Zt)=>{var pe=1e3,fe=pe*60,he=fe*60,oe=he*24,xn=oe*7,yn=oe*365.25;Zt.exports=function(t,e){e=e||{};var r=typeof t;if(r==="string"&&t.length>0)return Cn(t);if(r==="number"&&isFinite(t))return e.long?En(t):vn(t);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(t))};function Cn(t){if(t=String(t),!(t.length>100)){var e=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(t);if(e){var r=parseFloat(e[1]),n=(e[2]||"ms").toLowerCase();switch(n){case"years":case"year":case"yrs":case"yr":case"y":return r*yn;case"weeks":case"week":case"w":return r*xn;case"days":case"day":case"d":return r*oe;case"hours":case"hour":case"hrs":case"hr":case"h":return r*he;case"minutes":case"minute":case"mins":case"min":case"m":return r*fe;case"seconds":case"second":case"secs":case"sec":case"s":return r*pe;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return r;default:return}}}}function vn(t){var e=Math.abs(t);return e>=oe?Math.round(t/oe)+"d":e>=he?Math.round(t/he)+"h":e>=fe?Math.round(t/fe)+"m":e>=pe?Math.round(t/pe)+"s":t+"ms"}function En(t){var e=Math.abs(t);return e>=oe?ke(t,e,oe,"day"):e>=he?ke(t,e,he,"hour"):e>=fe?ke(t,e,fe,"minute"):e>=pe?ke(t,e,pe,"second"):t+" ms"}function ke(t,e,r,n){var o=e>=r*1.5;return Math.round(t/r)+" "+n+(o?"s":"")}});var Qe=M((ei,tr)=>{function An(t){r.debug=r,r.default=r,r.coerce=p,r.disable=s,r.enable=o,r.enabled=i,r.humanize=er(),r.destroy=y,Object.keys(t).forEach(l=>{r[l]=t[l]}),r.names=[],r.skips=[],r.formatters={};function e(l){let u=0;for(let f=0;f<l.length;f++)u=(u<<5)-u+l.charCodeAt(f),u|=0;return r.colors[Math.abs(u)%r.colors.length]}r.selectColor=e;function r(l){let u,f=null,g,h;function w(...C){if(!w.enabled)return;let m=w,A=Number(new Date),U=A-(u||A);m.diff=U,m.prev=u,m.curr=A,u=A,C[0]=r.coerce(C[0]),typeof C[0]!="string"&&C.unshift("%O");let I=0;C[0]=C[0].replace(/%([a-zA-Z%])/g,($,R)=>{if($==="%%")return"%";I++;let B=r.formatters[R];if(typeof B=="function"){let ue=C[I];$=B.call(m,ue),C.splice(I,1),I--}return $}),r.formatArgs.call(m,C),(m.log||r.log).apply(m,C)}return w.namespace=l,w.useColors=r.useColors(),w.color=r.selectColor(l),w.extend=n,w.destroy=r.destroy,Object.defineProperty(w,"enabled",{enumerable:!0,configurable:!1,get:()=>f!==null?f:(g!==r.namespaces&&(g=r.namespaces,h=r.enabled(l)),h),set:C=>{f=C}}),typeof r.init=="function"&&r.init(w),w}function n(l,u){let f=r(this.namespace+(typeof u>"u"?":":u)+l);return f.log=this.log,f}function o(l){r.save(l),r.namespaces=l,r.names=[],r.skips=[];let u,f=(typeof l=="string"?l:"").split(/[\s,]+/),g=f.length;for(u=0;u<g;u++)f[u]&&(l=f[u].replace(/\*/g,".*?"),l[0]==="-"?r.skips.push(new RegExp("^"+l.slice(1)+"$")):r.names.push(new RegExp("^"+l+"$")))}function s(){let l=[...r.names.map(a),...r.skips.map(a).map(u=>"-"+u)].join(",");return r.enable(""),l}function i(l){if(l[l.length-1]==="*")return!0;let u,f;for(u=0,f=r.skips.length;u<f;u++)if(r.skips[u].test(l))return!1;for(u=0,f=r.names.length;u<f;u++)if(r.names[u].test(l))return!0;return!1}function a(l){return l.toString().substring(2,l.toString().length-2).replace(/\.\*\?$/,"*")}function p(l){return l instanceof Error?l.stack||l.message:l}function y(){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 r.enable(r.load()),r}tr.exports=An});var rr=M((L,Ne)=>{L.formatArgs=Sn;L.save=Tn;L.load=Pn;L.useColors=In;L.storage=Fn();L.destroy=(()=>{let t=!1;return()=>{t||(t=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})();L.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function In(){return typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs)?!0:typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)?!1:typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function Sn(t){if(t[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+t[0]+(this.useColors?"%c ":" ")+"+"+Ne.exports.humanize(this.diff),!this.useColors)return;let e="color: "+this.color;t.splice(1,0,e,"color: inherit");let r=0,n=0;t[0].replace(/%[a-zA-Z%]/g,o=>{o!=="%%"&&(r++,o==="%c"&&(n=r))}),t.splice(n,0,e)}L.log=console.debug||console.log||(()=>{});function Tn(t){try{t?L.storage.setItem("debug",t):L.storage.removeItem("debug")}catch{}}function Pn(){let t;try{t=L.storage.getItem("debug")}catch{}return!t&&typeof process<"u"&&"env"in process&&(t=process.env.DEBUG),t}function Fn(){try{return localStorage}catch{}}Ne.exports=Qe()(L);var{formatters:On}=Ne.exports;On.j=function(t){try{return JSON.stringify(t)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}});var or=M((ti,nr)=>{"use strict";nr.exports=(t,e)=>{e=e||process.argv;let r=t.startsWith("-")?"":t.length===1?"-":"--",n=e.indexOf(r+t),o=e.indexOf("--");return n!==-1&&(o===-1?!0:n<o)}});var ir=M((ri,sr)=>{"use strict";var Rn=X("os"),j=or(),T=process.env,me;j("no-color")||j("no-colors")||j("color=false")?me=!1:(j("color")||j("colors")||j("color=true")||j("color=always"))&&(me=!0);"FORCE_COLOR"in T&&(me=T.FORCE_COLOR.length===0||parseInt(T.FORCE_COLOR,10)!==0);function Mn(t){return t===0?!1:{level:t,hasBasic:!0,has256:t>=2,has16m:t>=3}}function kn(t){if(me===!1)return 0;if(j("color=16m")||j("color=full")||j("color=truecolor"))return 3;if(j("color=256"))return 2;if(t&&!t.isTTY&&me!==!0)return 0;let e=me?1:0;if(process.platform==="win32"){let r=Rn.release().split(".");return Number(process.versions.node.split(".")[0])>=8&&Number(r[0])>=10&&Number(r[2])>=10586?Number(r[2])>=14931?3:2:1}if("CI"in T)return["TRAVIS","CIRCLECI","APPVEYOR","GITLAB_CI"].some(r=>r in T)||T.CI_NAME==="codeship"?1:e;if("TEAMCITY_VERSION"in T)return/^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(T.TEAMCITY_VERSION)?1:0;if(T.COLORTERM==="truecolor")return 3;if("TERM_PROGRAM"in T){let r=parseInt((T.TERM_PROGRAM_VERSION||"").split(".")[0],10);switch(T.TERM_PROGRAM){case"iTerm.app":return r>=3?3:2;case"Apple_Terminal":return 2}}return/-256(color)?$/i.test(T.TERM)?2:/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(T.TERM)||"COLORTERM"in T?1:(T.TERM==="dumb",e)}function Ke(t){let e=kn(t);return Mn(e)}sr.exports={supportsColor:Ke,stdout:Ke(process.stdout),stderr:Ke(process.stderr)}});var ar=M((S,De)=>{var Nn=X("tty"),Le=X("util");S.init=zn;S.log=Un;S.formatArgs=Dn;S.save=$n;S.load=Bn;S.useColors=Ln;S.destroy=Le.deprecate(()=>{},"Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.");S.colors=[6,2,3,4,5,1];try{let t=ir();t&&(t.stderr||t).level>=2&&(S.colors=[20,21,26,27,32,33,38,39,40,41,42,43,44,45,56,57,62,63,68,69,74,75,76,77,78,79,80,81,92,93,98,99,112,113,128,129,134,135,148,149,160,161,162,163,164,165,166,167,168,169,170,171,172,173,178,179,184,185,196,197,198,199,200,201,202,203,204,205,206,207,208,209,214,215,220,221])}catch{}S.inspectOpts=Object.keys(process.env).filter(t=>/^debug_/i.test(t)).reduce((t,e)=>{let r=e.substring(6).toLowerCase().replace(/_([a-z])/g,(o,s)=>s.toUpperCase()),n=process.env[e];return/^(yes|on|true|enabled)$/i.test(n)?n=!0:/^(no|off|false|disabled)$/i.test(n)?n=!1:n==="null"?n=null:n=Number(n),t[r]=n,t},{});function Ln(){return"colors"in S.inspectOpts?!!S.inspectOpts.colors:Nn.isatty(process.stderr.fd)}function Dn(t){let{namespace:e,useColors:r}=this;if(r){let n=this.color,o="\x1B[3"+(n<8?n:"8;5;"+n),s=` ${o};1m${e} \x1B[0m`;t[0]=s+t[0].split(`
2
+ "use strict";var Libp2PTcp=(()=>{var hn=Object.create;var Me=Object.defineProperty;var mn=Object.getOwnPropertyDescriptor;var gn=Object.getOwnPropertyNames;var wn=Object.getPrototypeOf,bn=Object.prototype.hasOwnProperty;var H=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,r)=>(typeof require<"u"?require:e)[r]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var D=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),_=(t,e)=>{for(var r in e)Me(t,r,{get:e[r],enumerable:!0})},Yt=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of gn(e))!bn.call(t,o)&&o!==r&&Me(t,o,{get:()=>e[o],enumerable:!(n=mn(e,o))||n.enumerable});return t};var oe=(t,e,r)=>(r=t!=null?hn(wn(t)):{},Yt(e||!t||!t.__esModule?Me(r,"default",{value:t,enumerable:!0}):r,t)),xn=t=>Yt(Me({},"__esModule",{value:!0}),t);var tr=D((Ks,er)=>{var fe=1e3,he=fe*60,me=he*60,se=me*24,yn=se*7,Cn=se*365.25;er.exports=function(t,e){e=e||{};var r=typeof t;if(r==="string"&&t.length>0)return vn(t);if(r==="number"&&isFinite(t))return e.long?An(t):En(t);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(t))};function vn(t){if(t=String(t),!(t.length>100)){var e=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(t);if(e){var r=parseFloat(e[1]),n=(e[2]||"ms").toLowerCase();switch(n){case"years":case"year":case"yrs":case"yr":case"y":return r*Cn;case"weeks":case"week":case"w":return r*yn;case"days":case"day":case"d":return r*se;case"hours":case"hour":case"hrs":case"hr":case"h":return r*me;case"minutes":case"minute":case"mins":case"min":case"m":return r*he;case"seconds":case"second":case"secs":case"sec":case"s":return r*fe;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return r;default:return}}}}function En(t){var e=Math.abs(t);return e>=se?Math.round(t/se)+"d":e>=me?Math.round(t/me)+"h":e>=he?Math.round(t/he)+"m":e>=fe?Math.round(t/fe)+"s":t+"ms"}function An(t){var e=Math.abs(t);return e>=se?ke(t,e,se,"day"):e>=me?ke(t,e,me,"hour"):e>=he?ke(t,e,he,"minute"):e>=fe?ke(t,e,fe,"second"):t+" ms"}function ke(t,e,r,n){var o=e>=r*1.5;return Math.round(t/r)+" "+n+(o?"s":"")}});var Ye=D((Zs,rr)=>{function In(t){r.debug=r,r.default=r,r.coerce=p,r.disable=s,r.enable=o,r.enabled=i,r.humanize=tr(),r.destroy=y,Object.keys(t).forEach(l=>{r[l]=t[l]}),r.names=[],r.skips=[],r.formatters={};function e(l){let u=0;for(let f=0;f<l.length;f++)u=(u<<5)-u+l.charCodeAt(f),u|=0;return r.colors[Math.abs(u)%r.colors.length]}r.selectColor=e;function r(l){let u,f=null,g,h;function w(...C){if(!w.enabled)return;let m=w,A=Number(new Date),$=A-(u||A);m.diff=$,m.prev=u,m.curr=A,u=A,C[0]=r.coerce(C[0]),typeof C[0]!="string"&&C.unshift("%O");let S=0;C[0]=C[0].replace(/%([a-zA-Z%])/g,(V,k)=>{if(V==="%%")return"%";S++;let B=r.formatters[k];if(typeof B=="function"){let de=C[S];V=B.call(m,de),C.splice(S,1),S--}return V}),r.formatArgs.call(m,C),(m.log||r.log).apply(m,C)}return w.namespace=l,w.useColors=r.useColors(),w.color=r.selectColor(l),w.extend=n,w.destroy=r.destroy,Object.defineProperty(w,"enabled",{enumerable:!0,configurable:!1,get:()=>f!==null?f:(g!==r.namespaces&&(g=r.namespaces,h=r.enabled(l)),h),set:C=>{f=C}}),typeof r.init=="function"&&r.init(w),w}function n(l,u){let f=r(this.namespace+(typeof u>"u"?":":u)+l);return f.log=this.log,f}function o(l){r.save(l),r.namespaces=l,r.names=[],r.skips=[];let u,f=(typeof l=="string"?l:"").split(/[\s,]+/),g=f.length;for(u=0;u<g;u++)f[u]&&(l=f[u].replace(/\*/g,".*?"),l[0]==="-"?r.skips.push(new RegExp("^"+l.slice(1)+"$")):r.names.push(new RegExp("^"+l+"$")))}function s(){let l=[...r.names.map(a),...r.skips.map(a).map(u=>"-"+u)].join(",");return r.enable(""),l}function i(l){if(l[l.length-1]==="*")return!0;let u,f;for(u=0,f=r.skips.length;u<f;u++)if(r.skips[u].test(l))return!1;for(u=0,f=r.names.length;u<f;u++)if(r.names[u].test(l))return!0;return!1}function a(l){return l.toString().substring(2,l.toString().length-2).replace(/\.\*\?$/,"*")}function p(l){return l instanceof Error?l.stack||l.message:l}function y(){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 r.enable(r.load()),r}rr.exports=In});var nr=D((U,De)=>{U.formatArgs=Tn;U.save=Pn;U.load=Fn;U.useColors=Sn;U.storage=Rn();U.destroy=(()=>{let t=!1;return()=>{t||(t=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})();U.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function Sn(){return typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs)?!0:typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)?!1:typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/)&&parseInt(RegExp.$1,10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function Tn(t){if(t[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+t[0]+(this.useColors?"%c ":" ")+"+"+De.exports.humanize(this.diff),!this.useColors)return;let e="color: "+this.color;t.splice(1,0,e,"color: inherit");let r=0,n=0;t[0].replace(/%[a-zA-Z%]/g,o=>{o!=="%%"&&(r++,o==="%c"&&(n=r))}),t.splice(n,0,e)}U.log=console.debug||console.log||(()=>{});function Pn(t){try{t?U.storage.setItem("debug",t):U.storage.removeItem("debug")}catch{}}function Fn(){let t;try{t=U.storage.getItem("debug")}catch{}return!t&&typeof process<"u"&&"env"in process&&(t=process.env.DEBUG),t}function Rn(){try{return localStorage}catch{}}De.exports=Ye()(U);var{formatters:On}=De.exports;On.j=function(t){try{return JSON.stringify(t)}catch(e){return"[UnexpectedJSONParseError]: "+e.message}}});var sr=D((ei,or)=>{"use strict";or.exports=(t,e)=>{e=e||process.argv;let r=t.startsWith("-")?"":t.length===1?"-":"--",n=e.indexOf(r+t),o=e.indexOf("--");return n!==-1&&(o===-1?!0:n<o)}});var cr=D((ti,ir)=>{"use strict";var Nn=H("os"),G=sr(),F=process.env,ge;G("no-color")||G("no-colors")||G("color=false")?ge=!1:(G("color")||G("colors")||G("color=true")||G("color=always"))&&(ge=!0);"FORCE_COLOR"in F&&(ge=F.FORCE_COLOR.length===0||parseInt(F.FORCE_COLOR,10)!==0);function Mn(t){return t===0?!1:{level:t,hasBasic:!0,has256:t>=2,has16m:t>=3}}function kn(t){if(ge===!1)return 0;if(G("color=16m")||G("color=full")||G("color=truecolor"))return 3;if(G("color=256"))return 2;if(t&&!t.isTTY&&ge!==!0)return 0;let e=ge?1:0;if(process.platform==="win32"){let r=Nn.release().split(".");return Number(process.versions.node.split(".")[0])>=8&&Number(r[0])>=10&&Number(r[2])>=10586?Number(r[2])>=14931?3:2:1}if("CI"in F)return["TRAVIS","CIRCLECI","APPVEYOR","GITLAB_CI"].some(r=>r in F)||F.CI_NAME==="codeship"?1:e;if("TEAMCITY_VERSION"in F)return/^(9\.(0*[1-9]\d*)\.|\d{2,}\.)/.test(F.TEAMCITY_VERSION)?1:0;if(F.COLORTERM==="truecolor")return 3;if("TERM_PROGRAM"in F){let r=parseInt((F.TERM_PROGRAM_VERSION||"").split(".")[0],10);switch(F.TERM_PROGRAM){case"iTerm.app":return r>=3?3:2;case"Apple_Terminal":return 2}}return/-256(color)?$/i.test(F.TERM)?2:/^screen|^xterm|^vt100|^vt220|^rxvt|color|ansi|cygwin|linux/i.test(F.TERM)||"COLORTERM"in F?1:(F.TERM==="dumb",e)}function Ke(t){let e=kn(t);return Mn(e)}ir.exports={supportsColor:Ke,stdout:Ke(process.stdout),stderr:Ke(process.stderr)}});var lr=D((P,Ue)=>{var Dn=H("tty"),_e=H("util");P.init=zn;P.log=$n;P.formatArgs=Un;P.save=Vn;P.load=Bn;P.useColors=_n;P.destroy=_e.deprecate(()=>{},"Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.");P.colors=[6,2,3,4,5,1];try{let t=cr();t&&(t.stderr||t).level>=2&&(P.colors=[20,21,26,27,32,33,38,39,40,41,42,43,44,45,56,57,62,63,68,69,74,75,76,77,78,79,80,81,92,93,98,99,112,113,128,129,134,135,148,149,160,161,162,163,164,165,166,167,168,169,170,171,172,173,178,179,184,185,196,197,198,199,200,201,202,203,204,205,206,207,208,209,214,215,220,221])}catch{}P.inspectOpts=Object.keys(process.env).filter(t=>/^debug_/i.test(t)).reduce((t,e)=>{let r=e.substring(6).toLowerCase().replace(/_([a-z])/g,(o,s)=>s.toUpperCase()),n=process.env[e];return/^(yes|on|true|enabled)$/i.test(n)?n=!0:/^(no|off|false|disabled)$/i.test(n)?n=!1:n==="null"?n=null:n=Number(n),t[r]=n,t},{});function _n(){return"colors"in P.inspectOpts?!!P.inspectOpts.colors:Dn.isatty(process.stderr.fd)}function Un(t){let{namespace:e,useColors:r}=this;if(r){let n=this.color,o="\x1B[3"+(n<8?n:"8;5;"+n),s=` ${o};1m${e} \x1B[0m`;t[0]=s+t[0].split(`
3
3
  `).join(`
4
- `+s),t.push(o+"m+"+De.exports.humanize(this.diff)+"\x1B[0m")}else t[0]=_n()+e+" "+t[0]}function _n(){return S.inspectOpts.hideDate?"":new Date().toISOString()+" "}function Un(...t){return process.stderr.write(Le.format(...t)+`
5
- `)}function $n(t){t?process.env.DEBUG=t:delete process.env.DEBUG}function Bn(){return process.env.DEBUG}function zn(t){t.inspectOpts={};let e=Object.keys(S.inspectOpts);for(let r=0;r<e.length;r++)t.inspectOpts[e[r]]=S.inspectOpts[e[r]]}De.exports=Qe()(S);var{formatters:cr}=De.exports;cr.o=function(t){return this.inspectOpts.colors=this.useColors,Le.inspect(t,this.inspectOpts).split(`
6
- `).map(e=>e.trim()).join(" ")};cr.O=function(t){return this.inspectOpts.colors=this.useColors,Le.inspect(t,this.inspectOpts)}});var lr=M((ni,Ye)=>{typeof process>"u"||process.type==="renderer"||process.browser===!0||process.__nwjs?Ye.exports=rr():Ye.exports=ar()});var Je=M((Da,en)=>{en.exports=t=>{if(t[Symbol.asyncIterator])return t;if(t.getReader)return async function*(){let e=t.getReader();try{for(;;){let{done:r,value:n}=await e.read();if(r)return;yield n}}finally{e.releaseLock()}}();throw new Error("unknown stream")}});var rn=M((_a,tn)=>{tn.exports=function(e){if(e){if(typeof e[Symbol.iterator]=="function")return e[Symbol.iterator]();if(typeof e[Symbol.asyncIterator]=="function")return e[Symbol.asyncIterator]();if(typeof e.next=="function")return e}throw new Error("argument is not an iterator or iterable")}});var qt=M((Ua,nn)=>{var Ns=rn();nn.exports=t=>async e=>{e=Ns(e);let r=m=>{typeof m.return=="function"&&m.return()},n=null,o=null,s=m=>{n=m,o&&o(m),r(e)},i=null,a=!1,p=()=>{a=!0,i&&i()},y=null,l=!1,u=()=>{l=!0,y&&y()},f=null,g=()=>{f&&f()},h=()=>new Promise((m,A)=>{i=f=m,o=A,t.once("drain",g)}),w=()=>(r(e),new Promise((m,A)=>{if(a||l||n)return m();y=i=m,o=A})),C=()=>{t.removeListener("error",s),t.removeListener("close",p),t.removeListener("finish",u),t.removeListener("drain",g)};t.once("error",s),t.once("close",p),t.once("finish",u);try{for await(let m of e){if(!t.writable||t.destroyed||n)break;t.write(m)===!1&&await h()}}catch(m){n||t.destroy(),n=m}try{if(t.writable&&t.end(),await w(),n)throw n}finally{C()}}});var jt=M(($a,on)=>{var Ls=qt(),Ds=Je();on.exports=t=>({sink:Ls(t),source:Ds(t)})});var cn=M((Ba,sn)=>{var _s=jt();sn.exports=t=>async function*(e){let r=_s(t),n;if(r.sink(e).catch(o=>{n=o}),yield*r.source,n)throw n}});var an=M((za,Se)=>{Se.exports=Je();Se.exports.source=Je();Se.exports.sink=qt();Se.exports.transform=cn();Se.exports.duplex=jt()});var Hs={};k(Hs,{tcp:()=>Xs});var pn=ne(X("net"),1);var de=class t extends Error{code;type;constructor(e="The operation was aborted"){super(e),this.code=t.code,this.type=t.type}static code="ABORT_ERR";static type="aborted"},N=class extends Error{code;props;constructor(e,r,n){super(e),this.code=r,this.name=n?.name??"CodeError",this.props=n??{}}};var Yt=Symbol.for("@libp2p/transport");var Kt;(function(t){t[t.FATAL_ALL=0]="FATAL_ALL",t[t.NO_FATAL=1]="NO_FATAL"})(Kt||(Kt={}));var D=ne(lr(),1);var nt={};k(nt,{base32:()=>G,base32hex:()=>Qn,base32hexpad:()=>Yn,base32hexpadupper:()=>Zn,base32hexupper:()=>Kn,base32pad:()=>Xn,base32padupper:()=>Hn,base32upper:()=>Jn,base32z:()=>eo});function Vn(t,e){if(t.length>=255)throw new TypeError("Alphabet too long");for(var r=new Uint8Array(256),n=0;n<r.length;n++)r[n]=255;for(var o=0;o<t.length;o++){var s=t.charAt(o),i=s.charCodeAt(0);if(r[i]!==255)throw new TypeError(s+" is ambiguous");r[i]=o}var a=t.length,p=t.charAt(0),y=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(h){if(h instanceof Uint8Array||(ArrayBuffer.isView(h)?h=new Uint8Array(h.buffer,h.byteOffset,h.byteLength):Array.isArray(h)&&(h=Uint8Array.from(h))),!(h instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(h.length===0)return"";for(var w=0,C=0,m=0,A=h.length;m!==A&&h[m]===0;)m++,w++;for(var U=(A-m)*l+1>>>0,I=new Uint8Array(U);m!==A;){for(var q=h[m],$=0,R=U-1;(q!==0||$<C)&&R!==-1;R--,$++)q+=256*I[R]>>>0,I[R]=q%a>>>0,q=q/a>>>0;if(q!==0)throw new Error("Non-zero carry");C=$,m++}for(var B=U-C;B!==U&&I[B]===0;)B++;for(var ue=p.repeat(w);B<U;++B)ue+=t.charAt(I[B]);return ue}function f(h){if(typeof h!="string")throw new TypeError("Expected String");if(h.length===0)return new Uint8Array;var w=0;if(h[w]!==" "){for(var C=0,m=0;h[w]===p;)C++,w++;for(var A=(h.length-w)*y+1>>>0,U=new Uint8Array(A);h[w];){var I=r[h.charCodeAt(w)];if(I===255)return;for(var q=0,$=A-1;(I!==0||q<m)&&$!==-1;$--,q++)I+=a*U[$]>>>0,U[$]=I%256>>>0,I=I/256>>>0;if(I!==0)throw new Error("Non-zero carry");m=q,w++}if(h[w]!==" "){for(var R=A-m;R!==A&&U[R]===0;)R++;for(var B=new Uint8Array(C+(A-R)),ue=C;R!==A;)B[ue++]=U[R++];return B}}}function g(h){var w=f(h);if(w)return w;throw new Error(`Non-${e} character`)}return{encode:u,decodeUnsafe:f,decode:g}}var qn=Vn,jn=qn,ur=jn;var si=new Uint8Array(0);var dr=(t,e)=>{if(t===e)return!0;if(t.byteLength!==e.byteLength)return!1;for(let r=0;r<t.byteLength;r++)if(t[r]!==e[r])return!1;return!0},z=t=>{if(t instanceof Uint8Array&&t.constructor.name==="Uint8Array")return t;if(t instanceof ArrayBuffer)return new Uint8Array(t);if(ArrayBuffer.isView(t))return new Uint8Array(t.buffer,t.byteOffset,t.byteLength);throw new Error("Unknown type, must be binary type")};var pr=t=>new TextEncoder().encode(t),fr=t=>new TextDecoder().decode(t);var Ze=class{constructor(e,r,n){this.name=e,this.prefix=r,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},et=class{constructor(e,r,n){if(this.name=e,this.prefix=r,r.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=r.codePointAt(0),this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return mr(this,e)}},tt=class{constructor(e){this.decoders=e}or(e){return mr(this,e)}decode(e){let r=e[0],n=this.decoders[r];if(n)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}},mr=(t,e)=>new tt({...t.decoders||{[t.prefix]:t},...e.decoders||{[e.prefix]:e}}),rt=class{constructor(e,r,n,o){this.name=e,this.prefix=r,this.baseEncode=n,this.baseDecode=o,this.encoder=new Ze(e,r,n),this.decoder=new et(e,r,o)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}},ge=({name:t,prefix:e,encode:r,decode:n})=>new rt(t,e,r,n),Y=({prefix:t,name:e,alphabet:r})=>{let{encode:n,decode:o}=ur(r,e);return ge({prefix:t,name:e,encode:n,decode:s=>z(o(s))})},Gn=(t,e,r,n)=>{let o={};for(let l=0;l<e.length;++l)o[e[l]]=l;let s=t.length;for(;t[s-1]==="=";)--s;let i=new Uint8Array(s*r/8|0),a=0,p=0,y=0;for(let l=0;l<s;++l){let u=o[t[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);p=p<<r|u,a+=r,a>=8&&(a-=8,i[y++]=255&p>>a)}if(a>=r||255&p<<8-a)throw new SyntaxError("Unexpected end of data");return i},Wn=(t,e,r)=>{let n=e[e.length-1]==="=",o=(1<<r)-1,s="",i=0,a=0;for(let p=0;p<t.length;++p)for(a=a<<8|t[p],i+=8;i>r;)i-=r,s+=e[o&a>>i];if(i&&(s+=e[o&a<<r-i]),n)for(;s.length*r&7;)s+="=";return s},v=({name:t,prefix:e,bitsPerChar:r,alphabet:n})=>ge({prefix:e,name:t,encode(o){return Wn(o,n,r)},decode(o){return Gn(o,n,r,t)}});var G=v({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Jn=v({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Xn=v({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Hn=v({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Qn=v({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Kn=v({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Yn=v({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Zn=v({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),eo=v({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ot={};k(ot,{base58btc:()=>P,base58flickr:()=>to});var P=Y({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),to=Y({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var it={};k(it,{base64:()=>st,base64pad:()=>ro,base64url:()=>no,base64urlpad:()=>oo});var st=v({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),ro=v({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),no=v({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),oo=v({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});D.default.formatters.b=t=>t==null?"undefined":P.baseEncode(t);D.default.formatters.t=t=>t==null?"undefined":G.baseEncode(t);D.default.formatters.m=t=>t==null?"undefined":st.baseEncode(t);D.default.formatters.p=t=>t==null?"undefined":t.toString();D.default.formatters.c=t=>t==null?"undefined":t.toString();D.default.formatters.k=t=>t==null?"undefined":t.toString();D.default.formatters.a=t=>t==null?"undefined":t.toString();function so(t){let e=()=>{};return e.enabled=!1,e.color="",e.diff=0,e.log=()=>{},e.namespace=t,e.destroy=()=>!0,e.extend=()=>e,e}function Z(t){let e=so(`${t}:trace`);return D.default.enabled(`${t}:trace`)&&D.default.names.map(r=>r.toString()).find(r=>r.includes(":trace"))!=null&&(e=(0,D.default)(`${t}:trace`)),Object.assign((0,D.default)(t),{error:(0,D.default)(`${t}:error`),trace:e})}var io=br,gr=128,co=127,ao=~co,lo=Math.pow(2,31);function br(t,e,r){e=e||[],r=r||0;for(var n=r;t>=lo;)e[r++]=t&255|gr,t/=128;for(;t&ao;)e[r++]=t&255|gr,t>>>=7;return e[r]=t|0,br.bytes=r-n+1,e}var uo=ct,po=128,wr=127;function ct(t,n){var r=0,n=n||0,o=0,s=n,i,a=t.length;do{if(s>=a)throw ct.bytes=0,new RangeError("Could not decode varint");i=t[s++],r+=o<28?(i&wr)<<o:(i&wr)*Math.pow(2,o),o+=7}while(i>=po);return ct.bytes=s-n,r}var fo=Math.pow(2,7),ho=Math.pow(2,14),mo=Math.pow(2,21),go=Math.pow(2,28),wo=Math.pow(2,35),bo=Math.pow(2,42),xo=Math.pow(2,49),yo=Math.pow(2,56),Co=Math.pow(2,63),vo=function(t){return t<fo?1:t<ho?2:t<mo?3:t<go?4:t<wo?5:t<bo?6:t<xo?7:t<yo?8:t<Co?9:10},Eo={encode:io,decode:uo,encodingLength:vo},Ao=Eo,Pe=Ao;var Fe=(t,e=0)=>[Pe.decode(t,e),Pe.decode.bytes],we=(t,e,r=0)=>(Pe.encode(t,e,r),e),be=t=>Pe.encodingLength(t);var se=(t,e)=>{let r=e.byteLength,n=be(t),o=n+be(r),s=new Uint8Array(o+r);return we(t,s,0),we(r,s,n),s.set(e,o),new xe(t,r,e,s)},Ue=t=>{let e=z(t),[r,n]=Fe(e),[o,s]=Fe(e.subarray(n)),i=e.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new xe(r,o,i,e)},xr=(t,e)=>{if(t===e)return!0;{let r=e;return t.code===r.code&&t.size===r.size&&r.bytes instanceof Uint8Array&&dr(t.bytes,r.bytes)}},xe=class{constructor(e,r,n,o){this.code=e,this.size=r,this.digest=n,this.bytes=o}};var yr=(t,e)=>{let{bytes:r,version:n}=t;switch(n){case 0:return So(r,at(t),e||P.encoder);default:return To(r,at(t),e||G.encoder)}};var Cr=new WeakMap,at=t=>{let e=Cr.get(t);if(e==null){let r=new Map;return Cr.set(t,r),r}return e},ee=class t{constructor(e,r,n,o){this.code=r,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:r}=this;if(e!==Oe)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(r.code!==Po)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return t.createV0(r)}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:r}=this.multihash,n=se(e,r);return t.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 t.equals(this,e)}static equals(e,r){let n=r;return n&&e.code===n.code&&e.version===n.version&&xr(e.multihash,n.multihash)}toString(e){return yr(this,e)}toJSON(){return{"/":yr(this)}}link(){return this}get[Symbol.toStringTag](){return"CID"}[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let r=e;if(r instanceof t)return r;if(r["/"]!=null&&r["/"]===r.bytes||r.asCID===r){let{version:n,code:o,multihash:s,bytes:i}=r;return new t(n,o,s,i||vr(n,o,s.bytes))}else if(r[Fo]===!0){let{version:n,multihash:o,code:s}=r,i=Ue(o);return t.create(n,s,i)}else return null}static create(e,r,n){if(typeof r!="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(r!==Oe)throw new Error(`Version 0 CID must use dag-pb (code: ${Oe}) block encoding`);return new t(e,r,n,n.bytes)}case 1:{let o=vr(e,r,n.bytes);return new t(e,r,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return t.create(0,Oe,e)}static createV1(e,r){return t.create(1,e,r)}static decode(e){let[r,n]=t.decodeFirst(e);if(n.length)throw new Error("Incorrect length");return r}static decodeFirst(e){let r=t.inspectBytes(e),n=r.size-r.multihashSize,o=z(e.subarray(n,n+r.multihashSize));if(o.byteLength!==r.multihashSize)throw new Error("Incorrect length");let s=o.subarray(r.multihashSize-r.digestSize),i=new xe(r.multihashCode,r.digestSize,s,o);return[r.version===0?t.createV0(i):t.createV1(r.codec,i),e.subarray(r.size)]}static inspectBytes(e){let r=0,n=()=>{let[u,f]=Fe(e.subarray(r));return r+=f,u},o=n(),s=Oe;if(o===18?(o=0,r=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=r,a=n(),p=n(),y=r+p,l=y-i;return{version:o,codec:s,multihashCode:a,digestSize:p,multihashSize:l,size:y}}static parse(e,r){let[n,o]=Io(e,r),s=t.decode(o);if(s.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return at(s).set(n,e),s}},Io=(t,e)=>{switch(t[0]){case"Q":{let r=e||P;return[P.prefix,r.decode(`${P.prefix}${t}`)]}case P.prefix:{let r=e||P;return[P.prefix,r.decode(t)]}case G.prefix:{let r=e||G;return[G.prefix,r.decode(t)]}default:{if(e==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[t[0],e.decode(t)]}}},So=(t,e,r)=>{let{prefix:n}=r;if(n!==P.prefix)throw Error(`Cannot string encode V0 in ${r.name} encoding`);let o=e.get(n);if(o==null){let s=r.encode(t).slice(1);return e.set(n,s),s}else return o},To=(t,e,r)=>{let{prefix:n}=r,o=e.get(n);if(o==null){let s=r.encode(t);return e.set(n,s),s}else return o},Oe=112,Po=18,vr=(t,e,r)=>{let n=be(t),o=n+be(e),s=new Uint8Array(o+r.byteLength);return we(t,s,0),we(e,s,n),s.set(r,o),s},Fo=Symbol.for("@ipld/js-cid/CID");function Er(t,e){if(t===e)return!0;if(t.byteLength!==e.byteLength)return!1;for(let r=0;r<t.byteLength;r++)if(t[r]!==e[r])return!1;return!0}var lt={};k(lt,{base10:()=>Oo});var Oo=Y({prefix:"9",name:"base10",alphabet:"0123456789"});var ut={};k(ut,{base16:()=>Ro,base16upper:()=>Mo});var Ro=v({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Mo=v({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var dt={};k(dt,{base2:()=>ko});var ko=v({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var pt={};k(pt,{base256emoji:()=>Uo});var Ar=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}"),No=Ar.reduce((t,e,r)=>(t[r]=e,t),[]),Lo=Ar.reduce((t,e,r)=>(t[e.codePointAt(0)]=r,t),[]);function Do(t){return t.reduce((e,r)=>(e+=No[r],e),"")}function _o(t){let e=[];for(let r of t){let n=Lo[r.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${r}`);e.push(n)}return new Uint8Array(e)}var Uo=ge({prefix:"\u{1F680}",name:"base256emoji",encode:Do,decode:_o});var ft={};k(ft,{base36:()=>$o,base36upper:()=>Bo});var $o=Y({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Bo=Y({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var ht={};k(ht,{base8:()=>zo});var zo=v({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var mt={};k(mt,{identity:()=>Vo});var Vo=ge({prefix:"\0",name:"identity",encode:t=>fr(t),decode:t=>pr(t)});var ki=new TextEncoder,Ni=new TextDecoder;var gt={};k(gt,{identity:()=>Jo});var Ir=0,Go="identity",Sr=z,Wo=t=>se(Ir,Sr(t)),Jo={code:Ir,name:Go,encode:Sr,digest:Wo};var yt={};k(yt,{sha256:()=>Xo,sha512:()=>Ho});var xt=ne(X("crypto"),1);var bt=({name:t,code:e,encode:r})=>new wt(t,e,r),wt=class{constructor(e,r,n){this.name=e,this.code=r,this.encode=n}digest(e){if(e instanceof Uint8Array){let r=this.encode(e);return r instanceof Uint8Array?se(this.code,r):r.then(n=>se(this.code,n))}else throw Error("Unknown type, must be binary type")}};var Xo=bt({name:"sha2-256",code:18,encode:t=>z(xt.default.createHash("sha256").update(t).digest())}),Ho=bt({name:"sha2-512",code:19,encode:t=>z(xt.default.createHash("sha512").update(t).digest())});var Re={...mt,...dt,...ht,...lt,...ut,...nt,...ft,...ot,...it,...pt},qi={...yt,...gt};function Ce(t){return globalThis.Buffer!=null?new Uint8Array(t.buffer,t.byteOffset,t.byteLength):t}function ve(t=0){return globalThis.Buffer?.allocUnsafe!=null?Ce(globalThis.Buffer.allocUnsafe(t)):new Uint8Array(t)}function Fr(t,e,r,n){return{name:t,prefix:e,encoder:{name:t,prefix:e,encode:r},decoder:{decode:n}}}var Pr=Fr("utf8","u",t=>"u"+new TextDecoder("utf8").decode(t),t=>new TextEncoder().encode(t.substring(1))),Ct=Fr("ascii","a",t=>{let e="a";for(let r=0;r<t.length;r++)e+=String.fromCharCode(t[r]);return e},t=>{t=t.substring(1);let e=ve(t.length);for(let r=0;r<t.length;r++)e[r]=t.charCodeAt(r);return e}),Qo={utf8:Pr,"utf-8":Pr,hex:Re.base16,latin1:Ct,ascii:Ct,binary:Ct,...Re},$e=Qo;function O(t,e="utf8"){let r=$e[e];if(r==null)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?globalThis.Buffer.from(t.buffer,t.byteOffset,t.byteLength).toString("utf8"):r.encoder.encode(t).substring(1)}var Ko=Math.pow(2,7),Yo=Math.pow(2,14),Zo=Math.pow(2,21),vt=Math.pow(2,28),Et=Math.pow(2,35),At=Math.pow(2,42),It=Math.pow(2,49),b=128,F=127;function W(t){if(t<Ko)return 1;if(t<Yo)return 2;if(t<Zo)return 3;if(t<vt)return 4;if(t<Et)return 5;if(t<At)return 6;if(t<It)return 7;if(Number.MAX_SAFE_INTEGER!=null&&t>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function es(t,e,r=0){switch(W(t)){case 8:e[r++]=t&255|b,t/=128;case 7:e[r++]=t&255|b,t/=128;case 6:e[r++]=t&255|b,t/=128;case 5:e[r++]=t&255|b,t/=128;case 4:e[r++]=t&255|b,t>>>=7;case 3:e[r++]=t&255|b,t>>>=7;case 2:e[r++]=t&255|b,t>>>=7;case 1:{e[r++]=t&255,t>>>=7;break}default:throw new Error("unreachable")}return e}function ts(t,e,r=0){switch(W(t)){case 8:e.set(r++,t&255|b),t/=128;case 7:e.set(r++,t&255|b),t/=128;case 6:e.set(r++,t&255|b),t/=128;case 5:e.set(r++,t&255|b),t/=128;case 4:e.set(r++,t&255|b),t>>>=7;case 3:e.set(r++,t&255|b),t>>>=7;case 2:e.set(r++,t&255|b),t>>>=7;case 1:{e.set(r++,t&255),t>>>=7;break}default:throw new Error("unreachable")}return e}function rs(t,e){let r=t[e],n=0;if(n+=r&F,r<b||(r=t[e+1],n+=(r&F)<<7,r<b)||(r=t[e+2],n+=(r&F)<<14,r<b)||(r=t[e+3],n+=(r&F)<<21,r<b)||(r=t[e+4],n+=(r&F)*vt,r<b)||(r=t[e+5],n+=(r&F)*Et,r<b)||(r=t[e+6],n+=(r&F)*At,r<b)||(r=t[e+7],n+=(r&F)*It,r<b))return n;throw new RangeError("Could not decode varint")}function ns(t,e){let r=t.get(e),n=0;if(n+=r&F,r<b||(r=t.get(e+1),n+=(r&F)<<7,r<b)||(r=t.get(e+2),n+=(r&F)<<14,r<b)||(r=t.get(e+3),n+=(r&F)<<21,r<b)||(r=t.get(e+4),n+=(r&F)*vt,r<b)||(r=t.get(e+5),n+=(r&F)*Et,r<b)||(r=t.get(e+6),n+=(r&F)*At,r<b)||(r=t.get(e+7),n+=(r&F)*It,r<b))return n;throw new RangeError("Could not decode varint")}function Ee(t,e,r=0){return e==null&&(e=ve(W(t))),e instanceof Uint8Array?es(t,e,r):ts(t,e,r)}function ie(t,e=0){return t instanceof Uint8Array?rs(t,e):ns(t,e)}function H(t,e){e==null&&(e=t.reduce((o,s)=>o+s.length,0));let r=ve(e),n=0;for(let o of t)r.set(o,n),n+=o.length;return Ce(r)}var Be=class{index=0;input="";new(e){return this.index=0,this.input=e,this}readAtomically(e){let r=this.index,n=e();return n===void 0&&(this.index=r),n}parseWith(e){let r=e();if(this.index===this.input.length)return r}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 r=this.readChar();if(r===e)return r})}readSeparator(e,r,n){return this.readAtomically(()=>{if(!(r>0&&this.readGivenChar(e)===void 0))return n()})}readNumber(e,r,n,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let p=a==="0",y=2**(8*o)-1;for(;;){let l=this.readAtomically(()=>{let u=this.readChar();if(u===void 0)return;let f=Number.parseInt(u,e);if(!Number.isNaN(f))return f});if(l===void 0)break;if(s*=e,s+=l,s>y||(i+=1,r!==void 0&&i>r))return}if(i!==0)return!n&&p&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let e=new Uint8Array(4);for(let r=0;r<e.length;r++){let n=this.readSeparator(".",r,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;e[r]=n}return e})}readIPv6Addr(){let e=r=>{for(let n=0;n<r.length/2;n++){let o=n*2;if(n<r.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return r[o]=i[0],r[o+1]=i[1],r[o+2]=i[2],r[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];r[o]=s>>8,r[o+1]=s&255}return[r.length,!1]};return this.readAtomically(()=>{let r=new Uint8Array(16),[n,o]=e(r);if(n===16)return r;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 r.set(s.subarray(0,a),16-a),r})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var sc=new Be;var fc=parseInt("0xFFFF",16),hc=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function St(t,e="utf8"){let r=$e[e];if(r==null)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?Ce(globalThis.Buffer.from(t,"utf-8")):r.decoder.decode(`${r.prefix}${t}`)}var V=X("node:net");function ze(t){return!!(0,V.isIP)(t)}var kr=V.isIPv4,ls=V.isIPv6,Tt=function(t){let e=0;if(t=t.toString().trim(),kr(t)){let r=new Uint8Array(e+4);return t.split(/\./g).forEach(n=>{r[e++]=parseInt(n,10)&255}),r}if(ls(t)){let r=t.split(":",8),n;for(n=0;n<r.length;n++){let s=kr(r[n]),i;s&&(i=Tt(r[n]),r[n]=O(i.slice(0,2),"base16")),i!=null&&++n<8&&r.splice(n,0,O(i.slice(2,4),"base16"))}if(r[0]==="")for(;r.length<8;)r.unshift("0");else if(r[r.length-1]==="")for(;r.length<8;)r.push("0");else if(r.length<8){for(n=0;n<r.length&&r[n]!=="";n++);let s=[n,1];for(n=9-r.length;n>0;n--)s.push("0");r.splice.apply(r,s)}let o=new Uint8Array(e+16);for(n=0;n<r.length;n++){let s=parseInt(r[n],16);o[e++]=s>>8&255,o[e++]=s&255}return o}throw new Error("invalid ip address")},Nr=function(t,e=0,r){e=~~e,r=r??t.length-e;let n=new DataView(t.buffer);if(r===4){let o=[];for(let s=0;s<r;s++)o.push(t[e+s]);return o.join(".")}if(r===16){let o=[];for(let s=0;s<r;s+=2)o.push(n.getUint16(e+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var Ae={},Pt={},ds=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[777,-1,"memory"]];ds.forEach(t=>{let e=ps(...t);Pt[e.code]=e,Ae[e.name]=e});function ps(t,e,r,n,o){return{code:t,size:e,name:r,resolvable:!!n,path:!!o}}function x(t){if(typeof t=="number"){if(Pt[t]!=null)return Pt[t];throw new Error(`no protocol with code: ${t}`)}else if(typeof t=="string"){if(Ae[t]!=null)return Ae[t];throw new Error(`no protocol with name: ${t}`)}throw new Error(`invalid protocol id type: ${typeof t}`)}var ta=x("ip4"),ra=x("ip6"),na=x("ipcidr");function Ot(t,e){switch(x(t).code){case 4:case 41:return hs(e);case 42:return _r(e);case 6:case 273:case 33:case 132:return $r(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return _r(e);case 421:return bs(e);case 444:return Ur(e);case 445:return Ur(e);case 466:return ws(e);default:return O(e,"base16")}}function Rt(t,e){switch(x(t).code){case 4:return Lr(e);case 41:return Lr(e);case 42:return Dr(e);case 6:case 273:case 33:case 132:return Mt(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Dr(e);case 421:return ms(e);case 444:return xs(e);case 445:return ys(e);case 466:return gs(e);default:return St(e,"base16")}}var Ft=Object.values(Re).map(t=>t.decoder),fs=function(){let t=Ft[0].or(Ft[1]);return Ft.slice(2).forEach(e=>t=t.or(e)),t}();function Lr(t){if(!ze(t))throw new Error("invalid ip address");return Tt(t)}function hs(t){let e=Nr(t,0,t.length);if(e==null)throw new Error("ipBuff is required");if(!ze(e))throw new Error("invalid ip address");return e}function Mt(t){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,t),new Uint8Array(e)}function $r(t){return new DataView(t.buffer).getUint16(t.byteOffset)}function Dr(t){let e=St(t),r=Uint8Array.from(Ee(e.length));return H([r,e],r.length+e.length)}function _r(t){let e=ie(t);if(t=t.slice(W(e)),t.length!==e)throw new Error("inconsistent lengths");return O(t)}function ms(t){let e;t[0]==="Q"||t[0]==="1"?e=Ue(P.decode(`z${t}`)).bytes:e=ee.parse(t).multihash.bytes;let r=Uint8Array.from(Ee(e.length));return H([r,e],r.length+e.length)}function gs(t){let e=fs.decode(t),r=Uint8Array.from(Ee(e.length));return H([r,e],r.length+e.length)}function ws(t){let e=ie(t),r=t.slice(W(e));if(r.length!==e)throw new Error("inconsistent lengths");return"u"+O(r,"base64url")}function bs(t){let e=ie(t),r=t.slice(W(e));if(r.length!==e)throw new Error("inconsistent lengths");return O(r,"base58btc")}function xs(t){let e=t.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 r=G.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=Mt(n);return H([r,o],r.length+o.length)}function ys(t){let e=t.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 r=G.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=Mt(n);return H([r,o],r.length+o.length)}function Ur(t){let e=t.slice(0,t.length-2),r=t.slice(t.length-2),n=O(e,"base32"),o=$r(r);return`${n}:${o}`}function Br(t){t=kt(t);let e=[],r=[],n=null,o=t.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=x(i);if(a.size===0){e.push([a.code]),r.push([a.code]);continue}if(s++,s>=o.length)throw Vr("invalid address: "+t);if(a.path===!0){n=kt(o.slice(s).join("/")),e.push([a.code,Rt(a.code,n)]),r.push([a.code,n]);break}let p=Rt(a.code,o[s]);e.push([a.code,p]),r.push([a.code,Ot(a.code,p)])}return{string:zr(r),bytes:Lt(e),tuples:e,stringTuples:r,path:n}}function Nt(t){let e=[],r=[],n=null,o=0;for(;o<t.length;){let s=ie(t,o),i=W(s),a=x(s),p=Cs(a,t.slice(o+i));if(p===0){e.push([s]),r.push([s]),o+=i;continue}let y=t.slice(o+i,o+i+p);if(o+=p+i,o>t.length)throw Vr("Invalid address Uint8Array: "+O(t,"base16"));e.push([s,y]);let l=Ot(s,y);if(r.push([s,l]),a.path===!0){n=l;break}}return{bytes:Uint8Array.from(t),string:zr(r),tuples:e,stringTuples:r,path:n}}function zr(t){let e=[];return t.map(r=>{let n=x(r[0]);return e.push(n.name),r.length>1&&r[1]!=null&&e.push(r[1]),null}),kt(e.join("/"))}function Lt(t){return H(t.map(e=>{let r=x(e[0]),n=Uint8Array.from(Ee(r.code));return e.length>1&&e[1]!=null&&(n=H([n,e[1]])),n}))}function Cs(t,e){if(t.size>0)return t.size/8;if(t.size===0)return 0;{let r=ie(e instanceof Uint8Array?e:Uint8Array.from(e));return r+W(r)}}function kt(t){return"/"+t.trim().split("/").filter(e=>e).join("/")}function Vr(t){return new Error("Error parsing address: "+t)}var vs=Symbol.for("nodejs.util.inspect.custom"),Es=[x("dns").code,x("dns4").code,x("dns6").code,x("dnsaddr").code],As=new Map,qr=Symbol.for("@multiformats/js-multiaddr/multiaddr");function Is(t){return!!t?.[qr]}var Dt=class t{bytes;#e;#t;#r;#n;[qr]=!0;constructor(e){e==null&&(e="");let r;if(e instanceof Uint8Array)r=Nt(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);r=Br(e)}else if(Is(e))r=Nt(e.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=r.bytes,this.#e=r.string,this.#t=r.tuples,this.#r=r.stringTuples,this.#n=r.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let e,r,n,o,s="",i=x("tcp"),a=x("udp"),p=x("ip4"),y=x("ip6"),l=x("dns6"),u=x("ip6zone");for(let[g,h]of this.stringTuples())g===u.code&&(s=`%${h??""}`),Es.includes(g)&&(r=i.name,o=443,n=`${h??""}${s}`,e=g===l.code?6:4),(g===i.code||g===a.code)&&(r=x(g).name,o=parseInt(h??"")),(g===p.code||g===y.code)&&(r=x(g).name,n=`${h??""}${s}`,e=g===y.code?6:4);if(e==null||r==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:e,host:n,transport:r,port:o}}protos(){return this.#t.map(([e])=>Object.assign({},x(e)))}protoCodes(){return this.#t.map(([e])=>e)}protoNames(){return this.#t.map(([e])=>x(e).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(e){return e=new t(e),new t(this.toString()+e.toString())}decapsulate(e){let r=e.toString(),n=this.toString(),o=n.lastIndexOf(r);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${e.toString()}`);return new t(n.slice(0,o))}decapsulateCode(e){let r=this.tuples();for(let n=r.length-1;n>=0;n--)if(r[n][0]===e)return new t(Lt(r.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,o])=>{n===Ae.p2p.code&&e.push([n,o]),n===Ae["p2p-circuit"].code&&(e=[])});let r=e.pop();if(r?.[1]!=null){let n=r[1];return n[0]==="Q"||n[0]==="1"?O(P.decode(`z${n}`),"base58btc"):O(ee.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(e){return Er(this.bytes,e.bytes)}async resolve(e){let r=this.protos().find(s=>s.resolvable);if(r==null)return[this];let n=As.get(r.name);if(n==null)throw new N(`no available resolver for ${r.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,e)).map(s=>new t(s))}nodeAddress(){let e=this.toOptions();if(e.transport!=="tcp"&&e.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${e.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:e.family,address:e.host,port:e.port}}isThinWaistAddress(e){let r=(e??this).protos();return!(r.length!==2||r[0].code!==4&&r[0].code!==41||r[1].code!==6&&r[1].code!==273)}[vs](){return`Multiaddr(${this.#e})`}};function Q(t){return new Dt(t)}var Ss=c("dns4"),Ts=c("dns6"),Ps=c("dnsaddr"),ae=E(c("dns"),Ps,Ss,Ts),je=E(c("ip4"),c("ip6")),re=E(d(je,c("tcp")),d(ae,c("tcp"))),Ge=d(je,c("udp")),Fs=d(Ge,c("utp")),Os=d(Ge,c("quic")),Rs=d(Ge,c("quic-v1")),_t=E(d(re,c("ws")),d(ae,c("ws"))),Ve=E(d(_t,c("p2p")),_t),Ut=E(d(re,c("wss")),d(ae,c("wss")),d(re,c("tls"),c("ws")),d(ae,c("tls"),c("ws"))),qe=E(d(Ut,c("p2p")),Ut),$t=E(d(re,c("http")),d(je,c("http")),d(ae,c("http"))),Bt=E(d(re,c("https")),d(je,c("https")),d(ae,c("https"))),jr=d(Ge,c("webrtc-direct"),c("certhash")),Jr=E(d(jr,c("p2p")),jr),Gr=d(Rs,c("webtransport"),c("certhash"),c("certhash")),Xr=E(d(Gr,c("p2p")),Gr),Hr=E(d(Ve,c("p2p-webrtc-star"),c("p2p")),d(qe,c("p2p-webrtc-star"),c("p2p")),d(Ve,c("p2p-webrtc-star")),d(qe,c("p2p-webrtc-star"))),Ia=E(d(Ve,c("p2p-websocket-star"),c("p2p")),d(qe,c("p2p-websocket-star"),c("p2p")),d(Ve,c("p2p-websocket-star")),d(qe,c("p2p-websocket-star"))),Qr=E(d($t,c("p2p-webrtc-direct"),c("p2p")),d(Bt,c("p2p-webrtc-direct"),c("p2p")),d($t,c("p2p-webrtc-direct")),d(Bt,c("p2p-webrtc-direct"))),le=E(_t,Ut,$t,Bt,Hr,Qr,re,Fs,Os,ae,Jr,Xr),Sa=E(d(le,c("p2p-stardust"),c("p2p")),d(le,c("p2p-stardust"))),te=E(d(le,c("p2p")),Hr,Qr,Jr,Xr,c("p2p")),Wr=E(d(te,c("p2p-circuit"),te),d(te,c("p2p-circuit")),d(c("p2p-circuit"),te),d(le,c("p2p-circuit")),d(c("p2p-circuit"),le),c("p2p-circuit")),Kr=()=>E(d(Wr,Kr),Wr),ce=Kr(),Ta=E(d(ce,te,ce),d(te,ce),d(ce,te),ce,te);var Pa=E(d(ce,c("webrtc"),c("p2p")),d(ce,c("webrtc")),d(le,c("webrtc"),c("p2p")),d(le,c("webrtc")),c("webrtc"));function Yr(t){function e(r){let n;try{n=Q(r)}catch{return!1}let o=t(n.protoNames());return o===null?!1:o===!0||o===!1?o:o.length===0}return e}function d(...t){function e(r){if(r.length<t.length)return null;let n=r;return t.some(o=>(n=typeof o=="function"?o().partialMatch(r):o.partialMatch(r),Array.isArray(n)&&(r=n),n===null)),n}return{toString:function(){return"{ "+t.join(" ")+" }"},input:t,matches:Yr(e),partialMatch:e}}function E(...t){function e(n){let o=null;return t.some(s=>{let i=typeof s=="function"?s().partialMatch(n):s.partialMatch(n);return i!=null?(o=i,!0):!1}),o}return{toString:function(){return"{ "+t.join(" ")+" }"},input:t,matches:Yr(e),partialMatch:e}}function c(t){let e=t;function r(o){let s;try{s=Q(o)}catch{return!1}let i=s.protoNames();return i.length===1&&i[0]===e}function n(o){return o.length===0?null:o[0]===e?o.slice(1):null}return{toString:function(){return e},matches:r,partialMatch:n}}var dn=ne(X("net"),1);var We=class extends EventTarget{#e=new Map;listenerCount(e){let r=this.#e.get(e);return r==null?0:r.length}addEventListener(e,r,n){super.addEventListener(e,r,n);let o=this.#e.get(e);o==null&&(o=[],this.#e.set(e,o)),o.push({callback:r,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(e,r,n){super.removeEventListener(e.toString(),r??null,n);let o=this.#e.get(e);o!=null&&(o=o.filter(({callback:s})=>s!==r),this.#e.set(e,o))}dispatchEvent(e){let r=super.dispatchEvent(e),n=this.#e.get(e.type);return n==null||(n=n.filter(({once:o})=>!o),this.#e.set(e.type,n)),r}safeDispatchEvent(e,r){return this.dispatchEvent(new Ie(e,r))}},zt=class extends Event{detail;constructor(e,r){super(e,r),this.detail=r?.detail}},Ie=globalThis.CustomEvent??zt;var ks=Z("libp2p:ip-port-to-multiaddr"),Vt={ERR_INVALID_IP_PARAMETER:"ERR_INVALID_IP_PARAMETER",ERR_INVALID_PORT_PARAMETER:"ERR_INVALID_PORT_PARAMETER",ERR_INVALID_IP:"ERR_INVALID_IP"};function Zr(t,e){if(typeof t!="string")throw new N(`invalid ip provided: ${t}`,Vt.ERR_INVALID_IP_PARAMETER);if(typeof e=="string"&&(e=parseInt(e)),isNaN(e))throw new N(`invalid port provided: ${e}`,Vt.ERR_INVALID_PORT_PARAMETER);if((0,V.isIPv4)(t))return Q(`/ip4/${t}/tcp/${e}`);if((0,V.isIPv6)(t))return Q(`/ip6/${t}/tcp/${e}`);let r=`invalid ip:port for creating a multiaddr: ${t}:${e}`;throw ks.error(r),new N(r,Vt.ERR_INVALID_IP)}var un=ne(an(),1);var Gt=ne(X("os"),1),ln=ne(X("path"),1);var Us={ip4:"IPv4",ip6:"IPv6"};function Te(t,e={}){let r=t.getPath();return r!=null?Gt.default.platform()==="win32"?{path:ln.default.join("\\\\.\\pipe\\",r)}:{path:r}:{...t.toOptions(),...e}}function Wt(t,e,r){let n=o=>Q(`/${t}/${o}/tcp/${r}`);return($s(e)?zs(Us[t]):[e]).map(n)}function $s(t){return["0.0.0.0","::"].includes(t)}var Bs=Gt.default.networkInterfaces();function zs(t){let e=[];for(let[,r]of Object.entries(Bs))if(r!=null)for(let n of r)n.family===t&&e.push(n.address);return e}var J=Z("libp2p:tcp:socket"),Xe=(t,e)=>{let r=e.metrics,n=e.metricPrefix??"",o=e.socketInactivityTimeout??3e5,s=e.socketCloseTimeout??500;e.listeningAddr?.getPath()!=null&&(e.remoteAddr=e.listeningAddr),e.remoteAddr?.getPath()!=null&&(e.localAddr=e.remoteAddr);let i;if(e.remoteAddr!=null)i=e.remoteAddr;else{if(t.remoteAddress==null||t.remotePort==null)throw new N("Could not determine remote address or port","ERR_NO_REMOTE_ADDRESS");i=Zr(t.remoteAddress,t.remotePort)}let a=Te(i),p=a.path??`${a.host??""}:${a.port??""}`,{sink:y,source:l}=un.default.duplex(t);t.setTimeout(o,()=>{J("%s socket read timeout",p),r?.increment({[`${n}timeout`]:!0});let f;t.readable&&(f=new N("Socket read timeout","ERR_SOCKET_READ_TIMEOUT")),t.destroy(f)}),t.once("close",()=>{J("%s socket close",p),r?.increment({[`${n}close`]:!0}),u.timeline.close==null&&(u.timeline.close=Date.now())}),t.once("end",()=>{J("%s socket end",p),r?.increment({[`${n}end`]:!0})});let u={async sink(f){try{await y(f)}catch(g){g.type!=="aborted"&&J(g)}t.end()},source:l,remoteAddr:i,timeline:{open:Date.now()},async close(f={}){if(t.destroyed){J("%s socket was already destroyed when trying to close",p);return}f.signal=f.signal??AbortSignal.timeout(s);try{J("%s closing socket",p),await new Promise((g,h)=>{t.once("close",()=>{J("%s socket closed",p),g()}),t.once("error",w=>{J("%s socket error",p,w),u.timeline.close==null&&(u.timeline.close=Date.now()),h(w)}),t.setTimeout(s),t.end(),t.writableLength>0?t.once("drain",()=>{J("%s socket drained",p),t.destroy()}):t.destroy()})}catch(g){this.abort(g)}},abort:f=>{J("%s socket abort due to error",p,f),t.destroy(f)}};return u};var _=Z("libp2p:tcp:listener");async function Jt(t){try{await t.close()}catch(e){_.error("an error occurred closing the connection",e)}}var js=1,Gs=0,He=class extends We{context;server;connections=new Set;status={started:!1};metrics;addr;constructor(e){if(super(),this.context=e,e.keepAlive=e.keepAlive??!0,this.addr="unknown",this.server=dn.default.createServer(e,this.onSocket.bind(this)),e.maxConnections!==void 0&&(this.server.maxConnections=e.maxConnections),e.closeServerOnMaxConnections!=null&&e.closeServerOnMaxConnections.closeAbove<e.closeServerOnMaxConnections.listenBelow)throw Error("closeAbove must be >= listenBelow");this.server.on("listening",()=>{if(e.metrics!=null){let r=this.server.address();r==null?this.addr="unknown":typeof r=="string"?this.addr=r:this.addr=`${r.address}:${r.port}`,e.metrics?.registerMetricGroup("libp2p_tcp_inbound_connections_total",{label:"address",help:"Current active connections in TCP listener",calculate:()=>({[this.addr]:this.connections.size})}),this.metrics={status:e.metrics.registerMetricGroup("libp2p_tcp_listener_status_info",{label:"address",help:"Current status of the TCP listener socket"}),errors:e.metrics.registerMetricGroup("libp2p_tcp_listener_errors_total",{label:"address",help:"Total count of TCP listener errors by type"}),events:e.metrics.registerMetricGroup("libp2p_tcp_listener_events_total",{label:"address",help:"Total count of TCP listener events by type"})},this.metrics?.status.update({[this.addr]:js})}this.dispatchEvent(new Ie("listening"))}).on("error",r=>{this.metrics?.errors.increment({[`${this.addr} listen_error`]:!0}),this.dispatchEvent(new Ie("error",{detail:r}))}).on("close",()=>{this.metrics?.status.update({[this.addr]:Gs}),this.dispatchEvent(new Ie("close"))})}onSocket(e){e.on("error",n=>{_("socket error",n),this.metrics?.events.increment({[`${this.addr} error`]:!0})});let r;try{r=Xe(e,{listeningAddr:this.status.started?this.status.listeningAddr:void 0,socketInactivityTimeout:this.context.socketInactivityTimeout,socketCloseTimeout:this.context.socketCloseTimeout,metrics:this.metrics?.events,metricPrefix:`${this.addr} `})}catch(n){_.error("inbound connection failed",n),this.metrics?.errors.increment({[`${this.addr} inbound_to_connection`]:!0});return}_("new inbound connection %s",r.remoteAddr);try{this.context.upgrader.upgradeInbound(r).then(n=>{_("inbound connection upgraded %s",r.remoteAddr),this.connections.add(r),e.once("close",()=>{this.connections.delete(r),this.context.closeServerOnMaxConnections!=null&&this.connections.size<this.context.closeServerOnMaxConnections.listenBelow&&this.netListen().catch(o=>{_.error("error attempting to listen server once connection count under limit",o),this.context.closeServerOnMaxConnections?.onListenError?.(o)})}),this.context.handler!=null&&this.context.handler(n),this.context.closeServerOnMaxConnections!=null&&this.connections.size>=this.context.closeServerOnMaxConnections.closeAbove&&this.netClose(),this.dispatchEvent(new Ie("connection",{detail:n}))}).catch(async n=>{_.error("inbound connection failed",n),this.metrics?.errors.increment({[`${this.addr} inbound_upgrade`]:!0}),await Jt(r)}).catch(n=>{_.error("closing inbound connection failed",n)})}catch(n){_.error("inbound connection failed",n),Jt(r).catch(o=>{_.error("closing inbound connection failed",o),this.metrics?.errors.increment({[`${this.addr} inbound_closing_failed`]:!0})})}}getAddrs(){if(!this.status.started)return[];let e=[],r=this.server.address(),{listeningAddr:n,peerId:o}=this.status;if(r==null)return[];if(typeof r=="string")e=[n];else try{n.toString().startsWith("/ip4")?e=e.concat(Wt("ip4",r.address,r.port)):r.family==="IPv6"&&(e=e.concat(Wt("ip6",r.address,r.port)))}catch(s){_.error("could not turn %s:%s into multiaddr",r.address,r.port,s)}return e.map(s=>o!=null?s.encapsulate(`/p2p/${o}`):s)}async listen(e){if(this.status.started)throw Error("server is already listening");let r=e.getPeerId(),n=r==null?e.decapsulateCode(421):e,{backlog:o}=this.context;this.status={started:!0,listeningAddr:n,peerId:r,netConfig:Te(n,{backlog:o})},await this.netListen()}async close(){await Promise.all(Array.from(this.connections.values()).map(async e=>{await Jt(e)})),this.netClose()}async netListen(){if(!this.status.started||this.server.listening)return;let e=this.status.netConfig;await new Promise((r,n)=>{this.server.once("error",n),this.server.listen(e,r)}),_("Listening on %s",this.server.address())}netClose(){!this.status.started||!this.server.listening||(_("Closing server on %s",this.server.address()),this.server.close())}};var K=Z("libp2p:tcp"),Ht=class{opts;metrics;components;constructor(e,r={}){this.opts=r,this.components=e,e.metrics!=null&&(this.metrics={dialerEvents:e.metrics.registerCounterGroup("libp2p_tcp_dialer_events_total",{label:"event",help:"Total count of TCP dialer events by type"})})}[Yt]=!0;[Symbol.toStringTag]="@libp2p/tcp";async dial(e,r){r.keepAlive=r.keepAlive??!0;let n=await this._connect(e,r);n.on("error",a=>{K("socket error",a)});let o=Xe(n,{remoteAddr:e,socketInactivityTimeout:this.opts.outboundSocketInactivityTimeout,socketCloseTimeout:this.opts.socketCloseTimeout,metrics:this.metrics?.dialerEvents}),s=()=>{o.close().catch(a=>{K.error("Error closing maConn after abort",a)})};r.signal?.addEventListener("abort",s,{once:!0}),K("new outbound connection %s",o.remoteAddr);let i=await r.upgrader.upgradeOutbound(o);if(K("outbound connection %s upgraded",o.remoteAddr),r.signal?.removeEventListener("abort",s),r.signal?.aborted===!0)throw i.close().catch(a=>{K.error("Error closing conn after abort",a)}),new de;return i}async _connect(e,r){if(r.signal?.aborted===!0)throw new de;return new Promise((n,o)=>{let s=Date.now(),i=Te(e),a=i.path??`${i.host??""}:${i.port}`;K("dialing %j",i);let p=pn.default.connect(i),y=h=>{h.message=`connection error ${a}: ${h.message}`,this.metrics?.dialerEvents.increment({error:!0}),g(h)},l=()=>{K("connection timeout %s",a),this.metrics?.dialerEvents.increment({timeout:!0});let h=new N(`connection timeout after ${Date.now()-s}ms`,"ERR_CONNECT_TIMEOUT");p.emit("error",h)},u=()=>{K("connection opened %j",i),this.metrics?.dialerEvents.increment({connect:!0}),g()},f=()=>{K("connection aborted %j",i),this.metrics?.dialerEvents.increment({abort:!0}),p.destroy(),g(new de)},g=h=>{if(p.removeListener("error",y),p.removeListener("timeout",l),p.removeListener("connect",u),r.signal!=null&&r.signal.removeEventListener("abort",f),h!=null){o(h);return}n(p)};p.on("error",y),p.on("timeout",l),p.on("connect",u),r.signal!=null&&r.signal.addEventListener("abort",f)})}createListener(e){return new He({...e,maxConnections:this.opts.maxConnections,backlog:this.opts.backlog,closeServerOnMaxConnections:this.opts.closeServerOnMaxConnections,socketInactivityTimeout:this.opts.inboundSocketInactivityTimeout,socketCloseTimeout:this.opts.socketCloseTimeout,metrics:this.components.metrics})}filter(e){return e=Array.isArray(e)?e:[e],e.filter(r=>r.protoCodes().includes(290)?!1:r.protoCodes().includes(400)?!0:re.matches(r.decapsulateCode(421)))}};function Xs(t={}){return(e={})=>new Ht(e,t)}return bn(Hs);})();
4
+ `+s),t.push(o+"m+"+Ue.exports.humanize(this.diff)+"\x1B[0m")}else t[0]=Ln()+e+" "+t[0]}function Ln(){return P.inspectOpts.hideDate?"":new Date().toISOString()+" "}function $n(...t){return process.stderr.write(_e.format(...t)+`
5
+ `)}function Vn(t){t?process.env.DEBUG=t:delete process.env.DEBUG}function Bn(){return process.env.DEBUG}function zn(t){t.inspectOpts={};let e=Object.keys(P.inspectOpts);for(let r=0;r<e.length;r++)t.inspectOpts[e[r]]=P.inspectOpts[e[r]]}Ue.exports=Ye()(P);var{formatters:ar}=Ue.exports;ar.o=function(t){return this.inspectOpts.colors=this.useColors,_e.inspect(t,this.inspectOpts).split(`
6
+ `).map(e=>e.trim()).join(" ")};ar.O=function(t){return this.inspectOpts.colors=this.useColors,_e.inspect(t,this.inspectOpts)}});var ur=D((ri,Ze)=>{typeof process>"u"||process.type==="renderer"||process.browser===!0||process.__nwjs?Ze.exports=nr():Ze.exports=lr()});var Xe=D((Da,tn)=>{tn.exports=t=>{if(t[Symbol.asyncIterator])return t;if(t.getReader)return async function*(){let e=t.getReader();try{for(;;){let{done:r,value:n}=await e.read();if(r)return;yield n}}finally{e.releaseLock()}}();throw new Error("unknown stream")}});var nn=D((_a,rn)=>{rn.exports=function(e){if(e){if(typeof e[Symbol.iterator]=="function")return e[Symbol.iterator]();if(typeof e[Symbol.asyncIterator]=="function")return e[Symbol.asyncIterator]();if(typeof e.next=="function")return e}throw new Error("argument is not an iterator or iterable")}});var jt=D((Ua,on)=>{var Ds=nn();on.exports=t=>async e=>{e=Ds(e);let r=m=>{typeof m.return=="function"&&m.return()},n=null,o=null,s=m=>{n=m,o&&o(m),r(e)},i=null,a=!1,p=()=>{a=!0,i&&i()},y=null,l=!1,u=()=>{l=!0,y&&y()},f=null,g=()=>{f&&f()},h=()=>new Promise((m,A)=>{i=f=m,o=A,t.once("drain",g)}),w=()=>(r(e),new Promise((m,A)=>{if(a||l||n)return m();y=i=m,o=A})),C=()=>{t.removeListener("error",s),t.removeListener("close",p),t.removeListener("finish",u),t.removeListener("drain",g)};t.once("error",s),t.once("close",p),t.once("finish",u);try{for await(let m of e){if(!t.writable||t.destroyed||n)break;t.write(m)===!1&&await h()}}catch(m){n||t.destroy(),n=m}try{if(t.writable&&t.end(),await w(),n)throw n}finally{C()}}});var Gt=D((La,sn)=>{var _s=jt(),Us=Xe();sn.exports=t=>({sink:_s(t),source:Us(t)})});var an=D(($a,cn)=>{var Ls=Gt();cn.exports=t=>async function*(e){let r=Ls(t),n;if(r.sink(e).catch(o=>{n=o}),yield*r.source,n)throw n}});var ln=D((Va,Te)=>{Te.exports=Xe();Te.exports.source=Xe();Te.exports.sink=jt();Te.exports.transform=an();Te.exports.duplex=Gt()});var Xs={};_(Xs,{tcp:()=>Js});var fn=oe(H("net"),1);var pe=class t extends Error{code;type;constructor(e="The operation was aborted"){super(e),this.code=t.code,this.type=t.type}static code="ABORT_ERR";static type="aborted"},T=class extends Error{code;props;constructor(e,r,n){super(e),this.code=r,this.name=n?.name??"CodeError",this.props=n??{}}};var Zt=Symbol.for("@libp2p/transport");var Kt;(function(t){t[t.FATAL_ALL=0]="FATAL_ALL",t[t.NO_FATAL=1]="NO_FATAL"})(Kt||(Kt={}));var L=oe(ur(),1);var ot={};_(ot,{base32:()=>W,base32hex:()=>Yn,base32hexpad:()=>Zn,base32hexpadupper:()=>eo,base32hexupper:()=>Kn,base32pad:()=>Hn,base32padupper:()=>Qn,base32upper:()=>Xn,base32z:()=>to});function qn(t,e){if(t.length>=255)throw new TypeError("Alphabet too long");for(var r=new Uint8Array(256),n=0;n<r.length;n++)r[n]=255;for(var o=0;o<t.length;o++){var s=t.charAt(o),i=s.charCodeAt(0);if(r[i]!==255)throw new TypeError(s+" is ambiguous");r[i]=o}var a=t.length,p=t.charAt(0),y=Math.log(a)/Math.log(256),l=Math.log(256)/Math.log(a);function u(h){if(h instanceof Uint8Array||(ArrayBuffer.isView(h)?h=new Uint8Array(h.buffer,h.byteOffset,h.byteLength):Array.isArray(h)&&(h=Uint8Array.from(h))),!(h instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(h.length===0)return"";for(var w=0,C=0,m=0,A=h.length;m!==A&&h[m]===0;)m++,w++;for(var $=(A-m)*l+1>>>0,S=new Uint8Array($);m!==A;){for(var j=h[m],V=0,k=$-1;(j!==0||V<C)&&k!==-1;k--,V++)j+=256*S[k]>>>0,S[k]=j%a>>>0,j=j/a>>>0;if(j!==0)throw new Error("Non-zero carry");C=V,m++}for(var B=$-C;B!==$&&S[B]===0;)B++;for(var de=p.repeat(w);B<$;++B)de+=t.charAt(S[B]);return de}function f(h){if(typeof h!="string")throw new TypeError("Expected String");if(h.length===0)return new Uint8Array;var w=0;if(h[w]!==" "){for(var C=0,m=0;h[w]===p;)C++,w++;for(var A=(h.length-w)*y+1>>>0,$=new Uint8Array(A);h[w];){var S=r[h.charCodeAt(w)];if(S===255)return;for(var j=0,V=A-1;(S!==0||j<m)&&V!==-1;V--,j++)S+=a*$[V]>>>0,$[V]=S%256>>>0,S=S/256>>>0;if(S!==0)throw new Error("Non-zero carry");m=j,w++}if(h[w]!==" "){for(var k=A-m;k!==A&&$[k]===0;)k++;for(var B=new Uint8Array(C+(A-k)),de=C;k!==A;)B[de++]=$[k++];return B}}}function g(h){var w=f(h);if(w)return w;throw new Error(`Non-${e} character`)}return{encode:u,decodeUnsafe:f,decode:g}}var jn=qn,Gn=jn,dr=Gn;var oi=new Uint8Array(0);var pr=(t,e)=>{if(t===e)return!0;if(t.byteLength!==e.byteLength)return!1;for(let r=0;r<t.byteLength;r++)if(t[r]!==e[r])return!1;return!0},z=t=>{if(t instanceof Uint8Array&&t.constructor.name==="Uint8Array")return t;if(t instanceof ArrayBuffer)return new Uint8Array(t);if(ArrayBuffer.isView(t))return new Uint8Array(t.buffer,t.byteOffset,t.byteLength);throw new Error("Unknown type, must be binary type")};var fr=t=>new TextEncoder().encode(t),hr=t=>new TextDecoder().decode(t);var et=class{constructor(e,r,n){this.name=e,this.prefix=r,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}},tt=class{constructor(e,r,n){if(this.name=e,this.prefix=r,r.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=r.codePointAt(0),this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return gr(this,e)}},rt=class{constructor(e){this.decoders=e}or(e){return gr(this,e)}decode(e){let r=e[0],n=this.decoders[r];if(n)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}},gr=(t,e)=>new rt({...t.decoders||{[t.prefix]:t},...e.decoders||{[e.prefix]:e}}),nt=class{constructor(e,r,n,o){this.name=e,this.prefix=r,this.baseEncode=n,this.baseDecode=o,this.encoder=new et(e,r,n),this.decoder=new tt(e,r,o)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}},we=({name:t,prefix:e,encode:r,decode:n})=>new nt(t,e,r,n),Z=({prefix:t,name:e,alphabet:r})=>{let{encode:n,decode:o}=dr(r,e);return we({prefix:t,name:e,encode:n,decode:s=>z(o(s))})},Wn=(t,e,r,n)=>{let o={};for(let l=0;l<e.length;++l)o[e[l]]=l;let s=t.length;for(;t[s-1]==="=";)--s;let i=new Uint8Array(s*r/8|0),a=0,p=0,y=0;for(let l=0;l<s;++l){let u=o[t[l]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);p=p<<r|u,a+=r,a>=8&&(a-=8,i[y++]=255&p>>a)}if(a>=r||255&p<<8-a)throw new SyntaxError("Unexpected end of data");return i},Jn=(t,e,r)=>{let n=e[e.length-1]==="=",o=(1<<r)-1,s="",i=0,a=0;for(let p=0;p<t.length;++p)for(a=a<<8|t[p],i+=8;i>r;)i-=r,s+=e[o&a>>i];if(i&&(s+=e[o&a<<r-i]),n)for(;s.length*r&7;)s+="=";return s},v=({name:t,prefix:e,bitsPerChar:r,alphabet:n})=>we({prefix:e,name:t,encode(o){return Jn(o,n,r)},decode(o){return Wn(o,n,r,t)}});var W=v({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Xn=v({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Hn=v({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Qn=v({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Yn=v({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Kn=v({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),Zn=v({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),eo=v({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),to=v({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var st={};_(st,{base58btc:()=>R,base58flickr:()=>ro});var R=Z({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),ro=Z({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var ct={};_(ct,{base64:()=>it,base64pad:()=>no,base64url:()=>oo,base64urlpad:()=>so});var it=v({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),no=v({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),oo=v({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),so=v({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});L.default.formatters.b=t=>t==null?"undefined":R.baseEncode(t);L.default.formatters.t=t=>t==null?"undefined":W.baseEncode(t);L.default.formatters.m=t=>t==null?"undefined":it.baseEncode(t);L.default.formatters.p=t=>t==null?"undefined":t.toString();L.default.formatters.c=t=>t==null?"undefined":t.toString();L.default.formatters.k=t=>t==null?"undefined":t.toString();L.default.formatters.a=t=>t==null?"undefined":t.toString();function io(t){let e=()=>{};return e.enabled=!1,e.color="",e.diff=0,e.log=()=>{},e.namespace=t,e.destroy=()=>!0,e.extend=()=>e,e}function ee(t){let e=io(`${t}:trace`);return L.default.enabled(`${t}:trace`)&&L.default.names.map(r=>r.toString()).find(r=>r.includes(":trace"))!=null&&(e=(0,L.default)(`${t}:trace`)),Object.assign((0,L.default)(t),{error:(0,L.default)(`${t}:error`),trace:e})}var co=xr,wr=128,ao=127,lo=~ao,uo=Math.pow(2,31);function xr(t,e,r){e=e||[],r=r||0;for(var n=r;t>=uo;)e[r++]=t&255|wr,t/=128;for(;t&lo;)e[r++]=t&255|wr,t>>>=7;return e[r]=t|0,xr.bytes=r-n+1,e}var po=at,fo=128,br=127;function at(t,n){var r=0,n=n||0,o=0,s=n,i,a=t.length;do{if(s>=a)throw at.bytes=0,new RangeError("Could not decode varint");i=t[s++],r+=o<28?(i&br)<<o:(i&br)*Math.pow(2,o),o+=7}while(i>=fo);return at.bytes=s-n,r}var ho=Math.pow(2,7),mo=Math.pow(2,14),go=Math.pow(2,21),wo=Math.pow(2,28),bo=Math.pow(2,35),xo=Math.pow(2,42),yo=Math.pow(2,49),Co=Math.pow(2,56),vo=Math.pow(2,63),Eo=function(t){return t<ho?1:t<mo?2:t<go?3:t<wo?4:t<bo?5:t<xo?6:t<yo?7:t<Co?8:t<vo?9:10},Ao={encode:co,decode:po,encodingLength:Eo},Io=Ao,Fe=Io;var Re=(t,e=0)=>[Fe.decode(t,e),Fe.decode.bytes],be=(t,e,r=0)=>(Fe.encode(t,e,r),e),xe=t=>Fe.encodingLength(t);var ie=(t,e)=>{let r=e.byteLength,n=xe(t),o=n+xe(r),s=new Uint8Array(o+r);return be(t,s,0),be(r,s,n),s.set(e,o),new ye(t,r,e,s)},$e=t=>{let e=z(t),[r,n]=Re(e),[o,s]=Re(e.subarray(n)),i=e.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new ye(r,o,i,e)},yr=(t,e)=>{if(t===e)return!0;{let r=e;return t.code===r.code&&t.size===r.size&&r.bytes instanceof Uint8Array&&pr(t.bytes,r.bytes)}},ye=class{constructor(e,r,n,o){this.code=e,this.size=r,this.digest=n,this.bytes=o}};var Cr=(t,e)=>{let{bytes:r,version:n}=t;switch(n){case 0:return To(r,lt(t),e||R.encoder);default:return Po(r,lt(t),e||W.encoder)}};var vr=new WeakMap,lt=t=>{let e=vr.get(t);if(e==null){let r=new Map;return vr.set(t,r),r}return e},te=class t{constructor(e,r,n,o){this.code=r,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:r}=this;if(e!==Oe)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(r.code!==Fo)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return t.createV0(r)}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:r}=this.multihash,n=ie(e,r);return t.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 t.equals(this,e)}static equals(e,r){let n=r;return n&&e.code===n.code&&e.version===n.version&&yr(e.multihash,n.multihash)}toString(e){return Cr(this,e)}toJSON(){return{"/":Cr(this)}}link(){return this}get[Symbol.toStringTag](){return"CID"}[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let r=e;if(r instanceof t)return r;if(r["/"]!=null&&r["/"]===r.bytes||r.asCID===r){let{version:n,code:o,multihash:s,bytes:i}=r;return new t(n,o,s,i||Er(n,o,s.bytes))}else if(r[Ro]===!0){let{version:n,multihash:o,code:s}=r,i=$e(o);return t.create(n,s,i)}else return null}static create(e,r,n){if(typeof r!="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(r!==Oe)throw new Error(`Version 0 CID must use dag-pb (code: ${Oe}) block encoding`);return new t(e,r,n,n.bytes)}case 1:{let o=Er(e,r,n.bytes);return new t(e,r,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return t.create(0,Oe,e)}static createV1(e,r){return t.create(1,e,r)}static decode(e){let[r,n]=t.decodeFirst(e);if(n.length)throw new Error("Incorrect length");return r}static decodeFirst(e){let r=t.inspectBytes(e),n=r.size-r.multihashSize,o=z(e.subarray(n,n+r.multihashSize));if(o.byteLength!==r.multihashSize)throw new Error("Incorrect length");let s=o.subarray(r.multihashSize-r.digestSize),i=new ye(r.multihashCode,r.digestSize,s,o);return[r.version===0?t.createV0(i):t.createV1(r.codec,i),e.subarray(r.size)]}static inspectBytes(e){let r=0,n=()=>{let[u,f]=Re(e.subarray(r));return r+=f,u},o=n(),s=Oe;if(o===18?(o=0,r=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=r,a=n(),p=n(),y=r+p,l=y-i;return{version:o,codec:s,multihashCode:a,digestSize:p,multihashSize:l,size:y}}static parse(e,r){let[n,o]=So(e,r),s=t.decode(o);if(s.version===0&&e[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return lt(s).set(n,e),s}},So=(t,e)=>{switch(t[0]){case"Q":{let r=e||R;return[R.prefix,r.decode(`${R.prefix}${t}`)]}case R.prefix:{let r=e||R;return[R.prefix,r.decode(t)]}case W.prefix:{let r=e||W;return[W.prefix,r.decode(t)]}default:{if(e==null)throw Error("To parse non base32 or base58btc encoded CID multibase decoder must be provided");return[t[0],e.decode(t)]}}},To=(t,e,r)=>{let{prefix:n}=r;if(n!==R.prefix)throw Error(`Cannot string encode V0 in ${r.name} encoding`);let o=e.get(n);if(o==null){let s=r.encode(t).slice(1);return e.set(n,s),s}else return o},Po=(t,e,r)=>{let{prefix:n}=r,o=e.get(n);if(o==null){let s=r.encode(t);return e.set(n,s),s}else return o},Oe=112,Fo=18,Er=(t,e,r)=>{let n=xe(t),o=n+xe(e),s=new Uint8Array(o+r.byteLength);return be(t,s,0),be(e,s,n),s.set(r,o),s},Ro=Symbol.for("@ipld/js-cid/CID");function Ar(t,e){if(t===e)return!0;if(t.byteLength!==e.byteLength)return!1;for(let r=0;r<t.byteLength;r++)if(t[r]!==e[r])return!1;return!0}var ut={};_(ut,{base10:()=>Oo});var Oo=Z({prefix:"9",name:"base10",alphabet:"0123456789"});var dt={};_(dt,{base16:()=>No,base16upper:()=>Mo});var No=v({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Mo=v({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var pt={};_(pt,{base2:()=>ko});var ko=v({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var ft={};_(ft,{base256emoji:()=>$o});var Ir=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}"),Do=Ir.reduce((t,e,r)=>(t[r]=e,t),[]),_o=Ir.reduce((t,e,r)=>(t[e.codePointAt(0)]=r,t),[]);function Uo(t){return t.reduce((e,r)=>(e+=Do[r],e),"")}function Lo(t){let e=[];for(let r of t){let n=_o[r.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${r}`);e.push(n)}return new Uint8Array(e)}var $o=we({prefix:"\u{1F680}",name:"base256emoji",encode:Uo,decode:Lo});var ht={};_(ht,{base36:()=>Vo,base36upper:()=>Bo});var Vo=Z({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Bo=Z({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var mt={};_(mt,{base8:()=>zo});var zo=v({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var gt={};_(gt,{identity:()=>qo});var qo=we({prefix:"\0",name:"identity",encode:t=>hr(t),decode:t=>fr(t)});var Ni=new TextEncoder,Mi=new TextDecoder;var wt={};_(wt,{identity:()=>Xo});var Sr=0,Wo="identity",Tr=z,Jo=t=>ie(Sr,Tr(t)),Xo={code:Sr,name:Wo,encode:Tr,digest:Jo};var Ct={};_(Ct,{sha256:()=>Ho,sha512:()=>Qo});var yt=oe(H("crypto"),1);var xt=({name:t,code:e,encode:r})=>new bt(t,e,r),bt=class{constructor(e,r,n){this.name=e,this.code=r,this.encode=n}digest(e){if(e instanceof Uint8Array){let r=this.encode(e);return r instanceof Uint8Array?ie(this.code,r):r.then(n=>ie(this.code,n))}else throw Error("Unknown type, must be binary type")}};var Ho=xt({name:"sha2-256",code:18,encode:t=>z(yt.default.createHash("sha256").update(t).digest())}),Qo=xt({name:"sha2-512",code:19,encode:t=>z(yt.default.createHash("sha512").update(t).digest())});var Ne={...gt,...pt,...mt,...ut,...dt,...ot,...ht,...st,...ct,...ft},zi={...Ct,...wt};function ve(t){return globalThis.Buffer!=null?new Uint8Array(t.buffer,t.byteOffset,t.byteLength):t}function Ee(t=0){return globalThis.Buffer?.allocUnsafe!=null?ve(globalThis.Buffer.allocUnsafe(t)):new Uint8Array(t)}function Rr(t,e,r,n){return{name:t,prefix:e,encoder:{name:t,prefix:e,encode:r},decoder:{decode:n}}}var Fr=Rr("utf8","u",t=>"u"+new TextDecoder("utf8").decode(t),t=>new TextEncoder().encode(t.substring(1))),vt=Rr("ascii","a",t=>{let e="a";for(let r=0;r<t.length;r++)e+=String.fromCharCode(t[r]);return e},t=>{t=t.substring(1);let e=Ee(t.length);for(let r=0;r<t.length;r++)e[r]=t.charCodeAt(r);return e}),Yo={utf8:Fr,"utf-8":Fr,hex:Ne.base16,latin1:vt,ascii:vt,binary:vt,...Ne},Ve=Yo;function M(t,e="utf8"){let r=Ve[e];if(r==null)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?globalThis.Buffer.from(t.buffer,t.byteOffset,t.byteLength).toString("utf8"):r.encoder.encode(t).substring(1)}var Ko=Math.pow(2,7),Zo=Math.pow(2,14),es=Math.pow(2,21),Et=Math.pow(2,28),At=Math.pow(2,35),It=Math.pow(2,42),St=Math.pow(2,49),b=128,O=127;function J(t){if(t<Ko)return 1;if(t<Zo)return 2;if(t<es)return 3;if(t<Et)return 4;if(t<At)return 5;if(t<It)return 6;if(t<St)return 7;if(Number.MAX_SAFE_INTEGER!=null&&t>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ts(t,e,r=0){switch(J(t)){case 8:e[r++]=t&255|b,t/=128;case 7:e[r++]=t&255|b,t/=128;case 6:e[r++]=t&255|b,t/=128;case 5:e[r++]=t&255|b,t/=128;case 4:e[r++]=t&255|b,t>>>=7;case 3:e[r++]=t&255|b,t>>>=7;case 2:e[r++]=t&255|b,t>>>=7;case 1:{e[r++]=t&255,t>>>=7;break}default:throw new Error("unreachable")}return e}function rs(t,e,r=0){switch(J(t)){case 8:e.set(r++,t&255|b),t/=128;case 7:e.set(r++,t&255|b),t/=128;case 6:e.set(r++,t&255|b),t/=128;case 5:e.set(r++,t&255|b),t/=128;case 4:e.set(r++,t&255|b),t>>>=7;case 3:e.set(r++,t&255|b),t>>>=7;case 2:e.set(r++,t&255|b),t>>>=7;case 1:{e.set(r++,t&255),t>>>=7;break}default:throw new Error("unreachable")}return e}function ns(t,e){let r=t[e],n=0;if(n+=r&O,r<b||(r=t[e+1],n+=(r&O)<<7,r<b)||(r=t[e+2],n+=(r&O)<<14,r<b)||(r=t[e+3],n+=(r&O)<<21,r<b)||(r=t[e+4],n+=(r&O)*Et,r<b)||(r=t[e+5],n+=(r&O)*At,r<b)||(r=t[e+6],n+=(r&O)*It,r<b)||(r=t[e+7],n+=(r&O)*St,r<b))return n;throw new RangeError("Could not decode varint")}function os(t,e){let r=t.get(e),n=0;if(n+=r&O,r<b||(r=t.get(e+1),n+=(r&O)<<7,r<b)||(r=t.get(e+2),n+=(r&O)<<14,r<b)||(r=t.get(e+3),n+=(r&O)<<21,r<b)||(r=t.get(e+4),n+=(r&O)*Et,r<b)||(r=t.get(e+5),n+=(r&O)*At,r<b)||(r=t.get(e+6),n+=(r&O)*It,r<b)||(r=t.get(e+7),n+=(r&O)*St,r<b))return n;throw new RangeError("Could not decode varint")}function Ae(t,e,r=0){return e==null&&(e=Ee(J(t))),e instanceof Uint8Array?ts(t,e,r):rs(t,e,r)}function ce(t,e=0){return t instanceof Uint8Array?ns(t,e):os(t,e)}function Q(t,e){e==null&&(e=t.reduce((o,s)=>o+s.length,0));let r=Ee(e),n=0;for(let o of t)r.set(o,n),n+=o.length;return ve(r)}var Be=class{index=0;input="";new(e){return this.index=0,this.input=e,this}readAtomically(e){let r=this.index,n=e();return n===void 0&&(this.index=r),n}parseWith(e){let r=e();if(this.index===this.input.length)return r}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 r=this.readChar();if(r===e)return r})}readSeparator(e,r,n){return this.readAtomically(()=>{if(!(r>0&&this.readGivenChar(e)===void 0))return n()})}readNumber(e,r,n,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let p=a==="0",y=2**(8*o)-1;for(;;){let l=this.readAtomically(()=>{let u=this.readChar();if(u===void 0)return;let f=Number.parseInt(u,e);if(!Number.isNaN(f))return f});if(l===void 0)break;if(s*=e,s+=l,s>y||(i+=1,r!==void 0&&i>r))return}if(i!==0)return!n&&p&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let e=new Uint8Array(4);for(let r=0;r<e.length;r++){let n=this.readSeparator(".",r,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;e[r]=n}return e})}readIPv6Addr(){let e=r=>{for(let n=0;n<r.length/2;n++){let o=n*2;if(n<r.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return r[o]=i[0],r[o+1]=i[1],r[o+2]=i[2],r[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];r[o]=s>>8,r[o+1]=s&255}return[r.length,!1]};return this.readAtomically(()=>{let r=new Uint8Array(16),[n,o]=e(r);if(n===16)return r;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 r.set(s.subarray(0,a),16-a),r})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var oc=new Be;var pc=parseInt("0xFFFF",16),fc=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function Tt(t,e="utf8"){let r=Ve[e];if(r==null)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?ve(globalThis.Buffer.from(t,"utf-8")):r.decoder.decode(`${r.prefix}${t}`)}var q=H("node:net");function ze(t){return!!(0,q.isIP)(t)}var kr=q.isIPv4,us=q.isIPv6,Pt=function(t){let e=0;if(t=t.toString().trim(),kr(t)){let r=new Uint8Array(e+4);return t.split(/\./g).forEach(n=>{r[e++]=parseInt(n,10)&255}),r}if(us(t)){let r=t.split(":",8),n;for(n=0;n<r.length;n++){let s=kr(r[n]),i;s&&(i=Pt(r[n]),r[n]=M(i.slice(0,2),"base16")),i!=null&&++n<8&&r.splice(n,0,M(i.slice(2,4),"base16"))}if(r[0]==="")for(;r.length<8;)r.unshift("0");else if(r[r.length-1]==="")for(;r.length<8;)r.push("0");else if(r.length<8){for(n=0;n<r.length&&r[n]!=="";n++);let s=[n,1];for(n=9-r.length;n>0;n--)s.push("0");r.splice.apply(r,s)}let o=new Uint8Array(e+16);for(n=0;n<r.length;n++){let s=parseInt(r[n],16);o[e++]=s>>8&255,o[e++]=s&255}return o}throw new Error("invalid ip address")},Dr=function(t,e=0,r){e=~~e,r=r??t.length-e;let n=new DataView(t.buffer);if(r===4){let o=[];for(let s=0;s<r;s++)o.push(t[e+s]);return o.join(".")}if(r===16){let o=[];for(let s=0;s<r;s+=2)o.push(n.getUint16(e+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var Ie={},Ft={},ps=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[777,-1,"memory"]];ps.forEach(t=>{let e=fs(...t);Ft[e.code]=e,Ie[e.name]=e});function fs(t,e,r,n,o){return{code:t,size:e,name:r,resolvable:!!n,path:!!o}}function x(t){if(typeof t=="number"){if(Ft[t]!=null)return Ft[t];throw new Error(`no protocol with code: ${t}`)}else if(typeof t=="string"){if(Ie[t]!=null)return Ie[t];throw new Error(`no protocol with name: ${t}`)}throw new Error(`invalid protocol id type: ${typeof t}`)}var ea=x("ip4"),ta=x("ip6"),ra=x("ipcidr");function Ot(t,e){switch(x(t).code){case 4:case 41:return ms(e);case 42:return Lr(e);case 6:case 273:case 33:case 132:return Vr(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Lr(e);case 421:return xs(e);case 444:return $r(e);case 445:return $r(e);case 466:return bs(e);default:return M(e,"base16")}}function Nt(t,e){switch(x(t).code){case 4:return _r(e);case 41:return _r(e);case 42:return Ur(e);case 6:case 273:case 33:case 132:return Mt(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ur(e);case 421:return gs(e);case 444:return ys(e);case 445:return Cs(e);case 466:return ws(e);default:return Tt(e,"base16")}}var Rt=Object.values(Ne).map(t=>t.decoder),hs=function(){let t=Rt[0].or(Rt[1]);return Rt.slice(2).forEach(e=>t=t.or(e)),t}();function _r(t){if(!ze(t))throw new Error("invalid ip address");return Pt(t)}function ms(t){let e=Dr(t,0,t.length);if(e==null)throw new Error("ipBuff is required");if(!ze(e))throw new Error("invalid ip address");return e}function Mt(t){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,t),new Uint8Array(e)}function Vr(t){return new DataView(t.buffer).getUint16(t.byteOffset)}function Ur(t){let e=Tt(t),r=Uint8Array.from(Ae(e.length));return Q([r,e],r.length+e.length)}function Lr(t){let e=ce(t);if(t=t.slice(J(e)),t.length!==e)throw new Error("inconsistent lengths");return M(t)}function gs(t){let e;t[0]==="Q"||t[0]==="1"?e=$e(R.decode(`z${t}`)).bytes:e=te.parse(t).multihash.bytes;let r=Uint8Array.from(Ae(e.length));return Q([r,e],r.length+e.length)}function ws(t){let e=hs.decode(t),r=Uint8Array.from(Ae(e.length));return Q([r,e],r.length+e.length)}function bs(t){let e=ce(t),r=t.slice(J(e));if(r.length!==e)throw new Error("inconsistent lengths");return"u"+M(r,"base64url")}function xs(t){let e=ce(t),r=t.slice(J(e));if(r.length!==e)throw new Error("inconsistent lengths");return M(r,"base58btc")}function ys(t){let e=t.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 r=W.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=Mt(n);return Q([r,o],r.length+o.length)}function Cs(t){let e=t.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 r=W.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=Mt(n);return Q([r,o],r.length+o.length)}function $r(t){let e=t.slice(0,t.length-2),r=t.slice(t.length-2),n=M(e,"base32"),o=Vr(r);return`${n}:${o}`}function Br(t){t=kt(t);let e=[],r=[],n=null,o=t.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=x(i);if(a.size===0){e.push([a.code]),r.push([a.code]);continue}if(s++,s>=o.length)throw qr("invalid address: "+t);if(a.path===!0){n=kt(o.slice(s).join("/")),e.push([a.code,Nt(a.code,n)]),r.push([a.code,n]);break}let p=Nt(a.code,o[s]);e.push([a.code,p]),r.push([a.code,Ot(a.code,p)])}return{string:zr(r),bytes:_t(e),tuples:e,stringTuples:r,path:n}}function Dt(t){let e=[],r=[],n=null,o=0;for(;o<t.length;){let s=ce(t,o),i=J(s),a=x(s),p=vs(a,t.slice(o+i));if(p===0){e.push([s]),r.push([s]),o+=i;continue}let y=t.slice(o+i,o+i+p);if(o+=p+i,o>t.length)throw qr("Invalid address Uint8Array: "+M(t,"base16"));e.push([s,y]);let l=Ot(s,y);if(r.push([s,l]),a.path===!0){n=l;break}}return{bytes:Uint8Array.from(t),string:zr(r),tuples:e,stringTuples:r,path:n}}function zr(t){let e=[];return t.map(r=>{let n=x(r[0]);return e.push(n.name),r.length>1&&r[1]!=null&&e.push(r[1]),null}),kt(e.join("/"))}function _t(t){return Q(t.map(e=>{let r=x(e[0]),n=Uint8Array.from(Ae(r.code));return e.length>1&&e[1]!=null&&(n=Q([n,e[1]])),n}))}function vs(t,e){if(t.size>0)return t.size/8;if(t.size===0)return 0;{let r=ce(e instanceof Uint8Array?e:Uint8Array.from(e));return r+J(r)}}function kt(t){return"/"+t.trim().split("/").filter(e=>e).join("/")}function qr(t){return new Error("Error parsing address: "+t)}var Es=Symbol.for("nodejs.util.inspect.custom"),As=[x("dns").code,x("dns4").code,x("dns6").code,x("dnsaddr").code],Is=new Map,jr=Symbol.for("@multiformats/js-multiaddr/multiaddr");function Ss(t){return!!t?.[jr]}var Ut=class t{bytes;#e;#t;#r;#n;[jr]=!0;constructor(e){e==null&&(e="");let r;if(e instanceof Uint8Array)r=Dt(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);r=Br(e)}else if(Ss(e))r=Dt(e.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=r.bytes,this.#e=r.string,this.#t=r.tuples,this.#r=r.stringTuples,this.#n=r.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let e,r,n,o,s="",i=x("tcp"),a=x("udp"),p=x("ip4"),y=x("ip6"),l=x("dns6"),u=x("ip6zone");for(let[g,h]of this.stringTuples())g===u.code&&(s=`%${h??""}`),As.includes(g)&&(r=i.name,o=443,n=`${h??""}${s}`,e=g===l.code?6:4),(g===i.code||g===a.code)&&(r=x(g).name,o=parseInt(h??"")),(g===p.code||g===y.code)&&(r=x(g).name,n=`${h??""}${s}`,e=g===y.code?6:4);if(e==null||r==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:e,host:n,transport:r,port:o}}protos(){return this.#t.map(([e])=>Object.assign({},x(e)))}protoCodes(){return this.#t.map(([e])=>e)}protoNames(){return this.#t.map(([e])=>x(e).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(e){return e=new t(e),new t(this.toString()+e.toString())}decapsulate(e){let r=e.toString(),n=this.toString(),o=n.lastIndexOf(r);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${e.toString()}`);return new t(n.slice(0,o))}decapsulateCode(e){let r=this.tuples();for(let n=r.length-1;n>=0;n--)if(r[n][0]===e)return new t(_t(r.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,o])=>{n===Ie.p2p.code&&e.push([n,o]),n===Ie["p2p-circuit"].code&&(e=[])});let r=e.pop();if(r?.[1]!=null){let n=r[1];return n[0]==="Q"||n[0]==="1"?M(R.decode(`z${n}`),"base58btc"):M(te.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(e){return Ar(this.bytes,e.bytes)}async resolve(e){let r=this.protos().find(s=>s.resolvable);if(r==null)return[this];let n=Is.get(r.name);if(n==null)throw new T(`no available resolver for ${r.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,e)).map(s=>new t(s))}nodeAddress(){let e=this.toOptions();if(e.transport!=="tcp"&&e.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${e.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:e.family,address:e.host,port:e.port}}isThinWaistAddress(e){let r=(e??this).protos();return!(r.length!==2||r[0].code!==4&&r[0].code!==41||r[1].code!==6&&r[1].code!==273)}[Es](){return`Multiaddr(${this.#e})`}};function Y(t){return new Ut(t)}var Ts=c("dns4"),Ps=c("dns6"),Fs=c("dnsaddr"),le=E(c("dns"),Fs,Ts,Ps),Ge=E(c("ip4"),c("ip6")),ne=E(d(Ge,c("tcp")),d(le,c("tcp"))),We=d(Ge,c("udp")),Rs=d(We,c("utp")),Os=d(We,c("quic")),Ns=d(We,c("quic-v1")),Lt=E(d(ne,c("ws")),d(le,c("ws"))),qe=E(d(Lt,c("p2p")),Lt),$t=E(d(ne,c("wss")),d(le,c("wss")),d(ne,c("tls"),c("ws")),d(le,c("tls"),c("ws"))),je=E(d($t,c("p2p")),$t),Vt=E(d(ne,c("http")),d(Ge,c("http")),d(le,c("http"))),Bt=E(d(ne,c("https")),d(Ge,c("https")),d(le,c("https"))),Gr=d(We,c("webrtc-direct"),c("certhash")),Xr=E(d(Gr,c("p2p")),Gr),Wr=d(Ns,c("webtransport"),c("certhash"),c("certhash")),Hr=E(d(Wr,c("p2p")),Wr),Qr=E(d(qe,c("p2p-webrtc-star"),c("p2p")),d(je,c("p2p-webrtc-star"),c("p2p")),d(qe,c("p2p-webrtc-star")),d(je,c("p2p-webrtc-star"))),Aa=E(d(qe,c("p2p-websocket-star"),c("p2p")),d(je,c("p2p-websocket-star"),c("p2p")),d(qe,c("p2p-websocket-star")),d(je,c("p2p-websocket-star"))),Yr=E(d(Vt,c("p2p-webrtc-direct"),c("p2p")),d(Bt,c("p2p-webrtc-direct"),c("p2p")),d(Vt,c("p2p-webrtc-direct")),d(Bt,c("p2p-webrtc-direct"))),ue=E(Lt,$t,Vt,Bt,Qr,Yr,ne,Rs,Os,le,Xr,Hr),Ia=E(d(ue,c("p2p-stardust"),c("p2p")),d(ue,c("p2p-stardust"))),re=E(d(ue,c("p2p")),Qr,Yr,Xr,Hr,c("p2p")),Jr=E(d(re,c("p2p-circuit"),re),d(re,c("p2p-circuit")),d(c("p2p-circuit"),re),d(ue,c("p2p-circuit")),d(c("p2p-circuit"),ue),c("p2p-circuit")),Kr=()=>E(d(Jr,Kr),Jr),ae=Kr(),Sa=E(d(ae,re,ae),d(re,ae),d(ae,re),ae,re);var Ta=E(d(ae,c("webrtc"),c("p2p")),d(ae,c("webrtc")),d(ue,c("webrtc"),c("p2p")),d(ue,c("webrtc")),c("webrtc"));function Zr(t){function e(r){let n;try{n=Y(r)}catch{return!1}let o=t(n.protoNames());return o===null?!1:o===!0||o===!1?o:o.length===0}return e}function d(...t){function e(r){if(r.length<t.length)return null;let n=r;return t.some(o=>(n=typeof o=="function"?o().partialMatch(r):o.partialMatch(r),Array.isArray(n)&&(r=n),n===null)),n}return{toString:function(){return"{ "+t.join(" ")+" }"},input:t,matches:Zr(e),partialMatch:e}}function E(...t){function e(n){let o=null;return t.some(s=>{let i=typeof s=="function"?s().partialMatch(n):s.partialMatch(n);return i!=null?(o=i,!0):!1}),o}return{toString:function(){return"{ "+t.join(" ")+" }"},input:t,matches:Zr(e),partialMatch:e}}function c(t){let e=t;function r(o){let s;try{s=Y(o)}catch{return!1}let i=s.protoNames();return i.length===1&&i[0]===e}function n(o){return o.length===0?null:o[0]===e?o.slice(1):null}return{toString:function(){return e},matches:r,partialMatch:n}}var pn=oe(H("net"),1);var Je=class extends EventTarget{#e=new Map;listenerCount(e){let r=this.#e.get(e);return r==null?0:r.length}addEventListener(e,r,n){super.addEventListener(e,r,n);let o=this.#e.get(e);o==null&&(o=[],this.#e.set(e,o)),o.push({callback:r,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(e,r,n){super.removeEventListener(e.toString(),r??null,n);let o=this.#e.get(e);o!=null&&(o=o.filter(({callback:s})=>s!==r),this.#e.set(e,o))}dispatchEvent(e){let r=super.dispatchEvent(e),n=this.#e.get(e.type);return n==null||(n=n.filter(({once:o})=>!o),this.#e.set(e.type,n)),r}safeDispatchEvent(e,r){return this.dispatchEvent(new Se(e,r))}},zt=class extends Event{detail;constructor(e,r){super(e,r),this.detail=r?.detail}},Se=globalThis.CustomEvent??zt;var ks=ee("libp2p:ip-port-to-multiaddr"),qt={ERR_INVALID_IP_PARAMETER:"ERR_INVALID_IP_PARAMETER",ERR_INVALID_PORT_PARAMETER:"ERR_INVALID_PORT_PARAMETER",ERR_INVALID_IP:"ERR_INVALID_IP"};function en(t,e){if(typeof t!="string")throw new T(`invalid ip provided: ${t}`,qt.ERR_INVALID_IP_PARAMETER);if(typeof e=="string"&&(e=parseInt(e)),isNaN(e))throw new T(`invalid port provided: ${e}`,qt.ERR_INVALID_PORT_PARAMETER);if((0,q.isIPv4)(t))return Y(`/ip4/${t}/tcp/${e}`);if((0,q.isIPv6)(t))return Y(`/ip6/${t}/tcp/${e}`);let r=`invalid ip:port for creating a multiaddr: ${t}:${e}`;throw ks.error(r),new T(r,qt.ERR_INVALID_IP)}var dn=oe(ln(),1);var Wt=oe(H("os"),1),un=oe(H("path"),1);var $s={ip4:"IPv4",ip6:"IPv6"};function Pe(t,e={}){let r=t.getPath();return r!=null?Wt.default.platform()==="win32"?{path:un.default.join("\\\\.\\pipe\\",r)}:{path:r}:{...t.toOptions(),...e}}function Jt(t,e,r){let n=o=>Y(`/${t}/${o}/tcp/${r}`);return(Vs(e)?zs($s[t]):[e]).map(n)}function Vs(t){return["0.0.0.0","::"].includes(t)}var Bs=Wt.default.networkInterfaces();function zs(t){let e=[];for(let[,r]of Object.entries(Bs))if(r!=null)for(let n of r)n.family===t&&e.push(n.address);return e}var X=ee("libp2p:tcp:socket"),He=(t,e)=>{let r=e.metrics,n=e.metricPrefix??"",o=e.socketInactivityTimeout??3e5,s=e.socketCloseTimeout??500;e.listeningAddr?.getPath()!=null&&(e.remoteAddr=e.listeningAddr),e.remoteAddr?.getPath()!=null&&(e.localAddr=e.remoteAddr);let i;if(e.remoteAddr!=null)i=e.remoteAddr;else{if(t.remoteAddress==null||t.remotePort==null)throw new T("Could not determine remote address or port","ERR_NO_REMOTE_ADDRESS");i=en(t.remoteAddress,t.remotePort)}let a=Pe(i),p=a.path??`${a.host??""}:${a.port??""}`,{sink:y,source:l}=dn.default.duplex(t);t.setTimeout(o,()=>{X("%s socket read timeout",p),r?.increment({[`${n}timeout`]:!0});let f;t.readable&&(f=new T("Socket read timeout","ERR_SOCKET_READ_TIMEOUT")),t.destroy(f)}),t.once("close",()=>{X("%s socket close",p),r?.increment({[`${n}close`]:!0}),u.timeline.close==null&&(u.timeline.close=Date.now())}),t.once("end",()=>{X("%s socket end",p),r?.increment({[`${n}end`]:!0})});let u={async sink(f){try{await y(f)}catch(g){g.type!=="aborted"&&X(g)}t.end()},source:l,remoteAddr:i,timeline:{open:Date.now()},async close(f={}){if(t.destroyed){X("%s socket was already destroyed when trying to close",p);return}f.signal=f.signal??AbortSignal.timeout(s);try{X("%s closing socket",p),await new Promise((g,h)=>{t.once("close",()=>{X("%s socket closed",p),g()}),t.once("error",w=>{X("%s socket error",p,w),u.timeline.close==null&&(u.timeline.close=Date.now()),h(w)}),t.setTimeout(s),t.end(),t.writableLength>0?t.once("drain",()=>{X("%s socket drained",p),t.destroy()}):t.destroy()})}catch(g){this.abort(g)}},abort:f=>{X("%s socket abort due to error",p,f),t.destroy(f)}};return u};var N=ee("libp2p:tcp:listener");async function Xt(t){try{await t.close()}catch(e){N.error("an error occurred closing the connection",e)}}var I;(function(t){t[t.INACTIVE=0]="INACTIVE",t[t.ACTIVE=1]="ACTIVE",t[t.PAUSED=2]="PAUSED"})(I||(I={}));var Qe=class extends Je{context;server;connections=new Set;status={code:I.INACTIVE};metrics;addr;constructor(e){if(super(),this.context=e,e.keepAlive=e.keepAlive??!0,this.addr="unknown",this.server=pn.default.createServer(e,this.onSocket.bind(this)),e.maxConnections!==void 0&&(this.server.maxConnections=e.maxConnections),e.closeServerOnMaxConnections!=null&&e.closeServerOnMaxConnections.closeAbove<e.closeServerOnMaxConnections.listenBelow)throw new T("closeAbove must be >= listenBelow","ERROR_CONNECTION_LIMITS");this.server.on("listening",()=>{if(e.metrics!=null){let r=this.server.address();r==null?this.addr="unknown":typeof r=="string"?this.addr=r:this.addr=`${r.address}:${r.port}`,e.metrics?.registerMetricGroup("libp2p_tcp_inbound_connections_total",{label:"address",help:"Current active connections in TCP listener",calculate:()=>({[this.addr]:this.connections.size})}),this.metrics={status:e.metrics.registerMetricGroup("libp2p_tcp_listener_status_info",{label:"address",help:"Current status of the TCP listener socket"}),errors:e.metrics.registerMetricGroup("libp2p_tcp_listener_errors_total",{label:"address",help:"Total count of TCP listener errors by type"}),events:e.metrics.registerMetricGroup("libp2p_tcp_listener_events_total",{label:"address",help:"Total count of TCP listener events by type"})},this.metrics?.status.update({[this.addr]:I.ACTIVE})}this.dispatchEvent(new Se("listening"))}).on("error",r=>{this.metrics?.errors.increment({[`${this.addr} listen_error`]:!0}),this.dispatchEvent(new Se("error",{detail:r}))}).on("close",()=>{this.metrics?.status.update({[this.addr]:this.status.code}),this.status.code!==I.PAUSED&&this.dispatchEvent(new Se("close"))})}onSocket(e){if(this.status.code!==I.ACTIVE)throw new T("Server is is not listening yet","ERR_SERVER_NOT_RUNNING");e.on("error",n=>{N("socket error",n),this.metrics?.events.increment({[`${this.addr} error`]:!0})});let r;try{r=He(e,{listeningAddr:this.status.listeningAddr,socketInactivityTimeout:this.context.socketInactivityTimeout,socketCloseTimeout:this.context.socketCloseTimeout,metrics:this.metrics?.events,metricPrefix:`${this.addr} `})}catch(n){N.error("inbound connection failed",n),this.metrics?.errors.increment({[`${this.addr} inbound_to_connection`]:!0});return}N("new inbound connection %s",r.remoteAddr);try{this.context.upgrader.upgradeInbound(r).then(n=>{N("inbound connection upgraded %s",r.remoteAddr),this.connections.add(r),e.once("close",()=>{this.connections.delete(r),this.context.closeServerOnMaxConnections!=null&&this.connections.size<this.context.closeServerOnMaxConnections.listenBelow&&this.resume().catch(o=>{N.error("error attempting to listen server once connection count under limit",o),this.context.closeServerOnMaxConnections?.onListenError?.(o)})}),this.context.handler!=null&&this.context.handler(n),this.context.closeServerOnMaxConnections!=null&&this.connections.size>=this.context.closeServerOnMaxConnections.closeAbove&&this.pause(!1).catch(o=>{N.error("error attempting to close server once connection count over limit",o)}),this.dispatchEvent(new Se("connection",{detail:n}))}).catch(async n=>{N.error("inbound connection failed",n),this.metrics?.errors.increment({[`${this.addr} inbound_upgrade`]:!0}),await Xt(r)}).catch(n=>{N.error("closing inbound connection failed",n)})}catch(n){N.error("inbound connection failed",n),Xt(r).catch(o=>{N.error("closing inbound connection failed",o),this.metrics?.errors.increment({[`${this.addr} inbound_closing_failed`]:!0})})}}getAddrs(){if(this.status.code===I.INACTIVE)return[];let e=[],r=this.server.address(),{listeningAddr:n,peerId:o}=this.status;if(r==null)return[];if(typeof r=="string")e=[n];else try{n.toString().startsWith("/ip4")?e=e.concat(Jt("ip4",r.address,r.port)):r.family==="IPv6"&&(e=e.concat(Jt("ip6",r.address,r.port)))}catch(s){N.error("could not turn %s:%s into multiaddr",r.address,r.port,s)}return e.map(s=>o!=null?s.encapsulate(`/p2p/${o}`):s)}async listen(e){if(this.status.code===I.ACTIVE||this.status.code===I.PAUSED)throw new T("server is already listening","ERR_SERVER_ALREADY_LISTENING");let r=e.getPeerId(),n=r==null?e.decapsulateCode(421):e,{backlog:o}=this.context;try{this.status={code:I.ACTIVE,listeningAddr:n,peerId:r,netConfig:Pe(n,{backlog:o})},await this.resume()}catch(s){throw this.status={code:I.INACTIVE},s}}async close(){await Promise.all([Promise.all(Array.from(this.connections.values()).map(async e=>Xt(e))),this.pause(!0).catch(e=>{N.error("error attempting to close server once connection count over limit",e)})])}async resume(){if(this.server.listening||this.status.code===I.INACTIVE)return;let e=this.status.netConfig;await new Promise((r,n)=>{this.server.once("error",n),this.server.listen(e,r)}),this.status={...this.status,code:I.ACTIVE},N("Listening on %s",this.server.address())}async pause(e){if(!this.server.listening&&this.status.code===I.PAUSED&&e){this.status={code:I.INACTIVE};return}!this.server.listening||this.status.code!==I.ACTIVE||(N("Closing server on %s",this.server.address()),this.status=e?{code:I.INACTIVE}:{...this.status,code:I.PAUSED},await new Promise((r,n)=>{this.server.close(o=>{o!=null?n(o):r()})}))}};var K=ee("libp2p:tcp"),Qt=class{opts;metrics;components;constructor(e,r={}){this.opts=r,this.components=e,e.metrics!=null&&(this.metrics={dialerEvents:e.metrics.registerCounterGroup("libp2p_tcp_dialer_events_total",{label:"event",help:"Total count of TCP dialer events by type"})})}[Zt]=!0;[Symbol.toStringTag]="@libp2p/tcp";async dial(e,r){r.keepAlive=r.keepAlive??!0;let n=await this._connect(e,r);n.on("error",a=>{K("socket error",a)});let o=He(n,{remoteAddr:e,socketInactivityTimeout:this.opts.outboundSocketInactivityTimeout,socketCloseTimeout:this.opts.socketCloseTimeout,metrics:this.metrics?.dialerEvents}),s=()=>{o.close().catch(a=>{K.error("Error closing maConn after abort",a)})};r.signal?.addEventListener("abort",s,{once:!0}),K("new outbound connection %s",o.remoteAddr);let i=await r.upgrader.upgradeOutbound(o);if(K("outbound connection %s upgraded",o.remoteAddr),r.signal?.removeEventListener("abort",s),r.signal?.aborted===!0)throw i.close().catch(a=>{K.error("Error closing conn after abort",a)}),new pe;return i}async _connect(e,r){if(r.signal?.aborted===!0)throw new pe;return new Promise((n,o)=>{let s=Date.now(),i=Pe(e),a=i.path??`${i.host??""}:${i.port}`;K("dialing %j",i);let p=fn.default.connect(i),y=h=>{h.message=`connection error ${a}: ${h.message}`,this.metrics?.dialerEvents.increment({error:!0}),g(h)},l=()=>{K("connection timeout %s",a),this.metrics?.dialerEvents.increment({timeout:!0});let h=new T(`connection timeout after ${Date.now()-s}ms`,"ERR_CONNECT_TIMEOUT");p.emit("error",h)},u=()=>{K("connection opened %j",i),this.metrics?.dialerEvents.increment({connect:!0}),g()},f=()=>{K("connection aborted %j",i),this.metrics?.dialerEvents.increment({abort:!0}),p.destroy(),g(new pe)},g=h=>{if(p.removeListener("error",y),p.removeListener("timeout",l),p.removeListener("connect",u),r.signal!=null&&r.signal.removeEventListener("abort",f),h!=null){o(h);return}n(p)};p.on("error",y),p.on("timeout",l),p.on("connect",u),r.signal!=null&&r.signal.addEventListener("abort",f)})}createListener(e){return new Qe({...e,maxConnections:this.opts.maxConnections,backlog:this.opts.backlog,closeServerOnMaxConnections:this.opts.closeServerOnMaxConnections,socketInactivityTimeout:this.opts.inboundSocketInactivityTimeout,socketCloseTimeout:this.opts.socketCloseTimeout,metrics:this.components.metrics})}filter(e){return e=Array.isArray(e)?e:[e],e.filter(r=>r.protoCodes().includes(290)?!1:r.protoCodes().includes(400)?!0:ne.matches(r.decapsulateCode(421)))}};function Js(t={}){return(e={})=>new Qt(e,t)}return xn(Xs);})();
7
7
  return Libp2PTcp}));
@@ -39,8 +39,11 @@ export declare class TCPListener extends EventEmitter<ListenerEvents> implements
39
39
  getAddrs(): Multiaddr[];
40
40
  listen(ma: Multiaddr): Promise<void>;
41
41
  close(): Promise<void>;
42
- private netListen;
43
- private netClose;
42
+ /**
43
+ * Can resume a stopped or start an inert server
44
+ */
45
+ private resume;
46
+ private pause;
44
47
  }
45
48
  export {};
46
49
  //# sourceMappingURL=listener.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"listener.d.ts","sourceRoot":"","sources":["../../src/listener.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAe,MAAM,0BAA0B,CAAA;AASpE,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,YAAY,CAAA;AAC1D,OAAO,KAAK,EAAuB,UAAU,EAAE,MAAM,8BAA8B,CAAA;AACnF,OAAO,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAA;AACnF,OAAO,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAA;AACrF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AAexD,MAAM,WAAW,+BAA+B;IAC9C,sEAAsE;IACtE,WAAW,EAAE,MAAM,CAAA;IACnB,kFAAkF;IAClF,UAAU,EAAE,MAAM,CAAA;IAClB,aAAa,CAAC,EAAE,CAAC,GAAG,EAAE,KAAK,KAAK,IAAI,CAAA;CACrC;AAED,UAAU,OAAQ,SAAQ,wBAAwB;IAChD,OAAO,CAAC,EAAE,CAAC,IAAI,EAAE,UAAU,KAAK,IAAI,CAAA;IACpC,QAAQ,EAAE,QAAQ,CAAA;IAClB,uBAAuB,CAAC,EAAE,MAAM,CAAA;IAChC,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,2BAA2B,CAAC,EAAE,+BAA+B,CAAA;CAC9D;AAKD,MAAM,WAAW,kBAAkB;IACjC,MAAM,EAAE,WAAW,CAAA;IACnB,MAAM,EAAE,YAAY,CAAA;IACpB,MAAM,EAAE,YAAY,CAAA;CACrB;AASD,qBAAa,WAAY,SAAQ,YAAY,CAAC,cAAc,CAAE,YAAW,QAAQ;IAQlE,OAAO,CAAC,QAAQ,CAAC,OAAO;IAPrC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAY;IACnC,mEAAmE;IACnE,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAiC;IAC7D,OAAO,CAAC,MAAM,CAA6B;IAC3C,OAAO,CAAC,OAAO,CAAC,CAAoB;IACpC,OAAO,CAAC,IAAI,CAAQ;gBAEU,OAAO,EAAE,OAAO;IAiF9C,OAAO,CAAC,QAAQ;IAgFhB,QAAQ,IAAK,SAAS,EAAE;IAgClB,MAAM,CAAE,EAAE,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAmBrC,KAAK,IAAK,OAAO,CAAC,IAAI,CAAC;YASf,SAAS;IAgBvB,OAAO,CAAC,QAAQ;CAwBjB"}
1
+ {"version":3,"file":"listener.d.ts","sourceRoot":"","sources":["../../src/listener.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,YAAY,EAAe,MAAM,0BAA0B,CAAA;AASpE,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,YAAY,CAAA;AAC1D,OAAO,KAAK,EAAuB,UAAU,EAAE,MAAM,8BAA8B,CAAA;AACnF,OAAO,KAAK,EAAE,YAAY,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAA;AACnF,OAAO,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAE,QAAQ,EAAE,MAAM,6BAA6B,CAAA;AACrF,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AAexD,MAAM,WAAW,+BAA+B;IAC9C,sEAAsE;IACtE,WAAW,EAAE,MAAM,CAAA;IACnB,kFAAkF;IAClF,UAAU,EAAE,MAAM,CAAA;IAClB,aAAa,CAAC,EAAE,CAAC,GAAG,EAAE,KAAK,KAAK,IAAI,CAAA;CACrC;AAED,UAAU,OAAQ,SAAQ,wBAAwB;IAChD,OAAO,CAAC,EAAE,CAAC,IAAI,EAAE,UAAU,KAAK,IAAI,CAAA;IACpC,QAAQ,EAAE,QAAQ,CAAA;IAClB,uBAAuB,CAAC,EAAE,MAAM,CAAA;IAChC,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,2BAA2B,CAAC,EAAE,+BAA+B,CAAA;CAC9D;AAED,MAAM,WAAW,kBAAkB;IACjC,MAAM,EAAE,WAAW,CAAA;IACnB,MAAM,EAAE,YAAY,CAAA;IACpB,MAAM,EAAE,YAAY,CAAA;CACrB;AAoBD,qBAAa,WAAY,SAAQ,YAAY,CAAC,cAAc,CAAE,YAAW,QAAQ;IAQlE,OAAO,CAAC,QAAQ,CAAC,OAAO;IAPrC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAY;IACnC,mEAAmE;IACnE,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAiC;IAC7D,OAAO,CAAC,MAAM,CAAmD;IACjE,OAAO,CAAC,OAAO,CAAC,CAAoB;IACpC,OAAO,CAAC,IAAI,CAAQ;gBAEU,OAAO,EAAE,OAAO;IAuF9C,OAAO,CAAC,QAAQ;IAqFhB,QAAQ,IAAK,SAAS,EAAE;IAgClB,MAAM,CAAE,EAAE,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAwBrC,KAAK,IAAK,OAAO,CAAC,IAAI,CAAC;IAU7B;;OAEG;YACW,MAAM;YAiBN,KAAK;CAgCpB"}
@@ -1,4 +1,5 @@
1
1
  import net from 'net';
2
+ import { CodeError } from '@libp2p/interface/errors';
2
3
  import { EventEmitter, CustomEvent } from '@libp2p/interface/events';
3
4
  import { logger } from '@libp2p/logger';
4
5
  import { CODE_P2P } from './constants.js';
@@ -16,14 +17,23 @@ async function attemptClose(maConn) {
16
17
  log.error('an error occurred closing the connection', err);
17
18
  }
18
19
  }
19
- const SERVER_STATUS_UP = 1;
20
- const SERVER_STATUS_DOWN = 0;
20
+ var TCPListenerStatusCode;
21
+ (function (TCPListenerStatusCode) {
22
+ /**
23
+ * When server object is initialized but we don't know the listening address yet or
24
+ * the server object is stopped manually, can be resumed only by calling listen()
25
+ **/
26
+ TCPListenerStatusCode[TCPListenerStatusCode["INACTIVE"] = 0] = "INACTIVE";
27
+ TCPListenerStatusCode[TCPListenerStatusCode["ACTIVE"] = 1] = "ACTIVE";
28
+ /* During the connection limits */
29
+ TCPListenerStatusCode[TCPListenerStatusCode["PAUSED"] = 2] = "PAUSED";
30
+ })(TCPListenerStatusCode || (TCPListenerStatusCode = {}));
21
31
  export class TCPListener extends EventEmitter {
22
32
  context;
23
33
  server;
24
34
  /** Keep track of open connections to destroy in case of timeout */
25
35
  connections = new Set();
26
- status = { started: false };
36
+ status = { code: TCPListenerStatusCode.INACTIVE };
27
37
  metrics;
28
38
  addr;
29
39
  constructor(context) {
@@ -41,7 +51,7 @@ export class TCPListener extends EventEmitter {
41
51
  if (context.closeServerOnMaxConnections != null) {
42
52
  // Sanity check options
43
53
  if (context.closeServerOnMaxConnections.closeAbove < context.closeServerOnMaxConnections.listenBelow) {
44
- throw Error('closeAbove must be >= listenBelow');
54
+ throw new CodeError('closeAbove must be >= listenBelow', 'ERROR_CONNECTION_LIMITS');
45
55
  }
46
56
  }
47
57
  this.server
@@ -83,7 +93,7 @@ export class TCPListener extends EventEmitter {
83
93
  })
84
94
  };
85
95
  this.metrics?.status.update({
86
- [this.addr]: SERVER_STATUS_UP
96
+ [this.addr]: TCPListenerStatusCode.ACTIVE
87
97
  });
88
98
  }
89
99
  this.dispatchEvent(new CustomEvent('listening'));
@@ -94,12 +104,20 @@ export class TCPListener extends EventEmitter {
94
104
  })
95
105
  .on('close', () => {
96
106
  this.metrics?.status.update({
97
- [this.addr]: SERVER_STATUS_DOWN
107
+ [this.addr]: this.status.code
98
108
  });
99
- this.dispatchEvent(new CustomEvent('close'));
109
+ // If this event is emitted, the transport manager will remove the listener from it's cache
110
+ // in the meanwhile if the connections are dropped then listener will start listening again
111
+ // and the transport manager will not be able to close the server
112
+ if (this.status.code !== TCPListenerStatusCode.PAUSED) {
113
+ this.dispatchEvent(new CustomEvent('close'));
114
+ }
100
115
  });
101
116
  }
102
117
  onSocket(socket) {
118
+ if (this.status.code !== TCPListenerStatusCode.ACTIVE) {
119
+ throw new CodeError('Server is is not listening yet', 'ERR_SERVER_NOT_RUNNING');
120
+ }
103
121
  // Avoid uncaught errors caused by unstable connections
104
122
  socket.on('error', err => {
105
123
  log('socket error', err);
@@ -108,7 +126,7 @@ export class TCPListener extends EventEmitter {
108
126
  let maConn;
109
127
  try {
110
128
  maConn = toMultiaddrConnection(socket, {
111
- listeningAddr: this.status.started ? this.status.listeningAddr : undefined,
129
+ listeningAddr: this.status.listeningAddr,
112
130
  socketInactivityTimeout: this.context.socketInactivityTimeout,
113
131
  socketCloseTimeout: this.context.socketCloseTimeout,
114
132
  metrics: this.metrics?.events,
@@ -132,9 +150,9 @@ export class TCPListener extends EventEmitter {
132
150
  this.connections.size < this.context.closeServerOnMaxConnections.listenBelow) {
133
151
  // The most likely case of error is if the port taken by this application is binded by
134
152
  // another process during the time the server if closed. In that case there's not much
135
- // we can do. netListen() will be called again every time a connection is dropped, which
153
+ // we can do. resume() will be called again every time a connection is dropped, which
136
154
  // acts as an eventual retry mechanism. onListenError allows the consumer act on this.
137
- this.netListen().catch(e => {
155
+ this.resume().catch(e => {
138
156
  log.error('error attempting to listen server once connection count under limit', e);
139
157
  this.context.closeServerOnMaxConnections?.onListenError?.(e);
140
158
  });
@@ -145,7 +163,9 @@ export class TCPListener extends EventEmitter {
145
163
  }
146
164
  if (this.context.closeServerOnMaxConnections != null &&
147
165
  this.connections.size >= this.context.closeServerOnMaxConnections.closeAbove) {
148
- this.netClose();
166
+ this.pause(false).catch(e => {
167
+ log.error('error attempting to close server once connection count over limit', e);
168
+ });
149
169
  }
150
170
  this.dispatchEvent(new CustomEvent('connection', { detail: conn }));
151
171
  })
@@ -168,7 +188,7 @@ export class TCPListener extends EventEmitter {
168
188
  }
169
189
  }
170
190
  getAddrs() {
171
- if (!this.status.started) {
191
+ if (this.status.code === TCPListenerStatusCode.INACTIVE) {
172
192
  return [];
173
193
  }
174
194
  let addrs = [];
@@ -198,27 +218,40 @@ export class TCPListener extends EventEmitter {
198
218
  return addrs.map(ma => peerId != null ? ma.encapsulate(`/p2p/${peerId}`) : ma);
199
219
  }
200
220
  async listen(ma) {
201
- if (this.status.started) {
202
- throw Error('server is already listening');
221
+ if (this.status.code === TCPListenerStatusCode.ACTIVE || this.status.code === TCPListenerStatusCode.PAUSED) {
222
+ throw new CodeError('server is already listening', 'ERR_SERVER_ALREADY_LISTENING');
203
223
  }
204
224
  const peerId = ma.getPeerId();
205
225
  const listeningAddr = peerId == null ? ma.decapsulateCode(CODE_P2P) : ma;
206
226
  const { backlog } = this.context;
207
- this.status = {
208
- started: true,
209
- listeningAddr,
210
- peerId,
211
- netConfig: multiaddrToNetConfig(listeningAddr, { backlog })
212
- };
213
- await this.netListen();
227
+ try {
228
+ this.status = {
229
+ code: TCPListenerStatusCode.ACTIVE,
230
+ listeningAddr,
231
+ peerId,
232
+ netConfig: multiaddrToNetConfig(listeningAddr, { backlog })
233
+ };
234
+ await this.resume();
235
+ }
236
+ catch (err) {
237
+ this.status = { code: TCPListenerStatusCode.INACTIVE };
238
+ throw err;
239
+ }
214
240
  }
215
241
  async close() {
216
- await Promise.all(Array.from(this.connections.values()).map(async (maConn) => { await attemptClose(maConn); }));
217
- // netClose already checks if server.listening
218
- this.netClose();
242
+ // Close connections and server the same time to avoid any race condition
243
+ await Promise.all([
244
+ Promise.all(Array.from(this.connections.values()).map(async (maConn) => attemptClose(maConn))),
245
+ this.pause(true).catch(e => {
246
+ log.error('error attempting to close server once connection count over limit', e);
247
+ })
248
+ ]);
219
249
  }
220
- async netListen() {
221
- if (!this.status.started || this.server.listening) {
250
+ /**
251
+ * Can resume a stopped or start an inert server
252
+ */
253
+ async resume() {
254
+ if (this.server.listening || this.status.code === TCPListenerStatusCode.INACTIVE) {
222
255
  return;
223
256
  }
224
257
  const netConfig = this.status.netConfig;
@@ -227,10 +260,15 @@ export class TCPListener extends EventEmitter {
227
260
  this.server.once('error', reject);
228
261
  this.server.listen(netConfig, resolve);
229
262
  });
263
+ this.status = { ...this.status, code: TCPListenerStatusCode.ACTIVE };
230
264
  log('Listening on %s', this.server.address());
231
265
  }
232
- netClose() {
233
- if (!this.status.started || !this.server.listening) {
266
+ async pause(permanent) {
267
+ if (!this.server.listening && this.status.code === TCPListenerStatusCode.PAUSED && permanent) {
268
+ this.status = { code: TCPListenerStatusCode.INACTIVE };
269
+ return;
270
+ }
271
+ if (!this.server.listening || this.status.code !== TCPListenerStatusCode.ACTIVE) {
234
272
  return;
235
273
  }
236
274
  log('Closing server on %s', this.server.address());
@@ -245,10 +283,12 @@ export class TCPListener extends EventEmitter {
245
283
  // Stops the server from accepting new connections and keeps existing connections.
246
284
  // 'close' event is emitted only emitted when all connections are ended.
247
285
  // The optional callback will be called once the 'close' event occurs.
248
- //
249
- // NOTE: Since we want to keep existing connections and have checked `!this.server.listening` it's not necessary
250
- // to pass a callback to close.
251
- this.server.close();
286
+ // We need to set this status before closing server, so other procedures are aware
287
+ // during the time the server is closing
288
+ this.status = permanent ? { code: TCPListenerStatusCode.INACTIVE } : { ...this.status, code: TCPListenerStatusCode.PAUSED };
289
+ await new Promise((resolve, reject) => {
290
+ this.server.close(err => { (err != null) ? reject(err) : resolve(); });
291
+ });
252
292
  }
253
293
  }
254
294
  //# sourceMappingURL=listener.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"listener.js","sourceRoot":"","sources":["../../src/listener.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"listener.js","sourceRoot":"","sources":["../../src/listener.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@libp2p/tcp",
3
- "version": "8.0.7",
3
+ "version": "8.0.8-c88de8e1",
4
4
  "description": "A TCP transport for libp2p",
5
5
  "license": "Apache-2.0 OR MIT",
6
6
  "homepage": "https://github.com/libp2p/js-libp2p/tree/master/packages/transport-tcp#readme",
@@ -50,16 +50,16 @@
50
50
  "test:electron-main": "aegir test -t electron-main"
51
51
  },
52
52
  "dependencies": {
53
- "@libp2p/interface": "^0.1.2",
54
- "@libp2p/logger": "^3.0.2",
55
- "@libp2p/utils": "^4.0.3",
53
+ "@libp2p/interface": "0.1.2-c88de8e1",
54
+ "@libp2p/logger": "3.0.2-c88de8e1",
55
+ "@libp2p/utils": "4.0.3-c88de8e1",
56
56
  "@multiformats/mafmt": "^12.1.2",
57
57
  "@multiformats/multiaddr": "^12.1.5",
58
58
  "@types/sinon": "^10.0.15",
59
59
  "stream-to-it": "^0.2.2"
60
60
  },
61
61
  "devDependencies": {
62
- "@libp2p/interface-compliance-tests": "^4.0.6",
62
+ "@libp2p/interface-compliance-tests": "4.1.0-c88de8e1",
63
63
  "aegir": "^40.0.8",
64
64
  "it-all": "^3.0.1",
65
65
  "it-pipe": "^3.0.1",
package/src/listener.ts CHANGED
@@ -1,4 +1,5 @@
1
1
  import net from 'net'
2
+ import { CodeError } from '@libp2p/interface/errors'
2
3
  import { EventEmitter, CustomEvent } from '@libp2p/interface/events'
3
4
  import { logger } from '@libp2p/logger'
4
5
  import { CODE_P2P } from './constants.js'
@@ -46,17 +47,25 @@ interface Context extends TCPCreateListenerOptions {
46
47
  closeServerOnMaxConnections?: CloseServerOnMaxConnectionsOpts
47
48
  }
48
49
 
49
- const SERVER_STATUS_UP = 1
50
- const SERVER_STATUS_DOWN = 0
51
-
52
50
  export interface TCPListenerMetrics {
53
51
  status: MetricGroup
54
52
  errors: CounterGroup
55
53
  events: CounterGroup
56
54
  }
57
55
 
58
- type Status = { started: false } | {
59
- started: true
56
+ enum TCPListenerStatusCode {
57
+ /**
58
+ * When server object is initialized but we don't know the listening address yet or
59
+ * the server object is stopped manually, can be resumed only by calling listen()
60
+ **/
61
+ INACTIVE = 0,
62
+ ACTIVE = 1,
63
+ /* During the connection limits */
64
+ PAUSED = 2,
65
+ }
66
+
67
+ type Status = { code: TCPListenerStatusCode.INACTIVE } | {
68
+ code: Exclude<TCPListenerStatusCode, TCPListenerStatusCode.INACTIVE>
60
69
  listeningAddr: Multiaddr
61
70
  peerId: string | null
62
71
  netConfig: NetConfig
@@ -66,7 +75,7 @@ export class TCPListener extends EventEmitter<ListenerEvents> implements Listene
66
75
  private readonly server: net.Server
67
76
  /** Keep track of open connections to destroy in case of timeout */
68
77
  private readonly connections = new Set<MultiaddrConnection>()
69
- private status: Status = { started: false }
78
+ private status: Status = { code: TCPListenerStatusCode.INACTIVE }
70
79
  private metrics?: TCPListenerMetrics
71
80
  private addr: string
72
81
 
@@ -88,7 +97,7 @@ export class TCPListener extends EventEmitter<ListenerEvents> implements Listene
88
97
  if (context.closeServerOnMaxConnections != null) {
89
98
  // Sanity check options
90
99
  if (context.closeServerOnMaxConnections.closeAbove < context.closeServerOnMaxConnections.listenBelow) {
91
- throw Error('closeAbove must be >= listenBelow')
100
+ throw new CodeError('closeAbove must be >= listenBelow', 'ERROR_CONNECTION_LIMITS')
92
101
  }
93
102
  }
94
103
 
@@ -133,7 +142,7 @@ export class TCPListener extends EventEmitter<ListenerEvents> implements Listene
133
142
  }
134
143
 
135
144
  this.metrics?.status.update({
136
- [this.addr]: SERVER_STATUS_UP
145
+ [this.addr]: TCPListenerStatusCode.ACTIVE
137
146
  })
138
147
  }
139
148
 
@@ -145,13 +154,22 @@ export class TCPListener extends EventEmitter<ListenerEvents> implements Listene
145
154
  })
146
155
  .on('close', () => {
147
156
  this.metrics?.status.update({
148
- [this.addr]: SERVER_STATUS_DOWN
157
+ [this.addr]: this.status.code
149
158
  })
150
- this.dispatchEvent(new CustomEvent('close'))
159
+
160
+ // If this event is emitted, the transport manager will remove the listener from it's cache
161
+ // in the meanwhile if the connections are dropped then listener will start listening again
162
+ // and the transport manager will not be able to close the server
163
+ if (this.status.code !== TCPListenerStatusCode.PAUSED) {
164
+ this.dispatchEvent(new CustomEvent('close'))
165
+ }
151
166
  })
152
167
  }
153
168
 
154
169
  private onSocket (socket: net.Socket): void {
170
+ if (this.status.code !== TCPListenerStatusCode.ACTIVE) {
171
+ throw new CodeError('Server is is not listening yet', 'ERR_SERVER_NOT_RUNNING')
172
+ }
155
173
  // Avoid uncaught errors caused by unstable connections
156
174
  socket.on('error', err => {
157
175
  log('socket error', err)
@@ -161,7 +179,7 @@ export class TCPListener extends EventEmitter<ListenerEvents> implements Listene
161
179
  let maConn: MultiaddrConnection
162
180
  try {
163
181
  maConn = toMultiaddrConnection(socket, {
164
- listeningAddr: this.status.started ? this.status.listeningAddr : undefined,
182
+ listeningAddr: this.status.listeningAddr,
165
183
  socketInactivityTimeout: this.context.socketInactivityTimeout,
166
184
  socketCloseTimeout: this.context.socketCloseTimeout,
167
185
  metrics: this.metrics?.events,
@@ -189,9 +207,9 @@ export class TCPListener extends EventEmitter<ListenerEvents> implements Listene
189
207
  ) {
190
208
  // The most likely case of error is if the port taken by this application is binded by
191
209
  // another process during the time the server if closed. In that case there's not much
192
- // we can do. netListen() will be called again every time a connection is dropped, which
210
+ // we can do. resume() will be called again every time a connection is dropped, which
193
211
  // acts as an eventual retry mechanism. onListenError allows the consumer act on this.
194
- this.netListen().catch(e => {
212
+ this.resume().catch(e => {
195
213
  log.error('error attempting to listen server once connection count under limit', e)
196
214
  this.context.closeServerOnMaxConnections?.onListenError?.(e as Error)
197
215
  })
@@ -206,7 +224,9 @@ export class TCPListener extends EventEmitter<ListenerEvents> implements Listene
206
224
  this.context.closeServerOnMaxConnections != null &&
207
225
  this.connections.size >= this.context.closeServerOnMaxConnections.closeAbove
208
226
  ) {
209
- this.netClose()
227
+ this.pause(false).catch(e => {
228
+ log.error('error attempting to close server once connection count over limit', e)
229
+ })
210
230
  }
211
231
 
212
232
  this.dispatchEvent(new CustomEvent<Connection>('connection', { detail: conn }))
@@ -232,7 +252,7 @@ export class TCPListener extends EventEmitter<ListenerEvents> implements Listene
232
252
  }
233
253
 
234
254
  getAddrs (): Multiaddr[] {
235
- if (!this.status.started) {
255
+ if (this.status.code === TCPListenerStatusCode.INACTIVE) {
236
256
  return []
237
257
  }
238
258
 
@@ -264,35 +284,44 @@ export class TCPListener extends EventEmitter<ListenerEvents> implements Listene
264
284
  }
265
285
 
266
286
  async listen (ma: Multiaddr): Promise<void> {
267
- if (this.status.started) {
268
- throw Error('server is already listening')
287
+ if (this.status.code === TCPListenerStatusCode.ACTIVE || this.status.code === TCPListenerStatusCode.PAUSED) {
288
+ throw new CodeError('server is already listening', 'ERR_SERVER_ALREADY_LISTENING')
269
289
  }
270
290
 
271
291
  const peerId = ma.getPeerId()
272
292
  const listeningAddr = peerId == null ? ma.decapsulateCode(CODE_P2P) : ma
273
293
  const { backlog } = this.context
274
294
 
275
- this.status = {
276
- started: true,
277
- listeningAddr,
278
- peerId,
279
- netConfig: multiaddrToNetConfig(listeningAddr, { backlog })
280
- }
295
+ try {
296
+ this.status = {
297
+ code: TCPListenerStatusCode.ACTIVE,
298
+ listeningAddr,
299
+ peerId,
300
+ netConfig: multiaddrToNetConfig(listeningAddr, { backlog })
301
+ }
281
302
 
282
- await this.netListen()
303
+ await this.resume()
304
+ } catch (err) {
305
+ this.status = { code: TCPListenerStatusCode.INACTIVE }
306
+ throw err
307
+ }
283
308
  }
284
309
 
285
310
  async close (): Promise<void> {
286
- await Promise.all(
287
- Array.from(this.connections.values()).map(async maConn => { await attemptClose(maConn) })
288
- )
289
-
290
- // netClose already checks if server.listening
291
- this.netClose()
311
+ // Close connections and server the same time to avoid any race condition
312
+ await Promise.all([
313
+ Promise.all(Array.from(this.connections.values()).map(async maConn => attemptClose(maConn))),
314
+ this.pause(true).catch(e => {
315
+ log.error('error attempting to close server once connection count over limit', e)
316
+ })
317
+ ])
292
318
  }
293
319
 
294
- private async netListen (): Promise<void> {
295
- if (!this.status.started || this.server.listening) {
320
+ /**
321
+ * Can resume a stopped or start an inert server
322
+ */
323
+ private async resume (): Promise<void> {
324
+ if (this.server.listening || this.status.code === TCPListenerStatusCode.INACTIVE) {
296
325
  return
297
326
  }
298
327
 
@@ -304,11 +333,17 @@ export class TCPListener extends EventEmitter<ListenerEvents> implements Listene
304
333
  this.server.listen(netConfig, resolve)
305
334
  })
306
335
 
336
+ this.status = { ...this.status, code: TCPListenerStatusCode.ACTIVE }
307
337
  log('Listening on %s', this.server.address())
308
338
  }
309
339
 
310
- private netClose (): void {
311
- if (!this.status.started || !this.server.listening) {
340
+ private async pause (permanent: boolean): Promise<void> {
341
+ if (!this.server.listening && this.status.code === TCPListenerStatusCode.PAUSED && permanent) {
342
+ this.status = { code: TCPListenerStatusCode.INACTIVE }
343
+ return
344
+ }
345
+
346
+ if (!this.server.listening || this.status.code !== TCPListenerStatusCode.ACTIVE) {
312
347
  return
313
348
  }
314
349
 
@@ -326,9 +361,12 @@ export class TCPListener extends EventEmitter<ListenerEvents> implements Listene
326
361
  // Stops the server from accepting new connections and keeps existing connections.
327
362
  // 'close' event is emitted only emitted when all connections are ended.
328
363
  // The optional callback will be called once the 'close' event occurs.
329
- //
330
- // NOTE: Since we want to keep existing connections and have checked `!this.server.listening` it's not necessary
331
- // to pass a callback to close.
332
- this.server.close()
364
+
365
+ // We need to set this status before closing server, so other procedures are aware
366
+ // during the time the server is closing
367
+ this.status = permanent ? { code: TCPListenerStatusCode.INACTIVE } : { ...this.status, code: TCPListenerStatusCode.PAUSED }
368
+ await new Promise<void>((resolve, reject) => {
369
+ this.server.close(err => { (err != null) ? reject(err) : resolve() })
370
+ })
333
371
  }
334
372
  }
@@ -1,16 +0,0 @@
1
- {
2
- "TCPComponents": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_tcp.TCPComponents.html",
3
- ".:TCPComponents": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_tcp.TCPComponents.html",
4
- "TCPCreateListenerOptions": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_tcp.TCPCreateListenerOptions.html",
5
- ".:TCPCreateListenerOptions": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_tcp.TCPCreateListenerOptions.html",
6
- "TCPDialOptions": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_tcp.TCPDialOptions.html",
7
- ".:TCPDialOptions": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_tcp.TCPDialOptions.html",
8
- "TCPMetrics": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_tcp.TCPMetrics.html",
9
- ".:TCPMetrics": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_tcp.TCPMetrics.html",
10
- "TCPOptions": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_tcp.TCPOptions.html",
11
- ".:TCPOptions": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_tcp.TCPOptions.html",
12
- "TCPSocketOptions": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_tcp.TCPSocketOptions.html",
13
- ".:TCPSocketOptions": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_tcp.TCPSocketOptions.html",
14
- "tcp": "https://libp2p.github.io/js-libp2p/functions/_libp2p_tcp.tcp.html",
15
- ".:tcp": "https://libp2p.github.io/js-libp2p/functions/_libp2p_tcp.tcp.html"
16
- }