@libp2p/websockets 8.1.0 → 8.1.1-ce6da9896
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 +3 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +13 -31
- package/dist/src/index.js.map +1 -1
- package/package.json +7 -5
- package/src/index.ts +22 -37
- package/dist/typedoc-urls.json +0 -16
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 qr=Object.create;var we=Object.defineProperty;var Qr=Object.getOwnPropertyDescriptor;var Gr=Object.getOwnPropertyNames;var Hr=Object.getPrototypeOf,Xr=Object.prototype.hasOwnProperty;var Te=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),C=(t,e)=>{for(var r in e)we(t,r,{get:e[r],enumerable:!0})},Et=(t,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let o of Gr(e))!Xr.call(t,o)&&o!==r&&we(t,o,{get:()=>e[o],enumerable:!(n=Qr(e,o))||n.enumerable});return t};var St=(t,e,r)=>(r=t!=null?qr(Hr(t)):{},Et(e||!t||!t.__esModule?we(r,"default",{value:t,enumerable:!0}):r,t)),Jr=t=>Et(we({},"__esModule",{value:!0}),t);var wr=Te(Ce=>{"use strict";Object.defineProperty(Ce,"__esModule",{value:!0});var ht=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}))}}},Ae=class{constructor(e,{highWaterMark:r=100,lowWaterMark:n=1}={}){let o=new ht;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)}};Ce.EventIterator=Ae;Ce.default=Ae});var gr=Te(he=>{"use strict";Object.defineProperty(he,"__esModule",{value:!0});var mt=wr();he.EventIterator=mt.EventIterator;function $o(t,e,r){return new mt.EventIterator(({push:n})=>(this.addEventListener(t,n,e),()=>this.removeEventListener(t,n,e)),r)}he.subscribe=$o;he.default=mt.EventIterator});var Pr=Te((da,Ir)=>{function ko(){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)}Ir.exports=ko});var Jo={};C(Jo,{webSockets:()=>Xo});var Ct=Symbol.for("@libp2p/transport");var At;(function(t){t[t.FATAL_ALL=0]="FATAL_ALL",t[t.NO_FATAL=1]="NO_FATAL"})(At||(At={}));var ae=class t extends Error{code;type;constructor(e="The operation was aborted"){super(e),this.name="AbortError",this.code=t.code,this.type=t.type}static code="ABORT_ERR";static type="aborted"},z=class extends Error{code;props;constructor(e,r,n){super(e),this.code=r,this.name=n?.name??"CodeError",this.props=n??{}}};var It=Symbol.for("@libp2p/service-capabilities"),es=Symbol.for("@libp2p/service-dependencies");var Re={};C(Re,{base58btc:()=>E,base58flickr:()=>rn});var As=new Uint8Array(0);function Pt(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 Tt(t){return new TextEncoder().encode(t)}function Ut(t){return new TextDecoder().decode(t)}function Kr(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),h=Math.log(256)/Math.log(c);function x(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],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 me=d.repeat(v);O<L;++O)me+=t.charAt(P[O]);return me}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]===d;)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,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(l[v]!==" "){for(var U=N-T;U!==N&&L[U]===0;)U++;for(var O=new Uint8Array(q+(N-U)),me=q;U!==N;)O[me++]=L[U++];return O}}}function I(l){var v=y(l);if(v)return v;throw new Error(`Non-${e} character`)}return{encode:x,decodeUnsafe:y,decode:I}}var Yr=Kr,Zr=Yr,Lt=Zr;var Ue=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")}},Ne=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 Dt(this,e)}},Le=class{decoders;constructor(e){this.decoders=e}or(e){return Dt(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 Dt(t,e){return new Le({...t.decoders??{[t.prefix]:t},...e.decoders??{[e.prefix]:e}})}var De=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 Ue(e,r,n),this.decoder=new Ne(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 De(t,e,r,n)}function V({name:t,prefix:e,alphabet:r}){let{encode:n,decode:o}=Lt(r,t);return K({prefix:e,name:t,encode:n,decode:s=>$(o(s))})}function en(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,d=0,m=0;for(let h=0;h<s;++h){let x=o[t[h]];if(x===void 0)throw new SyntaxError(`Non-${n} character`);d=d<<r|x,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 tn(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 w({name:t,prefix:e,bitsPerChar:r,alphabet:n}){return K({prefix:e,name:t,encode(o){return tn(o,n,r)},decode(o){return en(o,n,r,t)}})}var E=V({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),rn=V({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Oe={};C(Oe,{base32:()=>F,base32hex:()=>cn,base32hexpad:()=>pn,base32hexpadupper:()=>dn,base32hexupper:()=>an,base32pad:()=>on,base32padupper:()=>sn,base32upper:()=>nn,base32z:()=>un});var F=w({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),nn=w({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),on=w({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),sn=w({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),cn=w({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),an=w({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),pn=w({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),dn=w({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),un=w({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ln=$t,Rt=128,fn=127,hn=~fn,mn=Math.pow(2,31);function $t(t,e,r){e=e||[],r=r||0;for(var n=r;t>=mn;)e[r++]=t&255|Rt,t/=128;for(;t&hn;)e[r++]=t&255|Rt,t>>>=7;return e[r]=t|0,$t.bytes=r-n+1,e}var wn=$e,gn=128,Ot=127;function $e(t,n){var r=0,n=n||0,o=0,s=n,i,c=t.length;do{if(s>=c)throw $e.bytes=0,new RangeError("Could not decode varint");i=t[s++],r+=o<28?(i&Ot)<<o:(i&Ot)*Math.pow(2,o),o+=7}while(i>=gn);return $e.bytes=s-n,r}var xn=Math.pow(2,7),bn=Math.pow(2,14),yn=Math.pow(2,21),vn=Math.pow(2,28),En=Math.pow(2,35),Sn=Math.pow(2,42),An=Math.pow(2,49),Cn=Math.pow(2,56),In=Math.pow(2,63),Pn=function(t){return t<xn?1:t<bn?2:t<yn?3:t<vn?4:t<En?5:t<Sn?6:t<An?7:t<Cn?8:t<In?9:10},Tn={encode:ln,decode:wn,encodingLength:Pn},Un=Tn,pe=Un;function de(t,e=0){return[pe.decode(t,e),pe.decode.bytes]}function Y(t,e,r=0){return pe.encode(t,e,r),e}function Z(t){return pe.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]=de(e),[o,s]=de(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 Ft(t,e){if(t===e)return!0;{let r=e;return t.code===r.code&&t.size===r.size&&r.bytes instanceof Uint8Array&&Pt(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 Ln(r,Fe(t),e??E.encoder);default:return Dn(r,Fe(t),e??F.encoder)}}var Mt=new WeakMap;function Fe(t){let e=Mt.get(t);if(e==null){let r=new Map;return Mt.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!==ue)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(r.code!==Rn)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&&Ft(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??zt(n,o,s.bytes))}else if(r[On]===!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!==ue)throw new Error(`Version 0 CID must use dag-pb (code: ${ue}) block encoding`);return new t(e,r,n,n.bytes)}case 1:{let o=zt(e,r,n.bytes);return new t(e,r,n,o)}default:throw new Error("Invalid version")}}static createV0(e){return t.create(0,ue,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[x,y]=de(e.subarray(r));return r+=y,x},o=n(),s=ue;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,h=m-i;return{version:o,codec:s,multihashCode:c,digestSize:d,multihashSize:h,size:m}}static parse(e,r){let[n,o]=Nn(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 Fe(s).set(n,e),s}};function Nn(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 Ln(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 Dn(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 ue=112,Rn=18;function zt(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 On=Symbol.for("@ipld/js-cid/CID");function Vt(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:()=>$n});var $n=V({prefix:"9",name:"base10",alphabet:"0123456789"});var Me={};C(Me,{base16:()=>Fn,base16upper:()=>kn});var Fn=w({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),kn=w({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var ze={};C(ze,{base2:()=>Mn});var Mn=w({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ve={};C(Ve,{base256emoji:()=>Bn});var Wt=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}"),zn=Wt.reduce((t,e,r)=>(t[r]=e,t),[]),Vn=Wt.reduce((t,e,r)=>(t[e.codePointAt(0)]=r,t),[]);function Wn(t){return t.reduce((e,r)=>(e+=zn[r],e),"")}function _n(t){let e=[];for(let r of t){let n=Vn[r.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${r}`);e.push(n)}return new Uint8Array(e)}var Bn=K({prefix:"\u{1F680}",name:"base256emoji",encode:Wn,decode:_n});var We={};C(We,{base36:()=>jn,base36upper:()=>qn});var jn=V({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),qn=V({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var _e={};C(_e,{base64:()=>Qn,base64pad:()=>Gn,base64url:()=>Hn,base64urlpad:()=>Xn});var Qn=w({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Gn=w({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Hn=w({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Xn=w({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Be={};C(Be,{base8:()=>Jn});var Jn=w({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var je={};C(je,{identity:()=>Kn});var Kn=K({prefix:"\0",name:"identity",encode:t=>Ut(t),decode:t=>Tt(t)});var Xs=new TextEncoder,Js=new TextDecoder;var qe={};C(qe,{identity:()=>ro});var _t=0,eo="identity",Bt=$;function to(t){return Q(_t,Bt(t))}var ro={code:_t,name:eo,encode:Bt,digest:to};var He={};C(He,{sha256:()=>no,sha512:()=>oo});function Ge({name:t,code:e,encode:r}){return new Qe(t,e,r)}var Qe=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 no=Ge({name:"sha2-256",code:18,encode:qt("SHA-256")}),oo=Ge({name:"sha2-512",code:19,encode:qt("SHA-512")});var le={...je,...ze,...Be,...ke,...Me,...Oe,...We,...Re,..._e,...Ve},pi={...He,...qe};function re(t=0){return new Uint8Array(t)}function Gt(t,e,r,n){return{name:t,prefix:e,encoder:{name:t,prefix:e,encode:r},decoder:{decode:n}}}var Qt=Gt("utf8","u",t=>"u"+new TextDecoder("utf8").decode(t),t=>new TextEncoder().encode(t.substring(1))),Xe=Gt("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}),so={utf8:Qt,"utf-8":Qt,hex:le.base16,latin1:Xe,ascii:Xe,binary:Xe,...le},be=so;function S(t,e="utf8"){let r=be[e];if(r==null)throw new Error(`Unsupported encoding "${e}"`);return r.encoder.encode(t).substring(1)}var io=Math.pow(2,7),co=Math.pow(2,14),ao=Math.pow(2,21),Je=Math.pow(2,28),Ke=Math.pow(2,35),Ye=Math.pow(2,42),Ze=Math.pow(2,49),f=128,b=127;function R(t){if(t<io)return 1;if(t<co)return 2;if(t<ao)return 3;if(t<Je)return 4;if(t<Ke)return 5;if(t<Ye)return 6;if(t<Ze)return 7;if(Number.MAX_SAFE_INTEGER!=null&&t>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function po(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 uo(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 lo(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)*Je,r<f)||(r=t[e+5],n+=(r&b)*Ke,r<f)||(r=t[e+6],n+=(r&b)*Ye,r<f)||(r=t[e+7],n+=(r&b)*Ze,r<f))return n;throw new RangeError("Could not decode varint")}function fo(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)*Je,r<f)||(r=t.get(e+5),n+=(r&b)*Ke,r<f)||(r=t.get(e+6),n+=(r&b)*Ye,r<f)||(r=t.get(e+7),n+=(r&b)*Ze,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?po(t,e,r):uo(t,e,r)}function G(t,e=0){return t instanceof Uint8Array?lo(t,e):fo(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 ye=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 h=this.readAtomically(()=>{let x=this.readChar();if(x===void 0)return;let y=Number.parseInt(x,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&&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 Xt=45,ho=15,oe=new ye;function et(t){if(!(t.length>ho))return oe.new(t).parseWith(()=>oe.readIPv4Addr())}function tt(t){if(t.includes("%")&&(t=t.split("%")[0]),!(t.length>Xt))return oe.new(t).parseWith(()=>oe.readIPv6Addr())}function ve(t){if(t.includes("%")&&(t=t.split("%")[0]),!(t.length>Xt))return oe.new(t).parseWith(()=>oe.readIPAddr())}var Di=parseInt("0xFFFF",16),Ri=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function fe(t,e="utf8"){let r=be[e];if(r==null)throw new Error(`Unsupported encoding "${e}"`);return r.decoder.decode(`${r.prefix}${t}`)}function Yt(t){return!!et(t)}function Zt(t){return!!tt(t)}function Ee(t){return!!ve(t)}var er=Yt,bo=Zt,rt=function(t){let e=0;if(t=t.toString().trim(),er(t)){let r=new Uint8Array(e+4);return t.split(/\./g).forEach(n=>{r[e++]=parseInt(n,10)&255}),r}if(bo(t)){let r=t.split(":",8),n;for(n=0;n<r.length;n++){let s=er(r[n]),i;s&&(i=rt(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")},tr=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={},nt={},vo=[[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"]];vo.forEach(t=>{let e=Eo(...t);nt[e.code]=e,se[e.name]=e});function Eo(t,e,r,n,o){return{code:t,size:e,name:r,resolvable:!!n,path:!!o}}function u(t){if(typeof t=="number"){if(nt[t]!=null)return nt[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 xc=u("ip4"),bc=u("ip6"),yc=u("ipcidr");function ct(t,e){switch(u(t).code){case 4:case 41:return Ao(e);case 42:return it(e);case 6:case 273:case 33:case 132:return or(e).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return it(e);case 421:return To(e);case 444:return nr(e);case 445:return nr(e);case 466:return Po(e);case 481:return globalThis.encodeURIComponent(it(e));default:return S(e,"base16")}}function at(t,e){switch(u(t).code){case 4:return rr(e);case 41:return rr(e);case 42:return st(e);case 6:case 273:case 33:case 132:return pt(parseInt(e,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return st(e);case 421:return Co(e);case 444:return Uo(e);case 445:return No(e);case 466:return Io(e);case 481:return st(globalThis.decodeURIComponent(e));default:return fe(e,"base16")}}var ot=Object.values(le).map(t=>t.decoder),So=function(){let t=ot[0].or(ot[1]);return ot.slice(2).forEach(e=>t=t.or(e)),t}();function rr(t){if(!Ee(t))throw new Error("invalid ip address");return rt(t)}function Ao(t){let e=tr(t,0,t.length);if(e==null)throw new Error("ipBuff is required");if(!Ee(e))throw new Error("invalid ip address");return e}function pt(t){let e=new ArrayBuffer(2);return new DataView(e).setUint16(0,t),new Uint8Array(e)}function or(t){return new DataView(t.buffer).getUint16(t.byteOffset)}function st(t){let e=fe(t),r=Uint8Array.from(ne(e.length));return k([r,e],r.length+e.length)}function it(t){let e=G(t);if(t=t.slice(R(e)),t.length!==e)throw new Error("inconsistent lengths");return S(t)}function Co(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 Io(t){let e=So.decode(t),r=Uint8Array.from(ne(e.length));return k([r,e],r.length+e.length)}function Po(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 To(t){let e=G(t),r=t.slice(R(e));if(r.length!==e)throw new Error("inconsistent lengths");return S(r,"base58btc")}function Uo(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=pt(n);return k([r,o],r.length+o.length)}function No(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=pt(n);return k([r,o],r.length+o.length)}function nr(t){let e=t.slice(0,t.length-2),r=t.slice(t.length-2),n=S(e,"base32"),o=or(r);return`${n}:${o}`}function sr(t){t=dt(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 cr("invalid address: "+t);if(c.path===!0){n=dt(o.slice(s).join("/")),e.push([c.code,at(c.code,n)]),r.push([c.code,n]);break}let d=at(c.code,o[s]);e.push([c.code,d]),r.push([c.code,ct(c.code,d)])}return{string:ir(r),bytes:lt(e),tuples:e,stringTuples:r,path:n}}function ut(t){let e=[],r=[],n=null,o=0;for(;o<t.length;){let s=G(t,o),i=R(s),c=u(s),d=Lo(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 cr("Invalid address Uint8Array: "+S(t,"base16"));e.push([s,m]);let h=ct(s,m);if(r.push([s,h]),c.path===!0){n=h;break}}return{bytes:Uint8Array.from(t),string:ir(r),tuples:e,stringTuples:r,path:n}}function ir(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}),dt(e.join("/"))}function lt(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 Lo(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 dt(t){return"/"+t.trim().split("/").filter(e=>e).join("/")}function cr(t){return new Error("Error parsing address: "+t)}var Do=Symbol.for("nodejs.util.inspect.custom"),ft=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Ro=[u("dns").code,u("dns4").code,u("dns6").code,u("dnsaddr").code],Se=class t{bytes;#t;#e;#r;#n;[ft]=!0;constructor(e){e==null&&(e="");let r;if(e instanceof Uint8Array)r=ut(e);else if(typeof e=="string"){if(e.length>0&&e.charAt(0)!=="/")throw new Error(`multiaddr "${e}" must start with a "/"`);r=sr(e)}else if(pr(e))r=ut(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"),h=u("dns6"),x=u("ip6zone");for(let[I,l]of this.stringTuples())I===x.code&&(s=`%${l??""}`),Ro.includes(I)&&(r=i.name,o=443,n=`${l??""}${s}`,e=I===h.code?6:4),(I===i.code||I===c.code)&&(r=u(I).name,o=parseInt(l??"")),(I===d.code||I===m.code)&&(r=u(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({},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(lt(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 Vt(this.bytes,e.bytes)}async resolve(e){let r=this.protos().find(s=>s.resolvable);if(r==null)return[this];let n=ar.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)}[Do](){return`Multiaddr(${this.#t})`}};var ar=new Map;function pr(t){return!!t?.[ft]}function _(t){return new Se(t)}var Oo=[u("tcp").code,u("dns").code,u("dnsaddr").code,u("dns4").code,u("dns6").code];function dr(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 ur(t){return t.some(([e,r])=>e===u("tls").code)}function A(t,e,r){let n=lr[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 lr={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=ur(e),n=dr(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=ur(e),n=dr(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 fr(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=lr[s.name];if(i==null)throw new Error(`No interpreter found for ${s.name}`);let c=i(o[1]??"",n);return e?.assumeHttp!==!1&&Oo.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 hr=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 mr=(t,e)=>(e=e??{},e.closeOnEnd=e.closeOnEnd!==!1,async n=>{for await(let o of n){try{await hr(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 br=St(gr(),1);function xr(t){return t instanceof ArrayBuffer||t?.constructor?.name==="ArrayBuffer"&&typeof t?.byteLength=="number"}var yr=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",d),t.removeEventListener("error",m),h()},d=()=>{c(s)},m=h=>{c(()=>{i(h.error??new Error(`connect ECONNREFUSED ${t.url}`))})};t.addEventListener("open",d),t.addEventListener("error",m)})},r=async function*(){let s=new br.EventIterator(({push:i,stop:c,fail:d})=>{let m=x=>{let y=null;typeof x.data=="string"&&(y=fe(x.data)),xr(x.data)&&(y=new Uint8Array(x.data)),x.data instanceof Uint8Array&&(y=x.data),y!=null&&i(y)},h=x=>{d(x.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 xr(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 vr=(t,e)=>{e=e??{};let r=yr(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:mr(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 Er=WebSocket;var Fo={"http:":"ws:","https:":"wss:"},Sr="ws:",Ar=(t,e)=>{if(t.startsWith("//")&&(t=`${e?.protocol??Sr}${t}`),t.startsWith("/")&&e!=null){let n=e.protocol??Sr,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(Fo))r.protocol===n&&(r.protocol=o);return r};function Cr(t,e){let r=typeof window>"u"?void 0:window.location;e=e??{};let n=Ar(t,r),o=new Er(n.toString(),e.websocket);return vr(o,e)}function wt(){let t={};return t.promise=new Promise((e,r)=>{t.resolve=e,t.reject=r}),t}var Tr=St(Pr(),1),Mo=typeof window=="object"&&typeof document=="object"&&document.nodeType===9,Ur=(0,Tr.default)(),Nr=Mo&&!Ur;var ua=typeof globalThis.process<"u"&&typeof globalThis.process.release<"u"&&globalThis.process.release.name==="node"&&!Ur,Lr=typeof importScripts=="function"&&typeof self<"u"&&typeof WorkerGlobalScope<"u"&&self instanceof WorkerGlobalScope,la=typeof globalThis.process<"u"&&typeof globalThis.process.env<"u"&&globalThis.process.env["NODE"+"_"+"ENV"]==="test",fa=typeof navigator<"u"&&navigator.product==="ReactNative";var zo=a("dns4"),Vo=a("dns6"),Wo=a("dnsaddr"),j=g(a("dns"),Wo,zo,Vo),Ie=g(a("ip4"),a("ip6")),ie=g(p(Ie,a("tcp")),p(j,a("tcp"))),Pe=p(Ie,a("udp")),_o=p(Pe,a("utp")),Bo=p(Pe,a("quic")),jo=p(Pe,a("quic-v1")),gt=g(p(ie,a("ws")),p(j,a("ws"))),ce=g(p(gt,a("p2p")),gt),xt=g(p(ie,a("wss")),p(j,a("wss")),p(ie,a("tls"),a("ws")),p(j,a("tls"),a("ws"))),X=g(p(xt,a("p2p")),xt),bt=g(p(ie,a("http")),p(Ie,a("http")),p(j,a("http"))),yt=g(p(ie,a("https")),p(Ie,a("https")),p(j,a("https"))),Dr=p(Pe,a("webrtc-direct"),a("certhash")),$r=g(p(Dr,a("p2p")),Dr),Rr=p(jo,a("webtransport"),a("certhash"),a("certhash")),Fr=g(p(Rr,a("p2p")),Rr),kr=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"))),wa=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"))),Mr=g(p(bt,a("p2p-webrtc-direct"),a("p2p")),p(yt,a("p2p-webrtc-direct"),a("p2p")),p(bt,a("p2p-webrtc-direct")),p(yt,a("p2p-webrtc-direct"))),J=g(gt,xt,bt,yt,kr,Mr,ie,_o,Bo,j,$r,Fr),ga=g(p(J,a("p2p-stardust"),a("p2p")),p(J,a("p2p-stardust"))),B=g(p(J,a("p2p")),kr,Mr,$r,Fr,a("p2p")),Or=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")),zr=()=>g(p(Or,zr),Or),H=zr(),xa=g(p(H,B,H),p(B,H),p(H,B),H,B);var ba=g(p(H,a("webrtc"),a("p2p")),p(H,a("webrtc")),p(J,a("webrtc"),a("p2p")),p(J,a("webrtc")),a("webrtc"));function Vr(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:Vr(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:Vr(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 Wr(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 _r(t){return t.filter(e=>{if(e.protoCodes().includes(290))return!1;let r=e.decapsulateCode(421);return X.matches(r)})}function Br(){throw new Error("WebSocket Servers can not be created in the browser!")}function jr(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 d=AbortSignal.timeout(500);s={...s,signal:d}}let c=()=>{let{host:d,port:m}=o.remoteAddr.toOptions();n("timeout closing stream to %s:%s after %dms, destroying it manually",d,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(d){n.error("error closing WebSocket gracefully",d),this.abort(d)}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 vt=class{log;init;logger;constructor(e,r){this.log=e.logger.forComponent("libp2p:websockets"),this.logger=e.logger,this.init=r}[Ct]=!0;[Symbol.toStringTag]="@libp2p/websockets";[It]=["@libp2p/transport"];async dial(e,r){this.log("dialing %s",e),r=r??{};let n=await this._connect(e,r),o=jr(n,e,{logger:this.logger});this.log("new outbound connection %s",o.remoteAddr);let s=await r.upgrader.upgradeOutbound(o);return this.log("outbound connection %s upgraded",o.remoteAddr),s}async _connect(e,r){if(r?.signal?.aborted===!0)throw new ae;let n=e.toOptions();this.log("dialing %s:%s",n.host,n.port);let o=wt(),s=Cr(fr(e),this.init);if(s.socket.addEventListener("error",()=>{let d=new z(`Could not connect to ${e.toString()}`,"ERR_CONNECTION_FAILED");this.log.error("connection error:",d),o.reject(d)}),r.signal==null)return await Promise.race([s.connected(),o.promise]),this.log("connected %s",e),s;let i,c=new Promise((d,m)=>{if(i=()=>{m(new ae),s.close().catch(h=>{this.log.error("error closing raw socket",h)})},r?.signal?.aborted===!0){i();return}r?.signal?.addEventListener("abort",i)});try{await Promise.race([c,o.promise,s.connected()])}finally{i!=null&&r?.signal?.removeEventListener("abort",i)}return this.log("connected %s",e),s}createListener(e){return Br({logger:this.logger},{...this.init,...e})}listenFilter(e){return e=Array.isArray(e)?e:[e],this.init?.filter!=null?this.init?.filter(e):Nr||Lr?_r(e):Wr(e)}dialFilter(e){return this.listenFilter(e)}};function Xo(t={}){return e=>new vt(e,t)}return Jr(Jo);})();
|
|
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{constructor(e,r){super(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);})();
|
|
3
3
|
return Libp2PWebsockets}));
|
package/dist/src/index.d.ts
CHANGED
|
@@ -58,8 +58,9 @@
|
|
|
58
58
|
*/
|
|
59
59
|
/// <reference types="node" />
|
|
60
60
|
import { type WebSocketOptions } from 'it-ws/client';
|
|
61
|
-
import type { Transport, MultiaddrFilter, AbortOptions, ComponentLogger } from '@libp2p/interface';
|
|
61
|
+
import type { Transport, MultiaddrFilter, AbortOptions, ComponentLogger, OutboundConnectionUpgradeEvents } from '@libp2p/interface';
|
|
62
62
|
import type { Server } from 'http';
|
|
63
|
+
import type { ProgressEvent } from 'progress-events';
|
|
63
64
|
import type { ClientOptions } from 'ws';
|
|
64
65
|
export interface WebSocketsInit extends AbortOptions, WebSocketOptions {
|
|
65
66
|
filter?: MultiaddrFilter;
|
|
@@ -69,5 +70,6 @@ export interface WebSocketsInit extends AbortOptions, WebSocketOptions {
|
|
|
69
70
|
export interface WebSocketsComponents {
|
|
70
71
|
logger: ComponentLogger;
|
|
71
72
|
}
|
|
73
|
+
export type WebSocketsDialEvents = OutboundConnectionUpgradeEvents | ProgressEvent<'websockets:open-connection'>;
|
|
72
74
|
export declare function webSockets(init?: WebSocketsInit): (components: WebSocketsComponents) => Transport;
|
|
73
75
|
//# sourceMappingURL=index.d.ts.map
|
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;
|
|
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,EAAgD,YAAY,EAAE,eAAe,EAAsB,+BAA+B,EAAE,MAAM,mBAAmB,CAAA;AAErM,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;CACxB;AAED,MAAM,MAAM,oBAAoB,GAC9B,+BAA+B,GAC/B,aAAa,CAAC,4BAA4B,CAAC,CAAA;AA+G7C,wBAAgB,UAAU,CAAE,IAAI,GAAE,cAAmB,GAAG,CAAC,UAAU,EAAE,oBAAoB,KAAK,SAAS,CAItG"}
|
package/dist/src/index.js
CHANGED
|
@@ -56,10 +56,12 @@
|
|
|
56
56
|
* })
|
|
57
57
|
* ```
|
|
58
58
|
*/
|
|
59
|
-
import {
|
|
59
|
+
import { CodeError, transportSymbol, serviceCapabilities } from '@libp2p/interface';
|
|
60
60
|
import { multiaddrToUri as toUri } from '@multiformats/multiaddr-to-uri';
|
|
61
61
|
import { connect } from 'it-ws/client';
|
|
62
62
|
import pDefer from 'p-defer';
|
|
63
|
+
import { CustomProgressEvent } from 'progress-events';
|
|
64
|
+
import { raceSignal } from 'race-signal';
|
|
63
65
|
import { isBrowser, isWebWorker } from 'wherearewe';
|
|
64
66
|
import * as filters from './filters.js';
|
|
65
67
|
import { createListener } from './listener.js';
|
|
@@ -86,14 +88,12 @@ class WebSockets {
|
|
|
86
88
|
logger: this.logger
|
|
87
89
|
});
|
|
88
90
|
this.log('new outbound connection %s', maConn.remoteAddr);
|
|
89
|
-
const conn = await options.upgrader.upgradeOutbound(maConn);
|
|
91
|
+
const conn = await options.upgrader.upgradeOutbound(maConn, options);
|
|
90
92
|
this.log('outbound connection %s upgraded', maConn.remoteAddr);
|
|
91
93
|
return conn;
|
|
92
94
|
}
|
|
93
95
|
async _connect(ma, options) {
|
|
94
|
-
|
|
95
|
-
throw new AbortError();
|
|
96
|
-
}
|
|
96
|
+
options?.signal?.throwIfAborted();
|
|
97
97
|
const cOpts = ma.toOptions();
|
|
98
98
|
this.log('dialing %s:%s', cOpts.host, cOpts.port);
|
|
99
99
|
const errorPromise = pDefer();
|
|
@@ -106,34 +106,16 @@ class WebSockets {
|
|
|
106
106
|
this.log.error('connection error:', err);
|
|
107
107
|
errorPromise.reject(err);
|
|
108
108
|
});
|
|
109
|
-
if (options.signal == null) {
|
|
110
|
-
await Promise.race([rawSocket.connected(), errorPromise.promise]);
|
|
111
|
-
this.log('connected %s', ma);
|
|
112
|
-
return rawSocket;
|
|
113
|
-
}
|
|
114
|
-
// Allow abort via signal during connect
|
|
115
|
-
let onAbort;
|
|
116
|
-
const abort = new Promise((resolve, reject) => {
|
|
117
|
-
onAbort = () => {
|
|
118
|
-
reject(new AbortError());
|
|
119
|
-
rawSocket.close().catch(err => {
|
|
120
|
-
this.log.error('error closing raw socket', err);
|
|
121
|
-
});
|
|
122
|
-
};
|
|
123
|
-
// Already aborted?
|
|
124
|
-
if (options?.signal?.aborted === true) {
|
|
125
|
-
onAbort();
|
|
126
|
-
return;
|
|
127
|
-
}
|
|
128
|
-
options?.signal?.addEventListener('abort', onAbort);
|
|
129
|
-
});
|
|
130
109
|
try {
|
|
131
|
-
|
|
110
|
+
options.onProgress?.(new CustomProgressEvent('websockets:open-connection'));
|
|
111
|
+
await raceSignal(Promise.race([rawSocket.connected(), errorPromise.promise]), options.signal);
|
|
132
112
|
}
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
113
|
+
catch (err) {
|
|
114
|
+
rawSocket.close()
|
|
115
|
+
.catch(err => {
|
|
116
|
+
this.log.error('error closing raw socket', err);
|
|
117
|
+
});
|
|
118
|
+
throw err;
|
|
137
119
|
}
|
|
138
120
|
this.log('connected %s', ma);
|
|
139
121
|
return rawSocket;
|
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,
|
|
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;AAsBpD,MAAM,UAAU;IACG,GAAG,CAAQ;IACX,IAAI,CAAiB;IACrB,MAAM,CAAiB;IAExC,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,IAAI,GAAG,IAAI,CAAA;IAClB,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,OAA0C;QACnE,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;SACpB,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,OAA0C;QACvE,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,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,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,OAAO,SAAS,CAAA;IAClB,CAAC;IAED;;;;OAIG;IACH,cAAc,CAAE,OAA8B;QAC5C,OAAO,cAAc,CAAC;YACpB,MAAM,EAAE,IAAI,CAAC,MAAM;SACpB,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/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libp2p/websockets",
|
|
3
|
-
"version": "8.1.
|
|
3
|
+
"version": "8.1.1-ce6da9896",
|
|
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,20 +74,22 @@
|
|
|
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.0-ce6da9896",
|
|
78
|
+
"@libp2p/utils": "5.4.5-ce6da9896",
|
|
79
79
|
"@multiformats/mafmt": "^12.1.6",
|
|
80
80
|
"@multiformats/multiaddr": "^12.2.3",
|
|
81
81
|
"@multiformats/multiaddr-to-uri": "^10.0.1",
|
|
82
82
|
"@types/ws": "^8.5.10",
|
|
83
83
|
"it-ws": "^6.1.1",
|
|
84
84
|
"p-defer": "^4.0.1",
|
|
85
|
+
"progress-events": "^1.0.0",
|
|
86
|
+
"race-signal": "^1.0.2",
|
|
85
87
|
"wherearewe": "^2.0.1",
|
|
86
88
|
"ws": "^8.17.0"
|
|
87
89
|
},
|
|
88
90
|
"devDependencies": {
|
|
89
|
-
"@libp2p/interface-compliance-tests": "
|
|
90
|
-
"@libp2p/logger": "
|
|
91
|
+
"@libp2p/interface-compliance-tests": "5.4.8-ce6da9896",
|
|
92
|
+
"@libp2p/logger": "4.0.16-ce6da9896",
|
|
91
93
|
"aegir": "^43.0.1",
|
|
92
94
|
"is-loopback-addr": "^2.0.2",
|
|
93
95
|
"it-all": "^3.0.6",
|
package/src/index.ts
CHANGED
|
@@ -57,18 +57,21 @@
|
|
|
57
57
|
* ```
|
|
58
58
|
*/
|
|
59
59
|
|
|
60
|
-
import {
|
|
60
|
+
import { CodeError, transportSymbol, serviceCapabilities } from '@libp2p/interface'
|
|
61
61
|
import { multiaddrToUri as toUri } from '@multiformats/multiaddr-to-uri'
|
|
62
62
|
import { connect, type WebSocketOptions } from 'it-ws/client'
|
|
63
63
|
import pDefer from 'p-defer'
|
|
64
|
+
import { CustomProgressEvent } from 'progress-events'
|
|
65
|
+
import { raceSignal } from 'race-signal'
|
|
64
66
|
import { isBrowser, isWebWorker } from 'wherearewe'
|
|
65
67
|
import * as filters from './filters.js'
|
|
66
68
|
import { createListener } from './listener.js'
|
|
67
69
|
import { socketToMaConn } from './socket-to-conn.js'
|
|
68
|
-
import type { Transport, MultiaddrFilter, CreateListenerOptions, DialOptions, Listener, AbortOptions, ComponentLogger, Logger, Connection } from '@libp2p/interface'
|
|
70
|
+
import type { Transport, MultiaddrFilter, CreateListenerOptions, DialOptions, Listener, AbortOptions, ComponentLogger, Logger, Connection, OutboundConnectionUpgradeEvents } from '@libp2p/interface'
|
|
69
71
|
import type { Multiaddr } from '@multiformats/multiaddr'
|
|
70
72
|
import type { Server } from 'http'
|
|
71
73
|
import type { DuplexWebSocket } from 'it-ws/duplex'
|
|
74
|
+
import type { ProgressEvent } from 'progress-events'
|
|
72
75
|
import type { ClientOptions } from 'ws'
|
|
73
76
|
|
|
74
77
|
export interface WebSocketsInit extends AbortOptions, WebSocketOptions {
|
|
@@ -81,7 +84,11 @@ export interface WebSocketsComponents {
|
|
|
81
84
|
logger: ComponentLogger
|
|
82
85
|
}
|
|
83
86
|
|
|
84
|
-
|
|
87
|
+
export type WebSocketsDialEvents =
|
|
88
|
+
OutboundConnectionUpgradeEvents |
|
|
89
|
+
ProgressEvent<'websockets:open-connection'>
|
|
90
|
+
|
|
91
|
+
class WebSockets implements Transport<WebSocketsDialEvents> {
|
|
85
92
|
private readonly log: Logger
|
|
86
93
|
private readonly init?: WebSocketsInit
|
|
87
94
|
private readonly logger: ComponentLogger
|
|
@@ -100,7 +107,7 @@ class WebSockets implements Transport {
|
|
|
100
107
|
'@libp2p/transport'
|
|
101
108
|
]
|
|
102
109
|
|
|
103
|
-
async dial (ma: Multiaddr, options: DialOptions): Promise<Connection> {
|
|
110
|
+
async dial (ma: Multiaddr, options: DialOptions<WebSocketsDialEvents>): Promise<Connection> {
|
|
104
111
|
this.log('dialing %s', ma)
|
|
105
112
|
options = options ?? {}
|
|
106
113
|
|
|
@@ -110,15 +117,14 @@ class WebSockets implements Transport {
|
|
|
110
117
|
})
|
|
111
118
|
this.log('new outbound connection %s', maConn.remoteAddr)
|
|
112
119
|
|
|
113
|
-
const conn = await options.upgrader.upgradeOutbound(maConn)
|
|
120
|
+
const conn = await options.upgrader.upgradeOutbound(maConn, options)
|
|
114
121
|
this.log('outbound connection %s upgraded', maConn.remoteAddr)
|
|
115
122
|
return conn
|
|
116
123
|
}
|
|
117
124
|
|
|
118
|
-
async _connect (ma: Multiaddr, options:
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
}
|
|
125
|
+
async _connect (ma: Multiaddr, options: DialOptions<WebSocketsDialEvents>): Promise<DuplexWebSocket> {
|
|
126
|
+
options?.signal?.throwIfAborted()
|
|
127
|
+
|
|
122
128
|
const cOpts = ma.toOptions()
|
|
123
129
|
this.log('dialing %s:%s', cOpts.host, cOpts.port)
|
|
124
130
|
|
|
@@ -133,37 +139,16 @@ class WebSockets implements Transport {
|
|
|
133
139
|
errorPromise.reject(err)
|
|
134
140
|
})
|
|
135
141
|
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
// Allow abort via signal during connect
|
|
144
|
-
let onAbort
|
|
145
|
-
const abort = new Promise((resolve, reject) => {
|
|
146
|
-
onAbort = () => {
|
|
147
|
-
reject(new AbortError())
|
|
148
|
-
rawSocket.close().catch(err => {
|
|
142
|
+
try {
|
|
143
|
+
options.onProgress?.(new CustomProgressEvent('websockets:open-connection'))
|
|
144
|
+
await raceSignal(Promise.race([rawSocket.connected(), errorPromise.promise]), options.signal)
|
|
145
|
+
} catch (err: any) {
|
|
146
|
+
rawSocket.close()
|
|
147
|
+
.catch(err => {
|
|
149
148
|
this.log.error('error closing raw socket', err)
|
|
150
149
|
})
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
// Already aborted?
|
|
154
|
-
if (options?.signal?.aborted === true) {
|
|
155
|
-
onAbort(); return
|
|
156
|
-
}
|
|
157
150
|
|
|
158
|
-
|
|
159
|
-
})
|
|
160
|
-
|
|
161
|
-
try {
|
|
162
|
-
await Promise.race([abort, errorPromise.promise, rawSocket.connected()])
|
|
163
|
-
} finally {
|
|
164
|
-
if (onAbort != null) {
|
|
165
|
-
options?.signal?.removeEventListener('abort', onAbort)
|
|
166
|
-
}
|
|
151
|
+
throw err
|
|
167
152
|
}
|
|
168
153
|
|
|
169
154
|
this.log('connected %s', ma)
|
package/dist/typedoc-urls.json
DELETED
|
@@ -1,16 +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
|
-
"webSockets": "https://libp2p.github.io/js-libp2p/functions/_libp2p_websockets.index.webSockets.html",
|
|
15
|
-
".:webSockets": "https://libp2p.github.io/js-libp2p/functions/_libp2p_websockets.index.webSockets.html"
|
|
16
|
-
}
|