@libp2p/webtransport 4.0.32-167bf2b3c → 4.0.32-169c9d85e
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/muxer.d.ts.map +1 -1
- package/dist/src/muxer.js +17 -3
- package/dist/src/muxer.js.map +1 -1
- package/package.json +8 -8
- package/src/muxer.ts +45 -31
package/dist/index.min.js
CHANGED
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
`));let e=this.idBlock.tagClass===3?`[${this.idBlock.tagNumber}]`:this.constructor.NAME;return t.length?`${e} :
|
|
5
5
|
${t.join(`
|
|
6
6
|
`)}`:`${e} :`}};il=Me;U.Constructed=il;Me.NAME="CONSTRUCTED";var es=class extends Lt{fromBER(t,e,n){return e}toBER(t){return te}};es.override="EndOfContentValueBlock";var al,rs=class extends St{constructor(t={}){super(t,es),this.idBlock.tagClass=1,this.idBlock.tagNumber=0}};al=rs;U.EndOfContent=al;rs.NAME=an;var cl,Ke=class extends St{constructor(t={}){super(t,Lt),this.idBlock.tagClass=1,this.idBlock.tagNumber=5}fromBER(t,e,n){return this.lenBlock.length>0&&this.warnings.push("Non-zero length of value block for Null type"),this.idBlock.error.length||(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length||(this.blockLength+=this.lenBlock.blockLength),this.blockLength+=n,e+n>t.byteLength?(this.error="End of input reached before message was fully decoded (inconsistent offset and length values)",-1):e+n}toBER(t,e){let n=new ArrayBuffer(2);if(!t){let s=new Uint8Array(n);s[0]=5,s[1]=0}return e&&e.write(n),n}onAsciiEncoding(){return`${this.constructor.NAME}`}};cl=Ke;U.Null=cl;Ke.NAME="NULL";var ns=class extends ke(Lt){constructor({value:t,...e}={}){super(e),e.valueHex?this.valueHexView=Y.BufferSourceConverter.toUint8Array(e.valueHex):this.valueHexView=new Uint8Array(1),t&&(this.value=t)}get value(){for(let t of this.valueHexView)if(t>0)return!0;return!1}set value(t){this.valueHexView[0]=t?255:0}fromBER(t,e,n){let s=Y.BufferSourceConverter.toUint8Array(t);return Se(this,s,e,n)?(this.valueHexView=s.subarray(e,e+n),n>1&&this.warnings.push("Boolean value encoded in more then 1 octet"),this.isHexOnly=!0,Ei.call(this),this.blockLength=n,e+n):-1}toBER(){return this.valueHexView.slice()}toJSON(){return{...super.toJSON(),value:this.value}}};ns.NAME="BooleanValueBlock";var ll,ss=class extends St{constructor(t={}){super(t,ns),this.idBlock.tagClass=1,this.idBlock.tagNumber=1}getValue(){return this.valueBlock.value}setValue(t){this.valueBlock.value=t}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.getValue}`}};ll=ss;U.Boolean=ll;ss.NAME="BOOLEAN";var os=class extends ke(ae){constructor({isConstructed:t=!1,...e}={}){super(e),this.isConstructed=t}fromBER(t,e,n){let s=0;if(this.isConstructed){if(this.isHexOnly=!1,s=ae.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let o=0;o<this.value.length;o++){let i=this.value[o].constructor.NAME;if(i===an){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, OCTET STRING may consists of OCTET STRINGs only",-1}if(i!==rl)return this.error="OCTET STRING may consists of OCTET STRINGs only",-1}}else this.isHexOnly=!0,s=super.fromBER(t,e,n),this.blockLength=n;return s}toBER(t,e){return this.isConstructed?ae.prototype.toBER.call(this,t,e):t?new ArrayBuffer(this.valueHexView.byteLength):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),isConstructed:this.isConstructed}}};os.NAME="OctetStringValueBlock";var ul,Be=class r extends St{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},os),this.idBlock.tagClass=1,this.idBlock.tagNumber=4}fromBER(t,e,n){if(this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,n===0)return this.idBlock.error.length===0&&(this.blockLength+=this.idBlock.blockLength),this.lenBlock.error.length===0&&(this.blockLength+=this.lenBlock.blockLength),e;if(!this.valueBlock.isConstructed){let o=(t instanceof ArrayBuffer?new Uint8Array(t):t).subarray(e,e+n);try{if(o.byteLength){let i=Cs(o,0,o.byteLength);i.offset!==-1&&i.offset===n&&(this.valueBlock.value=[i.result])}}catch{}}return super.fromBER(t,e,n)}onAsciiEncoding(){return this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length?Me.prototype.onAsciiEncoding.call(this):`${this.constructor.NAME} : ${Y.Convert.ToHex(this.valueBlock.valueHexView)}`}getValue(){if(!this.idBlock.isConstructed)return this.valueBlock.valueHexView.slice().buffer;let t=[];for(let e of this.valueBlock.value)e instanceof r&&t.push(e.valueBlock.valueHexView);return Y.BufferSourceConverter.concat(t)}};ul=Be;U.OctetString=ul;Be.NAME=rl;var is=class extends ke(ae){constructor({unusedBits:t=0,isConstructed:e=!1,...n}={}){super(n),this.unusedBits=t,this.isConstructed=e,this.blockLength=this.valueHexView.byteLength}fromBER(t,e,n){if(!n)return e;let s=-1;if(this.isConstructed){if(s=ae.prototype.fromBER.call(this,t,e,n),s===-1)return s;for(let a of this.value){let c=a.constructor.NAME;if(c===an){if(this.isIndefiniteForm)break;return this.error="EndOfContent is unexpected, BIT STRING may consists of BIT STRINGs only",-1}if(c!==nl)return this.error="BIT STRING may consists of BIT STRINGs only",-1;let l=a.valueBlock;if(this.unusedBits>0&&l.unusedBits>0)return this.error='Using of "unused bits" inside constructive BIT STRING allowed for least one only',-1;this.unusedBits=l.unusedBits}return s}let o=Y.BufferSourceConverter.toUint8Array(t);if(!Se(this,o,e,n))return-1;let i=o.subarray(e,e+n);if(this.unusedBits=i[0],this.unusedBits>7)return this.error="Unused bits for BitString must be in range 0-7",-1;if(!this.unusedBits){let a=i.subarray(1);try{if(a.byteLength){let c=Cs(a,0,a.byteLength);c.offset!==-1&&c.offset===n-1&&(this.value=[c.result])}}catch{}}return this.valueHexView=i.subarray(1),this.blockLength=i.length,e+n}toBER(t,e){if(this.isConstructed)return ae.prototype.toBER.call(this,t,e);if(t)return new ArrayBuffer(this.valueHexView.byteLength+1);if(!this.valueHexView.byteLength)return te;let n=new Uint8Array(this.valueHexView.length+1);return n[0]=this.unusedBits,n.set(this.valueHexView,1),n.buffer}toJSON(){return{...super.toJSON(),unusedBits:this.unusedBits,isConstructed:this.isConstructed}}};is.NAME="BitStringValueBlock";var fl,kr=class extends St{constructor({idBlock:t={},lenBlock:e={},...n}={}){var s,o;(s=n.isConstructed)!==null&&s!==void 0||(n.isConstructed=!!(!((o=n.value)===null||o===void 0)&&o.length)),super({idBlock:{isConstructed:n.isConstructed,...t},lenBlock:{...e,isIndefiniteForm:!!n.isIndefiniteForm},...n},is),this.idBlock.tagClass=1,this.idBlock.tagNumber=3}fromBER(t,e,n){return this.valueBlock.isConstructed=this.idBlock.isConstructed,this.valueBlock.isIndefiniteForm=this.lenBlock.isIndefiniteForm,super.fromBER(t,e,n)}onAsciiEncoding(){if(this.valueBlock.isConstructed||this.valueBlock.value&&this.valueBlock.value.length)return Me.prototype.onAsciiEncoding.call(this);{let t=[],e=this.valueBlock.valueHexView;for(let s of e)t.push(s.toString(2).padStart(8,"0"));let n=t.join("");return`${this.constructor.NAME} : ${n.substring(0,n.length-this.valueBlock.unusedBits)}`}}};fl=kr;U.BitString=fl;kr.NAME=nl;var hl;function b0(r,t){let e=new Uint8Array([0]),n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,l=0,u=c<i?i:c,f=0;for(let p=u;p>=0;p--,f++){switch(!0){case f<a.length:l=o[i-f]+a[c-f]+e[0];break;default:l=o[i-f]+e[0]}switch(e[0]=l/10,!0){case f>=o.length:o=Wn(new Uint8Array([l%10]),o);break;default:o[i-f]=l%10}}return e[0]>0&&(o=Wn(e,o)),o}function el(r){if(r>=sn.length)for(let t=sn.length;t<=r;t++){let e=new Uint8Array([0]),n=sn[t-1].slice(0);for(let s=n.length-1;s>=0;s--){let o=new Uint8Array([(n[s]<<1)+e[0]]);e[0]=o[0]/10,n[s]=o[0]%10}e[0]>0&&(n=Wn(e,n)),sn.push(n)}return sn[r]}function x0(r,t){let e=0,n=new Uint8Array(r),s=new Uint8Array(t),o=n.slice(0),i=o.length-1,a=s.slice(0),c=a.length-1,l,u=0;for(let f=c;f>=0;f--,u++)switch(l=o[i-u]-a[c-u]-e,!0){case l<0:e=1,o[i-u]=l+10;break;default:e=0,o[i-u]=l}if(e>0)for(let f=i-c+1;f>=0;f--,u++)if(l=o[i-u]-e,l<0)e=1,o[i-u]=l+10;else{e=0,o[i-u]=l;break}return o.slice()}var cn=class extends ke(Lt){constructor({value:t,...e}={}){super(e),this._valueDec=0,e.valueHex&&this.setValueHex(),t!==void 0&&(this.valueDec=t)}setValueHex(){this.valueHexView.length>=4?(this.warnings.push("Too big Integer for decoding, hex only"),this.isHexOnly=!0,this._valueDec=0):(this.isHexOnly=!1,this.valueHexView.length>0&&(this._valueDec=Ei.call(this)))}set valueDec(t){this._valueDec=t,this.isHexOnly=!1,this.valueHexView=new Uint8Array(Jc(t))}get valueDec(){return this._valueDec}fromDER(t,e,n,s=0){let o=this.fromBER(t,e,n);if(o===-1)return o;let i=this.valueHexView;return i[0]===0&&i[1]&128?this.valueHexView=i.subarray(1):s!==0&&i.length<s&&(s-i.length>1&&(s=i.length+1),this.valueHexView=i.subarray(s-i.length)),o}toDER(t=!1){let e=this.valueHexView;switch(!0){case(e[0]&128)!==0:{let n=new Uint8Array(this.valueHexView.length+1);n[0]=0,n.set(e,1),this.valueHexView=n}break;case(e[0]===0&&(e[1]&128)===0):this.valueHexView=this.valueHexView.subarray(1);break}return this.toBER(t)}fromBER(t,e,n){let s=super.fromBER(t,e,n);return s===-1||this.setValueHex(),s}toBER(t){return t?new ArrayBuffer(this.valueHexView.length):this.valueHexView.slice().buffer}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}toString(){let t=this.valueHexView.length*8-1,e=new Uint8Array(this.valueHexView.length*8/3),n=0,s,o=this.valueHexView,i="",a=!1;for(let c=o.byteLength-1;c>=0;c--){s=o[c];for(let l=0;l<8;l++){if((s&1)===1)switch(n){case t:e=x0(el(n),e),i="-";break;default:e=b0(e,el(n))}n++,s>>=1}}for(let c=0;c<e.length;c++)e[c]&&(a=!0),a&&(i+=tl.charAt(e[c]));return a===!1&&(i+=tl.charAt(0)),i}};hl=cn;cn.NAME="IntegerValueBlock";Object.defineProperty(hl.prototype,"valueHex",{set:function(r){this.valueHexView=new Uint8Array(r),this.setValueHex()},get:function(){return this.valueHexView.slice().buffer}});var dl,pt=class r extends St{constructor(t={}){super(t,cn),this.idBlock.tagClass=1,this.idBlock.tagNumber=2}toBigInt(){return Yn(),BigInt(this.valueBlock.toString())}static fromBigInt(t){Yn();let e=BigInt(t),n=new on,s=e.toString(16).replace(/^-/,""),o=new Uint8Array(Y.Convert.FromHex(s));if(e<0){let a=new Uint8Array(o.length+(o[0]&128?1:0));a[0]|=128;let l=BigInt(`0x${Y.Convert.ToHex(a)}`)+e,u=Y.BufferSourceConverter.toUint8Array(Y.Convert.FromHex(l.toString(16)));u[0]|=128,n.write(u)}else o[0]&128&&n.write(new Uint8Array([0])),n.write(o);return new r({valueHex:n.final()})}convertToDER(){let t=new r({valueHex:this.valueBlock.valueHexView});return t.valueBlock.toDER(),t}convertFromDER(){return new r({valueHex:this.valueBlock.valueHexView[0]===0?this.valueBlock.valueHexView.subarray(1):this.valueBlock.valueHexView})}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()}`}};dl=pt;U.Integer=dl;pt.NAME="INTEGER";var pl,as=class extends pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=10}};pl=as;U.Enumerated=pl;as.NAME="ENUMERATED";var ln=class extends ke(Lt){constructor({valueDec:t=-1,isFirstSid:e=!1,...n}={}){super(n),this.valueDec=t,this.isFirstSid=e}fromBER(t,e,n){if(!n)return e;let s=Y.BufferSourceConverter.toUint8Array(t);if(!Se(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=sr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}set valueBigInt(t){Yn();let e=BigInt(t).toString(2);for(;e.length%7;)e="0"+e;let n=new Uint8Array(e.length/7);for(let s=0;s<n.length;s++)n[s]=parseInt(e.slice(s*7,s*7+7),2)+(s+1<n.length?128:0);this.fromBER(n.buffer,0,n.length)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=He(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",te;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n}toString(){let t="";if(this.isHexOnly)t=Y.Convert.ToHex(this.valueHexView);else if(this.isFirstSid){let e=this.valueDec;this.valueDec<=39?t="0.":this.valueDec<=79?(t="1.",e-=40):(t="2.",e-=80),t+=e.toString()}else t=this.valueDec.toString();return t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec,isFirstSid:this.isFirstSid}}};ln.NAME="sidBlock";var cs=class extends Lt{constructor({value:t=Ir,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new ln;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.value.length===0&&(o.isFirstSid=!0),this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t){let e=[];for(let n=0;n<this.value.length;n++){let s=this.value[n].toBER(t);if(s.byteLength===0)return this.error=this.value[n].error,te;e.push(s)}return vi(e)}fromString(t){this.value=[];let e=0,n=0,s="",o=!1;do if(n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1,o){let i=this.value[0],a=0;switch(i.valueDec){case 0:break;case 1:a=40;break;case 2:a=80;break;default:this.value=[];return}let c=parseInt(s,10);if(isNaN(c))return;i.valueDec=c+a,o=!1}else{let i=new ln;if(s>Number.MAX_SAFE_INTEGER){Yn();let a=BigInt(s);i.valueBigInt=a}else if(i.valueDec=parseInt(s,10),isNaN(i.valueDec))return;this.value.length||(i.isFirstSid=!0,o=!0),this.value.push(i)}while(n!==-1)}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e?(s=`{${s}}`,this.value[n].isFirstSid?t=`2.{${s} - 80}`:t+=s):t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};cs.NAME="ObjectIdentifierValueBlock";var gl,Qt=class extends St{constructor(t={}){super(t,cs),this.idBlock.tagClass=1,this.idBlock.tagNumber=6}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};gl=Qt;U.ObjectIdentifier=gl;Qt.NAME="OBJECT IDENTIFIER";var un=class extends ke(ve){constructor({valueDec:t=0,...e}={}){super(e),this.valueDec=t}fromBER(t,e,n){if(n===0)return e;let s=Y.BufferSourceConverter.toUint8Array(t);if(!Se(this,s,e,n))return-1;let o=s.subarray(e,e+n);this.valueHexView=new Uint8Array(n);for(let a=0;a<n&&(this.valueHexView[a]=o[a]&127,this.blockLength++,!!(o[a]&128));a++);let i=new Uint8Array(this.blockLength);for(let a=0;a<this.blockLength;a++)i[a]=this.valueHexView[a];return this.valueHexView=i,o[this.blockLength-1]&128?(this.error="End of input reached before message was fully decoded",-1):(this.valueHexView[0]===0&&this.warnings.push("Needlessly long format of SID encoding"),this.blockLength<=8?this.valueDec=sr(this.valueHexView,7):(this.isHexOnly=!0,this.warnings.push("Too big SID for decoding, hex only")),e+this.blockLength)}toBER(t){if(this.isHexOnly){if(t)return new ArrayBuffer(this.valueHexView.byteLength);let s=this.valueHexView,o=new Uint8Array(this.blockLength);for(let i=0;i<this.blockLength-1;i++)o[i]=s[i]|128;return o[this.blockLength-1]=s[this.blockLength-1],o.buffer}let e=He(this.valueDec,7);if(e.byteLength===0)return this.error="Error during encoding SID value",te;let n=new Uint8Array(e.byteLength);if(!t){let s=new Uint8Array(e),o=e.byteLength-1;for(let i=0;i<o;i++)n[i]=s[i]|128;n[o]=s[o]}return n.buffer}toString(){let t="";return this.isHexOnly?t=Y.Convert.ToHex(this.valueHexView):t=this.valueDec.toString(),t}toJSON(){return{...super.toJSON(),valueDec:this.valueDec}}};un.NAME="relativeSidBlock";var ls=class extends Lt{constructor({value:t=Ir,...e}={}){super(e),this.value=[],t&&this.fromString(t)}fromBER(t,e,n){let s=e;for(;n>0;){let o=new un;if(s=o.fromBER(t,s,n),s===-1)return this.blockLength=0,this.error=o.error,s;this.blockLength+=o.blockLength,n-=o.blockLength,this.value.push(o)}return s}toBER(t,e){let n=[];for(let s=0;s<this.value.length;s++){let o=this.value[s].toBER(t);if(o.byteLength===0)return this.error=this.value[s].error,te;n.push(o)}return vi(n)}fromString(t){this.value=[];let e=0,n=0,s="";do{n=t.indexOf(".",e),n===-1?s=t.substring(e):s=t.substring(e,n),e=n+1;let o=new un;if(o.valueDec=parseInt(s,10),isNaN(o.valueDec))return!0;this.value.push(o)}while(n!==-1);return!0}toString(){let t="",e=!1;for(let n=0;n<this.value.length;n++){e=this.value[n].isHexOnly;let s=this.value[n].toString();n!==0&&(t=`${t}.`),e&&(s=`{${s}}`),t+=s}return t}toJSON(){let t={...super.toJSON(),value:this.toString(),sidArray:[]};for(let e=0;e<this.value.length;e++)t.sidArray.push(this.value[e].toJSON());return t}};ls.NAME="RelativeObjectIdentifierValueBlock";var ml,us=class extends St{constructor(t={}){super(t,ls),this.idBlock.tagClass=1,this.idBlock.tagNumber=13}getValue(){return this.valueBlock.toString()}setValue(t){this.valueBlock.fromString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.valueBlock.toString()||"empty"}`}toJSON(){return{...super.toJSON(),value:this.getValue()}}};ml=us;U.RelativeObjectIdentifier=ml;us.NAME="RelativeObjectIdentifier";var yl,Et=class extends Me{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=16}};yl=Et;U.Sequence=yl;Et.NAME="SEQUENCE";var wl,fs=class extends Me{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=17}};wl=fs;U.Set=wl;fs.NAME="SET";var hs=class extends ke(Lt){constructor({...t}={}){super(t),this.isHexOnly=!0,this.value=Ir}toJSON(){return{...super.toJSON(),value:this.value}}};hs.NAME="StringValueBlock";var ds=class extends hs{};ds.NAME="SimpleStringValueBlock";var Pt=class extends Jn{constructor({...t}={}){super(t,ds)}fromBuffer(t){this.valueBlock.value=String.fromCharCode.apply(null,Y.BufferSourceConverter.toUint8Array(t))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e);for(let s=0;s<e;s++)n[s]=t.charCodeAt(s);this.valueBlock.value=t}};Pt.NAME="SIMPLE STRING";var ps=class extends Pt{fromBuffer(t){this.valueBlock.valueHexView=Y.BufferSourceConverter.toUint8Array(t);try{this.valueBlock.value=Y.Convert.ToUtf8String(t)}catch(e){this.warnings.push(`Error during "decodeURIComponent": ${e}, using raw string`),this.valueBlock.value=Y.Convert.ToBinary(t)}}fromString(t){this.valueBlock.valueHexView=new Uint8Array(Y.Convert.FromUtf8String(t)),this.valueBlock.value=t}};ps.NAME="Utf8StringValueBlock";var bl,Ae=class extends ps{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=12}};bl=Ae;U.Utf8String=bl;Ae.NAME="UTF8String";var gs=class extends Pt{fromBuffer(t){this.valueBlock.value=Y.Convert.ToUtf16String(t),this.valueBlock.valueHexView=Y.BufferSourceConverter.toUint8Array(t)}fromString(t){this.valueBlock.value=t,this.valueBlock.valueHexView=new Uint8Array(Y.Convert.FromUtf16String(t))}};gs.NAME="BmpStringValueBlock";var xl,ms=class extends gs{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=30}};xl=ms;U.BmpString=xl;ms.NAME="BMPString";var ys=class extends Pt{fromBuffer(t){let e=ArrayBuffer.isView(t)?t.slice().buffer:t.slice(0),n=new Uint8Array(e);for(let s=0;s<n.length;s+=4)n[s]=n[s+3],n[s+1]=n[s+2],n[s+2]=0,n[s+3]=0;this.valueBlock.value=String.fromCharCode.apply(null,new Uint32Array(e))}fromString(t){let e=t.length,n=this.valueBlock.valueHexView=new Uint8Array(e*4);for(let s=0;s<e;s++){let o=He(t.charCodeAt(s),8),i=new Uint8Array(o);if(i.length>4)continue;let a=4-i.length;for(let c=i.length-1;c>=0;c--)n[s*4+c+a]=i[c]}this.valueBlock.value=t}};ys.NAME="UniversalStringValueBlock";var El,ws=class extends ys{constructor({...t}={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=28}};El=ws;U.UniversalString=El;ws.NAME="UniversalString";var vl,bs=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=18}};vl=bs;U.NumericString=vl;bs.NAME="NumericString";var Bl,xs=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=19}};Bl=xs;U.PrintableString=Bl;xs.NAME="PrintableString";var Al,Es=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=20}};Al=Es;U.TeletexString=Al;Es.NAME="TeletexString";var Sl,vs=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=21}};Sl=vs;U.VideotexString=Sl;vs.NAME="VideotexString";var kl,Bs=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=22}};kl=Bs;U.IA5String=kl;Bs.NAME="IA5String";var Il,As=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=25}};Il=As;U.GraphicString=Il;As.NAME="GraphicString";var _l,fn=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=26}};_l=fn;U.VisibleString=_l;fn.NAME="VisibleString";var Nl,Ss=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=27}};Nl=Ss;U.GeneralString=Nl;Ss.NAME="GeneralString";var Rl,ks=class extends Pt{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=29}};Rl=ks;U.CharacterString=Rl;ks.NAME="CharacterString";var Tl,hn=class extends fn{constructor({value:t,valueDate:e,...n}={}){if(super(n),this.year=0,this.month=0,this.day=0,this.hour=0,this.minute=0,this.second=0,t){this.fromString(t),this.valueBlock.valueHexView=new Uint8Array(t.length);for(let s=0;s<t.length;s++)this.valueBlock.valueHexView[s]=t.charCodeAt(s)}e&&(this.fromDate(e),this.valueBlock.valueHexView=new Uint8Array(this.toBuffer())),this.idBlock.tagClass=1,this.idBlock.tagNumber=23}fromBuffer(t){this.fromString(String.fromCharCode.apply(null,Y.BufferSourceConverter.toUint8Array(t)))}toBuffer(){let t=this.toString(),e=new ArrayBuffer(t.length),n=new Uint8Array(e);for(let s=0;s<t.length;s++)n[s]=t.charCodeAt(s);return e}fromDate(t){this.year=t.getUTCFullYear(),this.month=t.getUTCMonth()+1,this.day=t.getUTCDate(),this.hour=t.getUTCHours(),this.minute=t.getUTCMinutes(),this.second=t.getUTCSeconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second))}fromString(t){let n=/(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})Z/ig.exec(t);if(n===null){this.error="Wrong input string for conversion";return}let s=parseInt(n[1],10);s>=50?this.year=1900+s:this.year=2e3+s,this.month=parseInt(n[2],10),this.day=parseInt(n[3],10),this.hour=parseInt(n[4],10),this.minute=parseInt(n[5],10),this.second=parseInt(n[6],10)}toString(t="iso"){if(t==="iso"){let e=new Array(7);return e[0]=Vt(this.year<2e3?this.year-1900:this.year-2e3,2),e[1]=Vt(this.month,2),e[2]=Vt(this.day,2),e[3]=Vt(this.hour,2),e[4]=Vt(this.minute,2),e[5]=Vt(this.second,2),e[6]="Z",e.join("")}return super.toString(t)}onAsciiEncoding(){return`${this.constructor.NAME} : ${this.toDate().toISOString()}`}toJSON(){return{...super.toJSON(),year:this.year,month:this.month,day:this.day,hour:this.hour,minute:this.minute,second:this.second}}};Tl=hn;U.UTCTime=Tl;hn.NAME="UTCTime";var Ll,Is=class extends hn{constructor(t={}){var e;super(t),(e=this.millisecond)!==null&&e!==void 0||(this.millisecond=0),this.idBlock.tagClass=1,this.idBlock.tagNumber=24}fromDate(t){super.fromDate(t),this.millisecond=t.getUTCMilliseconds()}toDate(){return new Date(Date.UTC(this.year,this.month-1,this.day,this.hour,this.minute,this.second,this.millisecond))}fromString(t){let e=!1,n="",s="",o=0,i,a=0,c=0;if(t[t.length-1]==="Z")n=t.substring(0,t.length-1),e=!0;else{let f=new Number(t[t.length-1]);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");n=t}if(e){if(n.indexOf("+")!==-1)throw new Error("Wrong input string for conversion");if(n.indexOf("-")!==-1)throw new Error("Wrong input string for conversion")}else{let f=1,p=n.indexOf("+"),y="";if(p===-1&&(p=n.indexOf("-"),f=-1),p!==-1){if(y=n.substring(p+1),n=n.substring(0,p),y.length!==2&&y.length!==4)throw new Error("Wrong input string for conversion");let g=parseInt(y.substring(0,2),10);if(isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");if(a=f*g,y.length===4){if(g=parseInt(y.substring(2,4),10),isNaN(g.valueOf()))throw new Error("Wrong input string for conversion");c=f*g}}}let l=n.indexOf(".");if(l===-1&&(l=n.indexOf(",")),l!==-1){let f=new Number(`0${n.substring(l)}`);if(isNaN(f.valueOf()))throw new Error("Wrong input string for conversion");o=f.valueOf(),s=n.substring(0,l)}else s=n;switch(!0){case s.length===8:if(i=/(\d{4})(\d{2})(\d{2})/ig,l!==-1)throw new Error("Wrong input string for conversion");break;case s.length===10:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let f=60*o;this.minute=Math.floor(f),f=60*(f-this.minute),this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===12:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let f=60*o;this.second=Math.floor(f),f=1e3*(f-this.second),this.millisecond=Math.floor(f)}break;case s.length===14:if(i=/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2})/ig,l!==-1){let f=1e3*o;this.millisecond=Math.floor(f)}break;default:throw new Error("Wrong input string for conversion")}let u=i.exec(s);if(u===null)throw new Error("Wrong input string for conversion");for(let f=1;f<u.length;f++)switch(f){case 1:this.year=parseInt(u[f],10);break;case 2:this.month=parseInt(u[f],10);break;case 3:this.day=parseInt(u[f],10);break;case 4:this.hour=parseInt(u[f],10)+a;break;case 5:this.minute=parseInt(u[f],10)+c;break;case 6:this.second=parseInt(u[f],10);break;default:throw new Error("Wrong input string for conversion")}if(e===!1){let f=new Date(this.year,this.month,this.day,this.hour,this.minute,this.second,this.millisecond);this.year=f.getUTCFullYear(),this.month=f.getUTCMonth(),this.day=f.getUTCDay(),this.hour=f.getUTCHours(),this.minute=f.getUTCMinutes(),this.second=f.getUTCSeconds(),this.millisecond=f.getUTCMilliseconds()}}toString(t="iso"){if(t==="iso"){let e=[];return e.push(Vt(this.year,4)),e.push(Vt(this.month,2)),e.push(Vt(this.day,2)),e.push(Vt(this.hour,2)),e.push(Vt(this.minute,2)),e.push(Vt(this.second,2)),this.millisecond!==0&&(e.push("."),e.push(Vt(this.millisecond,3))),e.push("Z"),e.join("")}return super.toString(t)}toJSON(){return{...super.toJSON(),millisecond:this.millisecond}}};Ll=Is;U.GeneralizedTime=Ll;Is.NAME="GeneralizedTime";var Cl,_s=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=31}};Cl=_s;U.DATE=Cl;_s.NAME="DATE";var Ul,Ns=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=32}};Ul=Ns;U.TimeOfDay=Ul;Ns.NAME="TimeOfDay";var Pl,Rs=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=33}};Pl=Rs;U.DateTime=Pl;Rs.NAME="DateTime";var Dl,Ts=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=34}};Dl=Ts;U.Duration=Dl;Ts.NAME="Duration";var Vl,Ls=class extends Ae{constructor(t={}){super(t),this.idBlock.tagClass=1,this.idBlock.tagNumber=14}};Vl=Ls;U.TIME=Vl;Ls.NAME="TIME";function v0(r){let{result:t}=_r(r),e=t.valueBlock.value;return{n:q(ce(e[1].toBigInt()),"base64url"),e:q(ce(e[2].toBigInt()),"base64url"),d:q(ce(e[3].toBigInt()),"base64url"),p:q(ce(e[4].toBigInt()),"base64url"),q:q(ce(e[5].toBigInt()),"base64url"),dp:q(ce(e[6].toBigInt()),"base64url"),dq:q(ce(e[7].toBigInt()),"base64url"),qi:q(ce(e[8].toBigInt()),"base64url"),kty:"RSA",alg:"RS256"}}function B0(r){if(r.n==null||r.e==null||r.d==null||r.p==null||r.q==null||r.dp==null||r.dq==null||r.qi==null)throw new M("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new Et({value:[new pt({value:0}),pt.fromBigInt(le(et(r.n,"base64url"))),pt.fromBigInt(le(et(r.e,"base64url"))),pt.fromBigInt(le(et(r.d,"base64url"))),pt.fromBigInt(le(et(r.p,"base64url"))),pt.fromBigInt(le(et(r.q,"base64url"))),pt.fromBigInt(le(et(r.dp,"base64url"))),pt.fromBigInt(le(et(r.dq,"base64url"))),pt.fromBigInt(le(et(r.qi,"base64url")))]}).toBER();return new Uint8Array(e,0,e.byteLength)}function A0(r){let{result:t}=_r(r),e=t.valueBlock.value[1].valueBlock.value[0].valueBlock.value;return{kty:"RSA",n:q(ce(e[0].toBigInt()),"base64url"),e:q(ce(e[1].toBigInt()),"base64url")}}function S0(r){if(r.n==null||r.e==null)throw new M("JWK was missing components","ERR_INVALID_PARAMETERS");let e=new Et({value:[new Et({value:[new Qt({value:"1.2.840.113549.1.1.1"}),new Ke]}),new kr({valueHex:new Et({value:[pt.fromBigInt(le(et(r.n,"base64url"))),pt.fromBigInt(le(et(r.e,"base64url")))]}).toBER()})]}).toBER();return new Uint8Array(e,0,e.byteLength)}function ce(r){let t=r.toString(16);t.length%2>0&&(t=`0${t}`);let e=t.length/2,n=new Uint8Array(e),s=0,o=0;for(;s<e;)n[s]=parseInt(t.slice(o,o+2),16),s+=1,o+=2;return n}function le(r){let t=[];return r.forEach(function(e){let n=e.toString(16);n.length%2>0&&(n=`0${n}`),t.push(n)}),BigInt("0x"+t.join(""))}var k0=16,Ai=32,Si=1e4;async function I0(r,t){let e=Ut.get(),s=new Et({value:[new pt({value:0}),new Et({value:[new Qt({value:"1.2.840.113549.1.1.1"}),new Ke]}),new Be({valueHex:r.marshal()})]}).toBER(),o=new Uint8Array(s,0,s.byteLength),i=nr(k0),a=await bi(wr,t,i,{c:Si,dkLen:Ai}),c=nr(16),l=await e.subtle.importKey("raw",a,"AES-CBC",!1,["encrypt"]),u=await e.subtle.encrypt({name:"AES-CBC",iv:c},l,o),f=new Et({value:[new Be({valueHex:i}),new pt({value:Si}),new pt({value:Ai}),new Et({value:[new Qt({value:"1.2.840.113549.2.11"}),new Ke]})]}),p=new Et({value:[new Qt({value:"1.2.840.113549.1.5.13"}),new Et({value:[new Et({value:[new Qt({value:"1.2.840.113549.1.5.12"}),f]}),new Et({value:[new Qt({value:"2.16.840.1.101.3.4.1.42"}),new Be({valueHex:c})]})]})]}),g=new Et({value:[p,new Be({valueHex:u})]}).toBER(),h=new Uint8Array(g,0,g.byteLength);return["-----BEGIN ENCRYPTED PRIVATE KEY-----",...q(h,"base64pad").split(/(.{64})/).filter(Boolean),"-----END ENCRYPTED PRIVATE KEY-----"].join(`
|
|
7
|
-
`)}async function _0(r,t){let e=Ut.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=et(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=_r(s),{iv:i,salt:a,iterations:c,keySize:l,cipherText:u}=N0(o),f=await bi(wr,t,a,{c,dkLen:l}),p=await e.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),y=dn(await e.subtle.decrypt({name:"AES-CBC",iv:i},p,u)),{result:g}=_r(y);n=Ol(g)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=et(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=_r(s);n=Ol(o)}else throw new M("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return ki(n)}function N0(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new M("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new M("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=dn(o.valueBlock.value[0].getValue()),a=Si,c=Ai;if(o.valueBlock.value.length===3)a=Number(o.valueBlock.value[1].toBigInt()),c=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new M("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let l=t.valueBlock.value[1].valueBlock.value[1],u=l.valueBlock.value[0].toString();if(u!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(u!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new M("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let f=dn(l.valueBlock.value[1].getValue());return{cipherText:dn(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function Ol(r){return dn(r.valueBlock.value[2].getValue())}function dn(r){return new Uint8Array(r,0,r.byteLength)}async function Hl(r){let t=await Ut.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Fl(t);return{privateKey:e[0],publicKey:e[1]}}async function Ii(r){let e=[await Ut.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await R0(r)],n=await Fl({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ml(r,t){let e=await Ut.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ut.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Kl(r,t,e){let n=await Ut.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ut.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Fl(r){if(r.privateKey==null||r.publicKey==null)throw new M("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Ut.get().subtle.exportKey("jwk",r.privateKey),Ut.get().subtle.exportKey("jwk",r.publicKey)])}async function R0(r){return Ut.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function Us(r){if(r.kty!=="RSA")throw new M("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new M("invalid key modulus","ERR_INVALID_KEY_MODULUS");return et(r.n,"base64url").length*8}var gn=8192,pn=class{_key;constructor(t){this._key=t}verify(t,e){return Kl(this._key,e,t)}marshal(){return Fe.jwkToPkix(this._key)}get bytes(){return oe.encode({Type:at.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Kt(t)?t.then(({bytes:e})=>e):t.bytes}},Nr=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return nr(16)}sign(t){return Ml(this._key,t)}get public(){if(this._publicKey==null)throw new M("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new pn(this._publicKey)}marshal(){return Fe.jwkToPkcs1(this._key)}get bytes(){return ie.encode({Type:at.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Kt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return q(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Fe.exportToPem(this,t);if(e==="libp2p-key")return vr(this.bytes,t);throw new M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function ki(r){let t=Fe.pkcs1ToJwk(r);if(Us(t)>gn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Ii(t);return new Nr(e.privateKey,e.publicKey)}function L0(r){let t=Fe.pkixToJwk(r);if(Us(t)>gn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new pn(t)}async function C0(r){if(Us(r)>gn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Ii(r);return new Nr(t.privateKey,t.publicKey)}async function U0(r){if(r>gn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Hl(r);return new Nr(t.privateKey,t.publicKey)}var Ci={};mt(Ci,{Secp256k1PrivateKey:()=>yn,Secp256k1PublicKey:()=>mn,generateKeyPair:()=>z0,unmarshalSecp256k1PrivateKey:()=>G0,unmarshalSecp256k1PublicKey:()=>j0});var P0=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),$e=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),qe=new Uint32Array(64),Ni=class extends yr{constructor(){super(64,32,8,!1),this.A=$e[0]|0,this.B=$e[1]|0,this.C=$e[2]|0,this.D=$e[3]|0,this.E=$e[4]|0,this.F=$e[5]|0,this.G=$e[6]|0,this.H=$e[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)qe[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let p=qe[f-15],y=qe[f-2],g=zt(p,7)^zt(p,18)^p>>>3,h=zt(y,17)^zt(y,19)^y>>>10;qe[f]=h+qe[f-7]+g+qe[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:l,H:u}=this;for(let f=0;f<64;f++){let p=zt(a,6)^zt(a,11)^zt(a,25),y=u+p+mc(a,c,l)+P0[f]+qe[f]|0,h=(zt(n,2)^zt(n,13)^zt(n,22))+yc(n,s,o)|0;u=l,l=c,c=a,a=i+y|0,i=o,o=s,s=n,n=y+h|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,u=u+this.H|0,this.set(n,s,o,i,a,c,l,u)}roundClean(){qe.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Rr=Tn(()=>new Ni);function D0(r){let t=Zr(r);Ft(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:V0,hexToBytes:O0}=Un,or={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=or;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:V0(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=or,e=typeof r=="string"?O0(r):r;br(e);let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l:o}=or._parseInt(e.subarray(2)),{d:i,l:a}=or._parseInt(o);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:s,s:i}},hexFromSig(r){let t=l=>Number.parseInt(l[0],16)&8?"00"+l:l,e=l=>{let u=l.toString(16);return u.length&1?`0${u}`:u},n=t(e(r.s)),s=t(e(r.r)),o=n.length/2,i=s.length/2,a=e(o),c=e(i);return`30${e(i+o+4)}02${c}${s}02${a}${n}`}},Ie=BigInt(0),qt=BigInt(1),Rw=BigInt(2),$l=BigInt(3),Tw=BigInt(4);function H0(r){let t=D0(r),{Fp:e}=t,n=t.toBytes||((g,h,d)=>{let b=h.toAffine();return we(Uint8Array.from([4]),e.toBytes(b.x),e.toBytes(b.y))}),s=t.fromBytes||(g=>{let h=g.subarray(1),d=e.fromBytes(h.subarray(0,e.BYTES)),b=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:d,y:b}});function o(g){let{a:h,b:d}=t,b=e.sqr(g),v=e.mul(b,g);return e.add(e.add(v,e.mul(g,h)),d)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function i(g){return typeof g=="bigint"&&Ie<g&&g<t.n}function a(g){if(!i(g))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(g){let{allowedPrivateKeyLengths:h,nByteLength:d,wrapPrivateKey:b,n:v}=t;if(h&&typeof g!="bigint"){if(Pe(g)&&(g=ge(g)),typeof g!="string"||!h.includes(g.length))throw new Error("Invalid key");g=g.padStart(d*2,"0")}let w;try{w=typeof g=="bigint"?g:me(st("private key",g,d))}catch{throw new Error(`private key must be ${d} bytes, hex or bigint, not ${typeof g}`)}return b&&(w=Z(w,v)),a(w),w}let l=new Map;function u(g){if(!(g instanceof f))throw new Error("ProjectivePoint expected")}class f{constructor(h,d,b){if(this.px=h,this.py=d,this.pz=b,h==null||!e.isValid(h))throw new Error("x required");if(d==null||!e.isValid(d))throw new Error("y required");if(b==null||!e.isValid(b))throw new Error("z required")}static fromAffine(h){let{x:d,y:b}=h||{};if(!h||!e.isValid(d)||!e.isValid(b))throw new Error("invalid affine point");if(h instanceof f)throw new Error("projective point not allowed");let v=w=>e.eql(w,e.ZERO);return v(d)&&v(b)?f.ZERO:new f(d,b,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let d=e.invertBatch(h.map(b=>b.pz));return h.map((b,v)=>b.toAffine(d[v])).map(f.fromAffine)}static fromHex(h){let d=f.fromAffine(s(st("pointHex",h)));return d.assertValidity(),d}static fromPrivateKey(h){return f.BASE.multiply(c(h))}_setWindowSize(h){this._WINDOW_SIZE=h,l.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:h,y:d}=this.toAffine();if(!e.isValid(h)||!e.isValid(d))throw new Error("bad point: x or y not FE");let b=e.sqr(d),v=o(h);if(!e.eql(b,v))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){u(h);let{px:d,py:b,pz:v}=this,{px:w,py:A,pz:B}=h,S=e.eql(e.mul(d,B),e.mul(w,v)),N=e.eql(e.mul(b,B),e.mul(A,v));return S&&N}negate(){return new f(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:d}=t,b=e.mul(d,$l),{px:v,py:w,pz:A}=this,B=e.ZERO,S=e.ZERO,N=e.ZERO,_=e.mul(v,v),V=e.mul(w,w),P=e.mul(A,A),T=e.mul(v,w);return T=e.add(T,T),N=e.mul(v,A),N=e.add(N,N),B=e.mul(h,N),S=e.mul(b,P),S=e.add(B,S),B=e.sub(V,S),S=e.add(V,S),S=e.mul(B,S),B=e.mul(T,B),N=e.mul(b,N),P=e.mul(h,P),T=e.sub(_,P),T=e.mul(h,T),T=e.add(T,N),N=e.add(_,_),_=e.add(N,_),_=e.add(_,P),_=e.mul(_,T),S=e.add(S,_),P=e.mul(w,A),P=e.add(P,P),_=e.mul(P,T),B=e.sub(B,_),N=e.mul(P,V),N=e.add(N,N),N=e.add(N,N),new f(B,S,N)}add(h){u(h);let{px:d,py:b,pz:v}=this,{px:w,py:A,pz:B}=h,S=e.ZERO,N=e.ZERO,_=e.ZERO,V=t.a,P=e.mul(t.b,$l),T=e.mul(d,w),H=e.mul(b,A),O=e.mul(v,B),W=e.add(d,b),x=e.add(w,A);W=e.mul(W,x),x=e.add(T,H),W=e.sub(W,x),x=e.add(d,v);let I=e.add(w,B);return x=e.mul(x,I),I=e.add(T,O),x=e.sub(x,I),I=e.add(b,v),S=e.add(A,B),I=e.mul(I,S),S=e.add(H,O),I=e.sub(I,S),_=e.mul(V,x),S=e.mul(P,O),_=e.add(S,_),S=e.sub(H,_),_=e.add(H,_),N=e.mul(S,_),H=e.add(T,T),H=e.add(H,T),O=e.mul(V,O),x=e.mul(P,x),H=e.add(H,O),O=e.sub(T,O),O=e.mul(V,O),x=e.add(x,O),T=e.mul(H,x),N=e.add(N,T),T=e.mul(I,x),S=e.mul(W,S),S=e.sub(S,T),T=e.mul(W,H),_=e.mul(I,_),_=e.add(_,T),new f(S,N,_)}subtract(h){return this.add(h.negate())}is0(){return this.equals(f.ZERO)}wNAF(h){return y.wNAFCached(this,l,h,d=>{let b=e.invertBatch(d.map(v=>v.pz));return d.map((v,w)=>v.toAffine(b[w])).map(f.fromAffine)})}multiplyUnsafe(h){let d=f.ZERO;if(h===Ie)return d;if(a(h),h===qt)return this;let{endo:b}=t;if(!b)return y.unsafeLadder(this,h);let{k1neg:v,k1:w,k2neg:A,k2:B}=b.splitScalar(h),S=d,N=d,_=this;for(;w>Ie||B>Ie;)w&qt&&(S=S.add(_)),B&qt&&(N=N.add(_)),_=_.double(),w>>=qt,B>>=qt;return v&&(S=S.negate()),A&&(N=N.negate()),N=new f(e.mul(N.px,b.beta),N.py,N.pz),S.add(N)}multiply(h){a(h);let d=h,b,v,{endo:w}=t;if(w){let{k1neg:A,k1:B,k2neg:S,k2:N}=w.splitScalar(d),{p:_,f:V}=this.wNAF(B),{p:P,f:T}=this.wNAF(N);_=y.constTimeNegate(A,_),P=y.constTimeNegate(S,P),P=new f(e.mul(P.px,w.beta),P.py,P.pz),b=_.add(P),v=V.add(T)}else{let{p:A,f:B}=this.wNAF(d);b=A,v=B}return f.normalizeZ([b,v])[0]}multiplyAndAddUnsafe(h,d,b){let v=f.BASE,w=(B,S)=>S===Ie||S===qt||!B.equals(v)?B.multiplyUnsafe(S):B.multiply(S),A=w(this,d).add(w(h,b));return A.is0()?void 0:A}toAffine(h){let{px:d,py:b,pz:v}=this,w=this.is0();h==null&&(h=w?e.ONE:e.inv(v));let A=e.mul(d,h),B=e.mul(b,h),S=e.mul(v,h);if(w)return{x:e.ZERO,y:e.ZERO};if(!e.eql(S,e.ONE))throw new Error("invZ was invalid");return{x:A,y:B}}isTorsionFree(){let{h,isTorsionFree:d}=t;if(h===qt)return!0;if(d)return d(f,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:d}=t;return h===qt?this:d?d(f,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return this.assertValidity(),n(f,this,h)}toHex(h=!0){return ge(this.toRawBytes(h))}}f.BASE=new f(t.Gx,t.Gy,e.ONE),f.ZERO=new f(e.ZERO,e.ONE,e.ZERO);let p=t.nBitLength,y=Vn(f,t.endo?Math.ceil(p/2):p);return{CURVE:t,ProjectivePoint:f,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:i}}function M0(r){let t=Zr(r);return Ft(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function ql(r){let t=M0(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(x){return Ie<x&&x<e.ORDER}function a(x){return Z(x,n)}function c(x){return Pn(x,n)}let{ProjectivePoint:l,normPrivateKeyToScalar:u,weierstrassEquation:f,isWithinCurveOrder:p}=H0({...t,toBytes(x,I,C){let E=I.toAffine(),m=e.toBytes(E.x),k=we;return C?k(Uint8Array.from([I.hasEvenY()?2:3]),m):k(Uint8Array.from([4]),m,e.toBytes(E.y))},fromBytes(x){let I=x.length,C=x[0],E=x.subarray(1);if(I===s&&(C===2||C===3)){let m=me(E);if(!i(m))throw new Error("Point is not on curve");let k=f(m),R;try{R=e.sqrt(k)}catch(F){let j=F instanceof Error?": "+F.message:"";throw new Error("Point is not on curve"+j)}let L=(R&qt)===qt;return(C&1)===1!==L&&(R=e.neg(R)),{x:m,y:R}}else if(I===o&&C===4){let m=e.fromBytes(E.subarray(0,e.BYTES)),k=e.fromBytes(E.subarray(e.BYTES,2*e.BYTES));return{x:m,y:k}}else throw new Error(`Point of length ${I} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),y=x=>ge(De(x,t.nByteLength));function g(x){let I=n>>qt;return x>I}function h(x){return g(x)?a(-x):x}let d=(x,I,C)=>me(x.slice(I,C));class b{constructor(I,C,E){this.r=I,this.s=C,this.recovery=E,this.assertValidity()}static fromCompact(I){let C=t.nByteLength;return I=st("compactSignature",I,C*2),new b(d(I,0,C),d(I,C,2*C))}static fromDER(I){let{r:C,s:E}=or.toSig(st("DER",I));return new b(C,E)}assertValidity(){if(!p(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!p(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(I){return new b(this.r,this.s,I)}recoverPublicKey(I){let{r:C,s:E,recovery:m}=this,k=N(st("msgHash",I));if(m==null||![0,1,2,3].includes(m))throw new Error("recovery id invalid");let R=m===2||m===3?C+t.n:C;if(R>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let L=m&1?"03":"02",K=l.fromHex(L+y(R)),F=c(R),j=a(-k*F),$=a(E*F),G=l.BASE.multiplyAndAddUnsafe(K,j,$);if(!G)throw new Error("point at infinify");return G.assertValidity(),G}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new b(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Ye(this.toDERHex())}toDERHex(){return or.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ye(this.toCompactHex())}toCompactHex(){return y(this.r)+y(this.s)}}let v={isValidPrivateKey(x){try{return u(x),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let x=zo(t.n);return _c(t.randomBytes(x),t.n)},precompute(x=8,I=l.BASE){return I._setWindowSize(x),I.multiply(BigInt(3)),I}};function w(x,I=!0){return l.fromPrivateKey(x).toRawBytes(I)}function A(x){let I=Pe(x),C=typeof x=="string",E=(I||C)&&x.length;return I?E===s||E===o:C?E===2*s||E===2*o:x instanceof l}function B(x,I,C=!0){if(A(x))throw new Error("first arg must be private key");if(!A(I))throw new Error("second arg must be public key");return l.fromHex(I).multiply(u(x)).toRawBytes(C)}let S=t.bits2int||function(x){let I=me(x),C=x.length*8-t.nBitLength;return C>0?I>>BigInt(C):I},N=t.bits2int_modN||function(x){return a(S(x))},_=Yr(t.nBitLength);function V(x){if(typeof x!="bigint")throw new Error("bigint expected");if(!(Ie<=x&&x<_))throw new Error(`bigint expected < 2^${t.nBitLength}`);return De(x,t.nByteLength)}function P(x,I,C=T){if(["recovered","canonical"].some(tt=>tt in C))throw new Error("sign() legacy options not supported");let{hash:E,randomBytes:m}=t,{lowS:k,prehash:R,extraEntropy:L}=C;k==null&&(k=!0),x=st("msgHash",x),R&&(x=st("prehashed msgHash",E(x)));let K=N(x),F=u(I),j=[V(F),V(K)];if(L!=null&&L!==!1){let tt=L===!0?m(e.BYTES):L;j.push(st("extraEntropy",tt))}let $=we(...j),G=K;function nt(tt){let vt=S(tt);if(!p(vt))return;let Bt=c(vt),gt=l.BASE.multiply(vt).toAffine(),Nt=a(gt.x);if(Nt===Ie)return;let fe=a(Bt*a(G+Nt*F));if(fe===Ie)return;let Ge=(gt.x===Nt?0:2)|Number(gt.y&qt),qr=fe;return k&&g(fe)&&(qr=h(fe),Ge^=1),new b(Nt,qr,Ge)}return{seed:$,k2sig:nt}}let T={lowS:t.lowS,prehash:!1},H={lowS:t.lowS,prehash:!1};function O(x,I,C=T){let{seed:E,k2sig:m}=P(x,I,C),k=t;return Fo(k.hash.outputLen,k.nByteLength,k.hmac)(E,m)}l.BASE._setWindowSize(8);function W(x,I,C,E=H){let m=x;if(I=st("msgHash",I),C=st("publicKey",C),"strict"in E)throw new Error("options.strict was renamed to lowS");let{lowS:k,prehash:R}=E,L,K;try{if(typeof m=="string"||Pe(m))try{L=b.fromDER(m)}catch(gt){if(!(gt instanceof or.Err))throw gt;L=b.fromCompact(m)}else if(typeof m=="object"&&typeof m.r=="bigint"&&typeof m.s=="bigint"){let{r:gt,s:Nt}=m;L=new b(gt,Nt)}else throw new Error("PARSE");K=l.fromHex(C)}catch(gt){if(gt.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(k&&L.hasHighS())return!1;R&&(I=t.hash(I));let{r:F,s:j}=L,$=N(I),G=c(j),nt=a($*G),tt=a(F*G),vt=l.BASE.multiplyAndAddUnsafe(K,nt,tt)?.toAffine();return vt?a(vt.x)===F:!1}return{CURVE:t,getPublicKey:w,getSharedSecret:B,sign:O,verify:W,ProjectivePoint:l,Signature:b,utils:v}}function K0(r){return{hash:r,hmac:(t,...e)=>Oe(r,t,Rn(...e)),randomBytes:We}}function Gl(r,t){let e=n=>ql({...r,...K0(n)});return Object.freeze({...e(t),create:e})}var Wl=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),jl=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),F0=BigInt(1),Ri=BigInt(2),zl=(r,t)=>(r+t/Ri)/t;function $0(r){let t=Wl,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%t,u=l*l*r%t,f=ot(u,e,t)*u%t,p=ot(f,e,t)*u%t,y=ot(p,Ri,t)*l%t,g=ot(y,s,t)*y%t,h=ot(g,o,t)*g%t,d=ot(h,a,t)*h%t,b=ot(d,c,t)*d%t,v=ot(b,a,t)*h%t,w=ot(v,e,t)*u%t,A=ot(w,i,t)*g%t,B=ot(A,n,t)*l%t,S=ot(B,Ri,t);if(!Ti.eql(Ti.sqr(S),r))throw new Error("Cannot find square root");return S}var Ti=Dn(Wl,void 0,void 0,{sqrt:$0}),ee=Gl({a:BigInt(0),b:BigInt(7),Fp:Ti,n:jl,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=jl,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-F0*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=zl(o*r,t),c=zl(-n*r,t),l=Z(r-a*e-c*s,t),u=Z(-a*n-c*o,t),f=l>i,p=u>i;if(f&&(l=t-l),p&&(u=t-u),l>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:l,k2neg:p,k2:u}}}},Rr),Mw=BigInt(0);var Kw=ee.ProjectivePoint;function Yl(){return ee.utils.randomPrivateKey()}function Zl(r,t){let e=At.digest(t instanceof Uint8Array?t:t.subarray());if(Kt(e))return e.then(({digest:n})=>ee.sign(n,r).toDERRawBytes()).catch(n=>{throw new M(String(n),"ERR_INVALID_INPUT")});try{return ee.sign(e.digest,r).toDERRawBytes()}catch(n){throw new M(String(n),"ERR_INVALID_INPUT")}}function Xl(r,t,e){let n=At.digest(e instanceof Uint8Array?e:e.subarray());if(Kt(n))return n.then(({digest:s})=>ee.verify(t,s,r)).catch(s=>{throw new M(String(s),"ERR_INVALID_INPUT")});try{return ee.verify(t,n.digest,r)}catch(s){throw new M(String(s),"ERR_INVALID_INPUT")}}function Jl(r){return ee.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ql(r){try{ee.getPublicKey(r,!0)}catch(t){throw new M(String(t),"ERR_INVALID_PRIVATE_KEY")}}function Li(r){try{ee.ProjectivePoint.fromHex(r)}catch(t){throw new M(String(t),"ERR_INVALID_PUBLIC_KEY")}}function tu(r){try{return ee.getPublicKey(r,!0)}catch(t){throw new M(String(t),"ERR_INVALID_PRIVATE_KEY")}}var mn=class{_key;constructor(t){Li(t),this._key=t}verify(t,e){return Xl(this._key,e,t)}marshal(){return Jl(this._key)}get bytes(){return oe.encode({Type:at.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return Kt(t)?{bytes:e}=await t:e=t.bytes,e}},yn=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??tu(t),Ql(this._key),Li(this._publicKey)}sign(t){return Zl(this._key,t)}get public(){return new mn(this._publicKey)}marshal(){return this._key}get bytes(){return ie.encode({Type:at.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Kt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return q(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return vr(this.bytes,t);throw new M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function G0(r){return new yn(r)}function j0(r){return new mn(r)}async function z0(){let r=Yl();return new yn(r)}var ir={rsa:_i,ed25519:wi,secp256k1:Ci};function eu(r){let t=Object.keys(ir).join(" / ");return new M(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function ru(r){let t=oe.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return ir.rsa.unmarshalRsaPublicKey(e);case at.Ed25519:return ir.ed25519.unmarshalEd25519PublicKey(e);case at.Secp256k1:return ir.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw eu(t.Type??"unknown")}}async function Ui(r){let t=ie.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return ir.rsa.unmarshalRsaPrivateKey(e);case at.Ed25519:return ir.ed25519.unmarshalEd25519PrivateKey(e);case at.Secp256k1:return ir.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw eu(t.Type??"RSA")}}var W0=Symbol.for("nodejs.util.inspect.custom"),nu=Object.values(ne).map(r=>r.decoder).reduce((r,t)=>r.or(t),ne.identity.decoder),su=114,Pi=36,Di=37,wn=class{type;multihash;privateKey;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,this.privateKey=t.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Ga]=!0;toString(){return this.string==null&&(this.string=ut.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return jt.createV1(su,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return ft(this.multihash.bytes,t);if(typeof t=="string")return Vi(t).equals(this);if(t?.multihash?.bytes!=null)return ft(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[W0](){return`PeerId(${this.toString()})`}},Tr=class extends wn{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Lr=class extends wn{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},Cr=class extends wn{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function Vi(r,t){if(t=t??nu,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Re(ut.decode(`z${r}`));return r.startsWith("12D")?new Lr({multihash:e}):r.startsWith("16U")?new Cr({multihash:e}):new Tr({multihash:e})}return Y0(nu.decode(r))}function Y0(r){try{let t=Re(r);if(t.code===Te.code){if(t.digest.length===Pi)return new Lr({multihash:t});if(t.digest.length===Di)return new Cr({multihash:t})}if(t.code===At.code)return new Tr({multihash:t})}catch{return Z0(jt.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function Z0(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==su)throw new Error("Supplied PeerID CID is invalid");let t=r.multihash;if(t.code===At.code)return new Tr({multihash:r.multihash});if(t.code===Te.code){if(t.digest.length===Pi)return new Lr({multihash:r.multihash});if(t.digest.length===Di)return new Cr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function Oi(r,t){return r.length===Pi?new Lr({multihash:Gt(Te.code,r),privateKey:t}):r.length===Di?new Cr({multihash:Gt(Te.code,r),privateKey:t}):new Tr({multihash:await At.digest(r),publicKey:r,privateKey:t})}var iu=Symbol.for("@achingbrain/uint8arraylist");function ou(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function Ps(r){return!!r?.[iu]}var ct=class r{bufs;length;[iu]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(Ps(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(Ps(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=ou(this.bufs,t);return e.buf[e.index]}set(t,e){let n=ou(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(Ps(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return xt(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:xt(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let l=t>=a&&t<c,u=e>a&&e<=c;if(l&&u){if(t===a&&e===c){n.push(i);break}let f=t-a;n.push(i.subarray(f,f+(e-t)));break}if(l){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(u){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!Ps(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let f=0;f<o;f++)i[f]=-1;for(let f=0;f<s;f++)i[n[f]]=f;let a=i,c=this.byteLength-n.byteLength,l=n.byteLength-1,u;for(let f=e;f<=c;f+=u){u=0;for(let p=l;p>=0;p--){let y=this.get(f+p);if(n[p]!==y){u=Math.max(1,p-a[y]);break}}if(u===0)return f}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=wt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=yt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=yt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=yt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=wt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=yt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=yt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=yt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=yt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=yt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!ft(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};function Ds(r){return r[Symbol.asyncIterator]!=null}var Vs=r=>{let t=dt(r),e=wt(t);return se(r,e),Vs.bytes=t,e};Vs.bytes=0;function au(r,t){t=t??{};let e=t.lengthEncoder??Vs;function*n(s){let o=e(s.byteLength);o instanceof Uint8Array?yield o:yield*o,s instanceof Uint8Array?yield s:yield*s}return Ds(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}au.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Vs;return new ct(e(r.byteLength),r)};var Ur=qa(uu(),1);var J0=8,Q0=1024*1024*4,ar;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(ar||(ar={}));var Hi=r=>{let t=Xt(r);return Hi.bytes=dt(t),t};Hi.bytes=0;function bn(r,t){let e=new ct,n=ar.LENGTH,s=-1,o=t?.lengthDecoder??Hi,i=t?.maxLengthLength??J0,a=t?.maxDataLength??Q0;function*c(){for(;e.byteLength>0;){if(n===ar.LENGTH)try{if(s=o(e),s<0)throw(0,Ur.default)(new Error("invalid message length"),"ERR_INVALID_MSG_LENGTH");if(s>a)throw(0,Ur.default)(new Error("message length too long"),"ERR_MSG_DATA_TOO_LONG");let l=o.bytes;e.consume(l),t?.onLength!=null&&t.onLength(s),n=ar.DATA}catch(l){if(l instanceof RangeError){if(e.byteLength>i)throw(0,Ur.default)(new Error("message length length too long"),"ERR_MSG_LENGTH_TOO_LONG");break}throw l}if(n===ar.DATA){if(e.byteLength<s)break;let l=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(l),yield l,n=ar.LENGTH}}}return Ds(r)?async function*(){for await(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw(0,Ur.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}():function*(){for(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw(0,Ur.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}()}bn.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:o,value:i}=await r.next(e);if(o===!0)return;i!=null&&(yield i)}catch(o){if(o.code==="ERR_UNDER_READ")return{done:!0,value:null};throw o}finally{e=1}}();return bn(n,{...t??{},onLength:o=>{e=o}})};function Ct(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Os=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=e??"ABORT_ERR"}};async function Dt(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new Os(e?.errorMessage,e?.errorCode));let n,s=new Os(e?.errorMessage,e?.errorCode);try{return await Promise.race([r,new Promise((o,i)=>{n=()=>{i(s)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var Mi=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=Ct(),this.haveNext=Ct()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let t=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=Ct(),t}async throw(t){return this.ended=!0,t!=null&&this.haveNext.reject(t),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return await this._push(void 0),t}async push(t,e){await this._push(t,e)}async end(t,e){t!=null?await this.throw(t):await this._push(void 0,e)}async _push(t,e){if(t!=null&&this.ended)throw new Error("Cannot push value onto an ended pushable");if(this.nextResult!=null&&(await this.readNext.promise,this.nextResult!=null))throw new Error("NeedNext promise resolved but nextResult was not consumed");t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Ct(),await Dt(this.readNext.promise,e?.signal,e)}};function fu(){return new Mi}var Hs=class extends Error{code;constructor(t,e){super(t),this.code=e}},Ki=class extends Hs{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted"}};function hu(r,t){let e=fu();r.sink(e).catch(async i=>{await e.end(i)}),r.sink=async i=>{for await(let a of i)await e.push(a);await e.end()};let n=r.source;r.source[Symbol.iterator]!=null?n=r.source[Symbol.iterator]():r.source[Symbol.asyncIterator]!=null&&(n=r.source[Symbol.asyncIterator]());let s=new ct;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,l=new Promise((u,f)=>{c=()=>{f(new Ki("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:f,value:p}=await Promise.race([n.next(),l]);return f===!0?new ct:p}for(;s.byteLength<i;){let{value:f,done:p}=await Promise.race([n.next(),l]);if(p===!0)throw new Hs("unexpected end of input","ERR_UNEXPECTED_EOF");s.append(f)}let u=s.sublist(0,i);return s.consume(i),u}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await e.push(i,a):await e.push(i.subarray(),a)},unwrap:()=>{if(s.byteLength>0){let i=r.source;r.source=async function*(){t?.yieldBytes===!1?yield s:yield*s,yield*i}()}return r}}}var Ms=class extends Error{code;constructor(t,e){super(t),this.code=e}};function Fi(r,t={}){let e=hu(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=dt(t.maxDataLength));let n=t?.lengthDecoder??Xt,s=t?.lengthEncoder??se;return{read:async i=>{let a=-1,c=new ct;for(;;){c.append(await e.read(1,i));try{a=n(c)}catch(l){if(l instanceof RangeError)continue;throw l}if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Ms("message length length too long","ERR_MSG_LENGTH_TOO_LONG");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Ms("message length too long","ERR_MSG_DATA_TOO_LONG");return e.read(a,i)},write:async(i,a)=>{await e.write(new ct(s(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new ct(...i.flatMap(l=>[s(l.byteLength),l]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function $i(){let r=Ct(),t=!1;return{sink:async e=>{if(t)throw new Error("already piped");t=!0,r.resolve(e)},source:async function*(){yield*await r.promise}()}}function du(){let r=$i(),t=$i();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var Ks=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},Pr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Ks(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new Ks(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var qi=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Dr(r={}){return tp(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function tp(r,t){t=t??{};let e=t.onEnd,n=new Pr,s,o,i,a=Ct(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((d,b)=>{o=v=>{o=null,n.push(v);try{d(r(n))}catch(w){b(w)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ct()})}},l=d=>o!=null?o(d):(n.push(d),s),u=d=>(n=new Pr,o!=null?o({error:d}):(n.push({error:d}),s)),f=d=>{if(i)return s;if(t?.objectMode!==!0&&d?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:d})},p=d=>i?s:(i=!0,d!=null?u(d):l({done:!0})),y=()=>(n=new Pr,p(),{done:!0}),g=d=>(p(d),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:y,throw:g,push:f,end:p,get readableLength(){return n.size},onEmpty:async d=>{let b=d?.signal;if(b?.throwIfAborted(),n.isEmpty())return;let v,w;b!=null&&(v=new Promise((A,B)=>{w=()=>{B(new qi)},b.addEventListener("abort",w)}));try{await Promise.race([a.promise,v])}finally{w!=null&&b!=null&&b?.removeEventListener("abort",w)}}},e==null)return s;let h=s;return s={[Symbol.asyncIterator](){return this},next(){return h.next()},throw(d){return h.throw(d),e!=null&&(e(d),e=void 0),{done:!0}},return(){return h.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(d){return h.end(d),e!=null&&(e(d),e=void 0),s},get readableLength(){return h.readableLength},onEmpty:d=>h.onEmpty(d)},s}function ep(r){return r[Symbol.asyncIterator]!=null}function rp(...r){let t=[];for(let e of r)ep(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Dr({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let s of n)e.push(s)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var pu=rp;function gu(r,...t){if(r==null)throw new Error("Empty pipeline");if(Gi(r)){let n=r;r=()=>n.source}else if(yu(r)||mu(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Gi(e[e.length-1])&&(e[e.length-1]=e[e.length-1].sink),e.length>2)for(let n=1;n<e.length-1;n++)Gi(e[n])&&(e[n]=sp(e[n]));return np(...e)}var np=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},mu=r=>r?.[Symbol.asyncIterator]!=null,yu=r=>r?.[Symbol.iterator]!=null,Gi=r=>r==null?!1:r.sink!=null&&r.source!=null,sp=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Dr({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(mu(o))s=async function*(){yield*o,n.end()};else if(yu(o))s=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return pu(n,s())}return r.source};var Vr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;var _e=r=>new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4));function wu(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var bu=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),op=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!op)throw new Error("Non little-endian hardware is not supported");function Fs(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function $s(r){if(typeof r=="string")r=Fs(r);else if(wu(r))r=r.slice();else throw new Error(`expected Uint8Array, got ${typeof r}`);return r}var ip=r=>Object.prototype.toString.call(r)==="[object Object]"&&r.constructor===Object;function xu(r,t){if(t!==void 0&&(typeof t!="object"||!ip(t)))throw new Error("options must be object or undefined");return Object.assign(r,t)}function cr(r,t){if(!wu(r))throw new Error("Uint8Array expected");if(typeof t=="number"&&r.length!==t)throw new Error(`Uint8Array length ${t} expected`)}function Eu(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}var ji=(r,t)=>(Object.assign(t,r),t);function zi(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}function qs(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`wrong positive integer: ${r}`)}function Wi(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}function ap(r){return r!=null&&typeof r=="object"&&(r instanceof Uint8Array||r.constructor.name==="Uint8Array")}function Or(r,...t){if(!ap(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function Yi(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function vu(r,t){Or(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var kt=(r,t)=>r[t++]&255|(r[t++]&255)<<8,Zi=class{constructor(t){this.blockLen=16,this.outputLen=16,this.buffer=new Uint8Array(16),this.r=new Uint16Array(10),this.h=new Uint16Array(10),this.pad=new Uint16Array(8),this.pos=0,this.finished=!1,t=$s(t),cr(t,32);let e=kt(t,0),n=kt(t,2),s=kt(t,4),o=kt(t,6),i=kt(t,8),a=kt(t,10),c=kt(t,12),l=kt(t,14);this.r[0]=e&8191,this.r[1]=(e>>>13|n<<3)&8191,this.r[2]=(n>>>10|s<<6)&7939,this.r[3]=(s>>>7|o<<9)&8191,this.r[4]=(o>>>4|i<<12)&255,this.r[5]=i>>>1&8190,this.r[6]=(i>>>14|a<<2)&8191,this.r[7]=(a>>>11|c<<5)&8065,this.r[8]=(c>>>8|l<<8)&8191,this.r[9]=l>>>5&127;for(let u=0;u<8;u++)this.pad[u]=kt(t,16+2*u)}process(t,e,n=!1){let s=n?0:2048,{h:o,r:i}=this,a=i[0],c=i[1],l=i[2],u=i[3],f=i[4],p=i[5],y=i[6],g=i[7],h=i[8],d=i[9],b=kt(t,e+0),v=kt(t,e+2),w=kt(t,e+4),A=kt(t,e+6),B=kt(t,e+8),S=kt(t,e+10),N=kt(t,e+12),_=kt(t,e+14),V=o[0]+(b&8191),P=o[1]+((b>>>13|v<<3)&8191),T=o[2]+((v>>>10|w<<6)&8191),H=o[3]+((w>>>7|A<<9)&8191),O=o[4]+((A>>>4|B<<12)&8191),W=o[5]+(B>>>1&8191),x=o[6]+((B>>>14|S<<2)&8191),I=o[7]+((S>>>11|N<<5)&8191),C=o[8]+((N>>>8|_<<8)&8191),E=o[9]+(_>>>5|s),m=0,k=m+V*a+P*(5*d)+T*(5*h)+H*(5*g)+O*(5*y);m=k>>>13,k&=8191,k+=W*(5*p)+x*(5*f)+I*(5*u)+C*(5*l)+E*(5*c),m+=k>>>13,k&=8191;let R=m+V*c+P*a+T*(5*d)+H*(5*h)+O*(5*g);m=R>>>13,R&=8191,R+=W*(5*y)+x*(5*p)+I*(5*f)+C*(5*u)+E*(5*l),m+=R>>>13,R&=8191;let L=m+V*l+P*c+T*a+H*(5*d)+O*(5*h);m=L>>>13,L&=8191,L+=W*(5*g)+x*(5*y)+I*(5*p)+C*(5*f)+E*(5*u),m+=L>>>13,L&=8191;let K=m+V*u+P*l+T*c+H*a+O*(5*d);m=K>>>13,K&=8191,K+=W*(5*h)+x*(5*g)+I*(5*y)+C*(5*p)+E*(5*f),m+=K>>>13,K&=8191;let F=m+V*f+P*u+T*l+H*c+O*a;m=F>>>13,F&=8191,F+=W*(5*d)+x*(5*h)+I*(5*g)+C*(5*y)+E*(5*p),m+=F>>>13,F&=8191;let j=m+V*p+P*f+T*u+H*l+O*c;m=j>>>13,j&=8191,j+=W*a+x*(5*d)+I*(5*h)+C*(5*g)+E*(5*y),m+=j>>>13,j&=8191;let $=m+V*y+P*p+T*f+H*u+O*l;m=$>>>13,$&=8191,$+=W*c+x*a+I*(5*d)+C*(5*h)+E*(5*g),m+=$>>>13,$&=8191;let G=m+V*g+P*y+T*p+H*f+O*u;m=G>>>13,G&=8191,G+=W*l+x*c+I*a+C*(5*d)+E*(5*h),m+=G>>>13,G&=8191;let nt=m+V*h+P*g+T*y+H*p+O*f;m=nt>>>13,nt&=8191,nt+=W*u+x*l+I*c+C*a+E*(5*d),m+=nt>>>13,nt&=8191;let tt=m+V*d+P*h+T*g+H*y+O*p;m=tt>>>13,tt&=8191,tt+=W*f+x*u+I*l+C*c+E*a,m+=tt>>>13,tt&=8191,m=(m<<2)+m|0,m=m+k|0,k=m&8191,m=m>>>13,R+=m,o[0]=k,o[1]=R,o[2]=L,o[3]=K,o[4]=F,o[5]=j,o[6]=$,o[7]=G,o[8]=nt,o[9]=tt}finalize(){let{h:t,pad:e}=this,n=new Uint16Array(10),s=t[1]>>>13;t[1]&=8191;for(let a=2;a<10;a++)t[a]+=s,s=t[a]>>>13,t[a]&=8191;t[0]+=s*5,s=t[0]>>>13,t[0]&=8191,t[1]+=s,s=t[1]>>>13,t[1]&=8191,t[2]+=s,n[0]=t[0]+5,s=n[0]>>>13,n[0]&=8191;for(let a=1;a<10;a++)n[a]=t[a]+s,s=n[a]>>>13,n[a]&=8191;n[9]-=8192;let o=(s^1)-1;for(let a=0;a<10;a++)n[a]&=o;o=~o;for(let a=0;a<10;a++)t[a]=t[a]&o|n[a];t[0]=(t[0]|t[1]<<13)&65535,t[1]=(t[1]>>>3|t[2]<<10)&65535,t[2]=(t[2]>>>6|t[3]<<7)&65535,t[3]=(t[3]>>>9|t[4]<<4)&65535,t[4]=(t[4]>>>12|t[5]<<1|t[6]<<14)&65535,t[5]=(t[6]>>>2|t[7]<<11)&65535,t[6]=(t[7]>>>5|t[8]<<8)&65535,t[7]=(t[8]>>>8|t[9]<<5)&65535;let i=t[0]+e[0];t[0]=i&65535;for(let a=1;a<8;a++)i=(t[a]+e[a]|0)+(i>>>16)|0,t[a]=i&65535}update(t){Yi(this);let{buffer:e,blockLen:n}=this;t=$s(t);let s=t.length;for(let o=0;o<s;){let i=Math.min(n-this.pos,s-o);if(i===n){for(;n<=s-o;o+=n)this.process(t,o);continue}e.set(t.subarray(o,o+i),this.pos),this.pos+=i,o+=i,this.pos===n&&(this.process(e,0,!1),this.pos=0)}return this}destroy(){this.h.fill(0),this.r.fill(0),this.buffer.fill(0),this.pad.fill(0)}digestInto(t){Yi(this),vu(t,this),this.finished=!0;let{buffer:e,h:n}=this,{pos:s}=this;if(s){for(e[s++]=1;s<16;s++)e[s]=0;this.process(e,0,!0)}this.finalize();let o=0;for(let i=0;i<8;i++)t[o++]=n[i]>>>0,t[o++]=n[i]>>>8;return t}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}};function cp(r){let t=(n,s)=>r(s).update($s(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var Bu=cp(r=>new Zi(r));var lp=Fs("expand 16-byte k"),up=Fs("expand 32-byte k"),fp=_e(lp),hp=_e(up);function D(r,t){return r<<t|r>>>32-t}function Xi(r){return r.byteOffset%4===0}var Gs=64,dp=16,Su=2**32-1,Au=new Uint32Array;function pp(r,t,e,n,s,o,i,a){let c=s.length,l=new Uint8Array(Gs),u=_e(l),f=Xi(s)&&Xi(o),p=f?_e(s):Au,y=f?_e(o):Au;for(let g=0;g<c;i++){if(r(t,e,n,u,i,a),i>=Su)throw new Error("arx: counter overflow");let h=Math.min(Gs,c-g);if(f&&h===Gs){let d=g/4;if(g%4!==0)throw new Error("arx: invalid block position");for(let b=0,v;b<dp;b++)v=d+b,y[v]=p[v]^u[b];g+=Gs;continue}for(let d=0,b;d<h;d++)b=g+d,o[b]=s[b]^l[d];g+=h}}function Ji(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:s,counterRight:o,rounds:i}=xu({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return qs(s),qs(i),Wi(o),Wi(e),(a,c,l,u,f=0)=>{Or(a),Or(c),Or(l);let p=l.length;if(u||(u=new Uint8Array(p)),Or(u),qs(f),f<0||f>=Su)throw new Error("arx: counter overflow");if(u.length<p)throw new Error(`arx: output (${u.length}) is shorter than data (${p})`);let y=[],g=a.length,h,d;if(g===32)h=a.slice(),y.push(h),d=hp;else if(g===16&&e)h=new Uint8Array(32),h.set(a),h.set(a,16),d=fp,y.push(h);else throw new Error(`arx: invalid 32-byte key, got length=${g}`);Xi(c)||(c=c.slice(),y.push(c));let b=_e(h);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(d,b,_e(c.subarray(0,16)),b),c=c.subarray(16)}let v=16-s;if(v!==c.length)throw new Error(`arx: nonce must be ${v} or 16 bytes`);if(v!==12){let A=new Uint8Array(12);A.set(c,o?0:12-c.length),c=A,y.push(c)}let w=_e(c);for(pp(r,d,b,w,l,u,f,i);y.length>0;)y.pop().fill(0);return u}}function _u(r,t,e,n,s,o=20){let i=r[0],a=r[1],c=r[2],l=r[3],u=t[0],f=t[1],p=t[2],y=t[3],g=t[4],h=t[5],d=t[6],b=t[7],v=s,w=e[0],A=e[1],B=e[2],S=i,N=a,_=c,V=l,P=u,T=f,H=p,O=y,W=g,x=h,I=d,C=b,E=v,m=w,k=A,R=B;for(let K=0;K<o;K+=2)S=S+P|0,E=D(E^S,16),W=W+E|0,P=D(P^W,12),S=S+P|0,E=D(E^S,8),W=W+E|0,P=D(P^W,7),N=N+T|0,m=D(m^N,16),x=x+m|0,T=D(T^x,12),N=N+T|0,m=D(m^N,8),x=x+m|0,T=D(T^x,7),_=_+H|0,k=D(k^_,16),I=I+k|0,H=D(H^I,12),_=_+H|0,k=D(k^_,8),I=I+k|0,H=D(H^I,7),V=V+O|0,R=D(R^V,16),C=C+R|0,O=D(O^C,12),V=V+O|0,R=D(R^V,8),C=C+R|0,O=D(O^C,7),S=S+T|0,R=D(R^S,16),I=I+R|0,T=D(T^I,12),S=S+T|0,R=D(R^S,8),I=I+R|0,T=D(T^I,7),N=N+H|0,E=D(E^N,16),C=C+E|0,H=D(H^C,12),N=N+H|0,E=D(E^N,8),C=C+E|0,H=D(H^C,7),_=_+O|0,m=D(m^_,16),W=W+m|0,O=D(O^W,12),_=_+O|0,m=D(m^_,8),W=W+m|0,O=D(O^W,7),V=V+P|0,k=D(k^V,16),x=x+k|0,P=D(P^x,12),V=V+P|0,k=D(k^V,8),x=x+k|0,P=D(P^x,7);let L=0;n[L++]=i+S|0,n[L++]=a+N|0,n[L++]=c+_|0,n[L++]=l+V|0,n[L++]=u+P|0,n[L++]=f+T|0,n[L++]=p+H|0,n[L++]=y+O|0,n[L++]=g+W|0,n[L++]=h+x|0,n[L++]=d+I|0,n[L++]=b+C|0,n[L++]=v+E|0,n[L++]=w+m|0,n[L++]=A+k|0,n[L++]=B+R|0}function gp(r,t,e,n){let s=r[0],o=r[1],i=r[2],a=r[3],c=t[0],l=t[1],u=t[2],f=t[3],p=t[4],y=t[5],g=t[6],h=t[7],d=e[0],b=e[1],v=e[2],w=e[3];for(let B=0;B<20;B+=2)s=s+c|0,d=D(d^s,16),p=p+d|0,c=D(c^p,12),s=s+c|0,d=D(d^s,8),p=p+d|0,c=D(c^p,7),o=o+l|0,b=D(b^o,16),y=y+b|0,l=D(l^y,12),o=o+l|0,b=D(b^o,8),y=y+b|0,l=D(l^y,7),i=i+u|0,v=D(v^i,16),g=g+v|0,u=D(u^g,12),i=i+u|0,v=D(v^i,8),g=g+v|0,u=D(u^g,7),a=a+f|0,w=D(w^a,16),h=h+w|0,f=D(f^h,12),a=a+f|0,w=D(w^a,8),h=h+w|0,f=D(f^h,7),s=s+l|0,w=D(w^s,16),g=g+w|0,l=D(l^g,12),s=s+l|0,w=D(w^s,8),g=g+w|0,l=D(l^g,7),o=o+u|0,d=D(d^o,16),h=h+d|0,u=D(u^h,12),o=o+u|0,d=D(d^o,8),h=h+d|0,u=D(u^h,7),i=i+f|0,b=D(b^i,16),p=p+b|0,f=D(f^p,12),i=i+f|0,b=D(b^i,8),p=p+b|0,f=D(f^p,7),a=a+c|0,v=D(v^a,16),y=y+v|0,c=D(c^y,12),a=a+c|0,v=D(v^a,8),y=y+v|0,c=D(c^y,7);let A=0;n[A++]=s,n[A++]=o,n[A++]=i,n[A++]=a,n[A++]=d,n[A++]=b,n[A++]=v,n[A++]=w}var mp=Ji(_u,{counterRight:!1,counterLength:4,allowShortKeys:!1}),yp=Ji(_u,{counterRight:!1,counterLength:8,extendNonceFn:gp,allowShortKeys:!1});var wp=new Uint8Array(16),ku=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(wp.subarray(e))},bp=new Uint8Array(32);function Iu(r,t,e,n,s){let o=r(t,e,bp),i=Bu.create(o);s&&ku(i,s),ku(i,n);let a=new Uint8Array(16),c=bu(a);zi(c,0,BigInt(s?s.length:0),!0),zi(c,8,BigInt(n.length),!0),i.update(a);let l=i.digest();return o.fill(0),l}var Nu=r=>(t,e,n)=>(cr(t,32),cr(e),{encrypt:(o,i)=>{let a=o.length,c=a+16;i?cr(i,c):i=new Uint8Array(c),r(t,e,o,i,1);let l=Iu(r,t,e,i.subarray(0,-16),n);return i.set(l,a),i},decrypt:(o,i)=>{let a=o.length,c=a-16;if(a<16)throw new Error("encrypted data must be at least 16 bytes");i?cr(i,c):i=new Uint8Array(c);let l=o.subarray(0,-16),u=o.subarray(-16),f=Iu(r,t,e,l,n);if(!Eu(u,f))throw new Error("invalid tag");return r(t,e,l,i,1),i}}),Qi=ji({blockSize:64,nonceLength:12,tagLength:16},Nu(mp)),cx=ji({blockSize:64,nonceLength:24,tagLength:16},Nu(yp));function Tu(r,t,e){return ze(r),e===void 0&&(e=new Uint8Array(r.outputLen)),Oe(r,Wt(e),Wt(t))}var ta=new Uint8Array([0]),Ru=new Uint8Array;function Lu(r,t,e,n=32){if(ze(r),Le(n),n>255*r.outputLen)throw new Error("Length should be <= 255*HashLen");let s=Math.ceil(n/r.outputLen);e===void 0&&(e=Ru);let o=new Uint8Array(s*r.outputLen),i=Oe.create(r,t),a=i._cloneInto(),c=new Uint8Array(i.outputLen);for(let l=0;l<s;l++)ta[0]=l+1,a.update(l===0?Ru:c).update(e).update(ta).digestInto(c),o.set(c,r.outputLen*l),i._cloneInto(a);return i.destroy(),a.destroy(),c.fill(0),ta.fill(0),o.slice(0,n)}var ea={hashSHA256(r){return Rr(r.subarray())},getHKDF(r,t){let e=Tu(Rr,t,r),s=Lu(Rr,e,void 0,96),o=s.subarray(0,32),i=s.subarray(32,64),a=s.subarray(64,96);return[o,i,a]},generateX25519KeyPair(){let r=Qr.utils.randomPrivateKey();return{publicKey:Qr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:Qr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return Qr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return Qi(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,s){return Qi(n,t,e).decrypt(r.subarray(),s)}};var Cu=ea;function Uu(r){return{generateKeypair:r.generateX25519KeyPair,dh:(t,e)=>r.generateX25519SharedKey(t.privateKey,e).subarray(0,32),encrypt:r.chaCha20Poly1305Encrypt,decrypt:r.chaCha20Poly1305Decrypt,hash:r.hashSHA256,hkdf:r.getHKDF}}var Hr=r=>{let t=wt(2);return t[0]=r>>8,t[1]=r,t};Hr.bytes=2;var xn=r=>{if(r.length<2)throw RangeError("Could not decode int16BE");if(r instanceof Uint8Array){let t=0;return t+=r[0]<<8,t+=r[1],t}return r.getUint16(0)};xn.bytes=2;function Pu(r){return{xxHandshakeSuccesses:r.registerCounter("libp2p_noise_xxhandshake_successes_total",{help:"Total count of noise xxHandshakes successes_"}),xxHandshakeErrors:r.registerCounter("libp2p_noise_xxhandshake_error_total",{help:"Total count of noise xxHandshakes errors"}),encryptedPackets:r.registerCounter("libp2p_noise_encrypted_packets_total",{help:"Total count of noise encrypted packets successfully"}),decryptedPackets:r.registerCounter("libp2p_noise_decrypted_packets_total",{help:"Total count of noise decrypted packets"}),decryptErrors:r.registerCounter("libp2p_noise_decrypt_errors_total",{help:"Total count of noise decrypt errors"})}}function ra(r,t){!t.enabled||!Vr||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${q(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${q(r.privateKey,"hex")}`)):t("Missing local static keys."))}function na(r,t){!t.enabled||!Vr||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${q(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${q(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function Du(r,t){!t.enabled||!Vr||t(r?`REMOTE_STATIC_PUBLIC_KEY ${q(r.subarray(),"hex")}`:"Missing remote static public key.")}function sa(r,t){!t.enabled||!Vr||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${q(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function oa(r,t,e){!e.enabled||!Vr||(e(`CIPHER_STATE_1 ${r.n.getUint64()} ${r.k&&q(r.k,"hex")}`),e(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&q(t.k,"hex")}`))}var js=class r extends Error{code;constructor(t="Unexpected Peer"){super(t),this.code=r.code}static code="ERR_UNEXPECTED_PEER"},Mr=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var xp=0,Ep=4294967295,vp="Cipherstate has reached maximum n, a new handshake must be performed",zs=class{n;bytes;view;constructor(t=xp){this.n=t,this.bytes=yt(12),this.view=new DataView(this.bytes.buffer,this.bytes.byteOffset,this.bytes.byteLength),this.view.setUint32(4,t,!0)}increment(){this.n++,this.view.setUint32(4,this.n,!0)}getBytes(){return this.bytes}getUint64(){return this.n}assertValue(){if(this.n>Ep)throw new Error(vp)}};var lr=yt(0),Kr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new zs(n)}hasKey(){return!!this.k}encryptWithAd(t,e){if(!this.hasKey())return e;this.n.assertValue();let n=this.crypto.encrypt(e,this.n.getBytes(),t,this.k);return this.n.increment(),n}decryptWithAd(t,e,n){if(!this.hasKey())return e;this.n.assertValue();let s=this.crypto.decrypt(e,this.n.getBytes(),t,this.k,n);return this.n.increment(),s}},ia=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=et(e,"utf-8");this.h=Bp(t,n),this.ck=this.h,this.cs=new Kr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new Kr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new ct(this.h,t))}encryptAndHash(t){let e=this.cs.encryptWithAd(this.h,t);return this.mixHash(e),e}decryptAndHash(t){let e=this.cs.decryptWithAd(this.h,t);return this.mixHash(t),e}split(){let[t,e]=this.crypto.hkdf(this.ck,lr);return[new Kr(this.crypto,t),new Kr(this.crypto,e)]}},aa=class{ss;s;e;rs;re;initiator;crypto;constructor(t){let{crypto:e,protocolName:n,prologue:s,initiator:o,s:i,e:a,rs:c,re:l}=t;this.crypto=e,this.ss=new ia(e,n),this.ss.mixHash(s),this.initiator=o,this.s=i,this.e=a,this.rs=c,this.re=l}writeE(){if(this.e)throw new Error("ephemeral keypair is already set");let t=this.crypto.generateKeypair();return this.ss.mixHash(t.publicKey),this.e=t,t.publicKey}writeS(){if(!this.s)throw new Error("static keypair is not set");return this.ss.encryptAndHash(this.s.publicKey)}writeEE(){if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.re))}writeES(){if(this.initiator){if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.rs)throw new Error("remote static public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.rs))}else{if(!this.s)throw new Error("static keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.s,this.re))}}writeSE(){if(this.initiator){if(!this.s)throw new Error("static keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.s,this.re))}else{if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.rs)throw new Error("remote static public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.rs))}}readE(t,e=0){if(this.re)throw new Error("remote ephemeral public key is already set");if(t.byteLength<e+32)throw new Error("message is not long enough");this.re=t.sublist(e,e+32),this.ss.mixHash(this.re)}readS(t,e=0){if(this.rs)throw new Error("remote static public key is already set");let n=32+(this.ss.cs.hasKey()?16:0);if(t.byteLength<e+n)throw new Error("message is not long enough");let s=t.sublist(e,e+n);return this.rs=this.ss.decryptAndHash(s),n}readEE(){this.writeEE()}readES(){this.writeES()}readSE(){this.writeSE()}},En=class extends aa{writeMessageA(t){return new ct(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new ct(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new ct(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new Mr(`handshake stage 0 validation fail: ${e.message}`)}}readMessageB(t){try{this.readE(t),this.readEE();let e=this.readS(t,32);return this.readES(),this.ss.decryptAndHash(t.sublist(32+e))}catch(e){throw new Mr(`handshake stage 1 validation fail: ${e.message}`)}}readMessageC(t){try{let e=this.readS(t);return this.readSE(),this.ss.decryptAndHash(t.sublist(e))}catch(e){throw new Mr(`handshake stage 2 validation fail: ${e.message}`)}}};function Bp(r,t){if(t.length<=32){let e=yt(32);return e.set(t),e}else return r.hash(t)}var Ws;(function(r){let t;r.codec=()=>(t==null&&(t=er((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.webtransportCerthashes!=null)for(let o of e.webtransportCerthashes)n.uint32(10),n.bytes(o);s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={webtransportCerthashes:[]},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:{s.webtransportCerthashes.push(e.bytes());break}default:{e.skipType(i&7);break}}}return s})),t),r.encode=e=>tr(e,r.codec()),r.decode=e=>Je(e,r.codec())})(Ws||(Ws={}));var vn;(function(r){let t;r.codec=()=>(t==null&&(t=er((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.identityKey!=null&&e.identityKey.byteLength>0&&(n.uint32(10),n.bytes(e.identityKey)),e.identitySig!=null&&e.identitySig.byteLength>0&&(n.uint32(18),n.bytes(e.identitySig)),e.extensions!=null&&(n.uint32(34),Ws.codec().encode(e.extensions,n)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={identityKey:yt(0),identitySig:yt(0)},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:{s.identityKey=e.bytes();break}case 2:{s.identitySig=e.bytes();break}case 4:{s.extensions=Ws.codec().decode(e,e.uint32());break}default:{e.skipType(i&7);break}}}return s})),t),r.encode=e=>tr(e,r.codec()),r.decode=e=>Je(e,r.codec())})(vn||(vn={}));async function ca(r,t,e){let n=await r.sign(Vu(t));return vn.encode({identityKey:r.public.bytes,identitySig:n,extensions:e})}async function la(r,t,e){try{let n=vn.decode(r);if(e){let i=e.subarray();if(!ft(i,n.identityKey))throw new Error(`Payload identity key ${q(n.identityKey,"hex")} does not match expected remote identity key ${q(i,"hex")}`)}if(!t)throw new Error("Remote static does not exist");let s=Vu(t);if(!await ru(n.identityKey).verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new js(n.message)}}function Vu(r){let t=et("noise-libp2p-static-key:");return r instanceof Uint8Array?xt([t,r],t.length+r.length):(r.prepend(t),r)}async function Ou(r){let{log:t,connection:e,crypto:n,privateKey:s,prologue:o,s:i,remoteIdentityKey:a,extensions:c}=r,l=await ca(s,i.publicKey,c),u=new En({crypto:n,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:o,s:i});ra(u.s,t),t.trace("Stage 0 - Initiator starting to send first message."),await e.write(u.writeMessageA(lr)),t.trace("Stage 0 - Initiator finished sending first message."),na(u.e,t),t.trace("Stage 1 - Initiator waiting to receive first message from responder...");let f=u.readMessageB(await e.read());t.trace("Stage 1 - Initiator received the message."),sa(u.re,t),Du(u.rs,t),t.trace("Initiator going to check remote's signature...");let p=await la(f,u.rs,a);t.trace("All good with the signature!"),t.trace("Stage 2 - Initiator sending third handshake message."),await e.write(u.writeMessageC(l)),t.trace("Stage 2 - Initiator sent message with signed payload.");let[y,g]=u.ss.split();return oa(y,g,t),{payload:p,encrypt:h=>y.encryptWithAd(lr,h),decrypt:(h,d)=>g.decryptWithAd(lr,h,d)}}async function Hu(r){let{log:t,connection:e,crypto:n,privateKey:s,prologue:o,s:i,remoteIdentityKey:a,extensions:c}=r,l=await ca(s,i.publicKey,c),u=new En({crypto:n,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:o,s:i});ra(u.s,t),t.trace("Stage 0 - Responder waiting to receive first message."),u.readMessageA(await e.read()),t.trace("Stage 0 - Responder received first message."),sa(u.re,t),t.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await e.write(u.writeMessageB(l)),t.trace("Stage 1 - Responder sent the second handshake message with signed payload."),na(u.e,t),t.trace("Stage 2 - Responder waiting for third handshake message...");let f=u.readMessageC(await e.read());t.trace("Stage 2 - Responder received the message, finished handshake.");let p=await la(f,u.rs,a),[y,g]=u.ss.split();return oa(y,g,t),{payload:p,encrypt:h=>g.encryptWithAd(lr,h),decrypt:(h,d)=>y.decryptWithAd(lr,h,d)}}var Ku=16;function Fu(r,t){return async function*(e){for await(let n of e)for(let s=0;s<n.length;s+=65519){let o=s+65519;o>n.length&&(o=n.length);let i;n instanceof Uint8Array?i=r.encrypt(n.subarray(s,o)):i=r.encrypt(n.sublist(s,o)),t?.encryptedPackets.increment(),yield new ct(Hr(i.byteLength),i)}}}function $u(r,t){return async function*(e){for await(let n of e)for(let s=0;s<n.length;s+=65535){let o=s+65535;if(o>n.length&&(o=n.length),o-Ku<s)throw new Error("Invalid chunk");let i=n.sublist(s,o),a=n.subarray(s,o-Ku);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var Ys=class{protocol="/noise";crypto;prologue;staticKey;extensions;metrics;components;constructor(t,e={}){let{staticNoiseKey:n,extensions:s,crypto:o,prologueBytes:i}=e,{metrics:a}=t;this.components=t;let c=o??Cu;this.crypto=Uu(c),this.extensions=s,this.metrics=a?Pu(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??yt(0)}async secureOutbound(t,e,n){let s=Fi(e,{lengthEncoder:Hr,lengthDecoder:xn,maxDataLength:65535});if(!t.privateKey)throw new M("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let o=await Ui(t.privateKey),i=n?.publicKey,a=await this.performHandshakeInitiator(s,o,i),c=await this.createSecureConnection(s,a);return e.source=c.source,e.sink=c.sink,{conn:e,remoteExtensions:a.payload.extensions,remotePeer:await Oi(a.payload.identityKey)}}async secureInbound(t,e,n){let s=Fi(e,{lengthEncoder:Hr,lengthDecoder:xn,maxDataLength:65535});if(!t.privateKey)throw new M("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let o=await Ui(t.privateKey),i=n?.publicKey,a=await this.performHandshakeResponder(s,o,i),c=await this.createSecureConnection(s,a);return e.source=c.source,e.sink=c.sink,{conn:e,remoteExtensions:a.payload.extensions,remotePeer:await Oi(a.payload.identityKey)}}async performHandshakeInitiator(t,e,n){let s;try{s=await Ou({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:this.extensions}),this.metrics?.xxHandshakeSuccesses.increment()}catch(o){throw this.metrics?.xxHandshakeErrors.increment(),o}return s}async performHandshakeResponder(t,e,n){let s;try{s=await Hu({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:this.extensions}),this.metrics?.xxHandshakeSuccesses.increment()}catch(o){throw this.metrics?.xxHandshakeErrors.increment(),o}return s}async createSecureConnection(t,e){let[n,s]=du(),o=t.unwrap();return await gu(n,Fu(e,this.metrics),o,i=>bn(i,{lengthDecoder:xn}),$u(e,this.metrics),n),s}};function qu(r={}){return t=>new Ys(t,r)}var Zs=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,s){return this.readAtomically(()=>{let o=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",l=2**(8*s)-1;for(;;){let u=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let p=Number.parseInt(f,t);if(!Number.isNaN(p))return p});if(u===void 0)break;if(o*=t,o+=u,o>l||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&c&&i>1?void 0:o})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let s=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[s]=i[0],e[s+1]=i[1],e[s+2]=i[2],e[s+3]=i[3],[s+4,!0]}let o=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(o===void 0)return[s,!1];e[s]=o>>8,e[s+1]=o&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,s]=t(e);if(n===16)return e;if(s||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let o=new Uint8Array(14),i=16-(n+2),[a]=t(o.subarray(0,i));return e.set(o.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Gu=45,Ap=15,Fr=new Zs;function ua(r){if(!(r.length>Ap))return Fr.new(r).parseWith(()=>Fr.readIPv4Addr())}function fa(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Gu))return Fr.new(r).parseWith(()=>Fr.readIPv6Addr())}function Xs(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Gu))return Fr.new(r).parseWith(()=>Fr.readIPAddr())}function Js(r){return!!ua(r)}function Qs(r){return!!fa(r)}function to(r){return!!Xs(r)}var j1=parseInt("0xFFFF",16),z1=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Wu=Js,Np=Qs,ha=function(r){let t=0;if(r=r.toString().trim(),Wu(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(Np(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let o=Wu(e[n]),i;o&&(i=ha(e[n]),e[n]=q(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,q(i.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let o=[n,1];for(n=9-e.length;n>0;n--)o.push("0");e.splice.apply(e,o)}let s=new Uint8Array(t+16);for(n=0;n<e.length;n++){let o=parseInt(e[n],16);s[t++]=o>>8&255,s[t++]=o&255}return s}throw new Error("invalid ip address")},Yu=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let s=[];for(let o=0;o<e;o++)s.push(r[t+o]);return s.join(".")}if(e===16){let s=[];for(let o=0;o<e;o+=2)s.push(n.getUint16(t+o).toString(16));return s.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var $r={},da={},Tp=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[777,-1,"memory"]];Tp.forEach(r=>{let t=Lp(...r);da[t.code]=t,$r[t.name]=t});function Lp(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function Q(r){if(typeof r=="number"){if(da[r]!=null)return da[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if($r[r]!=null)return $r[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var _2=Q("ip4"),N2=Q("ip6"),R2=Q("ipcidr");function ga(r,t){switch(Q(r).code){case 4:case 41:return Up(t);case 42:return Ju(t);case 6:case 273:case 33:case 132:return tf(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ju(t);case 421:return Op(t);case 444:return Qu(t);case 445:return Qu(t);case 466:return Vp(t);default:return q(t,"base16")}}function ma(r,t){switch(Q(r).code){case 4:return Zu(t);case 41:return Zu(t);case 42:return Xu(t);case 6:case 273:case 33:case 132:return ya(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Xu(t);case 421:return Pp(t);case 444:return Hp(t);case 445:return Mp(t);case 466:return Dp(t);default:return et(t,"base16")}}var pa=Object.values(ne).map(r=>r.decoder),Cp=function(){let r=pa[0].or(pa[1]);return pa.slice(2).forEach(t=>r=r.or(t)),r}();function Zu(r){if(!to(r))throw new Error("invalid ip address");return ha(r)}function Up(r){let t=Yu(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!to(t))throw new Error("invalid ip address");return t}function ya(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function tf(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Xu(r){let t=et(r),e=Uint8Array.from(se(t.length));return xt([e,t],e.length+t.length)}function Ju(r){let t=Xt(r);if(r=r.slice(dt(t)),r.length!==t)throw new Error("inconsistent lengths");return q(r)}function Pp(r){let t;r[0]==="Q"||r[0]==="1"?t=Re(ut.decode(`z${r}`)).bytes:t=jt.parse(r).multihash.bytes;let e=Uint8Array.from(se(t.length));return xt([e,t],e.length+t.length)}function Dp(r){let t=Cp.decode(r),e=Uint8Array.from(se(t.length));return xt([e,t],e.length+t.length)}function Vp(r){let t=Xt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+q(e,"base64url")}function Op(r){let t=Xt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return q(e,"base58btc")}function Hp(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let e=de.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=ya(n);return xt([e,s],e.length+s.length)}function Mp(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let e=de.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=ya(n);return xt([e,s],e.length+s.length)}function Qu(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=q(t,"base32"),s=tf(e);return`${n}:${s}`}function ef(r){r=wa(r);let t=[],e=[],n=null,s=r.split("/").slice(1);if(s.length===1&&s[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let o=0;o<s.length;o++){let i=s[o],a=Q(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(o++,o>=s.length)throw nf("invalid address: "+r);if(a.path===!0){n=wa(s.slice(o).join("/")),t.push([a.code,ma(a.code,n)]),e.push([a.code,n]);break}let c=ma(a.code,s[o]);t.push([a.code,c]),e.push([a.code,ga(a.code,c)])}return{string:rf(e),bytes:xa(t),tuples:t,stringTuples:e,path:n}}function ba(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let o=Xt(r,s),i=dt(o),a=Q(o),c=Kp(a,r.slice(s+i));if(c===0){t.push([o]),e.push([o]),s+=i;continue}let l=r.slice(s+i,s+i+c);if(s+=c+i,s>r.length)throw nf("Invalid address Uint8Array: "+q(r,"base16"));t.push([o,l]);let u=ga(o,l);if(e.push([o,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:rf(e),tuples:t,stringTuples:e,path:n}}function rf(r){let t=[];return r.map(e=>{let n=Q(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),wa(t.join("/"))}function xa(r){return xt(r.map(t=>{let e=Q(t[0]),n=Uint8Array.from(se(e.code));return t.length>1&&t[1]!=null&&(n=xt([n,t[1]])),n}))}function Kp(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Xt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+dt(e)}}function wa(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function nf(r){return new Error("Error parsing address: "+r)}var Fp=Symbol.for("nodejs.util.inspect.custom"),Ea=Symbol.for("@multiformats/js-multiaddr/multiaddr"),$p=[Q("dns").code,Q("dns4").code,Q("dns6").code,Q("dnsaddr").code],eo=class r{bytes;#e;#t;#r;#n;[Ea]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=ba(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=ef(t)}else if(of(t))e=ba(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#e=e.string,this.#t=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let t,e,n,s,o="",i=Q("tcp"),a=Q("udp"),c=Q("ip4"),l=Q("ip6"),u=Q("dns6"),f=Q("ip6zone");for(let[y,g]of this.stringTuples())y===f.code&&(o=`%${g??""}`),$p.includes(y)&&(e=i.name,s=443,n=`${g??""}${o}`,t=y===u.code?6:4),(y===i.code||y===a.code)&&(e=Q(y).name,s=parseInt(g??"")),(y===c.code||y===l.code)&&(e=Q(y).name,n=`${g??""}${o}`,t=y===l.code?6:4);if(t==null||e==null||n==null||s==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:s}}protos(){return this.#t.map(([t])=>Object.assign({},Q(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>Q(t).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),s=n.lastIndexOf(e);if(s<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,s))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(xa(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,s])=>{n===$r.p2p.code&&t.push([n,s]),n===$r["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?q(ut.decode(`z${n}`),"base58btc"):q(jt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return ft(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(o=>o.resolvable);if(e==null)return[this];let n=sf.get(e.name);if(n==null)throw new M(`no available resolver for ${e.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,t)).map(o=>va(o))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[Fp](){return`Multiaddr(${this.#e})`}};var sf=new Map;function of(r){return!!r?.[Ea]}function va(r){return new eo(r)}var qp=r=>r.toString().split("/").slice(1),An=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),X=r=>({match:t=>An(e=>e===r).match(t),pattern:r}),so=()=>({match:r=>An(t=>typeof t=="string").match(r),pattern:"{string}"}),oo=()=>({match:r=>An(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),It=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{ut.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),ro=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{To.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),_t=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),Mt=(...r)=>({match:t=>{let e;for(let n of r){let s=n.match(t);s!==!1&&(e==null||s.length<e.length)&&(e=s)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),rt=(...r)=>({match:t=>{for(let e of r){let n=e.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${r.map(t=>t.pattern).join(", ")})`});function ht(...r){function t(s){let o=qp(s);for(let i of r){let a=i.match(o);if(a===!1)return!1;o=a}return o}function e(s){return t(s)!==!1}function n(s){let o=t(s);return o===!1?!1:o.length===0}return{matches:e,exactMatch:n}}var Aa=rt(X("dns4"),so()),Sa=rt(X("dns6"),so()),ka=rt(X("dnsaddr"),so()),af=rt(X("dns"),so()),oE=ht(Aa),iE=ht(Sa),aE=ht(ka),cE=ht(Mt(af,ka,Aa,Sa)),cf=rt(X("ip4"),An(Js)),lf=rt(X("ip6"),An(Qs)),uf=Mt(cf,lf),ue=Mt(uf,af,Aa,Sa,ka),lE=ht(ue),uE=ht(cf),fE=ht(lf),hE=ht(uf),io=rt(ue,X("tcp"),oo()),Sn=rt(ue,X("udp"),oo()),Gp=Mt(io,Sn),dE=ht(io),pE=ht(Sn),Ia=rt(Sn,X("quic")),ao=rt(Sn,X("quic-v1")),jp=Mt(Ia,ao),gE=ht(Ia),mE=ht(ao),Ba=Mt(ue,io,Sn,Ia,ao),ff=Mt(rt(Ba,X("ws"),_t(It()))),yE=ht(ff),hf=Mt(rt(Ba,X("wss"),_t(It())),rt(Ba,X("tls"),X("ws"),_t(It()))),wE=ht(hf),df=rt(Gp,X("webrtc-direct"),ro(),_t(ro()),_t(It())),bE=ht(df),pf=rt(ao,X("webtransport"),_t(ro()),_t(ro()),_t(It())),co=ht(pf),no=Mt(ff,hf,rt(io,_t(It())),rt(jp,_t(It())),rt(ue,_t(It())),df,pf,It()),xE=ht(no),zp=rt(no,X("p2p-circuit"),It()),EE=ht(zp),Wp=Mt(rt(no,X("p2p-circuit"),X("webrtc"),It()),rt(no,X("webrtc"),_t(It())),X("webrtc")),vE=ht(Wp),Yp=Mt(rt(ue,X("tcp"),oo(),X("http"),_t(It())),rt(ue,X("http"),_t(It()))),BE=ht(Yp),Zp=Mt(rt(ue,X("tcp"),Mt(rt(X("443"),X("http")),rt(oo(),X("https"))),_t(It())),rt(ue,X("tls"),X("http"),_t(It())),rt(ue,X("https"),_t(It()))),AE=ht(Zp);function _a(r){throw new Error("Not implemented")}function gf(r){if(r!=null){if(typeof r[Symbol.iterator]=="function")return r[Symbol.iterator]();if(typeof r[Symbol.asyncIterator]=="function")return r[Symbol.asyncIterator]();if(typeof r.next=="function")return r}throw new Error("argument is not an iterator or iterable")}function mf(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function yf(r,t){let e=gf(r).return?.();mf(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var Xp="ERR_STREAM_RESET",Jp="ERR_SINK_INVALID_STATE",Qp=5e3;function Na(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var lo=class{id;direction;timeline;protocol;metadata;source;status;readStatus;writeStatus;log;sinkController;sinkEnd;closed;endErr;streamSource;onEnd;onCloseRead;onCloseWrite;onReset;onAbort;sendCloseWriteTimeout;sendingData;constructor(t){this.sinkController=new AbortController,this.sinkEnd=Ct(),this.closed=Ct(),this.log=t.log,this.status="open",this.readStatus="ready",this.writeStatus="ready",this.id=t.id,this.metadata=t.metadata??{},this.direction=t.direction,this.timeline={open:Date.now()},this.sendCloseWriteTimeout=t.sendCloseWriteTimeout??Qp,this.onEnd=t.onEnd,this.onCloseRead=t?.onCloseRead,this.onCloseWrite=t?.onCloseWrite,this.onReset=t?.onReset,this.onAbort=t?.onAbort,this.source=this.streamSource=Dr({onEnd:e=>{e!=null?this.log.trace("source ended with error",e):this.log.trace("source ended"),this.onSourceEnd(e)}}),this.sink=this.sink.bind(this)}async sink(t){if(this.writeStatus!=="ready")throw new M(`writable end state is "${this.writeStatus}" not "ready"`,Jp);try{this.writeStatus="writing";let e={signal:this.sinkController.signal};if(this.direction==="outbound"){let s=this.sendNewStream(e);Na(s)&&await s}let n=()=>{yf(t,this.log)};try{this.sinkController.signal.addEventListener("abort",n),this.log.trace("sink reading from source");for await(let s of t){s=s instanceof Uint8Array?new ct(s):s;let o=this.sendData(s,e);Na(o)&&(this.sendingData=Ct(),await o,this.sendingData.resolve(),this.sendingData=void 0)}}finally{this.sinkController.signal.removeEventListener("abort",n)}this.log.trace('sink finished reading from source, write status is "%s"',this.writeStatus),this.writeStatus==="writing"&&(this.writeStatus="closing",this.log.trace("send close write to remote"),await this.sendCloseWrite({signal:AbortSignal.timeout(this.sendCloseWriteTimeout)}),this.writeStatus="closed"),this.onSinkEnd()}catch(e){throw this.log.trace("sink ended with error, calling abort with error",e),this.abort(e),e}finally{this.log.trace("resolve sink end"),this.sinkEnd.resolve()}}onSourceEnd(t){this.timeline.closeRead==null&&(this.timeline.closeRead=Date.now(),this.readStatus="closed",t!=null&&this.endErr==null&&(this.endErr=t),this.onCloseRead?.(),this.timeline.closeWrite!=null?(this.log.trace("source and sink ended"),this.timeline.close=Date.now(),this.status!=="aborted"&&this.status!=="reset"&&(this.status="closed"),this.onEnd!=null&&this.onEnd(this.endErr),this.closed.resolve()):this.log.trace("source ended, waiting for sink to end"))}onSinkEnd(t){this.timeline.closeWrite==null&&(this.timeline.closeWrite=Date.now(),this.writeStatus="closed",t!=null&&this.endErr==null&&(this.endErr=t),this.onCloseWrite?.(),this.timeline.closeRead!=null?(this.log.trace("sink and source ended"),this.timeline.close=Date.now(),this.status!=="aborted"&&this.status!=="reset"&&(this.status="closed"),this.onEnd!=null&&this.onEnd(this.endErr),this.closed.resolve()):this.log.trace("sink ended, waiting for source to end"))}async close(t){this.log.trace("closing gracefully"),this.status="closing",await Dt(Promise.all([this.closeWrite(t),this.closeRead(t),this.closed.promise]),t?.signal),this.status="closed",this.log.trace("closed gracefully")}async closeRead(t={}){if(this.readStatus==="closing"||this.readStatus==="closed")return;this.log.trace('closing readable end of stream with starting read status "%s"',this.readStatus);let e=this.readStatus;this.readStatus="closing",this.status!=="reset"&&this.status!=="aborted"&&this.timeline.closeRead==null&&(this.log.trace("send close read to remote"),await this.sendCloseRead(t)),e==="ready"&&(this.log.trace("ending internal source queue with %d queued bytes",this.streamSource.readableLength),this.streamSource.end()),this.log.trace("closed readable end of stream")}async closeWrite(t={}){this.writeStatus==="closing"||this.writeStatus==="closed"||(this.log.trace('closing writable end of stream with starting write status "%s"',this.writeStatus),this.writeStatus==="ready"&&(this.log.trace("sink was never sunk, sink an empty array"),await Dt(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await Dt(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await Dt(this.sinkEnd.promise,t.signal)),this.writeStatus="closed",this.log.trace("closed writable end of stream"))}abort(t){if(this.status==="closed"||this.status==="aborted"||this.status==="reset")return;this.log("abort with error",t),this.log("try to send reset to remote");let e=this.sendReset();Na(e)&&e.catch(n=>{this.log.error("error sending reset message",n)}),this.status="aborted",this.timeline.abort=Date.now(),this._closeSinkAndSource(t),this.onAbort?.(t)}reset(){if(this.status==="closed"||this.status==="aborted"||this.status==="reset")return;let t=new M("stream reset",Xp);this.status="reset",this.timeline.reset=Date.now(),this._closeSinkAndSource(t),this.onReset?.()}_closeSinkAndSource(t){this._closeSink(t),this._closeSource(t)}_closeSink(t){this.writeStatus==="writing"&&(this.log.trace("end sink source"),this.sinkController.abort()),this.onSinkEnd(t)}_closeSource(t){this.readStatus!=="closing"&&this.readStatus!=="closed"&&(this.log.trace("ending source with %d bytes to be read by consumer",this.streamSource.readableLength),this.readStatus="closing",this.streamSource.end(t))}remoteCloseWrite(){if(this.readStatus==="closing"||this.readStatus==="closed"){this.log("received remote close write but local source is already closed");return}this.log.trace("remote close write"),this._closeSource()}remoteCloseRead(){if(this.writeStatus==="closing"||this.writeStatus==="closed"){this.log("received remote close read but local sink is already closed");return}this.log.trace("remote close read"),this._closeSink()}destroy(){if(this.status==="closed"||this.status==="aborted"||this.status==="reset"){this.log("received destroy but we are already closed");return}this.log.trace("stream destroyed"),this._closeSinkAndSource()}sourcePush(t){this.streamSource.push(t)}sourceReadableLength(){return this.streamSource.readableLength}};var Ra=class extends lo{writer;reader;constructor(t){super(t),this.writer=t.bidiStream.writable.getWriter(),this.reader=t.bidiStream.readable.getReader(),Promise.resolve().then(async()=>{for(;;){let e=await this.reader.read();if(e.done){t.log("remote closed write");return}e.value!=null&&this.sourcePush(new ct(e.value))}}).catch(e=>{t.log.error("error reading from stream",e),this.abort(e)}).finally(()=>{this.remoteCloseWrite()}),this.writer.closed.then(()=>{t.log("writer closed")}).catch(e=>{t.log("writer close promise rejected",e)}).finally(()=>{this.remoteCloseRead()})}sendNewStream(t){}async sendData(t,e){for await(let n of t)this.log("sendData waiting for writer to be ready"),await Dt(this.writer.ready,e?.signal),this.writer.write(n).catch(s=>{this.log.error("error sending stream data",s)})}async sendReset(t){this.log("sendReset aborting writer"),await Dt(this.writer.abort(),t?.signal),this.log("sendReset aborted writer")}async sendCloseWrite(t){this.log("sendCloseWrite closing writer"),await Dt(this.writer.close(),t?.signal),this.log("sendCloseWrite closed writer")}async sendCloseRead(t){this.log("sendCloseRead cancelling reader"),await Dt(this.reader.cancel(),t?.signal),this.log("sendCloseRead cancelled reader")}};async function Ta(r,t,e,n,s,o){let i=o.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=new Ra({bidiStream:r,id:t,direction:e,log:i,onEnd:()=>{let c=n.findIndex(l=>l===a);c!==-1&&n.splice(c,1),s?.(a)}});return a}function uo(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function wf(r,t,e,n){let s=0,o=e.forComponent("libp2p:webtransport:muxer");return{protocol:"webtransport",createStreamMuxer:i=>{typeof i=="function"&&(i={onIncomingStream:i});let a=[];return Promise.resolve().then(async()=>{for(;;){let{done:l,value:u}=await t.read();if(l)break;if(a.length>=n.maxInboundStreams)o(`too many inbound streams open - ${a.length}/${n.maxInboundStreams}, closing new incoming stream`),u.writable.close().catch(f=>{o.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${f.message}`)}),u.readable.cancel().catch(f=>{o.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${f.message}`)});else{let f=await Ta(u,String(s++),"inbound",a,i?.onStreamEnd,e);a.push(f),i?.onIncomingStream?.(f)}}}),{protocol:"webtransport",streams:a,newStream:async l=>{o("new outgoing stream",l);let u=await r.createBidirectionalStream(),f=await Ta(u,String(s++),i?.direction??"outbound",a,i?.onStreamEnd,e);return a.push(f),f},close:async()=>{o("closing webtransport muxer gracefully"),r.close()},abort:l=>{o("closing webtransport muxer with err:",l),r.close()},...uo()}}}}function bf(r,t){return t.filter(n=>!!r.find(s=>ft(n,s))).length===t.length}var tg=Object.values(ne).map(r=>r.decoder).reduce((r,t)=>r.or(t));function eg(r){return re.decode(tg.decode(r))}function La(r){if(!co.matches(r))throw new M("Invalid multiaddr, was not a WebTransport address","ERR_INVALID_MULTIADDR");let t=r.stringTuples(),e=t.filter(([i,a])=>i===Q("certhash").code).map(([i,a])=>eg(a??"")),n=t.filter(([i,a])=>i===Q("p2p").code).map(([i,a])=>Vi(a??""))[0],s=r.toOptions(),o=s.host;return s.family===6&&o?.includes(":")&&(o=`[${o}]`),{url:`https://${o}:${s.port}`,certhashes:e,remotePeer:n}}var xf=WebTransport;var Ca=class{log;components;config;metrics;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:webtransport"),this.components=t,this.config={...e,maxInboundStreams:e.maxInboundStreams??1e3,certificates:e.certificates??[]},t.metrics!=null&&(this.metrics={dialerEvents:t.metrics.registerCounterGroup("libp2p_webtransport_dialer_events_total",{label:"event",help:"Total count of WebTransport dialer events by type"})})}[Symbol.toStringTag]="@libp2p/webtransport";[za]=!0;async dial(t,e){if(e?.signal?.aborted===!0)throw new Gr;this.log("dialing %s",t);let n=this.components.peerId;if(n===void 0)throw new M("Need a local peerid","ERR_INVALID_PARAMETERS");e=e??{};let{url:s,certhashes:o,remotePeer:i}=La(t),a,c,l=()=>{},u=!1,f=!1,p=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let y=new xf(`${s}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(g=>({algorithm:"sha-256",value:g.digest}))});if(l=g=>{if(!u)try{this.metrics?.dialerEvents.increment({[g]:!0}),y.close()}catch(h){this.log.error("error closing wt session",h)}finally{c!=null&&(c.timeline.close=Date.now()),u=!0}},a=()=>{l(f?"noise_timeout":"ready_timeout")},e.signal?.addEventListener("abort",a,{once:!0}),this.log("wait for session to be ready"),await Promise.race([y.closed,y.ready]),this.log("session became ready"),f=!0,this.metrics?.dialerEvents.increment({ready:!0}),y.closed.catch(g=>{this.log.error("error on remote wt session close",g)}).finally(()=>{l("remote_close")}),p=await Dt(this.authenticateWebTransport(y,n,i,o),e.signal),!p)throw new M("Failed to authenticate webtransport","ERR_AUTHENTICATION_FAILED");return this.metrics?.dialerEvents.increment({open:!0}),c={close:async()=>{this.log("closing webtransport"),l("close")},abort:g=>{this.log("aborting webtransport due to passed err",g),l("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...uo()},await e.upgrader.upgradeOutbound(c,{skipEncryption:!0,muxerFactory:wf(y,y.incomingBidirectionalStreams.getReader(),this.components.logger,this.config),skipProtection:!0})}catch(y){throw this.log.error("caught wt session err",y),l(p?"upgrade_error":f?"noise_error":"ready_error"),y}finally{a!=null&&e.signal?.removeEventListener("abort",a)}}async authenticateWebTransport(t,e,n,s=[],o){if(o?.aborted===!0)throw new Gr;let i=await t.createBidirectionalStream(),a=i.writable.getWriter(),c=i.readable.getReader(),l={source:async function*(){for(;;){let p=await c.read();if(p.value!=null&&(yield p.value),p.done)break}}(),sink:async p=>{for await(let y of p){await Dt(a.ready,o);let g=y instanceof Uint8Array?y:y.subarray();a.write(g).catch(h=>{this.log.error("could not write chunk during authentication of WebTransport stream",h)})}}},u=qu()(this.components),{remoteExtensions:f}=await u.secureOutbound(e,l,n);if(a.close().catch(p=>{this.log.error(`Failed to close authentication stream writer: ${p.message}`)}),c.cancel().catch(p=>{this.log.error(`Failed to close authentication stream reader: ${p.message}`)}),!bf(f?.webtransportCerthashes??[],s.map(p=>p.bytes)))throw new Error("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return _a(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return t.filter(e=>{if(!co.exactMatch(e))return!1;let{url:n,certhashes:s}=La(e);return n!=null&&s.length>0})}};function rg(r={}){return t=>new Ca(t,r)}return Uf(ng);})();
|
|
7
|
+
`)}async function _0(r,t){let e=Ut.get(),n;if(r.includes("-----BEGIN ENCRYPTED PRIVATE KEY-----")){let s=et(r.replace("-----BEGIN ENCRYPTED PRIVATE KEY-----","").replace("-----END ENCRYPTED PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=_r(s),{iv:i,salt:a,iterations:c,keySize:l,cipherText:u}=N0(o),f=await bi(wr,t,a,{c,dkLen:l}),p=await e.subtle.importKey("raw",f,"AES-CBC",!1,["decrypt"]),y=dn(await e.subtle.decrypt({name:"AES-CBC",iv:i},p,u)),{result:g}=_r(y);n=Ol(g)}else if(r.includes("-----BEGIN PRIVATE KEY-----")){let s=et(r.replace("-----BEGIN PRIVATE KEY-----","").replace("-----END PRIVATE KEY-----","").replace(/\n/g,"").trim(),"base64pad"),{result:o}=_r(s);n=Ol(o)}else throw new M("Could not parse private key from PEM data","ERR_INVALID_PARAMETERS");return ki(n)}function N0(r){let t=r.valueBlock.value[0];if(t.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.13")throw new M("Only pkcs5PBES2 encrypted private keys are supported","ERR_INVALID_PARAMS");let n=t.valueBlock.value[1].valueBlock.value[0];if(n.valueBlock.value[0].toString()!=="OBJECT IDENTIFIER : 1.2.840.113549.1.5.12")throw new M("Only pkcs5PBKDF2 key derivation functions are supported","ERR_INVALID_PARAMS");let o=n.valueBlock.value[1],i=dn(o.valueBlock.value[0].getValue()),a=Si,c=Ai;if(o.valueBlock.value.length===3)a=Number(o.valueBlock.value[1].toBigInt()),c=Number(o.valueBlock.value[2].toBigInt());else if(o.valueBlock.value.length===2)throw new M("Could not derive key size and iterations from PEM file - please use @libp2p/rsa to re-import your key","ERR_INVALID_PARAMS");let l=t.valueBlock.value[1].valueBlock.value[1],u=l.valueBlock.value[0].toString();if(u!=="OBJECT IDENTIFIER : 1.2.840.113549.3.7"){if(u!=="OBJECT IDENTIFIER : 1.3.14.3.2.7"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.2"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.22"){if(u!=="OBJECT IDENTIFIER : 2.16.840.1.101.3.4.1.42")throw new M("Only AES-CBC encryption schemes are supported","ERR_INVALID_PARAMS")}}}}let f=dn(l.valueBlock.value[1].getValue());return{cipherText:dn(r.valueBlock.value[1].getValue()),salt:i,iterations:a,keySize:c,iv:f}}function Ol(r){return dn(r.valueBlock.value[2].getValue())}function dn(r){return new Uint8Array(r,0,r.byteLength)}async function Hl(r){let t=await Ut.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:r,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]),e=await Fl(t);return{privateKey:e[0],publicKey:e[1]}}async function Ii(r){let e=[await Ut.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["sign"]),await R0(r)],n=await Fl({privateKey:e[0],publicKey:e[1]});return{privateKey:n[0],publicKey:n[1]}}async function Ml(r,t){let e=await Ut.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ut.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Kl(r,t,e){let n=await Ut.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ut.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Fl(r){if(r.privateKey==null||r.publicKey==null)throw new M("Private and public key are required","ERR_INVALID_PARAMETERS");return Promise.all([Ut.get().subtle.exportKey("jwk",r.privateKey),Ut.get().subtle.exportKey("jwk",r.publicKey)])}async function R0(r){return Ut.get().subtle.importKey("jwk",{kty:r.kty,n:r.n,e:r.e},{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!0,["verify"])}function Us(r){if(r.kty!=="RSA")throw new M("invalid key type","ERR_INVALID_KEY_TYPE");if(r.n==null)throw new M("invalid key modulus","ERR_INVALID_KEY_MODULUS");return et(r.n,"base64url").length*8}var gn=8192,pn=class{_key;constructor(t){this._key=t}verify(t,e){return Kl(this._key,e,t)}marshal(){return Fe.jwkToPkix(this._key)}get bytes(){return oe.encode({Type:at.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Kt(t)?t.then(({bytes:e})=>e):t.bytes}},Nr=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e}genSecret(){return nr(16)}sign(t){return Ml(this._key,t)}get public(){if(this._publicKey==null)throw new M("public key not provided","ERR_PUBKEY_NOT_PROVIDED");return new pn(this._publicKey)}marshal(){return Fe.jwkToPkcs1(this._key)}get bytes(){return ie.encode({Type:at.RSA,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Kt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return q(t,"base58btc")}async export(t,e="pkcs-8"){if(e==="pkcs-8")return Fe.exportToPem(this,t);if(e==="libp2p-key")return vr(this.bytes,t);throw new M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};async function ki(r){let t=Fe.pkcs1ToJwk(r);if(Us(t)>gn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let e=await Ii(t);return new Nr(e.privateKey,e.publicKey)}function L0(r){let t=Fe.pkixToJwk(r);if(Us(t)>gn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");return new pn(t)}async function C0(r){if(Us(r)>gn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Ii(r);return new Nr(t.privateKey,t.publicKey)}async function U0(r){if(r>gn)throw new M("key size is too large","ERR_KEY_SIZE_TOO_LARGE");let t=await Hl(r);return new Nr(t.privateKey,t.publicKey)}var Ci={};mt(Ci,{Secp256k1PrivateKey:()=>yn,Secp256k1PublicKey:()=>mn,generateKeyPair:()=>z0,unmarshalSecp256k1PrivateKey:()=>G0,unmarshalSecp256k1PublicKey:()=>j0});var P0=new Uint32Array([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),$e=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),qe=new Uint32Array(64),Ni=class extends yr{constructor(){super(64,32,8,!1),this.A=$e[0]|0,this.B=$e[1]|0,this.C=$e[2]|0,this.D=$e[3]|0,this.E=$e[4]|0,this.F=$e[5]|0,this.G=$e[6]|0,this.H=$e[7]|0}get(){let{A:t,B:e,C:n,D:s,E:o,F:i,G:a,H:c}=this;return[t,e,n,s,o,i,a,c]}set(t,e,n,s,o,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=s|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)qe[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let p=qe[f-15],y=qe[f-2],g=zt(p,7)^zt(p,18)^p>>>3,h=zt(y,17)^zt(y,19)^y>>>10;qe[f]=h+qe[f-7]+g+qe[f-16]|0}let{A:n,B:s,C:o,D:i,E:a,F:c,G:l,H:u}=this;for(let f=0;f<64;f++){let p=zt(a,6)^zt(a,11)^zt(a,25),y=u+p+mc(a,c,l)+P0[f]+qe[f]|0,h=(zt(n,2)^zt(n,13)^zt(n,22))+yc(n,s,o)|0;u=l,l=c,c=a,a=i+y|0,i=o,o=s,s=n,n=y+h|0}n=n+this.A|0,s=s+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,u=u+this.H|0,this.set(n,s,o,i,a,c,l,u)}roundClean(){qe.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var Rr=Tn(()=>new Ni);function D0(r){let t=Zr(r);Ft(t,{a:"field",b:"field"},{allowedPrivateKeyLengths:"array",wrapPrivateKey:"boolean",isTorsionFree:"function",clearCofactor:"function",allowInfinityPoint:"boolean",fromBytes:"function",toBytes:"function"});let{endo:e,Fp:n,a:s}=t;if(e){if(!n.eql(s,n.ZERO))throw new Error("Endomorphism can only be defined for Koblitz curves that have a=0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error("Expected endomorphism with beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:V0,hexToBytes:O0}=Un,or={Err:class extends Error{constructor(t=""){super(t)}},_parseInt(r){let{Err:t}=or;if(r.length<2||r[0]!==2)throw new t("Invalid signature integer tag");let e=r[1],n=r.subarray(2,e+2);if(!e||n.length!==e)throw new t("Invalid signature integer: wrong length");if(n[0]&128)throw new t("Invalid signature integer: negative");if(n[0]===0&&!(n[1]&128))throw new t("Invalid signature integer: unnecessary leading zero");return{d:V0(n),l:r.subarray(e+2)}},toSig(r){let{Err:t}=or,e=typeof r=="string"?O0(r):r;br(e);let n=e.length;if(n<2||e[0]!=48)throw new t("Invalid signature tag");if(e[1]!==n-2)throw new t("Invalid signature: incorrect length");let{d:s,l:o}=or._parseInt(e.subarray(2)),{d:i,l:a}=or._parseInt(o);if(a.length)throw new t("Invalid signature: left bytes after parsing");return{r:s,s:i}},hexFromSig(r){let t=l=>Number.parseInt(l[0],16)&8?"00"+l:l,e=l=>{let u=l.toString(16);return u.length&1?`0${u}`:u},n=t(e(r.s)),s=t(e(r.r)),o=n.length/2,i=s.length/2,a=e(o),c=e(i);return`30${e(i+o+4)}02${c}${s}02${a}${n}`}},Ie=BigInt(0),qt=BigInt(1),Rw=BigInt(2),$l=BigInt(3),Tw=BigInt(4);function H0(r){let t=D0(r),{Fp:e}=t,n=t.toBytes||((g,h,d)=>{let b=h.toAffine();return we(Uint8Array.from([4]),e.toBytes(b.x),e.toBytes(b.y))}),s=t.fromBytes||(g=>{let h=g.subarray(1),d=e.fromBytes(h.subarray(0,e.BYTES)),b=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:d,y:b}});function o(g){let{a:h,b:d}=t,b=e.sqr(g),v=e.mul(b,g);return e.add(e.add(v,e.mul(g,h)),d)}if(!e.eql(e.sqr(t.Gy),o(t.Gx)))throw new Error("bad generator point: equation left != right");function i(g){return typeof g=="bigint"&&Ie<g&&g<t.n}function a(g){if(!i(g))throw new Error("Expected valid bigint: 0 < bigint < curve.n")}function c(g){let{allowedPrivateKeyLengths:h,nByteLength:d,wrapPrivateKey:b,n:v}=t;if(h&&typeof g!="bigint"){if(Pe(g)&&(g=ge(g)),typeof g!="string"||!h.includes(g.length))throw new Error("Invalid key");g=g.padStart(d*2,"0")}let w;try{w=typeof g=="bigint"?g:me(st("private key",g,d))}catch{throw new Error(`private key must be ${d} bytes, hex or bigint, not ${typeof g}`)}return b&&(w=Z(w,v)),a(w),w}let l=new Map;function u(g){if(!(g instanceof f))throw new Error("ProjectivePoint expected")}class f{constructor(h,d,b){if(this.px=h,this.py=d,this.pz=b,h==null||!e.isValid(h))throw new Error("x required");if(d==null||!e.isValid(d))throw new Error("y required");if(b==null||!e.isValid(b))throw new Error("z required")}static fromAffine(h){let{x:d,y:b}=h||{};if(!h||!e.isValid(d)||!e.isValid(b))throw new Error("invalid affine point");if(h instanceof f)throw new Error("projective point not allowed");let v=w=>e.eql(w,e.ZERO);return v(d)&&v(b)?f.ZERO:new f(d,b,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let d=e.invertBatch(h.map(b=>b.pz));return h.map((b,v)=>b.toAffine(d[v])).map(f.fromAffine)}static fromHex(h){let d=f.fromAffine(s(st("pointHex",h)));return d.assertValidity(),d}static fromPrivateKey(h){return f.BASE.multiply(c(h))}_setWindowSize(h){this._WINDOW_SIZE=h,l.delete(this)}assertValidity(){if(this.is0()){if(t.allowInfinityPoint&&!e.is0(this.py))return;throw new Error("bad point: ZERO")}let{x:h,y:d}=this.toAffine();if(!e.isValid(h)||!e.isValid(d))throw new Error("bad point: x or y not FE");let b=e.sqr(d),v=o(h);if(!e.eql(b,v))throw new Error("bad point: equation left != right");if(!this.isTorsionFree())throw new Error("bad point: not in prime-order subgroup")}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){u(h);let{px:d,py:b,pz:v}=this,{px:w,py:A,pz:B}=h,S=e.eql(e.mul(d,B),e.mul(w,v)),N=e.eql(e.mul(b,B),e.mul(A,v));return S&&N}negate(){return new f(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:d}=t,b=e.mul(d,$l),{px:v,py:w,pz:A}=this,B=e.ZERO,S=e.ZERO,N=e.ZERO,_=e.mul(v,v),V=e.mul(w,w),P=e.mul(A,A),T=e.mul(v,w);return T=e.add(T,T),N=e.mul(v,A),N=e.add(N,N),B=e.mul(h,N),S=e.mul(b,P),S=e.add(B,S),B=e.sub(V,S),S=e.add(V,S),S=e.mul(B,S),B=e.mul(T,B),N=e.mul(b,N),P=e.mul(h,P),T=e.sub(_,P),T=e.mul(h,T),T=e.add(T,N),N=e.add(_,_),_=e.add(N,_),_=e.add(_,P),_=e.mul(_,T),S=e.add(S,_),P=e.mul(w,A),P=e.add(P,P),_=e.mul(P,T),B=e.sub(B,_),N=e.mul(P,V),N=e.add(N,N),N=e.add(N,N),new f(B,S,N)}add(h){u(h);let{px:d,py:b,pz:v}=this,{px:w,py:A,pz:B}=h,S=e.ZERO,N=e.ZERO,_=e.ZERO,V=t.a,P=e.mul(t.b,$l),T=e.mul(d,w),H=e.mul(b,A),O=e.mul(v,B),W=e.add(d,b),x=e.add(w,A);W=e.mul(W,x),x=e.add(T,H),W=e.sub(W,x),x=e.add(d,v);let I=e.add(w,B);return x=e.mul(x,I),I=e.add(T,O),x=e.sub(x,I),I=e.add(b,v),S=e.add(A,B),I=e.mul(I,S),S=e.add(H,O),I=e.sub(I,S),_=e.mul(V,x),S=e.mul(P,O),_=e.add(S,_),S=e.sub(H,_),_=e.add(H,_),N=e.mul(S,_),H=e.add(T,T),H=e.add(H,T),O=e.mul(V,O),x=e.mul(P,x),H=e.add(H,O),O=e.sub(T,O),O=e.mul(V,O),x=e.add(x,O),T=e.mul(H,x),N=e.add(N,T),T=e.mul(I,x),S=e.mul(W,S),S=e.sub(S,T),T=e.mul(W,H),_=e.mul(I,_),_=e.add(_,T),new f(S,N,_)}subtract(h){return this.add(h.negate())}is0(){return this.equals(f.ZERO)}wNAF(h){return y.wNAFCached(this,l,h,d=>{let b=e.invertBatch(d.map(v=>v.pz));return d.map((v,w)=>v.toAffine(b[w])).map(f.fromAffine)})}multiplyUnsafe(h){let d=f.ZERO;if(h===Ie)return d;if(a(h),h===qt)return this;let{endo:b}=t;if(!b)return y.unsafeLadder(this,h);let{k1neg:v,k1:w,k2neg:A,k2:B}=b.splitScalar(h),S=d,N=d,_=this;for(;w>Ie||B>Ie;)w&qt&&(S=S.add(_)),B&qt&&(N=N.add(_)),_=_.double(),w>>=qt,B>>=qt;return v&&(S=S.negate()),A&&(N=N.negate()),N=new f(e.mul(N.px,b.beta),N.py,N.pz),S.add(N)}multiply(h){a(h);let d=h,b,v,{endo:w}=t;if(w){let{k1neg:A,k1:B,k2neg:S,k2:N}=w.splitScalar(d),{p:_,f:V}=this.wNAF(B),{p:P,f:T}=this.wNAF(N);_=y.constTimeNegate(A,_),P=y.constTimeNegate(S,P),P=new f(e.mul(P.px,w.beta),P.py,P.pz),b=_.add(P),v=V.add(T)}else{let{p:A,f:B}=this.wNAF(d);b=A,v=B}return f.normalizeZ([b,v])[0]}multiplyAndAddUnsafe(h,d,b){let v=f.BASE,w=(B,S)=>S===Ie||S===qt||!B.equals(v)?B.multiplyUnsafe(S):B.multiply(S),A=w(this,d).add(w(h,b));return A.is0()?void 0:A}toAffine(h){let{px:d,py:b,pz:v}=this,w=this.is0();h==null&&(h=w?e.ONE:e.inv(v));let A=e.mul(d,h),B=e.mul(b,h),S=e.mul(v,h);if(w)return{x:e.ZERO,y:e.ZERO};if(!e.eql(S,e.ONE))throw new Error("invZ was invalid");return{x:A,y:B}}isTorsionFree(){let{h,isTorsionFree:d}=t;if(h===qt)return!0;if(d)return d(f,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:d}=t;return h===qt?this:d?d(f,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return this.assertValidity(),n(f,this,h)}toHex(h=!0){return ge(this.toRawBytes(h))}}f.BASE=new f(t.Gx,t.Gy,e.ONE),f.ZERO=new f(e.ZERO,e.ONE,e.ZERO);let p=t.nBitLength,y=Vn(f,t.endo?Math.ceil(p/2):p);return{CURVE:t,ProjectivePoint:f,normPrivateKeyToScalar:c,weierstrassEquation:o,isWithinCurveOrder:i}}function M0(r){let t=Zr(r);return Ft(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function ql(r){let t=M0(r),{Fp:e,n}=t,s=e.BYTES+1,o=2*e.BYTES+1;function i(x){return Ie<x&&x<e.ORDER}function a(x){return Z(x,n)}function c(x){return Pn(x,n)}let{ProjectivePoint:l,normPrivateKeyToScalar:u,weierstrassEquation:f,isWithinCurveOrder:p}=H0({...t,toBytes(x,I,C){let E=I.toAffine(),m=e.toBytes(E.x),k=we;return C?k(Uint8Array.from([I.hasEvenY()?2:3]),m):k(Uint8Array.from([4]),m,e.toBytes(E.y))},fromBytes(x){let I=x.length,C=x[0],E=x.subarray(1);if(I===s&&(C===2||C===3)){let m=me(E);if(!i(m))throw new Error("Point is not on curve");let k=f(m),R;try{R=e.sqrt(k)}catch(F){let j=F instanceof Error?": "+F.message:"";throw new Error("Point is not on curve"+j)}let L=(R&qt)===qt;return(C&1)===1!==L&&(R=e.neg(R)),{x:m,y:R}}else if(I===o&&C===4){let m=e.fromBytes(E.subarray(0,e.BYTES)),k=e.fromBytes(E.subarray(e.BYTES,2*e.BYTES));return{x:m,y:k}}else throw new Error(`Point of length ${I} was invalid. Expected ${s} compressed bytes or ${o} uncompressed bytes`)}}),y=x=>ge(De(x,t.nByteLength));function g(x){let I=n>>qt;return x>I}function h(x){return g(x)?a(-x):x}let d=(x,I,C)=>me(x.slice(I,C));class b{constructor(I,C,E){this.r=I,this.s=C,this.recovery=E,this.assertValidity()}static fromCompact(I){let C=t.nByteLength;return I=st("compactSignature",I,C*2),new b(d(I,0,C),d(I,C,2*C))}static fromDER(I){let{r:C,s:E}=or.toSig(st("DER",I));return new b(C,E)}assertValidity(){if(!p(this.r))throw new Error("r must be 0 < r < CURVE.n");if(!p(this.s))throw new Error("s must be 0 < s < CURVE.n")}addRecoveryBit(I){return new b(this.r,this.s,I)}recoverPublicKey(I){let{r:C,s:E,recovery:m}=this,k=N(st("msgHash",I));if(m==null||![0,1,2,3].includes(m))throw new Error("recovery id invalid");let R=m===2||m===3?C+t.n:C;if(R>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let L=m&1?"03":"02",K=l.fromHex(L+y(R)),F=c(R),j=a(-k*F),$=a(E*F),G=l.BASE.multiplyAndAddUnsafe(K,j,$);if(!G)throw new Error("point at infinify");return G.assertValidity(),G}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new b(this.r,a(-this.s),this.recovery):this}toDERRawBytes(){return Ye(this.toDERHex())}toDERHex(){return or.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Ye(this.toCompactHex())}toCompactHex(){return y(this.r)+y(this.s)}}let v={isValidPrivateKey(x){try{return u(x),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{let x=zo(t.n);return _c(t.randomBytes(x),t.n)},precompute(x=8,I=l.BASE){return I._setWindowSize(x),I.multiply(BigInt(3)),I}};function w(x,I=!0){return l.fromPrivateKey(x).toRawBytes(I)}function A(x){let I=Pe(x),C=typeof x=="string",E=(I||C)&&x.length;return I?E===s||E===o:C?E===2*s||E===2*o:x instanceof l}function B(x,I,C=!0){if(A(x))throw new Error("first arg must be private key");if(!A(I))throw new Error("second arg must be public key");return l.fromHex(I).multiply(u(x)).toRawBytes(C)}let S=t.bits2int||function(x){let I=me(x),C=x.length*8-t.nBitLength;return C>0?I>>BigInt(C):I},N=t.bits2int_modN||function(x){return a(S(x))},_=Yr(t.nBitLength);function V(x){if(typeof x!="bigint")throw new Error("bigint expected");if(!(Ie<=x&&x<_))throw new Error(`bigint expected < 2^${t.nBitLength}`);return De(x,t.nByteLength)}function P(x,I,C=T){if(["recovered","canonical"].some(tt=>tt in C))throw new Error("sign() legacy options not supported");let{hash:E,randomBytes:m}=t,{lowS:k,prehash:R,extraEntropy:L}=C;k==null&&(k=!0),x=st("msgHash",x),R&&(x=st("prehashed msgHash",E(x)));let K=N(x),F=u(I),j=[V(F),V(K)];if(L!=null&&L!==!1){let tt=L===!0?m(e.BYTES):L;j.push(st("extraEntropy",tt))}let $=we(...j),G=K;function nt(tt){let vt=S(tt);if(!p(vt))return;let Bt=c(vt),gt=l.BASE.multiply(vt).toAffine(),Nt=a(gt.x);if(Nt===Ie)return;let fe=a(Bt*a(G+Nt*F));if(fe===Ie)return;let Ge=(gt.x===Nt?0:2)|Number(gt.y&qt),qr=fe;return k&&g(fe)&&(qr=h(fe),Ge^=1),new b(Nt,qr,Ge)}return{seed:$,k2sig:nt}}let T={lowS:t.lowS,prehash:!1},H={lowS:t.lowS,prehash:!1};function O(x,I,C=T){let{seed:E,k2sig:m}=P(x,I,C),k=t;return Fo(k.hash.outputLen,k.nByteLength,k.hmac)(E,m)}l.BASE._setWindowSize(8);function W(x,I,C,E=H){let m=x;if(I=st("msgHash",I),C=st("publicKey",C),"strict"in E)throw new Error("options.strict was renamed to lowS");let{lowS:k,prehash:R}=E,L,K;try{if(typeof m=="string"||Pe(m))try{L=b.fromDER(m)}catch(gt){if(!(gt instanceof or.Err))throw gt;L=b.fromCompact(m)}else if(typeof m=="object"&&typeof m.r=="bigint"&&typeof m.s=="bigint"){let{r:gt,s:Nt}=m;L=new b(gt,Nt)}else throw new Error("PARSE");K=l.fromHex(C)}catch(gt){if(gt.message==="PARSE")throw new Error("signature must be Signature instance, Uint8Array or hex string");return!1}if(k&&L.hasHighS())return!1;R&&(I=t.hash(I));let{r:F,s:j}=L,$=N(I),G=c(j),nt=a($*G),tt=a(F*G),vt=l.BASE.multiplyAndAddUnsafe(K,nt,tt)?.toAffine();return vt?a(vt.x)===F:!1}return{CURVE:t,getPublicKey:w,getSharedSecret:B,sign:O,verify:W,ProjectivePoint:l,Signature:b,utils:v}}function K0(r){return{hash:r,hmac:(t,...e)=>Oe(r,t,Rn(...e)),randomBytes:We}}function Gl(r,t){let e=n=>ql({...r,...K0(n)});return Object.freeze({...e(t),create:e})}var Wl=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),jl=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),F0=BigInt(1),Ri=BigInt(2),zl=(r,t)=>(r+t/Ri)/t;function $0(r){let t=Wl,e=BigInt(3),n=BigInt(6),s=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%t,u=l*l*r%t,f=ot(u,e,t)*u%t,p=ot(f,e,t)*u%t,y=ot(p,Ri,t)*l%t,g=ot(y,s,t)*y%t,h=ot(g,o,t)*g%t,d=ot(h,a,t)*h%t,b=ot(d,c,t)*d%t,v=ot(b,a,t)*h%t,w=ot(v,e,t)*u%t,A=ot(w,i,t)*g%t,B=ot(A,n,t)*l%t,S=ot(B,Ri,t);if(!Ti.eql(Ti.sqr(S),r))throw new Error("Cannot find square root");return S}var Ti=Dn(Wl,void 0,void 0,{sqrt:$0}),ee=Gl({a:BigInt(0),b:BigInt(7),Fp:Ti,n:jl,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=jl,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-F0*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),s=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),o=e,i=BigInt("0x100000000000000000000000000000000"),a=zl(o*r,t),c=zl(-n*r,t),l=Z(r-a*e-c*s,t),u=Z(-a*n-c*o,t),f=l>i,p=u>i;if(f&&(l=t-l),p&&(u=t-u),l>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:l,k2neg:p,k2:u}}}},Rr),Mw=BigInt(0);var Kw=ee.ProjectivePoint;function Yl(){return ee.utils.randomPrivateKey()}function Zl(r,t){let e=At.digest(t instanceof Uint8Array?t:t.subarray());if(Kt(e))return e.then(({digest:n})=>ee.sign(n,r).toDERRawBytes()).catch(n=>{throw new M(String(n),"ERR_INVALID_INPUT")});try{return ee.sign(e.digest,r).toDERRawBytes()}catch(n){throw new M(String(n),"ERR_INVALID_INPUT")}}function Xl(r,t,e){let n=At.digest(e instanceof Uint8Array?e:e.subarray());if(Kt(n))return n.then(({digest:s})=>ee.verify(t,s,r)).catch(s=>{throw new M(String(s),"ERR_INVALID_INPUT")});try{return ee.verify(t,n.digest,r)}catch(s){throw new M(String(s),"ERR_INVALID_INPUT")}}function Jl(r){return ee.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Ql(r){try{ee.getPublicKey(r,!0)}catch(t){throw new M(String(t),"ERR_INVALID_PRIVATE_KEY")}}function Li(r){try{ee.ProjectivePoint.fromHex(r)}catch(t){throw new M(String(t),"ERR_INVALID_PUBLIC_KEY")}}function tu(r){try{return ee.getPublicKey(r,!0)}catch(t){throw new M(String(t),"ERR_INVALID_PRIVATE_KEY")}}var mn=class{_key;constructor(t){Li(t),this._key=t}verify(t,e){return Xl(this._key,e,t)}marshal(){return Jl(this._key)}get bytes(){return oe.encode({Type:at.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}async hash(){let t=At.digest(this.bytes),e;return Kt(t)?{bytes:e}=await t:e=t.bytes,e}},yn=class{_key;_publicKey;constructor(t,e){this._key=t,this._publicKey=e??tu(t),Ql(this._key),Li(this._publicKey)}sign(t){return Zl(this._key,t)}get public(){return new mn(this._publicKey)}marshal(){return this._key}get bytes(){return ie.encode({Type:at.Secp256k1,Data:this.marshal()}).subarray()}equals(t){return ft(this.bytes,t.bytes)}hash(){let t=At.digest(this.bytes);return Kt(t)?t.then(({bytes:e})=>e):t.bytes}async id(){let t=await this.public.hash();return q(t,"base58btc")}async export(t,e="libp2p-key"){if(e==="libp2p-key")return vr(this.bytes,t);throw new M(`export format '${e}' is not supported`,"ERR_INVALID_EXPORT_FORMAT")}};function G0(r){return new yn(r)}function j0(r){return new mn(r)}async function z0(){let r=Yl();return new yn(r)}var ir={rsa:_i,ed25519:wi,secp256k1:Ci};function eu(r){let t=Object.keys(ir).join(" / ");return new M(`invalid or unsupported key type ${r}. Must be ${t}`,"ERR_UNSUPPORTED_KEY_TYPE")}function ru(r){let t=oe.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return ir.rsa.unmarshalRsaPublicKey(e);case at.Ed25519:return ir.ed25519.unmarshalEd25519PublicKey(e);case at.Secp256k1:return ir.secp256k1.unmarshalSecp256k1PublicKey(e);default:throw eu(t.Type??"unknown")}}async function Ui(r){let t=ie.decode(r),e=t.Data??new Uint8Array;switch(t.Type){case at.RSA:return ir.rsa.unmarshalRsaPrivateKey(e);case at.Ed25519:return ir.ed25519.unmarshalEd25519PrivateKey(e);case at.Secp256k1:return ir.secp256k1.unmarshalSecp256k1PrivateKey(e);default:throw eu(t.Type??"RSA")}}var W0=Symbol.for("nodejs.util.inspect.custom"),nu=Object.values(ne).map(r=>r.decoder).reduce((r,t)=>r.or(t),ne.identity.decoder),su=114,Pi=36,Di=37,wn=class{type;multihash;privateKey;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,this.privateKey=t.privateKey,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[Ga]=!0;toString(){return this.string==null&&(this.string=ut.encode(this.multihash.bytes).slice(1)),this.string}toCID(){return jt.createV1(su,this.multihash)}toBytes(){return this.multihash.bytes}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return ft(this.multihash.bytes,t);if(typeof t=="string")return Vi(t).equals(this);if(t?.multihash?.bytes!=null)return ft(this.multihash.bytes,t.multihash.bytes);throw new Error("not valid Id")}[W0](){return`PeerId(${this.toString()})`}},Tr=class extends wn{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Lr=class extends wn{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.multihash.digest}},Cr=class extends wn{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.multihash.digest}};function Vi(r,t){if(t=t??nu,r.charAt(0)==="1"||r.charAt(0)==="Q"){let e=Re(ut.decode(`z${r}`));return r.startsWith("12D")?new Lr({multihash:e}):r.startsWith("16U")?new Cr({multihash:e}):new Tr({multihash:e})}return Y0(nu.decode(r))}function Y0(r){try{let t=Re(r);if(t.code===Te.code){if(t.digest.length===Pi)return new Lr({multihash:t});if(t.digest.length===Di)return new Cr({multihash:t})}if(t.code===At.code)return new Tr({multihash:t})}catch{return Z0(jt.decode(r))}throw new Error("Supplied PeerID CID is invalid")}function Z0(r){if(r==null||r.multihash==null||r.version==null||r.version===1&&r.code!==su)throw new Error("Supplied PeerID CID is invalid");let t=r.multihash;if(t.code===At.code)return new Tr({multihash:r.multihash});if(t.code===Te.code){if(t.digest.length===Pi)return new Lr({multihash:r.multihash});if(t.digest.length===Di)return new Cr({multihash:r.multihash})}throw new Error("Supplied PeerID CID is invalid")}async function Oi(r,t){return r.length===Pi?new Lr({multihash:Gt(Te.code,r),privateKey:t}):r.length===Di?new Cr({multihash:Gt(Te.code,r),privateKey:t}):new Tr({multihash:await At.digest(r),publicKey:r,privateKey:t})}var iu=Symbol.for("@achingbrain/uint8arraylist");function ou(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let s=e+n.byteLength;if(t<s)return{buf:n,index:t-e};e=s}throw new RangeError("index is out of bounds")}function Ps(r){return!!r?.[iu]}var ct=class r{bufs;length;[iu]=!0;constructor(...t){this.bufs=[],this.length=0,t.length>0&&this.appendAll(t)}*[Symbol.iterator](){yield*this.bufs}get byteLength(){return this.length}append(...t){this.appendAll(t)}appendAll(t){let e=0;for(let n of t)if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.push(n);else if(Ps(n))e+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}prepend(...t){this.prependAll(t)}prependAll(t){let e=0;for(let n of t.reverse())if(n instanceof Uint8Array)e+=n.byteLength,this.bufs.unshift(n);else if(Ps(n))e+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=e}get(t){let e=ou(this.bufs,t);return e.buf[e.index]}set(t,e){let n=ou(this.bufs,t);n.buf[n.index]=e}write(t,e=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(e+n,t[n]);else if(Ps(t))for(let n=0;n<t.length;n++)this.set(e+n,t.get(n));else throw new Error("Could not write value, must be an Uint8Array or a Uint8ArrayList")}consume(t){if(t=Math.trunc(t),!(Number.isNaN(t)||t<=0)){if(t===this.byteLength){this.bufs=[],this.length=0;return}for(;this.bufs.length>0;)if(t>=this.bufs[0].byteLength)t-=this.bufs[0].byteLength,this.length-=this.bufs[0].byteLength,this.bufs.shift();else{this.bufs[0]=this.bufs[0].subarray(t),this.length-=t;break}}}slice(t,e){let{bufs:n,length:s}=this._subList(t,e);return xt(n,s)}subarray(t,e){let{bufs:n,length:s}=this._subList(t,e);return n.length===1?n[0]:xt(n,s)}sublist(t,e){let{bufs:n,length:s}=this._subList(t,e),o=new r;return o.length=s,o.bufs=[...n],o}_subList(t,e){if(t=t??0,e=e??this.length,t<0&&(t=this.length+t),e<0&&(e=this.length+e),t<0||e>this.length)throw new RangeError("index is out of bounds");if(t===e)return{bufs:[],length:0};if(t===0&&e===this.length)return{bufs:this.bufs,length:this.length};let n=[],s=0;for(let o=0;o<this.bufs.length;o++){let i=this.bufs[o],a=s,c=a+i.byteLength;if(s=c,t>=c)continue;let l=t>=a&&t<c,u=e>a&&e<=c;if(l&&u){if(t===a&&e===c){n.push(i);break}let f=t-a;n.push(i.subarray(f,f+(e-t)));break}if(l){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(u){if(e===c){n.push(i);break}n.push(i.subarray(0,e-a));break}n.push(i)}return{bufs:n,length:e-t}}indexOf(t,e=0){if(!Ps(t)&&!(t instanceof Uint8Array))throw new TypeError('The "value" argument must be a Uint8ArrayList or Uint8Array');let n=t instanceof Uint8Array?t:t.subarray();if(e=Number(e??0),isNaN(e)&&(e=0),e<0&&(e=this.length+e),e<0&&(e=0),t.length===0)return e>this.length?this.length:e;let s=n.byteLength;if(s===0)throw new TypeError("search must be at least 1 byte long");let o=256,i=new Int32Array(o);for(let f=0;f<o;f++)i[f]=-1;for(let f=0;f<s;f++)i[n[f]]=f;let a=i,c=this.byteLength-n.byteLength,l=n.byteLength-1,u;for(let f=e;f<=c;f+=u){u=0;for(let p=l;p>=0;p--){let y=this.get(f+p);if(n[p]!==y){u=Math.max(1,p-a[y]);break}}if(u===0)return f}return-1}getInt8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getInt8(0)}setInt8(t,e){let n=wt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,e),this.write(n,t)}getInt16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,e)}setInt16(t,e,n){let s=yt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt16(0,e,n),this.write(s,t)}getInt32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,e)}setInt32(t,e,n){let s=yt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setInt32(0,e,n),this.write(s,t)}getBigInt64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,e)}setBigInt64(t,e,n){let s=yt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigInt64(0,e,n),this.write(s,t)}getUint8(t){let e=this.subarray(t,t+1);return new DataView(e.buffer,e.byteOffset,e.byteLength).getUint8(0)}setUint8(t,e){let n=wt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,e),this.write(n,t)}getUint16(t,e){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,e)}setUint16(t,e,n){let s=yt(2);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint16(0,e,n),this.write(s,t)}getUint32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,e)}setUint32(t,e,n){let s=yt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setUint32(0,e,n),this.write(s,t)}getBigUint64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,e)}setBigUint64(t,e,n){let s=yt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setBigUint64(0,e,n),this.write(s,t)}getFloat32(t,e){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,e)}setFloat32(t,e,n){let s=yt(4);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat32(0,e,n),this.write(s,t)}getFloat64(t,e){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,e)}setFloat64(t,e,n){let s=yt(8);new DataView(s.buffer,s.byteOffset,s.byteLength).setFloat64(0,e,n),this.write(s,t)}equals(t){if(t==null||!(t instanceof r)||t.bufs.length!==this.bufs.length)return!1;for(let e=0;e<this.bufs.length;e++)if(!ft(this.bufs[e],t.bufs[e]))return!1;return!0}static fromUint8Arrays(t,e){let n=new r;return n.bufs=t,e==null&&(e=t.reduce((s,o)=>s+o.byteLength,0)),n.length=e,n}};function Ds(r){return r[Symbol.asyncIterator]!=null}var Vs=r=>{let t=dt(r),e=wt(t);return se(r,e),Vs.bytes=t,e};Vs.bytes=0;function au(r,t){t=t??{};let e=t.lengthEncoder??Vs;function*n(s){let o=e(s.byteLength);o instanceof Uint8Array?yield o:yield*o,s instanceof Uint8Array?yield s:yield*s}return Ds(r)?async function*(){for await(let s of r)yield*n(s)}():function*(){for(let s of r)yield*n(s)}()}au.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Vs;return new ct(e(r.byteLength),r)};var Ur=qa(uu(),1);var J0=8,Q0=1024*1024*4,ar;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(ar||(ar={}));var Hi=r=>{let t=Xt(r);return Hi.bytes=dt(t),t};Hi.bytes=0;function bn(r,t){let e=new ct,n=ar.LENGTH,s=-1,o=t?.lengthDecoder??Hi,i=t?.maxLengthLength??J0,a=t?.maxDataLength??Q0;function*c(){for(;e.byteLength>0;){if(n===ar.LENGTH)try{if(s=o(e),s<0)throw(0,Ur.default)(new Error("invalid message length"),"ERR_INVALID_MSG_LENGTH");if(s>a)throw(0,Ur.default)(new Error("message length too long"),"ERR_MSG_DATA_TOO_LONG");let l=o.bytes;e.consume(l),t?.onLength!=null&&t.onLength(s),n=ar.DATA}catch(l){if(l instanceof RangeError){if(e.byteLength>i)throw(0,Ur.default)(new Error("message length length too long"),"ERR_MSG_LENGTH_TOO_LONG");break}throw l}if(n===ar.DATA){if(e.byteLength<s)break;let l=e.sublist(0,s);e.consume(s),t?.onData!=null&&t.onData(l),yield l,n=ar.LENGTH}}}return Ds(r)?async function*(){for await(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw(0,Ur.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}():function*(){for(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw(0,Ur.default)(new Error("unexpected end of input"),"ERR_UNEXPECTED_EOF")}()}bn.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:o,value:i}=await r.next(e);if(o===!0)return;i!=null&&(yield i)}catch(o){if(o.code==="ERR_UNDER_READ")return{done:!0,value:null};throw o}finally{e=1}}();return bn(n,{...t??{},onLength:o=>{e=o}})};function Ct(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Os=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.name="AbortError",this.code=e??"ABORT_ERR"}};async function Dt(r,t,e){if(t==null)return r;if(t.aborted)return Promise.reject(new Os(e?.errorMessage,e?.errorCode));let n,s=new Os(e?.errorMessage,e?.errorCode);try{return await Promise.race([r,new Promise((o,i)=>{n=()=>{i(s)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var Mi=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=Ct(),this.haveNext=Ct()}[Symbol.asyncIterator](){return this}async next(){if(this.nextResult==null&&await this.haveNext.promise,this.nextResult==null)throw new Error("HaveNext promise resolved but nextResult was undefined");let t=this.nextResult;return this.nextResult=void 0,this.readNext.resolve(),this.readNext=Ct(),t}async throw(t){return this.ended=!0,t!=null&&this.haveNext.reject(t),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return await this._push(void 0),t}async push(t,e){await this._push(t,e)}async end(t,e){t!=null?await this.throw(t):await this._push(void 0,e)}async _push(t,e){if(t!=null&&this.ended)throw new Error("Cannot push value onto an ended pushable");if(this.nextResult!=null&&(await this.readNext.promise,this.nextResult!=null))throw new Error("NeedNext promise resolved but nextResult was not consumed");t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Ct(),await Dt(this.readNext.promise,e?.signal,e)}};function fu(){return new Mi}var Hs=class extends Error{code;constructor(t,e){super(t),this.code=e}},Ki=class extends Hs{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted"}};function hu(r,t){let e=fu();r.sink(e).catch(async i=>{await e.end(i)}),r.sink=async i=>{for await(let a of i)await e.push(a);await e.end()};let n=r.source;r.source[Symbol.iterator]!=null?n=r.source[Symbol.iterator]():r.source[Symbol.asyncIterator]!=null&&(n=r.source[Symbol.asyncIterator]());let s=new ct;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,l=new Promise((u,f)=>{c=()=>{f(new Ki("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:f,value:p}=await Promise.race([n.next(),l]);return f===!0?new ct:p}for(;s.byteLength<i;){let{value:f,done:p}=await Promise.race([n.next(),l]);if(p===!0)throw new Hs("unexpected end of input","ERR_UNEXPECTED_EOF");s.append(f)}let u=s.sublist(0,i);return s.consume(i),u}finally{c!=null&&a?.signal?.removeEventListener("abort",c)}},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await e.push(i,a):await e.push(i.subarray(),a)},unwrap:()=>{if(s.byteLength>0){let i=r.source;r.source=async function*(){t?.yieldBytes===!1?yield s:yield*s,yield*i}()}return r}}}var Ms=class extends Error{code;constructor(t,e){super(t),this.code=e}};function Fi(r,t={}){let e=hu(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=dt(t.maxDataLength));let n=t?.lengthDecoder??Xt,s=t?.lengthEncoder??se;return{read:async i=>{let a=-1,c=new ct;for(;;){c.append(await e.read(1,i));try{a=n(c)}catch(l){if(l instanceof RangeError)continue;throw l}if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Ms("message length length too long","ERR_MSG_LENGTH_TOO_LONG");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Ms("message length too long","ERR_MSG_DATA_TOO_LONG");return e.read(a,i)},write:async(i,a)=>{await e.write(new ct(s(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new ct(...i.flatMap(l=>[s(l.byteLength),l]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function $i(){let r=Ct(),t=!1;return{sink:async e=>{if(t)throw new Error("already piped");t=!0,r.resolve(e)},source:async function*(){yield*await r.promise}()}}function du(){let r=$i(),t=$i();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var Ks=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||t-1&t)throw new Error("Max size for a FixedFIFO should be a power of two");this.buffer=new Array(t),this.mask=t-1,this.top=0,this.btm=0,this.next=null}push(t){return this.buffer[this.top]!==void 0?!1:(this.buffer[this.top]=t,this.top=this.top+1&this.mask,!0)}shift(){let t=this.buffer[this.btm];if(t!==void 0)return this.buffer[this.btm]=void 0,this.btm=this.btm+1&this.mask,t}isEmpty(){return this.buffer[this.btm]===void 0}},Pr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Ks(this.hwm),this.tail=this.head,this.size=0}calculateSize(t){return t?.byteLength!=null?t.byteLength:1}push(t){if(t?.value!=null&&(this.size+=this.calculateSize(t.value)),!this.head.push(t)){let e=this.head;this.head=e.next=new Ks(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let e=this.tail.next;this.tail.next=null,this.tail=e,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var qi=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Dr(r={}){return tp(e=>{let n=e.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},r)}function tp(r,t){t=t??{};let e=t.onEnd,n=new Pr,s,o,i,a=Ct(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((d,b)=>{o=v=>{o=null,n.push(v);try{d(r(n))}catch(w){b(w)}return s}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ct()})}},l=d=>o!=null?o(d):(n.push(d),s),u=d=>(n=new Pr,o!=null?o({error:d}):(n.push({error:d}),s)),f=d=>{if(i)return s;if(t?.objectMode!==!0&&d?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:d})},p=d=>i?s:(i=!0,d!=null?u(d):l({done:!0})),y=()=>(n=new Pr,p(),{done:!0}),g=d=>(p(d),{done:!0});if(s={[Symbol.asyncIterator](){return this},next:c,return:y,throw:g,push:f,end:p,get readableLength(){return n.size},onEmpty:async d=>{let b=d?.signal;if(b?.throwIfAborted(),n.isEmpty())return;let v,w;b!=null&&(v=new Promise((A,B)=>{w=()=>{B(new qi)},b.addEventListener("abort",w)}));try{await Promise.race([a.promise,v])}finally{w!=null&&b!=null&&b?.removeEventListener("abort",w)}}},e==null)return s;let h=s;return s={[Symbol.asyncIterator](){return this},next(){return h.next()},throw(d){return h.throw(d),e!=null&&(e(d),e=void 0),{done:!0}},return(){return h.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(d){return h.end(d),e!=null&&(e(d),e=void 0),s},get readableLength(){return h.readableLength},onEmpty:d=>h.onEmpty(d)},s}function ep(r){return r[Symbol.asyncIterator]!=null}function rp(...r){let t=[];for(let e of r)ep(e)||t.push(e);return t.length===r.length?function*(){for(let e of t)yield*e}():async function*(){let e=Dr({objectMode:!0});Promise.resolve().then(async()=>{try{await Promise.all(r.map(async n=>{for await(let s of n)e.push(s)})),e.end()}catch(n){e.end(n)}}),yield*e}()}var pu=rp;function gu(r,...t){if(r==null)throw new Error("Empty pipeline");if(Gi(r)){let n=r;r=()=>n.source}else if(yu(r)||mu(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Gi(e[e.length-1])&&(e[e.length-1]=e[e.length-1].sink),e.length>2)for(let n=1;n<e.length-1;n++)Gi(e[n])&&(e[n]=sp(e[n]));return np(...e)}var np=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},mu=r=>r?.[Symbol.asyncIterator]!=null,yu=r=>r?.[Symbol.iterator]!=null,Gi=r=>r==null?!1:r.sink!=null&&r.source!=null,sp=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Dr({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let s,o=r.source;if(mu(o))s=async function*(){yield*o,n.end()};else if(yu(o))s=function*(){yield*o,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return pu(n,s())}return r.source};var Vr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;var _e=r=>new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4));function wu(r){return r instanceof Uint8Array||r!=null&&typeof r=="object"&&r.constructor.name==="Uint8Array"}var bu=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),op=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!op)throw new Error("Non little-endian hardware is not supported");function Fs(r){if(typeof r!="string")throw new Error(`utf8ToBytes expected string, got ${typeof r}`);return new Uint8Array(new TextEncoder().encode(r))}function $s(r){if(typeof r=="string")r=Fs(r);else if(wu(r))r=r.slice();else throw new Error(`expected Uint8Array, got ${typeof r}`);return r}var ip=r=>Object.prototype.toString.call(r)==="[object Object]"&&r.constructor===Object;function xu(r,t){if(t!==void 0&&(typeof t!="object"||!ip(t)))throw new Error("options must be object or undefined");return Object.assign(r,t)}function cr(r,t){if(!wu(r))throw new Error("Uint8Array expected");if(typeof t=="number"&&r.length!==t)throw new Error(`Uint8Array length ${t} expected`)}function Eu(r,t){if(r.length!==t.length)return!1;let e=0;for(let n=0;n<r.length;n++)e|=r[n]^t[n];return e===0}var ji=(r,t)=>(Object.assign(t,r),t);function zi(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let s=BigInt(32),o=BigInt(4294967295),i=Number(e>>s&o),a=Number(e&o),c=n?4:0,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}function qs(r){if(!Number.isSafeInteger(r)||r<0)throw new Error(`wrong positive integer: ${r}`)}function Wi(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}function ap(r){return r!=null&&typeof r=="object"&&(r instanceof Uint8Array||r.constructor.name==="Uint8Array")}function Or(r,...t){if(!ap(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error(`Uint8Array expected of length ${t}, not of length=${r.length}`)}function Yi(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function vu(r,t){Or(r);let e=t.outputLen;if(r.length<e)throw new Error(`digestInto() expects output buffer of length at least ${e}`)}var kt=(r,t)=>r[t++]&255|(r[t++]&255)<<8,Zi=class{constructor(t){this.blockLen=16,this.outputLen=16,this.buffer=new Uint8Array(16),this.r=new Uint16Array(10),this.h=new Uint16Array(10),this.pad=new Uint16Array(8),this.pos=0,this.finished=!1,t=$s(t),cr(t,32);let e=kt(t,0),n=kt(t,2),s=kt(t,4),o=kt(t,6),i=kt(t,8),a=kt(t,10),c=kt(t,12),l=kt(t,14);this.r[0]=e&8191,this.r[1]=(e>>>13|n<<3)&8191,this.r[2]=(n>>>10|s<<6)&7939,this.r[3]=(s>>>7|o<<9)&8191,this.r[4]=(o>>>4|i<<12)&255,this.r[5]=i>>>1&8190,this.r[6]=(i>>>14|a<<2)&8191,this.r[7]=(a>>>11|c<<5)&8065,this.r[8]=(c>>>8|l<<8)&8191,this.r[9]=l>>>5&127;for(let u=0;u<8;u++)this.pad[u]=kt(t,16+2*u)}process(t,e,n=!1){let s=n?0:2048,{h:o,r:i}=this,a=i[0],c=i[1],l=i[2],u=i[3],f=i[4],p=i[5],y=i[6],g=i[7],h=i[8],d=i[9],b=kt(t,e+0),v=kt(t,e+2),w=kt(t,e+4),A=kt(t,e+6),B=kt(t,e+8),S=kt(t,e+10),N=kt(t,e+12),_=kt(t,e+14),V=o[0]+(b&8191),P=o[1]+((b>>>13|v<<3)&8191),T=o[2]+((v>>>10|w<<6)&8191),H=o[3]+((w>>>7|A<<9)&8191),O=o[4]+((A>>>4|B<<12)&8191),W=o[5]+(B>>>1&8191),x=o[6]+((B>>>14|S<<2)&8191),I=o[7]+((S>>>11|N<<5)&8191),C=o[8]+((N>>>8|_<<8)&8191),E=o[9]+(_>>>5|s),m=0,k=m+V*a+P*(5*d)+T*(5*h)+H*(5*g)+O*(5*y);m=k>>>13,k&=8191,k+=W*(5*p)+x*(5*f)+I*(5*u)+C*(5*l)+E*(5*c),m+=k>>>13,k&=8191;let R=m+V*c+P*a+T*(5*d)+H*(5*h)+O*(5*g);m=R>>>13,R&=8191,R+=W*(5*y)+x*(5*p)+I*(5*f)+C*(5*u)+E*(5*l),m+=R>>>13,R&=8191;let L=m+V*l+P*c+T*a+H*(5*d)+O*(5*h);m=L>>>13,L&=8191,L+=W*(5*g)+x*(5*y)+I*(5*p)+C*(5*f)+E*(5*u),m+=L>>>13,L&=8191;let K=m+V*u+P*l+T*c+H*a+O*(5*d);m=K>>>13,K&=8191,K+=W*(5*h)+x*(5*g)+I*(5*y)+C*(5*p)+E*(5*f),m+=K>>>13,K&=8191;let F=m+V*f+P*u+T*l+H*c+O*a;m=F>>>13,F&=8191,F+=W*(5*d)+x*(5*h)+I*(5*g)+C*(5*y)+E*(5*p),m+=F>>>13,F&=8191;let j=m+V*p+P*f+T*u+H*l+O*c;m=j>>>13,j&=8191,j+=W*a+x*(5*d)+I*(5*h)+C*(5*g)+E*(5*y),m+=j>>>13,j&=8191;let $=m+V*y+P*p+T*f+H*u+O*l;m=$>>>13,$&=8191,$+=W*c+x*a+I*(5*d)+C*(5*h)+E*(5*g),m+=$>>>13,$&=8191;let G=m+V*g+P*y+T*p+H*f+O*u;m=G>>>13,G&=8191,G+=W*l+x*c+I*a+C*(5*d)+E*(5*h),m+=G>>>13,G&=8191;let nt=m+V*h+P*g+T*y+H*p+O*f;m=nt>>>13,nt&=8191,nt+=W*u+x*l+I*c+C*a+E*(5*d),m+=nt>>>13,nt&=8191;let tt=m+V*d+P*h+T*g+H*y+O*p;m=tt>>>13,tt&=8191,tt+=W*f+x*u+I*l+C*c+E*a,m+=tt>>>13,tt&=8191,m=(m<<2)+m|0,m=m+k|0,k=m&8191,m=m>>>13,R+=m,o[0]=k,o[1]=R,o[2]=L,o[3]=K,o[4]=F,o[5]=j,o[6]=$,o[7]=G,o[8]=nt,o[9]=tt}finalize(){let{h:t,pad:e}=this,n=new Uint16Array(10),s=t[1]>>>13;t[1]&=8191;for(let a=2;a<10;a++)t[a]+=s,s=t[a]>>>13,t[a]&=8191;t[0]+=s*5,s=t[0]>>>13,t[0]&=8191,t[1]+=s,s=t[1]>>>13,t[1]&=8191,t[2]+=s,n[0]=t[0]+5,s=n[0]>>>13,n[0]&=8191;for(let a=1;a<10;a++)n[a]=t[a]+s,s=n[a]>>>13,n[a]&=8191;n[9]-=8192;let o=(s^1)-1;for(let a=0;a<10;a++)n[a]&=o;o=~o;for(let a=0;a<10;a++)t[a]=t[a]&o|n[a];t[0]=(t[0]|t[1]<<13)&65535,t[1]=(t[1]>>>3|t[2]<<10)&65535,t[2]=(t[2]>>>6|t[3]<<7)&65535,t[3]=(t[3]>>>9|t[4]<<4)&65535,t[4]=(t[4]>>>12|t[5]<<1|t[6]<<14)&65535,t[5]=(t[6]>>>2|t[7]<<11)&65535,t[6]=(t[7]>>>5|t[8]<<8)&65535,t[7]=(t[8]>>>8|t[9]<<5)&65535;let i=t[0]+e[0];t[0]=i&65535;for(let a=1;a<8;a++)i=(t[a]+e[a]|0)+(i>>>16)|0,t[a]=i&65535}update(t){Yi(this);let{buffer:e,blockLen:n}=this;t=$s(t);let s=t.length;for(let o=0;o<s;){let i=Math.min(n-this.pos,s-o);if(i===n){for(;n<=s-o;o+=n)this.process(t,o);continue}e.set(t.subarray(o,o+i),this.pos),this.pos+=i,o+=i,this.pos===n&&(this.process(e,0,!1),this.pos=0)}return this}destroy(){this.h.fill(0),this.r.fill(0),this.buffer.fill(0),this.pad.fill(0)}digestInto(t){Yi(this),vu(t,this),this.finished=!0;let{buffer:e,h:n}=this,{pos:s}=this;if(s){for(e[s++]=1;s<16;s++)e[s]=0;this.process(e,0,!0)}this.finalize();let o=0;for(let i=0;i<8;i++)t[o++]=n[i]>>>0,t[o++]=n[i]>>>8;return t}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}};function cp(r){let t=(n,s)=>r(s).update($s(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var Bu=cp(r=>new Zi(r));var lp=Fs("expand 16-byte k"),up=Fs("expand 32-byte k"),fp=_e(lp),hp=_e(up);function D(r,t){return r<<t|r>>>32-t}function Xi(r){return r.byteOffset%4===0}var Gs=64,dp=16,Su=2**32-1,Au=new Uint32Array;function pp(r,t,e,n,s,o,i,a){let c=s.length,l=new Uint8Array(Gs),u=_e(l),f=Xi(s)&&Xi(o),p=f?_e(s):Au,y=f?_e(o):Au;for(let g=0;g<c;i++){if(r(t,e,n,u,i,a),i>=Su)throw new Error("arx: counter overflow");let h=Math.min(Gs,c-g);if(f&&h===Gs){let d=g/4;if(g%4!==0)throw new Error("arx: invalid block position");for(let b=0,v;b<dp;b++)v=d+b,y[v]=p[v]^u[b];g+=Gs;continue}for(let d=0,b;d<h;d++)b=g+d,o[b]=s[b]^l[d];g+=h}}function Ji(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:s,counterRight:o,rounds:i}=xu({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return qs(s),qs(i),Wi(o),Wi(e),(a,c,l,u,f=0)=>{Or(a),Or(c),Or(l);let p=l.length;if(u||(u=new Uint8Array(p)),Or(u),qs(f),f<0||f>=Su)throw new Error("arx: counter overflow");if(u.length<p)throw new Error(`arx: output (${u.length}) is shorter than data (${p})`);let y=[],g=a.length,h,d;if(g===32)h=a.slice(),y.push(h),d=hp;else if(g===16&&e)h=new Uint8Array(32),h.set(a),h.set(a,16),d=fp,y.push(h);else throw new Error(`arx: invalid 32-byte key, got length=${g}`);Xi(c)||(c=c.slice(),y.push(c));let b=_e(h);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(d,b,_e(c.subarray(0,16)),b),c=c.subarray(16)}let v=16-s;if(v!==c.length)throw new Error(`arx: nonce must be ${v} or 16 bytes`);if(v!==12){let A=new Uint8Array(12);A.set(c,o?0:12-c.length),c=A,y.push(c)}let w=_e(c);for(pp(r,d,b,w,l,u,f,i);y.length>0;)y.pop().fill(0);return u}}function _u(r,t,e,n,s,o=20){let i=r[0],a=r[1],c=r[2],l=r[3],u=t[0],f=t[1],p=t[2],y=t[3],g=t[4],h=t[5],d=t[6],b=t[7],v=s,w=e[0],A=e[1],B=e[2],S=i,N=a,_=c,V=l,P=u,T=f,H=p,O=y,W=g,x=h,I=d,C=b,E=v,m=w,k=A,R=B;for(let K=0;K<o;K+=2)S=S+P|0,E=D(E^S,16),W=W+E|0,P=D(P^W,12),S=S+P|0,E=D(E^S,8),W=W+E|0,P=D(P^W,7),N=N+T|0,m=D(m^N,16),x=x+m|0,T=D(T^x,12),N=N+T|0,m=D(m^N,8),x=x+m|0,T=D(T^x,7),_=_+H|0,k=D(k^_,16),I=I+k|0,H=D(H^I,12),_=_+H|0,k=D(k^_,8),I=I+k|0,H=D(H^I,7),V=V+O|0,R=D(R^V,16),C=C+R|0,O=D(O^C,12),V=V+O|0,R=D(R^V,8),C=C+R|0,O=D(O^C,7),S=S+T|0,R=D(R^S,16),I=I+R|0,T=D(T^I,12),S=S+T|0,R=D(R^S,8),I=I+R|0,T=D(T^I,7),N=N+H|0,E=D(E^N,16),C=C+E|0,H=D(H^C,12),N=N+H|0,E=D(E^N,8),C=C+E|0,H=D(H^C,7),_=_+O|0,m=D(m^_,16),W=W+m|0,O=D(O^W,12),_=_+O|0,m=D(m^_,8),W=W+m|0,O=D(O^W,7),V=V+P|0,k=D(k^V,16),x=x+k|0,P=D(P^x,12),V=V+P|0,k=D(k^V,8),x=x+k|0,P=D(P^x,7);let L=0;n[L++]=i+S|0,n[L++]=a+N|0,n[L++]=c+_|0,n[L++]=l+V|0,n[L++]=u+P|0,n[L++]=f+T|0,n[L++]=p+H|0,n[L++]=y+O|0,n[L++]=g+W|0,n[L++]=h+x|0,n[L++]=d+I|0,n[L++]=b+C|0,n[L++]=v+E|0,n[L++]=w+m|0,n[L++]=A+k|0,n[L++]=B+R|0}function gp(r,t,e,n){let s=r[0],o=r[1],i=r[2],a=r[3],c=t[0],l=t[1],u=t[2],f=t[3],p=t[4],y=t[5],g=t[6],h=t[7],d=e[0],b=e[1],v=e[2],w=e[3];for(let B=0;B<20;B+=2)s=s+c|0,d=D(d^s,16),p=p+d|0,c=D(c^p,12),s=s+c|0,d=D(d^s,8),p=p+d|0,c=D(c^p,7),o=o+l|0,b=D(b^o,16),y=y+b|0,l=D(l^y,12),o=o+l|0,b=D(b^o,8),y=y+b|0,l=D(l^y,7),i=i+u|0,v=D(v^i,16),g=g+v|0,u=D(u^g,12),i=i+u|0,v=D(v^i,8),g=g+v|0,u=D(u^g,7),a=a+f|0,w=D(w^a,16),h=h+w|0,f=D(f^h,12),a=a+f|0,w=D(w^a,8),h=h+w|0,f=D(f^h,7),s=s+l|0,w=D(w^s,16),g=g+w|0,l=D(l^g,12),s=s+l|0,w=D(w^s,8),g=g+w|0,l=D(l^g,7),o=o+u|0,d=D(d^o,16),h=h+d|0,u=D(u^h,12),o=o+u|0,d=D(d^o,8),h=h+d|0,u=D(u^h,7),i=i+f|0,b=D(b^i,16),p=p+b|0,f=D(f^p,12),i=i+f|0,b=D(b^i,8),p=p+b|0,f=D(f^p,7),a=a+c|0,v=D(v^a,16),y=y+v|0,c=D(c^y,12),a=a+c|0,v=D(v^a,8),y=y+v|0,c=D(c^y,7);let A=0;n[A++]=s,n[A++]=o,n[A++]=i,n[A++]=a,n[A++]=d,n[A++]=b,n[A++]=v,n[A++]=w}var mp=Ji(_u,{counterRight:!1,counterLength:4,allowShortKeys:!1}),yp=Ji(_u,{counterRight:!1,counterLength:8,extendNonceFn:gp,allowShortKeys:!1});var wp=new Uint8Array(16),ku=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(wp.subarray(e))},bp=new Uint8Array(32);function Iu(r,t,e,n,s){let o=r(t,e,bp),i=Bu.create(o);s&&ku(i,s),ku(i,n);let a=new Uint8Array(16),c=bu(a);zi(c,0,BigInt(s?s.length:0),!0),zi(c,8,BigInt(n.length),!0),i.update(a);let l=i.digest();return o.fill(0),l}var Nu=r=>(t,e,n)=>(cr(t,32),cr(e),{encrypt:(o,i)=>{let a=o.length,c=a+16;i?cr(i,c):i=new Uint8Array(c),r(t,e,o,i,1);let l=Iu(r,t,e,i.subarray(0,-16),n);return i.set(l,a),i},decrypt:(o,i)=>{let a=o.length,c=a-16;if(a<16)throw new Error("encrypted data must be at least 16 bytes");i?cr(i,c):i=new Uint8Array(c);let l=o.subarray(0,-16),u=o.subarray(-16),f=Iu(r,t,e,l,n);if(!Eu(u,f))throw new Error("invalid tag");return r(t,e,l,i,1),i}}),Qi=ji({blockSize:64,nonceLength:12,tagLength:16},Nu(mp)),cx=ji({blockSize:64,nonceLength:24,tagLength:16},Nu(yp));function Tu(r,t,e){return ze(r),e===void 0&&(e=new Uint8Array(r.outputLen)),Oe(r,Wt(e),Wt(t))}var ta=new Uint8Array([0]),Ru=new Uint8Array;function Lu(r,t,e,n=32){if(ze(r),Le(n),n>255*r.outputLen)throw new Error("Length should be <= 255*HashLen");let s=Math.ceil(n/r.outputLen);e===void 0&&(e=Ru);let o=new Uint8Array(s*r.outputLen),i=Oe.create(r,t),a=i._cloneInto(),c=new Uint8Array(i.outputLen);for(let l=0;l<s;l++)ta[0]=l+1,a.update(l===0?Ru:c).update(e).update(ta).digestInto(c),o.set(c,r.outputLen*l),i._cloneInto(a);return i.destroy(),a.destroy(),c.fill(0),ta.fill(0),o.slice(0,n)}var ea={hashSHA256(r){return Rr(r.subarray())},getHKDF(r,t){let e=Tu(Rr,t,r),s=Lu(Rr,e,void 0,96),o=s.subarray(0,32),i=s.subarray(32,64),a=s.subarray(64,96);return[o,i,a]},generateX25519KeyPair(){let r=Qr.utils.randomPrivateKey();return{publicKey:Qr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:Qr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return Qr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return Qi(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,s){return Qi(n,t,e).decrypt(r.subarray(),s)}};var Cu=ea;function Uu(r){return{generateKeypair:r.generateX25519KeyPair,dh:(t,e)=>r.generateX25519SharedKey(t.privateKey,e).subarray(0,32),encrypt:r.chaCha20Poly1305Encrypt,decrypt:r.chaCha20Poly1305Decrypt,hash:r.hashSHA256,hkdf:r.getHKDF}}var Hr=r=>{let t=wt(2);return t[0]=r>>8,t[1]=r,t};Hr.bytes=2;var xn=r=>{if(r.length<2)throw RangeError("Could not decode int16BE");if(r instanceof Uint8Array){let t=0;return t+=r[0]<<8,t+=r[1],t}return r.getUint16(0)};xn.bytes=2;function Pu(r){return{xxHandshakeSuccesses:r.registerCounter("libp2p_noise_xxhandshake_successes_total",{help:"Total count of noise xxHandshakes successes_"}),xxHandshakeErrors:r.registerCounter("libp2p_noise_xxhandshake_error_total",{help:"Total count of noise xxHandshakes errors"}),encryptedPackets:r.registerCounter("libp2p_noise_encrypted_packets_total",{help:"Total count of noise encrypted packets successfully"}),decryptedPackets:r.registerCounter("libp2p_noise_decrypted_packets_total",{help:"Total count of noise decrypted packets"}),decryptErrors:r.registerCounter("libp2p_noise_decrypt_errors_total",{help:"Total count of noise decrypt errors"})}}function ra(r,t){!t.enabled||!Vr||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${q(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${q(r.privateKey,"hex")}`)):t("Missing local static keys."))}function na(r,t){!t.enabled||!Vr||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${q(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${q(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function Du(r,t){!t.enabled||!Vr||t(r?`REMOTE_STATIC_PUBLIC_KEY ${q(r.subarray(),"hex")}`:"Missing remote static public key.")}function sa(r,t){!t.enabled||!Vr||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${q(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function oa(r,t,e){!e.enabled||!Vr||(e(`CIPHER_STATE_1 ${r.n.getUint64()} ${r.k&&q(r.k,"hex")}`),e(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&q(t.k,"hex")}`))}var js=class r extends Error{code;constructor(t="Unexpected Peer"){super(t),this.code=r.code}static code="ERR_UNEXPECTED_PEER"},Mr=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var xp=0,Ep=4294967295,vp="Cipherstate has reached maximum n, a new handshake must be performed",zs=class{n;bytes;view;constructor(t=xp){this.n=t,this.bytes=yt(12),this.view=new DataView(this.bytes.buffer,this.bytes.byteOffset,this.bytes.byteLength),this.view.setUint32(4,t,!0)}increment(){this.n++,this.view.setUint32(4,this.n,!0)}getBytes(){return this.bytes}getUint64(){return this.n}assertValue(){if(this.n>Ep)throw new Error(vp)}};var lr=yt(0),Kr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new zs(n)}hasKey(){return!!this.k}encryptWithAd(t,e){if(!this.hasKey())return e;this.n.assertValue();let n=this.crypto.encrypt(e,this.n.getBytes(),t,this.k);return this.n.increment(),n}decryptWithAd(t,e,n){if(!this.hasKey())return e;this.n.assertValue();let s=this.crypto.decrypt(e,this.n.getBytes(),t,this.k,n);return this.n.increment(),s}},ia=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=et(e,"utf-8");this.h=Bp(t,n),this.ck=this.h,this.cs=new Kr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new Kr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new ct(this.h,t))}encryptAndHash(t){let e=this.cs.encryptWithAd(this.h,t);return this.mixHash(e),e}decryptAndHash(t){let e=this.cs.decryptWithAd(this.h,t);return this.mixHash(t),e}split(){let[t,e]=this.crypto.hkdf(this.ck,lr);return[new Kr(this.crypto,t),new Kr(this.crypto,e)]}},aa=class{ss;s;e;rs;re;initiator;crypto;constructor(t){let{crypto:e,protocolName:n,prologue:s,initiator:o,s:i,e:a,rs:c,re:l}=t;this.crypto=e,this.ss=new ia(e,n),this.ss.mixHash(s),this.initiator=o,this.s=i,this.e=a,this.rs=c,this.re=l}writeE(){if(this.e)throw new Error("ephemeral keypair is already set");let t=this.crypto.generateKeypair();return this.ss.mixHash(t.publicKey),this.e=t,t.publicKey}writeS(){if(!this.s)throw new Error("static keypair is not set");return this.ss.encryptAndHash(this.s.publicKey)}writeEE(){if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.re))}writeES(){if(this.initiator){if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.rs)throw new Error("remote static public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.rs))}else{if(!this.s)throw new Error("static keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.s,this.re))}}writeSE(){if(this.initiator){if(!this.s)throw new Error("static keypair is not set");if(!this.re)throw new Error("remote ephemeral public key is not set");this.ss.mixKey(this.crypto.dh(this.s,this.re))}else{if(!this.e)throw new Error("ephemeral keypair is not set");if(!this.rs)throw new Error("remote static public key is not set");this.ss.mixKey(this.crypto.dh(this.e,this.rs))}}readE(t,e=0){if(this.re)throw new Error("remote ephemeral public key is already set");if(t.byteLength<e+32)throw new Error("message is not long enough");this.re=t.sublist(e,e+32),this.ss.mixHash(this.re)}readS(t,e=0){if(this.rs)throw new Error("remote static public key is already set");let n=32+(this.ss.cs.hasKey()?16:0);if(t.byteLength<e+n)throw new Error("message is not long enough");let s=t.sublist(e,e+n);return this.rs=this.ss.decryptAndHash(s),n}readEE(){this.writeEE()}readES(){this.writeES()}readSE(){this.writeSE()}},En=class extends aa{writeMessageA(t){return new ct(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new ct(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new ct(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new Mr(`handshake stage 0 validation fail: ${e.message}`)}}readMessageB(t){try{this.readE(t),this.readEE();let e=this.readS(t,32);return this.readES(),this.ss.decryptAndHash(t.sublist(32+e))}catch(e){throw new Mr(`handshake stage 1 validation fail: ${e.message}`)}}readMessageC(t){try{let e=this.readS(t);return this.readSE(),this.ss.decryptAndHash(t.sublist(e))}catch(e){throw new Mr(`handshake stage 2 validation fail: ${e.message}`)}}};function Bp(r,t){if(t.length<=32){let e=yt(32);return e.set(t),e}else return r.hash(t)}var Ws;(function(r){let t;r.codec=()=>(t==null&&(t=er((e,n,s={})=>{if(s.lengthDelimited!==!1&&n.fork(),e.webtransportCerthashes!=null)for(let o of e.webtransportCerthashes)n.uint32(10),n.bytes(o);s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={webtransportCerthashes:[]},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:{s.webtransportCerthashes.push(e.bytes());break}default:{e.skipType(i&7);break}}}return s})),t),r.encode=e=>tr(e,r.codec()),r.decode=e=>Je(e,r.codec())})(Ws||(Ws={}));var vn;(function(r){let t;r.codec=()=>(t==null&&(t=er((e,n,s={})=>{s.lengthDelimited!==!1&&n.fork(),e.identityKey!=null&&e.identityKey.byteLength>0&&(n.uint32(10),n.bytes(e.identityKey)),e.identitySig!=null&&e.identitySig.byteLength>0&&(n.uint32(18),n.bytes(e.identitySig)),e.extensions!=null&&(n.uint32(34),Ws.codec().encode(e.extensions,n)),s.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let s={identityKey:yt(0),identitySig:yt(0)},o=n==null?e.len:e.pos+n;for(;e.pos<o;){let i=e.uint32();switch(i>>>3){case 1:{s.identityKey=e.bytes();break}case 2:{s.identitySig=e.bytes();break}case 4:{s.extensions=Ws.codec().decode(e,e.uint32());break}default:{e.skipType(i&7);break}}}return s})),t),r.encode=e=>tr(e,r.codec()),r.decode=e=>Je(e,r.codec())})(vn||(vn={}));async function ca(r,t,e){let n=await r.sign(Vu(t));return vn.encode({identityKey:r.public.bytes,identitySig:n,extensions:e})}async function la(r,t,e){try{let n=vn.decode(r);if(e){let i=e.subarray();if(!ft(i,n.identityKey))throw new Error(`Payload identity key ${q(n.identityKey,"hex")} does not match expected remote identity key ${q(i,"hex")}`)}if(!t)throw new Error("Remote static does not exist");let s=Vu(t);if(!await ru(n.identityKey).verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new js(n.message)}}function Vu(r){let t=et("noise-libp2p-static-key:");return r instanceof Uint8Array?xt([t,r],t.length+r.length):(r.prepend(t),r)}async function Ou(r){let{log:t,connection:e,crypto:n,privateKey:s,prologue:o,s:i,remoteIdentityKey:a,extensions:c}=r,l=await ca(s,i.publicKey,c),u=new En({crypto:n,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:o,s:i});ra(u.s,t),t.trace("Stage 0 - Initiator starting to send first message."),await e.write(u.writeMessageA(lr)),t.trace("Stage 0 - Initiator finished sending first message."),na(u.e,t),t.trace("Stage 1 - Initiator waiting to receive first message from responder...");let f=u.readMessageB(await e.read());t.trace("Stage 1 - Initiator received the message."),sa(u.re,t),Du(u.rs,t),t.trace("Initiator going to check remote's signature...");let p=await la(f,u.rs,a);t.trace("All good with the signature!"),t.trace("Stage 2 - Initiator sending third handshake message."),await e.write(u.writeMessageC(l)),t.trace("Stage 2 - Initiator sent message with signed payload.");let[y,g]=u.ss.split();return oa(y,g,t),{payload:p,encrypt:h=>y.encryptWithAd(lr,h),decrypt:(h,d)=>g.decryptWithAd(lr,h,d)}}async function Hu(r){let{log:t,connection:e,crypto:n,privateKey:s,prologue:o,s:i,remoteIdentityKey:a,extensions:c}=r,l=await ca(s,i.publicKey,c),u=new En({crypto:n,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:o,s:i});ra(u.s,t),t.trace("Stage 0 - Responder waiting to receive first message."),u.readMessageA(await e.read()),t.trace("Stage 0 - Responder received first message."),sa(u.re,t),t.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await e.write(u.writeMessageB(l)),t.trace("Stage 1 - Responder sent the second handshake message with signed payload."),na(u.e,t),t.trace("Stage 2 - Responder waiting for third handshake message...");let f=u.readMessageC(await e.read());t.trace("Stage 2 - Responder received the message, finished handshake.");let p=await la(f,u.rs,a),[y,g]=u.ss.split();return oa(y,g,t),{payload:p,encrypt:h=>g.encryptWithAd(lr,h),decrypt:(h,d)=>y.decryptWithAd(lr,h,d)}}var Ku=16;function Fu(r,t){return async function*(e){for await(let n of e)for(let s=0;s<n.length;s+=65519){let o=s+65519;o>n.length&&(o=n.length);let i;n instanceof Uint8Array?i=r.encrypt(n.subarray(s,o)):i=r.encrypt(n.sublist(s,o)),t?.encryptedPackets.increment(),yield new ct(Hr(i.byteLength),i)}}}function $u(r,t){return async function*(e){for await(let n of e)for(let s=0;s<n.length;s+=65535){let o=s+65535;if(o>n.length&&(o=n.length),o-Ku<s)throw new Error("Invalid chunk");let i=n.sublist(s,o),a=n.subarray(s,o-Ku);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var Ys=class{protocol="/noise";crypto;prologue;staticKey;extensions;metrics;components;constructor(t,e={}){let{staticNoiseKey:n,extensions:s,crypto:o,prologueBytes:i}=e,{metrics:a}=t;this.components=t;let c=o??Cu;this.crypto=Uu(c),this.extensions=s,this.metrics=a?Pu(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??yt(0)}async secureOutbound(t,e,n){let s=Fi(e,{lengthEncoder:Hr,lengthDecoder:xn,maxDataLength:65535});if(!t.privateKey)throw new M("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let o=await Ui(t.privateKey),i=n?.publicKey,a=await this.performHandshakeInitiator(s,o,i),c=await this.createSecureConnection(s,a);return e.source=c.source,e.sink=c.sink,{conn:e,remoteExtensions:a.payload.extensions,remotePeer:await Oi(a.payload.identityKey)}}async secureInbound(t,e,n){let s=Fi(e,{lengthEncoder:Hr,lengthDecoder:xn,maxDataLength:65535});if(!t.privateKey)throw new M("local peerId does not contain private key","ERR_NO_PRIVATE_KEY");let o=await Ui(t.privateKey),i=n?.publicKey,a=await this.performHandshakeResponder(s,o,i),c=await this.createSecureConnection(s,a);return e.source=c.source,e.sink=c.sink,{conn:e,remoteExtensions:a.payload.extensions,remotePeer:await Oi(a.payload.identityKey)}}async performHandshakeInitiator(t,e,n){let s;try{s=await Ou({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:this.extensions}),this.metrics?.xxHandshakeSuccesses.increment()}catch(o){throw this.metrics?.xxHandshakeErrors.increment(),o}return s}async performHandshakeResponder(t,e,n){let s;try{s=await Hu({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:this.extensions}),this.metrics?.xxHandshakeSuccesses.increment()}catch(o){throw this.metrics?.xxHandshakeErrors.increment(),o}return s}async createSecureConnection(t,e){let[n,s]=du(),o=t.unwrap();return await gu(n,Fu(e,this.metrics),o,i=>bn(i,{lengthDecoder:xn}),$u(e,this.metrics),n),s}};function qu(r={}){return t=>new Ys(t,r)}var Zs=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let e=this.index,n=t();return n===void 0&&(this.index=e),n}parseWith(t){let e=t();if(this.index===this.input.length)return e}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let e=this.readChar();if(e===t)return e})}readSeparator(t,e,n){return this.readAtomically(()=>{if(!(e>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,e,n,s){return this.readAtomically(()=>{let o=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",l=2**(8*s)-1;for(;;){let u=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let p=Number.parseInt(f,t);if(!Number.isNaN(p))return p});if(u===void 0)break;if(o*=t,o+=u,o>l||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&c&&i>1?void 0:o})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let e=0;e<t.length;e++){let n=this.readSeparator(".",e,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[e]=n}return t})}readIPv6Addr(){let t=e=>{for(let n=0;n<e.length/2;n++){let s=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[s]=i[0],e[s+1]=i[1],e[s+2]=i[2],e[s+3]=i[3],[s+4,!0]}let o=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(o===void 0)return[s,!1];e[s]=o>>8,e[s+1]=o&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,s]=t(e);if(n===16)return e;if(s||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let o=new Uint8Array(14),i=16-(n+2),[a]=t(o.subarray(0,i));return e.set(o.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var Gu=45,Ap=15,Fr=new Zs;function ua(r){if(!(r.length>Ap))return Fr.new(r).parseWith(()=>Fr.readIPv4Addr())}function fa(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Gu))return Fr.new(r).parseWith(()=>Fr.readIPv6Addr())}function Xs(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Gu))return Fr.new(r).parseWith(()=>Fr.readIPAddr())}function Js(r){return!!ua(r)}function Qs(r){return!!fa(r)}function to(r){return!!Xs(r)}var j1=parseInt("0xFFFF",16),z1=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Wu=Js,Np=Qs,ha=function(r){let t=0;if(r=r.toString().trim(),Wu(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(Np(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let o=Wu(e[n]),i;o&&(i=ha(e[n]),e[n]=q(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,q(i.slice(2,4),"base16"))}if(e[0]==="")for(;e.length<8;)e.unshift("0");else if(e[e.length-1]==="")for(;e.length<8;)e.push("0");else if(e.length<8){for(n=0;n<e.length&&e[n]!=="";n++);let o=[n,1];for(n=9-e.length;n>0;n--)o.push("0");e.splice.apply(e,o)}let s=new Uint8Array(t+16);for(n=0;n<e.length;n++){let o=parseInt(e[n],16);s[t++]=o>>8&255,s[t++]=o&255}return s}throw new Error("invalid ip address")},Yu=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let s=[];for(let o=0;o<e;o++)s.push(r[t+o]);return s.join(".")}if(e===16){let s=[];for(let o=0;o<e;o+=2)s.push(n.getUint16(t+o).toString(16));return s.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var $r={},da={},Tp=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[777,-1,"memory"]];Tp.forEach(r=>{let t=Lp(...r);da[t.code]=t,$r[t.name]=t});function Lp(r,t,e,n,s){return{code:r,size:t,name:e,resolvable:!!n,path:!!s}}function Q(r){if(typeof r=="number"){if(da[r]!=null)return da[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if($r[r]!=null)return $r[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var _2=Q("ip4"),N2=Q("ip6"),R2=Q("ipcidr");function ga(r,t){switch(Q(r).code){case 4:case 41:return Up(t);case 42:return Ju(t);case 6:case 273:case 33:case 132:return tf(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ju(t);case 421:return Op(t);case 444:return Qu(t);case 445:return Qu(t);case 466:return Vp(t);default:return q(t,"base16")}}function ma(r,t){switch(Q(r).code){case 4:return Zu(t);case 41:return Zu(t);case 42:return Xu(t);case 6:case 273:case 33:case 132:return ya(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Xu(t);case 421:return Pp(t);case 444:return Hp(t);case 445:return Mp(t);case 466:return Dp(t);default:return et(t,"base16")}}var pa=Object.values(ne).map(r=>r.decoder),Cp=function(){let r=pa[0].or(pa[1]);return pa.slice(2).forEach(t=>r=r.or(t)),r}();function Zu(r){if(!to(r))throw new Error("invalid ip address");return ha(r)}function Up(r){let t=Yu(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!to(t))throw new Error("invalid ip address");return t}function ya(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function tf(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Xu(r){let t=et(r),e=Uint8Array.from(se(t.length));return xt([e,t],e.length+t.length)}function Ju(r){let t=Xt(r);if(r=r.slice(dt(t)),r.length!==t)throw new Error("inconsistent lengths");return q(r)}function Pp(r){let t;r[0]==="Q"||r[0]==="1"?t=Re(ut.decode(`z${r}`)).bytes:t=jt.parse(r).multihash.bytes;let e=Uint8Array.from(se(t.length));return xt([e,t],e.length+t.length)}function Dp(r){let t=Cp.decode(r),e=Uint8Array.from(se(t.length));return xt([e,t],e.length+t.length)}function Vp(r){let t=Xt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+q(e,"base64url")}function Op(r){let t=Xt(r),e=r.slice(dt(t));if(e.length!==t)throw new Error("inconsistent lengths");return q(e,"base58btc")}function Hp(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==16)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion address.`);let e=de.decode("b"+t[0]),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=ya(n);return xt([e,s],e.length+s.length)}function Mp(r){let t=r.split(":");if(t.length!==2)throw new Error(`failed to parse onion addr: ["'${t.join('", "')}'"]' does not contain a port number`);if(t[0].length!==56)throw new Error(`failed to parse onion addr: ${t[0]} not a Tor onion3 address.`);let e=de.decode(`b${t[0]}`),n=parseInt(t[1],10);if(n<1||n>65536)throw new Error("Port number is not in range(1, 65536)");let s=ya(n);return xt([e,s],e.length+s.length)}function Qu(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=q(t,"base32"),s=tf(e);return`${n}:${s}`}function ef(r){r=wa(r);let t=[],e=[],n=null,s=r.split("/").slice(1);if(s.length===1&&s[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let o=0;o<s.length;o++){let i=s[o],a=Q(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(o++,o>=s.length)throw nf("invalid address: "+r);if(a.path===!0){n=wa(s.slice(o).join("/")),t.push([a.code,ma(a.code,n)]),e.push([a.code,n]);break}let c=ma(a.code,s[o]);t.push([a.code,c]),e.push([a.code,ga(a.code,c)])}return{string:rf(e),bytes:xa(t),tuples:t,stringTuples:e,path:n}}function ba(r){let t=[],e=[],n=null,s=0;for(;s<r.length;){let o=Xt(r,s),i=dt(o),a=Q(o),c=Kp(a,r.slice(s+i));if(c===0){t.push([o]),e.push([o]),s+=i;continue}let l=r.slice(s+i,s+i+c);if(s+=c+i,s>r.length)throw nf("Invalid address Uint8Array: "+q(r,"base16"));t.push([o,l]);let u=ga(o,l);if(e.push([o,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:rf(e),tuples:t,stringTuples:e,path:n}}function rf(r){let t=[];return r.map(e=>{let n=Q(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),wa(t.join("/"))}function xa(r){return xt(r.map(t=>{let e=Q(t[0]),n=Uint8Array.from(se(e.code));return t.length>1&&t[1]!=null&&(n=xt([n,t[1]])),n}))}function Kp(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Xt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+dt(e)}}function wa(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}function nf(r){return new Error("Error parsing address: "+r)}var Fp=Symbol.for("nodejs.util.inspect.custom"),Ea=Symbol.for("@multiformats/js-multiaddr/multiaddr"),$p=[Q("dns").code,Q("dns4").code,Q("dns6").code,Q("dnsaddr").code],eo=class r{bytes;#e;#t;#r;#n;[Ea]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=ba(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=ef(t)}else if(of(t))e=ba(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#e=e.string,this.#t=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let t,e,n,s,o="",i=Q("tcp"),a=Q("udp"),c=Q("ip4"),l=Q("ip6"),u=Q("dns6"),f=Q("ip6zone");for(let[y,g]of this.stringTuples())y===f.code&&(o=`%${g??""}`),$p.includes(y)&&(e=i.name,s=443,n=`${g??""}${o}`,t=y===u.code?6:4),(y===i.code||y===a.code)&&(e=Q(y).name,s=parseInt(g??"")),(y===c.code||y===l.code)&&(e=Q(y).name,n=`${g??""}${o}`,t=y===l.code?6:4);if(t==null||e==null||n==null||s==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:s}}protos(){return this.#t.map(([t])=>Object.assign({},Q(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>Q(t).name)}tuples(){return this.#t}stringTuples(){return this.#r}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),s=n.lastIndexOf(e);if(s<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,s))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(xa(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,s])=>{n===$r.p2p.code&&t.push([n,s]),n===$r["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?q(ut.decode(`z${n}`),"base58btc"):q(jt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return ft(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(o=>o.resolvable);if(e==null)return[this];let n=sf.get(e.name);if(n==null)throw new M(`no available resolver for ${e.name}`,"ERR_NO_AVAILABLE_RESOLVER");return(await n(this,t)).map(o=>va(o))}nodeAddress(){let t=this.toOptions();if(t.transport!=="tcp"&&t.transport!=="udp")throw new Error(`multiaddr must have a valid format - no protocol with name: "${t.transport}". Must have a valid transport protocol: "{tcp, udp}"`);return{family:t.family,address:t.host,port:t.port}}isThinWaistAddress(t){let e=(t??this).protos();return!(e.length!==2||e[0].code!==4&&e[0].code!==41||e[1].code!==6&&e[1].code!==273)}[Fp](){return`Multiaddr(${this.#e})`}};var sf=new Map;function of(r){return!!r?.[Ea]}function va(r){return new eo(r)}var qp=r=>r.toString().split("/").slice(1),An=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),X=r=>({match:t=>An(e=>e===r).match(t),pattern:r}),so=()=>({match:r=>An(t=>typeof t=="string").match(r),pattern:"{string}"}),oo=()=>({match:r=>An(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),It=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{ut.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),ro=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{To.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),_t=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),Mt=(...r)=>({match:t=>{let e;for(let n of r){let s=n.match(t);s!==!1&&(e==null||s.length<e.length)&&(e=s)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),rt=(...r)=>({match:t=>{for(let e of r){let n=e.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${r.map(t=>t.pattern).join(", ")})`});function ht(...r){function t(s){let o=qp(s);for(let i of r){let a=i.match(o);if(a===!1)return!1;o=a}return o}function e(s){return t(s)!==!1}function n(s){let o=t(s);return o===!1?!1:o.length===0}return{matches:e,exactMatch:n}}var Aa=rt(X("dns4"),so()),Sa=rt(X("dns6"),so()),ka=rt(X("dnsaddr"),so()),af=rt(X("dns"),so()),oE=ht(Aa),iE=ht(Sa),aE=ht(ka),cE=ht(Mt(af,ka,Aa,Sa)),cf=rt(X("ip4"),An(Js)),lf=rt(X("ip6"),An(Qs)),uf=Mt(cf,lf),ue=Mt(uf,af,Aa,Sa,ka),lE=ht(ue),uE=ht(cf),fE=ht(lf),hE=ht(uf),io=rt(ue,X("tcp"),oo()),Sn=rt(ue,X("udp"),oo()),Gp=Mt(io,Sn),dE=ht(io),pE=ht(Sn),Ia=rt(Sn,X("quic")),ao=rt(Sn,X("quic-v1")),jp=Mt(Ia,ao),gE=ht(Ia),mE=ht(ao),Ba=Mt(ue,io,Sn,Ia,ao),ff=Mt(rt(Ba,X("ws"),_t(It()))),yE=ht(ff),hf=Mt(rt(Ba,X("wss"),_t(It())),rt(Ba,X("tls"),X("ws"),_t(It()))),wE=ht(hf),df=rt(Gp,X("webrtc-direct"),ro(),_t(ro()),_t(It())),bE=ht(df),pf=rt(ao,X("webtransport"),_t(ro()),_t(ro()),_t(It())),co=ht(pf),no=Mt(ff,hf,rt(io,_t(It())),rt(jp,_t(It())),rt(ue,_t(It())),df,pf,It()),xE=ht(no),zp=rt(no,X("p2p-circuit"),It()),EE=ht(zp),Wp=Mt(rt(no,X("p2p-circuit"),X("webrtc"),It()),rt(no,X("webrtc"),_t(It())),X("webrtc")),vE=ht(Wp),Yp=Mt(rt(ue,X("tcp"),oo(),X("http"),_t(It())),rt(ue,X("http"),_t(It()))),BE=ht(Yp),Zp=Mt(rt(ue,X("tcp"),Mt(rt(X("443"),X("http")),rt(oo(),X("https"))),_t(It())),rt(ue,X("tls"),X("http"),_t(It())),rt(ue,X("https"),_t(It()))),AE=ht(Zp);function _a(r){throw new Error("Not implemented")}function gf(r){if(r!=null){if(typeof r[Symbol.iterator]=="function")return r[Symbol.iterator]();if(typeof r[Symbol.asyncIterator]=="function")return r[Symbol.asyncIterator]();if(typeof r.next=="function")return r}throw new Error("argument is not an iterator or iterable")}function mf(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function yf(r,t){let e=gf(r).return?.();mf(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var Xp="ERR_STREAM_RESET",Jp="ERR_SINK_INVALID_STATE",Qp=5e3;function Na(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var lo=class{id;direction;timeline;protocol;metadata;source;status;readStatus;writeStatus;log;sinkController;sinkEnd;closed;endErr;streamSource;onEnd;onCloseRead;onCloseWrite;onReset;onAbort;sendCloseWriteTimeout;sendingData;constructor(t){this.sinkController=new AbortController,this.sinkEnd=Ct(),this.closed=Ct(),this.log=t.log,this.status="open",this.readStatus="ready",this.writeStatus="ready",this.id=t.id,this.metadata=t.metadata??{},this.direction=t.direction,this.timeline={open:Date.now()},this.sendCloseWriteTimeout=t.sendCloseWriteTimeout??Qp,this.onEnd=t.onEnd,this.onCloseRead=t?.onCloseRead,this.onCloseWrite=t?.onCloseWrite,this.onReset=t?.onReset,this.onAbort=t?.onAbort,this.source=this.streamSource=Dr({onEnd:e=>{e!=null?this.log.trace("source ended with error",e):this.log.trace("source ended"),this.onSourceEnd(e)}}),this.sink=this.sink.bind(this)}async sink(t){if(this.writeStatus!=="ready")throw new M(`writable end state is "${this.writeStatus}" not "ready"`,Jp);try{this.writeStatus="writing";let e={signal:this.sinkController.signal};if(this.direction==="outbound"){let s=this.sendNewStream(e);Na(s)&&await s}let n=()=>{yf(t,this.log)};try{this.sinkController.signal.addEventListener("abort",n),this.log.trace("sink reading from source");for await(let s of t){s=s instanceof Uint8Array?new ct(s):s;let o=this.sendData(s,e);Na(o)&&(this.sendingData=Ct(),await o,this.sendingData.resolve(),this.sendingData=void 0)}}finally{this.sinkController.signal.removeEventListener("abort",n)}this.log.trace('sink finished reading from source, write status is "%s"',this.writeStatus),this.writeStatus==="writing"&&(this.writeStatus="closing",this.log.trace("send close write to remote"),await this.sendCloseWrite({signal:AbortSignal.timeout(this.sendCloseWriteTimeout)}),this.writeStatus="closed"),this.onSinkEnd()}catch(e){throw this.log.trace("sink ended with error, calling abort with error",e),this.abort(e),e}finally{this.log.trace("resolve sink end"),this.sinkEnd.resolve()}}onSourceEnd(t){this.timeline.closeRead==null&&(this.timeline.closeRead=Date.now(),this.readStatus="closed",t!=null&&this.endErr==null&&(this.endErr=t),this.onCloseRead?.(),this.timeline.closeWrite!=null?(this.log.trace("source and sink ended"),this.timeline.close=Date.now(),this.status!=="aborted"&&this.status!=="reset"&&(this.status="closed"),this.onEnd!=null&&this.onEnd(this.endErr),this.closed.resolve()):this.log.trace("source ended, waiting for sink to end"))}onSinkEnd(t){this.timeline.closeWrite==null&&(this.timeline.closeWrite=Date.now(),this.writeStatus="closed",t!=null&&this.endErr==null&&(this.endErr=t),this.onCloseWrite?.(),this.timeline.closeRead!=null?(this.log.trace("sink and source ended"),this.timeline.close=Date.now(),this.status!=="aborted"&&this.status!=="reset"&&(this.status="closed"),this.onEnd!=null&&this.onEnd(this.endErr),this.closed.resolve()):this.log.trace("sink ended, waiting for source to end"))}async close(t){this.log.trace("closing gracefully"),this.status="closing",await Dt(Promise.all([this.closeWrite(t),this.closeRead(t),this.closed.promise]),t?.signal),this.status="closed",this.log.trace("closed gracefully")}async closeRead(t={}){if(this.readStatus==="closing"||this.readStatus==="closed")return;this.log.trace('closing readable end of stream with starting read status "%s"',this.readStatus);let e=this.readStatus;this.readStatus="closing",this.status!=="reset"&&this.status!=="aborted"&&this.timeline.closeRead==null&&(this.log.trace("send close read to remote"),await this.sendCloseRead(t)),e==="ready"&&(this.log.trace("ending internal source queue with %d queued bytes",this.streamSource.readableLength),this.streamSource.end()),this.log.trace("closed readable end of stream")}async closeWrite(t={}){this.writeStatus==="closing"||this.writeStatus==="closed"||(this.log.trace('closing writable end of stream with starting write status "%s"',this.writeStatus),this.writeStatus==="ready"&&(this.log.trace("sink was never sunk, sink an empty array"),await Dt(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await Dt(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await Dt(this.sinkEnd.promise,t.signal)),this.writeStatus="closed",this.log.trace("closed writable end of stream"))}abort(t){if(this.status==="closed"||this.status==="aborted"||this.status==="reset")return;this.log("abort with error",t),this.log("try to send reset to remote");let e=this.sendReset();Na(e)&&e.catch(n=>{this.log.error("error sending reset message",n)}),this.status="aborted",this.timeline.abort=Date.now(),this._closeSinkAndSource(t),this.onAbort?.(t)}reset(){if(this.status==="closed"||this.status==="aborted"||this.status==="reset")return;let t=new M("stream reset",Xp);this.status="reset",this.timeline.reset=Date.now(),this._closeSinkAndSource(t),this.onReset?.()}_closeSinkAndSource(t){this._closeSink(t),this._closeSource(t)}_closeSink(t){this.writeStatus==="writing"&&(this.log.trace("end sink source"),this.sinkController.abort()),this.onSinkEnd(t)}_closeSource(t){this.readStatus!=="closing"&&this.readStatus!=="closed"&&(this.log.trace("ending source with %d bytes to be read by consumer",this.streamSource.readableLength),this.readStatus="closing",this.streamSource.end(t))}remoteCloseWrite(){if(this.readStatus==="closing"||this.readStatus==="closed"){this.log("received remote close write but local source is already closed");return}this.log.trace("remote close write"),this._closeSource()}remoteCloseRead(){if(this.writeStatus==="closing"||this.writeStatus==="closed"){this.log("received remote close read but local sink is already closed");return}this.log.trace("remote close read"),this._closeSink()}destroy(){if(this.status==="closed"||this.status==="aborted"||this.status==="reset"){this.log("received destroy but we are already closed");return}this.log.trace("stream destroyed"),this._closeSinkAndSource()}sourcePush(t){this.streamSource.push(t)}sourceReadableLength(){return this.streamSource.readableLength}};var Ra=class extends lo{writer;reader;constructor(t){super(t),this.writer=t.bidiStream.writable.getWriter(),this.reader=t.bidiStream.readable.getReader(),Promise.resolve().then(async()=>{for(;;){let e=await this.reader.read();if(e.done){t.log("remote closed write");return}e.value!=null&&this.sourcePush(new ct(e.value))}}).catch(e=>{t.log.error("error reading from stream",e),this.abort(e)}).finally(()=>{this.remoteCloseWrite()}),this.writer.closed.then(()=>{t.log("writer closed")}).catch(e=>{t.log("writer close promise rejected",e)}).finally(()=>{this.remoteCloseRead()})}sendNewStream(t){}async sendData(t,e){for await(let n of t)this.log("sendData waiting for writer to be ready"),await Dt(this.writer.ready,e?.signal),this.writer.write(n).catch(s=>{this.log.error("error sending stream data",s)})}async sendReset(t){this.log("sendReset aborting writer"),await Dt(this.writer.abort(),t?.signal),this.log("sendReset aborted writer")}async sendCloseWrite(t){this.log("sendCloseWrite closing writer"),await Dt(this.writer.close(),t?.signal),this.log("sendCloseWrite closed writer")}async sendCloseRead(t){this.log("sendCloseRead cancelling reader"),await Dt(this.reader.cancel(),t?.signal),this.log("sendCloseRead cancelled reader")}};async function Ta(r,t,e,n,s,o){let i=o.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=new Ra({bidiStream:r,id:t,direction:e,log:i,onEnd:()=>{let c=n.findIndex(l=>l===a);c!==-1&&n.splice(c,1),s?.(a)}});return a}function uo(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function wf(r,t,e,n){let s=0,o=e.forComponent("libp2p:webtransport:muxer");return{protocol:"webtransport",createStreamMuxer:i=>{typeof i=="function"&&(i={onIncomingStream:i});let a=[];Promise.resolve().then(async()=>{for(;;){let{done:l,value:u}=await t.read();if(l)break;if(a.length>=n.maxInboundStreams)o(`too many inbound streams open - ${a.length}/${n.maxInboundStreams}, closing new incoming stream`),u.writable.close().catch(f=>{o.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${f.message}`)}),u.readable.cancel().catch(f=>{o.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${f.message}`)});else{let f=await Ta(u,String(s++),"inbound",a,i?.onStreamEnd,e);a.push(f),i?.onIncomingStream?.(f)}}}).catch(l=>{o.error("could not create a new stream",l)});let c={protocol:"webtransport",streams:a,newStream:async l=>{o("new outgoing stream",l);let u=await r.createBidirectionalStream(),f=await Ta(u,String(s++),i?.direction??"outbound",a,i?.onStreamEnd,e);return a.push(f),f},close:async()=>{o("closing webtransport muxer gracefully");try{r.close()}catch(l){c.abort(l)}},abort:l=>{o("closing webtransport muxer with err:",l);try{r.close()}catch(u){o.error("webtransport session threw error during close",u)}},...uo()};return c}}}function bf(r,t){return t.filter(n=>!!r.find(s=>ft(n,s))).length===t.length}var tg=Object.values(ne).map(r=>r.decoder).reduce((r,t)=>r.or(t));function eg(r){return re.decode(tg.decode(r))}function La(r){if(!co.matches(r))throw new M("Invalid multiaddr, was not a WebTransport address","ERR_INVALID_MULTIADDR");let t=r.stringTuples(),e=t.filter(([i,a])=>i===Q("certhash").code).map(([i,a])=>eg(a??"")),n=t.filter(([i,a])=>i===Q("p2p").code).map(([i,a])=>Vi(a??""))[0],s=r.toOptions(),o=s.host;return s.family===6&&o?.includes(":")&&(o=`[${o}]`),{url:`https://${o}:${s.port}`,certhashes:e,remotePeer:n}}var xf=WebTransport;var Ca=class{log;components;config;metrics;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:webtransport"),this.components=t,this.config={...e,maxInboundStreams:e.maxInboundStreams??1e3,certificates:e.certificates??[]},t.metrics!=null&&(this.metrics={dialerEvents:t.metrics.registerCounterGroup("libp2p_webtransport_dialer_events_total",{label:"event",help:"Total count of WebTransport dialer events by type"})})}[Symbol.toStringTag]="@libp2p/webtransport";[za]=!0;async dial(t,e){if(e?.signal?.aborted===!0)throw new Gr;this.log("dialing %s",t);let n=this.components.peerId;if(n===void 0)throw new M("Need a local peerid","ERR_INVALID_PARAMETERS");e=e??{};let{url:s,certhashes:o,remotePeer:i}=La(t),a,c,l=()=>{},u=!1,f=!1,p=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let y=new xf(`${s}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(g=>({algorithm:"sha-256",value:g.digest}))});if(l=g=>{if(!u)try{this.metrics?.dialerEvents.increment({[g]:!0}),y.close()}catch(h){this.log.error("error closing wt session",h)}finally{c!=null&&(c.timeline.close=Date.now()),u=!0}},a=()=>{l(f?"noise_timeout":"ready_timeout")},e.signal?.addEventListener("abort",a,{once:!0}),this.log("wait for session to be ready"),await Promise.race([y.closed,y.ready]),this.log("session became ready"),f=!0,this.metrics?.dialerEvents.increment({ready:!0}),y.closed.catch(g=>{this.log.error("error on remote wt session close",g)}).finally(()=>{l("remote_close")}),p=await Dt(this.authenticateWebTransport(y,n,i,o),e.signal),!p)throw new M("Failed to authenticate webtransport","ERR_AUTHENTICATION_FAILED");return this.metrics?.dialerEvents.increment({open:!0}),c={close:async()=>{this.log("closing webtransport"),l("close")},abort:g=>{this.log("aborting webtransport due to passed err",g),l("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...uo()},await e.upgrader.upgradeOutbound(c,{skipEncryption:!0,muxerFactory:wf(y,y.incomingBidirectionalStreams.getReader(),this.components.logger,this.config),skipProtection:!0})}catch(y){throw this.log.error("caught wt session err",y),l(p?"upgrade_error":f?"noise_error":"ready_error"),y}finally{a!=null&&e.signal?.removeEventListener("abort",a)}}async authenticateWebTransport(t,e,n,s=[],o){if(o?.aborted===!0)throw new Gr;let i=await t.createBidirectionalStream(),a=i.writable.getWriter(),c=i.readable.getReader(),l={source:async function*(){for(;;){let p=await c.read();if(p.value!=null&&(yield p.value),p.done)break}}(),sink:async p=>{for await(let y of p){await Dt(a.ready,o);let g=y instanceof Uint8Array?y:y.subarray();a.write(g).catch(h=>{this.log.error("could not write chunk during authentication of WebTransport stream",h)})}}},u=qu()(this.components),{remoteExtensions:f}=await u.secureOutbound(e,l,n);if(a.close().catch(p=>{this.log.error(`Failed to close authentication stream writer: ${p.message}`)}),c.cancel().catch(p=>{this.log.error(`Failed to close authentication stream reader: ${p.message}`)}),!bf(f?.webtransportCerthashes??[],s.map(p=>p.bytes)))throw new Error("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return _a(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return t.filter(e=>{if(!co.exactMatch(e))return!1;let{url:n,certhashes:s}=La(e);return n!=null&&s.length>0})}};function rg(r={}){return t=>new Ca(t,r)}return Uf(ng);})();
|
|
8
8
|
//! TODO unclear how to add backpressure here?
|
|
9
9
|
/*! Bundled license information:
|
|
10
10
|
|
package/dist/src/muxer.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"muxer.d.ts","sourceRoot":"","sources":["../../src/muxer.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,YAAY,MAAM,mBAAmB,CAAA;AACjD,OAAO,KAAK,EAAE,eAAe,EAAuB,kBAAkB,EAAmB,MAAM,mBAAmB,CAAA;AAElH,MAAM,WAAW,qBAAqB;IACpC,iBAAiB,EAAE,MAAM,CAAA;CAC1B;AAED,wBAAgB,iBAAiB,CAAE,EAAE,EAAE,IAAI,CAAC,YAAY,EAAE,OAAO,GAAG,2BAA2B,CAAC,EAAE,MAAM,EAAE,2BAA2B,CAAC,+BAA+B,CAAC,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,EAAE,qBAAqB,GAAG,kBAAkB,
|
|
1
|
+
{"version":3,"file":"muxer.d.ts","sourceRoot":"","sources":["../../src/muxer.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,YAAY,MAAM,mBAAmB,CAAA;AACjD,OAAO,KAAK,EAAE,eAAe,EAAuB,kBAAkB,EAAmB,MAAM,mBAAmB,CAAA;AAElH,MAAM,WAAW,qBAAqB;IACpC,iBAAiB,EAAE,MAAM,CAAA;CAC1B;AAED,wBAAgB,iBAAiB,CAAE,EAAE,EAAE,IAAI,CAAC,YAAY,EAAE,OAAO,GAAG,2BAA2B,CAAC,EAAE,MAAM,EAAE,2BAA2B,CAAC,+BAA+B,CAAC,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,EAAE,qBAAqB,GAAG,kBAAkB,CAmGlP"}
|
package/dist/src/muxer.js
CHANGED
|
@@ -12,7 +12,8 @@ export function webtransportMuxer(wt, reader, logger, config) {
|
|
|
12
12
|
init = { onIncomingStream: init };
|
|
13
13
|
}
|
|
14
14
|
const activeStreams = [];
|
|
15
|
-
|
|
15
|
+
Promise.resolve()
|
|
16
|
+
.then(async () => {
|
|
16
17
|
//! TODO unclear how to add backpressure here?
|
|
17
18
|
while (true) {
|
|
18
19
|
const { done, value: wtStream } = await reader.read();
|
|
@@ -35,6 +36,9 @@ export function webtransportMuxer(wt, reader, logger, config) {
|
|
|
35
36
|
init?.onIncomingStream?.(stream);
|
|
36
37
|
}
|
|
37
38
|
}
|
|
39
|
+
})
|
|
40
|
+
.catch(err => {
|
|
41
|
+
log.error('could not create a new stream', err);
|
|
38
42
|
});
|
|
39
43
|
const muxer = {
|
|
40
44
|
protocol: 'webtransport',
|
|
@@ -51,14 +55,24 @@ export function webtransportMuxer(wt, reader, logger, config) {
|
|
|
51
55
|
*/
|
|
52
56
|
close: async () => {
|
|
53
57
|
log('closing webtransport muxer gracefully');
|
|
54
|
-
|
|
58
|
+
try {
|
|
59
|
+
wt.close();
|
|
60
|
+
}
|
|
61
|
+
catch (err) {
|
|
62
|
+
muxer.abort(err);
|
|
63
|
+
}
|
|
55
64
|
},
|
|
56
65
|
/**
|
|
57
66
|
* Abort all tracked streams and stop the muxer
|
|
58
67
|
*/
|
|
59
68
|
abort: (err) => {
|
|
60
69
|
log('closing webtransport muxer with err:', err);
|
|
61
|
-
|
|
70
|
+
try {
|
|
71
|
+
wt.close();
|
|
72
|
+
}
|
|
73
|
+
catch (err) {
|
|
74
|
+
log.error('webtransport session threw error during close', err);
|
|
75
|
+
}
|
|
62
76
|
},
|
|
63
77
|
// This stream muxer is webtransport native. Therefore it doesn't plug in with any other duplex.
|
|
64
78
|
...inertDuplex()
|
package/dist/src/muxer.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"muxer.js","sourceRoot":"","sources":["../../src/muxer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,8BAA8B,EAAE,MAAM,aAAa,CAAA;AAC5D,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAQrD,MAAM,UAAU,iBAAiB,CAAE,EAA6D,EAAE,MAAoE,EAAE,MAAuB,EAAE,MAA6B;IAC5N,IAAI,eAAe,GAAG,CAAC,CAAA;IACvB,MAAM,GAAG,GAAG,MAAM,CAAC,YAAY,CAAC,2BAA2B,CAAC,CAAA;IAE5D,OAAO;QACL,QAAQ,EAAE,cAAc;QACxB,iBAAiB,EAAE,CAAC,IAAsB,EAAe,EAAE;YACzD,6DAA6D;YAE7D,IAAI,OAAO,IAAI,KAAK,UAAU,EAAE,CAAC;gBAC/B,+CAA+C;gBAC/C,IAAI,GAAG,EAAE,gBAAgB,EAAE,IAAI,EAAE,CAAA;YACnC,CAAC;YAED,MAAM,aAAa,GAAa,EAAE,CAAA;YAElC,
|
|
1
|
+
{"version":3,"file":"muxer.js","sourceRoot":"","sources":["../../src/muxer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,8BAA8B,EAAE,MAAM,aAAa,CAAA;AAC5D,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAA;AAQrD,MAAM,UAAU,iBAAiB,CAAE,EAA6D,EAAE,MAAoE,EAAE,MAAuB,EAAE,MAA6B;IAC5N,IAAI,eAAe,GAAG,CAAC,CAAA;IACvB,MAAM,GAAG,GAAG,MAAM,CAAC,YAAY,CAAC,2BAA2B,CAAC,CAAA;IAE5D,OAAO;QACL,QAAQ,EAAE,cAAc;QACxB,iBAAiB,EAAE,CAAC,IAAsB,EAAe,EAAE;YACzD,6DAA6D;YAE7D,IAAI,OAAO,IAAI,KAAK,UAAU,EAAE,CAAC;gBAC/B,+CAA+C;gBAC/C,IAAI,GAAG,EAAE,gBAAgB,EAAE,IAAI,EAAE,CAAA;YACnC,CAAC;YAED,MAAM,aAAa,GAAa,EAAE,CAAA;YAElC,OAAO,CAAC,OAAO,EAAE;iBACd,IAAI,CAAC,KAAK,IAAI,EAAE;gBACf,8CAA8C;gBAC9C,OAAO,IAAI,EAAE,CAAC;oBACZ,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,MAAM,MAAM,CAAC,IAAI,EAAE,CAAA;oBAErD,IAAI,IAAI,EAAE,CAAC;wBACT,MAAK;oBACP,CAAC;oBAED,IAAI,aAAa,CAAC,MAAM,IAAI,MAAM,CAAC,iBAAiB,EAAE,CAAC;wBACrD,GAAG,CAAC,mCAAmC,aAAa,CAAC,MAAM,IAAI,MAAM,CAAC,iBAAiB,+BAA+B,CAAC,CAAA;wBACvH,8CAA8C;wBAC9C,QAAQ,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,CAAC,GAAU,EAAE,EAAE;4BAC7C,GAAG,CAAC,KAAK,CAAC,2EAA2E,GAAG,CAAC,OAAO,EAAE,CAAC,CAAA;wBACrG,CAAC,CAAC,CAAA;wBACF,QAAQ,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,CAAC,GAAU,EAAE,EAAE;4BAC9C,GAAG,CAAC,KAAK,CAAC,2EAA2E,GAAG,CAAC,OAAO,EAAE,CAAC,CAAA;wBACrG,CAAC,CAAC,CAAA;oBACJ,CAAC;yBAAM,CAAC;wBACN,MAAM,MAAM,GAAG,MAAM,8BAA8B,CACjD,QAAQ,EACR,MAAM,CAAC,eAAe,EAAE,CAAC,EACzB,SAAS,EACT,aAAa,EACb,IAAI,EAAE,WAAW,EACjB,MAAM,CACP,CAAA;wBACD,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;wBAC1B,IAAI,EAAE,gBAAgB,EAAE,CAAC,MAAM,CAAC,CAAA;oBAClC,CAAC;gBACH,CAAC;YACH,CAAC,CAAC;iBACD,KAAK,CAAC,GAAG,CAAC,EAAE;gBACX,GAAG,CAAC,KAAK,CAAC,+BAA+B,EAAE,GAAG,CAAC,CAAA;YACjD,CAAC,CAAC,CAAA;YAEJ,MAAM,KAAK,GAAgB;gBACzB,QAAQ,EAAE,cAAc;gBACxB,OAAO,EAAE,aAAa;gBACtB,SAAS,EAAE,KAAK,EAAE,IAAa,EAAmB,EAAE;oBAClD,GAAG,CAAC,qBAAqB,EAAE,IAAI,CAAC,CAAA;oBAEhC,MAAM,QAAQ,GAAG,MAAM,EAAE,CAAC,yBAAyB,EAAE,CAAA;oBACrD,MAAM,MAAM,GAAG,MAAM,8BAA8B,CAAC,QAAQ,EAAE,MAAM,CAAC,eAAe,EAAE,CAAC,EAAE,IAAI,EAAE,SAAS,IAAI,UAAU,EAAE,aAAa,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,CAAC,CAAA;oBACjK,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;oBAE1B,OAAO,MAAM,CAAA;gBACf,CAAC;gBAED;;mBAEG;gBACH,KAAK,EAAE,KAAK,IAAI,EAAE;oBAChB,GAAG,CAAC,uCAAuC,CAAC,CAAA;oBAE5C,IAAI,CAAC;wBACH,EAAE,CAAC,KAAK,EAAE,CAAA;oBACZ,CAAC;oBAAC,OAAO,GAAQ,EAAE,CAAC;wBAClB,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;oBAClB,CAAC;gBACH,CAAC;gBAED;;mBAEG;gBACH,KAAK,EAAE,CAAC,GAAU,EAAE,EAAE;oBACpB,GAAG,CAAC,sCAAsC,EAAE,GAAG,CAAC,CAAA;oBAEhD,IAAI,CAAC;wBACH,EAAE,CAAC,KAAK,EAAE,CAAA;oBACZ,CAAC;oBAAC,OAAO,GAAQ,EAAE,CAAC;wBAClB,GAAG,CAAC,KAAK,CAAC,+CAA+C,EAAE,GAAG,CAAC,CAAA;oBACjE,CAAC;gBACH,CAAC;gBAED,gGAAgG;gBAChG,GAAG,WAAW,EAAE;aACjB,CAAA;YAED,OAAO,KAAK,CAAA;QACd,CAAC;KACF,CAAA;AACH,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libp2p/webtransport",
|
|
3
|
-
"version": "4.0.32-
|
|
3
|
+
"version": "4.0.32-169c9d85e",
|
|
4
4
|
"description": "JavaScript implementation of the WebTransport 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-webtransport#readme",
|
|
@@ -51,9 +51,9 @@
|
|
|
51
51
|
},
|
|
52
52
|
"dependencies": {
|
|
53
53
|
"@chainsafe/libp2p-noise": "^15.0.0",
|
|
54
|
-
"@libp2p/interface": "1.4.0-
|
|
55
|
-
"@libp2p/peer-id": "4.1.2-
|
|
56
|
-
"@libp2p/utils": "5.4.2-
|
|
54
|
+
"@libp2p/interface": "1.4.0-169c9d85e",
|
|
55
|
+
"@libp2p/peer-id": "4.1.2-169c9d85e",
|
|
56
|
+
"@libp2p/utils": "5.4.2-169c9d85e",
|
|
57
57
|
"@multiformats/multiaddr": "^12.2.3",
|
|
58
58
|
"@multiformats/multiaddr-matcher": "^1.2.1",
|
|
59
59
|
"it-stream-types": "^2.0.1",
|
|
@@ -64,16 +64,16 @@
|
|
|
64
64
|
},
|
|
65
65
|
"devDependencies": {
|
|
66
66
|
"@libp2p/daemon-client": "^8.0.5",
|
|
67
|
-
"@libp2p/logger": "4.0.13-
|
|
68
|
-
"@libp2p/peer-id-factory": "4.1.2-
|
|
69
|
-
"@libp2p/ping": "1.0.19-
|
|
67
|
+
"@libp2p/logger": "4.0.13-169c9d85e",
|
|
68
|
+
"@libp2p/peer-id-factory": "4.1.2-169c9d85e",
|
|
69
|
+
"@libp2p/ping": "1.0.19-169c9d85e",
|
|
70
70
|
"@noble/hashes": "^1.4.0",
|
|
71
71
|
"aegir": "^42.2.11",
|
|
72
72
|
"execa": "^9.1.0",
|
|
73
73
|
"go-libp2p": "^1.2.0",
|
|
74
74
|
"it-map": "^3.1.0",
|
|
75
75
|
"it-to-buffer": "^4.0.7",
|
|
76
|
-
"libp2p": "1.6.0-
|
|
76
|
+
"libp2p": "1.6.0-169c9d85e",
|
|
77
77
|
"p-defer": "^4.0.1",
|
|
78
78
|
"p-wait-for": "^5.0.2"
|
|
79
79
|
},
|
package/src/muxer.ts
CHANGED
|
@@ -23,38 +23,42 @@ export function webtransportMuxer (wt: Pick<WebTransport, 'close' | 'createBidir
|
|
|
23
23
|
|
|
24
24
|
const activeStreams: Stream[] = []
|
|
25
25
|
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
26
|
+
Promise.resolve()
|
|
27
|
+
.then(async () => {
|
|
28
|
+
//! TODO unclear how to add backpressure here?
|
|
29
|
+
while (true) {
|
|
30
|
+
const { done, value: wtStream } = await reader.read()
|
|
30
31
|
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
32
|
+
if (done) {
|
|
33
|
+
break
|
|
34
|
+
}
|
|
34
35
|
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
36
|
+
if (activeStreams.length >= config.maxInboundStreams) {
|
|
37
|
+
log(`too many inbound streams open - ${activeStreams.length}/${config.maxInboundStreams}, closing new incoming stream`)
|
|
38
|
+
// We've reached our limit, close this stream.
|
|
39
|
+
wtStream.writable.close().catch((err: Error) => {
|
|
40
|
+
log.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${err.message}`)
|
|
41
|
+
})
|
|
42
|
+
wtStream.readable.cancel().catch((err: Error) => {
|
|
43
|
+
log.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${err.message}`)
|
|
44
|
+
})
|
|
45
|
+
} else {
|
|
46
|
+
const stream = await webtransportBiDiStreamToStream(
|
|
47
|
+
wtStream,
|
|
48
|
+
String(streamIDCounter++),
|
|
49
|
+
'inbound',
|
|
50
|
+
activeStreams,
|
|
51
|
+
init?.onStreamEnd,
|
|
52
|
+
logger
|
|
53
|
+
)
|
|
54
|
+
activeStreams.push(stream)
|
|
55
|
+
init?.onIncomingStream?.(stream)
|
|
56
|
+
}
|
|
55
57
|
}
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
+
})
|
|
59
|
+
.catch(err => {
|
|
60
|
+
log.error('could not create a new stream', err)
|
|
61
|
+
})
|
|
58
62
|
|
|
59
63
|
const muxer: StreamMuxer = {
|
|
60
64
|
protocol: 'webtransport',
|
|
@@ -74,7 +78,12 @@ export function webtransportMuxer (wt: Pick<WebTransport, 'close' | 'createBidir
|
|
|
74
78
|
*/
|
|
75
79
|
close: async () => {
|
|
76
80
|
log('closing webtransport muxer gracefully')
|
|
77
|
-
|
|
81
|
+
|
|
82
|
+
try {
|
|
83
|
+
wt.close()
|
|
84
|
+
} catch (err: any) {
|
|
85
|
+
muxer.abort(err)
|
|
86
|
+
}
|
|
78
87
|
},
|
|
79
88
|
|
|
80
89
|
/**
|
|
@@ -82,7 +91,12 @@ export function webtransportMuxer (wt: Pick<WebTransport, 'close' | 'createBidir
|
|
|
82
91
|
*/
|
|
83
92
|
abort: (err: Error) => {
|
|
84
93
|
log('closing webtransport muxer with err:', err)
|
|
85
|
-
|
|
94
|
+
|
|
95
|
+
try {
|
|
96
|
+
wt.close()
|
|
97
|
+
} catch (err: any) {
|
|
98
|
+
log.error('webtransport session threw error during close', err)
|
|
99
|
+
}
|
|
86
100
|
},
|
|
87
101
|
|
|
88
102
|
// This stream muxer is webtransport native. Therefore it doesn't plug in with any other duplex.
|