@libp2p/websockets 8.1.3 → 8.1.4-1dfb74e79
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 +1 -1
- package/dist/src/index.d.ts +5 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +20 -2
- package/dist/src/index.js.map +1 -1
- package/dist/src/listener.d.ts +7 -1
- package/dist/src/listener.d.ts.map +1 -1
- package/dist/src/listener.js +38 -2
- package/dist/src/listener.js.map +1 -1
- package/dist/src/socket-to-conn.d.ts +3 -1
- package/dist/src/socket-to-conn.d.ts.map +1 -1
- package/dist/src/socket-to-conn.js +8 -0
- package/dist/src/socket-to-conn.js.map +1 -1
- package/package.json +6 -6
- package/src/index.ts +28 -3
- package/src/listener.ts +49 -3
- package/src/socket-to-conn.ts +13 -1
- package/dist/typedoc-urls.json +0 -18
package/dist/index.min.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
(function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PWebsockets = factory()}(typeof self !== 'undefined' ? self : this, function () {
|
|
2
|
-
"use strict";var Libp2PWebsockets=(()=>{var Gr=Object.create;var me=Object.defineProperty;var Hr=Object.getOwnPropertyDescriptor;var Xr=Object.getOwnPropertyNames;var Jr=Object.getPrototypeOf,Kr=Object.prototype.hasOwnProperty;var Ue=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),C=(t,e)=>{for(var r in e)me(t,r,{get:e[r],enumerable:!0})},St=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Xr(e))!Kr.call(t,o)&&o!==r&&me(t,o,{get:()=>e[o],enumerable:!(n=Hr(e,o))||n.enumerable});return t};var At=(t,e,r)=>(r=t!=null?Gr(Jr(t)):{},St(e||!t||!t.__esModule?me(r,"default",{value:t,enumerable:!0}):r,t)),Yr=t=>St(me({},"__esModule",{value:!0}),t);var xr=Ue(Ae=>{"use strict";Object.defineProperty(Ae,"__esModule",{value:!0});var mt=class{constructor(){this.pullQueue=[],this.pushQueue=[],this.eventHandlers={},this.isPaused=!1,this.isStopped=!1}push(e){if(this.isStopped)return;let r={value:e,done:!1};if(this.pullQueue.length){let n=this.pullQueue.shift();n&&n.resolve(r)}else this.pushQueue.push(Promise.resolve(r)),this.highWaterMark!==void 0&&this.pushQueue.length>=this.highWaterMark&&!this.isPaused&&(this.isPaused=!0,this.eventHandlers.highWater?this.eventHandlers.highWater():console&&console.warn(`EventIterator queue reached ${this.pushQueue.length} items`))}stop(){if(!this.isStopped){this.isStopped=!0,this.remove();for(let e of this.pullQueue)e.resolve({value:void 0,done:!0});this.pullQueue.length=0}}fail(e){if(!this.isStopped)if(this.isStopped=!0,this.remove(),this.pullQueue.length){for(let r of this.pullQueue)r.reject(e);this.pullQueue.length=0}else{let r=Promise.reject(e);r.catch(()=>{}),this.pushQueue.push(r)}}remove(){Promise.resolve().then(()=>{this.removeCallback&&this.removeCallback()})}[Symbol.asyncIterator](){return{next:e=>{let r=this.pushQueue.shift();return r?(this.lowWaterMark!==void 0&&this.pushQueue.length<=this.lowWaterMark&&this.isPaused&&(this.isPaused=!1,this.eventHandlers.lowWater&&this.eventHandlers.lowWater()),r):this.isStopped?Promise.resolve({value:void 0,done:!0}):new Promise((n,o)=>{this.pullQueue.push({resolve:n,reject:o})})},return:()=>(this.isStopped=!0,this.pushQueue.length=0,this.remove(),Promise.resolve({value:void 0,done:!0}))}}},Se=class{constructor(e,{highWaterMark:r=100,lowWaterMark:n=1}={}){let o=new mt;o.highWaterMark=r,o.lowWaterMark=n,o.removeCallback=e({push:s=>o.push(s),stop:()=>o.stop(),fail:s=>o.fail(s),on:(s,i)=>{o.eventHandlers[s]=i}})||(()=>{}),this[Symbol.asyncIterator]=()=>o[Symbol.asyncIterator](),Object.freeze(this)}};Ae.EventIterator=Se;Ae.default=Se});var gr=Ue(fe=>{"use strict";Object.defineProperty(fe,"__esModule",{value:!0});var wt=xr();fe.EventIterator=wt.EventIterator;function Mo(t,e,r){return new wt.EventIterator(({push:n})=>(this.addEventListener(t,n,e),()=>this.removeEventListener(t,n,e)),r)}fe.subscribe=Mo;fe.default=wt.EventIterator});var Ur=Ue((ha,Tr)=>{function zo(){return!!(typeof window<"u"&&typeof window.process=="object"&&window.process.type==="renderer"||typeof process<"u"&&typeof process.versions=="object"&&process.versions.electron||typeof navigator=="object"&&typeof navigator.userAgent=="string"&&navigator.userAgent.indexOf("Electron")>=0)}Tr.exports=zo});var Yo={};C(Yo,{webSockets:()=>Ko});var It=Symbol.for("@libp2p/transport");var Ct;(function(t){t[t.FATAL_ALL=0]="FATAL_ALL",t[t.NO_FATAL=1]="NO_FATAL"})(Ct||(Ct={}));var z=class extends Error{code;props;constructor(e,r,n){super(e),this.code=r,this.name=n?.name??"CodeError",this.props=n??{}}};var Pt=Symbol.for("@libp2p/service-capabilities"),rs=Symbol.for("@libp2p/service-dependencies");var Oe={};C(Oe,{base58btc:()=>E,base58flickr:()=>on});var Is=new Uint8Array(0);function Tt(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}function $(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")}function Ut(t){return new TextEncoder().encode(t)}function Nt(t){return new TextDecoder().decode(t)}function Zr(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 c=t.length,u=t.charAt(0),m=Math.log(c)/Math.log(256),h=Math.log(256)/Math.log(c);function g(l){if(l instanceof Uint8Array||(ArrayBuffer.isView(l)?l=new Uint8Array(l.buffer,l.byteOffset,l.byteLength):Array.isArray(l)&&(l=Uint8Array.from(l))),!(l instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(l.length===0)return"";for(var v=0,q=0,T=0,N=l.length;T!==N&&l[T]===0;)T++,v++;for(var L=(N-T)*h+1>>>0,P=new Uint8Array(L);T!==N;){for(var D=l[T],k=0,U=L-1;(D!==0||k<q)&&U!==-1;U--,k++)D+=256*P[U]>>>0,P[U]=D%c>>>0,D=D/c>>>0;if(D!==0)throw new Error("Non-zero carry");q=k,T++}for(var O=L-q;O!==L&&P[O]===0;)O++;for(var he=u.repeat(v);O<L;++O)he+=t.charAt(P[O]);return he}function y(l){if(typeof l!="string")throw new TypeError("Expected String");if(l.length===0)return new Uint8Array;var v=0;if(l[v]!==" "){for(var q=0,T=0;l[v]===u;)q++,v++;for(var N=(l.length-v)*m+1>>>0,L=new Uint8Array(N);l[v];){var P=r[l.charCodeAt(v)];if(P===255)return;for(var D=0,k=N-1;(P!==0||D<T)&&k!==-1;k--,D++)P+=c*L[k]>>>0,L[k]=P%256>>>0,P=P/256>>>0;if(P!==0)throw new Error("Non-zero carry");T=D,v++}if(l[v]!==" "){for(var U=N-T;U!==N&&L[U]===0;)U++;for(var O=new Uint8Array(q+(N-U)),he=q;U!==N;)O[he++]=L[U++];return O}}}function I(l){var v=y(l);if(v)return v;throw new Error(`Non-${e} character`)}return{encode:g,decodeUnsafe:y,decode:I}}var en=Zr,tn=en,Dt=tn;var Ne=class{name;prefix;baseEncode;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")}},Le=class{name;prefix;baseDecode;prefixCodePoint;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 Rt(this,e)}},De=class{decoders;constructor(e){this.decoders=e}or(e){return Rt(this,e)}decode(e){let r=e[0],n=this.decoders[r];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Rt(t,e){return new De({...t.decoders??{[t.prefix]:t},...e.decoders??{[e.prefix]:e}})}var Re=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,r,n,o){this.name=e,this.prefix=r,this.baseEncode=n,this.baseDecode=o,this.encoder=new Ne(e,r,n),this.decoder=new Le(e,r,o)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function K({name:t,prefix:e,encode:r,decode:n}){return new Re(t,e,r,n)}function V({name:t,prefix:e,alphabet:r}){let{encode:n,decode:o}=Dt(r,t);return K({prefix:e,name:t,encode:n,decode:s=>$(o(s))})}function rn(t,e,r,n){let o={};for(let h=0;h<e.length;++h)o[e[h]]=h;let s=t.length;for(;t[s-1]==="=";)--s;let i=new Uint8Array(s*r/8|0),c=0,u=0,m=0;for(let h=0;h<s;++h){let g=o[t[h]];if(g===void 0)throw new SyntaxError(`Non-${n} character`);u=u<<r|g,c+=r,c>=8&&(c-=8,i[m++]=255&u>>c)}if(c>=r||255&u<<8-c)throw new SyntaxError("Unexpected end of data");return i}function nn(t,e,r){let n=e[e.length-1]==="=",o=(1<<r)-1,s="",i=0,c=0;for(let u=0;u<t.length;++u)for(c=c<<8|t[u],i+=8;i>r;)i-=r,s+=e[o&c>>i];if(i!==0&&(s+=e[o&c<<r-i]),n)for(;s.length*r&7;)s+="=";return s}function w({name:t,prefix:e,bitsPerChar:r,alphabet:n}){return K({prefix:e,name:t,encode(o){return nn(o,n,r)},decode(o){return rn(o,n,r,t)}})}var E=V({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),on=V({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var $e={};C($e,{base32:()=>F,base32hex:()=>pn,base32hexpad:()=>un,base32hexpadupper:()=>ln,base32hexupper:()=>dn,base32pad:()=>cn,base32padupper:()=>an,base32upper:()=>sn,base32z:()=>fn});var F=w({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),sn=w({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),cn=w({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),an=w({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),pn=w({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),dn=w({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),un=w({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ln=w({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),fn=w({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var hn=Ft,Ot=128,mn=127,wn=~mn,xn=Math.pow(2,31);function Ft(t,e,r){e=e||[],r=r||0;for(var n=r;t>=xn;)e[r++]=t&255|Ot,t/=128;for(;t&wn;)e[r++]=t&255|Ot,t>>>=7;return e[r]=t|0,Ft.bytes=r-n+1,e}var gn=Fe,bn=128,$t=127;function Fe(t,n){var r=0,n=n||0,o=0,s=n,i,c=t.length;do{if(s>=c)throw Fe.bytes=0,new RangeError("Could not decode varint");i=t[s++],r+=o<28?(i&$t)<<o:(i&$t)*Math.pow(2,o),o+=7}while(i>=bn);return Fe.bytes=s-n,r}var yn=Math.pow(2,7),vn=Math.pow(2,14),En=Math.pow(2,21),Sn=Math.pow(2,28),An=Math.pow(2,35),Cn=Math.pow(2,42),In=Math.pow(2,49),Pn=Math.pow(2,56),Tn=Math.pow(2,63),Un=function(t){return t<yn?1:t<vn?2:t<En?3:t<Sn?4:t<An?5:t<Cn?6:t<In?7:t<Pn?8:t<Tn?9:10},Nn={encode:hn,decode:gn,encodingLength:Un},Ln=Nn,ae=Ln;function pe(t,e=0){return[ae.decode(t,e),ae.decode.bytes]}function Y(t,e,r=0){return ae.encode(t,e,r),e}function Z(t){return ae.encodingLength(t)}function Q(t,e){let r=e.byteLength,n=Z(t),o=n+Z(r),s=new Uint8Array(o+r);return Y(t,s,0),Y(r,s,n),s.set(e,o),new ee(t,r,e,s)}function xe(t){let e=$(t),[r,n]=pe(e),[o,s]=pe(e.subarray(n)),i=e.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new ee(r,o,i,e)}function Mt(t,e){if(t===e)return!0;{let r=e;return t.code===r.code&&t.size===r.size&&r.bytes instanceof Uint8Array&&Tt(t.bytes,r.bytes)}}var ee=class{code;size;digest;bytes;constructor(e,r,n,o){this.code=e,this.size=r,this.digest=n,this.bytes=o}};function kt(t,e){let{bytes:r,version:n}=t;switch(n){case 0:return Rn(r,Me(t),e??E.encoder);default:return On(r,Me(t),e??F.encoder)}}var zt=new WeakMap;function Me(t){let e=zt.get(t);if(e==null){let r=new Map;return zt.set(t,r),r}return e}var W=class t{code;version;multihash;bytes;"/";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!==de)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(r.code!==$n)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=Q(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!=null&&e.code===n.code&&e.version===n.version&&Mt(e.multihash,n.multihash)}toString(e){return kt(this,e)}toJSON(){return{"/":kt(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let 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??Vt(n,o,s.bytes))}else if(r[Fn]===!0){let{version:n,multihash:o,code:s}=r,i=xe(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!==de)throw new Error(`Version 0 CID must use dag-pb (code: ${de}) block encoding`);return new t(e,r,n,n.bytes)}case 1:{let o=Vt(e,r,n.bytes);return new t(e,r,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return t.create(0,de,e)}static createV1(e,r){return t.create(1,e,r)}static decode(e){let[r,n]=t.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return r}static decodeFirst(e){let r=t.inspectBytes(e),n=r.size-r.multihashSize,o=$(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 ee(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[g,y]=pe(e.subarray(r));return r+=y,g},o=n(),s=de;if(o===18?(o=0,r=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=r,c=n(),u=n(),m=r+u,h=m-i;return{version:o,codec:s,multihashCode:c,digestSize:u,multihashSize:h,size:m}}static parse(e,r){let[n,o]=Dn(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 Me(s).set(n,e),s}};function Dn(t,e){switch(t[0]){case"Q":{let r=e??E;return[E.prefix,r.decode(`${E.prefix}${t}`)]}case E.prefix:{let r=e??E;return[E.prefix,r.decode(t)]}case F.prefix:{let r=e??F;return[F.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)]}}}function Rn(t,e,r){let{prefix:n}=r;if(n!==E.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}function On(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}var de=112,$n=18;function Vt(t,e,r){let n=Z(t),o=n+Z(e),s=new Uint8Array(o+r.byteLength);return Y(t,s,0),Y(e,s,n),s.set(r,o),s}var Fn=Symbol.for("@ipld/js-cid/CID");function Wt(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 ke={};C(ke,{base10:()=>Mn});var Mn=V({prefix:"9",name:"base10",alphabet:"0123456789"});var ze={};C(ze,{base16:()=>kn,base16upper:()=>zn});var kn=w({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),zn=w({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ve={};C(Ve,{base2:()=>Vn});var Vn=w({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var We={};C(We,{base256emoji:()=>qn});var _t=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}"),Wn=_t.reduce((t,e,r)=>(t[r]=e,t),[]),_n=_t.reduce((t,e,r)=>(t[e.codePointAt(0)]=r,t),[]);function Bn(t){return t.reduce((e,r)=>(e+=Wn[r],e),"")}function jn(t){let e=[];for(let r of t){let n=_n[r.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${r}`);e.push(n)}return new Uint8Array(e)}var qn=K({prefix:"\u{1F680}",name:"base256emoji",encode:Bn,decode:jn});var _e={};C(_e,{base36:()=>Qn,base36upper:()=>Gn});var Qn=V({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Gn=V({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Be={};C(Be,{base64:()=>Hn,base64pad:()=>Xn,base64url:()=>Jn,base64urlpad:()=>Kn});var Hn=w({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Xn=w({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Jn=w({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Kn=w({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var je={};C(je,{base8:()=>Yn});var Yn=w({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var qe={};C(qe,{identity:()=>Zn});var Zn=K({prefix:"\0",name:"identity",encode:t=>Nt(t),decode:t=>Ut(t)});var Ks=new TextEncoder,Ys=new TextDecoder;var Qe={};C(Qe,{identity:()=>oo});var Bt=0,ro="identity",jt=$;function no(t){return Q(Bt,jt(t))}var oo={code:Bt,name:ro,encode:jt,digest:no};var Xe={};C(Xe,{sha256:()=>so,sha512:()=>io});function He({name:t,code:e,encode:r}){return new Ge(t,e,r)}var Ge=class{name;code;encode;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?Q(this.code,r):r.then(n=>Q(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Qt(t){return async e=>new Uint8Array(await crypto.subtle.digest(t,e))}var so=He({name:"sha2-256",code:18,encode:Qt("SHA-256")}),io=He({name:"sha2-512",code:19,encode:Qt("SHA-512")});var ue={...qe,...Ve,...je,...ke,...ze,...$e,..._e,...Oe,...Be,...We},ui={...Xe,...Qe};function re(t=0){return new Uint8Array(t)}function Ht(t,e,r,n){return{name:t,prefix:e,encoder:{name:t,prefix:e,encode:r},decoder:{decode:n}}}var Gt=Ht("utf8","u",t=>"u"+new TextDecoder("utf8").decode(t),t=>new TextEncoder().encode(t.substring(1))),Je=Ht("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=re(t.length);for(let r=0;r<t.length;r++)e[r]=t.charCodeAt(r);return e}),co={utf8:Gt,"utf-8":Gt,hex:ue.base16,latin1:Je,ascii:Je,binary:Je,...ue},ge=co;function S(t,e="utf8"){let r=ge[e];if(r==null)throw new Error(`Unsupported encoding "${e}"`);return r.encoder.encode(t).substring(1)}var ao=Math.pow(2,7),po=Math.pow(2,14),uo=Math.pow(2,21),Ke=Math.pow(2,28),Ye=Math.pow(2,35),Ze=Math.pow(2,42),et=Math.pow(2,49),f=128,b=127;function R(t){if(t<ao)return 1;if(t<po)return 2;if(t<uo)return 3;if(t<Ke)return 4;if(t<Ye)return 5;if(t<Ze)return 6;if(t<et)return 7;if(Number.MAX_SAFE_INTEGER!=null&&t>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function lo(t,e,r=0){switch(R(t)){case 8:e[r++]=t&255|f,t/=128;case 7:e[r++]=t&255|f,t/=128;case 6:e[r++]=t&255|f,t/=128;case 5:e[r++]=t&255|f,t/=128;case 4:e[r++]=t&255|f,t>>>=7;case 3:e[r++]=t&255|f,t>>>=7;case 2:e[r++]=t&255|f,t>>>=7;case 1:{e[r++]=t&255,t>>>=7;break}default:throw new Error("unreachable")}return e}function fo(t,e,r=0){switch(R(t)){case 8:e.set(r++,t&255|f),t/=128;case 7:e.set(r++,t&255|f),t/=128;case 6:e.set(r++,t&255|f),t/=128;case 5:e.set(r++,t&255|f),t/=128;case 4:e.set(r++,t&255|f),t>>>=7;case 3:e.set(r++,t&255|f),t>>>=7;case 2:e.set(r++,t&255|f),t>>>=7;case 1:{e.set(r++,t&255),t>>>=7;break}default:throw new Error("unreachable")}return e}function ho(t,e){let r=t[e],n=0;if(n+=r&b,r<f||(r=t[e+1],n+=(r&b)<<7,r<f)||(r=t[e+2],n+=(r&b)<<14,r<f)||(r=t[e+3],n+=(r&b)<<21,r<f)||(r=t[e+4],n+=(r&b)*Ke,r<f)||(r=t[e+5],n+=(r&b)*Ye,r<f)||(r=t[e+6],n+=(r&b)*Ze,r<f)||(r=t[e+7],n+=(r&b)*et,r<f))return n;throw new RangeError("Could not decode varint")}function mo(t,e){let r=t.get(e),n=0;if(n+=r&b,r<f||(r=t.get(e+1),n+=(r&b)<<7,r<f)||(r=t.get(e+2),n+=(r&b)<<14,r<f)||(r=t.get(e+3),n+=(r&b)<<21,r<f)||(r=t.get(e+4),n+=(r&b)*Ke,r<f)||(r=t.get(e+5),n+=(r&b)*Ye,r<f)||(r=t.get(e+6),n+=(r&b)*Ze,r<f)||(r=t.get(e+7),n+=(r&b)*et,r<f))return n;throw new RangeError("Could not decode varint")}function ne(t,e,r=0){return e==null&&(e=re(R(t))),e instanceof Uint8Array?lo(t,e,r):fo(t,e,r)}function G(t,e=0){return t instanceof Uint8Array?ho(t,e):mo(t,e)}function M(t,e){e==null&&(e=t.reduce((o,s)=>o+s.length,0));let r=re(e),n=0;for(let o of t)r.set(o,n),n+=o.length;return 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,c=this.peekChar();if(c===void 0)return;let u=c==="0",m=2**(8*o)-1;for(;;){let h=this.readAtomically(()=>{let g=this.readChar();if(g===void 0)return;let y=Number.parseInt(g,e);if(!Number.isNaN(y))return y});if(h===void 0)break;if(s*=e,s+=h,s>m||(i+=1,r!==void 0&&i>r))return}if(i!==0)return!n&&u&&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),[c]=e(s.subarray(0,i));return r.set(s.subarray(0,c),16-c),r})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Jt=45,wo=15,oe=new be;function tt(t){if(!(t.length>wo))return oe.new(t).parseWith(()=>oe.readIPv4Addr())}function rt(t){if(t.includes("%")&&(t=t.split("%")[0]),!(t.length>Jt))return oe.new(t).parseWith(()=>oe.readIPv6Addr())}function ye(t){if(t.includes("%")&&(t=t.split("%")[0]),!(t.length>Jt))return oe.new(t).parseWith(()=>oe.readIPAddr())}var Oi=parseInt("0xFFFF",16),$i=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function le(t,e="utf8"){let r=ge[e];if(r==null)throw new Error(`Unsupported encoding "${e}"`);return r.decoder.decode(`${r.prefix}${t}`)}function Zt(t){return!!tt(t)}function er(t){return!!rt(t)}function ve(t){return!!ye(t)}var tr=Zt,vo=er,nt=function(t){let e=0;if(t=t.toString().trim(),tr(t)){let r=new Uint8Array(e+4);return t.split(/\./g).forEach(n=>{r[e++]=parseInt(n,10)&255}),r}if(vo(t)){let r=t.split(":",8),n;for(n=0;n<r.length;n++){let s=tr(r[n]),i;s&&(i=nt(r[n]),r[n]=S(i.slice(0,2),"base16")),i!=null&&++n<8&&r.splice(n,0,S(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")},rr=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 se={},ot={},So=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[481,-1,"http-path"],[777,-1,"memory"]];So.forEach(t=>{let e=Ao(...t);ot[e.code]=e,se[e.name]=e});function Ao(t,e,r,n,o){return{code:t,size:e,name:r,resolvable:!!n,path:!!o}}function d(t){if(typeof t=="number"){if(ot[t]!=null)return ot[t];throw new Error(`no protocol with code: ${t}`)}else if(typeof t=="string"){if(se[t]!=null)return se[t];throw new Error(`no protocol with name: ${t}`)}throw new Error(`invalid protocol id type: ${typeof t}`)}var yc=d("ip4"),vc=d("ip6"),Ec=d("ipcidr");function at(t,e){switch(d(t).code){case 4:case 41:return Io(e);case 42:return ct(e);case 6:case 273:case 33:case 132:return sr(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return ct(e);case 421:return No(e);case 444:return or(e);case 445:return or(e);case 466:return Uo(e);case 481:return globalThis.encodeURIComponent(ct(e));default:return S(e,"base16")}}function pt(t,e){switch(d(t).code){case 4:return nr(e);case 41:return nr(e);case 42:return it(e);case 6:case 273:case 33:case 132:return dt(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return it(e);case 421:return Po(e);case 444:return Lo(e);case 445:return Do(e);case 466:return To(e);case 481:return it(globalThis.decodeURIComponent(e));default:return le(e,"base16")}}var st=Object.values(ue).map(t=>t.decoder),Co=function(){let t=st[0].or(st[1]);return st.slice(2).forEach(e=>t=t.or(e)),t}();function nr(t){if(!ve(t))throw new Error("invalid ip address");return nt(t)}function Io(t){let e=rr(t,0,t.length);if(e==null)throw new Error("ipBuff is required");if(!ve(e))throw new Error("invalid ip address");return e}function dt(t){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,t),new Uint8Array(e)}function sr(t){return new DataView(t.buffer).getUint16(t.byteOffset)}function it(t){let e=le(t),r=Uint8Array.from(ne(e.length));return M([r,e],r.length+e.length)}function ct(t){let e=G(t);if(t=t.slice(R(e)),t.length!==e)throw new Error("inconsistent lengths");return S(t)}function Po(t){let e;t[0]==="Q"||t[0]==="1"?e=xe(E.decode(`z${t}`)).bytes:e=W.parse(t).multihash.bytes;let r=Uint8Array.from(ne(e.length));return M([r,e],r.length+e.length)}function To(t){let e=Co.decode(t),r=Uint8Array.from(ne(e.length));return M([r,e],r.length+e.length)}function Uo(t){let e=G(t),r=t.slice(R(e));if(r.length!==e)throw new Error("inconsistent lengths");return"u"+S(r,"base64url")}function No(t){let e=G(t),r=t.slice(R(e));if(r.length!==e)throw new Error("inconsistent lengths");return S(r,"base58btc")}function Lo(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=F.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=dt(n);return M([r,o],r.length+o.length)}function Do(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=F.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=dt(n);return M([r,o],r.length+o.length)}function or(t){let e=t.slice(0,t.length-2),r=t.slice(t.length-2),n=S(e,"base32"),o=sr(r);return`${n}:${o}`}function ir(t){t=ut(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],c=d(i);if(c.size===0){e.push([c.code]),r.push([c.code]);continue}if(s++,s>=o.length)throw ar("invalid address: "+t);if(c.path===!0){n=ut(o.slice(s).join("/")),e.push([c.code,pt(c.code,n)]),r.push([c.code,n]);break}let u=pt(c.code,o[s]);e.push([c.code,u]),r.push([c.code,at(c.code,u)])}return{string:cr(r),bytes:ft(e),tuples:e,stringTuples:r,path:n}}function lt(t){let e=[],r=[],n=null,o=0;for(;o<t.length;){let s=G(t,o),i=R(s),c=d(s),u=Ro(c,t.slice(o+i));if(u===0){e.push([s]),r.push([s]),o+=i;continue}let m=t.slice(o+i,o+i+u);if(o+=u+i,o>t.length)throw ar("Invalid address Uint8Array: "+S(t,"base16"));e.push([s,m]);let h=at(s,m);if(r.push([s,h]),c.path===!0){n=h;break}}return{bytes:Uint8Array.from(t),string:cr(r),tuples:e,stringTuples:r,path:n}}function cr(t){let e=[];return t.map(r=>{let n=d(r[0]);return e.push(n.name),r.length>1&&r[1]!=null&&e.push(r[1]),null}),ut(e.join("/"))}function ft(t){return M(t.map(e=>{let r=d(e[0]),n=Uint8Array.from(ne(r.code));return e.length>1&&e[1]!=null&&(n=M([n,e[1]])),n}))}function Ro(t,e){if(t.size>0)return t.size/8;if(t.size===0)return 0;{let r=G(e instanceof Uint8Array?e:Uint8Array.from(e));return r+R(r)}}function ut(t){return"/"+t.trim().split("/").filter(e=>e).join("/")}function ar(t){return new Error("Error parsing address: "+t)}var Oo=Symbol.for("nodejs.util.inspect.custom"),ht=Symbol.for("@multiformats/js-multiaddr/multiaddr"),$o=[d("dns").code,d("dns4").code,d("dns6").code,d("dnsaddr").code],Ee=class t{bytes;#t;#e;#r;#n;[ht]=!0;constructor(e){e==null&&(e="");let r;if(e instanceof Uint8Array)r=lt(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);r=ir(e)}else if(dr(e))r=lt(e.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=r.bytes,this.#t=r.string,this.#e=r.tuples,this.#r=r.stringTuples,this.#n=r.path}toString(){return this.#t}toJSON(){return this.toString()}toOptions(){let e,r,n,o,s="",i=d("tcp"),c=d("udp"),u=d("ip4"),m=d("ip6"),h=d("dns6"),g=d("ip6zone");for(let[I,l]of this.stringTuples())I===g.code&&(s=`%${l??""}`),$o.includes(I)&&(r=i.name,o=443,n=`${l??""}${s}`,e=I===h.code?6:4),(I===i.code||I===c.code)&&(r=d(I).name,o=parseInt(l??"")),(I===u.code||I===m.code)&&(r=d(I).name,n=`${l??""}${s}`,e=I===m.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.#e.map(([e])=>Object.assign({},d(e)))}protoCodes(){return this.#e.map(([e])=>e)}protoNames(){return this.#e.map(([e])=>d(e).name)}tuples(){return this.#e}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(ft(r.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,o])=>{n===se.p2p.code&&e.push([n,o]),n===se["p2p-circuit"].code&&(e=[])});let r=e.pop();if(r?.[1]!=null){let n=r[1];return n[0]==="Q"||n[0]==="1"?S(E.decode(`z${n}`),"base58btc"):S(W.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(e){return Wt(this.bytes,e.bytes)}async resolve(e){let r=this.protos().find(s=>s.resolvable);if(r==null)return[this];let n=pr.get(r.name);if(n==null)throw new z(`no available resolver for ${r.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,e)).map(s=>_(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)}[Oo](){return`Multiaddr(${this.#t})`}};var pr=new Map;function dr(t){return!!t?.[ht]}function _(t){return new Ee(t)}var Fo=[d("tcp").code,d("dns").code,d("dnsaddr").code,d("dns4").code,d("dns6").code];function ur(t){let e;try{e=d("sni").code}catch{return null}for(let[r,n]of t)if(r===e&&n!==void 0)return n;return null}function lr(t){return t.some(([e,r])=>e===d("tls").code)}function A(t,e,r){let n=fr[d(t).name];if(n===void 0)throw new Error(`Can't interpret protocol ${d(t).name}`);let o=n(e,r);return t===d("ip6").code?`[${o}]`:o}var fr={ip4:(t,e)=>t,ip6:(t,e)=>e.length===0?t:`[${t}]`,tcp:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return`tcp://${A(r[0],r[1]??"",e)}:${t}`},udp:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return`udp://${A(r[0],r[1]??"",e)}:${t}`},dnsaddr:(t,e)=>t,dns4:(t,e)=>t,dns6:(t,e)=>t,dns:(t,e)=>t,ipfs:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return`${A(r[0],r[1]??"",e)}/ipfs/${t}`},p2p:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return`${A(r[0],r[1]??"",e)}/p2p/${t}`},http:(t,e)=>{let r=lr(e),n=ur(e);if(r&&n!==null)return`https://${n}`;let o=r?"https://":"http://",s=e.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let i=A(s[0],s[1]??"",e);return i=i.replace("tcp://",""),`${o}${i}`},"http-path":(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");let n=A(r[0],r[1]??"",e),o=decodeURIComponent(t);return`${n}/${o}`},tls:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return A(r[0],r[1]??"",e)},sni:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return A(r[0],r[1]??"",e)},https:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");let n=A(r[0],r[1]??"",e);return n=n.replace("tcp://",""),`https://${n}`},ws:(t,e)=>{let r=lr(e),n=ur(e);if(r&&n!==null)return`wss://${n}`;let o=r?"wss://":"ws://",s=e.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let i=A(s[0],s[1]??"",e);return i=i.replace("tcp://",""),`${o}${i}`},wss:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");let n=A(r[0],r[1]??"",e);return n=n.replace("tcp://",""),`wss://${n}`},"p2p-websocket-star":(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return`${A(r[0],r[1]??"",e)}/p2p-websocket-star`},"p2p-webrtc-star":(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return`${A(r[0],r[1]??"",e)}/p2p-webrtc-star`},"p2p-webrtc-direct":(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return`${A(r[0],r[1]??"",e)}/p2p-webrtc-direct`}};function hr(t,e){let n=_(t).stringTuples(),o=n.pop();if(o===void 0)throw new Error("Unexpected end of multiaddr");let s=d(o[0]),i=fr[s.name];if(i==null)throw new Error(`No interpreter found for ${s.name}`);let c=i(o[1]??"",n);return e?.assumeHttp!==!1&&Fo.includes(o[0])&&(c=c.replace(/^.*:\/\//,""),o[1]==="443"?c=`https://${c}`:c=`http://${c}`),(c.startsWith("http://")||c.startsWith("https://"))&&(c=new URL(c).toString(),c.endsWith("/")&&(c=c.substring(0,c.length-1))),c}var mr=async t=>{if(t.readyState>=2)throw new Error("socket closed");t.readyState!==1&&await new Promise((e,r)=>{function n(){t.removeEventListener("open",o),t.removeEventListener("error",s)}function o(){n(),e()}function s(i){n(),r(i.error??new Error(`connect ECONNREFUSED ${t.url}`))}t.addEventListener("open",o),t.addEventListener("error",s)})};var wr=(t,e)=>(e=e??{},e.closeOnEnd=e.closeOnEnd!==!1,async n=>{for await(let o of n){try{await mr(t)}catch(s){if(s.message==="socket closed")break;throw s}if(t.readyState===t.CLOSING||t.readyState===t.CLOSED)break;t.send(o)}e.closeOnEnd!=null&&t.readyState<=1&&await new Promise((o,s)=>{t.addEventListener("close",i=>{if(i.wasClean||i.code===1006)o();else{let c=Object.assign(new Error("ws error"),{event:i});s(c)}}),setTimeout(()=>{t.close()})})});var yr=At(gr(),1);function br(t){return t instanceof ArrayBuffer||t?.constructor?.name==="ArrayBuffer"&&typeof t?.byteLength=="number"}var vr=t=>{t.binaryType="arraybuffer";let e=async()=>{await new Promise((s,i)=>{if(n){s();return}if(o!=null){i(o);return}let c=h=>{t.removeEventListener("open",u),t.removeEventListener("error",m),h()},u=()=>{c(s)},m=h=>{c(()=>{i(h.error??new Error(`connect ECONNREFUSED ${t.url}`))})};t.addEventListener("open",u),t.addEventListener("error",m)})},r=async function*(){let s=new yr.EventIterator(({push:i,stop:c,fail:u})=>{let m=g=>{let y=null;typeof g.data=="string"&&(y=le(g.data)),br(g.data)&&(y=new Uint8Array(g.data)),g.data instanceof Uint8Array&&(y=g.data),y!=null&&i(y)},h=g=>{u(g.error??new Error("Socket error"))};return t.addEventListener("message",m),t.addEventListener("error",h),t.addEventListener("close",c),()=>{t.removeEventListener("message",m),t.removeEventListener("error",h),t.removeEventListener("close",c)}},{highWaterMark:1/0});await e();for await(let i of s)yield br(i)?new Uint8Array(i):i}(),n=t.readyState===1,o;return t.addEventListener("open",()=>{n=!0,o=null}),t.addEventListener("close",()=>{n=!1,o=null}),t.addEventListener("error",s=>{n||(o=s.error??new Error(`connect ECONNREFUSED ${t.url}`))}),Object.assign(r,{connected:e})};var Er=(t,e)=>{e=e??{};let r=vr(t),n=e.remoteAddress,o=e.remotePort;if(t.url!=null)try{let i=new URL(t.url);n=i.hostname,o=parseInt(i.port,10)}catch{}if(n==null||o==null)throw new Error("Remote connection did not have address and/or port");return{sink:wr(t,e),source:r,connected:async()=>{await r.connected()},close:async()=>{(t.readyState===t.CONNECTING||t.readyState===t.OPEN)&&await new Promise(i=>{t.addEventListener("close",()=>{i()}),t.close()})},destroy:()=>{t.terminate!=null?t.terminate():t.close()},remoteAddress:n,remotePort:o,socket:t}};var Sr=WebSocket;var ko={"http:":"ws:","https:":"wss:"},Ar="ws:",Cr=(t,e)=>{if(t.startsWith("//")&&(t=`${e?.protocol??Ar}${t}`),t.startsWith("/")&&e!=null){let n=e.protocol??Ar,o=e.host,s=e.port!=null&&o?.endsWith(`:${e.port}`)!==!0?`:${e.port}`:"";t=`${n}//${o}${s}${t}`}let r=new URL(t);for(let[n,o]of Object.entries(ko))r.protocol===n&&(r.protocol=o);return r};function Ir(t,e){let r=typeof window>"u"?void 0:window.location;e=e??{};let n=Cr(t,r),o=new Sr(n.toString(),e.websocket);return Er(o,e)}function xt(){let t={};return t.promise=new Promise((e,r)=>{t.resolve=e,t.reject=r}),t}var Ce=class extends Event{type;detail;constructor(e,r){super(e),this.type=e,this.detail=r}};var Ie=class extends Error{type;code;constructor(e,r){super(e??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=r??"ABORT_ERR"}};async function Pr(t,e,r){if(e==null)return t;if(e.aborted)return Promise.reject(new Ie(r?.errorMessage,r?.errorCode));let n,o=new Ie(r?.errorMessage,r?.errorCode);try{return await Promise.race([t,new Promise((s,i)=>{n=()=>{i(o)},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var Nr=At(Ur(),1),Vo=typeof window=="object"&&typeof document=="object"&&document.nodeType===9,Lr=(0,Nr.default)(),Dr=Vo&&!Lr;var ma=typeof globalThis.process<"u"&&typeof globalThis.process.release<"u"&&globalThis.process.release.name==="node"&&!Lr,Rr=typeof importScripts=="function"&&typeof self<"u"&&typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope,wa=typeof globalThis.process<"u"&&typeof globalThis.process.env<"u"&&globalThis.process.env["NODE"+"_"+"ENV"]==="test",xa=typeof navigator<"u"&&navigator.product==="ReactNative";var Wo=a("dns4"),_o=a("dns6"),Bo=a("dnsaddr"),j=x(a("dns"),Bo,Wo,_o),Pe=x(a("ip4"),a("ip6")),ie=x(p(Pe,a("tcp")),p(j,a("tcp"))),Te=p(Pe,a("udp")),jo=p(Te,a("utp")),qo=p(Te,a("quic")),Qo=p(Te,a("quic-v1")),gt=x(p(ie,a("ws")),p(j,a("ws"))),ce=x(p(gt,a("p2p")),gt),bt=x(p(ie,a("wss")),p(j,a("wss")),p(ie,a("tls"),a("ws")),p(j,a("tls"),a("ws"))),X=x(p(bt,a("p2p")),bt),yt=x(p(ie,a("http")),p(Pe,a("http")),p(j,a("http"))),vt=x(p(ie,a("https")),p(Pe,a("https")),p(j,a("https"))),Or=p(Te,a("webrtc-direct"),a("certhash")),Mr=x(p(Or,a("p2p")),Or),$r=p(Qo,a("webtransport"),a("certhash"),a("certhash")),kr=x(p($r,a("p2p")),$r),zr=x(p(ce,a("p2p-webrtc-star"),a("p2p")),p(X,a("p2p-webrtc-star"),a("p2p")),p(ce,a("p2p-webrtc-star")),p(X,a("p2p-webrtc-star"))),ya=x(p(ce,a("p2p-websocket-star"),a("p2p")),p(X,a("p2p-websocket-star"),a("p2p")),p(ce,a("p2p-websocket-star")),p(X,a("p2p-websocket-star"))),Vr=x(p(yt,a("p2p-webrtc-direct"),a("p2p")),p(vt,a("p2p-webrtc-direct"),a("p2p")),p(yt,a("p2p-webrtc-direct")),p(vt,a("p2p-webrtc-direct"))),J=x(gt,bt,yt,vt,zr,Vr,ie,jo,qo,j,Mr,kr),va=x(p(J,a("p2p-stardust"),a("p2p")),p(J,a("p2p-stardust"))),B=x(p(J,a("p2p")),zr,Vr,Mr,kr,a("p2p")),Fr=x(p(B,a("p2p-circuit"),B),p(B,a("p2p-circuit")),p(a("p2p-circuit"),B),p(J,a("p2p-circuit")),p(a("p2p-circuit"),J),a("p2p-circuit")),Wr=()=>x(p(Fr,Wr),Fr),H=Wr(),Ea=x(p(H,B,H),p(B,H),p(H,B),H,B);var Sa=x(p(H,a("webrtc"),a("p2p")),p(H,a("webrtc")),p(J,a("webrtc"),a("p2p")),p(J,a("webrtc")),a("webrtc"));function _r(t){function e(r){let n;try{n=_(r)}catch{return!1}let o=t(n.protoNames());return o===null?!1:o===!0||o===!1?o:o.length===0}return e}function p(...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:_r(e),partialMatch:e}}function x(...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:_r(e),partialMatch:e}}function a(t){let e=t;function r(o){let s;try{s=_(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}}function Br(t){return t.filter(e=>{if(e.protoCodes().includes(290))return!1;let r=e.decapsulateCode(421);return ce.matches(r)||X.matches(r)})}function jr(t){return t.filter(e=>{if(e.protoCodes().includes(290))return!1;let r=e.decapsulateCode(421);return X.matches(r)})}function qr(){throw new Error("WebSocket Servers can not be created in the browser!")}function Qr(t,e,r){let n=r.logger.forComponent("libp2p:websockets:maconn"),o={log:n,async sink(s){try{await t.sink(async function*(){for await(let i of s)i instanceof Uint8Array?yield i:yield i.subarray()}())}catch(i){i.type!=="aborted"&&n.error(i)}},source:t.source,remoteAddr:e,timeline:{open:Date.now()},async close(s={}){let i=Date.now();if(s.signal==null){let u=AbortSignal.timeout(500);s={...s,signal:u}}let c=()=>{let{host:u,port:m}=o.remoteAddr.toOptions();n("timeout closing stream to %s:%s after %dms, destroying it manually",u,m,Date.now()-i),this.abort(new z("Socket close timeout","ERR_SOCKET_CLOSE_TIMEOUT"))};s.signal?.addEventListener("abort",c);try{await t.close()}catch(u){n.error("error closing WebSocket gracefully",u),this.abort(u)}finally{s.signal?.removeEventListener("abort",c),o.timeline.close=Date.now()}},abort(s){let{host:i,port:c}=o.remoteAddr.toOptions();n("timeout closing stream to %s:%s due to error",i,c,s),t.destroy(),o.timeline.close=Date.now()}};return t.socket.addEventListener("close",()=>{o.timeline.close==null&&(o.timeline.close=Date.now())},{once:!0}),o}var Et=class{log;init;logger;constructor(e,r){this.log=e.logger.forComponent("libp2p:websockets"),this.logger=e.logger,this.init=r}[It]=!0;[Symbol.toStringTag]="@libp2p/websockets";[Pt]=["@libp2p/transport"];async dial(e,r){this.log("dialing %s",e),r=r??{};let n=await this._connect(e,r),o=Qr(n,e,{logger:this.logger});this.log("new outbound connection %s",o.remoteAddr);let s=await r.upgrader.upgradeOutbound(o,r);return this.log("outbound connection %s upgraded",o.remoteAddr),s}async _connect(e,r){r?.signal?.throwIfAborted();let n=e.toOptions();this.log("dialing %s:%s",n.host,n.port);let o=xt(),s=Ir(hr(e),this.init);s.socket.addEventListener("error",()=>{let i=new z(`Could not connect to ${e.toString()}`,"ERR_CONNECTION_FAILED");this.log.error("connection error:",i),o.reject(i)});try{r.onProgress?.(new Ce("websockets:open-connection")),await Pr(Promise.race([s.connected(),o.promise]),r.signal)}catch(i){throw s.close().catch(c=>{this.log.error("error closing raw socket",c)}),i}return this.log("connected %s",e),s}createListener(e){return qr({logger:this.logger},{...this.init,...e})}listenFilter(e){return e=Array.isArray(e)?e:[e],this.init?.filter!=null?this.init?.filter(e):Dr||Rr?jr(e):Br(e)}dialFilter(e){return this.listenFilter(e)}};function Ko(t={}){return e=>new Et(e,t)}return Yr(Yo);})();
|
|
2
|
+
"use strict";var Libp2PWebsockets=(()=>{var Gr=Object.create;var me=Object.defineProperty;var Hr=Object.getOwnPropertyDescriptor;var Xr=Object.getOwnPropertyNames;var Jr=Object.getPrototypeOf,Kr=Object.prototype.hasOwnProperty;var Ue=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),C=(t,e)=>{for(var r in e)me(t,r,{get:e[r],enumerable:!0})},St=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Xr(e))!Kr.call(t,o)&&o!==r&&me(t,o,{get:()=>e[o],enumerable:!(n=Hr(e,o))||n.enumerable});return t};var At=(t,e,r)=>(r=t!=null?Gr(Jr(t)):{},St(e||!t||!t.__esModule?me(r,"default",{value:t,enumerable:!0}):r,t)),Yr=t=>St(me({},"__esModule",{value:!0}),t);var xr=Ue(Ae=>{"use strict";Object.defineProperty(Ae,"__esModule",{value:!0});var mt=class{constructor(){this.pullQueue=[],this.pushQueue=[],this.eventHandlers={},this.isPaused=!1,this.isStopped=!1}push(e){if(this.isStopped)return;let r={value:e,done:!1};if(this.pullQueue.length){let n=this.pullQueue.shift();n&&n.resolve(r)}else this.pushQueue.push(Promise.resolve(r)),this.highWaterMark!==void 0&&this.pushQueue.length>=this.highWaterMark&&!this.isPaused&&(this.isPaused=!0,this.eventHandlers.highWater?this.eventHandlers.highWater():console&&console.warn(`EventIterator queue reached ${this.pushQueue.length} items`))}stop(){if(!this.isStopped){this.isStopped=!0,this.remove();for(let e of this.pullQueue)e.resolve({value:void 0,done:!0});this.pullQueue.length=0}}fail(e){if(!this.isStopped)if(this.isStopped=!0,this.remove(),this.pullQueue.length){for(let r of this.pullQueue)r.reject(e);this.pullQueue.length=0}else{let r=Promise.reject(e);r.catch(()=>{}),this.pushQueue.push(r)}}remove(){Promise.resolve().then(()=>{this.removeCallback&&this.removeCallback()})}[Symbol.asyncIterator](){return{next:e=>{let r=this.pushQueue.shift();return r?(this.lowWaterMark!==void 0&&this.pushQueue.length<=this.lowWaterMark&&this.isPaused&&(this.isPaused=!1,this.eventHandlers.lowWater&&this.eventHandlers.lowWater()),r):this.isStopped?Promise.resolve({value:void 0,done:!0}):new Promise((n,o)=>{this.pullQueue.push({resolve:n,reject:o})})},return:()=>(this.isStopped=!0,this.pushQueue.length=0,this.remove(),Promise.resolve({value:void 0,done:!0}))}}},Se=class{constructor(e,{highWaterMark:r=100,lowWaterMark:n=1}={}){let o=new mt;o.highWaterMark=r,o.lowWaterMark=n,o.removeCallback=e({push:s=>o.push(s),stop:()=>o.stop(),fail:s=>o.fail(s),on:(s,i)=>{o.eventHandlers[s]=i}})||(()=>{}),this[Symbol.asyncIterator]=()=>o[Symbol.asyncIterator](),Object.freeze(this)}};Ae.EventIterator=Se;Ae.default=Se});var gr=Ue(fe=>{"use strict";Object.defineProperty(fe,"__esModule",{value:!0});var wt=xr();fe.EventIterator=wt.EventIterator;function ko(t,e,r){return new wt.EventIterator(({push:n})=>(this.addEventListener(t,n,e),()=>this.removeEventListener(t,n,e)),r)}fe.subscribe=ko;fe.default=wt.EventIterator});var Ur=Ue((ha,Tr)=>{function zo(){return!!(typeof window<"u"&&typeof window.process=="object"&&window.process.type==="renderer"||typeof process<"u"&&typeof process.versions=="object"&&process.versions.electron||typeof navigator=="object"&&typeof navigator.userAgent=="string"&&navigator.userAgent.indexOf("Electron")>=0)}Tr.exports=zo});var Yo={};C(Yo,{webSockets:()=>Ko});var It=Symbol.for("@libp2p/transport");var Ct;(function(t){t[t.FATAL_ALL=0]="FATAL_ALL",t[t.NO_FATAL=1]="NO_FATAL"})(Ct||(Ct={}));var z=class extends Error{code;props;constructor(e,r,n){super(e),this.code=r,this.name=n?.name??"CodeError",this.props=n??{}}};var Pt=Symbol.for("@libp2p/service-capabilities"),rs=Symbol.for("@libp2p/service-dependencies");var Oe={};C(Oe,{base58btc:()=>E,base58flickr:()=>on});var Is=new Uint8Array(0);function Tt(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}function $(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")}function Ut(t){return new TextEncoder().encode(t)}function Nt(t){return new TextDecoder().decode(t)}function Zr(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 c=t.length,d=t.charAt(0),m=Math.log(c)/Math.log(256),l=Math.log(256)/Math.log(c);function w(f){if(f instanceof Uint8Array||(ArrayBuffer.isView(f)?f=new Uint8Array(f.buffer,f.byteOffset,f.byteLength):Array.isArray(f)&&(f=Uint8Array.from(f))),!(f instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(f.length===0)return"";for(var v=0,q=0,T=0,N=f.length;T!==N&&f[T]===0;)T++,v++;for(var L=(N-T)*l+1>>>0,P=new Uint8Array(L);T!==N;){for(var D=f[T],M=0,U=L-1;(D!==0||M<q)&&U!==-1;U--,M++)D+=256*P[U]>>>0,P[U]=D%c>>>0,D=D/c>>>0;if(D!==0)throw new Error("Non-zero carry");q=M,T++}for(var O=L-q;O!==L&&P[O]===0;)O++;for(var he=d.repeat(v);O<L;++O)he+=t.charAt(P[O]);return he}function y(f){if(typeof f!="string")throw new TypeError("Expected String");if(f.length===0)return new Uint8Array;var v=0;if(f[v]!==" "){for(var q=0,T=0;f[v]===d;)q++,v++;for(var N=(f.length-v)*m+1>>>0,L=new Uint8Array(N);f[v];){var P=r[f.charCodeAt(v)];if(P===255)return;for(var D=0,M=N-1;(P!==0||D<T)&&M!==-1;M--,D++)P+=c*L[M]>>>0,L[M]=P%256>>>0,P=P/256>>>0;if(P!==0)throw new Error("Non-zero carry");T=D,v++}if(f[v]!==" "){for(var U=N-T;U!==N&&L[U]===0;)U++;for(var O=new Uint8Array(q+(N-U)),he=q;U!==N;)O[he++]=L[U++];return O}}}function I(f){var v=y(f);if(v)return v;throw new Error(`Non-${e} character`)}return{encode:w,decodeUnsafe:y,decode:I}}var en=Zr,tn=en,Dt=tn;var Ne=class{name;prefix;baseEncode;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")}},Le=class{name;prefix;baseDecode;prefixCodePoint;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 Rt(this,e)}},De=class{decoders;constructor(e){this.decoders=e}or(e){return Rt(this,e)}decode(e){let r=e[0],n=this.decoders[r];if(n!=null)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Rt(t,e){return new De({...t.decoders??{[t.prefix]:t},...e.decoders??{[e.prefix]:e}})}var Re=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(e,r,n,o){this.name=e,this.prefix=r,this.baseEncode=n,this.baseDecode=o,this.encoder=new Ne(e,r,n),this.decoder=new Le(e,r,o)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}};function K({name:t,prefix:e,encode:r,decode:n}){return new Re(t,e,r,n)}function V({name:t,prefix:e,alphabet:r}){let{encode:n,decode:o}=Dt(r,t);return K({prefix:e,name:t,encode:n,decode:s=>$(o(s))})}function rn(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),c=0,d=0,m=0;for(let l=0;l<s;++l){let w=o[t[l]];if(w===void 0)throw new SyntaxError(`Non-${n} character`);d=d<<r|w,c+=r,c>=8&&(c-=8,i[m++]=255&d>>c)}if(c>=r||255&d<<8-c)throw new SyntaxError("Unexpected end of data");return i}function nn(t,e,r){let n=e[e.length-1]==="=",o=(1<<r)-1,s="",i=0,c=0;for(let d=0;d<t.length;++d)for(c=c<<8|t[d],i+=8;i>r;)i-=r,s+=e[o&c>>i];if(i!==0&&(s+=e[o&c<<r-i]),n)for(;s.length*r&7;)s+="=";return s}function x({name:t,prefix:e,bitsPerChar:r,alphabet:n}){return K({prefix:e,name:t,encode(o){return nn(o,n,r)},decode(o){return rn(o,n,r,t)}})}var E=V({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),on=V({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var $e={};C($e,{base32:()=>F,base32hex:()=>pn,base32hexpad:()=>un,base32hexpadupper:()=>ln,base32hexupper:()=>dn,base32pad:()=>cn,base32padupper:()=>an,base32upper:()=>sn,base32z:()=>fn});var F=x({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),sn=x({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),cn=x({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),an=x({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),pn=x({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),dn=x({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),un=x({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ln=x({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),fn=x({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var hn=Ft,Ot=128,mn=127,wn=~mn,xn=Math.pow(2,31);function Ft(t,e,r){e=e||[],r=r||0;for(var n=r;t>=xn;)e[r++]=t&255|Ot,t/=128;for(;t&wn;)e[r++]=t&255|Ot,t>>>=7;return e[r]=t|0,Ft.bytes=r-n+1,e}var gn=Fe,bn=128,$t=127;function Fe(t,n){var r=0,n=n||0,o=0,s=n,i,c=t.length;do{if(s>=c)throw Fe.bytes=0,new RangeError("Could not decode varint");i=t[s++],r+=o<28?(i&$t)<<o:(i&$t)*Math.pow(2,o),o+=7}while(i>=bn);return Fe.bytes=s-n,r}var yn=Math.pow(2,7),vn=Math.pow(2,14),En=Math.pow(2,21),Sn=Math.pow(2,28),An=Math.pow(2,35),Cn=Math.pow(2,42),In=Math.pow(2,49),Pn=Math.pow(2,56),Tn=Math.pow(2,63),Un=function(t){return t<yn?1:t<vn?2:t<En?3:t<Sn?4:t<An?5:t<Cn?6:t<In?7:t<Pn?8:t<Tn?9:10},Nn={encode:hn,decode:gn,encodingLength:Un},Ln=Nn,ae=Ln;function pe(t,e=0){return[ae.decode(t,e),ae.decode.bytes]}function Y(t,e,r=0){return ae.encode(t,e,r),e}function Z(t){return ae.encodingLength(t)}function Q(t,e){let r=e.byteLength,n=Z(t),o=n+Z(r),s=new Uint8Array(o+r);return Y(t,s,0),Y(r,s,n),s.set(e,o),new ee(t,r,e,s)}function xe(t){let e=$(t),[r,n]=pe(e),[o,s]=pe(e.subarray(n)),i=e.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new ee(r,o,i,e)}function kt(t,e){if(t===e)return!0;{let r=e;return t.code===r.code&&t.size===r.size&&r.bytes instanceof Uint8Array&&Tt(t.bytes,r.bytes)}}var ee=class{code;size;digest;bytes;constructor(e,r,n,o){this.code=e,this.size=r,this.digest=n,this.bytes=o}};function Mt(t,e){let{bytes:r,version:n}=t;switch(n){case 0:return Rn(r,ke(t),e??E.encoder);default:return On(r,ke(t),e??F.encoder)}}var zt=new WeakMap;function ke(t){let e=zt.get(t);if(e==null){let r=new Map;return zt.set(t,r),r}return e}var W=class t{code;version;multihash;bytes;"/";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!==de)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(r.code!==$n)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=Q(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!=null&&e.code===n.code&&e.version===n.version&&kt(e.multihash,n.multihash)}toString(e){return Mt(this,e)}toJSON(){return{"/":Mt(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(e){if(e==null)return null;let 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??Vt(n,o,s.bytes))}else if(r[Fn]===!0){let{version:n,multihash:o,code:s}=r,i=xe(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!==de)throw new Error(`Version 0 CID must use dag-pb (code: ${de}) block encoding`);return new t(e,r,n,n.bytes)}case 1:{let o=Vt(e,r,n.bytes);return new t(e,r,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return t.create(0,de,e)}static createV1(e,r){return t.create(1,e,r)}static decode(e){let[r,n]=t.decodeFirst(e);if(n.length!==0)throw new Error("Incorrect length");return r}static decodeFirst(e){let r=t.inspectBytes(e),n=r.size-r.multihashSize,o=$(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 ee(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[w,y]=pe(e.subarray(r));return r+=y,w},o=n(),s=de;if(o===18?(o=0,r=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=r,c=n(),d=n(),m=r+d,l=m-i;return{version:o,codec:s,multihashCode:c,digestSize:d,multihashSize:l,size:m}}static parse(e,r){let[n,o]=Dn(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 ke(s).set(n,e),s}};function Dn(t,e){switch(t[0]){case"Q":{let r=e??E;return[E.prefix,r.decode(`${E.prefix}${t}`)]}case E.prefix:{let r=e??E;return[E.prefix,r.decode(t)]}case F.prefix:{let r=e??F;return[F.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)]}}}function Rn(t,e,r){let{prefix:n}=r;if(n!==E.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}function On(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}var de=112,$n=18;function Vt(t,e,r){let n=Z(t),o=n+Z(e),s=new Uint8Array(o+r.byteLength);return Y(t,s,0),Y(e,s,n),s.set(r,o),s}var Fn=Symbol.for("@ipld/js-cid/CID");function Wt(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 Me={};C(Me,{base10:()=>kn});var kn=V({prefix:"9",name:"base10",alphabet:"0123456789"});var ze={};C(ze,{base16:()=>Mn,base16upper:()=>zn});var Mn=x({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),zn=x({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ve={};C(Ve,{base2:()=>Vn});var Vn=x({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var We={};C(We,{base256emoji:()=>qn});var _t=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}"),Wn=_t.reduce((t,e,r)=>(t[r]=e,t),[]),_n=_t.reduce((t,e,r)=>(t[e.codePointAt(0)]=r,t),[]);function Bn(t){return t.reduce((e,r)=>(e+=Wn[r],e),"")}function jn(t){let e=[];for(let r of t){let n=_n[r.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${r}`);e.push(n)}return new Uint8Array(e)}var qn=K({prefix:"\u{1F680}",name:"base256emoji",encode:Bn,decode:jn});var _e={};C(_e,{base36:()=>Qn,base36upper:()=>Gn});var Qn=V({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Gn=V({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Be={};C(Be,{base64:()=>Hn,base64pad:()=>Xn,base64url:()=>Jn,base64urlpad:()=>Kn});var Hn=x({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Xn=x({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Jn=x({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Kn=x({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var je={};C(je,{base8:()=>Yn});var Yn=x({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var qe={};C(qe,{identity:()=>Zn});var Zn=K({prefix:"\0",name:"identity",encode:t=>Nt(t),decode:t=>Ut(t)});var Ks=new TextEncoder,Ys=new TextDecoder;var Qe={};C(Qe,{identity:()=>oo});var Bt=0,ro="identity",jt=$;function no(t){return Q(Bt,jt(t))}var oo={code:Bt,name:ro,encode:jt,digest:no};var Xe={};C(Xe,{sha256:()=>so,sha512:()=>io});function He({name:t,code:e,encode:r}){return new Ge(t,e,r)}var Ge=class{name;code;encode;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?Q(this.code,r):r.then(n=>Q(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Qt(t){return async e=>new Uint8Array(await crypto.subtle.digest(t,e))}var so=He({name:"sha2-256",code:18,encode:Qt("SHA-256")}),io=He({name:"sha2-512",code:19,encode:Qt("SHA-512")});var ue={...qe,...Ve,...je,...Me,...ze,...$e,..._e,...Oe,...Be,...We},ui={...Xe,...Qe};function re(t=0){return new Uint8Array(t)}function Ht(t,e,r,n){return{name:t,prefix:e,encoder:{name:t,prefix:e,encode:r},decoder:{decode:n}}}var Gt=Ht("utf8","u",t=>"u"+new TextDecoder("utf8").decode(t),t=>new TextEncoder().encode(t.substring(1))),Je=Ht("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=re(t.length);for(let r=0;r<t.length;r++)e[r]=t.charCodeAt(r);return e}),co={utf8:Gt,"utf-8":Gt,hex:ue.base16,latin1:Je,ascii:Je,binary:Je,...ue},ge=co;function S(t,e="utf8"){let r=ge[e];if(r==null)throw new Error(`Unsupported encoding "${e}"`);return r.encoder.encode(t).substring(1)}var ao=Math.pow(2,7),po=Math.pow(2,14),uo=Math.pow(2,21),Ke=Math.pow(2,28),Ye=Math.pow(2,35),Ze=Math.pow(2,42),et=Math.pow(2,49),h=128,b=127;function R(t){if(t<ao)return 1;if(t<po)return 2;if(t<uo)return 3;if(t<Ke)return 4;if(t<Ye)return 5;if(t<Ze)return 6;if(t<et)return 7;if(Number.MAX_SAFE_INTEGER!=null&&t>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function lo(t,e,r=0){switch(R(t)){case 8:e[r++]=t&255|h,t/=128;case 7:e[r++]=t&255|h,t/=128;case 6:e[r++]=t&255|h,t/=128;case 5:e[r++]=t&255|h,t/=128;case 4:e[r++]=t&255|h,t>>>=7;case 3:e[r++]=t&255|h,t>>>=7;case 2:e[r++]=t&255|h,t>>>=7;case 1:{e[r++]=t&255,t>>>=7;break}default:throw new Error("unreachable")}return e}function fo(t,e,r=0){switch(R(t)){case 8:e.set(r++,t&255|h),t/=128;case 7:e.set(r++,t&255|h),t/=128;case 6:e.set(r++,t&255|h),t/=128;case 5:e.set(r++,t&255|h),t/=128;case 4:e.set(r++,t&255|h),t>>>=7;case 3:e.set(r++,t&255|h),t>>>=7;case 2:e.set(r++,t&255|h),t>>>=7;case 1:{e.set(r++,t&255),t>>>=7;break}default:throw new Error("unreachable")}return e}function ho(t,e){let r=t[e],n=0;if(n+=r&b,r<h||(r=t[e+1],n+=(r&b)<<7,r<h)||(r=t[e+2],n+=(r&b)<<14,r<h)||(r=t[e+3],n+=(r&b)<<21,r<h)||(r=t[e+4],n+=(r&b)*Ke,r<h)||(r=t[e+5],n+=(r&b)*Ye,r<h)||(r=t[e+6],n+=(r&b)*Ze,r<h)||(r=t[e+7],n+=(r&b)*et,r<h))return n;throw new RangeError("Could not decode varint")}function mo(t,e){let r=t.get(e),n=0;if(n+=r&b,r<h||(r=t.get(e+1),n+=(r&b)<<7,r<h)||(r=t.get(e+2),n+=(r&b)<<14,r<h)||(r=t.get(e+3),n+=(r&b)<<21,r<h)||(r=t.get(e+4),n+=(r&b)*Ke,r<h)||(r=t.get(e+5),n+=(r&b)*Ye,r<h)||(r=t.get(e+6),n+=(r&b)*Ze,r<h)||(r=t.get(e+7),n+=(r&b)*et,r<h))return n;throw new RangeError("Could not decode varint")}function ne(t,e,r=0){return e==null&&(e=re(R(t))),e instanceof Uint8Array?lo(t,e,r):fo(t,e,r)}function G(t,e=0){return t instanceof Uint8Array?ho(t,e):mo(t,e)}function k(t,e){e==null&&(e=t.reduce((o,s)=>o+s.length,0));let r=re(e),n=0;for(let o of t)r.set(o,n),n+=o.length;return 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,c=this.peekChar();if(c===void 0)return;let d=c==="0",m=2**(8*o)-1;for(;;){let l=this.readAtomically(()=>{let w=this.readChar();if(w===void 0)return;let y=Number.parseInt(w,e);if(!Number.isNaN(y))return y});if(l===void 0)break;if(s*=e,s+=l,s>m||(i+=1,r!==void 0&&i>r))return}if(i!==0)return!n&&d&&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),[c]=e(s.subarray(0,i));return r.set(s.subarray(0,c),16-c),r})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Jt=45,wo=15,oe=new be;function tt(t){if(!(t.length>wo))return oe.new(t).parseWith(()=>oe.readIPv4Addr())}function rt(t){if(t.includes("%")&&(t=t.split("%")[0]),!(t.length>Jt))return oe.new(t).parseWith(()=>oe.readIPv6Addr())}function ye(t){if(t.includes("%")&&(t=t.split("%")[0]),!(t.length>Jt))return oe.new(t).parseWith(()=>oe.readIPAddr())}var Oi=parseInt("0xFFFF",16),$i=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function le(t,e="utf8"){let r=ge[e];if(r==null)throw new Error(`Unsupported encoding "${e}"`);return r.decoder.decode(`${r.prefix}${t}`)}function Zt(t){return!!tt(t)}function er(t){return!!rt(t)}function ve(t){return!!ye(t)}var tr=Zt,vo=er,nt=function(t){let e=0;if(t=t.toString().trim(),tr(t)){let r=new Uint8Array(e+4);return t.split(/\./g).forEach(n=>{r[e++]=parseInt(n,10)&255}),r}if(vo(t)){let r=t.split(":",8),n;for(n=0;n<r.length;n++){let s=tr(r[n]),i;s&&(i=nt(r[n]),r[n]=S(i.slice(0,2),"base16")),i!=null&&++n<8&&r.splice(n,0,S(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")},rr=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 se={},ot={},So=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[481,-1,"http-path"],[777,-1,"memory"]];So.forEach(t=>{let e=Ao(...t);ot[e.code]=e,se[e.name]=e});function Ao(t,e,r,n,o){return{code:t,size:e,name:r,resolvable:!!n,path:!!o}}function u(t){if(typeof t=="number"){if(ot[t]!=null)return ot[t];throw new Error(`no protocol with code: ${t}`)}else if(typeof t=="string"){if(se[t]!=null)return se[t];throw new Error(`no protocol with name: ${t}`)}throw new Error(`invalid protocol id type: ${typeof t}`)}var yc=u("ip4"),vc=u("ip6"),Ec=u("ipcidr");function at(t,e){switch(u(t).code){case 4:case 41:return Io(e);case 42:return ct(e);case 6:case 273:case 33:case 132:return sr(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return ct(e);case 421:return No(e);case 444:return or(e);case 445:return or(e);case 466:return Uo(e);case 481:return globalThis.encodeURIComponent(ct(e));default:return S(e,"base16")}}function pt(t,e){switch(u(t).code){case 4:return nr(e);case 41:return nr(e);case 42:return it(e);case 6:case 273:case 33:case 132:return dt(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return it(e);case 421:return Po(e);case 444:return Lo(e);case 445:return Do(e);case 466:return To(e);case 481:return it(globalThis.decodeURIComponent(e));default:return le(e,"base16")}}var st=Object.values(ue).map(t=>t.decoder),Co=function(){let t=st[0].or(st[1]);return st.slice(2).forEach(e=>t=t.or(e)),t}();function nr(t){if(!ve(t))throw new Error("invalid ip address");return nt(t)}function Io(t){let e=rr(t,0,t.length);if(e==null)throw new Error("ipBuff is required");if(!ve(e))throw new Error("invalid ip address");return e}function dt(t){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,t),new Uint8Array(e)}function sr(t){return new DataView(t.buffer).getUint16(t.byteOffset)}function it(t){let e=le(t),r=Uint8Array.from(ne(e.length));return k([r,e],r.length+e.length)}function ct(t){let e=G(t);if(t=t.slice(R(e)),t.length!==e)throw new Error("inconsistent lengths");return S(t)}function Po(t){let e;t[0]==="Q"||t[0]==="1"?e=xe(E.decode(`z${t}`)).bytes:e=W.parse(t).multihash.bytes;let r=Uint8Array.from(ne(e.length));return k([r,e],r.length+e.length)}function To(t){let e=Co.decode(t),r=Uint8Array.from(ne(e.length));return k([r,e],r.length+e.length)}function Uo(t){let e=G(t),r=t.slice(R(e));if(r.length!==e)throw new Error("inconsistent lengths");return"u"+S(r,"base64url")}function No(t){let e=G(t),r=t.slice(R(e));if(r.length!==e)throw new Error("inconsistent lengths");return S(r,"base58btc")}function Lo(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=F.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=dt(n);return k([r,o],r.length+o.length)}function Do(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=F.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=dt(n);return k([r,o],r.length+o.length)}function or(t){let e=t.slice(0,t.length-2),r=t.slice(t.length-2),n=S(e,"base32"),o=sr(r);return`${n}:${o}`}function ir(t){t=ut(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],c=u(i);if(c.size===0){e.push([c.code]),r.push([c.code]);continue}if(s++,s>=o.length)throw ar("invalid address: "+t);if(c.path===!0){n=ut(o.slice(s).join("/")),e.push([c.code,pt(c.code,n)]),r.push([c.code,n]);break}let d=pt(c.code,o[s]);e.push([c.code,d]),r.push([c.code,at(c.code,d)])}return{string:cr(r),bytes:ft(e),tuples:e,stringTuples:r,path:n}}function lt(t){let e=[],r=[],n=null,o=0;for(;o<t.length;){let s=G(t,o),i=R(s),c=u(s),d=Ro(c,t.slice(o+i));if(d===0){e.push([s]),r.push([s]),o+=i;continue}let m=t.slice(o+i,o+i+d);if(o+=d+i,o>t.length)throw ar("Invalid address Uint8Array: "+S(t,"base16"));e.push([s,m]);let l=at(s,m);if(r.push([s,l]),c.path===!0){n=l;break}}return{bytes:Uint8Array.from(t),string:cr(r),tuples:e,stringTuples:r,path:n}}function cr(t){let e=[];return t.map(r=>{let n=u(r[0]);return e.push(n.name),r.length>1&&r[1]!=null&&e.push(r[1]),null}),ut(e.join("/"))}function ft(t){return k(t.map(e=>{let r=u(e[0]),n=Uint8Array.from(ne(r.code));return e.length>1&&e[1]!=null&&(n=k([n,e[1]])),n}))}function Ro(t,e){if(t.size>0)return t.size/8;if(t.size===0)return 0;{let r=G(e instanceof Uint8Array?e:Uint8Array.from(e));return r+R(r)}}function ut(t){return"/"+t.trim().split("/").filter(e=>e).join("/")}function ar(t){return new Error("Error parsing address: "+t)}var Oo=Symbol.for("nodejs.util.inspect.custom"),ht=Symbol.for("@multiformats/js-multiaddr/multiaddr"),$o=[u("dns").code,u("dns4").code,u("dns6").code,u("dnsaddr").code],Ee=class t{bytes;#t;#e;#r;#n;[ht]=!0;constructor(e){e==null&&(e="");let r;if(e instanceof Uint8Array)r=lt(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);r=ir(e)}else if(dr(e))r=lt(e.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=r.bytes,this.#t=r.string,this.#e=r.tuples,this.#r=r.stringTuples,this.#n=r.path}toString(){return this.#t}toJSON(){return this.toString()}toOptions(){let e,r,n,o,s="",i=u("tcp"),c=u("udp"),d=u("ip4"),m=u("ip6"),l=u("dns6"),w=u("ip6zone");for(let[I,f]of this.stringTuples())I===w.code&&(s=`%${f??""}`),$o.includes(I)&&(r=i.name,o=443,n=`${f??""}${s}`,e=I===l.code?6:4),(I===i.code||I===c.code)&&(r=u(I).name,o=parseInt(f??"")),(I===d.code||I===m.code)&&(r=u(I).name,n=`${f??""}${s}`,e=I===m.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.#e.map(([e])=>Object.assign({},u(e)))}protoCodes(){return this.#e.map(([e])=>e)}protoNames(){return this.#e.map(([e])=>u(e).name)}tuples(){return this.#e}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(ft(r.slice(0,n)));return this}getPeerId(){try{let e=[];this.stringTuples().forEach(([n,o])=>{n===se.p2p.code&&e.push([n,o]),n===se["p2p-circuit"].code&&(e=[])});let r=e.pop();if(r?.[1]!=null){let n=r[1];return n[0]==="Q"||n[0]==="1"?S(E.decode(`z${n}`),"base58btc"):S(W.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(e){return Wt(this.bytes,e.bytes)}async resolve(e){let r=this.protos().find(s=>s.resolvable);if(r==null)return[this];let n=pr.get(r.name);if(n==null)throw new z(`no available resolver for ${r.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,e)).map(s=>_(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)}[Oo](){return`Multiaddr(${this.#t})`}};var pr=new Map;function dr(t){return!!t?.[ht]}function _(t){return new Ee(t)}var Fo=[u("tcp").code,u("dns").code,u("dnsaddr").code,u("dns4").code,u("dns6").code];function ur(t){let e;try{e=u("sni").code}catch{return null}for(let[r,n]of t)if(r===e&&n!==void 0)return n;return null}function lr(t){return t.some(([e,r])=>e===u("tls").code)}function A(t,e,r){let n=fr[u(t).name];if(n===void 0)throw new Error(`Can't interpret protocol ${u(t).name}`);let o=n(e,r);return t===u("ip6").code?`[${o}]`:o}var fr={ip4:(t,e)=>t,ip6:(t,e)=>e.length===0?t:`[${t}]`,tcp:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return`tcp://${A(r[0],r[1]??"",e)}:${t}`},udp:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return`udp://${A(r[0],r[1]??"",e)}:${t}`},dnsaddr:(t,e)=>t,dns4:(t,e)=>t,dns6:(t,e)=>t,dns:(t,e)=>t,ipfs:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return`${A(r[0],r[1]??"",e)}/ipfs/${t}`},p2p:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return`${A(r[0],r[1]??"",e)}/p2p/${t}`},http:(t,e)=>{let r=lr(e),n=ur(e);if(r&&n!==null)return`https://${n}`;let o=r?"https://":"http://",s=e.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let i=A(s[0],s[1]??"",e);return i=i.replace("tcp://",""),`${o}${i}`},"http-path":(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");let n=A(r[0],r[1]??"",e),o=decodeURIComponent(t);return`${n}/${o}`},tls:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return A(r[0],r[1]??"",e)},sni:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return A(r[0],r[1]??"",e)},https:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");let n=A(r[0],r[1]??"",e);return n=n.replace("tcp://",""),`https://${n}`},ws:(t,e)=>{let r=lr(e),n=ur(e);if(r&&n!==null)return`wss://${n}`;let o=r?"wss://":"ws://",s=e.pop();if(s===void 0)throw new Error("Unexpected end of multiaddr");let i=A(s[0],s[1]??"",e);return i=i.replace("tcp://",""),`${o}${i}`},wss:(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");let n=A(r[0],r[1]??"",e);return n=n.replace("tcp://",""),`wss://${n}`},"p2p-websocket-star":(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return`${A(r[0],r[1]??"",e)}/p2p-websocket-star`},"p2p-webrtc-star":(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return`${A(r[0],r[1]??"",e)}/p2p-webrtc-star`},"p2p-webrtc-direct":(t,e)=>{let r=e.pop();if(r===void 0)throw new Error("Unexpected end of multiaddr");return`${A(r[0],r[1]??"",e)}/p2p-webrtc-direct`}};function hr(t,e){let n=_(t).stringTuples(),o=n.pop();if(o===void 0)throw new Error("Unexpected end of multiaddr");let s=u(o[0]),i=fr[s.name];if(i==null)throw new Error(`No interpreter found for ${s.name}`);let c=i(o[1]??"",n);return e?.assumeHttp!==!1&&Fo.includes(o[0])&&(c=c.replace(/^.*:\/\//,""),o[1]==="443"?c=`https://${c}`:c=`http://${c}`),(c.startsWith("http://")||c.startsWith("https://"))&&(c=new URL(c).toString(),c.endsWith("/")&&(c=c.substring(0,c.length-1))),c}var mr=async t=>{if(t.readyState>=2)throw new Error("socket closed");t.readyState!==1&&await new Promise((e,r)=>{function n(){t.removeEventListener("open",o),t.removeEventListener("error",s)}function o(){n(),e()}function s(i){n(),r(i.error??new Error(`connect ECONNREFUSED ${t.url}`))}t.addEventListener("open",o),t.addEventListener("error",s)})};var wr=(t,e)=>(e=e??{},e.closeOnEnd=e.closeOnEnd!==!1,async n=>{for await(let o of n){try{await mr(t)}catch(s){if(s.message==="socket closed")break;throw s}if(t.readyState===t.CLOSING||t.readyState===t.CLOSED)break;t.send(o)}e.closeOnEnd!=null&&t.readyState<=1&&await new Promise((o,s)=>{t.addEventListener("close",i=>{if(i.wasClean||i.code===1006)o();else{let c=Object.assign(new Error("ws error"),{event:i});s(c)}}),setTimeout(()=>{t.close()})})});var yr=At(gr(),1);function br(t){return t instanceof ArrayBuffer||t?.constructor?.name==="ArrayBuffer"&&typeof t?.byteLength=="number"}var vr=t=>{t.binaryType="arraybuffer";let e=async()=>{await new Promise((s,i)=>{if(n){s();return}if(o!=null){i(o);return}let c=l=>{t.removeEventListener("open",d),t.removeEventListener("error",m),l()},d=()=>{c(s)},m=l=>{c(()=>{i(l.error??new Error(`connect ECONNREFUSED ${t.url}`))})};t.addEventListener("open",d),t.addEventListener("error",m)})},r=async function*(){let s=new yr.EventIterator(({push:i,stop:c,fail:d})=>{let m=w=>{let y=null;typeof w.data=="string"&&(y=le(w.data)),br(w.data)&&(y=new Uint8Array(w.data)),w.data instanceof Uint8Array&&(y=w.data),y!=null&&i(y)},l=w=>{d(w.error??new Error("Socket error"))};return t.addEventListener("message",m),t.addEventListener("error",l),t.addEventListener("close",c),()=>{t.removeEventListener("message",m),t.removeEventListener("error",l),t.removeEventListener("close",c)}},{highWaterMark:1/0});await e();for await(let i of s)yield br(i)?new Uint8Array(i):i}(),n=t.readyState===1,o;return t.addEventListener("open",()=>{n=!0,o=null}),t.addEventListener("close",()=>{n=!1,o=null}),t.addEventListener("error",s=>{n||(o=s.error??new Error(`connect ECONNREFUSED ${t.url}`))}),Object.assign(r,{connected:e})};var Er=(t,e)=>{e=e??{};let r=vr(t),n=e.remoteAddress,o=e.remotePort;if(t.url!=null)try{let i=new URL(t.url);n=i.hostname,o=parseInt(i.port,10)}catch{}if(n==null||o==null)throw new Error("Remote connection did not have address and/or port");return{sink:wr(t,e),source:r,connected:async()=>{await r.connected()},close:async()=>{(t.readyState===t.CONNECTING||t.readyState===t.OPEN)&&await new Promise(i=>{t.addEventListener("close",()=>{i()}),t.close()})},destroy:()=>{t.terminate!=null?t.terminate():t.close()},remoteAddress:n,remotePort:o,socket:t}};var Sr=WebSocket;var Mo={"http:":"ws:","https:":"wss:"},Ar="ws:",Cr=(t,e)=>{if(t.startsWith("//")&&(t=`${e?.protocol??Ar}${t}`),t.startsWith("/")&&e!=null){let n=e.protocol??Ar,o=e.host,s=e.port!=null&&o?.endsWith(`:${e.port}`)!==!0?`:${e.port}`:"";t=`${n}//${o}${s}${t}`}let r=new URL(t);for(let[n,o]of Object.entries(Mo))r.protocol===n&&(r.protocol=o);return r};function Ir(t,e){let r=typeof window>"u"?void 0:window.location;e=e??{};let n=Cr(t,r),o=new Sr(n.toString(),e.websocket);return Er(o,e)}function xt(){let t={};return t.promise=new Promise((e,r)=>{t.resolve=e,t.reject=r}),t}var Ce=class extends Event{type;detail;constructor(e,r){super(e),this.type=e,this.detail=r}};var Ie=class extends Error{type;code;constructor(e,r,n){super(e??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=r??"ABORT_ERR"}};async function Pr(t,e,r){if(e==null)return t;if(e.aborted)return Promise.reject(new Ie(r?.errorMessage,r?.errorCode,r?.errorName));let n,o=new Ie(r?.errorMessage,r?.errorCode,r?.errorName);try{return await Promise.race([t,new Promise((s,i)=>{n=()=>{i(o)},e.addEventListener("abort",n)})])}finally{n!=null&&e.removeEventListener("abort",n)}}var Nr=At(Ur(),1),Vo=typeof window=="object"&&typeof document=="object"&&document.nodeType===9,Lr=(0,Nr.default)(),Dr=Vo&&!Lr;var ma=typeof globalThis.process<"u"&&typeof globalThis.process.release<"u"&&globalThis.process.release.name==="node"&&!Lr,Rr=typeof importScripts=="function"&&typeof self<"u"&&typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope,wa=typeof globalThis.process<"u"&&typeof globalThis.process.env<"u"&&globalThis.process.env["NODE"+"_"+"ENV"]==="test",xa=typeof navigator<"u"&&navigator.product==="ReactNative";var Wo=a("dns4"),_o=a("dns6"),Bo=a("dnsaddr"),j=g(a("dns"),Bo,Wo,_o),Pe=g(a("ip4"),a("ip6")),ie=g(p(Pe,a("tcp")),p(j,a("tcp"))),Te=p(Pe,a("udp")),jo=p(Te,a("utp")),qo=p(Te,a("quic")),Qo=p(Te,a("quic-v1")),gt=g(p(ie,a("ws")),p(j,a("ws"))),ce=g(p(gt,a("p2p")),gt),bt=g(p(ie,a("wss")),p(j,a("wss")),p(ie,a("tls"),a("ws")),p(j,a("tls"),a("ws"))),X=g(p(bt,a("p2p")),bt),yt=g(p(ie,a("http")),p(Pe,a("http")),p(j,a("http"))),vt=g(p(ie,a("https")),p(Pe,a("https")),p(j,a("https"))),Or=p(Te,a("webrtc-direct"),a("certhash")),kr=g(p(Or,a("p2p")),Or),$r=p(Qo,a("webtransport"),a("certhash"),a("certhash")),Mr=g(p($r,a("p2p")),$r),zr=g(p(ce,a("p2p-webrtc-star"),a("p2p")),p(X,a("p2p-webrtc-star"),a("p2p")),p(ce,a("p2p-webrtc-star")),p(X,a("p2p-webrtc-star"))),ya=g(p(ce,a("p2p-websocket-star"),a("p2p")),p(X,a("p2p-websocket-star"),a("p2p")),p(ce,a("p2p-websocket-star")),p(X,a("p2p-websocket-star"))),Vr=g(p(yt,a("p2p-webrtc-direct"),a("p2p")),p(vt,a("p2p-webrtc-direct"),a("p2p")),p(yt,a("p2p-webrtc-direct")),p(vt,a("p2p-webrtc-direct"))),J=g(gt,bt,yt,vt,zr,Vr,ie,jo,qo,j,kr,Mr),va=g(p(J,a("p2p-stardust"),a("p2p")),p(J,a("p2p-stardust"))),B=g(p(J,a("p2p")),zr,Vr,kr,Mr,a("p2p")),Fr=g(p(B,a("p2p-circuit"),B),p(B,a("p2p-circuit")),p(a("p2p-circuit"),B),p(J,a("p2p-circuit")),p(a("p2p-circuit"),J),a("p2p-circuit")),Wr=()=>g(p(Fr,Wr),Fr),H=Wr(),Ea=g(p(H,B,H),p(B,H),p(H,B),H,B);var Sa=g(p(H,a("webrtc"),a("p2p")),p(H,a("webrtc")),p(J,a("webrtc"),a("p2p")),p(J,a("webrtc")),a("webrtc"));function _r(t){function e(r){let n;try{n=_(r)}catch{return!1}let o=t(n.protoNames());return o===null?!1:o===!0||o===!1?o:o.length===0}return e}function p(...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:_r(e),partialMatch:e}}function g(...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:_r(e),partialMatch:e}}function a(t){let e=t;function r(o){let s;try{s=_(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}}function Br(t){return t.filter(e=>{if(e.protoCodes().includes(290))return!1;let r=e.decapsulateCode(421);return ce.matches(r)||X.matches(r)})}function jr(t){return t.filter(e=>{if(e.protoCodes().includes(290))return!1;let r=e.decapsulateCode(421);return X.matches(r)})}function qr(){throw new Error("WebSocket Servers can not be created in the browser!")}function Qr(t,e,r){let n=r.logger.forComponent("libp2p:websockets:maconn"),o=r.metrics,s=r.metricPrefix??"",i={log:n,async sink(c){try{await t.sink(async function*(){for await(let d of c)d instanceof Uint8Array?yield d:yield d.subarray()}())}catch(d){d.type!=="aborted"&&n.error(d)}},source:t.source,remoteAddr:e,timeline:{open:Date.now()},async close(c={}){let d=Date.now();if(c.signal==null){let l=AbortSignal.timeout(500);c={...c,signal:l}}let m=()=>{let{host:l,port:w}=i.remoteAddr.toOptions();n("timeout closing stream to %s:%s after %dms, destroying it manually",l,w,Date.now()-d),this.abort(new z("Socket close timeout","ERR_SOCKET_CLOSE_TIMEOUT"))};c.signal?.addEventListener("abort",m);try{await t.close()}catch(l){n.error("error closing WebSocket gracefully",l),this.abort(l)}finally{c.signal?.removeEventListener("abort",m),i.timeline.close=Date.now()}},abort(c){let{host:d,port:m}=i.remoteAddr.toOptions();n("timeout closing stream to %s:%s due to error",d,m,c),t.destroy(),i.timeline.close=Date.now(),o?.increment({[`${s}error`]:!0})}};return t.socket.addEventListener("close",()=>{o?.increment({[`${s}close`]:!0}),i.timeline.close==null&&(i.timeline.close=Date.now())},{once:!0}),i}var Et=class{log;init;logger;metrics;components;constructor(e,r){this.log=e.logger.forComponent("libp2p:websockets"),this.logger=e.logger,this.components=e,this.init=r,e.metrics!=null&&(this.metrics={dialerEvents:e.metrics.registerCounterGroup("libp2p_websockets_dialer_events_total",{label:"event",help:"Total count of WebSockets dialer events by type"})})}[It]=!0;[Symbol.toStringTag]="@libp2p/websockets";[Pt]=["@libp2p/transport"];async dial(e,r){this.log("dialing %s",e),r=r??{};let n=await this._connect(e,r),o=Qr(n,e,{logger:this.logger,metrics:this.metrics?.dialerEvents});this.log("new outbound connection %s",o.remoteAddr);let s=await r.upgrader.upgradeOutbound(o,r);return this.log("outbound connection %s upgraded",o.remoteAddr),s}async _connect(e,r){r?.signal?.throwIfAborted();let n=e.toOptions();this.log("dialing %s:%s",n.host,n.port);let o=xt(),s=Ir(hr(e),this.init);s.socket.addEventListener("error",()=>{let i=new z(`Could not connect to ${e.toString()}`,"ERR_CONNECTION_FAILED");this.log.error("connection error:",i),this.metrics?.dialerEvents.increment({error:!0}),o.reject(i)});try{r.onProgress?.(new Ce("websockets:open-connection")),await Pr(Promise.race([s.connected(),o.promise]),r.signal)}catch(i){throw r.signal?.aborted===!0&&this.metrics?.dialerEvents.increment({abort:!0}),s.close().catch(c=>{this.log.error("error closing raw socket",c)}),i}return this.log("connected %s",e),this.metrics?.dialerEvents.increment({connect:!0}),s}createListener(e){return qr({logger:this.logger,metrics:this.components.metrics},{...this.init,...e})}listenFilter(e){return e=Array.isArray(e)?e:[e],this.init?.filter!=null?this.init?.filter(e):Dr||Rr?jr(e):Br(e)}dialFilter(e){return this.listenFilter(e)}};function Ko(t={}){return e=>new Et(e,t)}return Yr(Yo);})();
|
|
3
3
|
return Libp2PWebsockets}));
|
package/dist/src/index.d.ts
CHANGED
|
@@ -58,7 +58,7 @@
|
|
|
58
58
|
*/
|
|
59
59
|
/// <reference types="node" />
|
|
60
60
|
import { type WebSocketOptions } from 'it-ws/client';
|
|
61
|
-
import type { Transport, MultiaddrFilter, AbortOptions, ComponentLogger, OutboundConnectionUpgradeEvents } from '@libp2p/interface';
|
|
61
|
+
import type { Transport, MultiaddrFilter, AbortOptions, ComponentLogger, OutboundConnectionUpgradeEvents, Metrics, CounterGroup } from '@libp2p/interface';
|
|
62
62
|
import type { Server } from 'http';
|
|
63
63
|
import type { ProgressEvent } from 'progress-events';
|
|
64
64
|
import type { ClientOptions } from 'ws';
|
|
@@ -69,6 +69,10 @@ export interface WebSocketsInit extends AbortOptions, WebSocketOptions {
|
|
|
69
69
|
}
|
|
70
70
|
export interface WebSocketsComponents {
|
|
71
71
|
logger: ComponentLogger;
|
|
72
|
+
metrics?: Metrics;
|
|
73
|
+
}
|
|
74
|
+
export interface WebSocketsMetrics {
|
|
75
|
+
dialerEvents: CounterGroup;
|
|
72
76
|
}
|
|
73
77
|
export type WebSocketsDialEvents = OutboundConnectionUpgradeEvents | ProgressEvent<'websockets:open-connection'>;
|
|
74
78
|
export declare function webSockets(init?: WebSocketsInit): (components: WebSocketsComponents) => Transport;
|
package/dist/src/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyDG;;AAIH,OAAO,EAAW,KAAK,gBAAgB,EAAE,MAAM,cAAc,CAAA;AAQ7D,OAAO,KAAK,EAAE,SAAS,EAAE,eAAe,EAAyD,YAAY,EAAE,eAAe,EAAsB,+BAA+B,EAAE,MAAM,mBAAmB,CAAA;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyDG;;AAIH,OAAO,EAAW,KAAK,gBAAgB,EAAE,MAAM,cAAc,CAAA;AAQ7D,OAAO,KAAK,EAAE,SAAS,EAAE,eAAe,EAAyD,YAAY,EAAE,eAAe,EAAsB,+BAA+B,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAA;AAErO,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAA;AAElC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AACpD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,IAAI,CAAA;AAEvC,MAAM,WAAW,cAAe,SAAQ,YAAY,EAAE,gBAAgB;IACpE,MAAM,CAAC,EAAE,eAAe,CAAA;IACxB,SAAS,CAAC,EAAE,aAAa,CAAA;IACzB,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB;AAED,MAAM,WAAW,oBAAoB;IACnC,MAAM,EAAE,eAAe,CAAA;IACvB,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB;AAED,MAAM,WAAW,iBAAiB;IAChC,YAAY,EAAE,YAAY,CAAA;CAC3B;AAED,MAAM,MAAM,oBAAoB,GAC9B,+BAA+B,GAC/B,aAAa,CAAC,4BAA4B,CAAC,CAAA;AAmI7C,wBAAgB,UAAU,CAAE,IAAI,GAAE,cAAmB,GAAG,CAAC,UAAU,EAAE,oBAAoB,KAAK,SAAS,CAItG"}
|
package/dist/src/index.js
CHANGED
|
@@ -70,10 +70,21 @@ class WebSockets {
|
|
|
70
70
|
log;
|
|
71
71
|
init;
|
|
72
72
|
logger;
|
|
73
|
+
metrics;
|
|
74
|
+
components;
|
|
73
75
|
constructor(components, init) {
|
|
74
76
|
this.log = components.logger.forComponent('libp2p:websockets');
|
|
75
77
|
this.logger = components.logger;
|
|
78
|
+
this.components = components;
|
|
76
79
|
this.init = init;
|
|
80
|
+
if (components.metrics != null) {
|
|
81
|
+
this.metrics = {
|
|
82
|
+
dialerEvents: components.metrics.registerCounterGroup('libp2p_websockets_dialer_events_total', {
|
|
83
|
+
label: 'event',
|
|
84
|
+
help: 'Total count of WebSockets dialer events by type'
|
|
85
|
+
})
|
|
86
|
+
};
|
|
87
|
+
}
|
|
77
88
|
}
|
|
78
89
|
[transportSymbol] = true;
|
|
79
90
|
[Symbol.toStringTag] = '@libp2p/websockets';
|
|
@@ -85,7 +96,8 @@ class WebSockets {
|
|
|
85
96
|
options = options ?? {};
|
|
86
97
|
const socket = await this._connect(ma, options);
|
|
87
98
|
const maConn = socketToMaConn(socket, ma, {
|
|
88
|
-
logger: this.logger
|
|
99
|
+
logger: this.logger,
|
|
100
|
+
metrics: this.metrics?.dialerEvents
|
|
89
101
|
});
|
|
90
102
|
this.log('new outbound connection %s', maConn.remoteAddr);
|
|
91
103
|
const conn = await options.upgrader.upgradeOutbound(maConn, options);
|
|
@@ -104,6 +116,7 @@ class WebSockets {
|
|
|
104
116
|
// https://developer.mozilla.org/en-US/docs/Web/API/WebSocket/error_event
|
|
105
117
|
const err = new CodeError(`Could not connect to ${ma.toString()}`, 'ERR_CONNECTION_FAILED');
|
|
106
118
|
this.log.error('connection error:', err);
|
|
119
|
+
this.metrics?.dialerEvents.increment({ error: true });
|
|
107
120
|
errorPromise.reject(err);
|
|
108
121
|
});
|
|
109
122
|
try {
|
|
@@ -111,6 +124,9 @@ class WebSockets {
|
|
|
111
124
|
await raceSignal(Promise.race([rawSocket.connected(), errorPromise.promise]), options.signal);
|
|
112
125
|
}
|
|
113
126
|
catch (err) {
|
|
127
|
+
if (options.signal?.aborted === true) {
|
|
128
|
+
this.metrics?.dialerEvents.increment({ abort: true });
|
|
129
|
+
}
|
|
114
130
|
rawSocket.close()
|
|
115
131
|
.catch(err => {
|
|
116
132
|
this.log.error('error closing raw socket', err);
|
|
@@ -118,6 +134,7 @@ class WebSockets {
|
|
|
118
134
|
throw err;
|
|
119
135
|
}
|
|
120
136
|
this.log('connected %s', ma);
|
|
137
|
+
this.metrics?.dialerEvents.increment({ connect: true });
|
|
121
138
|
return rawSocket;
|
|
122
139
|
}
|
|
123
140
|
/**
|
|
@@ -127,7 +144,8 @@ class WebSockets {
|
|
|
127
144
|
*/
|
|
128
145
|
createListener(options) {
|
|
129
146
|
return createListener({
|
|
130
|
-
logger: this.logger
|
|
147
|
+
logger: this.logger,
|
|
148
|
+
metrics: this.components.metrics
|
|
131
149
|
}, {
|
|
132
150
|
...this.init,
|
|
133
151
|
...options
|
package/dist/src/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyDG;AAEH,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAA;AACnF,OAAO,EAAE,cAAc,IAAI,KAAK,EAAE,MAAM,gCAAgC,CAAA;AACxE,OAAO,EAAE,OAAO,EAAyB,MAAM,cAAc,CAAA;AAC7D,OAAO,MAAM,MAAM,SAAS,CAAA;AAC5B,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAA;AACrD,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AACxC,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,YAAY,CAAA;AACnD,OAAO,KAAK,OAAO,MAAM,cAAc,CAAA;AACvC,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAA;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyDG;AAEH,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAA;AACnF,OAAO,EAAE,cAAc,IAAI,KAAK,EAAE,MAAM,gCAAgC,CAAA;AACxE,OAAO,EAAE,OAAO,EAAyB,MAAM,cAAc,CAAA;AAC7D,OAAO,MAAM,MAAM,SAAS,CAAA;AAC5B,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAA;AACrD,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAA;AACxC,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,YAAY,CAAA;AACnD,OAAO,KAAK,OAAO,MAAM,cAAc,CAAA;AACvC,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAA;AA2BpD,MAAM,UAAU;IACG,GAAG,CAAQ;IACX,IAAI,CAAiB;IACrB,MAAM,CAAiB;IACvB,OAAO,CAAoB;IAC3B,UAAU,CAAsB;IAEjD,YAAa,UAAgC,EAAE,IAAqB;QAClE,IAAI,CAAC,GAAG,GAAG,UAAU,CAAC,MAAM,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAA;QAC9D,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC,MAAM,CAAA;QAC/B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAA;QAC5B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAA;QAEhB,IAAI,UAAU,CAAC,OAAO,IAAI,IAAI,EAAE,CAAC;YAC/B,IAAI,CAAC,OAAO,GAAG;gBACb,YAAY,EAAE,UAAU,CAAC,OAAO,CAAC,oBAAoB,CAAC,uCAAuC,EAAE;oBAC7F,KAAK,EAAE,OAAO;oBACd,IAAI,EAAE,iDAAiD;iBACxD,CAAC;aACH,CAAA;QACH,CAAC;IACH,CAAC;IAEQ,CAAC,eAAe,CAAC,GAAG,IAAI,CAAA;IAExB,CAAC,MAAM,CAAC,WAAW,CAAC,GAAG,oBAAoB,CAAA;IAE3C,CAAC,mBAAmB,CAAC,GAAa;QACzC,mBAAmB;KACpB,CAAA;IAED,KAAK,CAAC,IAAI,CAAE,EAAa,EAAE,OAAmD;QAC5E,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,EAAE,CAAC,CAAA;QAC1B,OAAO,GAAG,OAAO,IAAI,EAAE,CAAA;QAEvB,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,OAAO,CAAC,CAAA;QAC/C,MAAM,MAAM,GAAG,cAAc,CAAC,MAAM,EAAE,EAAE,EAAE;YACxC,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,YAAY;SACpC,CAAC,CAAA;QACF,IAAI,CAAC,GAAG,CAAC,4BAA4B,EAAE,MAAM,CAAC,UAAU,CAAC,CAAA;QAEzD,MAAM,IAAI,GAAG,MAAM,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;QACpE,IAAI,CAAC,GAAG,CAAC,iCAAiC,EAAE,MAAM,CAAC,UAAU,CAAC,CAAA;QAC9D,OAAO,IAAI,CAAA;IACb,CAAC;IAED,KAAK,CAAC,QAAQ,CAAE,EAAa,EAAE,OAAmD;QAChF,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,CAAA;QAEjC,MAAM,KAAK,GAAG,EAAE,CAAC,SAAS,EAAE,CAAA;QAC5B,IAAI,CAAC,GAAG,CAAC,eAAe,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,IAAI,CAAC,CAAA;QAEjD,MAAM,YAAY,GAAG,MAAM,EAAE,CAAA;QAC7B,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAA;QAC/C,SAAS,CAAC,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;YAC9C,oEAAoE;YACpE,kCAAkC;YAClC,yEAAyE;YACzE,MAAM,GAAG,GAAG,IAAI,SAAS,CAAC,wBAAwB,EAAE,CAAC,QAAQ,EAAE,EAAE,EAAE,uBAAuB,CAAC,CAAA;YAC3F,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,mBAAmB,EAAE,GAAG,CAAC,CAAA;YACxC,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAA;YACrD,YAAY,CAAC,MAAM,CAAC,GAAG,CAAC,CAAA;QAC1B,CAAC,CAAC,CAAA;QAEF,IAAI,CAAC;YACH,OAAO,CAAC,UAAU,EAAE,CAAC,IAAI,mBAAmB,CAAC,4BAA4B,CAAC,CAAC,CAAA;YAC3E,MAAM,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,SAAS,EAAE,EAAE,YAAY,CAAC,OAAO,CAAC,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,CAAA;QAC/F,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,IAAI,OAAO,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,EAAE,CAAC;gBACrC,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAA;YACvD,CAAC;YAED,SAAS,CAAC,KAAK,EAAE;iBACd,KAAK,CAAC,GAAG,CAAC,EAAE;gBACX,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,0BAA0B,EAAE,GAAG,CAAC,CAAA;YACjD,CAAC,CAAC,CAAA;YAEJ,MAAM,GAAG,CAAA;QACX,CAAC;QAED,IAAI,CAAC,GAAG,CAAC,cAAc,EAAE,EAAE,CAAC,CAAA;QAC5B,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAA;QACvD,OAAO,SAAS,CAAA;IAClB,CAAC;IAED;;;;OAIG;IACH,cAAc,CAAE,OAA8B;QAC5C,OAAO,cAAc,CAAC;YACpB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,OAAO;SACjC,EAAE;YACD,GAAG,IAAI,CAAC,IAAI;YACZ,GAAG,OAAO;SACX,CAAC,CAAA;IACJ,CAAC;IAED;;;;OAIG;IACH,YAAY,CAAE,UAAuB;QACnC,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAA;QAElE,IAAI,IAAI,CAAC,IAAI,EAAE,MAAM,IAAI,IAAI,EAAE,CAAC;YAC9B,OAAO,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,UAAU,CAAC,CAAA;QACtC,CAAC;QAED,UAAU;QACV,IAAI,SAAS,IAAI,WAAW,EAAE,CAAC;YAC7B,OAAO,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAA;QAChC,CAAC;QAED,OAAO,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAA;IAChC,CAAC;IAED;;OAEG;IACH,UAAU,CAAE,UAAuB;QACjC,OAAO,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,CAAA;IACtC,CAAC;CACF;AAED,MAAM,UAAU,UAAU,CAAE,OAAuB,EAAE;IACnD,OAAO,CAAC,UAAU,EAAE,EAAE;QACpB,OAAO,IAAI,UAAU,CAAC,UAAU,EAAE,IAAI,CAAC,CAAA;IACzC,CAAC,CAAA;AACH,CAAC"}
|
package/dist/src/listener.d.ts
CHANGED
|
@@ -1,11 +1,17 @@
|
|
|
1
1
|
/// <reference types="node" />
|
|
2
|
-
import type { ComponentLogger, Listener, CreateListenerOptions } from '@libp2p/interface';
|
|
2
|
+
import type { ComponentLogger, Listener, CreateListenerOptions, CounterGroup, MetricGroup, Metrics } from '@libp2p/interface';
|
|
3
3
|
import type { Server } from 'http';
|
|
4
4
|
export interface WebSocketListenerComponents {
|
|
5
5
|
logger: ComponentLogger;
|
|
6
|
+
metrics?: Metrics;
|
|
6
7
|
}
|
|
7
8
|
export interface WebSocketListenerInit extends CreateListenerOptions {
|
|
8
9
|
server?: Server;
|
|
9
10
|
}
|
|
11
|
+
export interface WebSocketListenerMetrics {
|
|
12
|
+
status: MetricGroup;
|
|
13
|
+
errors: CounterGroup;
|
|
14
|
+
events: CounterGroup;
|
|
15
|
+
}
|
|
10
16
|
export declare function createListener(components: WebSocketListenerComponents, init: WebSocketListenerInit): Listener;
|
|
11
17
|
//# sourceMappingURL=listener.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"listener.d.ts","sourceRoot":"","sources":["../../src/listener.ts"],"names":[],"mappings":";AAMA,OAAO,KAAK,EAAE,eAAe,EAAsB,QAAQ,EAAkB,qBAAqB,EAAE,MAAM,mBAAmB,CAAA;
|
|
1
|
+
{"version":3,"file":"listener.d.ts","sourceRoot":"","sources":["../../src/listener.ts"],"names":[],"mappings":";AAMA,OAAO,KAAK,EAAE,eAAe,EAAsB,QAAQ,EAAkB,qBAAqB,EAAE,YAAY,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAA;AAEjK,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,MAAM,CAAA;AAIlC,MAAM,WAAW,2BAA2B;IAC1C,MAAM,EAAE,eAAe,CAAA;IACvB,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB;AAED,MAAM,WAAW,qBAAsB,SAAQ,qBAAqB;IAClE,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB;AAED,MAAM,WAAW,wBAAwB;IACvC,MAAM,EAAE,WAAW,CAAA;IACnB,MAAM,EAAE,YAAY,CAAA;IACpB,MAAM,EAAE,YAAY,CAAA;CACrB;AAsLD,wBAAgB,cAAc,CAAE,UAAU,EAAE,2BAA2B,EAAE,IAAI,EAAE,qBAAqB,GAAG,QAAQ,CAE9G"}
|
package/dist/src/listener.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import os from 'os';
|
|
2
|
-
import { TypedEventEmitter
|
|
2
|
+
import { TypedEventEmitter } from '@libp2p/interface';
|
|
3
3
|
import { ipPortToMultiaddr as toMultiaddr } from '@libp2p/utils/ip-port-to-multiaddr';
|
|
4
4
|
import { multiaddr, protocols } from '@multiformats/multiaddr';
|
|
5
5
|
import { createServer } from 'it-ws/server';
|
|
@@ -9,17 +9,23 @@ class WebSocketListener extends TypedEventEmitter {
|
|
|
9
9
|
listeningMultiaddr;
|
|
10
10
|
server;
|
|
11
11
|
log;
|
|
12
|
+
metrics;
|
|
13
|
+
addr;
|
|
12
14
|
constructor(components, init) {
|
|
13
15
|
super();
|
|
14
16
|
this.log = components.logger.forComponent('libp2p:websockets:listener');
|
|
17
|
+
const metrics = components.metrics;
|
|
15
18
|
// Keep track of open connections to destroy when the listener is closed
|
|
16
19
|
this.connections = new Set();
|
|
17
20
|
const self = this; // eslint-disable-line @typescript-eslint/no-this-alias
|
|
21
|
+
this.addr = 'unknown';
|
|
18
22
|
this.server = createServer({
|
|
19
23
|
...init,
|
|
20
24
|
onConnection: (stream) => {
|
|
21
25
|
const maConn = socketToMaConn(stream, toMultiaddr(stream.remoteAddress ?? '', stream.remotePort ?? 0), {
|
|
22
|
-
logger: components.logger
|
|
26
|
+
logger: components.logger,
|
|
27
|
+
metrics: this.metrics?.events,
|
|
28
|
+
metricPrefix: `${this.addr} `
|
|
23
29
|
});
|
|
24
30
|
this.log('new inbound connection %s', maConn.remoteAddr);
|
|
25
31
|
this.connections.add(stream);
|
|
@@ -39,6 +45,7 @@ class WebSocketListener extends TypedEventEmitter {
|
|
|
39
45
|
})
|
|
40
46
|
.catch(async (err) => {
|
|
41
47
|
this.log.error('inbound connection failed to upgrade', err);
|
|
48
|
+
this.metrics?.errors.increment({ [`${this.addr} inbound_upgrade`]: true });
|
|
42
49
|
await maConn.close().catch(err => {
|
|
43
50
|
this.log.error('inbound connection failed to close after upgrade failed', err);
|
|
44
51
|
});
|
|
@@ -48,14 +55,43 @@ class WebSocketListener extends TypedEventEmitter {
|
|
|
48
55
|
this.log.error('inbound connection failed to upgrade', err);
|
|
49
56
|
maConn.close().catch(err => {
|
|
50
57
|
this.log.error('inbound connection failed to close after upgrade failed', err);
|
|
58
|
+
this.metrics?.errors.increment({ [`${this.addr} inbound_closing_failed`]: true });
|
|
51
59
|
});
|
|
52
60
|
}
|
|
53
61
|
}
|
|
54
62
|
});
|
|
55
63
|
this.server.on('listening', () => {
|
|
64
|
+
if (metrics != null) {
|
|
65
|
+
const { host, port } = this.listeningMultiaddr?.toOptions() ?? {};
|
|
66
|
+
this.addr = `${host}:${port}`;
|
|
67
|
+
metrics.registerMetricGroup('libp2p_websockets_inbound_connections_total', {
|
|
68
|
+
label: 'address',
|
|
69
|
+
help: 'Current active connections in WebSocket listener',
|
|
70
|
+
calculate: () => {
|
|
71
|
+
return {
|
|
72
|
+
[this.addr]: this.connections.size
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
this.metrics = {
|
|
77
|
+
status: metrics?.registerMetricGroup('libp2p_websockets_listener_status_info', {
|
|
78
|
+
label: 'address',
|
|
79
|
+
help: 'Current status of the WebSocket listener socket'
|
|
80
|
+
}),
|
|
81
|
+
errors: metrics?.registerMetricGroup('libp2p_websockets_listener_errors_total', {
|
|
82
|
+
label: 'address',
|
|
83
|
+
help: 'Total count of WebSocket listener errors by type'
|
|
84
|
+
}),
|
|
85
|
+
events: metrics?.registerMetricGroup('libp2p_websockets_listener_events_total', {
|
|
86
|
+
label: 'address',
|
|
87
|
+
help: 'Total count of WebSocket listener events by type'
|
|
88
|
+
})
|
|
89
|
+
};
|
|
90
|
+
}
|
|
56
91
|
this.dispatchEvent(new CustomEvent('listening'));
|
|
57
92
|
});
|
|
58
93
|
this.server.on('error', (err) => {
|
|
94
|
+
this.metrics?.errors.increment({ [`${this.addr} listen_error`]: true });
|
|
59
95
|
this.dispatchEvent(new CustomEvent('error', {
|
|
60
96
|
detail: err
|
|
61
97
|
}));
|
package/dist/src/listener.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"listener.js","sourceRoot":"","sources":["../../src/listener.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,CAAA;AACnB,OAAO,EAAE,iBAAiB,EAAE,
|
|
1
|
+
{"version":3,"file":"listener.js","sourceRoot":"","sources":["../../src/listener.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
|
-
import type { ComponentLogger, MultiaddrConnection } from '@libp2p/interface';
|
|
1
|
+
import type { ComponentLogger, CounterGroup, MultiaddrConnection } from '@libp2p/interface';
|
|
2
2
|
import type { Multiaddr } from '@multiformats/multiaddr';
|
|
3
3
|
import type { DuplexWebSocket } from 'it-ws/duplex';
|
|
4
4
|
export interface SocketToConnOptions {
|
|
5
5
|
localAddr?: Multiaddr;
|
|
6
6
|
logger: ComponentLogger;
|
|
7
|
+
metrics?: CounterGroup;
|
|
8
|
+
metricPrefix?: string;
|
|
7
9
|
}
|
|
8
10
|
export declare function socketToMaConn(stream: DuplexWebSocket, remoteAddr: Multiaddr, options: SocketToConnOptions): MultiaddrConnection;
|
|
9
11
|
//# sourceMappingURL=socket-to-conn.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"socket-to-conn.d.ts","sourceRoot":"","sources":["../../src/socket-to-conn.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAgB,eAAe,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAA;
|
|
1
|
+
{"version":3,"file":"socket-to-conn.d.ts","sourceRoot":"","sources":["../../src/socket-to-conn.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAgB,eAAe,EAAE,YAAY,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAA;AACzG,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAA;AACxD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAEnD,MAAM,WAAW,mBAAmB;IAClC,SAAS,CAAC,EAAE,SAAS,CAAA;IACrB,MAAM,EAAE,eAAe,CAAA;IACvB,OAAO,CAAC,EAAE,YAAY,CAAA;IACtB,YAAY,CAAC,EAAE,MAAM,CAAA;CACtB;AAID,wBAAgB,cAAc,CAAE,MAAM,EAAE,eAAe,EAAE,UAAU,EAAE,SAAS,EAAE,OAAO,EAAE,mBAAmB,GAAG,mBAAmB,CA6FjI"}
|
|
@@ -4,6 +4,8 @@ import { CLOSE_TIMEOUT } from './constants.js';
|
|
|
4
4
|
// https://github.com/libp2p/interface-transport#multiaddrconnection
|
|
5
5
|
export function socketToMaConn(stream, remoteAddr, options) {
|
|
6
6
|
const log = options.logger.forComponent('libp2p:websockets:maconn');
|
|
7
|
+
const metrics = options.metrics;
|
|
8
|
+
const metricPrefix = options.metricPrefix ?? '';
|
|
7
9
|
const maConn = {
|
|
8
10
|
log,
|
|
9
11
|
async sink(source) {
|
|
@@ -60,9 +62,15 @@ export function socketToMaConn(stream, remoteAddr, options) {
|
|
|
60
62
|
log('timeout closing stream to %s:%s due to error', host, port, err);
|
|
61
63
|
stream.destroy();
|
|
62
64
|
maConn.timeline.close = Date.now();
|
|
65
|
+
// ws WebSocket.terminate does not accept an Error arg to emit an 'error'
|
|
66
|
+
// event on destroy like other node streams so we can't update a metric
|
|
67
|
+
// with an event listener
|
|
68
|
+
// https://github.com/websockets/ws/issues/1752#issuecomment-622380981
|
|
69
|
+
metrics?.increment({ [`${metricPrefix}error`]: true });
|
|
63
70
|
}
|
|
64
71
|
};
|
|
65
72
|
stream.socket.addEventListener('close', () => {
|
|
73
|
+
metrics?.increment({ [`${metricPrefix}close`]: true });
|
|
66
74
|
// In instances where `close` was not explicitly called,
|
|
67
75
|
// such as an iterable stream ending, ensure we have set the close
|
|
68
76
|
// timeline
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"socket-to-conn.js","sourceRoot":"","sources":["../../src/socket-to-conn.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAA;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAA;
|
|
1
|
+
{"version":3,"file":"socket-to-conn.js","sourceRoot":"","sources":["../../src/socket-to-conn.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libp2p/websockets",
|
|
3
|
-
"version": "8.1.
|
|
3
|
+
"version": "8.1.4-1dfb74e79",
|
|
4
4
|
"description": "JavaScript implementation of the WebSockets module that libp2p uses and that implements the interface-transport spec",
|
|
5
5
|
"license": "Apache-2.0 OR MIT",
|
|
6
6
|
"homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/transport-websockets#readme",
|
|
@@ -74,8 +74,8 @@
|
|
|
74
74
|
"test:electron-main": "aegir test -t electron-main -f ./dist/test/node.js --cov"
|
|
75
75
|
},
|
|
76
76
|
"dependencies": {
|
|
77
|
-
"@libp2p/interface": "
|
|
78
|
-
"@libp2p/utils": "
|
|
77
|
+
"@libp2p/interface": "1.6.3-1dfb74e79",
|
|
78
|
+
"@libp2p/utils": "5.4.8-1dfb74e79",
|
|
79
79
|
"@multiformats/mafmt": "^12.1.6",
|
|
80
80
|
"@multiformats/multiaddr": "^12.2.3",
|
|
81
81
|
"@multiformats/multiaddr-to-uri": "^10.0.1",
|
|
@@ -88,9 +88,9 @@
|
|
|
88
88
|
"ws": "^8.17.0"
|
|
89
89
|
},
|
|
90
90
|
"devDependencies": {
|
|
91
|
-
"@libp2p/interface-compliance-tests": "
|
|
92
|
-
"@libp2p/logger": "
|
|
93
|
-
"aegir": "^
|
|
91
|
+
"@libp2p/interface-compliance-tests": "5.4.11-1dfb74e79",
|
|
92
|
+
"@libp2p/logger": "4.0.19-1dfb74e79",
|
|
93
|
+
"aegir": "^44.0.1",
|
|
94
94
|
"is-loopback-addr": "^2.0.2",
|
|
95
95
|
"it-all": "^3.0.6",
|
|
96
96
|
"it-drain": "^3.0.7",
|
package/src/index.ts
CHANGED
|
@@ -67,7 +67,7 @@ import { isBrowser, isWebWorker } from 'wherearewe'
|
|
|
67
67
|
import * as filters from './filters.js'
|
|
68
68
|
import { createListener } from './listener.js'
|
|
69
69
|
import { socketToMaConn } from './socket-to-conn.js'
|
|
70
|
-
import type { Transport, MultiaddrFilter, CreateListenerOptions, DialTransportOptions, Listener, AbortOptions, ComponentLogger, Logger, Connection, OutboundConnectionUpgradeEvents } from '@libp2p/interface'
|
|
70
|
+
import type { Transport, MultiaddrFilter, CreateListenerOptions, DialTransportOptions, Listener, AbortOptions, ComponentLogger, Logger, Connection, OutboundConnectionUpgradeEvents, Metrics, CounterGroup } from '@libp2p/interface'
|
|
71
71
|
import type { Multiaddr } from '@multiformats/multiaddr'
|
|
72
72
|
import type { Server } from 'http'
|
|
73
73
|
import type { DuplexWebSocket } from 'it-ws/duplex'
|
|
@@ -82,6 +82,11 @@ export interface WebSocketsInit extends AbortOptions, WebSocketOptions {
|
|
|
82
82
|
|
|
83
83
|
export interface WebSocketsComponents {
|
|
84
84
|
logger: ComponentLogger
|
|
85
|
+
metrics?: Metrics
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
export interface WebSocketsMetrics {
|
|
89
|
+
dialerEvents: CounterGroup
|
|
85
90
|
}
|
|
86
91
|
|
|
87
92
|
export type WebSocketsDialEvents =
|
|
@@ -92,11 +97,23 @@ class WebSockets implements Transport<WebSocketsDialEvents> {
|
|
|
92
97
|
private readonly log: Logger
|
|
93
98
|
private readonly init?: WebSocketsInit
|
|
94
99
|
private readonly logger: ComponentLogger
|
|
100
|
+
private readonly metrics?: WebSocketsMetrics
|
|
101
|
+
private readonly components: WebSocketsComponents
|
|
95
102
|
|
|
96
103
|
constructor (components: WebSocketsComponents, init?: WebSocketsInit) {
|
|
97
104
|
this.log = components.logger.forComponent('libp2p:websockets')
|
|
98
105
|
this.logger = components.logger
|
|
106
|
+
this.components = components
|
|
99
107
|
this.init = init
|
|
108
|
+
|
|
109
|
+
if (components.metrics != null) {
|
|
110
|
+
this.metrics = {
|
|
111
|
+
dialerEvents: components.metrics.registerCounterGroup('libp2p_websockets_dialer_events_total', {
|
|
112
|
+
label: 'event',
|
|
113
|
+
help: 'Total count of WebSockets dialer events by type'
|
|
114
|
+
})
|
|
115
|
+
}
|
|
116
|
+
}
|
|
100
117
|
}
|
|
101
118
|
|
|
102
119
|
readonly [transportSymbol] = true
|
|
@@ -113,7 +130,8 @@ class WebSockets implements Transport<WebSocketsDialEvents> {
|
|
|
113
130
|
|
|
114
131
|
const socket = await this._connect(ma, options)
|
|
115
132
|
const maConn = socketToMaConn(socket, ma, {
|
|
116
|
-
logger: this.logger
|
|
133
|
+
logger: this.logger,
|
|
134
|
+
metrics: this.metrics?.dialerEvents
|
|
117
135
|
})
|
|
118
136
|
this.log('new outbound connection %s', maConn.remoteAddr)
|
|
119
137
|
|
|
@@ -136,6 +154,7 @@ class WebSockets implements Transport<WebSocketsDialEvents> {
|
|
|
136
154
|
// https://developer.mozilla.org/en-US/docs/Web/API/WebSocket/error_event
|
|
137
155
|
const err = new CodeError(`Could not connect to ${ma.toString()}`, 'ERR_CONNECTION_FAILED')
|
|
138
156
|
this.log.error('connection error:', err)
|
|
157
|
+
this.metrics?.dialerEvents.increment({ error: true })
|
|
139
158
|
errorPromise.reject(err)
|
|
140
159
|
})
|
|
141
160
|
|
|
@@ -143,6 +162,10 @@ class WebSockets implements Transport<WebSocketsDialEvents> {
|
|
|
143
162
|
options.onProgress?.(new CustomProgressEvent('websockets:open-connection'))
|
|
144
163
|
await raceSignal(Promise.race([rawSocket.connected(), errorPromise.promise]), options.signal)
|
|
145
164
|
} catch (err: any) {
|
|
165
|
+
if (options.signal?.aborted === true) {
|
|
166
|
+
this.metrics?.dialerEvents.increment({ abort: true })
|
|
167
|
+
}
|
|
168
|
+
|
|
146
169
|
rawSocket.close()
|
|
147
170
|
.catch(err => {
|
|
148
171
|
this.log.error('error closing raw socket', err)
|
|
@@ -152,6 +175,7 @@ class WebSockets implements Transport<WebSocketsDialEvents> {
|
|
|
152
175
|
}
|
|
153
176
|
|
|
154
177
|
this.log('connected %s', ma)
|
|
178
|
+
this.metrics?.dialerEvents.increment({ connect: true })
|
|
155
179
|
return rawSocket
|
|
156
180
|
}
|
|
157
181
|
|
|
@@ -162,7 +186,8 @@ class WebSockets implements Transport<WebSocketsDialEvents> {
|
|
|
162
186
|
*/
|
|
163
187
|
createListener (options: CreateListenerOptions): Listener {
|
|
164
188
|
return createListener({
|
|
165
|
-
logger: this.logger
|
|
189
|
+
logger: this.logger,
|
|
190
|
+
metrics: this.components.metrics
|
|
166
191
|
}, {
|
|
167
192
|
...this.init,
|
|
168
193
|
...options
|
package/src/listener.ts
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import os from 'os'
|
|
2
|
-
import { TypedEventEmitter
|
|
2
|
+
import { TypedEventEmitter } from '@libp2p/interface'
|
|
3
3
|
import { ipPortToMultiaddr as toMultiaddr } from '@libp2p/utils/ip-port-to-multiaddr'
|
|
4
4
|
import { multiaddr, protocols } from '@multiformats/multiaddr'
|
|
5
5
|
import { createServer } from 'it-ws/server'
|
|
6
6
|
import { socketToMaConn } from './socket-to-conn.js'
|
|
7
|
-
import type { ComponentLogger, Logger, Connection, Listener, ListenerEvents, CreateListenerOptions } from '@libp2p/interface'
|
|
7
|
+
import type { ComponentLogger, Logger, Connection, Listener, ListenerEvents, CreateListenerOptions, CounterGroup, MetricGroup, Metrics } from '@libp2p/interface'
|
|
8
8
|
import type { Multiaddr } from '@multiformats/multiaddr'
|
|
9
9
|
import type { Server } from 'http'
|
|
10
10
|
import type { DuplexWebSocket } from 'it-ws/duplex'
|
|
@@ -12,32 +12,46 @@ import type { WebSocketServer } from 'it-ws/server'
|
|
|
12
12
|
|
|
13
13
|
export interface WebSocketListenerComponents {
|
|
14
14
|
logger: ComponentLogger
|
|
15
|
+
metrics?: Metrics
|
|
15
16
|
}
|
|
16
17
|
|
|
17
18
|
export interface WebSocketListenerInit extends CreateListenerOptions {
|
|
18
19
|
server?: Server
|
|
19
20
|
}
|
|
20
21
|
|
|
22
|
+
export interface WebSocketListenerMetrics {
|
|
23
|
+
status: MetricGroup
|
|
24
|
+
errors: CounterGroup
|
|
25
|
+
events: CounterGroup
|
|
26
|
+
}
|
|
27
|
+
|
|
21
28
|
class WebSocketListener extends TypedEventEmitter<ListenerEvents> implements Listener {
|
|
22
29
|
private readonly connections: Set<DuplexWebSocket>
|
|
23
30
|
private listeningMultiaddr?: Multiaddr
|
|
24
31
|
private readonly server: WebSocketServer
|
|
25
32
|
private readonly log: Logger
|
|
33
|
+
private metrics?: WebSocketListenerMetrics
|
|
34
|
+
private addr: string
|
|
26
35
|
|
|
27
36
|
constructor (components: WebSocketListenerComponents, init: WebSocketListenerInit) {
|
|
28
37
|
super()
|
|
29
38
|
|
|
30
39
|
this.log = components.logger.forComponent('libp2p:websockets:listener')
|
|
40
|
+
const metrics = components.metrics
|
|
31
41
|
// Keep track of open connections to destroy when the listener is closed
|
|
32
42
|
this.connections = new Set<DuplexWebSocket>()
|
|
33
43
|
|
|
34
44
|
const self = this // eslint-disable-line @typescript-eslint/no-this-alias
|
|
35
45
|
|
|
46
|
+
this.addr = 'unknown'
|
|
47
|
+
|
|
36
48
|
this.server = createServer({
|
|
37
49
|
...init,
|
|
38
50
|
onConnection: (stream: DuplexWebSocket) => {
|
|
39
51
|
const maConn = socketToMaConn(stream, toMultiaddr(stream.remoteAddress ?? '', stream.remotePort ?? 0), {
|
|
40
|
-
logger: components.logger
|
|
52
|
+
logger: components.logger,
|
|
53
|
+
metrics: this.metrics?.events,
|
|
54
|
+
metricPrefix: `${this.addr} `
|
|
41
55
|
})
|
|
42
56
|
this.log('new inbound connection %s', maConn.remoteAddr)
|
|
43
57
|
|
|
@@ -62,6 +76,7 @@ class WebSocketListener extends TypedEventEmitter<ListenerEvents> implements Lis
|
|
|
62
76
|
})
|
|
63
77
|
.catch(async err => {
|
|
64
78
|
this.log.error('inbound connection failed to upgrade', err)
|
|
79
|
+
this.metrics?.errors.increment({ [`${this.addr} inbound_upgrade`]: true })
|
|
65
80
|
|
|
66
81
|
await maConn.close().catch(err => {
|
|
67
82
|
this.log.error('inbound connection failed to close after upgrade failed', err)
|
|
@@ -71,15 +86,46 @@ class WebSocketListener extends TypedEventEmitter<ListenerEvents> implements Lis
|
|
|
71
86
|
this.log.error('inbound connection failed to upgrade', err)
|
|
72
87
|
maConn.close().catch(err => {
|
|
73
88
|
this.log.error('inbound connection failed to close after upgrade failed', err)
|
|
89
|
+
this.metrics?.errors.increment({ [`${this.addr} inbound_closing_failed`]: true })
|
|
74
90
|
})
|
|
75
91
|
}
|
|
76
92
|
}
|
|
77
93
|
})
|
|
78
94
|
|
|
79
95
|
this.server.on('listening', () => {
|
|
96
|
+
if (metrics != null) {
|
|
97
|
+
const { host, port } = this.listeningMultiaddr?.toOptions() ?? {}
|
|
98
|
+
this.addr = `${host}:${port}`
|
|
99
|
+
|
|
100
|
+
metrics.registerMetricGroup('libp2p_websockets_inbound_connections_total', {
|
|
101
|
+
label: 'address',
|
|
102
|
+
help: 'Current active connections in WebSocket listener',
|
|
103
|
+
calculate: () => {
|
|
104
|
+
return {
|
|
105
|
+
[this.addr]: this.connections.size
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
})
|
|
109
|
+
|
|
110
|
+
this.metrics = {
|
|
111
|
+
status: metrics?.registerMetricGroup('libp2p_websockets_listener_status_info', {
|
|
112
|
+
label: 'address',
|
|
113
|
+
help: 'Current status of the WebSocket listener socket'
|
|
114
|
+
}),
|
|
115
|
+
errors: metrics?.registerMetricGroup('libp2p_websockets_listener_errors_total', {
|
|
116
|
+
label: 'address',
|
|
117
|
+
help: 'Total count of WebSocket listener errors by type'
|
|
118
|
+
}),
|
|
119
|
+
events: metrics?.registerMetricGroup('libp2p_websockets_listener_events_total', {
|
|
120
|
+
label: 'address',
|
|
121
|
+
help: 'Total count of WebSocket listener events by type'
|
|
122
|
+
})
|
|
123
|
+
}
|
|
124
|
+
}
|
|
80
125
|
this.dispatchEvent(new CustomEvent('listening'))
|
|
81
126
|
})
|
|
82
127
|
this.server.on('error', (err: Error) => {
|
|
128
|
+
this.metrics?.errors.increment({ [`${this.addr} listen_error`]: true })
|
|
83
129
|
this.dispatchEvent(new CustomEvent('error', {
|
|
84
130
|
detail: err
|
|
85
131
|
}))
|
package/src/socket-to-conn.ts
CHANGED
|
@@ -1,18 +1,22 @@
|
|
|
1
1
|
import { CodeError } from '@libp2p/interface'
|
|
2
2
|
import { CLOSE_TIMEOUT } from './constants.js'
|
|
3
|
-
import type { AbortOptions, ComponentLogger, MultiaddrConnection } from '@libp2p/interface'
|
|
3
|
+
import type { AbortOptions, ComponentLogger, CounterGroup, MultiaddrConnection } from '@libp2p/interface'
|
|
4
4
|
import type { Multiaddr } from '@multiformats/multiaddr'
|
|
5
5
|
import type { DuplexWebSocket } from 'it-ws/duplex'
|
|
6
6
|
|
|
7
7
|
export interface SocketToConnOptions {
|
|
8
8
|
localAddr?: Multiaddr
|
|
9
9
|
logger: ComponentLogger
|
|
10
|
+
metrics?: CounterGroup
|
|
11
|
+
metricPrefix?: string
|
|
10
12
|
}
|
|
11
13
|
|
|
12
14
|
// Convert a stream into a MultiaddrConnection
|
|
13
15
|
// https://github.com/libp2p/interface-transport#multiaddrconnection
|
|
14
16
|
export function socketToMaConn (stream: DuplexWebSocket, remoteAddr: Multiaddr, options: SocketToConnOptions): MultiaddrConnection {
|
|
15
17
|
const log = options.logger.forComponent('libp2p:websockets:maconn')
|
|
18
|
+
const metrics = options.metrics
|
|
19
|
+
const metricPrefix = options.metricPrefix ?? ''
|
|
16
20
|
|
|
17
21
|
const maConn: MultiaddrConnection = {
|
|
18
22
|
log,
|
|
@@ -81,10 +85,18 @@ export function socketToMaConn (stream: DuplexWebSocket, remoteAddr: Multiaddr,
|
|
|
81
85
|
|
|
82
86
|
stream.destroy()
|
|
83
87
|
maConn.timeline.close = Date.now()
|
|
88
|
+
|
|
89
|
+
// ws WebSocket.terminate does not accept an Error arg to emit an 'error'
|
|
90
|
+
// event on destroy like other node streams so we can't update a metric
|
|
91
|
+
// with an event listener
|
|
92
|
+
// https://github.com/websockets/ws/issues/1752#issuecomment-622380981
|
|
93
|
+
metrics?.increment({ [`${metricPrefix}error`]: true })
|
|
84
94
|
}
|
|
85
95
|
}
|
|
86
96
|
|
|
87
97
|
stream.socket.addEventListener('close', () => {
|
|
98
|
+
metrics?.increment({ [`${metricPrefix}close`]: true })
|
|
99
|
+
|
|
88
100
|
// In instances where `close` was not explicitly called,
|
|
89
101
|
// such as an iterable stream ending, ensure we have set the close
|
|
90
102
|
// timeline
|
package/dist/typedoc-urls.json
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"all": "https://libp2p.github.io/js-libp2p/functions/_libp2p_websockets.filters.all.html",
|
|
3
|
-
"./filters:all": "https://libp2p.github.io/js-libp2p/functions/_libp2p_websockets.filters.all.html",
|
|
4
|
-
"dnsWsOrWss": "https://libp2p.github.io/js-libp2p/functions/_libp2p_websockets.filters.dnsWsOrWss.html",
|
|
5
|
-
"./filters:dnsWsOrWss": "https://libp2p.github.io/js-libp2p/functions/_libp2p_websockets.filters.dnsWsOrWss.html",
|
|
6
|
-
"dnsWss": "https://libp2p.github.io/js-libp2p/functions/_libp2p_websockets.filters.dnsWss.html",
|
|
7
|
-
"./filters:dnsWss": "https://libp2p.github.io/js-libp2p/functions/_libp2p_websockets.filters.dnsWss.html",
|
|
8
|
-
"wss": "https://libp2p.github.io/js-libp2p/functions/_libp2p_websockets.filters.wss.html",
|
|
9
|
-
"./filters:wss": "https://libp2p.github.io/js-libp2p/functions/_libp2p_websockets.filters.wss.html",
|
|
10
|
-
"WebSocketsComponents": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_websockets.index.WebSocketsComponents.html",
|
|
11
|
-
".:WebSocketsComponents": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_websockets.index.WebSocketsComponents.html",
|
|
12
|
-
"WebSocketsInit": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_websockets.index.WebSocketsInit.html",
|
|
13
|
-
".:WebSocketsInit": "https://libp2p.github.io/js-libp2p/interfaces/_libp2p_websockets.index.WebSocketsInit.html",
|
|
14
|
-
"WebSocketsDialEvents": "https://libp2p.github.io/js-libp2p/types/_libp2p_websockets.index.WebSocketsDialEvents.html",
|
|
15
|
-
".:WebSocketsDialEvents": "https://libp2p.github.io/js-libp2p/types/_libp2p_websockets.index.WebSocketsDialEvents.html",
|
|
16
|
-
"webSockets": "https://libp2p.github.io/js-libp2p/functions/_libp2p_websockets.index.webSockets.html",
|
|
17
|
-
".:webSockets": "https://libp2p.github.io/js-libp2p/functions/_libp2p_websockets.index.webSockets.html"
|
|
18
|
-
}
|