@libp2p/webrtc 5.2.8 → 5.2.9-b2124c2db

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.min.js CHANGED
@@ -1,5 +1,5 @@
1
1
  (function (root, factory) {(typeof module === 'object' && module.exports) ? module.exports = factory() : root.Libp2PWebrtc = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PWebrtc=(()=>{var Wo=Object.defineProperty;var Yu=Object.getOwnPropertyDescriptor;var Ju=Object.getOwnPropertyNames;var Qu=Object.prototype.hasOwnProperty;var At=(r,t)=>{for(var e in t)Wo(r,e,{get:t[e],enumerable:!0})},tf=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Ju(t))!Qu.call(r,o)&&o!==e&&Wo(r,o,{get:()=>t[o],enumerable:!(n=Yu(t,o))||n.enumerable});return r};var ef=r=>tf(Wo({},"__esModule",{value:!0}),r);var Am={};At(Am,{webRTC:()=>Sm,webRTCDirect:()=>Em});var $o=Symbol.for("@libp2p/peer-id");var pn=Symbol.for("@libp2p/transport");var Ca;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Ca||(Ca={}));var mn=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}};var rt=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ye=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var gn=class extends Error{static name="ConnectionFailedError";constructor(t="Connection failed"){super(t),this.name="ConnectionFailedError"}};var yn=class extends Error{static name="StreamResetError";constructor(t="The stream has been reset"){super(t),this.name="StreamResetError"}},Pe=class extends Error{static name="StreamStateError";constructor(t="The stream is in an invalid state"){super(t),this.name="StreamStateError"}};var wn=class extends Error{static name="InvalidCIDError";constructor(t="Invalid CID"){super(t),this.name="InvalidCIDError"}},bn=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var xn=class extends Error{static name="InvalidMessageError";constructor(t="Invalid message"){super(t),this.name="InvalidMessageError"}};var En=class extends Error{static name="TimeoutError";constructor(t="Timed out"){super(t),this.name="TimeoutError"}};var De=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Je=class extends EventTarget{#t=new Map;constructor(){super()}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let o=this.#t.get(t);o==null&&(o=[],this.#t.set(t,o)),o.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let o=this.#t.get(t);o!=null&&(o=o.filter(({callback:s})=>s!==e),this.#t.set(t,o))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:o})=>!o),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new CustomEvent(t,e))}};var Qe=Symbol.for("@libp2p/service-capabilities"),Ba=Symbol.for("@libp2p/service-dependencies");var Jo={};At(Jo,{base58btc:()=>nt,base58flickr:()=>cf});var Ym=new Uint8Array(0);function _a(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function ne(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Ra(r){return new TextEncoder().encode(r)}function Pa(r){return new TextDecoder().decode(r)}function rf(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(e[i]!==255)throw new TypeError(s+" is ambiguous");e[i]=o}var a=r.length,c=r.charAt(0),l=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function f(b){if(b instanceof Uint8Array||(ArrayBuffer.isView(b)?b=new Uint8Array(b.buffer,b.byteOffset,b.byteLength):Array.isArray(b)&&(b=Uint8Array.from(b))),!(b instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(b.length===0)return"";for(var m=0,h=0,w=0,x=b.length;w!==x&&b[w]===0;)w++,m++;for(var p=(x-w)*u+1>>>0,I=new Uint8Array(p);w!==x;){for(var R=b[w],_=0,v=p-1;(R!==0||_<h)&&v!==-1;v--,_++)R+=256*I[v]>>>0,I[v]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");h=_,w++}for(var B=p-h;B!==p&&I[B]===0;)B++;for(var L=c.repeat(m);B<p;++B)L+=r.charAt(I[B]);return L}function d(b){if(typeof b!="string")throw new TypeError("Expected String");if(b.length===0)return new Uint8Array;var m=0;if(b[m]!==" "){for(var h=0,w=0;b[m]===c;)h++,m++;for(var x=(b.length-m)*l+1>>>0,p=new Uint8Array(x);b[m];){var I=e[b.charCodeAt(m)];if(I===255)return;for(var R=0,_=x-1;(I!==0||R<w)&&_!==-1;_--,R++)I+=a*p[_]>>>0,p[_]=I%256>>>0,I=I/256>>>0;if(I!==0)throw new Error("Non-zero carry");w=R,m++}if(b[m]!==" "){for(var v=x-w;v!==x&&p[v]===0;)v++;for(var B=new Uint8Array(h+(x-v)),L=h;v!==x;)B[L++]=p[v++];return B}}}function g(b){var m=d(b);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:d,decode:g}}var nf=rf,of=nf,Na=of;var Xo=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Zo=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let o=e.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Ua(this,t)}},jo=class{decoders;constructor(t){this.decoders=t}or(t){return Ua(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Ua(r,t){return new jo({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var Yo=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,o){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=o,this.encoder=new Xo(t,e,n),this.decoder=new Zo(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function tr({name:r,prefix:t,encode:e,decode:n}){return new Yo(r,t,e,n)}function ye({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Na(e,r);return tr({prefix:t,name:r,encode:n,decode:s=>ne(o(s))})}function sf(r,t,e,n){let o={};for(let u=0;u<t.length;++u)o[t[u]]=u;let s=r.length;for(;r[s-1]==="=";)--s;let i=new Uint8Array(s*e/8|0),a=0,c=0,l=0;for(let u=0;u<s;++u){let f=o[r[u]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|f,a+=e,a>=8&&(a-=8,i[l++]=255&c>>a)}if(a>=e||(255&c<<8-a)!==0)throw new SyntaxError("Unexpected end of data");return i}function af(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,s+=t[o&a>>i];if(i!==0&&(s+=t[o&a<<e-i]),n)for(;(s.length*e&7)!==0;)s+="=";return s}function ft({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return tr({prefix:t,name:r,encode(o){return af(o,n,e)},decode(o){return sf(o,n,e,r)}})}var nt=ye({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),cf=ye({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var Qo={};At(Qo,{base32:()=>oe,base32hex:()=>hf,base32hexpad:()=>pf,base32hexpadupper:()=>mf,base32hexupper:()=>df,base32pad:()=>uf,base32padupper:()=>ff,base32upper:()=>lf,base32z:()=>gf});var oe=ft({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),lf=ft({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),uf=ft({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),ff=ft({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),hf=ft({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),df=ft({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),pf=ft({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),mf=ft({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),gf=ft({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ts={};At(ts,{base36:()=>Tr,base36upper:()=>yf});var Tr=ye({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),yf=ye({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Mt={};At(Mt,{Digest:()=>Ne,create:()=>vt,decode:()=>we,equals:()=>rs,hasCode:()=>kf});var wf=Ma,ka=128,bf=127,xf=~bf,Ef=Math.pow(2,31);function Ma(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Ef;)t[e++]=r&255|ka,r/=128;for(;r&xf;)t[e++]=r&255|ka,r>>>=7;return t[e]=r|0,Ma.bytes=e-n+1,t}var Sf=es,Af=128,Oa=127;function es(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw es.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&Oa)<<o:(i&Oa)*Math.pow(2,o),o+=7}while(i>=Af);return es.bytes=s-n,e}var vf=Math.pow(2,7),If=Math.pow(2,14),Tf=Math.pow(2,21),Lf=Math.pow(2,28),Cf=Math.pow(2,35),Bf=Math.pow(2,42),_f=Math.pow(2,49),Rf=Math.pow(2,56),Pf=Math.pow(2,63),Df=function(r){return r<vf?1:r<If?2:r<Tf?3:r<Lf?4:r<Cf?5:r<Bf?6:r<_f?7:r<Rf?8:r<Pf?9:10},Nf={encode:wf,decode:Sf,encodingLength:Df},Uf=Nf,Lr=Uf;function Cr(r,t=0){return[Lr.decode(r,t),Lr.decode.bytes]}function er(r,t,e=0){return Lr.encode(r,t,e),t}function rr(r){return Lr.encodingLength(r)}function vt(r,t){let e=t.byteLength,n=rr(r),o=n+rr(e),s=new Uint8Array(o+e);return er(r,s,0),er(e,s,n),s.set(t,o),new Ne(r,e,t,s)}function we(r){let t=ne(r),[e,n]=Cr(t),[o,s]=Cr(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Ne(e,o,i,t)}function rs(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&_a(r.bytes,e.bytes)}}var Ne=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function kf(r,t){return r.code===t}function Ka(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Mf(e,ns(r),t??nt.encoder);default:return Kf(e,ns(r),t??oe.encoder)}}var Fa=new WeakMap;function ns(r){let t=Fa.get(r);if(t==null){let e=new Map;return Fa.set(r,e),e}return t}var pt=class r{code;version;multihash;bytes;"/";constructor(t,e,n,o){this.code=e,this.version=t,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==Br)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Ff)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=vt(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&rs(t.multihash,n.multihash)}toString(t){return Ka(this,t)}toJSON(){return{"/":Ka(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:o,multihash:s,bytes:i}=e;return new r(n,o,s,i??Ha(n,o,s.bytes))}else if(e[Hf]===!0){let{version:n,multihash:o,code:s}=e,i=we(o);return r.create(n,s,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==Br)throw new Error(`Version 0 CID must use dag-pb (code: ${Br}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=Ha(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Br,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,o=ne(t.subarray(n,n+e.multihashSize));if(o.byteLength!==e.multihashSize)throw new Error("Incorrect length");let s=o.subarray(e.multihashSize-e.digestSize),i=new Ne(e.multihashCode,e.digestSize,s,o);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[f,d]=Cr(t.subarray(e));return e+=d,f},o=n(),s=Br;if(o===18?(o=0,e=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=e,a=n(),c=n(),l=e+c,u=l-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:l}}static parse(t,e){let[n,o]=Of(t,e),s=r.decode(o);if(s.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return ns(s).set(n,t),s}};function Of(r,t){switch(r[0]){case"Q":{let e=t??nt;return[nt.prefix,e.decode(`${nt.prefix}${r}`)]}case nt.prefix:{let e=t??nt;return[nt.prefix,e.decode(r)]}case oe.prefix:{let e=t??oe;return[oe.prefix,e.decode(r)]}case Tr.prefix:{let e=t??Tr;return[Tr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Mf(r,t,e){let{prefix:n}=e;if(n!==nt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let o=t.get(n);if(o==null){let s=e.encode(r).slice(1);return t.set(n,s),s}else return o}function Kf(r,t,e){let{prefix:n}=e,o=t.get(n);if(o==null){let s=e.encode(r);return t.set(n,s),s}else return o}var Br=112,Ff=18;function Ha(r,t,e){let n=rr(r),o=n+rr(t),s=new Uint8Array(o+e.byteLength);return er(r,s,0),er(t,s,n),s.set(e,o),s}var Hf=Symbol.for("@ipld/js-cid/CID");var os={};At(os,{identity:()=>se});var Va=0,Vf="identity",qa=ne;function qf(r){return vt(Va,qa(r))}var se={code:Va,name:Vf,encode:qa,digest:qf};function Rt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function An(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Gf(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function nr(r,...t){if(!Gf(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function _r(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");An(r.outputLen),An(r.blockLen)}function or(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 Ga(r,t){nr(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Ue=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function vn(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function qt(r,t){return r<<32-t|r>>>t}function za(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function be(r){return typeof r=="string"&&(r=za(r)),nr(r),r}function ss(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];nr(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let s=r[n];e.set(s,o),o+=s.length}return e}var sr=class{clone(){return this._cloneInto()}};function In(r){let t=n=>r().update(be(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Rr(r=32){if(Ue&&typeof Ue.getRandomValues=="function")return Ue.getRandomValues(new Uint8Array(r));if(Ue&&typeof Ue.randomBytes=="function")return Ue.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function zf(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(e>>o&s),a=Number(e&s),c=n?4:0,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}function Wa(r,t,e){return r&t^~r&e}function $a(r,t,e){return r&t^r&e^t&e}var ir=class extends sr{constructor(t,e,n,o){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=o,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=vn(this.buffer)}update(t){or(this);let{view:e,buffer:n,blockLen:o}=this;t=be(t);let s=t.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=vn(t);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){or(this),Ga(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>o-i&&(this.process(n,0),i=0);for(let f=i;f<o;f++)e[f]=0;zf(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=vn(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let l=c/4,u=this.get();if(l>u.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<l;f++)a.setUint32(4*f,u[f],s)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return t.length=o,t.pos=a,t.finished=s,t.destroyed=i,o%e&&t.buffer.set(n),t}};var Tn=BigInt(4294967295),is=BigInt(32);function Xa(r,t=!1){return t?{h:Number(r&Tn),l:Number(r>>is&Tn)}:{h:Number(r>>is&Tn)|0,l:Number(r&Tn)|0}}function Wf(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let o=0;o<r.length;o++){let{h:s,l:i}=Xa(r[o],t);[e[o],n[o]]=[s,i]}return[e,n]}var $f=(r,t)=>BigInt(r>>>0)<<is|BigInt(t>>>0),Xf=(r,t,e)=>r>>>e,Zf=(r,t,e)=>r<<32-e|t>>>e,jf=(r,t,e)=>r>>>e|t<<32-e,Yf=(r,t,e)=>r<<32-e|t>>>e,Jf=(r,t,e)=>r<<64-e|t>>>e-32,Qf=(r,t,e)=>r>>>e-32|t<<64-e,th=(r,t)=>t,eh=(r,t)=>r,rh=(r,t,e)=>r<<e|t>>>32-e,nh=(r,t,e)=>t<<e|r>>>32-e,oh=(r,t,e)=>t<<e-32|r>>>64-e,sh=(r,t,e)=>r<<e-32|t>>>64-e;function ih(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var ah=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),ch=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,lh=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),uh=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,fh=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),hh=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var dh={fromBig:Xa,split:Wf,toBig:$f,shrSH:Xf,shrSL:Zf,rotrSH:jf,rotrSL:Yf,rotrBH:Jf,rotrBL:Qf,rotr32H:th,rotr32L:eh,rotlSH:rh,rotlSL:nh,rotlBH:oh,rotlBL:sh,add:ih,add3L:ah,add3H:ch,add4L:lh,add4H:uh,add5H:hh,add5L:fh},V=dh;var[ph,mh]=V.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),xe=new Uint32Array(80),Ee=new Uint32Array(80),as=class extends ir{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:l,El:u,Fh:f,Fl:d,Gh:g,Gl:b,Hh:m,Hl:h}=this;return[t,e,n,o,s,i,a,c,l,u,f,d,g,b,m,h]}set(t,e,n,o,s,i,a,c,l,u,f,d,g,b,m,h){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=o|0,this.Ch=s|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=l|0,this.El=u|0,this.Fh=f|0,this.Fl=d|0,this.Gh=g|0,this.Gl=b|0,this.Hh=m|0,this.Hl=h|0}process(t,e){for(let p=0;p<16;p++,e+=4)xe[p]=t.getUint32(e),Ee[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let I=xe[p-15]|0,R=Ee[p-15]|0,_=V.rotrSH(I,R,1)^V.rotrSH(I,R,8)^V.shrSH(I,R,7),v=V.rotrSL(I,R,1)^V.rotrSL(I,R,8)^V.shrSL(I,R,7),B=xe[p-2]|0,L=Ee[p-2]|0,M=V.rotrSH(B,L,19)^V.rotrBH(B,L,61)^V.shrSH(B,L,6),N=V.rotrSL(B,L,19)^V.rotrBL(B,L,61)^V.shrSL(B,L,6),O=V.add4L(v,N,Ee[p-7],Ee[p-16]),F=V.add4H(O,_,M,xe[p-7],xe[p-16]);xe[p]=F|0,Ee[p]=O|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:l,Dl:u,Eh:f,El:d,Fh:g,Fl:b,Gh:m,Gl:h,Hh:w,Hl:x}=this;for(let p=0;p<80;p++){let I=V.rotrSH(f,d,14)^V.rotrSH(f,d,18)^V.rotrBH(f,d,41),R=V.rotrSL(f,d,14)^V.rotrSL(f,d,18)^V.rotrBL(f,d,41),_=f&g^~f&m,v=d&b^~d&h,B=V.add5L(x,R,v,mh[p],Ee[p]),L=V.add5H(B,w,I,_,ph[p],xe[p]),M=B|0,N=V.rotrSH(n,o,28)^V.rotrBH(n,o,34)^V.rotrBH(n,o,39),O=V.rotrSL(n,o,28)^V.rotrBL(n,o,34)^V.rotrBL(n,o,39),F=n&s^n&a^s&a,T=o&i^o&c^i&c;w=m|0,x=h|0,m=g|0,h=b|0,g=f|0,b=d|0,{h:f,l:d}=V.add(l|0,u|0,L|0,M|0),l=a|0,u=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let C=V.add3L(M,O,T);n=V.add3H(C,L,N,F),o=C|0}({h:n,l:o}=V.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=V.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=V.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:u}=V.add(this.Dh|0,this.Dl|0,l|0,u|0),{h:f,l:d}=V.add(this.Eh|0,this.El|0,f|0,d|0),{h:g,l:b}=V.add(this.Fh|0,this.Fl|0,g|0,b|0),{h:m,l:h}=V.add(this.Gh|0,this.Gl|0,m|0,h|0),{h:w,l:x}=V.add(this.Hh|0,this.Hl|0,w|0,x|0),this.set(n,o,s,i,a,c,l,u,f,d,g,b,m,h,w,x)}roundClean(){xe.fill(0),Ee.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var Za=In(()=>new as);var Bn={};At(Bn,{aInRange:()=>xt,abool:()=>Gt,abytes:()=>ar,bitGet:()=>Eh,bitLen:()=>fs,bitMask:()=>Dr,bitSet:()=>Sh,bytesToHex:()=>ae,bytesToNumberBE:()=>ce,bytesToNumberLE:()=>zt,concatBytes:()=>ue,createHmacDrbg:()=>hs,ensureBytes:()=>ot,equalBytes:()=>bh,hexToBytes:()=>Oe,hexToNumber:()=>us,inRange:()=>Pr,isBytes:()=>Se,memoized:()=>Me,notImplemented:()=>vh,numberToBytesBE:()=>Ae,numberToBytesLE:()=>le,numberToHexUnpadded:()=>ke,numberToVarBytesBE:()=>wh,utf8ToBytes:()=>xh,validateObject:()=>Kt});var Ln=BigInt(0),Cn=BigInt(1),gh=BigInt(2);function Se(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function ar(r){if(!Se(r))throw new Error("Uint8Array expected")}function Gt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var yh=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function ae(r){ar(r);let t="";for(let e=0;e<r.length;e++)t+=yh[r[e]];return t}function ke(r){let t=r.toString(16);return t.length&1?"0"+t:t}function us(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?Ln:BigInt("0x"+r)}var ie={_0:48,_9:57,A:65,F:70,a:97,f:102};function ja(r){if(r>=ie._0&&r<=ie._9)return r-ie._0;if(r>=ie.A&&r<=ie.F)return r-(ie.A-10);if(r>=ie.a&&r<=ie.f)return r-(ie.a-10)}function Oe(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let o=0,s=0;o<e;o++,s+=2){let i=ja(r.charCodeAt(s)),a=ja(r.charCodeAt(s+1));if(i===void 0||a===void 0){let c=r[s]+r[s+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+s)}n[o]=i*16+a}return n}function ce(r){return us(ae(r))}function zt(r){return ar(r),us(ae(Uint8Array.from(r).reverse()))}function Ae(r,t){return Oe(r.toString(16).padStart(t*2,"0"))}function le(r,t){return Ae(r,t).reverse()}function wh(r){return Oe(ke(r))}function ot(r,t,e){let n;if(typeof t=="string")try{n=Oe(t)}catch(s){throw new Error(r+" must be hex string or Uint8Array, cause: "+s)}else if(Se(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let o=n.length;if(typeof e=="number"&&o!==e)throw new Error(r+" of length "+e+" expected, got "+o);return n}function ue(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];ar(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let s=r[n];e.set(s,o),o+=s.length}return e}function bh(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}function xh(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var cs=r=>typeof r=="bigint"&&Ln<=r;function Pr(r,t,e){return cs(r)&&cs(t)&&cs(e)&&t<=r&&r<e}function xt(r,t,e,n){if(!Pr(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function fs(r){let t;for(t=0;r>Ln;r>>=Cn,t+=1);return t}function Eh(r,t){return r>>BigInt(t)&Cn}function Sh(r,t,e){return r|(e?Cn:Ln)<<BigInt(t)}var Dr=r=>(gh<<BigInt(r-1))-Cn,ls=r=>new Uint8Array(r),Ya=r=>Uint8Array.from(r);function hs(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=ls(r),o=ls(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...f)=>e(o,n,...f),c=(f=ls())=>{o=a(Ya([0]),f),n=a(),f.length!==0&&(o=a(Ya([1]),f),n=a())},l=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,d=[];for(;f<t;){n=a();let g=n.slice();d.push(g),f+=n.length}return ue(...d)};return(f,d)=>{i(),c(f);let g;for(;!(g=d(l()));)c();return i(),g}}var Ah={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||Se(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Kt(r,t,e={}){let n=(o,s,i)=>{let a=Ah[s];if(typeof a!="function")throw new Error("invalid validator function");let c=r[o];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(o)+" is invalid. Expected "+s+", got "+c)};for(let[o,s]of Object.entries(t))n(o,s,!1);for(let[o,s]of Object.entries(e))n(o,s,!0);return r}var vh=()=>{throw new Error("not implemented")};function Me(r){let t=new WeakMap;return(e,...n)=>{let o=t.get(e);if(o!==void 0)return o;let s=r(e,...n);return t.set(e,s),s}}var mt=BigInt(0),ut=BigInt(1),Ke=BigInt(2),Ih=BigInt(3),ds=BigInt(4),Ja=BigInt(5),Qa=BigInt(8),Th=BigInt(9),Lh=BigInt(16);function Z(r,t){let e=r%t;return e>=mt?e:t+e}function ps(r,t,e){if(t<mt)throw new Error("invalid exponent, negatives unsupported");if(e<=mt)throw new Error("invalid modulus");if(e===ut)return mt;let n=ut;for(;t>mt;)t&ut&&(n=n*r%e),r=r*r%e,t>>=ut;return n}function at(r,t,e){let n=r;for(;t-- >mt;)n*=n,n%=e;return n}function _n(r,t){if(r===mt)throw new Error("invert: expected non-zero number");if(t<=mt)throw new Error("invert: expected positive modulus, got "+t);let e=Z(r,t),n=t,o=mt,s=ut,i=ut,a=mt;for(;e!==mt;){let l=n/e,u=n%e,f=o-i*l,d=s-a*l;n=e,e=u,o=i,s=a,i=f,a=d}if(n!==ut)throw new Error("invert: does not exist");return Z(o,t)}function Ch(r){let t=(r-ut)/Ke,e,n,o;for(e=r-ut,n=0;e%Ke===mt;e/=Ke,n++);for(o=Ke;o<r&&ps(o,t,r)!==r-ut;o++)if(o>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let i=(r+ut)/ds;return function(c,l){let u=c.pow(l,i);if(!c.eql(c.sqr(u),l))throw new Error("Cannot find square root");return u}}let s=(e+ut)/Ke;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let l=n,u=a.pow(a.mul(a.ONE,o),e),f=a.pow(c,s),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let g=1;for(let m=a.sqr(d);g<l&&!a.eql(m,a.ONE);g++)m=a.sqr(m);let b=a.pow(u,ut<<BigInt(l-g-1));u=a.sqr(b),f=a.mul(f,b),d=a.mul(d,u),l=g}return f}}function Bh(r){if(r%ds===Ih){let t=(r+ut)/ds;return function(n,o){let s=n.pow(o,t);if(!n.eql(n.sqr(s),o))throw new Error("Cannot find square root");return s}}if(r%Qa===Ja){let t=(r-Ja)/Qa;return function(n,o){let s=n.mul(o,Ke),i=n.pow(s,t),a=n.mul(o,i),c=n.mul(n.mul(a,Ke),i),l=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(l),o))throw new Error("Cannot find square root");return l}}return r%Lh,Ch(r)}var tc=(r,t)=>(Z(r,t)&ut)===ut,_h=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function ms(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=_h.reduce((n,o)=>(n[o]="function",n),t);return Kt(r,e)}function Rh(r,t,e){if(e<mt)throw new Error("invalid exponent, negatives unsupported");if(e===mt)return r.ONE;if(e===ut)return t;let n=r.ONE,o=t;for(;e>mt;)e&ut&&(n=r.mul(n,o)),o=r.sqr(o),e>>=ut;return n}function Ph(r,t){let e=new Array(t.length),n=t.reduce((s,i,a)=>r.is0(i)?s:(e[a]=s,r.mul(s,i)),r.ONE),o=r.inv(n);return t.reduceRight((s,i,a)=>r.is0(i)?s:(e[a]=r.mul(s,e[a]),r.mul(s,i)),o),e}function gs(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function ve(r,t,e=!1,n={}){if(r<=mt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:o,nByteLength:s}=gs(r,t);if(s>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,isLE:e,BITS:o,BYTES:s,MASK:Dr(o),ZERO:mt,ONE:ut,create:c=>Z(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return mt<=c&&c<r},is0:c=>c===mt,isOdd:c=>(c&ut)===ut,neg:c=>Z(-c,r),eql:(c,l)=>c===l,sqr:c=>Z(c*c,r),add:(c,l)=>Z(c+l,r),sub:(c,l)=>Z(c-l,r),mul:(c,l)=>Z(c*l,r),pow:(c,l)=>Rh(a,c,l),div:(c,l)=>Z(c*_n(l,r),r),sqrN:c=>c*c,addN:(c,l)=>c+l,subN:(c,l)=>c-l,mulN:(c,l)=>c*l,inv:c=>_n(c,r),sqrt:n.sqrt||(c=>(i||(i=Bh(r)),i(a,c))),invertBatch:c=>Ph(a,c),cmov:(c,l,u)=>u?l:c,toBytes:c=>e?le(c,s):Ae(c,s),fromBytes:c=>{if(c.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+c.length);return e?zt(c):ce(c)}});return Object.freeze(a)}function ec(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function ys(r){let t=ec(r);return t+Math.ceil(t/2)}function rc(r,t,e=!1){let n=r.length,o=ec(t),s=ys(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?zt(r):ce(r),a=Z(i,t-ut)+ut;return e?le(a,o):Ae(a,o)}var nc=BigInt(0),Rn=BigInt(1);function ws(r,t){let e=t.negate();return r?e:t}function oc(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function bs(r,t){oc(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function Dh(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function Nh(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var xs=new WeakMap,sc=new WeakMap;function Es(r){return sc.get(r)||1}function Pn(r,t){return{constTimeNegate:ws,hasPrecomputes(e){return Es(e)!==1},unsafeLadder(e,n,o=r.ZERO){let s=e;for(;n>nc;)n&Rn&&(o=o.add(s)),s=s.double(),n>>=Rn;return o},precomputeWindow(e,n){let{windows:o,windowSize:s}=bs(n,t),i=[],a=e,c=a;for(let l=0;l<o;l++){c=a,i.push(c);for(let u=1;u<s;u++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,o){let{windows:s,windowSize:i}=bs(e,t),a=r.ZERO,c=r.BASE,l=BigInt(2**e-1),u=2**e,f=BigInt(e);for(let d=0;d<s;d++){let g=d*i,b=Number(o&l);o>>=f,b>i&&(b-=u,o+=Rn);let m=g,h=g+Math.abs(b)-1,w=d%2!==0,x=b<0;b===0?c=c.add(ws(w,n[m])):a=a.add(ws(x,n[h]))}return{p:a,f:c}},wNAFUnsafe(e,n,o,s=r.ZERO){let{windows:i,windowSize:a}=bs(e,t),c=BigInt(2**e-1),l=2**e,u=BigInt(e);for(let f=0;f<i;f++){let d=f*a;if(o===nc)break;let g=Number(o&c);if(o>>=u,g>a&&(g-=l,o+=Rn),g===0)continue;let b=n[d+Math.abs(g)-1];g<0&&(b=b.negate()),s=s.add(b)}return s},getPrecomputes(e,n,o){let s=xs.get(n);return s||(s=this.precomputeWindow(n,e),e!==1&&xs.set(n,o(s))),s},wNAFCached(e,n,o){let s=Es(e);return this.wNAF(s,this.getPrecomputes(s,e,o),n)},wNAFCachedUnsafe(e,n,o,s){let i=Es(e);return i===1?this.unsafeLadder(e,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,e,o),n,s)},setWindowSize(e,n){oc(n,t),sc.set(e,n),xs.delete(e)}}}function Dn(r,t,e,n){if(Dh(e,r),Nh(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let o=r.ZERO,s=fs(BigInt(e.length)),i=s>12?s-3:s>4?s-2:s?2:1,a=(1<<i)-1,c=new Array(a+1).fill(o),l=Math.floor((t.BITS-1)/i)*i,u=o;for(let f=l;f>=0;f-=i){c.fill(o);for(let g=0;g<n.length;g++){let b=n[g],m=Number(b>>BigInt(f)&BigInt(a));c[m]=c[m].add(e[g])}let d=o;for(let g=c.length-1,b=o;g>0;g--)b=b.add(c[g]),d=d.add(b);if(u=u.add(d),f!==0)for(let g=0;g<i;g++)u=u.double()}return u}function Nr(r){return ms(r.Fp),Kt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...gs(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Wt=BigInt(0),Dt=BigInt(1),Nn=BigInt(2),Uh=BigInt(8),kh={zip215:!0};function Oh(r){let t=Nr(r);return Kt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function ic(r){let t=Oh(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,l=Nn<<BigInt(a*8)-Dt,u=e.create,f=ve(t.n,t.nBitLength),d=t.uvRatio||((E,y)=>{try{return{isValid:!0,value:e.sqrt(E*e.inv(y))}}catch{return{isValid:!1,value:Wt}}}),g=t.adjustScalarBytes||(E=>E),b=t.domain||((E,y,A)=>{if(Gt("phflag",A),y.length||A)throw new Error("Contexts/pre-hash are not supported");return E});function m(E,y){xt("coordinate "+E,y,Wt,l)}function h(E){if(!(E instanceof p))throw new Error("ExtendedPoint expected")}let w=Me((E,y)=>{let{ex:A,ey:S,ez:P}=E,D=E.is0();y==null&&(y=D?Uh:e.inv(P));let k=u(A*y),H=u(S*y),K=u(P*y);if(D)return{x:Wt,y:Dt};if(K!==Dt)throw new Error("invZ was invalid");return{x:k,y:H}}),x=Me(E=>{let{a:y,d:A}=t;if(E.is0())throw new Error("bad point: ZERO");let{ex:S,ey:P,ez:D,et:k}=E,H=u(S*S),K=u(P*P),G=u(D*D),X=u(G*G),st=u(H*y),it=u(G*u(st+K)),lt=u(X+u(A*u(H*K)));if(it!==lt)throw new Error("bad point: equation left != right (1)");let St=u(S*P),Pt=u(D*k);if(St!==Pt)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(y,A,S,P){this.ex=y,this.ey=A,this.ez=S,this.et=P,m("x",y),m("y",A),m("z",S),m("t",P),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(y){if(y instanceof p)throw new Error("extended point not allowed");let{x:A,y:S}=y||{};return m("x",A),m("y",S),new p(A,S,Dt,u(A*S))}static normalizeZ(y){let A=e.invertBatch(y.map(S=>S.ez));return y.map((S,P)=>S.toAffine(A[P])).map(p.fromAffine)}static msm(y,A){return Dn(p,f,y,A)}_setWindowSize(y){_.setWindowSize(this,y)}assertValidity(){x(this)}equals(y){h(y);let{ex:A,ey:S,ez:P}=this,{ex:D,ey:k,ez:H}=y,K=u(A*H),G=u(D*P),X=u(S*H),st=u(k*P);return K===G&&X===st}is0(){return this.equals(p.ZERO)}negate(){return new p(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:y}=t,{ex:A,ey:S,ez:P}=this,D=u(A*A),k=u(S*S),H=u(Nn*u(P*P)),K=u(y*D),G=A+S,X=u(u(G*G)-D-k),st=K+k,it=st-H,lt=K-k,St=u(X*it),Pt=u(st*lt),_t=u(X*lt),Jt=u(it*st);return new p(St,Pt,Jt,_t)}add(y){h(y);let{a:A,d:S}=t,{ex:P,ey:D,ez:k,et:H}=this,{ex:K,ey:G,ez:X,et:st}=y;if(A===BigInt(-1)){let Ea=u((D-P)*(G+K)),Sa=u((D+P)*(G-K)),zo=u(Sa-Ea);if(zo===Wt)return this.double();let Aa=u(k*Nn*st),va=u(H*Nn*X),Ia=va+Aa,Ta=Sa+Ea,La=va-Aa,$u=u(Ia*zo),Xu=u(Ta*La),Zu=u(Ia*La),ju=u(zo*Ta);return new p($u,Xu,ju,Zu)}let it=u(P*K),lt=u(D*G),St=u(H*S*st),Pt=u(k*X),_t=u((P+D)*(K+G)-it-lt),Jt=Pt-St,re=Pt+St,Ir=u(lt-A*it),qu=u(_t*Jt),Gu=u(re*Ir),zu=u(_t*Ir),Wu=u(Jt*re);return new p(qu,Gu,Wu,zu)}subtract(y){return this.add(y.negate())}wNAF(y){return _.wNAFCached(this,y,p.normalizeZ)}multiply(y){let A=y;xt("scalar",A,Dt,n);let{p:S,f:P}=this.wNAF(A);return p.normalizeZ([S,P])[0]}multiplyUnsafe(y,A=p.ZERO){let S=y;return xt("scalar",S,Wt,n),S===Wt?R:this.is0()||S===Dt?this:_.wNAFCachedUnsafe(this,S,p.normalizeZ,A)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return _.unsafeLadder(this,n).is0()}toAffine(y){return w(this,y)}clearCofactor(){let{h:y}=t;return y===Dt?this:this.multiplyUnsafe(y)}static fromHex(y,A=!1){let{d:S,a:P}=t,D=e.BYTES;y=ot("pointHex",y,D),Gt("zip215",A);let k=y.slice(),H=y[D-1];k[D-1]=H&-129;let K=zt(k),G=A?l:e.ORDER;xt("pointHex.y",K,Wt,G);let X=u(K*K),st=u(X-Dt),it=u(S*X-P),{isValid:lt,value:St}=d(st,it);if(!lt)throw new Error("Point.fromHex: invalid y coordinate");let Pt=(St&Dt)===Dt,_t=(H&128)!==0;if(!A&&St===Wt&&_t)throw new Error("Point.fromHex: x=0 and x_0=1");return _t!==Pt&&(St=u(-St)),p.fromAffine({x:St,y:K})}static fromPrivateKey(y){return L(y).point}toRawBytes(){let{x:y,y:A}=this.toAffine(),S=le(A,e.BYTES);return S[S.length-1]|=y&Dt?128:0,S}toHex(){return ae(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,Dt,u(t.Gx*t.Gy)),p.ZERO=new p(Wt,Dt,Dt,Wt);let{BASE:I,ZERO:R}=p,_=Pn(p,a*8);function v(E){return Z(E,n)}function B(E){return v(zt(E))}function L(E){let y=e.BYTES;E=ot("private key",E,y);let A=ot("hashed private key",s(E),2*y),S=g(A.slice(0,y)),P=A.slice(y,2*y),D=B(S),k=I.multiply(D),H=k.toRawBytes();return{head:S,prefix:P,scalar:D,point:k,pointBytes:H}}function M(E){return L(E).pointBytes}function N(E=new Uint8Array,...y){let A=ue(...y);return B(s(b(A,ot("context",E),!!o)))}function O(E,y,A={}){E=ot("message",E),o&&(E=o(E));let{prefix:S,scalar:P,pointBytes:D}=L(y),k=N(A.context,S,E),H=I.multiply(k).toRawBytes(),K=N(A.context,H,D,E),G=v(k+K*P);xt("signature.s",G,Wt,n);let X=ue(H,le(G,e.BYTES));return ot("result",X,e.BYTES*2)}let F=kh;function T(E,y,A,S=F){let{context:P,zip215:D}=S,k=e.BYTES;E=ot("signature",E,2*k),y=ot("message",y),A=ot("publicKey",A,k),D!==void 0&&Gt("zip215",D),o&&(y=o(y));let H=zt(E.slice(k,2*k)),K,G,X;try{K=p.fromHex(A,D),G=p.fromHex(E.slice(0,k),D),X=I.multiplyUnsafe(H)}catch{return!1}if(!D&&K.isSmallOrder())return!1;let st=N(P,G.toRawBytes(),K.toRawBytes(),y);return G.add(K.multiplyUnsafe(st)).subtract(X).clearCofactor().equals(p.ZERO)}return I._setWindowSize(8),{CURVE:t,getPublicKey:M,sign:O,verify:T,ExtendedPoint:p,utils:{getExtendedPublicKey:L,randomPrivateKey:()=>i(e.BYTES),precompute(E=8,y=p.BASE){return y._setWindowSize(E),y.multiply(BigInt(3)),y}}}}var cr=BigInt(0),Ss=BigInt(1);function Mh(r){return Kt(r,{a:"bigint"},{montgomeryBits:"isSafeInteger",nByteLength:"isSafeInteger",adjustScalarBytes:"function",domain:"function",powPminus2:"function",Gu:"bigint"}),Object.freeze({...r})}function ac(r){let t=Mh(r),{P:e}=t,n=x=>Z(x,e),o=t.montgomeryBits,s=Math.ceil(o/8),i=t.nByteLength,a=t.adjustScalarBytes||(x=>x),c=t.powPminus2||(x=>ps(x,e-BigInt(2),e));function l(x,p,I){let R=n(x*(p-I));return p=n(p-R),I=n(I+R),[p,I]}let u=(t.a-BigInt(2))/BigInt(4);function f(x,p){xt("u",x,cr,e),xt("scalar",p,cr,e);let I=p,R=x,_=Ss,v=cr,B=x,L=Ss,M=cr,N;for(let F=BigInt(o-1);F>=cr;F--){let T=I>>F&Ss;M^=T,N=l(M,_,B),_=N[0],B=N[1],N=l(M,v,L),v=N[0],L=N[1],M=T;let C=_+v,E=n(C*C),y=_-v,A=n(y*y),S=E-A,P=B+L,D=B-L,k=n(D*C),H=n(P*y),K=k+H,G=k-H;B=n(K*K),L=n(R*n(G*G)),_=n(E*A),v=n(S*(E+n(u*S)))}N=l(M,_,B),_=N[0],B=N[1],N=l(M,v,L),v=N[0],L=N[1];let O=c(v);return n(_*O)}function d(x){return le(n(x),s)}function g(x){let p=ot("u coordinate",x,s);return i===32&&(p[31]&=127),zt(p)}function b(x){let p=ot("scalar",x),I=p.length;if(I!==s&&I!==i){let R=""+s+" or "+i;throw new Error("invalid scalar, expected "+R+" bytes, got "+I)}return zt(a(p))}function m(x,p){let I=g(p),R=b(x),_=f(I,R);if(_===cr)throw new Error("invalid private or public key received");return d(_)}let h=d(t.Gu);function w(x){return m(x,h)}return{scalarMult:m,scalarMultBase:w,getSharedSecret:(x,p)=>m(x,p),getPublicKey:x=>w(x),utils:{randomPrivateKey:()=>t.randomBytes(t.nByteLength)},GuBytes:h}}var Ur=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),cc=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),$0=BigInt(0),Kh=BigInt(1),lc=BigInt(2),Fh=BigInt(3),Hh=BigInt(5),Vh=BigInt(8);function uc(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=Ur,a=r*r%s*r%s,c=at(a,lc,s)*a%s,l=at(c,Kh,s)*r%s,u=at(l,Hh,s)*l%s,f=at(u,t,s)*u%s,d=at(f,e,s)*f%s,g=at(d,n,s)*d%s,b=at(g,o,s)*g%s,m=at(b,o,s)*g%s,h=at(m,t,s)*u%s;return{pow_p_5_8:at(h,lc,s)*r%s,b2:a}}function fc(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function qh(r,t){let e=Ur,n=Z(t*t*t,e),o=Z(n*n*t,e),s=uc(r*o).pow_p_5_8,i=Z(r*n*s,e),a=Z(t*i*i,e),c=i,l=Z(i*cc,e),u=a===r,f=a===Z(-r,e),d=a===Z(-r*cc,e);return u&&(i=c),(f||d)&&(i=l),tc(i,e)&&(i=Z(-i,e)),{isValid:u||f,value:i}}var Gh=ve(Ur,void 0,!0),zh={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:Gh,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Vh,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Za,randomBytes:Rr,adjustScalarBytes:fc,uvRatio:qh},hc=ic(zh);var kr=ac({P:Ur,a:BigInt(486662),montgomeryBits:255,nByteLength:32,Gu:BigInt(9),powPminus2:r=>{let t=Ur,{pow_p_5_8:e,b2:n}=uc(r);return Z(at(e,Fh,t)*n,t)},adjustScalarBytes:fc,randomBytes:Rr});var Un=32;function dc(r,t,e){return hc.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var kn=class{type="Ed25519";raw;constructor(t){this.raw=As(t,Un)}toMultihash(){return se.digest(lr(this))}toCID(){return pt.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Rt(this.raw,t.raw)}verify(t,e){return dc(this.raw,e,t)}};function vs(r){return r=As(r,Un),new kn(r)}function As(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new rt(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function gt(r=0){return new Uint8Array(r)}function dt(r=0){return new Uint8Array(r)}var $h=Math.pow(2,7),Xh=Math.pow(2,14),Zh=Math.pow(2,21),Is=Math.pow(2,28),Ts=Math.pow(2,35),Ls=Math.pow(2,42),Cs=Math.pow(2,49),Y=128,It=127;function Q(r){if(r<$h)return 1;if(r<Xh)return 2;if(r<Zh)return 3;if(r<Is)return 4;if(r<Ts)return 5;if(r<Ls)return 6;if(r<Cs)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Bs(r,t,e=0){switch(Q(r)){case 8:t[e++]=r&255|Y,r/=128;case 7:t[e++]=r&255|Y,r/=128;case 6:t[e++]=r&255|Y,r/=128;case 5:t[e++]=r&255|Y,r/=128;case 4:t[e++]=r&255|Y,r>>>=7;case 3:t[e++]=r&255|Y,r>>>=7;case 2:t[e++]=r&255|Y,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function jh(r,t,e=0){switch(Q(r)){case 8:t.set(e++,r&255|Y),r/=128;case 7:t.set(e++,r&255|Y),r/=128;case 6:t.set(e++,r&255|Y),r/=128;case 5:t.set(e++,r&255|Y),r/=128;case 4:t.set(e++,r&255|Y),r>>>=7;case 3:t.set(e++,r&255|Y),r>>>=7;case 2:t.set(e++,r&255|Y),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function _s(r,t){let e=r[t],n=0;if(n+=e&It,e<Y||(e=r[t+1],n+=(e&It)<<7,e<Y)||(e=r[t+2],n+=(e&It)<<14,e<Y)||(e=r[t+3],n+=(e&It)<<21,e<Y)||(e=r[t+4],n+=(e&It)*Is,e<Y)||(e=r[t+5],n+=(e&It)*Ts,e<Y)||(e=r[t+6],n+=(e&It)*Ls,e<Y)||(e=r[t+7],n+=(e&It)*Cs,e<Y))return n;throw new RangeError("Could not decode varint")}function Yh(r,t){let e=r.get(t),n=0;if(n+=e&It,e<Y||(e=r.get(t+1),n+=(e&It)<<7,e<Y)||(e=r.get(t+2),n+=(e&It)<<14,e<Y)||(e=r.get(t+3),n+=(e&It)<<21,e<Y)||(e=r.get(t+4),n+=(e&It)*Is,e<Y)||(e=r.get(t+5),n+=(e&It)*Ts,e<Y)||(e=r.get(t+6),n+=(e&It)*Ls,e<Y)||(e=r.get(t+7),n+=(e&It)*Cs,e<Y))return n;throw new RangeError("Could not decode varint")}function Ft(r,t,e=0){return t==null&&(t=dt(Q(r))),t instanceof Uint8Array?Bs(r,t,e):jh(r,t,e)}function Ut(r,t=0){return r instanceof Uint8Array?_s(r,t):Yh(r,t)}var Rs=new Float32Array([-0]),Ie=new Uint8Array(Rs.buffer);function mc(r,t,e){Rs[0]=r,t[e]=Ie[0],t[e+1]=Ie[1],t[e+2]=Ie[2],t[e+3]=Ie[3]}function gc(r,t){return Ie[0]=r[t],Ie[1]=r[t+1],Ie[2]=r[t+2],Ie[3]=r[t+3],Rs[0]}var Ps=new Float64Array([-0]),Tt=new Uint8Array(Ps.buffer);function yc(r,t,e){Ps[0]=r,t[e]=Tt[0],t[e+1]=Tt[1],t[e+2]=Tt[2],t[e+3]=Tt[3],t[e+4]=Tt[4],t[e+5]=Tt[5],t[e+6]=Tt[6],t[e+7]=Tt[7]}function wc(r,t){return Tt[0]=r[t],Tt[1]=r[t+1],Tt[2]=r[t+2],Tt[3]=r[t+3],Tt[4]=r[t+4],Tt[5]=r[t+5],Tt[6]=r[t+6],Tt[7]=r[t+7],Ps[0]}var Jh=BigInt(Number.MAX_SAFE_INTEGER),Qh=BigInt(Number.MIN_SAFE_INTEGER),kt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return He;if(t<Jh&&t>Qh)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,o=t-(n<<32n);return e&&(n=~n|0n,o=~o|0n,++o>bc&&(o=0n,++n>bc&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return He;let e=t<0;e&&(t=-t);let n=t>>>0,o=(t-n)/4294967296>>>0;return e&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new r(n,o)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):He}},He=new kt(0,0);He.toBigInt=function(){return 0n};He.zzEncode=He.zzDecode=function(){return this};He.length=function(){return 1};var bc=4294967296n;function xc(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Ec(r,t,e){if(e-t<1)return"";let o,s=[],i=0,a;for(;t<e;)a=r[t++],a<128?s[i++]=a:a>191&&a<224?s[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,s)),i=0);return o!=null?(i>0&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))}function Ds(r,t,e){let n=e,o,s;for(let i=0;i<r.length;++i)o=r.charCodeAt(i),o<128?t[e++]=o:o<2048?(t[e++]=o>>6|192,t[e++]=o&63|128):(o&64512)===55296&&((s=r.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,t[e++]=o>>18|240,t[e++]=o>>12&63|128,t[e++]=o>>6&63|128,t[e++]=o&63|128):(t[e++]=o>>12|224,t[e++]=o>>6&63|128,t[e++]=o&63|128);return e-n}function $t(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function On(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Ns=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,$t(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw $t(this,4);return On(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw $t(this,4);return On(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw $t(this,4);let t=gc(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw $t(this,4);let t=wc(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw $t(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Ec(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw $t(this,t);this.pos+=t}else do if(this.pos>=this.len)throw $t(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new kt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw $t(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw $t(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw $t(this,8);let t=On(this.buf,this.pos+=4),e=On(this.buf,this.pos+=4);return new kt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=_s(this.buf,this.pos);return this.pos+=Q(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Us(r){return new Ns(r instanceof Uint8Array?r:r.subarray())}function Xt(r,t,e){let n=Us(r);return t.decode(n,void 0,e)}var ks={};At(ks,{base10:()=>td});var td=ye({prefix:"9",name:"base10",alphabet:"0123456789"});var Os={};At(Os,{base16:()=>ed,base16upper:()=>rd});var ed=ft({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),rd=ft({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Ms={};At(Ms,{base2:()=>nd});var nd=ft({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Ks={};At(Ks,{base256emoji:()=>cd});var Ac=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),od=Ac.reduce((r,t,e)=>(r[e]=t,r),[]),sd=Ac.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function id(r){return r.reduce((t,e)=>(t+=od[e],t),"")}function ad(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=sd[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var cd=tr({prefix:"\u{1F680}",name:"base256emoji",encode:id,decode:ad});var Fs={};At(Fs,{base64:()=>ld,base64pad:()=>ud,base64url:()=>Or,base64urlpad:()=>fd});var ld=ft({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),ud=ft({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Or=ft({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),fd=ft({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Hs={};At(Hs,{base8:()=>hd});var hd=ft({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Vs={};At(Vs,{identity:()=>dd});var dd=tr({prefix:"\0",name:"identity",encode:r=>Pa(r),decode:r=>Ra(r)});var Bg=new TextEncoder,_g=new TextDecoder;var zs={};At(zs,{sha256:()=>fe,sha512:()=>gd});function Gs({name:r,code:t,encode:e}){return new qs(r,t,e)}var qs=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?vt(this.code,e):e.then(n=>vt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Ic(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var fe=Gs({name:"sha2-256",code:18,encode:Ic("SHA-256")}),gd=Gs({name:"sha2-512",code:19,encode:Ic("SHA-512")});var Ve={...Vs,...Ms,...Hs,...ks,...Os,...Qo,...ts,...Jo,...Fs,...Ks},Vg={...zs,...os};function Lc(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Tc=Lc("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Ws=Lc("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=dt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),yd={utf8:Tc,"utf-8":Tc,hex:Ve.base16,latin1:Ws,ascii:Ws,binary:Ws,...Ve},Mn=yd;function J(r,t="utf8"){let e=Mn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function $s(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return dt(i);o+i>t&&(n=dt(t),o=0);let a=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),a}}var qe=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Xs(){}var js=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},wd=$s();function bd(r){return globalThis.Buffer!=null?dt(r):wd(r)}var Kr=class{len;head;tail;states;constructor(){this.len=0,this.head=new qe(Xs,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new qe(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Ys((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(Kn,10,kt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=kt.fromBigInt(t);return this._push(Kn,e.length(),e)}uint64Number(t){return this._push(Bs,Q(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=kt.fromBigInt(t).zzEncode();return this._push(Kn,e.length(),e)}sint64Number(t){let e=kt.fromNumber(t).zzEncode();return this._push(Kn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Zs,1,t?1:0)}fixed32(t){return this._push(Mr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=kt.fromBigInt(t);return this._push(Mr,4,e.lo)._push(Mr,4,e.hi)}fixed64Number(t){let e=kt.fromNumber(t);return this._push(Mr,4,e.lo)._push(Mr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(mc,4,t)}double(t){return this._push(yc,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Zs,1,0):this.uint32(e)._push(Ed,e,t)}string(t){let e=xc(t);return e!==0?this.uint32(e)._push(Ds,e,t):this._push(Zs,1,0)}fork(){return this.states=new js(this),this.head=this.tail=new qe(Xs,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new qe(Xs,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=bd(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Zs(r,t,e){t[e]=r&255}function xd(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Ys=class extends qe{next;constructor(t,e){super(xd,t,e),this.next=void 0}};function Kn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Mr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Ed(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Kr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Sd,t,r),this},Kr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Ad,t,r),this});function Sd(r,t,e){t.set(r,e)}function Ad(r,t,e){r.length<40?Ds(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(J(r),e)}function Js(){return new Kr}function Zt(r,t){let e=Js();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var ur;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(ur||(ur={}));function Fn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ge(r){function t(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let e=function(s,i){let a=t(s);i.int32(a)},n=function(s){let i=s.int32();return t(i)};return Fn("enum",ur.VARINT,e,n)}function jt(r,t){return Fn("message",ur.LENGTH_DELIMITED,r,t)}var yt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(yt||(yt={}));var Qs;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(Qs||(Qs={}));(function(r){r.codec=()=>Ge(Qs)})(yt||(yt={}));var Qt;(function(r){let t;r.codec=()=>(t==null&&(t=jt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),yt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.Type=yt.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Zt(e,r.codec()),r.decode=(e,n)=>Xt(e,r.codec(),n)})(Qt||(Qt={}));var ti;(function(r){let t;r.codec=()=>(t==null&&(t=jt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),yt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.Type=yt.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Zt(e,r.codec()),r.decode=(e,n)=>Xt(e,r.codec(),n)})(ti||(ti={}));var Vr={};At(Vr,{MAX_RSA_KEY_SIZE:()=>si,generateRSAKeyPair:()=>Vc,jwkToJWKKeyPair:()=>qc,jwkToPkcs1:()=>kd,jwkToPkix:()=>ai,jwkToRSAPrivateKey:()=>Hc,pkcs1ToJwk:()=>Mc,pkcs1ToRSAPrivateKey:()=>Fc,pkixToJwk:()=>Kc,pkixToRSAPublicKey:()=>ci});var vd=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]),Te=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Le=new Uint32Array(64),ei=class extends ir{constructor(){super(64,32,8,!1),this.A=Te[0]|0,this.B=Te[1]|0,this.C=Te[2]|0,this.D=Te[3]|0,this.E=Te[4]|0,this.F=Te[5]|0,this.G=Te[6]|0,this.H=Te[7]|0}get(){let{A:t,B:e,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[t,e,n,o,s,i,a,c]}set(t,e,n,o,s,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)Le[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let d=Le[f-15],g=Le[f-2],b=qt(d,7)^qt(d,18)^d>>>3,m=qt(g,17)^qt(g,19)^g>>>10;Le[f]=m+Le[f-7]+b+Le[f-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:l,H:u}=this;for(let f=0;f<64;f++){let d=qt(a,6)^qt(a,11)^qt(a,25),g=u+d+Wa(a,c,l)+vd[f]+Le[f]|0,m=(qt(n,2)^qt(n,13)^qt(n,22))+$a(n,o,s)|0;u=l,l=c,c=a,a=i+g|0,i=s,s=o,o=n,n=g+m|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,u=u+this.H|0,this.set(n,o,s,i,a,c,l,u)}roundClean(){Le.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var te=In(()=>new ei);function q(r,t="utf8"){let e=Mn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function wt(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=dt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var _c=Symbol.for("@achingbrain/uint8arraylist");function Bc(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let o=e+n.byteLength;if(t<o)return{buf:n,index:t-e};e=o}throw new RangeError("index is out of bounds")}function Hn(r){return!!r?.[_c]}var z=class r{bufs;length;[_c]=!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(Hn(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(Hn(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=Bc(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Bc(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(Hn(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:o}=this._subList(t,e);return wt(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:wt(n,o)}sublist(t,e){let{bufs:n,length:o}=this._subList(t,e),s=new r;return s.length=o,s.bufs=[...n],s}_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=[],o=0;for(let s=0;s<this.bufs.length;s++){let i=this.bufs[s],a=o,c=a+i.byteLength;if(o=c,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(!Hn(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 o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let s=256,i=new Int32Array(s);for(let f=0;f<s;f++)i[f]=-1;for(let f=0;f<o;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 d=l;d>=0;d--){let g=this.get(f+d);if(n[d]!==g){u=Math.max(1,d-a[g]);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=dt(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 o=gt(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,e,n),this.write(o,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 o=gt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,e,n),this.write(o,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 o=gt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,e,n),this.write(o,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=dt(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 o=gt(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,e,n),this.write(o,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 o=gt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,e,n),this.write(o,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 o=gt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,e,n),this.write(o,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 o=gt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,e,n),this.write(o,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 o=gt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,e,n),this.write(o,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(!Rt(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((o,s)=>o+s.byteLength,0)),n.length=e,n}};var Td=parseInt("11111",2),ni=parseInt("10000000",2),Ld=parseInt("01111111",2),Rc={2:Cd,3:Rd,5:_d,6:Bd,16:ri,22:ri,48:ri};function Fr(r,t={offset:0}){let e=r[t.offset]&Td;if(t.offset++,Rc[e]!=null)return Rc[e](r,t);throw new Error("No decoder for tag "+e)}function Vn(r,t){let e=0;if((r[t.offset]&ni)===ni){let n=r[t.offset]&Ld,o="0x";t.offset++;for(let s=0;s<n;s++,t.offset++)o+=r[t.offset].toString(16).padStart(2,"0");e=parseInt(o,16)}else e=r[t.offset],t.offset++;return e}function ri(r,t){Vn(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Fr(r,t);if(n===null)break;e.push(n)}return e}function Cd(r,t){let e=Vn(r,t),n=t.offset,o=t.offset+e,s=[];for(let i=n;i<o;i++)i===n&&r[i]===0||s.push(r[i]);return t.offset+=e,Uint8Array.from(s)}function Bd(r,t){let e=Vn(r,t);return t.offset+=e,["oid-unimplemented"]}function _d(r,t){return t.offset++,null}function Rd(r,t){let e=Vn(r,t),n=r[t.offset];t.offset++;let o=r.subarray(t.offset,t.offset+e);if(t.offset+=e,n!==0)throw new Error("Unused bits in bit string is unimplemented");return Fr(o,{offset:0})}function Pd(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new z;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function oi(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=Pd(r.byteLength);return new z(Uint8Array.from([t.byteLength|ni]),t)}function Ht(r){let t=new z,e=parseInt("10000000",2);return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new z(Uint8Array.from([2]),oi(t),t)}function Pc(r){let t=Uint8Array.from([0]),e=new z(t,r);return new z(Uint8Array.from([3]),oi(e),e)}function qn(r){let t=new z;for(let e of r)t.append(e);return new z(Uint8Array.from([48]),oi(t),t)}var Hr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Gn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Dc={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Gn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var Ce=Dc;async function Nc(r){let t=await Ce.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 Dd(t);return{privateKey:e[0],publicKey:e[1]}}async function Uc(r,t){let e=await Ce.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Ce.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function kc(r,t,e){let n=await Ce.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Ce.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function Dd(r){if(r.privateKey==null||r.publicKey==null)throw new rt("Private and public key are required");return Promise.all([Ce.get().subtle.exportKey("jwk",r.privateKey),Ce.get().subtle.exportKey("jwk",r.publicKey)])}function Oc(r){if(r.kty!=="RSA")throw new rt("invalid key type");if(r.n==null)throw new rt("invalid key modulus");return J(r.n,"base64url").length*8}var fr=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Vr.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return pt.createV1(114,this._multihash)}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Rt(this.raw,t.raw)}verify(t,e){return kc(this._key,e,t)}},qr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Vr.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Rt(this.raw,t.raw)}sign(t){return Uc(this._key,t)}};var si=8192,ii=18,Nd=1062,Ud=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function Mc(r){let t=Fr(r);return{n:q(t[1],"base64url"),e:q(t[2],"base64url"),d:q(t[3],"base64url"),p:q(t[4],"base64url"),q:q(t[5],"base64url"),dp:q(t[6],"base64url"),dq:q(t[7],"base64url"),qi:q(t[8],"base64url"),kty:"RSA"}}function kd(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 rt("JWK was missing components");return qn([Ht(Uint8Array.from([0])),Ht(J(r.n,"base64url")),Ht(J(r.e,"base64url")),Ht(J(r.d,"base64url")),Ht(J(r.p,"base64url")),Ht(J(r.q,"base64url")),Ht(J(r.dp,"base64url")),Ht(J(r.dq,"base64url")),Ht(J(r.qi,"base64url"))]).subarray()}function Kc(r){let t=Fr(r,{offset:0});return{kty:"RSA",n:q(t[1][0],"base64url"),e:q(t[1][1],"base64url")}}function ai(r){if(r.n==null||r.e==null)throw new rt("JWK was missing components");return qn([Ud,Pc(qn([Ht(J(r.n,"base64url")),Ht(J(r.e,"base64url"))]))]).subarray()}function Fc(r){let t=Mc(r);return Hc(t)}function ci(r,t){if(r.byteLength>=Nd)throw new Ye("Key size is too large");let e=Kc(r);if(t==null){let n=te(Qt.encode({Type:yt.RSA,Data:r}));t=vt(ii,n)}return new fr(e,t)}function Hc(r){if(Oc(r)>si)throw new rt("Key size is too large");let t=qc(r),e=te(Qt.encode({Type:yt.RSA,Data:ai(t.publicKey)})),n=vt(ii,e);return new qr(t.privateKey,new fr(t.publicKey,n))}async function Vc(r){if(r>si)throw new rt("Key size is too large");let t=await Nc(r),e=te(Qt.encode({Type:yt.RSA,Data:ai(t.publicKey)})),n=vt(ii,e);return new qr(t.privateKey,new fr(t.publicKey,n))}function qc(r){if(r==null)throw new rt("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var zn=class extends sr{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,_r(t);let n=be(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let o=this.blockLen,s=new Uint8Array(o);s.set(n.length>o?t.create().update(n).digest():n);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=t.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),s.fill(0)}update(t){return or(this),this.iHash.update(t),this}digestInto(t){or(this),nr(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return t=t,t.finished=o,t.destroyed=s,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},hr=(r,t,e)=>new zn(r,t).update(e).digest();hr.create=(r,t)=>new zn(r,t);function Gc(r){r.lowS!==void 0&&Gt("lowS",r.lowS),r.prehash!==void 0&&Gt("prehash",r.prehash)}function Od(r){let t=Nr(r);Kt(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:o}=t;if(e){if(!n.eql(o,n.ZERO))throw new Error("invalid 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("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Md,hexToBytes:Kd}=Bn,li=class extends Error{constructor(t=""){super(t)}},he={Err:li,_tlv:{encode:(r,t)=>{let{Err:e}=he;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,o=ke(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?ke(o.length/2|128):"";return ke(r)+s+o+t},decode(r,t){let{Err:e}=he,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let o=t[n++],s=!!(o&128),i=0;if(!s)i=o;else{let c=o&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let l=t.subarray(n,n+c);if(l.length!==c)throw new e("tlv.decode: length bytes not complete");if(l[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let u of l)i=i<<8|u;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=he;if(r<de)throw new t("integer: negative integers are not allowed");let e=ke(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=he;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Md(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=he,o=typeof r=="string"?Kd(r):r;ar(o);let{v:s,l:i}=n.decode(48,o);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,s),{v:l,l:u}=n.decode(2,c);if(u.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(l)}},hexFromSig(r){let{_tlv:t,_int:e}=he,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}},de=BigInt(0),bt=BigInt(1),lw=BigInt(2),zc=BigInt(3),uw=BigInt(4);function Fd(r){let t=Od(r),{Fp:e}=t,n=ve(t.n,t.nBitLength),o=t.toBytes||((m,h,w)=>{let x=h.toAffine();return ue(Uint8Array.from([4]),e.toBytes(x.x),e.toBytes(x.y))}),s=t.fromBytes||(m=>{let h=m.subarray(1),w=e.fromBytes(h.subarray(0,e.BYTES)),x=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:w,y:x}});function i(m){let{a:h,b:w}=t,x=e.sqr(m),p=e.mul(x,m);return e.add(e.add(p,e.mul(m,h)),w)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return Pr(m,bt,t.n)}function c(m){let{allowedPrivateKeyLengths:h,nByteLength:w,wrapPrivateKey:x,n:p}=t;if(h&&typeof m!="bigint"){if(Se(m)&&(m=ae(m)),typeof m!="string"||!h.includes(m.length))throw new Error("invalid private key");m=m.padStart(w*2,"0")}let I;try{I=typeof m=="bigint"?m:ce(ot("private key",m,w))}catch{throw new Error("invalid private key, expected hex or "+w+" bytes, got "+typeof m)}return x&&(I=Z(I,p)),xt("private key",I,bt,p),I}function l(m){if(!(m instanceof d))throw new Error("ProjectivePoint expected")}let u=Me((m,h)=>{let{px:w,py:x,pz:p}=m;if(e.eql(p,e.ONE))return{x:w,y:x};let I=m.is0();h==null&&(h=I?e.ONE:e.inv(p));let R=e.mul(w,h),_=e.mul(x,h),v=e.mul(p,h);if(I)return{x:e.ZERO,y:e.ZERO};if(!e.eql(v,e.ONE))throw new Error("invZ was invalid");return{x:R,y:_}}),f=Me(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:h,y:w}=m.toAffine();if(!e.isValid(h)||!e.isValid(w))throw new Error("bad point: x or y not FE");let x=e.sqr(w),p=i(h);if(!e.eql(x,p))throw new Error("bad point: equation left != right");if(!m.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class d{constructor(h,w,x){if(this.px=h,this.py=w,this.pz=x,h==null||!e.isValid(h))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(x==null||!e.isValid(x))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x:w,y:x}=h||{};if(!h||!e.isValid(w)||!e.isValid(x))throw new Error("invalid affine point");if(h instanceof d)throw new Error("projective point not allowed");let p=I=>e.eql(I,e.ZERO);return p(w)&&p(x)?d.ZERO:new d(w,x,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let w=e.invertBatch(h.map(x=>x.pz));return h.map((x,p)=>x.toAffine(w[p])).map(d.fromAffine)}static fromHex(h){let w=d.fromAffine(s(ot("pointHex",h)));return w.assertValidity(),w}static fromPrivateKey(h){return d.BASE.multiply(c(h))}static msm(h,w){return Dn(d,n,h,w)}_setWindowSize(h){b.setWindowSize(this,h)}assertValidity(){f(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){l(h);let{px:w,py:x,pz:p}=this,{px:I,py:R,pz:_}=h,v=e.eql(e.mul(w,_),e.mul(I,p)),B=e.eql(e.mul(x,_),e.mul(R,p));return v&&B}negate(){return new d(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:w}=t,x=e.mul(w,zc),{px:p,py:I,pz:R}=this,_=e.ZERO,v=e.ZERO,B=e.ZERO,L=e.mul(p,p),M=e.mul(I,I),N=e.mul(R,R),O=e.mul(p,I);return O=e.add(O,O),B=e.mul(p,R),B=e.add(B,B),_=e.mul(h,B),v=e.mul(x,N),v=e.add(_,v),_=e.sub(M,v),v=e.add(M,v),v=e.mul(_,v),_=e.mul(O,_),B=e.mul(x,B),N=e.mul(h,N),O=e.sub(L,N),O=e.mul(h,O),O=e.add(O,B),B=e.add(L,L),L=e.add(B,L),L=e.add(L,N),L=e.mul(L,O),v=e.add(v,L),N=e.mul(I,R),N=e.add(N,N),L=e.mul(N,O),_=e.sub(_,L),B=e.mul(N,M),B=e.add(B,B),B=e.add(B,B),new d(_,v,B)}add(h){l(h);let{px:w,py:x,pz:p}=this,{px:I,py:R,pz:_}=h,v=e.ZERO,B=e.ZERO,L=e.ZERO,M=t.a,N=e.mul(t.b,zc),O=e.mul(w,I),F=e.mul(x,R),T=e.mul(p,_),C=e.add(w,x),E=e.add(I,R);C=e.mul(C,E),E=e.add(O,F),C=e.sub(C,E),E=e.add(w,p);let y=e.add(I,_);return E=e.mul(E,y),y=e.add(O,T),E=e.sub(E,y),y=e.add(x,p),v=e.add(R,_),y=e.mul(y,v),v=e.add(F,T),y=e.sub(y,v),L=e.mul(M,E),v=e.mul(N,T),L=e.add(v,L),v=e.sub(F,L),L=e.add(F,L),B=e.mul(v,L),F=e.add(O,O),F=e.add(F,O),T=e.mul(M,T),E=e.mul(N,E),F=e.add(F,T),T=e.sub(O,T),T=e.mul(M,T),E=e.add(E,T),O=e.mul(F,E),B=e.add(B,O),O=e.mul(y,E),v=e.mul(C,v),v=e.sub(v,O),O=e.mul(C,F),L=e.mul(y,L),L=e.add(L,O),new d(v,B,L)}subtract(h){return this.add(h.negate())}is0(){return this.equals(d.ZERO)}wNAF(h){return b.wNAFCached(this,h,d.normalizeZ)}multiplyUnsafe(h){let{endo:w,n:x}=t;xt("scalar",h,de,x);let p=d.ZERO;if(h===de)return p;if(this.is0()||h===bt)return this;if(!w||b.hasPrecomputes(this))return b.wNAFCachedUnsafe(this,h,d.normalizeZ);let{k1neg:I,k1:R,k2neg:_,k2:v}=w.splitScalar(h),B=p,L=p,M=this;for(;R>de||v>de;)R&bt&&(B=B.add(M)),v&bt&&(L=L.add(M)),M=M.double(),R>>=bt,v>>=bt;return I&&(B=B.negate()),_&&(L=L.negate()),L=new d(e.mul(L.px,w.beta),L.py,L.pz),B.add(L)}multiply(h){let{endo:w,n:x}=t;xt("scalar",h,bt,x);let p,I;if(w){let{k1neg:R,k1:_,k2neg:v,k2:B}=w.splitScalar(h),{p:L,f:M}=this.wNAF(_),{p:N,f:O}=this.wNAF(B);L=b.constTimeNegate(R,L),N=b.constTimeNegate(v,N),N=new d(e.mul(N.px,w.beta),N.py,N.pz),p=L.add(N),I=M.add(O)}else{let{p:R,f:_}=this.wNAF(h);p=R,I=_}return d.normalizeZ([p,I])[0]}multiplyAndAddUnsafe(h,w,x){let p=d.BASE,I=(_,v)=>v===de||v===bt||!_.equals(p)?_.multiplyUnsafe(v):_.multiply(v),R=I(this,w).add(I(h,x));return R.is0()?void 0:R}toAffine(h){return u(this,h)}isTorsionFree(){let{h,isTorsionFree:w}=t;if(h===bt)return!0;if(w)return w(d,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:w}=t;return h===bt?this:w?w(d,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return Gt("isCompressed",h),this.assertValidity(),o(d,this,h)}toHex(h=!0){return Gt("isCompressed",h),ae(this.toRawBytes(h))}}d.BASE=new d(t.Gx,t.Gy,e.ONE),d.ZERO=new d(e.ZERO,e.ONE,e.ZERO);let g=t.nBitLength,b=Pn(d,t.endo?Math.ceil(g/2):g);return{CURVE:t,ProjectivePoint:d,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function Hd(r){let t=Nr(r);return Kt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Wc(r){let t=Hd(r),{Fp:e,n}=t,o=e.BYTES+1,s=2*e.BYTES+1;function i(T){return Z(T,n)}function a(T){return _n(T,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:l,weierstrassEquation:u,isWithinCurveOrder:f}=Fd({...t,toBytes(T,C,E){let y=C.toAffine(),A=e.toBytes(y.x),S=ue;return Gt("isCompressed",E),E?S(Uint8Array.from([C.hasEvenY()?2:3]),A):S(Uint8Array.from([4]),A,e.toBytes(y.y))},fromBytes(T){let C=T.length,E=T[0],y=T.subarray(1);if(C===o&&(E===2||E===3)){let A=ce(y);if(!Pr(A,bt,e.ORDER))throw new Error("Point is not on curve");let S=u(A),P;try{P=e.sqrt(S)}catch(H){let K=H instanceof Error?": "+H.message:"";throw new Error("Point is not on curve"+K)}let D=(P&bt)===bt;return(E&1)===1!==D&&(P=e.neg(P)),{x:A,y:P}}else if(C===s&&E===4){let A=e.fromBytes(y.subarray(0,e.BYTES)),S=e.fromBytes(y.subarray(e.BYTES,2*e.BYTES));return{x:A,y:S}}else{let A=o,S=s;throw new Error("invalid Point, expected length of "+A+", or uncompressed "+S+", got "+C)}}}),d=T=>ae(Ae(T,t.nByteLength));function g(T){let C=n>>bt;return T>C}function b(T){return g(T)?i(-T):T}let m=(T,C,E)=>ce(T.slice(C,E));class h{constructor(C,E,y){this.r=C,this.s=E,this.recovery=y,this.assertValidity()}static fromCompact(C){let E=t.nByteLength;return C=ot("compactSignature",C,E*2),new h(m(C,0,E),m(C,E,2*E))}static fromDER(C){let{r:E,s:y}=he.toSig(ot("DER",C));return new h(E,y)}assertValidity(){xt("r",this.r,bt,n),xt("s",this.s,bt,n)}addRecoveryBit(C){return new h(this.r,this.s,C)}recoverPublicKey(C){let{r:E,s:y,recovery:A}=this,S=_(ot("msgHash",C));if(A==null||![0,1,2,3].includes(A))throw new Error("recovery id invalid");let P=A===2||A===3?E+t.n:E;if(P>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let D=(A&1)===0?"02":"03",k=c.fromHex(D+d(P)),H=a(P),K=i(-S*H),G=i(y*H),X=c.BASE.multiplyAndAddUnsafe(k,K,G);if(!X)throw new Error("point at infinify");return X.assertValidity(),X}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new h(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Oe(this.toDERHex())}toDERHex(){return he.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Oe(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}let w={isValidPrivateKey(T){try{return l(T),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let T=ys(t.n);return rc(t.randomBytes(T),t.n)},precompute(T=8,C=c.BASE){return C._setWindowSize(T),C.multiply(BigInt(3)),C}};function x(T,C=!0){return c.fromPrivateKey(T).toRawBytes(C)}function p(T){let C=Se(T),E=typeof T=="string",y=(C||E)&&T.length;return C?y===o||y===s:E?y===2*o||y===2*s:T instanceof c}function I(T,C,E=!0){if(p(T))throw new Error("first arg must be private key");if(!p(C))throw new Error("second arg must be public key");return c.fromHex(C).multiply(l(T)).toRawBytes(E)}let R=t.bits2int||function(T){if(T.length>8192)throw new Error("input is too large");let C=ce(T),E=T.length*8-t.nBitLength;return E>0?C>>BigInt(E):C},_=t.bits2int_modN||function(T){return i(R(T))},v=Dr(t.nBitLength);function B(T){return xt("num < 2^"+t.nBitLength,T,de,v),Ae(T,t.nByteLength)}function L(T,C,E=M){if(["recovered","canonical"].some(it=>it in E))throw new Error("sign() legacy options not supported");let{hash:y,randomBytes:A}=t,{lowS:S,prehash:P,extraEntropy:D}=E;S==null&&(S=!0),T=ot("msgHash",T),Gc(E),P&&(T=ot("prehashed msgHash",y(T)));let k=_(T),H=l(C),K=[B(H),B(k)];if(D!=null&&D!==!1){let it=D===!0?A(e.BYTES):D;K.push(ot("extraEntropy",it))}let G=ue(...K),X=k;function st(it){let lt=R(it);if(!f(lt))return;let St=a(lt),Pt=c.BASE.multiply(lt).toAffine(),_t=i(Pt.x);if(_t===de)return;let Jt=i(St*i(X+_t*H));if(Jt===de)return;let re=(Pt.x===_t?0:2)|Number(Pt.y&bt),Ir=Jt;return S&&g(Jt)&&(Ir=b(Jt),re^=1),new h(_t,Ir,re)}return{seed:G,k2sig:st}}let M={lowS:t.lowS,prehash:!1},N={lowS:t.lowS,prehash:!1};function O(T,C,E=M){let{seed:y,k2sig:A}=L(T,C,E),S=t;return hs(S.hash.outputLen,S.nByteLength,S.hmac)(y,A)}c.BASE._setWindowSize(8);function F(T,C,E,y=N){let A=T;C=ot("msgHash",C),E=ot("publicKey",E);let{lowS:S,prehash:P,format:D}=y;if(Gc(y),"strict"in y)throw new Error("options.strict was renamed to lowS");if(D!==void 0&&D!=="compact"&&D!=="der")throw new Error("format must be compact or der");let k=typeof A=="string"||Se(A),H=!k&&!D&&typeof A=="object"&&A!==null&&typeof A.r=="bigint"&&typeof A.s=="bigint";if(!k&&!H)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let K,G;try{if(H&&(K=new h(A.r,A.s)),k){try{D!=="compact"&&(K=h.fromDER(A))}catch(re){if(!(re instanceof he.Err))throw re}!K&&D!=="der"&&(K=h.fromCompact(A))}G=c.fromHex(E)}catch{return!1}if(!K||S&&K.hasHighS())return!1;P&&(C=t.hash(C));let{r:X,s:st}=K,it=_(C),lt=a(st),St=i(it*lt),Pt=i(X*lt),_t=c.BASE.multiplyAndAddUnsafe(G,St,Pt)?.toAffine();return _t?i(_t.x)===X:!1}return{CURVE:t,getPublicKey:x,getSharedSecret:I,sign:O,verify:F,ProjectivePoint:c,Signature:h,utils:w}}function Vd(r){return{hash:r,hmac:(t,...e)=>hr(r,t,ss(...e)),randomBytes:Rr}}function $c(r,t){let e=n=>Wc({...r,...Vd(n)});return{...e(t),create:e}}var jc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Xc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),qd=BigInt(1),ui=BigInt(2),Zc=(r,t)=>(r+t/ui)/t;function Gd(r){let t=jc,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%t,u=l*l*r%t,f=at(u,e,t)*u%t,d=at(f,e,t)*u%t,g=at(d,ui,t)*l%t,b=at(g,o,t)*g%t,m=at(b,s,t)*b%t,h=at(m,a,t)*m%t,w=at(h,c,t)*h%t,x=at(w,a,t)*m%t,p=at(x,e,t)*u%t,I=at(p,i,t)*b%t,R=at(I,n,t)*l%t,_=at(R,ui,t);if(!fi.eql(fi.sqr(_),r))throw new Error("Cannot find square root");return _}var fi=ve(jc,void 0,void 0,{sqrt:Gd}),ze=$c({a:BigInt(0),b:BigInt(7),Fp:fi,n:Xc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Xc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-qd*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=Zc(s*r,t),c=Zc(-n*r,t),l=Z(r-a*e-c*o,t),u=Z(-a*n-c*s,t),f=l>i,d=u>i;if(f&&(l=t-l),d&&(u=t-u),l>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:l,k2neg:d,k2:u}}}},te),bw=BigInt(0);var xw=ze.ProjectivePoint;function Yc(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Jc(r,t,e){let n=fe.digest(e instanceof Uint8Array?e:e.subarray());if(Yc(n))return n.then(({digest:o})=>ze.verify(t,o,r)).catch(o=>{throw new Hr(String(o))});try{return ze.verify(t,n.digest,r)}catch(o){throw new Hr(String(o))}}var Wn=class{type="secp256k1";raw;_key;constructor(t){this._key=tl(t),this.raw=Qc(this._key)}toMultihash(){return se.digest(lr(this))}toCID(){return pt.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Rt(this.raw,t.raw)}verify(t,e){return Jc(this._key,e,t)}};function hi(r){return new Wn(r)}function Qc(r){return ze.ProjectivePoint.fromHex(r).toRawBytes(!0)}function tl(r){try{return ze.ProjectivePoint.fromHex(r),r}catch(t){throw new Ye(String(t))}}function Gr(r,t){let{Type:e,Data:n}=Qt.decode(r),o=n??new Uint8Array;switch(e){case yt.RSA:return ci(o,t);case yt.Ed25519:return vs(o);case yt.secp256k1:return hi(o);default:throw new De}}function el(r){let{Type:t,Data:e}=Qt.decode(r.digest),n=e??new Uint8Array;switch(t){case yt.Ed25519:return vs(n);case yt.secp256k1:return hi(n);default:throw new De}}function lr(r){return Qt.encode({Type:yt[r.type],Data:r.raw})}var rl=Symbol.for("nodejs.util.inspect.custom"),zd=114,zr=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[$o]=!0;toString(){return this.string==null&&(this.string=nt.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return pt.createV1(zd,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return Rt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return Rt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[rl](){return`PeerId(${this.toString()})`}},Wr=class extends zr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},$r=class extends zr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Xr=class extends zr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},Wd=2336,Zr=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=se.digest(J(this.url))}[rl](){return`PeerId(${this.url})`}[$o]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return pt.createV1(Wd,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=q(t)),t.toString()===this.toString())}};var $d=114,nl=2336;function dr(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=we(nt.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return Xd(pt.parse(r));if(t==null)throw new rt('Please pass a multibase decoder for strings that do not start with "1" or "Q"');e=we(t.decode(r))}return ol(e)}function di(r){if(r.type==="Ed25519")return new $r({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Xr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new Wr({multihash:r.toCID().multihash,publicKey:r});throw new De}function ol(r){if(jd(r))return new Wr({multihash:r});if(Zd(r))try{let t=el(r);if(t.type==="Ed25519")return new $r({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Xr({multihash:r,publicKey:t})}catch{let e=q(r.digest);return new Zr(new URL(e))}throw new bn("Supplied PeerID Multihash is invalid")}function Xd(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==$d&&r.code!==nl)throw new wn("Supplied PeerID CID is invalid");if(r.code===nl){let t=q(r.multihash.digest);return new Zr(new URL(t))}return ol(r.multihash)}function Zd(r){return r.code===se.code}function jd(r){return r.code===fe.code}var $n=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,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",l=2**(8*o)-1;for(;;){let u=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let d=Number.parseInt(f,t);if(!Number.isNaN(d))return d});if(u===void 0)break;if(s*=t,s+=u,s>l||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&c&&i>1?void 0:s})}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 o=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[o]=i[0],e[o+1]=i[1],e[o+2]=i[2],e[o+3]=i[3],[o+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[o,!1];e[o]=s>>8,e[o+1]=s&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,o]=t(e);if(n===16)return e;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=t(s.subarray(0,i));return e.set(s.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var sl=45,Yd=15,pr=new $n;function pi(r){if(!(r.length>Yd))return pr.new(r).parseWith(()=>pr.readIPv4Addr())}function mi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>sl))return pr.new(r).parseWith(()=>pr.readIPv6Addr())}function Xn(r,t=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>sl)return;let e=pr.new(r).parseWith(()=>pr.readIPAddr());if(e)return t&&e.length===4?Uint8Array.from([0,0,0,0,0,0,0,0,0,0,255,255,e[0],e[1],e[2],e[3]]):e}var _b=parseInt("0xFFFF",16),Rb=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function Zn(r){return!!pi(r)}function jn(r){return!!mi(r)}function Yn(r){return!!Xn(r)}var cl=Zn,rp=jn,gi=function(r){let t=0;if(r=r.toString().trim(),cl(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(rp(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=cl(e[n]),i;s&&(i=gi(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 s=[n,1];for(n=9-e.length;n>0;n--)s.push("0");e.splice.apply(e,s)}let o=new Uint8Array(t+16);for(n=0;n<e.length;n++){let s=parseInt(e[n],16);o[t++]=s>>8&255,o[t++]=s&255}return o}throw new Error("invalid ip address")},ll=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let o=[];for(let s=0;s<e;s++)o.push(r[t+s]);return o.join(".")}if(e===16){let o=[];for(let s=0;s<e;s+=2)o.push(n.getUint16(t+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var mr={},yi={},op=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[481,-1,"http-path"],[777,-1,"memory"]];op.forEach(r=>{let t=sp(...r);yi[t.code]=t,mr[t.name]=t});function sp(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function et(r){if(typeof r=="number"){if(yi[r]!=null)return yi[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(mr[r]!=null)return mr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var px=et("ip4"),mx=et("ip6"),gx=et("ipcidr");function Ei(r,t){switch(et(r).code){case 4:case 41:return ap(t);case 42:return xi(t);case 43:return q(t,"base10");case 6:case 273:case 33:case 132:return hl(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return xi(t);case 421:return fp(t);case 444:return fl(t);case 445:return fl(t);case 466:return up(t);case 481:return globalThis.encodeURIComponent(xi(t));default:return q(t,"base16")}}function Si(r,t){switch(et(r).code){case 4:return ul(t);case 41:return ul(t);case 42:return bi(t);case 43:return J(t,"base10");case 6:case 273:case 33:case 132:return Ai(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return bi(t);case 421:return cp(t);case 444:return hp(t);case 445:return dp(t);case 466:return lp(t);case 481:return bi(globalThis.decodeURIComponent(t));default:return J(t,"base16")}}var wi=Object.values(Ve).map(r=>r.decoder),ip=function(){let r=wi[0].or(wi[1]);return wi.slice(2).forEach(t=>r=r.or(t)),r}();function ul(r){if(!Yn(r))throw new Error("invalid ip address");return gi(r)}function ap(r){let t=ll(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!Yn(t))throw new Error("invalid ip address");return t}function Ai(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function hl(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function bi(r){let t=J(r),e=Uint8Array.from(Ft(t.length));return wt([e,t],e.length+t.length)}function xi(r){let t=Ut(r);if(r=r.slice(Q(t)),r.length!==t)throw new Error("inconsistent lengths");return q(r)}function cp(r){let t;r[0]==="Q"||r[0]==="1"?t=we(nt.decode(`z${r}`)).bytes:t=pt.parse(r).multihash.bytes;let e=Uint8Array.from(Ft(t.length));return wt([e,t],e.length+t.length)}function lp(r){let t=ip.decode(r),e=Uint8Array.from(Ft(t.length));return wt([e,t],e.length+t.length)}function up(r){let t=Ut(r),e=r.slice(Q(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+q(e,"base64url")}function fp(r){let t=Ut(r),e=r.slice(Q(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=oe.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 o=Ai(n);return wt([e,o],e.length+o.length)}function dp(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=oe.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 o=Ai(n);return wt([e,o],e.length+o.length)}function fl(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=q(t,"base32"),o=hl(e);return`${n}:${o}`}function dl(r){r=vi(r);let t=[],e=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=et(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw new Jn("invalid address: "+r);if(a.path===!0){n=vi(o.slice(s).join("/")),t.push([a.code,Si(a.code,n)]),e.push([a.code,n]);break}let c=Si(a.code,o[s]);t.push([a.code,c]),e.push([a.code,Ei(a.code,c)])}return{string:pl(e),bytes:Qn(t),tuples:t,stringTuples:e,path:n}}function Ii(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=Ut(r,o),i=Q(s),a=et(s),c=pp(a,r.slice(o+i));if(c===0){t.push([s]),e.push([s]),o+=i;continue}let l=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw new Jn("Invalid address Uint8Array: "+q(r,"base16"));t.push([s,l]);let u=Ei(s,l);if(e.push([s,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:pl(e),tuples:t,stringTuples:e,path:n}}function pl(r){let t=[];return r.map(e=>{let n=et(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),vi(t.join("/"))}function Qn(r){return wt(r.map(t=>{let e=et(t[0]),n=Uint8Array.from(Ft(e.code));return t.length>1&&t[1]!=null&&(n=wt([n,t[1]])),n}))}function pp(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Ut(t instanceof Uint8Array?t:Uint8Array.from(t));return e+Q(e)}}function vi(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}var Jn=class extends Error{static name="ParseError";name="ParseError";constructor(t){super(`Error parsing address: ${t}`)}};var mp=Symbol.for("nodejs.util.inspect.custom"),Li=Symbol.for("@multiformats/js-multiaddr/multiaddr"),gp=[et("dns").code,et("dns4").code,et("dns6").code,et("dnsaddr").code],Ti=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},to=class r{bytes;#t;#e;#r;#n;[Li]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Ii(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=dl(t)}else if(gl(t))e=Ii(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#t=e.string,this.#e=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#t}toJSON(){return this.toString()}toOptions(){let t,e,n,o,s="",i=et("tcp"),a=et("udp"),c=et("ip4"),l=et("ip6"),u=et("dns6"),f=et("ip6zone");for(let[g,b]of this.stringTuples())g===f.code&&(s=`%${b??""}`),gp.includes(g)&&(e=i.name==="tcp"?"tcp":"udp",o=443,n=`${b??""}${s}`,t=g===u.code?6:4),(g===i.code||g===a.code)&&(e=et(g).name==="tcp"?"tcp":"udp",o=parseInt(b??"")),(g===c.code||g===l.code)&&(e=et(g).name==="tcp"?"tcp":"udp",n=`${b??""}${s}`,t=g===l.code?6:4);if(t==null||e==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:o}}protos(){return this.#e.map(([t])=>Object.assign({},et(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>et(t).name)}tuples(){return this.#e.map(([t,e])=>e==null?[t]:[t,e])}stringTuples(){return this.#r.map(([t,e])=>e==null?[t]:[t,e])}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),o=n.lastIndexOf(e);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,o))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(Qn(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===mr.p2p.code&&t.push([n,o]),n===mr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?q(nt.decode(`z${n}`),"base58btc"):q(pt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return Rt(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=ml.get(e.name);if(n==null)throw new Ti(`no available resolver for ${e.name}`);return(await n(this,t)).map(s=>ee(s))}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)}[mp](){return`Multiaddr(${this.#t})`}};var ml=new Map;function gl(r){return!!r?.[Li]}function ee(r){return new to(r)}var yp=r=>r.toString().split("/").slice(1),gr=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),W=r=>({match:t=>gr(e=>e===r).match(t),pattern:r}),We=()=>({match:r=>gr(t=>typeof t=="string").match(r),pattern:"{string}"}),jr=()=>({match:r=>gr(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),tt=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{nt.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),Yr=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Or.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),j=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),Lt=(...r)=>({match:t=>{let e;for(let n of r){let o=n.match(t);o!==!1&&(e==null||o.length<e.length)&&(e=o)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),$=(...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 ct(...r){function t(o){let s=yp(o);for(let i of r){let a=i.match(s);if(a===!1)return!1;s=a}return s}function e(o){return t(o)!==!1}function n(o){let s=t(o);return s===!1?!1:s.length===0}return{matchers:r,matches:e,exactMatch:n}}var ro=$(W("dns4"),We()),no=$(W("dns6"),We()),oo=$(W("dnsaddr"),We()),Bi=$(W("dns"),We()),$x=ct(ro,j(tt())),Xx=ct(no,j(tt())),Zx=ct(oo,j(tt())),jx=ct(Lt(Bi,oo,ro,no),j(tt())),yl=$(W("ip4"),gr(Zn)),wl=$(W("ip6"),gr(jn)),_i=Lt(yl,wl),pe=Lt(_i,Bi,ro,no,oo),Yx=ct(Lt(_i,$(Lt(Bi,oo,ro,no),j(tt())))),Jx=ct(yl),Qx=ct(wl),t1=ct(_i),Ri=$(pe,W("tcp"),jr()),Jr=$(pe,W("udp"),jr()),e1=ct($(Ri,j(tt()))),r1=ct(Jr),Pi=$(Jr,W("quic"),j(tt())),so=$(Jr,W("quic-v1"),j(tt())),wp=Lt(Pi,so),n1=ct(Pi),o1=ct(so),Ci=Lt(pe,Ri,Jr,Pi,so),bl=Lt($(Ci,W("ws"),j(tt()))),s1=ct(bl),xl=Lt($(Ci,W("wss"),j(tt())),$(Ci,W("tls"),j($(W("sni"),We())),W("ws"),j(tt()))),i1=ct(xl),El=$(Jr,W("webrtc-direct"),j(Yr()),j(Yr()),j(tt())),Sl=ct(El),Al=$(so,W("webtransport"),j(Yr()),j(Yr()),j(tt())),a1=ct(Al),eo=Lt(bl,xl,$(Ri,j(tt())),$(wp,j(tt())),$(pe,j(tt())),El,Al,tt()),vl=ct(eo),bp=$(eo,W("p2p-circuit"),tt()),c1=ct(bp),xp=Lt($(eo,W("p2p-circuit"),W("webrtc"),j(tt())),$(eo,W("webrtc"),j(tt())),$(W("webrtc"),j(tt()))),Il=ct(xp),Ep=Lt($(pe,W("tcp"),jr(),W("http"),j(tt())),$(pe,W("http"),j(tt()))),l1=ct(Ep),Sp=Lt($(pe,W("tcp"),Lt($(W("443"),W("http")),$(jr(),W("https"))),j(tt())),$(pe,W("tls"),W("http"),j(tt())),$(pe,W("https"),j(tt()))),u1=ct(Sp),Ap=Lt($(W("memory"),We(),j(tt()))),f1=ct(Ap);var Ct;(function(r){let t;(function(o){o.FIN="FIN",o.STOP_SENDING="STOP_SENDING",o.RESET="RESET",o.FIN_ACK="FIN_ACK"})(t=r.Flag||(r.Flag={}));let e;(function(o){o[o.FIN=0]="FIN",o[o.STOP_SENDING=1]="STOP_SENDING",o[o.RESET=2]="RESET",o[o.FIN_ACK=3]="FIN_ACK"})(e||(e={})),function(o){o.codec=()=>Ge(e)}(t=r.Flag||(r.Flag={}));let n;r.codec=()=>(n==null&&(n=jt((o,s,i={})=>{i.lengthDelimited!==!1&&s.fork(),o.flag!=null&&(s.uint32(8),r.Flag.codec().encode(o.flag,s)),o.message!=null&&(s.uint32(18),s.bytes(o.message)),i.lengthDelimited!==!1&&s.ldelim()},(o,s,i={})=>{let a={},c=s==null?o.len:o.pos+s;for(;o.pos<c;){let l=o.uint32();switch(l>>>3){case 1:{a.flag=r.Flag.codec().decode(o);break}case 2:{a.message=o.bytes();break}default:{o.skipType(l&7);break}}}return a})),n),r.encode=o=>Zt(o,r.codec()),r.decode=(o,s)=>Xt(o,r.codec(),s)})(Ct||(Ct={}));var Tl=["stun:stun.l.google.com:19302","stun:global.stun.twilio.com:3478","stun:stun.cloudflare.com:3478","stun:stun.services.mozilla.com:3478"],Di=Array.from("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890"),Ll="libp2p+webrtc+v1/";var Cl=466,Bl=2*1024*1024,_l=30*1e3,yr=16*1024;function vp(r=yr){let t=Q(r-Q(r)),e=1+Q(Object.keys(Ct.Flag).length-1),n=1,o=r-t-e-n,s=Q(o);return t+e+n+s}var Rl=vp(),Pl=5e3,Dl=5e3,Nl=3e4,Ni="/webrtc",Qr="/webrtc-signaling/0.0.1";var Ul=function(r,t,e){if(e||arguments.length===2)for(var n=0,o=t.length,s;n<o;n++)(s||!(n in t))&&(s||(s=Array.prototype.slice.call(t,0,n)),s[n]=t[n]);return r.concat(s||Array.prototype.slice.call(t))},Ip=function(){function r(t,e,n){this.name=t,this.version=e,this.os=n,this.type="browser"}return r}();var Tp=function(){function r(t){this.version=t,this.type="node",this.name="node",this.os=process.platform}return r}();var Lp=function(){function r(t,e,n,o){this.name=t,this.version=e,this.os=n,this.bot=o,this.type="bot-device"}return r}();var Cp=function(){function r(){this.type="bot",this.bot=!0,this.name="bot",this.version=null,this.os=null}return r}();var Bp=function(){function r(){this.type="react-native",this.name="react-native",this.version=null,this.os=null}return r}();var _p=/alexa|bot|crawl(er|ing)|facebookexternalhit|feedburner|google web preview|nagios|postrank|pingdom|slurp|spider|yahoo!|yandex/,Rp=/(nuhk|curl|Googlebot|Yammybot|Openbot|Slurp|MSNBot|Ask\ Jeeves\/Teoma|ia_archiver)/,kl=3,Pp=[["aol",/AOLShield\/([0-9\._]+)/],["edge",/Edge\/([0-9\._]+)/],["edge-ios",/EdgiOS\/([0-9\._]+)/],["yandexbrowser",/YaBrowser\/([0-9\._]+)/],["kakaotalk",/KAKAOTALK\s([0-9\.]+)/],["samsung",/SamsungBrowser\/([0-9\.]+)/],["silk",/\bSilk\/([0-9._-]+)\b/],["miui",/MiuiBrowser\/([0-9\.]+)$/],["beaker",/BeakerBrowser\/([0-9\.]+)/],["edge-chromium",/EdgA?\/([0-9\.]+)/],["chromium-webview",/(?!Chrom.*OPR)wv\).*Chrom(?:e|ium)\/([0-9\.]+)(:?\s|$)/],["chrome",/(?!Chrom.*OPR)Chrom(?:e|ium)\/([0-9\.]+)(:?\s|$)/],["phantomjs",/PhantomJS\/([0-9\.]+)(:?\s|$)/],["crios",/CriOS\/([0-9\.]+)(:?\s|$)/],["firefox",/Firefox\/([0-9\.]+)(?:\s|$)/],["fxios",/FxiOS\/([0-9\.]+)/],["opera-mini",/Opera Mini.*Version\/([0-9\.]+)/],["opera",/Opera\/([0-9\.]+)(?:\s|$)/],["opera",/OPR\/([0-9\.]+)(:?\s|$)/],["pie",/^Microsoft Pocket Internet Explorer\/(\d+\.\d+)$/],["pie",/^Mozilla\/\d\.\d+\s\(compatible;\s(?:MSP?IE|MSInternet Explorer) (\d+\.\d+);.*Windows CE.*\)$/],["netfront",/^Mozilla\/\d\.\d+.*NetFront\/(\d.\d)/],["ie",/Trident\/7\.0.*rv\:([0-9\.]+).*\).*Gecko$/],["ie",/MSIE\s([0-9\.]+);.*Trident\/[4-7].0/],["ie",/MSIE\s(7\.0)/],["bb10",/BB10;\sTouch.*Version\/([0-9\.]+)/],["android",/Android\s([0-9\.]+)/],["ios",/Version\/([0-9\._]+).*Mobile.*Safari.*/],["safari",/Version\/([0-9\._]+).*Safari/],["facebook",/FB[AS]V\/([0-9\.]+)/],["instagram",/Instagram\s([0-9\.]+)/],["ios-webview",/AppleWebKit\/([0-9\.]+).*Mobile/],["ios-webview",/AppleWebKit\/([0-9\.]+).*Gecko\)$/],["curl",/^curl\/([0-9\.]+)$/],["searchbot",_p]],Ol=[["iOS",/iP(hone|od|ad)/],["Android OS",/Android/],["BlackBerry OS",/BlackBerry|BB10/],["Windows Mobile",/IEMobile/],["Amazon OS",/Kindle/],["Windows 3.11",/Win16/],["Windows 95",/(Windows 95)|(Win95)|(Windows_95)/],["Windows 98",/(Windows 98)|(Win98)/],["Windows 2000",/(Windows NT 5.0)|(Windows 2000)/],["Windows XP",/(Windows NT 5.1)|(Windows XP)/],["Windows Server 2003",/(Windows NT 5.2)/],["Windows Vista",/(Windows NT 6.0)/],["Windows 7",/(Windows NT 6.1)/],["Windows 8",/(Windows NT 6.2)/],["Windows 8.1",/(Windows NT 6.3)/],["Windows 10",/(Windows NT 10.0)/],["Windows ME",/Windows ME/],["Windows CE",/Windows CE|WinCE|Microsoft Pocket Internet Explorer/],["Open BSD",/OpenBSD/],["Sun OS",/SunOS/],["Chrome OS",/CrOS/],["Linux",/(Linux)|(X11)/],["Mac OS",/(Mac_PowerPC)|(Macintosh)/],["QNX",/QNX/],["BeOS",/BeOS/],["OS/2",/OS\/2/]];function Kl(r){return r?Ml(r):typeof document>"u"&&typeof navigator<"u"&&navigator.product==="ReactNative"?new Bp:typeof navigator<"u"?Ml(navigator.userAgent):Up()}function Dp(r){return r!==""&&Pp.reduce(function(t,e){var n=e[0],o=e[1];if(t)return t;var s=o.exec(r);return!!s&&[n,s]},!1)}function Ml(r){var t=Dp(r);if(!t)return null;var e=t[0],n=t[1];if(e==="searchbot")return new Cp;var o=n[1]&&n[1].split(".").join("_").split("_").slice(0,3);o?o.length<kl&&(o=Ul(Ul([],o,!0),kp(kl-o.length),!0)):o=[];var s=o.join("."),i=Np(r),a=Rp.exec(r);return a&&a[1]?new Lp(e,s,i,a[1]):new Ip(e,s,i)}function Np(r){for(var t=0,e=Ol.length;t<e;t++){var n=Ol[t],o=n[0],s=n[1],i=s.exec(r);if(i)return o}return null}function Up(){var r=typeof process<"u"&&process.version;return r?new Tp(process.version.slice(1)):null}function kp(r){for(var t=[],e=0;e<r;e++)t.push("0");return t}function ht(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Ui=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},ki=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},Fl=r=>globalThis.DOMException===void 0?new ki(r):new DOMException(r),Hl=r=>{let t=r.reason===void 0?Fl("This operation was aborted."):r.reason;return t instanceof Error?t:Fl(t)};function tn(r,t){let{milliseconds:e,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout}}=t,i,a,l=new Promise((u,f)=>{if(typeof e!="number"||Math.sign(e)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${e}\``);if(t.signal){let{signal:g}=t;g.aborted&&f(Hl(g)),a=()=>{f(Hl(g))},g.addEventListener("abort",a,{once:!0})}if(e===Number.POSITIVE_INFINITY){r.then(u,f);return}let d=new Ui;i=s.setTimeout.call(void 0,()=>{if(n){try{u(n())}catch(g){f(g)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?u():o instanceof Error?f(o):(d.message=o??`Promise timed out after ${e} milliseconds`,f(d))},e),(async()=>{try{u(await r)}catch(g){f(g)}})()}).finally(()=>{l.clear(),a&&t.signal&&t.signal.removeEventListener("abort",a)});return l.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},l}var Vl=Kl(),en=Vl!=null&&Vl.name==="firefox",io=async function*(){},ao=async r=>{};function ql(r,t,e=Nl,n){r.readyState==="open"&&Promise.resolve().then(async()=>{if(r.bufferedAmount>0){n.log("%s drain channel with %d buffered bytes",t,r.bufferedAmount);let o=ht(),s=!1;r.bufferedAmountLowThreshold=0;let i=()=>{s||(n.log("%s drain channel closed before drain",t),o.resolve())};r.addEventListener("close",i,{once:!0}),r.addEventListener("bufferedamountlow",()=>{s=!0,r.removeEventListener("close",i),o.resolve()}),await tn(o.promise,{milliseconds:e})}}).then(async()=>{r.readyState==="open"&&r.close()}).catch(o=>{n.log.error("error closing outbound stream",o)})}async function Oi(r){return r=r??{},typeof r=="function"&&(r=await r()),r.iceServers=r.iceServers??Tl.map(t=>({urls:[t]})),r}var Gl=(r=32)=>Ll+[...Array(r)].map(()=>Di.at(Math.floor(Math.random()*Di.length))).join("");var $e=class{log;peerConnection;remoteAddr;timeline;metrics;source=io();sink=ao;constructor(t,e){this.log=t.logger.forComponent("libp2p:webrtc:maconn"),this.remoteAddr=e.remoteAddr,this.timeline=e.timeline,this.peerConnection=e.peerConnection;let n=this.peerConnection,o=n.connectionState;this.peerConnection.onconnectionstatechange=()=>{this.log.trace("peer connection state change",n.connectionState,"initial state",o),(n.connectionState==="disconnected"||n.connectionState==="failed"||n.connectionState==="closed")&&(this.timeline.close=Date.now())}}async close(t){this.log.trace("closing connection"),this.peerConnection.close(),this.timeline.close=Date.now(),this.metrics?.increment({close:!0})}abort(t){this.log.error("closing connection due to error",t),this.peerConnection.close(),this.timeline.close=Date.now(),this.metrics?.increment({abort:!0})}};var co=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||(t-1&t)!==0)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}},wr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new co(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 co(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 Mi=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Be(r={}){return Op(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 Op(r,t){t=t??{};let e=t.onEnd,n=new wr,o,s,i,a=ht(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((h,w)=>{s=x=>{s=null,n.push(x);try{h(r(n))}catch(p){w(p)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=ht()})}},l=h=>s!=null?s(h):(n.push(h),o),u=h=>(n=new wr,s!=null?s({error:h}):(n.push({error:h}),o)),f=h=>{if(i)return o;if(t?.objectMode!==!0&&h?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:h})},d=h=>i?o:(i=!0,h!=null?u(h):l({done:!0})),g=()=>(n=new wr,d(),{done:!0}),b=h=>(d(h),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:g,throw:b,push:f,end:d,get readableLength(){return n.size},onEmpty:async h=>{let w=h?.signal;if(w?.throwIfAborted(),n.isEmpty())return;let x,p;w!=null&&(x=new Promise((I,R)=>{p=()=>{R(new Mi)},w.addEventListener("abort",p)}));try{await Promise.race([a.promise,x])}finally{p!=null&&w!=null&&w?.removeEventListener("abort",p)}}},e==null)return o;let m=o;return o={[Symbol.asyncIterator](){return this},next(){return m.next()},throw(h){return m.throw(h),e!=null&&(e(h),e=void 0),{done:!0}},return(){return m.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(h){return m.end(h),e!=null&&(e(h),e=void 0),o},get readableLength(){return m.readableLength},onEmpty:h=>m.onEmpty(h)},o}var lo=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};async function Yt(r,t,e){if(t==null)return r;if(t.aborted)return r.catch(()=>{}),Promise.reject(new lo(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new lo(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}function zl(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 Wl(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function $l(r,t){let e=zl(r).return?.();Wl(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var Mp=5e3;function Ki(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var uo=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=ht(),this.closed=ht(),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??Mp,this.onEnd=t.onEnd,this.onCloseRead=t?.onCloseRead,this.onCloseWrite=t?.onCloseWrite,this.onReset=t?.onReset,this.onAbort=t?.onAbort,this.source=this.streamSource=Be({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 Pe(`writable end state is "${this.writeStatus}" not "ready"`);try{this.writeStatus="writing";let e={signal:this.sinkController.signal};if(this.direction==="outbound"){let o=this.sendNewStream(e);Ki(o)&&await o}let n=()=>{$l(t,this.log)};try{this.sinkController.signal.addEventListener("abort",n),this.log.trace("sink reading from source");for await(let o of t){o=o instanceof Uint8Array?new z(o):o;let s=this.sendData(o,e);Ki(s)&&(this.sendingData=ht(),await s,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.status==="open"&&(this.log.trace("closing gracefully"),this.status="closing",await Yt(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 Yt(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await Yt(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await Yt(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();Ki(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 yn("stream reset");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}};function Fi(r){let t=new globalThis.AbortController;function e(){t.abort();for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",e)}for(let s of r){if(s?.aborted===!0){e();break}s?.addEventListener!=null&&s.addEventListener("abort",e)}function n(){for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",e)}let o=t.signal;return o.clear=n,o}var fo=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},br=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},ho=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},rn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function po(r){return r[Symbol.asyncIterator]!=null}function Xl(r,t){if(r.byteLength>t)throw new br("Message length too long")}var go=r=>{let t=Q(r),e=dt(t);return Ft(r,e),go.bytes=t,e};go.bytes=0;function nn(r,t){t=t??{};let e=t.lengthEncoder??go,n=t?.maxDataLength??4194304;function*o(s){Xl(s,n);let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return po(r)?async function*(){for await(let s of r)yield*o(s)}():function*(){for(let s of r)yield*o(s)}()}nn.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??go,n=t?.maxDataLength??4194304;return Xl(r,n),new z(e(r.byteLength),r)};var Xe;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Xe||(Xe={}));var Hi=r=>{let t=Ut(r);return Hi.bytes=Q(t),t};Hi.bytes=0;function on(r,t){let e=new z,n=Xe.LENGTH,o=-1,s=t?.lengthDecoder??Hi,i=t?.maxLengthLength??8,a=t?.maxDataLength??4194304;function*c(){for(;e.byteLength>0;){if(n===Xe.LENGTH)try{if(o=s(e),o<0)throw new fo("Invalid message length");if(o>a)throw new br("Message length too long");let l=s.bytes;e.consume(l),t?.onLength!=null&&t.onLength(o),n=Xe.DATA}catch(l){if(l instanceof RangeError){if(e.byteLength>i)throw new ho("Message length length too long");break}throw l}if(n===Xe.DATA){if(e.byteLength<o)break;let l=e.sublist(0,o);e.consume(o),t?.onData!=null&&t.onData(l),yield l,n=Xe.LENGTH}}}return po(r)?async function*(){for await(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new rn("Unexpected end of input")}():function*(){for(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new rn("Unexpected end of input")}()}on.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:s,value:i}=await r.next(e);if(s===!0)return;i!=null&&(yield i)}catch(s){if(s.code==="ERR_UNDER_READ")return{done:!0,value:null};throw s}finally{e=1}}();return on(n,{...t??{},onLength:s=>{e=s}})};var Vi=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 sn(r,t,e,n){let o=new Vi(n?.errorMessage,n?.errorCode);return e?.aborted===!0?Promise.reject(o):new Promise((s,i)=>{function a(){e?.removeEventListener("abort",u),r.removeEventListener(t,c),n?.errorEvent!=null&&r.removeEventListener(n.errorEvent,l)}let c=f=>{try{if(n?.filter?.(f)===!1)return}catch(d){a(),i(d);return}a(),s(f)},l=f=>{a(),i(f.detail)},u=()=>{a(),i(o)};e?.addEventListener("abort",u),r.addEventListener(t,c),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,l)})}var qi=class extends uo{channel;incomingData;maxBufferedAmount;bufferedAmountLowEventTimeout;maxMessageSize;receiveFinAck;finAckTimeout;openTimeout;closeController;constructor(t){let e=t.onEnd;switch(t.onEnd=o=>{this.log.trace("readable and writeable ends closed",this.status),Promise.resolve(async()=>{if(!(this.timeline.abort!=null||this.timeline.reset!==null))try{await tn(this.receiveFinAck.promise,{milliseconds:this.finAckTimeout})}catch(s){this.log.error("error receiving FIN_ACK",s)}}).then(()=>{this.incomingData.end(),this.channel.close(),e?.(o)}).catch(s=>{this.log.error("error ending stream",s)})},super(t),this.channel=t.channel,this.channel.binaryType="arraybuffer",this.incomingData=Be(),this.bufferedAmountLowEventTimeout=t.bufferedAmountLowEventTimeout??_l,this.maxBufferedAmount=t.maxBufferedAmount??Bl,this.maxMessageSize=(t.maxMessageSize??yr)-Rl,this.receiveFinAck=ht(),this.finAckTimeout=t.closeTimeout??Pl,this.openTimeout=t.openTimeout??Dl,this.closeController=new AbortController,this.channel.readyState){case"open":this.timeline.open=new Date().getTime();break;case"closed":case"closing":(this.timeline.close===void 0||this.timeline.close===0)&&(this.timeline.close=Date.now());break;case"connecting":break;default:throw this.log.error("unknown datachannel state %s",this.channel.readyState),new Pe("Unknown datachannel state")}this.channel.onopen=o=>{this.timeline.open=new Date().getTime()},this.channel.onclose=o=>{this.log.trace("received onclose event"),this.closeController.abort(),this.receiveFinAck.resolve(),this.close().catch(s=>{this.log.error("error closing stream after channel closed",s)})},this.channel.onerror=o=>{this.log.trace("received onerror event"),this.closeController.abort();let s=o.error;this.abort(s)},this.channel.onmessage=async o=>{let{data:s}=o;s===null||s.byteLength===0||this.incomingData.push(new Uint8Array(s,0,s.byteLength))};let n=this;Promise.resolve().then(async()=>{for await(let o of on(this.incomingData)){let s=n.processIncomingProtobuf(o);s!=null&&n.sourcePush(new z(s))}}).catch(o=>{this.log.error("error processing incoming data channel messages",o)})}sendNewStream(){}async _sendMessage(t,e=!0){if(this.channel.readyState==="closed"||this.channel.readyState==="closing")throw new Pe(`Invalid datachannel state - ${this.channel.readyState}`);if(this.channel.readyState!=="open"){let n=AbortSignal.timeout(this.openTimeout),o=Fi([this.closeController.signal,n]);try{this.log('channel state is "%s" and not "open", waiting for "open" event before sending data',this.channel.readyState),await sn(this.channel,"open",o)}finally{o.clear()}this.log('channel state is now "%s", sending data',this.channel.readyState)}if(e&&this.channel.bufferedAmount>this.maxBufferedAmount){let n=AbortSignal.timeout(this.bufferedAmountLowEventTimeout),o=Fi([this.closeController.signal,n]);try{this.log('channel buffer is %d, wait for "bufferedamountlow" event',this.channel.bufferedAmount),await sn(this.channel,"bufferedamountlow",o)}catch(s){throw n.aborted?new En(`Timed out waiting for DataChannel buffer to clear after ${this.bufferedAmountLowEventTimeout}ms`):s}finally{o.clear()}}try{this.channel.send(t.subarray())}catch(n){this.log.error("error while sending message",n)}}async sendData(t){for(this.log.trace("-> will send %d bytes",t.byteLength),t=t.sublist();t.byteLength>0;){let e=Math.min(t.byteLength,this.maxMessageSize),n=t.subarray(0,e),o=Ct.encode({message:n}),s=nn.single(o);this.log.trace("-> sending message %s",this.channel.readyState),await this._sendMessage(s),this.log.trace("-> sent message %s",this.channel.readyState),t.consume(e)}this.log.trace("-> sent data %s",this.channel.readyState)}async sendReset(){try{await this._sendFlag(Ct.Flag.RESET)}catch(t){this.log.error("failed to send reset - %e",t)}}async sendCloseWrite(t){if(this.channel.readyState!=="open"){this.receiveFinAck.resolve();return}if(await this._sendFlag(Ct.Flag.FIN)){this.log.trace("awaiting FIN_ACK");try{await Yt(this.receiveFinAck.promise,t?.signal,{errorMessage:"sending close-write was aborted before FIN_ACK was received",errorName:"FinAckNotReceivedError"})}catch(n){this.log.error("failed to await FIN_ACK",n)}}else this.log.trace("sending FIN failed, not awaiting FIN_ACK");this.receiveFinAck.resolve()}async sendCloseRead(){this.channel.readyState==="open"&&await this._sendFlag(Ct.Flag.STOP_SENDING)}processIncomingProtobuf(t){let e=Ct.decode(t);if(e.flag!==void 0&&(this.log.trace('incoming flag %s, write status "%s", read status "%s"',e.flag,this.writeStatus,this.readStatus),e.flag===Ct.Flag.FIN&&(this.remoteCloseWrite(),this.log.trace("sending FIN_ACK"),this._sendFlag(Ct.Flag.FIN_ACK).catch(n=>{this.log.error("error sending FIN_ACK immediately",n)})),e.flag===Ct.Flag.RESET&&this.reset(),e.flag===Ct.Flag.STOP_SENDING&&this.remoteCloseRead(),e.flag===Ct.Flag.FIN_ACK&&(this.log.trace("received FIN_ACK"),this.receiveFinAck.resolve())),this.readStatus==="ready")return e.message}async _sendFlag(t){if(this.channel.readyState!=="open")return this.log.trace('not sending flag %s because channel is "%s" and not "open"',this.channel.readyState,t.toString()),!1;this.log.trace("sending flag %s",t.toString());let e=Ct.encode({flag:t}),n=nn.single(e);try{return await this._sendMessage(n,!1),!0}catch(o){this.log.error("could not send flag %s - %e",t.toString(),o)}return!1}};function xr(r){let{channel:t,direction:e}=r;return new qi({id:e==="inbound"?`i${t.id}`:`r${t.id}`,log:r.logger.forComponent(`libp2p:webrtc:stream:${e}:${t.id}`),...r})}var _e=class{protocol;peerConnection;bufferedStreams=[];metrics;dataChannelOptions;components;log;constructor(t,e){this.components=t,this.peerConnection=e.peerConnection,this.metrics=e.metrics,this.protocol=e.protocol??Ni,this.dataChannelOptions=e.dataChannelOptions??{},this.log=t.logger.forComponent("libp2p:webrtc:muxerfactory"),this.peerConnection.ondatachannel=({channel:n})=>{if(this.log.trace('incoming early datachannel with channel id %d and label "%s"',n.id),n.label==="init"){this.log.trace("closing early init channel"),n.close();return}let o={},s=xr({channel:n,direction:"inbound",onEnd:i=>{o.onEnd(i)},logger:t.logger,...this.dataChannelOptions});o.stream=s,o.channel=n,o.onEnd=()=>{this.bufferedStreams=this.bufferedStreams.filter(i=>i.stream.id!==s.id)},this.bufferedStreams.push(o)}}createStreamMuxer(t){return new Gi(this.components,{...t,peerConnection:this.peerConnection,dataChannelOptions:this.dataChannelOptions,metrics:this.metrics,streams:this.bufferedStreams,protocol:this.protocol})}},Gi=class{init;streams;protocol;log;peerConnection;dataChannelOptions;metrics;logger;constructor(t,e){this.init=e,this.log=t.logger.forComponent("libp2p:webrtc:muxer"),this.logger=t.logger,this.streams=e.streams.map(n=>n.stream),this.peerConnection=e.peerConnection,this.protocol=e.protocol??Ni,this.metrics=e.metrics,this.dataChannelOptions=e.dataChannelOptions??{},this.peerConnection.ondatachannel=({channel:n})=>{if(this.log.trace("incoming datachannel with channel id %d",n.id),n.label==="init"){this.log.trace("closing init channel"),n.close();return}let o=n.id,s=xr({channel:n,direction:"inbound",onEnd:()=>{this.#t(s,n),this.log("incoming channel %s ended",o)},logger:this.logger,...this.dataChannelOptions});this.streams.push(s),this.metrics?.increment({incoming_stream:!0}),e?.onIncomingStream?.(s)},this.init.streams.length>0&&queueMicrotask(()=>{this.init.streams.forEach(n=>{n.onEnd=()=>{this.log("incoming early channel %s ended with state %s",n.channel.id,n.channel.readyState),this.#t(n.stream,n.channel)},this.metrics?.increment({incoming_stream:!0}),this.init?.onIncomingStream?.(n.stream)})})}#t(t,e){this.log.trace("stream %s %s %s onEnd",t.direction,t.id,t.protocol),ql(e,`${t.direction} ${t.id} ${t.protocol}`,this.dataChannelOptions.drainTimeout,{log:this.log}),this.streams=this.streams.filter(n=>n.id!==t.id),this.metrics?.increment({stream_end:!0}),this.init?.onStreamEnd?.(t)}async close(t){try{await Promise.all(this.streams.map(async e=>e.close(t)))}catch(e){this.abort(e)}}abort(t){for(let e of this.streams)e.abort(t)}source=io();sink=ao;newStream(){let t=this.peerConnection.createDataChannel(""),e=t.id;this.log.trace("opened outgoing datachannel with channel id %s",e);let n=xr({channel:t,direction:"outbound",onEnd:()=>{this.#t(n,t),this.log("outgoing channel %s ended",e)},logger:this.logger,...this.dataChannelOptions});return this.streams.push(n),this.metrics?.increment({outgoing_stream:!0}),n}};var yo=globalThis.RTCPeerConnection,wo=globalThis.RTCSessionDescription,Zl=globalThis.RTCIceCandidate;var zi=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=ht(),this.haveNext=ht()}[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=ht(),t}async throw(t){return this.ended=!0,t!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(t)),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return this.ended=!0,this.nextResult=t,this.haveNext.resolve(),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");for(;this.nextResult!=null;)await this.readNext.promise;t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=ht(),await Yt(this.readNext.promise,e?.signal,e)}};function jl(){return new zi}var bo=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Wi=class extends Error{code;constructor(t,e){super(t),this.code=e}},$i=class extends Wi{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function Yl(r,t){let e=jl();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 o=new z;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,l=new Promise((u,f)=>{c=()=>{f(new $i("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:f,value:d}=await Promise.race([n.next(),l]);return f===!0?new z:d}for(;o.byteLength<i;){let{value:f,done:d}=await Promise.race([n.next(),l]);if(d===!0)throw new bo("unexpected end of input");o.append(f)}let u=o.sublist(0,i);return o.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(o.byteLength>0){let i=r.source;r.source=async function*(){t?.yieldBytes===!1?yield o:yield*o,yield*i}()}return r}}}var xo=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Eo=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},So=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function an(r,t={}){let e=Yl(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=Q(t.maxDataLength));let n=t?.lengthDecoder??Ut,o=t?.lengthEncoder??Ft;return{read:async i=>{let a=-1,c=new z;for(;;){c.append(await e.read(1,i));try{a=n(c)}catch(l){if(l instanceof RangeError)continue;throw l}if(a<0)throw new xo("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new So("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Eo("message length too long");return e.read(a,i)},write:async(i,a)=>{await e.write(new z(o(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new z(...i.flatMap(l=>[o(l.byteLength),l]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Ao(r,t){let e=an(r,t),n={read:async(o,s)=>{let i=await e.read(s);return o.decode(i)},write:async(o,s,i)=>{await e.write(s.encode(o),i)},writeV:async(o,s,i)=>{await e.writeV(o.map(a=>s.encode(a)),i)},pb:o=>({read:async s=>n.read(o,s),write:async(s,i)=>n.write(s,o,i),writeV:async(s,i)=>n.writeV(s,o,i),unwrap:()=>n}),unwrap:()=>e.unwrap()};return n}var Ot=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};var Re=class extends Error{constructor(t){super(`WebRTC transport error: ${t}`),this.name="WebRTCTransportError"}},Vt=class extends Re{constructor(t="SDP handshake failed"){super(t),this.name="SDPHandshakeFailedError"}};var vo=class extends Re{constructor(t,e){super(`Invalid fingerprint "${t}" within ${e}`),this.name="WebRTC/InvalidFingerprintError"}};var Io=class extends Re{constructor(t){super(`A method (${t}) was called though it has been intentionally left unimplemented.`),this.name="WebRTC/UnimplementedError"}},To=class extends Re{constructor(t){super(`unsupported hash algorithm code: ${t} please see the codes at https://github.com/multiformats/multicodec/blob/master/table.csv `),this.name="WebRTC/UnsupportedHashAlgorithmError"}};var Nt;(function(r){let t;(function(o){o.SDP_OFFER="SDP_OFFER",o.SDP_ANSWER="SDP_ANSWER",o.ICE_CANDIDATE="ICE_CANDIDATE"})(t=r.Type||(r.Type={}));let e;(function(o){o[o.SDP_OFFER=0]="SDP_OFFER",o[o.SDP_ANSWER=1]="SDP_ANSWER",o[o.ICE_CANDIDATE=2]="ICE_CANDIDATE"})(e||(e={})),function(o){o.codec=()=>Ge(e)}(t=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=jt((o,s,i={})=>{i.lengthDelimited!==!1&&s.fork(),o.type!=null&&(s.uint32(8),r.Type.codec().encode(o.type,s)),o.data!=null&&(s.uint32(18),s.string(o.data)),i.lengthDelimited!==!1&&s.ldelim()},(o,s,i={})=>{let a={},c=s==null?o.len:o.pos+s;for(;o.pos<c;){let l=o.uint32();switch(l>>>3){case 1:{a.type=r.Type.codec().decode(o);break}case 2:{a.data=o.string();break}default:{o.skipType(l&7);break}}}return a})),n),r.encode=o=>Zt(o,r.codec()),r.decode=(o,s)=>Xt(o,r.codec(),s)})(Nt||(Nt={}));var Lo=async(r,t,e)=>{try{let n=ht();for(Hp(r,n);;){let o=await Promise.race([n.promise,t.read({signal:e.signal}).catch(()=>{})]);if(o==null){e.signal?.throwIfAborted();break}if(o.type!==Nt.Type.ICE_CANDIDATE)throw new xn("ICE candidate message expected");let s=JSON.parse(o.data??"null");if(s===""||s===null){e.onProgress?.(new Ot("webrtc:end-of-ice-candidates")),e.log.trace("end-of-candidates received");continue}let i=new Zl(s);e.log.trace("%s received new ICE candidate %o",e.direction,s);try{e.onProgress?.(new Ot("webrtc:add-ice-candidate",i.candidate)),await r.addIceCandidate(i)}catch(a){e.log.error("%s bad candidate received",e.direction,s,a)}}}catch(n){if(e.log.error("%s error parsing ICE candidate",e.direction,n),e.signal?.aborted===!0&&Co(r)!=="connected")throw n}};function Co(r){return en?r.iceConnectionState:r.connectionState}function Hp(r,t){r[en?"oniceconnectionstatechange":"onconnectionstatechange"]=e=>{switch(Co(r)){case"connected":t.resolve();break;case"failed":case"disconnected":case"closed":t.reject(new gn("RTCPeerConnection was closed"));break;default:break}}}async function Jl({rtcConfiguration:r,dataChannel:t,signal:e,metrics:n,multiaddr:o,connectionManager:s,transportManager:i,log:a,logger:c,onProgress:l}){let{baseAddr:u}=Ql(o);n?.dialerEvents.increment({open:!0}),a.trace("dialing base address: %a",u);let f=u.getPeerId();if(f==null)throw new rt("Relay peer was missing");let d=s.getConnections(dr(f)),g,b=!1;d.length===0?(l?.(new Ot("webrtc:dial-relay")),g=await i.dial(u,{signal:e,onProgress:l}),b=!0):(l?.(new Ot("webrtc:reuse-relay-connection")),g=d[0]);try{l?.(new Ot("webrtc:open-signaling-stream"));let m=await g.newStream(Qr,{signal:e,runOnLimitedConnection:!0}),h=Ao(m).pb(Nt),w=new yo(r),x=new _e({logger:c},{peerConnection:w,dataChannelOptions:t});try{let p=w.createDataChannel("init");w.onicecandidate=({candidate:v})=>{let B=JSON.stringify(v?.toJSON()??null);a.trace("initiator sending ICE candidate %o",v),h.write({type:Nt.Type.ICE_CANDIDATE,data:B},{signal:e}).catch(L=>{a.error("error sending ICE candidate",L)})},w.onicecandidateerror=v=>{a.error("initiator ICE candidate error",v)};let I=await w.createOffer().catch(v=>{throw a.error("could not execute createOffer",v),new Vt("Failed to set createOffer")});a.trace("initiator send SDP offer %s",I.sdp),l?.(new Ot("webrtc:send-sdp-offer")),await h.write({type:Nt.Type.SDP_OFFER,data:I.sdp},{signal:e}),await w.setLocalDescription(I).catch(v=>{throw a.error("could not execute setLocalDescription",v),new Vt("Failed to set localDescription")}),l?.(new Ot("webrtc:read-sdp-answer")),a.trace("initiator read SDP answer");let R=await h.read({signal:e});if(R.type!==Nt.Type.SDP_ANSWER)throw new Vt("Remote should send an SDP answer");a.trace("initiator received SDP answer %s",R.data);let _=new wo({type:"answer",sdp:R.data});return await w.setRemoteDescription(_).catch(v=>{throw a.error("could not execute setRemoteDescription",v),new Vt("Failed to set remoteDescription")}),a.trace("initiator read candidates until connected"),l?.(new Ot("webrtc:read-ice-candidates")),await Lo(w,h,{direction:"initiator",signal:e,log:a,onProgress:l}),a.trace("initiator connected, closing init channel"),p.close(),l?.(new Ot("webrtc:close-signaling-stream")),a.trace("closing signaling channel"),await m.close({signal:e}),a.trace("initiator connected to remote address %s",o),{remoteAddress:o,peerConnection:w,muxerFactory:x}}catch(p){throw a.error("outgoing signaling error",p),w.close(),m.abort(p),p}finally{w.onicecandidate=null,w.onicecandidateerror=null}}finally{if(b)try{await g.close({signal:e})}catch(m){g.abort(m)}}}var tu=ct(vl.matchers[0],W("p2p-circuit")),Bo=class r extends Je{transportManager;shutdownController;events;constructor(t,e){super(),this.transportManager=t.transportManager,this.events=t.events,this.shutdownController=e.shutdownController,this.onTransportListening=this.onTransportListening.bind(this)}async listen(){this.events.addEventListener("transport:listening",this.onTransportListening)}onTransportListening(t){t.detail.getAddrs().filter(n=>tu.exactMatch(n)).map(n=>n.encapsulate("/webrtc")).length>0&&this.safeDispatchEvent("listening")}getAddrs(){return this.transportManager.getListeners().filter(t=>!(t instanceof r)).map(t=>t.getAddrs().filter(e=>tu.exactMatch(e)).map(e=>e.encapsulate("/webrtc"))).flat()}updateAnnounceAddrs(){}async close(){this.events.removeEventListener("transport:listening",this.onTransportListening),this.shutdownController.abort(),queueMicrotask(()=>{this.safeDispatchEvent("close")})}};async function eu({peerConnection:r,stream:t,signal:e,connection:n,log:o}){o.trace("new inbound signaling stream");let s=Ao(t).pb(Nt);try{r.onicecandidate=({candidate:u})=>{let f=JSON.stringify(u?.toJSON()??null);o.trace("recipient sending ICE candidate %s",f),s.write({type:Nt.Type.ICE_CANDIDATE,data:f},{signal:e}).catch(d=>{o.error("error sending ICE candidate",d)})},o.trace("recipient read SDP offer");let a=await s.read({signal:e});if(a.type!==Nt.Type.SDP_OFFER)throw new Vt(`expected message type SDP_OFFER, received: ${a.type??"undefined"} `);o.trace("recipient received SDP offer %s",a.data);let c=new wo({type:"offer",sdp:a.data});await r.setRemoteDescription(c).catch(u=>{throw o.error("could not execute setRemoteDescription",u),new Vt("Failed to set remoteDescription")});let l=await r.createAnswer().catch(u=>{throw o.error("could not execute createAnswer",u),new Vt("Failed to create answer")});o.trace("recipient send SDP answer %s",l.sdp),await s.write({type:Nt.Type.SDP_ANSWER,data:l.sdp},{signal:e}),await r.setLocalDescription(l).catch(u=>{throw o.error("could not execute setLocalDescription",u),new Vt("Failed to set localDescription")}),o.trace("recipient read candidates until connected"),await Lo(r,s,{direction:"recipient",signal:e,log:o})}catch(a){if(Co(r)!=="connected")throw o.error("error while handling signaling stream from peer %a",n.remoteAddr,a),r.close(),a;o("error while handling signaling stream from peer %a, ignoring as the RTCPeerConnection is already connected",n.remoteAddr,a)}let i=ee(`/webrtc/p2p/${n.remoteAddr.getPeerId()}`);return o.trace("recipient connected to remote address %s",i),{remoteAddress:i}}var _o=class{components;init;log;_started=!1;metrics;shutdownController;constructor(t,e={}){this.components=t,this.init=e,this.log=t.logger.forComponent("libp2p:webrtc"),this.shutdownController=new AbortController,this.shutdownController.signal,t.metrics!=null&&(this.metrics={dialerEvents:t.metrics.registerCounterGroup("libp2p_webrtc_dialer_events_total",{label:"event",help:"Total count of WebRTC dialer events by type"}),listenerEvents:t.metrics.registerCounterGroup("libp2p_webrtc_listener_events_total",{label:"event",help:"Total count of WebRTC listener events by type"})})}[pn]=!0;[Symbol.toStringTag]="@libp2p/webrtc";[Qe]=["@libp2p/transport"];[Ba]=["@libp2p/identify","@libp2p/circuit-relay-v2-transport"];isStarted(){return this._started}async start(){await this.components.registrar.handle(Qr,t=>{let e=this.components.upgrader.createInboundAbortSignal(this.shutdownController.signal);this._onProtocol(t,e).catch(n=>{this.log.error("failed to handle incoming connect from %p",t.connection.remotePeer,n)}).finally(()=>{e.clear()})},{runOnLimitedConnection:!0}),this._started=!0}async stop(){await this.components.registrar.unhandle(Qr),this._started=!1}createListener(t){return new Bo(this.components,{shutdownController:this.shutdownController})}listenFilter(t){return t.filter(Il.exactMatch)}dialFilter(t){return this.listenFilter(t)}async dial(t,e){this.log.trace("dialing address: %a",t);let{remoteAddress:n,peerConnection:o,muxerFactory:s}=await Jl({rtcConfiguration:await Oi(this.init.rtcConfiguration),dataChannel:this.init.dataChannel,multiaddr:t,dataChannelOptions:this.init.dataChannel,signal:e.signal,connectionManager:this.components.connectionManager,transportManager:this.components.transportManager,log:this.log,logger:this.components.logger,onProgress:e.onProgress}),i=new $e(this.components,{peerConnection:o,timeline:{open:Date.now()},remoteAddr:n,metrics:this.metrics?.dialerEvents}),a=await e.upgrader.upgradeOutbound(i,{skipProtection:!0,skipEncryption:!0,muxerFactory:s,onProgress:e.onProgress,signal:e.signal});return this._closeOnShutdown(o,i),a}async _onProtocol({connection:t,stream:e},n){let o=new yo(await Oi(this.init.rtcConfiguration)),s=new _e(this.components,{peerConnection:o,dataChannelOptions:this.init.dataChannel});try{let{remoteAddress:i}=await eu({peerConnection:o,connection:t,stream:e,signal:n,log:this.log});await e.close({signal:n});let a=new $e(this.components,{peerConnection:o,timeline:{open:new Date().getTime()},remoteAddr:i,metrics:this.metrics?.listenerEvents});await this.components.upgrader.upgradeInbound(a,{skipEncryption:!0,skipProtection:!0,muxerFactory:s,signal:n}),this._closeOnShutdown(o,a)}catch(i){throw this.log.error("incoming signaling error",i),o.close(),e.abort(i),i}}_closeOnShutdown(t,e){let n=()=>{e.close().catch(o=>{this.log.error("could not close WebRTCMultiaddrConnection",o)})};this.shutdownController.signal.addEventListener("abort",n),t.addEventListener("close",()=>{this.shutdownController.signal.removeEventListener("abort",n)})}};function Ql(r){let t=r.toString().split("/webrtc/");if(t.length!==2)throw new rt("webrtc protocol was not present in multiaddr");if(!t[0].includes("/p2p-circuit"))throw new rt("p2p-circuit protocol was not present in multiaddr");let e=ee(t[0]),o=ee("/"+t[1]).getPeerId();if(o==null)throw new rt("destination peer id was missing");let s=e.protos().pop();if(s===void 0)throw new rt("invalid multiaddr");return s.name!=="p2p"&&(e=e.encapsulate(`/p2p/${o}`)),{baseAddr:e,peerId:dr(o)}}var Ro=class extends Je{async listen(){throw new Io("WebRTCTransport.createListener")}getAddrs(){return[]}updateAnnounceAddrs(){}async close(){}};function Po(r){return r[Symbol.asyncIterator]!=null}var Do=r=>{let t=Q(r),e=dt(t);return Ft(r,e),Do.bytes=t,e};Do.bytes=0;function ru(r,t){t=t??{};let e=t.lengthEncoder??Do;function*n(o){let s=e(o.byteLength);s instanceof Uint8Array?yield s:yield*s,o instanceof Uint8Array?yield o:yield*o}return Po(r)?async function*(){for await(let o of r)yield*n(o)}():function*(){for(let o of r)yield*n(o)}()}ru.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Do;return new z(e(r.byteLength),r)};var No=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Uo=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},ko=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},cn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Vp=8,qp=1024*1024*4,Ze;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Ze||(Ze={}));var Xi=r=>{let t=Ut(r);return Xi.bytes=Q(t),t};Xi.bytes=0;function ln(r,t){let e=new z,n=Ze.LENGTH,o=-1,s=t?.lengthDecoder??Xi,i=t?.maxLengthLength??Vp,a=t?.maxDataLength??qp;function*c(){for(;e.byteLength>0;){if(n===Ze.LENGTH)try{if(o=s(e),o<0)throw new No("Invalid message length");if(o>a)throw new Uo("Message length too long");let l=s.bytes;e.consume(l),t?.onLength!=null&&t.onLength(o),n=Ze.DATA}catch(l){if(l instanceof RangeError){if(e.byteLength>i)throw new ko("Message length length too long");break}throw l}if(n===Ze.DATA){if(e.byteLength<o)break;let l=e.sublist(0,o);e.consume(o),t?.onData!=null&&t.onData(l),yield l,n=Ze.LENGTH}}}return Po(r)?async function*(){for await(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new cn("Unexpected end of input")}():function*(){for(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new cn("Unexpected end of input")}()}ln.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:s,value:i}=await r.next(e);if(s===!0)return;i!=null&&(yield i)}catch(s){if(s.code==="ERR_UNDER_READ")return{done:!0,value:null};throw s}finally{e=1}}();return ln(n,{...t??{},onLength:s=>{e=s}})};function Zi(){let r=ht(),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 nu(){let r=Zi(),t=Zi();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}function Gp(r){return r[Symbol.asyncIterator]!=null}async function zp(r,t){try{await Promise.all(r.map(async e=>{for await(let n of e)t.push(n)})),t.end()}catch(e){t.end(e)}}async function*Wp(r){let t=Be({objectMode:!0});zp(r,t).catch(()=>{}),yield*t}function*$p(r){for(let t of r)yield*t}function Xp(...r){let t=[];for(let e of r)Gp(e)||t.push(e);return t.length===r.length?$p(t):Wp(r)}var ou=Xp;function su(r,...t){if(r==null)throw new Error("Empty pipeline");if(ji(r)){let n=r;r=()=>n.source}else if(au(r)||iu(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&ji(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++)ji(e[n])&&(e[n]=jp(e[n]));return Zp(...e)}var Zp=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},iu=r=>r?.[Symbol.asyncIterator]!=null,au=r=>r?.[Symbol.iterator]!=null,ji=r=>r==null?!1:r.sink!=null&&r.source!=null,jp=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Be({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let o,s=r.source;if(iu(s))o=async function*(){yield*s,n.end()};else if(au(s))o=function*(){yield*s,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return ou(n,o())}return r.source};var Er=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function Oo(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Yi(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Bt(r,...t){if(!Yi(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function Ji(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 cu(r,t){Bt(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function Qi(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}var me=r=>new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4)),lu=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Yp=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!Yp)throw new Error("Non little-endian hardware is not supported");function Jp(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Mo(r){if(typeof r=="string")r=Jp(r);else if(Yi(r))r=Ko(r);else throw new Error("Uint8Array expected, got "+typeof r);return r}function uu(r,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(r,t)}function fu(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 ta=(r,t)=>{function e(n,...o){if(Bt(n),r.nonceLength!==void 0){let u=o[0];if(!u)throw new Error("nonce / iv required");r.varSizeNonce?Bt(u):Bt(u,r.nonceLength)}let s=r.tagLength;s&&o[1]!==void 0&&Bt(o[1]);let i=t(n,...o),a=(u,f)=>{if(f!==void 0){if(u!==2)throw new Error("cipher output not supported");Bt(f)}},c=!1;return{encrypt(u,f){if(c)throw new Error("cannot encrypt() twice with same key + nonce");return c=!0,Bt(u),a(i.encrypt.length,f),i.encrypt(u,f)},decrypt(u,f){if(Bt(u),s&&u.length<s)throw new Error("invalid ciphertext length: smaller than tagLength="+s);return a(i.decrypt.length,f),i.decrypt(u,f)}}}return Object.assign(e,r),e};function ea(r,t,e=!0){if(t===void 0)return new Uint8Array(r);if(t.length!==r)throw new Error("invalid output length, expected "+r+", got: "+t.length);if(e&&!Qp(t))throw new Error("invalid output, must be aligned");return t}function ra(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(e>>o&s),a=Number(e&s),c=n?4:0,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}function Qp(r){return r.byteOffset%4===0}function Ko(r){return Uint8Array.from(r)}function ge(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}var du=r=>Uint8Array.from(r.split("").map(t=>t.charCodeAt(0))),tm=du("expand 16-byte k"),em=du("expand 32-byte k"),rm=me(tm),nm=me(em);function U(r,t){return r<<t|r>>>32-t}function na(r){return r.byteOffset%4===0}var Fo=64,om=16,pu=2**32-1,hu=new Uint32Array;function sm(r,t,e,n,o,s,i,a){let c=o.length,l=new Uint8Array(Fo),u=me(l),f=na(o)&&na(s),d=f?me(o):hu,g=f?me(s):hu;for(let b=0;b<c;i++){if(r(t,e,n,u,i,a),i>=pu)throw new Error("arx: counter overflow");let m=Math.min(Fo,c-b);if(f&&m===Fo){let h=b/4;if(b%4!==0)throw new Error("arx: invalid block position");for(let w=0,x;w<om;w++)x=h+w,g[x]=d[x]^u[w];b+=Fo;continue}for(let h=0,w;h<m;h++)w=b+h,s[w]=o[w]^l[h];b+=m}}function oa(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:o,counterRight:s,rounds:i}=uu({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Oo(o),Oo(i),Qi(s),Qi(e),(a,c,l,u,f=0)=>{Bt(a),Bt(c),Bt(l);let d=l.length;if(u===void 0&&(u=new Uint8Array(d)),Bt(u),Oo(f),f<0||f>=pu)throw new Error("arx: counter overflow");if(u.length<d)throw new Error(`arx: output (${u.length}) is shorter than data (${d})`);let g=[],b=a.length,m,h;if(b===32)g.push(m=Ko(a)),h=nm;else if(b===16&&e)m=new Uint8Array(32),m.set(a),m.set(a,16),h=rm,g.push(m);else throw new Error(`arx: invalid 32-byte key, got length=${b}`);na(c)||g.push(c=Ko(c));let w=me(m);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(h,w,me(c.subarray(0,16)),w),c=c.subarray(16)}let x=16-o;if(x!==c.length)throw new Error(`arx: nonce must be ${x} or 16 bytes`);if(x!==12){let I=new Uint8Array(12);I.set(c,s?0:12-c.length),c=I,g.push(c)}let p=me(c);return sm(r,h,w,p,l,u,f,i),ge(...g),u}}var Et=(r,t)=>r[t++]&255|(r[t++]&255)<<8,sa=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=Mo(t),Bt(t,32);let e=Et(t,0),n=Et(t,2),o=Et(t,4),s=Et(t,6),i=Et(t,8),a=Et(t,10),c=Et(t,12),l=Et(t,14);this.r[0]=e&8191,this.r[1]=(e>>>13|n<<3)&8191,this.r[2]=(n>>>10|o<<6)&7939,this.r[3]=(o>>>7|s<<9)&8191,this.r[4]=(s>>>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]=Et(t,16+2*u)}process(t,e,n=!1){let o=n?0:2048,{h:s,r:i}=this,a=i[0],c=i[1],l=i[2],u=i[3],f=i[4],d=i[5],g=i[6],b=i[7],m=i[8],h=i[9],w=Et(t,e+0),x=Et(t,e+2),p=Et(t,e+4),I=Et(t,e+6),R=Et(t,e+8),_=Et(t,e+10),v=Et(t,e+12),B=Et(t,e+14),L=s[0]+(w&8191),M=s[1]+((w>>>13|x<<3)&8191),N=s[2]+((x>>>10|p<<6)&8191),O=s[3]+((p>>>7|I<<9)&8191),F=s[4]+((I>>>4|R<<12)&8191),T=s[5]+(R>>>1&8191),C=s[6]+((R>>>14|_<<2)&8191),E=s[7]+((_>>>11|v<<5)&8191),y=s[8]+((v>>>8|B<<8)&8191),A=s[9]+(B>>>5|o),S=0,P=S+L*a+M*(5*h)+N*(5*m)+O*(5*b)+F*(5*g);S=P>>>13,P&=8191,P+=T*(5*d)+C*(5*f)+E*(5*u)+y*(5*l)+A*(5*c),S+=P>>>13,P&=8191;let D=S+L*c+M*a+N*(5*h)+O*(5*m)+F*(5*b);S=D>>>13,D&=8191,D+=T*(5*g)+C*(5*d)+E*(5*f)+y*(5*u)+A*(5*l),S+=D>>>13,D&=8191;let k=S+L*l+M*c+N*a+O*(5*h)+F*(5*m);S=k>>>13,k&=8191,k+=T*(5*b)+C*(5*g)+E*(5*d)+y*(5*f)+A*(5*u),S+=k>>>13,k&=8191;let H=S+L*u+M*l+N*c+O*a+F*(5*h);S=H>>>13,H&=8191,H+=T*(5*m)+C*(5*b)+E*(5*g)+y*(5*d)+A*(5*f),S+=H>>>13,H&=8191;let K=S+L*f+M*u+N*l+O*c+F*a;S=K>>>13,K&=8191,K+=T*(5*h)+C*(5*m)+E*(5*b)+y*(5*g)+A*(5*d),S+=K>>>13,K&=8191;let G=S+L*d+M*f+N*u+O*l+F*c;S=G>>>13,G&=8191,G+=T*a+C*(5*h)+E*(5*m)+y*(5*b)+A*(5*g),S+=G>>>13,G&=8191;let X=S+L*g+M*d+N*f+O*u+F*l;S=X>>>13,X&=8191,X+=T*c+C*a+E*(5*h)+y*(5*m)+A*(5*b),S+=X>>>13,X&=8191;let st=S+L*b+M*g+N*d+O*f+F*u;S=st>>>13,st&=8191,st+=T*l+C*c+E*a+y*(5*h)+A*(5*m),S+=st>>>13,st&=8191;let it=S+L*m+M*b+N*g+O*d+F*f;S=it>>>13,it&=8191,it+=T*u+C*l+E*c+y*a+A*(5*h),S+=it>>>13,it&=8191;let lt=S+L*h+M*m+N*b+O*g+F*d;S=lt>>>13,lt&=8191,lt+=T*f+C*u+E*l+y*c+A*a,S+=lt>>>13,lt&=8191,S=(S<<2)+S|0,S=S+P|0,P=S&8191,S=S>>>13,D+=S,s[0]=P,s[1]=D,s[2]=k,s[3]=H,s[4]=K,s[5]=G,s[6]=X,s[7]=st,s[8]=it,s[9]=lt}finalize(){let{h:t,pad:e}=this,n=new Uint16Array(10),o=t[1]>>>13;t[1]&=8191;for(let a=2;a<10;a++)t[a]+=o,o=t[a]>>>13,t[a]&=8191;t[0]+=o*5,o=t[0]>>>13,t[0]&=8191,t[1]+=o,o=t[1]>>>13,t[1]&=8191,t[2]+=o,n[0]=t[0]+5,o=n[0]>>>13,n[0]&=8191;for(let a=1;a<10;a++)n[a]=t[a]+o,o=n[a]>>>13,n[a]&=8191;n[9]-=8192;let s=(o^1)-1;for(let a=0;a<10;a++)n[a]&=s;s=~s;for(let a=0;a<10;a++)t[a]=t[a]&s|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;ge(n)}update(t){Ji(this);let{buffer:e,blockLen:n}=this;t=Mo(t);let o=t.length;for(let s=0;s<o;){let i=Math.min(n-this.pos,o-s);if(i===n){for(;n<=o-s;s+=n)this.process(t,s);continue}e.set(t.subarray(s,s+i),this.pos),this.pos+=i,s+=i,this.pos===n&&(this.process(e,0,!1),this.pos=0)}return this}destroy(){ge(this.h,this.r,this.buffer,this.pad)}digestInto(t){Ji(this),cu(t,this),this.finished=!0;let{buffer:e,h:n}=this,{pos:o}=this;if(o){for(e[o++]=1;o<16;o++)e[o]=0;this.process(e,0,!0)}this.finalize();let s=0;for(let i=0;i<8;i++)t[s++]=n[i]>>>0,t[s++]=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 im(r){let t=(n,o)=>r(o).update(Mo(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var mu=im(r=>new sa(r));function wu(r,t,e,n,o,s=20){let i=r[0],a=r[1],c=r[2],l=r[3],u=t[0],f=t[1],d=t[2],g=t[3],b=t[4],m=t[5],h=t[6],w=t[7],x=o,p=e[0],I=e[1],R=e[2],_=i,v=a,B=c,L=l,M=u,N=f,O=d,F=g,T=b,C=m,E=h,y=w,A=x,S=p,P=I,D=R;for(let H=0;H<s;H+=2)_=_+M|0,A=U(A^_,16),T=T+A|0,M=U(M^T,12),_=_+M|0,A=U(A^_,8),T=T+A|0,M=U(M^T,7),v=v+N|0,S=U(S^v,16),C=C+S|0,N=U(N^C,12),v=v+N|0,S=U(S^v,8),C=C+S|0,N=U(N^C,7),B=B+O|0,P=U(P^B,16),E=E+P|0,O=U(O^E,12),B=B+O|0,P=U(P^B,8),E=E+P|0,O=U(O^E,7),L=L+F|0,D=U(D^L,16),y=y+D|0,F=U(F^y,12),L=L+F|0,D=U(D^L,8),y=y+D|0,F=U(F^y,7),_=_+N|0,D=U(D^_,16),E=E+D|0,N=U(N^E,12),_=_+N|0,D=U(D^_,8),E=E+D|0,N=U(N^E,7),v=v+O|0,A=U(A^v,16),y=y+A|0,O=U(O^y,12),v=v+O|0,A=U(A^v,8),y=y+A|0,O=U(O^y,7),B=B+F|0,S=U(S^B,16),T=T+S|0,F=U(F^T,12),B=B+F|0,S=U(S^B,8),T=T+S|0,F=U(F^T,7),L=L+M|0,P=U(P^L,16),C=C+P|0,M=U(M^C,12),L=L+M|0,P=U(P^L,8),C=C+P|0,M=U(M^C,7);let k=0;n[k++]=i+_|0,n[k++]=a+v|0,n[k++]=c+B|0,n[k++]=l+L|0,n[k++]=u+M|0,n[k++]=f+N|0,n[k++]=d+O|0,n[k++]=g+F|0,n[k++]=b+T|0,n[k++]=m+C|0,n[k++]=h+E|0,n[k++]=w+y|0,n[k++]=x+A|0,n[k++]=p+S|0,n[k++]=I+P|0,n[k++]=R+D|0}function am(r,t,e,n){let o=r[0],s=r[1],i=r[2],a=r[3],c=t[0],l=t[1],u=t[2],f=t[3],d=t[4],g=t[5],b=t[6],m=t[7],h=e[0],w=e[1],x=e[2],p=e[3];for(let R=0;R<20;R+=2)o=o+c|0,h=U(h^o,16),d=d+h|0,c=U(c^d,12),o=o+c|0,h=U(h^o,8),d=d+h|0,c=U(c^d,7),s=s+l|0,w=U(w^s,16),g=g+w|0,l=U(l^g,12),s=s+l|0,w=U(w^s,8),g=g+w|0,l=U(l^g,7),i=i+u|0,x=U(x^i,16),b=b+x|0,u=U(u^b,12),i=i+u|0,x=U(x^i,8),b=b+x|0,u=U(u^b,7),a=a+f|0,p=U(p^a,16),m=m+p|0,f=U(f^m,12),a=a+f|0,p=U(p^a,8),m=m+p|0,f=U(f^m,7),o=o+l|0,p=U(p^o,16),b=b+p|0,l=U(l^b,12),o=o+l|0,p=U(p^o,8),b=b+p|0,l=U(l^b,7),s=s+u|0,h=U(h^s,16),m=m+h|0,u=U(u^m,12),s=s+u|0,h=U(h^s,8),m=m+h|0,u=U(u^m,7),i=i+f|0,w=U(w^i,16),d=d+w|0,f=U(f^d,12),i=i+f|0,w=U(w^i,8),d=d+w|0,f=U(f^d,7),a=a+c|0,x=U(x^a,16),g=g+x|0,c=U(c^g,12),a=a+c|0,x=U(x^a,8),g=g+x|0,c=U(c^g,7);let I=0;n[I++]=o,n[I++]=s,n[I++]=i,n[I++]=a,n[I++]=h,n[I++]=w,n[I++]=x,n[I++]=p}var cm=oa(wu,{counterRight:!1,counterLength:4,allowShortKeys:!1}),lm=oa(wu,{counterRight:!1,counterLength:8,extendNonceFn:am,allowShortKeys:!1});var um=new Uint8Array(16),gu=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(um.subarray(e))},fm=new Uint8Array(32);function yu(r,t,e,n,o){let s=r(t,e,fm),i=mu.create(s);o&&gu(i,o),gu(i,n);let a=new Uint8Array(16),c=lu(a);ra(c,0,BigInt(o?o.length:0),!0),ra(c,8,BigInt(n.length),!0),i.update(a);let l=i.digest();return ge(s,a),l}var bu=r=>(t,e,n)=>({encrypt(s,i){let a=s.length;i=ea(a+16,i,!1),i.set(s);let c=i.subarray(0,-16);r(t,e,c,c,1);let l=yu(r,t,e,c,n);return i.set(l,a),ge(l),i},decrypt(s,i){i=ea(s.length-16,i,!1);let a=s.subarray(0,-16),c=s.subarray(-16),l=yu(r,t,e,a,n);if(!fu(c,l))throw new Error("invalid tag");return i.set(s.subarray(0,-16)),r(t,e,i,i,1),ge(l),i}}),ia=ta({blockSize:64,nonceLength:12,tagLength:16},bu(cm)),ES=ta({blockSize:64,nonceLength:24,tagLength:16},bu(lm));function Eu(r,t,e){return _r(r),e===void 0&&(e=new Uint8Array(r.outputLen)),hr(r,be(e),be(t))}var aa=new Uint8Array([0]),xu=new Uint8Array;function Su(r,t,e,n=32){if(_r(r),An(n),n>255*r.outputLen)throw new Error("Length should be <= 255*HashLen");let o=Math.ceil(n/r.outputLen);e===void 0&&(e=xu);let s=new Uint8Array(o*r.outputLen),i=hr.create(r,t),a=i._cloneInto(),c=new Uint8Array(i.outputLen);for(let l=0;l<o;l++)aa[0]=l+1,a.update(l===0?xu:c).update(e).update(aa).digestInto(c),s.set(c,r.outputLen*l),i._cloneInto(a);return i.destroy(),a.destroy(),c.fill(0),aa.fill(0),s.slice(0,n)}var ca={hashSHA256(r){return te(r.subarray())},getHKDF(r,t){let e=Eu(te,t,r),o=Su(te,e,void 0,96),s=o.subarray(0,32),i=o.subarray(32,64),a=o.subarray(64,96);return[s,i,a]},generateX25519KeyPair(){let r=kr.utils.randomPrivateKey();return{publicKey:kr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:kr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return kr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return ia(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,o){return ia(n,t,e).decrypt(r.subarray(),o)}};var Au=ca;function vu(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 Sr=r=>{let t=dt(2);return t[0]=r>>8,t[1]=r,t};Sr.bytes=2;var un=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)};un.bytes=2;function Iu(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 la(r,t){!t.enabled||!Er||(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 ua(r,t){!t.enabled||!Er||(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 Tu(r,t){!t.enabled||!Er||t(r?`REMOTE_STATIC_PUBLIC_KEY ${q(r.subarray(),"hex")}`:"Missing remote static public key.")}function fa(r,t){!t.enabled||!Er||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${q(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function ha(r,t,e){!e.enabled||!Er||(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 Ar=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var hm=0,dm=4294967295,pm="Cipherstate has reached maximum n, a new handshake must be performed",Ho=class{n;bytes;view;constructor(t=hm){this.n=t,this.bytes=gt(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>dm)throw new Error(pm)}};var je=gt(0),vr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new Ho(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 o=this.crypto.decrypt(e,this.n.getBytes(),t,this.k,n);return this.n.increment(),o}},da=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=J(e,"utf-8");this.h=mm(t,n),this.ck=this.h,this.cs=new vr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new vr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new z(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,je);return[new vr(this.crypto,t),new vr(this.crypto,e)]}},pa=class{ss;s;e;rs;re;initiator;crypto;constructor(t){let{crypto:e,protocolName:n,prologue:o,initiator:s,s:i,e:a,rs:c,re:l}=t;this.crypto=e,this.ss=new da(e,n),this.ss.mixHash(o),this.initiator=s,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 o=t.sublist(e,e+n);return this.rs=this.ss.decryptAndHash(o),n}readEE(){this.writeEE()}readES(){this.writeES()}readSE(){this.writeSE()}},fn=class extends pa{writeMessageA(t){return new z(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new z(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new z(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new Ar(`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 Ar(`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 Ar(`handshake stage 2 validation fail: ${e.message}`)}}};function mm(r,t){if(t.length<=32){let e=gt(32);return e.set(t),e}else return r.hash(t)}var Vo;(function(r){let t;r.codec=()=>(t==null&&(t=jt((e,n,o={})=>{if(o.lengthDelimited!==!1&&n.fork(),e.webtransportCerthashes!=null)for(let s of e.webtransportCerthashes)n.uint32(10),n.bytes(s);o.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let o={webtransportCerthashes:[]},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let i=e.uint32();switch(i>>>3){case 1:{o.webtransportCerthashes.push(e.bytes());break}default:{e.skipType(i&7);break}}}return o})),t),r.encode=e=>Zt(e,r.codec()),r.decode=e=>Xt(e,r.codec())})(Vo||(Vo={}));var hn;(function(r){let t;r.codec=()=>(t==null&&(t=jt((e,n,o={})=>{o.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),Vo.codec().encode(e.extensions,n)),o.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let o={identityKey:gt(0),identitySig:gt(0)},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let i=e.uint32();switch(i>>>3){case 1:{o.identityKey=e.bytes();break}case 2:{o.identitySig=e.bytes();break}case 4:{o.extensions=Vo.codec().decode(e,e.uint32());break}default:{e.skipType(i&7);break}}}return o})),t),r.encode=e=>Zt(e,r.codec()),r.decode=e=>Xt(e,r.codec())})(hn||(hn={}));async function ma(r,t,e){let n=await r.sign(Lu(t));return hn.encode({identityKey:lr(r.publicKey),identitySig:n,extensions:e})}async function ga(r,t,e){try{let n=hn.decode(r),o=Gr(n.identityKey);if(e?.equals(o)===!1)throw new Error(`Payload identity key ${o} does not match expected remote identity key ${e}`);if(!t)throw new Error("Remote static does not exist");let s=Lu(t);if(!await o.verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new mn(n.message)}}function Lu(r){let t=J("noise-libp2p-static-key:");return r instanceof Uint8Array?wt([t,r],t.length+r.length):(r.prepend(t),r)}async function Cu(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:l}=r,u=await ma(s,a.publicKey,l),f=new fn({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:i,s:a});la(f.s,e),e.trace("Stage 0 - Initiator starting to send first message."),await n.write(f.writeMessageA(je),t),e.trace("Stage 0 - Initiator finished sending first message."),ua(f.e,e),e.trace("Stage 1 - Initiator waiting to receive first message from responder...");let d=f.readMessageB(await n.read(t));e.trace("Stage 1 - Initiator received the message."),fa(f.re,e),Tu(f.rs,e),e.trace("Initiator going to check remote's signature...");let g=await ga(d,f.rs,c);e.trace("All good with the signature!"),e.trace("Stage 2 - Initiator sending third handshake message."),await n.write(f.writeMessageC(u),t),e.trace("Stage 2 - Initiator sent message with signed payload.");let[b,m]=f.ss.split();return ha(b,m,e),{payload:g,encrypt:h=>b.encryptWithAd(je,h),decrypt:(h,w)=>m.decryptWithAd(je,h,w)}}async function Bu(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:l}=r,u=await ma(s,a.publicKey,l),f=new fn({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:i,s:a});la(f.s,e),e.trace("Stage 0 - Responder waiting to receive first message."),f.readMessageA(await n.read(t)),e.trace("Stage 0 - Responder received first message."),fa(f.re,e),e.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await n.write(f.writeMessageB(u),t),e.trace("Stage 1 - Responder sent the second handshake message with signed payload."),ua(f.e,e),e.trace("Stage 2 - Responder waiting for third handshake message...");let d=f.readMessageC(await n.read(t));e.trace("Stage 2 - Responder received the message, finished handshake.");let g=await ga(d,f.rs,c),[b,m]=f.ss.split();return ha(b,m,e),{payload:g,encrypt:h=>m.encryptWithAd(je,h),decrypt:(h,w)=>b.decryptWithAd(je,h,w)}}var Ru=16;function Pu(r,t){return async function*(e){for await(let n of e)for(let o=0;o<n.length;o+=65519){let s=o+65519;s>n.length&&(s=n.length);let i;n instanceof Uint8Array?i=r.encrypt(n.subarray(o,s)):i=r.encrypt(n.sublist(o,s)),t?.encryptedPackets.increment(),yield new z(Sr(i.byteLength),i)}}}function Du(r,t){return async function*(e){for await(let n of e)for(let o=0;o<n.length;o+=65535){let s=o+65535;if(s>n.length&&(s=n.length),s-Ru<o)throw new Error("Invalid chunk");let i=n.sublist(o,s),a=n.subarray(o,s-Ru);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var qo=class{protocol="/noise";crypto;prologue;staticKey;extensions;metrics;components;constructor(t,e={}){let{staticNoiseKey:n,extensions:o,crypto:s,prologueBytes:i}=e,{metrics:a}=t;this.components=t;let c=s??Au;this.crypto=vu(c),this.extensions=o,this.metrics=a?Iu(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??gt(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[Qe]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(t,e){let n=an(t,{lengthEncoder:Sr,lengthDecoder:un,maxDataLength:65535}),o=await this.performHandshakeInitiator(n,this.components.privateKey,e?.remotePeer?.publicKey,e),s=await this.createSecureConnection(n,o);t.source=s.source,t.sink=s.sink;let i=Gr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:di(i)}}async secureInbound(t,e){let n=an(t,{lengthEncoder:Sr,lengthDecoder:un,maxDataLength:65535}),o=await this.performHandshakeResponder(n,this.components.privateKey,e?.remotePeer?.publicKey,e),s=await this.createSecureConnection(n,o);t.source=s.source,t.sink=s.sink;let i=Gr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:di(i)}}async performHandshakeInitiator(t,e,n,o){let s;try{s=await Cu({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},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(i){throw this.metrics?.xxHandshakeErrors.increment(),i}return s}async performHandshakeResponder(t,e,n,o){let s;try{s=await Bu({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},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(i){throw this.metrics?.xxHandshakeErrors.increment(),i}return s}async createSecureConnection(t,e){let[n,o]=nu(),s=t.unwrap();return await su(n,Pu(e,this.metrics),s,i=>ln(i,{lengthDecoder:un}),Du(e,this.metrics),n),o}};function Nu(r={}){return t=>new qo(t,r)}var ya=Object.values(Ve).map(r=>r.decoder).reduce((r,t)=>r.or(t)),gm=/^a=fingerprint:(?:\w+-[0-9]+)\s(?<fingerprint>(:?[0-9a-fA-F]{2})+)$/m;function Uu(r){return r?.match(gm)?.groups?.fingerprint}function wa(r){let e=r.stringTuples().filter(n=>n[0]===Cl).map(n=>n[1])[0];if(e===void 0||e==="")throw new rt(`Couldn't find a certhash component of multiaddr: ${r.toString()}`);return e}function ym(r){return Mt.decode(ya.decode(r))}function wm(r){let t=ym(wa(r)),e=bm(t.code),n=t.digest.reduce((s,i)=>s+i.toString(16).padStart(2,"0"),""),o=n.match(/.{1,2}/g);if(o==null)throw new vo(n,r.toString());return`${e} ${o.join(":").toUpperCase()}`}function ku(r){let t=r.split(":").map(o=>parseInt(o,16)),e=Uint8Array.from(t),n=vt(fe.code,e);return ee(`/certhash/${Or.encode(n.bytes)}`)}function bm(r){switch(r){case 17:return"sha-1";case 18:return"sha-256";case 19:return"sha-512";default:throw new To(r)}}function Ou(r,t){let{host:e,port:n,family:o}=r.toOptions(),s=wm(r);return{type:"answer",sdp:`v=0
2
+ "use strict";var Libp2PWebrtc=(()=>{var Zo=Object.defineProperty;var cf=Object.getOwnPropertyDescriptor;var lf=Object.getOwnPropertyNames;var uf=Object.prototype.hasOwnProperty;var vt=(r,t)=>{for(var e in t)Zo(r,e,{get:t[e],enumerable:!0})},ff=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of lf(t))!uf.call(r,o)&&o!==e&&Zo(r,o,{get:()=>t[o],enumerable:!(n=cf(t,o))||n.enumerable});return r};var hf=r=>ff(Zo({},"__esModule",{value:!0}),r);var Pm={};vt(Pm,{webRTC:()=>Nm,webRTCDirect:()=>Rm});var jo=Symbol.for("@libp2p/peer-id");var dn=Symbol.for("@libp2p/transport");var Da;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Da||(Da={}));var pn=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}};var nt=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},je=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var mn=class extends Error{static name="ConnectionFailedError";constructor(t="Connection failed"){super(t),this.name="ConnectionFailedError"}};var gn=class extends Error{static name="StreamResetError";constructor(t="The stream has been reset"){super(t),this.name="StreamResetError"}},Ne=class extends Error{static name="StreamStateError";constructor(t="The stream is in an invalid state"){super(t),this.name="StreamStateError"}};var yn=class extends Error{static name="InvalidCIDError";constructor(t="Invalid CID"){super(t),this.name="InvalidCIDError"}},wn=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var xn=class extends Error{static name="InvalidMessageError";constructor(t="Invalid message"){super(t),this.name="InvalidMessageError"}};var bn=class extends Error{static name="TimeoutError";constructor(t="Timed out"){super(t),this.name="TimeoutError"}};var Pe=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Ye=class extends EventTarget{#t=new Map;constructor(){super()}listenerCount(t){let e=this.#t.get(t);return e==null?0:e.length}addEventListener(t,e,n){super.addEventListener(t,e,n);let o=this.#t.get(t);o==null&&(o=[],this.#t.set(t,o)),o.push({callback:e,once:(n!==!0&&n!==!1&&n?.once)??!1})}removeEventListener(t,e,n){super.removeEventListener(t.toString(),e??null,n);let o=this.#t.get(t);o!=null&&(o=o.filter(({callback:s})=>s!==e),this.#t.set(t,o))}dispatchEvent(t){let e=super.dispatchEvent(t),n=this.#t.get(t.type);return n==null||(n=n.filter(({once:o})=>!o),this.#t.set(t.type,n)),e}safeDispatchEvent(t,e={}){return this.dispatchEvent(new CustomEvent(t,e))}};var Je=Symbol.for("@libp2p/service-capabilities"),Ua=Symbol.for("@libp2p/service-dependencies");var es={};vt(es,{base58btc:()=>ot,base58flickr:()=>wf});var a0=new Uint8Array(0);function ka(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function ne(r){if(r instanceof Uint8Array&&r.constructor.name==="Uint8Array")return r;if(r instanceof ArrayBuffer)return new Uint8Array(r);if(ArrayBuffer.isView(r))return new Uint8Array(r.buffer,r.byteOffset,r.byteLength);throw new Error("Unknown type, must be binary type")}function Oa(r){return new TextEncoder().encode(r)}function Ma(r){return new TextDecoder().decode(r)}function df(r,t){if(r.length>=255)throw new TypeError("Alphabet too long");for(var e=new Uint8Array(256),n=0;n<e.length;n++)e[n]=255;for(var o=0;o<r.length;o++){var s=r.charAt(o),i=s.charCodeAt(0);if(e[i]!==255)throw new TypeError(s+" is ambiguous");e[i]=o}var a=r.length,c=r.charAt(0),l=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function f(x){if(x instanceof Uint8Array||(ArrayBuffer.isView(x)?x=new Uint8Array(x.buffer,x.byteOffset,x.byteLength):Array.isArray(x)&&(x=Uint8Array.from(x))),!(x instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(x.length===0)return"";for(var m=0,h=0,w=0,b=x.length;w!==b&&x[w]===0;)w++,m++;for(var p=(b-w)*u+1>>>0,I=new Uint8Array(p);w!==b;){for(var R=x[w],_=0,v=p-1;(R!==0||_<h)&&v!==-1;v--,_++)R+=256*I[v]>>>0,I[v]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");h=_,w++}for(var B=p-h;B!==p&&I[B]===0;)B++;for(var T=c.repeat(m);B<p;++B)T+=r.charAt(I[B]);return T}function d(x){if(typeof x!="string")throw new TypeError("Expected String");if(x.length===0)return new Uint8Array;var m=0;if(x[m]!==" "){for(var h=0,w=0;x[m]===c;)h++,m++;for(var b=(x.length-m)*l+1>>>0,p=new Uint8Array(b);x[m];){var I=e[x.charCodeAt(m)];if(I===255)return;for(var R=0,_=b-1;(I!==0||R<w)&&_!==-1;_--,R++)I+=a*p[_]>>>0,p[_]=I%256>>>0,I=I/256>>>0;if(I!==0)throw new Error("Non-zero carry");w=R,m++}if(x[m]!==" "){for(var v=b-w;v!==b&&p[v]===0;)v++;for(var B=new Uint8Array(h+(b-v)),T=h;v!==b;)B[T++]=p[v++];return B}}}function g(x){var m=d(x);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:f,decodeUnsafe:d,decode:g}}var pf=df,mf=pf,Fa=mf;var Yo=class{name;prefix;baseEncode;constructor(t,e,n){this.name=t,this.prefix=e,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},Jo=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,e,n){this.name=t,this.prefix=e;let o=e.codePointAt(0);if(o===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=o,this.baseDecode=n}decode(t){if(typeof t=="string"){if(t.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(t)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(t.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(t){return Ha(this,t)}},Qo=class{decoders;constructor(t){this.decoders=t}or(t){return Ha(this,t)}decode(t){let e=t[0],n=this.decoders[e];if(n!=null)return n.decode(t);throw RangeError(`Unable to decode multibase string ${JSON.stringify(t)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}};function Ha(r,t){return new Qo({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var ts=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,e,n,o){this.name=t,this.prefix=e,this.baseEncode=n,this.baseDecode=o,this.encoder=new Yo(t,e,n),this.decoder=new Jo(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Qe({name:r,prefix:t,encode:e,decode:n}){return new ts(r,t,e,n)}function ye({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Fa(e,r);return Qe({prefix:t,name:r,encode:n,decode:s=>ne(o(s))})}function gf(r,t,e,n){let o={};for(let u=0;u<t.length;++u)o[t[u]]=u;let s=r.length;for(;r[s-1]==="=";)--s;let i=new Uint8Array(s*e/8|0),a=0,c=0,l=0;for(let u=0;u<s;++u){let f=o[r[u]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|f,a+=e,a>=8&&(a-=8,i[l++]=255&c>>a)}if(a>=e||(255&c<<8-a)!==0)throw new SyntaxError("Unexpected end of data");return i}function yf(r,t,e){let n=t[t.length-1]==="=",o=(1<<e)-1,s="",i=0,a=0;for(let c=0;c<r.length;++c)for(a=a<<8|r[c],i+=8;i>e;)i-=e,s+=t[o&a>>i];if(i!==0&&(s+=t[o&a<<e-i]),n)for(;(s.length*e&7)!==0;)s+="=";return s}function ht({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Qe({prefix:t,name:r,encode(o){return yf(o,n,e)},decode(o){return gf(o,n,e,r)}})}var ot=ye({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),wf=ye({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var rs={};vt(rs,{base32:()=>oe,base32hex:()=>Sf,base32hexpad:()=>vf,base32hexpadupper:()=>If,base32hexupper:()=>Af,base32pad:()=>bf,base32padupper:()=>Ef,base32upper:()=>xf,base32z:()=>Lf});var oe=ht({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),xf=ht({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),bf=ht({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),Ef=ht({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Sf=ht({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Af=ht({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),vf=ht({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),If=ht({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Lf=ht({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var ns={};vt(ns,{base36:()=>Lr,base36upper:()=>Tf});var Lr=ye({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),Tf=ye({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Ft={};vt(Ft,{Digest:()=>De,create:()=>It,decode:()=>we,equals:()=>ss,hasCode:()=>zf});var Cf=Ga,Va=128,Bf=127,_f=~Bf,Rf=Math.pow(2,31);function Ga(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Rf;)t[e++]=r&255|Va,r/=128;for(;r&_f;)t[e++]=r&255|Va,r>>>=7;return t[e]=r|0,Ga.bytes=e-n+1,t}var Nf=os,Pf=128,qa=127;function os(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw os.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&qa)<<o:(i&qa)*Math.pow(2,o),o+=7}while(i>=Pf);return os.bytes=s-n,e}var Df=Math.pow(2,7),Uf=Math.pow(2,14),kf=Math.pow(2,21),Of=Math.pow(2,28),Mf=Math.pow(2,35),Kf=Math.pow(2,42),Ff=Math.pow(2,49),Hf=Math.pow(2,56),Vf=Math.pow(2,63),qf=function(r){return r<Df?1:r<Uf?2:r<kf?3:r<Of?4:r<Mf?5:r<Kf?6:r<Ff?7:r<Hf?8:r<Vf?9:10},Gf={encode:Cf,decode:Nf,encodingLength:qf},Wf=Gf,Tr=Wf;function Cr(r,t=0){return[Tr.decode(r,t),Tr.decode.bytes]}function tr(r,t,e=0){return Tr.encode(r,t,e),t}function er(r){return Tr.encodingLength(r)}function It(r,t){let e=t.byteLength,n=er(r),o=n+er(e),s=new Uint8Array(o+e);return tr(r,s,0),tr(e,s,n),s.set(t,o),new De(r,e,t,s)}function we(r){let t=ne(r),[e,n]=Cr(t),[o,s]=Cr(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new De(e,o,i,t)}function ss(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&ka(r.bytes,e.bytes)}}var De=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function zf(r,t){return r.code===t}function Wa(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Xf(e,is(r),t??ot.encoder);default:return Zf(e,is(r),t??oe.encoder)}}var za=new WeakMap;function is(r){let t=za.get(r);if(t==null){let e=new Map;return za.set(r,e),e}return t}var pt=class r{code;version;multihash;bytes;"/";constructor(t,e,n,o){this.code=e,this.version=t,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==Br)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==jf)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return r.createV0(e)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:e}=this.multihash,n=It(t,e);return r.createV1(this.code,n)}case 1:return this;default:throw Error(`Can not convert CID version ${this.version} to version 1. This is a bug please report`)}}equals(t){return r.equals(this,t)}static equals(t,e){let n=e;return n!=null&&t.code===n.code&&t.version===n.version&&ss(t.multihash,n.multihash)}toString(t){return Wa(this,t)}toJSON(){return{"/":Wa(this)}}link(){return this}[Symbol.toStringTag]="CID";[Symbol.for("nodejs.util.inspect.custom")](){return`CID(${this.toString()})`}static asCID(t){if(t==null)return null;let e=t;if(e instanceof r)return e;if(e["/"]!=null&&e["/"]===e.bytes||e.asCID===e){let{version:n,code:o,multihash:s,bytes:i}=e;return new r(n,o,s,i??$a(n,o,s.bytes))}else if(e[Yf]===!0){let{version:n,multihash:o,code:s}=e,i=we(o);return r.create(n,s,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==Br)throw new Error(`Version 0 CID must use dag-pb (code: ${Br}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=$a(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,Br,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,o=ne(t.subarray(n,n+e.multihashSize));if(o.byteLength!==e.multihashSize)throw new Error("Incorrect length");let s=o.subarray(e.multihashSize-e.digestSize),i=new De(e.multihashCode,e.digestSize,s,o);return[e.version===0?r.createV0(i):r.createV1(e.codec,i),t.subarray(e.size)]}static inspectBytes(t){let e=0,n=()=>{let[f,d]=Cr(t.subarray(e));return e+=d,f},o=n(),s=Br;if(o===18?(o=0,e=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=e,a=n(),c=n(),l=e+c,u=l-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:l}}static parse(t,e){let[n,o]=$f(t,e),s=r.decode(o);if(s.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return is(s).set(n,t),s}};function $f(r,t){switch(r[0]){case"Q":{let e=t??ot;return[ot.prefix,e.decode(`${ot.prefix}${r}`)]}case ot.prefix:{let e=t??ot;return[ot.prefix,e.decode(r)]}case oe.prefix:{let e=t??oe;return[oe.prefix,e.decode(r)]}case Lr.prefix:{let e=t??Lr;return[Lr.prefix,e.decode(r)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[r[0],t.decode(r)]}}}function Xf(r,t,e){let{prefix:n}=e;if(n!==ot.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let o=t.get(n);if(o==null){let s=e.encode(r).slice(1);return t.set(n,s),s}else return o}function Zf(r,t,e){let{prefix:n}=e,o=t.get(n);if(o==null){let s=e.encode(r);return t.set(n,s),s}else return o}var Br=112,jf=18;function $a(r,t,e){let n=er(r),o=n+er(t),s=new Uint8Array(o+e.byteLength);return tr(r,s,0),tr(t,s,n),s.set(e,o),s}var Yf=Symbol.for("@ipld/js-cid/CID");var as={};vt(as,{identity:()=>se});var Xa=0,Jf="identity",Za=ne;function Qf(r){return It(Xa,Za(r))}var se={code:Xa,name:Jf,encode:Za,digest:Qf};function Nt(r,t){if(r===t)return!0;if(r.byteLength!==t.byteLength)return!1;for(let e=0;e<r.byteLength;e++)if(r[e]!==t[e])return!1;return!0}function Sn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function th(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function rr(r,...t){if(!th(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function _r(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Sn(r.outputLen),Sn(r.blockLen)}function nr(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 ja(r,t){rr(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Ue=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function An(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Gt(r,t){return r<<32-t|r>>>t}function Ya(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function xe(r){return typeof r=="string"&&(r=Ya(r)),rr(r),r}function cs(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];rr(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let s=r[n];e.set(s,o),o+=s.length}return e}var or=class{clone(){return this._cloneInto()}};function vn(r){let t=n=>r().update(xe(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Rr(r=32){if(Ue&&typeof Ue.getRandomValues=="function")return Ue.getRandomValues(new Uint8Array(r));if(Ue&&typeof Ue.randomBytes=="function")return Ue.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function eh(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(e>>o&s),a=Number(e&s),c=n?4:0,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}function Ja(r,t,e){return r&t^~r&e}function Qa(r,t,e){return r&t^r&e^t&e}var sr=class extends or{constructor(t,e,n,o){super(),this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=o,this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.buffer=new Uint8Array(t),this.view=An(this.buffer)}update(t){nr(this);let{view:e,buffer:n,blockLen:o}=this;t=xe(t);let s=t.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=An(t);for(;o<=s-i;i+=o)this.process(c,i);continue}n.set(t.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===o&&(this.process(e,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){nr(this),ja(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,this.buffer.subarray(i).fill(0),this.padOffset>o-i&&(this.process(n,0),i=0);for(let f=i;f<o;f++)e[f]=0;eh(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=An(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let l=c/4,u=this.get();if(l>u.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<l;f++)a.setUint32(4*f,u[f],s)}digest(){let{buffer:t,outputLen:e}=this;this.digestInto(t);let n=t.slice(0,e);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:e,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return t.length=o,t.pos=a,t.finished=s,t.destroyed=i,o%e&&t.buffer.set(n),t}};var In=BigInt(4294967295),ls=BigInt(32);function tc(r,t=!1){return t?{h:Number(r&In),l:Number(r>>ls&In)}:{h:Number(r>>ls&In)|0,l:Number(r&In)|0}}function rh(r,t=!1){let e=new Uint32Array(r.length),n=new Uint32Array(r.length);for(let o=0;o<r.length;o++){let{h:s,l:i}=tc(r[o],t);[e[o],n[o]]=[s,i]}return[e,n]}var nh=(r,t)=>BigInt(r>>>0)<<ls|BigInt(t>>>0),oh=(r,t,e)=>r>>>e,sh=(r,t,e)=>r<<32-e|t>>>e,ih=(r,t,e)=>r>>>e|t<<32-e,ah=(r,t,e)=>r<<32-e|t>>>e,ch=(r,t,e)=>r<<64-e|t>>>e-32,lh=(r,t,e)=>r>>>e-32|t<<64-e,uh=(r,t)=>t,fh=(r,t)=>r,hh=(r,t,e)=>r<<e|t>>>32-e,dh=(r,t,e)=>t<<e|r>>>32-e,ph=(r,t,e)=>t<<e-32|r>>>64-e,mh=(r,t,e)=>r<<e-32|t>>>64-e;function gh(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var yh=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),wh=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,xh=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),bh=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,Eh=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),Sh=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var Ah={fromBig:tc,split:rh,toBig:nh,shrSH:oh,shrSL:sh,rotrSH:ih,rotrSL:ah,rotrBH:ch,rotrBL:lh,rotr32H:uh,rotr32L:fh,rotlSH:hh,rotlSL:dh,rotlBH:ph,rotlBL:mh,add:gh,add3L:yh,add3H:wh,add4L:xh,add4H:bh,add5H:Sh,add5L:Eh},q=Ah;var[vh,Ih]=q.split(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(r=>BigInt(r))),be=new Uint32Array(80),Ee=new Uint32Array(80),us=class extends sr{constructor(){super(128,64,16,!1),this.Ah=1779033703,this.Al=-205731576,this.Bh=-1150833019,this.Bl=-2067093701,this.Ch=1013904242,this.Cl=-23791573,this.Dh=-1521486534,this.Dl=1595750129,this.Eh=1359893119,this.El=-1377402159,this.Fh=-1694144372,this.Fl=725511199,this.Gh=528734635,this.Gl=-79577749,this.Hh=1541459225,this.Hl=327033209}get(){let{Ah:t,Al:e,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:l,El:u,Fh:f,Fl:d,Gh:g,Gl:x,Hh:m,Hl:h}=this;return[t,e,n,o,s,i,a,c,l,u,f,d,g,x,m,h]}set(t,e,n,o,s,i,a,c,l,u,f,d,g,x,m,h){this.Ah=t|0,this.Al=e|0,this.Bh=n|0,this.Bl=o|0,this.Ch=s|0,this.Cl=i|0,this.Dh=a|0,this.Dl=c|0,this.Eh=l|0,this.El=u|0,this.Fh=f|0,this.Fl=d|0,this.Gh=g|0,this.Gl=x|0,this.Hh=m|0,this.Hl=h|0}process(t,e){for(let p=0;p<16;p++,e+=4)be[p]=t.getUint32(e),Ee[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let I=be[p-15]|0,R=Ee[p-15]|0,_=q.rotrSH(I,R,1)^q.rotrSH(I,R,8)^q.shrSH(I,R,7),v=q.rotrSL(I,R,1)^q.rotrSL(I,R,8)^q.shrSL(I,R,7),B=be[p-2]|0,T=Ee[p-2]|0,M=q.rotrSH(B,T,19)^q.rotrBH(B,T,61)^q.shrSH(B,T,6),D=q.rotrSL(B,T,19)^q.rotrBL(B,T,61)^q.shrSL(B,T,6),O=q.add4L(v,D,Ee[p-7],Ee[p-16]),F=q.add4H(O,_,M,be[p-7],be[p-16]);be[p]=F|0,Ee[p]=O|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:l,Dl:u,Eh:f,El:d,Fh:g,Fl:x,Gh:m,Gl:h,Hh:w,Hl:b}=this;for(let p=0;p<80;p++){let I=q.rotrSH(f,d,14)^q.rotrSH(f,d,18)^q.rotrBH(f,d,41),R=q.rotrSL(f,d,14)^q.rotrSL(f,d,18)^q.rotrBL(f,d,41),_=f&g^~f&m,v=d&x^~d&h,B=q.add5L(b,R,v,Ih[p],Ee[p]),T=q.add5H(B,w,I,_,vh[p],be[p]),M=B|0,D=q.rotrSH(n,o,28)^q.rotrBH(n,o,34)^q.rotrBH(n,o,39),O=q.rotrSL(n,o,28)^q.rotrBL(n,o,34)^q.rotrBL(n,o,39),F=n&s^n&a^s&a,L=o&i^o&c^i&c;w=m|0,b=h|0,m=g|0,h=x|0,g=f|0,x=d|0,{h:f,l:d}=q.add(l|0,u|0,T|0,M|0),l=a|0,u=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let C=q.add3L(M,O,L);n=q.add3H(C,T,D,F),o=C|0}({h:n,l:o}=q.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=q.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=q.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:u}=q.add(this.Dh|0,this.Dl|0,l|0,u|0),{h:f,l:d}=q.add(this.Eh|0,this.El|0,f|0,d|0),{h:g,l:x}=q.add(this.Fh|0,this.Fl|0,g|0,x|0),{h:m,l:h}=q.add(this.Gh|0,this.Gl|0,m|0,h|0),{h:w,l:b}=q.add(this.Hh|0,this.Hl|0,w|0,b|0),this.set(n,o,s,i,a,c,l,u,f,d,g,x,m,h,w,b)}roundClean(){be.fill(0),Ee.fill(0)}destroy(){this.buffer.fill(0),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var ec=vn(()=>new us);var Cn={};vt(Cn,{aInRange:()=>Et,abool:()=>Wt,abytes:()=>ir,bitGet:()=>Rh,bitLen:()=>ps,bitMask:()=>Pr,bitSet:()=>Nh,bytesToHex:()=>ae,bytesToNumberBE:()=>ce,bytesToNumberLE:()=>zt,concatBytes:()=>ue,createHmacDrbg:()=>ms,ensureBytes:()=>st,equalBytes:()=>Bh,hexToBytes:()=>Oe,hexToNumber:()=>ds,inRange:()=>Nr,isBytes:()=>Se,memoized:()=>Me,notImplemented:()=>Dh,numberToBytesBE:()=>Ae,numberToBytesLE:()=>le,numberToHexUnpadded:()=>ke,numberToVarBytesBE:()=>Ch,utf8ToBytes:()=>_h,validateObject:()=>Ht});var Ln=BigInt(0),Tn=BigInt(1),Lh=BigInt(2);function Se(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function ir(r){if(!Se(r))throw new Error("Uint8Array expected")}function Wt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var Th=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function ae(r){ir(r);let t="";for(let e=0;e<r.length;e++)t+=Th[r[e]];return t}function ke(r){let t=r.toString(16);return t.length&1?"0"+t:t}function ds(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?Ln:BigInt("0x"+r)}var ie={_0:48,_9:57,A:65,F:70,a:97,f:102};function rc(r){if(r>=ie._0&&r<=ie._9)return r-ie._0;if(r>=ie.A&&r<=ie.F)return r-(ie.A-10);if(r>=ie.a&&r<=ie.f)return r-(ie.a-10)}function Oe(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);let t=r.length,e=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(e);for(let o=0,s=0;o<e;o++,s+=2){let i=rc(r.charCodeAt(s)),a=rc(r.charCodeAt(s+1));if(i===void 0||a===void 0){let c=r[s]+r[s+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+s)}n[o]=i*16+a}return n}function ce(r){return ds(ae(r))}function zt(r){return ir(r),ds(ae(Uint8Array.from(r).reverse()))}function Ae(r,t){return Oe(r.toString(16).padStart(t*2,"0"))}function le(r,t){return Ae(r,t).reverse()}function Ch(r){return Oe(ke(r))}function st(r,t,e){let n;if(typeof t=="string")try{n=Oe(t)}catch(s){throw new Error(r+" must be hex string or Uint8Array, cause: "+s)}else if(Se(t))n=Uint8Array.from(t);else throw new Error(r+" must be hex string or Uint8Array");let o=n.length;if(typeof e=="number"&&o!==e)throw new Error(r+" of length "+e+" expected, got "+o);return n}function ue(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];ir(o),t+=o.length}let e=new Uint8Array(t);for(let n=0,o=0;n<r.length;n++){let s=r[n];e.set(s,o),o+=s.length}return e}function Bh(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}function _h(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var fs=r=>typeof r=="bigint"&&Ln<=r;function Nr(r,t,e){return fs(r)&&fs(t)&&fs(e)&&t<=r&&r<e}function Et(r,t,e,n){if(!Nr(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function ps(r){let t;for(t=0;r>Ln;r>>=Tn,t+=1);return t}function Rh(r,t){return r>>BigInt(t)&Tn}function Nh(r,t,e){return r|(e?Tn:Ln)<<BigInt(t)}var Pr=r=>(Lh<<BigInt(r-1))-Tn,hs=r=>new Uint8Array(r),nc=r=>Uint8Array.from(r);function ms(r,t,e){if(typeof r!="number"||r<2)throw new Error("hashLen must be a number");if(typeof t!="number"||t<2)throw new Error("qByteLen must be a number");if(typeof e!="function")throw new Error("hmacFn must be a function");let n=hs(r),o=hs(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...f)=>e(o,n,...f),c=(f=hs())=>{o=a(nc([0]),f),n=a(),f.length!==0&&(o=a(nc([1]),f),n=a())},l=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let f=0,d=[];for(;f<t;){n=a();let g=n.slice();d.push(g),f+=n.length}return ue(...d)};return(f,d)=>{i(),c(f);let g;for(;!(g=d(l()));)c();return i(),g}}var Ph={bigint:r=>typeof r=="bigint",function:r=>typeof r=="function",boolean:r=>typeof r=="boolean",string:r=>typeof r=="string",stringOrUint8Array:r=>typeof r=="string"||Se(r),isSafeInteger:r=>Number.isSafeInteger(r),array:r=>Array.isArray(r),field:(r,t)=>t.Fp.isValid(r),hash:r=>typeof r=="function"&&Number.isSafeInteger(r.outputLen)};function Ht(r,t,e={}){let n=(o,s,i)=>{let a=Ph[s];if(typeof a!="function")throw new Error("invalid validator function");let c=r[o];if(!(i&&c===void 0)&&!a(c,r))throw new Error("param "+String(o)+" is invalid. Expected "+s+", got "+c)};for(let[o,s]of Object.entries(t))n(o,s,!1);for(let[o,s]of Object.entries(e))n(o,s,!0);return r}var Dh=()=>{throw new Error("not implemented")};function Me(r){let t=new WeakMap;return(e,...n)=>{let o=t.get(e);if(o!==void 0)return o;let s=r(e,...n);return t.set(e,s),s}}var mt=BigInt(0),ft=BigInt(1),Ke=BigInt(2),Uh=BigInt(3),gs=BigInt(4),oc=BigInt(5),sc=BigInt(8),kh=BigInt(9),Oh=BigInt(16);function j(r,t){let e=r%t;return e>=mt?e:t+e}function ys(r,t,e){if(t<mt)throw new Error("invalid exponent, negatives unsupported");if(e<=mt)throw new Error("invalid modulus");if(e===ft)return mt;let n=ft;for(;t>mt;)t&ft&&(n=n*r%e),r=r*r%e,t>>=ft;return n}function ct(r,t,e){let n=r;for(;t-- >mt;)n*=n,n%=e;return n}function Bn(r,t){if(r===mt)throw new Error("invert: expected non-zero number");if(t<=mt)throw new Error("invert: expected positive modulus, got "+t);let e=j(r,t),n=t,o=mt,s=ft,i=ft,a=mt;for(;e!==mt;){let l=n/e,u=n%e,f=o-i*l,d=s-a*l;n=e,e=u,o=i,s=a,i=f,a=d}if(n!==ft)throw new Error("invert: does not exist");return j(o,t)}function Mh(r){let t=(r-ft)/Ke,e,n,o;for(e=r-ft,n=0;e%Ke===mt;e/=Ke,n++);for(o=Ke;o<r&&ys(o,t,r)!==r-ft;o++)if(o>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let i=(r+ft)/gs;return function(c,l){let u=c.pow(l,i);if(!c.eql(c.sqr(u),l))throw new Error("Cannot find square root");return u}}let s=(e+ft)/Ke;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let l=n,u=a.pow(a.mul(a.ONE,o),e),f=a.pow(c,s),d=a.pow(c,e);for(;!a.eql(d,a.ONE);){if(a.eql(d,a.ZERO))return a.ZERO;let g=1;for(let m=a.sqr(d);g<l&&!a.eql(m,a.ONE);g++)m=a.sqr(m);let x=a.pow(u,ft<<BigInt(l-g-1));u=a.sqr(x),f=a.mul(f,x),d=a.mul(d,u),l=g}return f}}function Kh(r){if(r%gs===Uh){let t=(r+ft)/gs;return function(n,o){let s=n.pow(o,t);if(!n.eql(n.sqr(s),o))throw new Error("Cannot find square root");return s}}if(r%sc===oc){let t=(r-oc)/sc;return function(n,o){let s=n.mul(o,Ke),i=n.pow(s,t),a=n.mul(o,i),c=n.mul(n.mul(a,Ke),i),l=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(l),o))throw new Error("Cannot find square root");return l}}return r%Oh,Mh(r)}var ic=(r,t)=>(j(r,t)&ft)===ft,Fh=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function ws(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Fh.reduce((n,o)=>(n[o]="function",n),t);return Ht(r,e)}function Hh(r,t,e){if(e<mt)throw new Error("invalid exponent, negatives unsupported");if(e===mt)return r.ONE;if(e===ft)return t;let n=r.ONE,o=t;for(;e>mt;)e&ft&&(n=r.mul(n,o)),o=r.sqr(o),e>>=ft;return n}function Vh(r,t){let e=new Array(t.length),n=t.reduce((s,i,a)=>r.is0(i)?s:(e[a]=s,r.mul(s,i)),r.ONE),o=r.inv(n);return t.reduceRight((s,i,a)=>r.is0(i)?s:(e[a]=r.mul(s,e[a]),r.mul(s,i)),o),e}function xs(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function ve(r,t,e=!1,n={}){if(r<=mt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:o,nByteLength:s}=xs(r,t);if(s>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let i,a=Object.freeze({ORDER:r,isLE:e,BITS:o,BYTES:s,MASK:Pr(o),ZERO:mt,ONE:ft,create:c=>j(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return mt<=c&&c<r},is0:c=>c===mt,isOdd:c=>(c&ft)===ft,neg:c=>j(-c,r),eql:(c,l)=>c===l,sqr:c=>j(c*c,r),add:(c,l)=>j(c+l,r),sub:(c,l)=>j(c-l,r),mul:(c,l)=>j(c*l,r),pow:(c,l)=>Hh(a,c,l),div:(c,l)=>j(c*Bn(l,r),r),sqrN:c=>c*c,addN:(c,l)=>c+l,subN:(c,l)=>c-l,mulN:(c,l)=>c*l,inv:c=>Bn(c,r),sqrt:n.sqrt||(c=>(i||(i=Kh(r)),i(a,c))),invertBatch:c=>Vh(a,c),cmov:(c,l,u)=>u?l:c,toBytes:c=>e?le(c,s):Ae(c,s),fromBytes:c=>{if(c.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+c.length);return e?zt(c):ce(c)}});return Object.freeze(a)}function ac(r){if(typeof r!="bigint")throw new Error("field order must be bigint");let t=r.toString(2).length;return Math.ceil(t/8)}function bs(r){let t=ac(r);return t+Math.ceil(t/2)}function cc(r,t,e=!1){let n=r.length,o=ac(t),s=bs(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?zt(r):ce(r),a=j(i,t-ft)+ft;return e?le(a,o):Ae(a,o)}var lc=BigInt(0),_n=BigInt(1);function Es(r,t){let e=t.negate();return r?e:t}function uc(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Ss(r,t){uc(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function qh(r,t){if(!Array.isArray(r))throw new Error("array expected");r.forEach((e,n)=>{if(!(e instanceof t))throw new Error("invalid point at index "+n)})}function Gh(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var As=new WeakMap,fc=new WeakMap;function vs(r){return fc.get(r)||1}function Rn(r,t){return{constTimeNegate:Es,hasPrecomputes(e){return vs(e)!==1},unsafeLadder(e,n,o=r.ZERO){let s=e;for(;n>lc;)n&_n&&(o=o.add(s)),s=s.double(),n>>=_n;return o},precomputeWindow(e,n){let{windows:o,windowSize:s}=Ss(n,t),i=[],a=e,c=a;for(let l=0;l<o;l++){c=a,i.push(c);for(let u=1;u<s;u++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(e,n,o){let{windows:s,windowSize:i}=Ss(e,t),a=r.ZERO,c=r.BASE,l=BigInt(2**e-1),u=2**e,f=BigInt(e);for(let d=0;d<s;d++){let g=d*i,x=Number(o&l);o>>=f,x>i&&(x-=u,o+=_n);let m=g,h=g+Math.abs(x)-1,w=d%2!==0,b=x<0;x===0?c=c.add(Es(w,n[m])):a=a.add(Es(b,n[h]))}return{p:a,f:c}},wNAFUnsafe(e,n,o,s=r.ZERO){let{windows:i,windowSize:a}=Ss(e,t),c=BigInt(2**e-1),l=2**e,u=BigInt(e);for(let f=0;f<i;f++){let d=f*a;if(o===lc)break;let g=Number(o&c);if(o>>=u,g>a&&(g-=l,o+=_n),g===0)continue;let x=n[d+Math.abs(g)-1];g<0&&(x=x.negate()),s=s.add(x)}return s},getPrecomputes(e,n,o){let s=As.get(n);return s||(s=this.precomputeWindow(n,e),e!==1&&As.set(n,o(s))),s},wNAFCached(e,n,o){let s=vs(e);return this.wNAF(s,this.getPrecomputes(s,e,o),n)},wNAFCachedUnsafe(e,n,o,s){let i=vs(e);return i===1?this.unsafeLadder(e,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,e,o),n,s)},setWindowSize(e,n){uc(n,t),fc.set(e,n),As.delete(e)}}}function Nn(r,t,e,n){if(qh(e,r),Gh(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let o=r.ZERO,s=ps(BigInt(e.length)),i=s>12?s-3:s>4?s-2:s?2:1,a=(1<<i)-1,c=new Array(a+1).fill(o),l=Math.floor((t.BITS-1)/i)*i,u=o;for(let f=l;f>=0;f-=i){c.fill(o);for(let g=0;g<n.length;g++){let x=n[g],m=Number(x>>BigInt(f)&BigInt(a));c[m]=c[m].add(e[g])}let d=o;for(let g=c.length-1,x=o;g>0;g--)x=x.add(c[g]),d=d.add(x);if(u=u.add(d),f!==0)for(let g=0;g<i;g++)u=u.double()}return u}function Dr(r){return ws(r.Fp),Ht(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...xs(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var $t=BigInt(0),Ut=BigInt(1),Pn=BigInt(2),Wh=BigInt(8),zh={zip215:!0};function $h(r){let t=Dr(r);return Ht(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function hc(r){let t=$h(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,l=Pn<<BigInt(a*8)-Ut,u=e.create,f=ve(t.n,t.nBitLength),d=t.uvRatio||((E,y)=>{try{return{isValid:!0,value:e.sqrt(E*e.inv(y))}}catch{return{isValid:!1,value:$t}}}),g=t.adjustScalarBytes||(E=>E),x=t.domain||((E,y,A)=>{if(Wt("phflag",A),y.length||A)throw new Error("Contexts/pre-hash are not supported");return E});function m(E,y){Et("coordinate "+E,y,$t,l)}function h(E){if(!(E instanceof p))throw new Error("ExtendedPoint expected")}let w=Me((E,y)=>{let{ex:A,ey:S,ez:N}=E,P=E.is0();y==null&&(y=P?Wh:e.inv(N));let k=u(A*y),H=u(S*y),K=u(N*y);if(P)return{x:$t,y:Ut};if(K!==Ut)throw new Error("invZ was invalid");return{x:k,y:H}}),b=Me(E=>{let{a:y,d:A}=t;if(E.is0())throw new Error("bad point: ZERO");let{ex:S,ey:N,ez:P,et:k}=E,H=u(S*S),K=u(N*N),W=u(P*P),X=u(W*W),it=u(H*y),at=u(W*u(it+K)),ut=u(X+u(A*u(H*K)));if(at!==ut)throw new Error("bad point: equation left != right (1)");let At=u(S*N),Dt=u(P*k);if(At!==Dt)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(y,A,S,N){this.ex=y,this.ey=A,this.ez=S,this.et=N,m("x",y),m("y",A),m("z",S),m("t",N),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(y){if(y instanceof p)throw new Error("extended point not allowed");let{x:A,y:S}=y||{};return m("x",A),m("y",S),new p(A,S,Ut,u(A*S))}static normalizeZ(y){let A=e.invertBatch(y.map(S=>S.ez));return y.map((S,N)=>S.toAffine(A[N])).map(p.fromAffine)}static msm(y,A){return Nn(p,f,y,A)}_setWindowSize(y){_.setWindowSize(this,y)}assertValidity(){b(this)}equals(y){h(y);let{ex:A,ey:S,ez:N}=this,{ex:P,ey:k,ez:H}=y,K=u(A*H),W=u(P*N),X=u(S*H),it=u(k*N);return K===W&&X===it}is0(){return this.equals(p.ZERO)}negate(){return new p(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:y}=t,{ex:A,ey:S,ez:N}=this,P=u(A*A),k=u(S*S),H=u(Pn*u(N*N)),K=u(y*P),W=A+S,X=u(u(W*W)-P-k),it=K+k,at=it-H,ut=K-k,At=u(X*at),Dt=u(it*ut),Rt=u(X*ut),Jt=u(at*it);return new p(At,Dt,Jt,Rt)}add(y){h(y);let{a:A,d:S}=t,{ex:N,ey:P,ez:k,et:H}=this,{ex:K,ey:W,ez:X,et:it}=y;if(A===BigInt(-1)){let Ta=u((P-N)*(W+K)),Ca=u((P+N)*(W-K)),Xo=u(Ca-Ta);if(Xo===$t)return this.double();let Ba=u(k*Pn*it),_a=u(H*Pn*X),Ra=_a+Ba,Na=Ca+Ta,Pa=_a-Ba,nf=u(Ra*Xo),of=u(Na*Pa),sf=u(Ra*Pa),af=u(Xo*Na);return new p(nf,of,af,sf)}let at=u(N*K),ut=u(P*W),At=u(H*S*it),Dt=u(k*X),Rt=u((N+P)*(K+W)-at-ut),Jt=Dt-At,re=Dt+At,Ir=u(ut-A*at),Qu=u(Rt*Jt),tf=u(re*Ir),ef=u(Rt*Ir),rf=u(Jt*re);return new p(Qu,tf,rf,ef)}subtract(y){return this.add(y.negate())}wNAF(y){return _.wNAFCached(this,y,p.normalizeZ)}multiply(y){let A=y;Et("scalar",A,Ut,n);let{p:S,f:N}=this.wNAF(A);return p.normalizeZ([S,N])[0]}multiplyUnsafe(y,A=p.ZERO){let S=y;return Et("scalar",S,$t,n),S===$t?R:this.is0()||S===Ut?this:_.wNAFCachedUnsafe(this,S,p.normalizeZ,A)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return _.unsafeLadder(this,n).is0()}toAffine(y){return w(this,y)}clearCofactor(){let{h:y}=t;return y===Ut?this:this.multiplyUnsafe(y)}static fromHex(y,A=!1){let{d:S,a:N}=t,P=e.BYTES;y=st("pointHex",y,P),Wt("zip215",A);let k=y.slice(),H=y[P-1];k[P-1]=H&-129;let K=zt(k),W=A?l:e.ORDER;Et("pointHex.y",K,$t,W);let X=u(K*K),it=u(X-Ut),at=u(S*X-N),{isValid:ut,value:At}=d(it,at);if(!ut)throw new Error("Point.fromHex: invalid y coordinate");let Dt=(At&Ut)===Ut,Rt=(H&128)!==0;if(!A&&At===$t&&Rt)throw new Error("Point.fromHex: x=0 and x_0=1");return Rt!==Dt&&(At=u(-At)),p.fromAffine({x:At,y:K})}static fromPrivateKey(y){return T(y).point}toRawBytes(){let{x:y,y:A}=this.toAffine(),S=le(A,e.BYTES);return S[S.length-1]|=y&Ut?128:0,S}toHex(){return ae(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,Ut,u(t.Gx*t.Gy)),p.ZERO=new p($t,Ut,Ut,$t);let{BASE:I,ZERO:R}=p,_=Rn(p,a*8);function v(E){return j(E,n)}function B(E){return v(zt(E))}function T(E){let y=e.BYTES;E=st("private key",E,y);let A=st("hashed private key",s(E),2*y),S=g(A.slice(0,y)),N=A.slice(y,2*y),P=B(S),k=I.multiply(P),H=k.toRawBytes();return{head:S,prefix:N,scalar:P,point:k,pointBytes:H}}function M(E){return T(E).pointBytes}function D(E=new Uint8Array,...y){let A=ue(...y);return B(s(x(A,st("context",E),!!o)))}function O(E,y,A={}){E=st("message",E),o&&(E=o(E));let{prefix:S,scalar:N,pointBytes:P}=T(y),k=D(A.context,S,E),H=I.multiply(k).toRawBytes(),K=D(A.context,H,P,E),W=v(k+K*N);Et("signature.s",W,$t,n);let X=ue(H,le(W,e.BYTES));return st("result",X,e.BYTES*2)}let F=zh;function L(E,y,A,S=F){let{context:N,zip215:P}=S,k=e.BYTES;E=st("signature",E,2*k),y=st("message",y),A=st("publicKey",A,k),P!==void 0&&Wt("zip215",P),o&&(y=o(y));let H=zt(E.slice(k,2*k)),K,W,X;try{K=p.fromHex(A,P),W=p.fromHex(E.slice(0,k),P),X=I.multiplyUnsafe(H)}catch{return!1}if(!P&&K.isSmallOrder())return!1;let it=D(N,W.toRawBytes(),K.toRawBytes(),y);return W.add(K.multiplyUnsafe(it)).subtract(X).clearCofactor().equals(p.ZERO)}return I._setWindowSize(8),{CURVE:t,getPublicKey:M,sign:O,verify:L,ExtendedPoint:p,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>i(e.BYTES),precompute(E=8,y=p.BASE){return y._setWindowSize(E),y.multiply(BigInt(3)),y}}}}var ar=BigInt(0),Is=BigInt(1);function Xh(r){return Ht(r,{a:"bigint"},{montgomeryBits:"isSafeInteger",nByteLength:"isSafeInteger",adjustScalarBytes:"function",domain:"function",powPminus2:"function",Gu:"bigint"}),Object.freeze({...r})}function dc(r){let t=Xh(r),{P:e}=t,n=b=>j(b,e),o=t.montgomeryBits,s=Math.ceil(o/8),i=t.nByteLength,a=t.adjustScalarBytes||(b=>b),c=t.powPminus2||(b=>ys(b,e-BigInt(2),e));function l(b,p,I){let R=n(b*(p-I));return p=n(p-R),I=n(I+R),[p,I]}let u=(t.a-BigInt(2))/BigInt(4);function f(b,p){Et("u",b,ar,e),Et("scalar",p,ar,e);let I=p,R=b,_=Is,v=ar,B=b,T=Is,M=ar,D;for(let F=BigInt(o-1);F>=ar;F--){let L=I>>F&Is;M^=L,D=l(M,_,B),_=D[0],B=D[1],D=l(M,v,T),v=D[0],T=D[1],M=L;let C=_+v,E=n(C*C),y=_-v,A=n(y*y),S=E-A,N=B+T,P=B-T,k=n(P*C),H=n(N*y),K=k+H,W=k-H;B=n(K*K),T=n(R*n(W*W)),_=n(E*A),v=n(S*(E+n(u*S)))}D=l(M,_,B),_=D[0],B=D[1],D=l(M,v,T),v=D[0],T=D[1];let O=c(v);return n(_*O)}function d(b){return le(n(b),s)}function g(b){let p=st("u coordinate",b,s);return i===32&&(p[31]&=127),zt(p)}function x(b){let p=st("scalar",b),I=p.length;if(I!==s&&I!==i){let R=""+s+" or "+i;throw new Error("invalid scalar, expected "+R+" bytes, got "+I)}return zt(a(p))}function m(b,p){let I=g(p),R=x(b),_=f(I,R);if(_===ar)throw new Error("invalid private or public key received");return d(_)}let h=d(t.Gu);function w(b){return m(b,h)}return{scalarMult:m,scalarMultBase:w,getSharedSecret:(b,p)=>m(b,p),getPublicKey:b=>w(b),utils:{randomPrivateKey:()=>t.randomBytes(t.nByteLength)},GuBytes:h}}var Ur=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),pc=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),ng=BigInt(0),Zh=BigInt(1),mc=BigInt(2),jh=BigInt(3),Yh=BigInt(5),Jh=BigInt(8);function gc(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=Ur,a=r*r%s*r%s,c=ct(a,mc,s)*a%s,l=ct(c,Zh,s)*r%s,u=ct(l,Yh,s)*l%s,f=ct(u,t,s)*u%s,d=ct(f,e,s)*f%s,g=ct(d,n,s)*d%s,x=ct(g,o,s)*g%s,m=ct(x,o,s)*g%s,h=ct(m,t,s)*u%s;return{pow_p_5_8:ct(h,mc,s)*r%s,b2:a}}function yc(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function Qh(r,t){let e=Ur,n=j(t*t*t,e),o=j(n*n*t,e),s=gc(r*o).pow_p_5_8,i=j(r*n*s,e),a=j(t*i*i,e),c=i,l=j(i*pc,e),u=a===r,f=a===j(-r,e),d=a===j(-r*pc,e);return u&&(i=c),(f||d)&&(i=l),ic(i,e)&&(i=j(-i,e)),{isValid:u||f,value:i}}var td=ve(Ur,void 0,!0),ed={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:td,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:Jh,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:ec,randomBytes:Rr,adjustScalarBytes:yc,uvRatio:Qh},wc=hc(ed);var kr=dc({P:Ur,a:BigInt(486662),montgomeryBits:255,nByteLength:32,Gu:BigInt(9),powPminus2:r=>{let t=Ur,{pow_p_5_8:e,b2:n}=gc(r);return j(ct(e,jh,t)*n,t)},adjustScalarBytes:yc,randomBytes:Rr});var Dn=32;function xc(r,t,e){return wc.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var Un=class{type="Ed25519";raw;constructor(t){this.raw=Ls(t,Dn)}toMultihash(){return se.digest(cr(this))}toCID(){return pt.createV1(114,this.toMultihash())}toString(){return ot.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Nt(this.raw,t.raw)}verify(t,e){return xc(this.raw,e,t)}};function Ts(r){return r=Ls(r,Dn),new Un(r)}function Ls(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new nt(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function gt(r=0){return new Uint8Array(r)}function dt(r=0){return new Uint8Array(r)}var nd=Math.pow(2,7),od=Math.pow(2,14),sd=Math.pow(2,21),Cs=Math.pow(2,28),Bs=Math.pow(2,35),_s=Math.pow(2,42),Rs=Math.pow(2,49),Q=128,Lt=127;function Y(r){if(r<nd)return 1;if(r<od)return 2;if(r<sd)return 3;if(r<Cs)return 4;if(r<Bs)return 5;if(r<_s)return 6;if(r<Rs)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function Ns(r,t,e=0){switch(Y(r)){case 8:t[e++]=r&255|Q,r/=128;case 7:t[e++]=r&255|Q,r/=128;case 6:t[e++]=r&255|Q,r/=128;case 5:t[e++]=r&255|Q,r/=128;case 4:t[e++]=r&255|Q,r>>>=7;case 3:t[e++]=r&255|Q,r>>>=7;case 2:t[e++]=r&255|Q,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function id(r,t,e=0){switch(Y(r)){case 8:t.set(e++,r&255|Q),r/=128;case 7:t.set(e++,r&255|Q),r/=128;case 6:t.set(e++,r&255|Q),r/=128;case 5:t.set(e++,r&255|Q),r/=128;case 4:t.set(e++,r&255|Q),r>>>=7;case 3:t.set(e++,r&255|Q),r>>>=7;case 2:t.set(e++,r&255|Q),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function Ps(r,t){let e=r[t],n=0;if(n+=e&Lt,e<Q||(e=r[t+1],n+=(e&Lt)<<7,e<Q)||(e=r[t+2],n+=(e&Lt)<<14,e<Q)||(e=r[t+3],n+=(e&Lt)<<21,e<Q)||(e=r[t+4],n+=(e&Lt)*Cs,e<Q)||(e=r[t+5],n+=(e&Lt)*Bs,e<Q)||(e=r[t+6],n+=(e&Lt)*_s,e<Q)||(e=r[t+7],n+=(e&Lt)*Rs,e<Q))return n;throw new RangeError("Could not decode varint")}function ad(r,t){let e=r.get(t),n=0;if(n+=e&Lt,e<Q||(e=r.get(t+1),n+=(e&Lt)<<7,e<Q)||(e=r.get(t+2),n+=(e&Lt)<<14,e<Q)||(e=r.get(t+3),n+=(e&Lt)<<21,e<Q)||(e=r.get(t+4),n+=(e&Lt)*Cs,e<Q)||(e=r.get(t+5),n+=(e&Lt)*Bs,e<Q)||(e=r.get(t+6),n+=(e&Lt)*_s,e<Q)||(e=r.get(t+7),n+=(e&Lt)*Rs,e<Q))return n;throw new RangeError("Could not decode varint")}function kt(r,t,e=0){return t==null&&(t=dt(Y(r))),t instanceof Uint8Array?Ns(r,t,e):id(r,t,e)}function Pt(r,t=0){return r instanceof Uint8Array?Ps(r,t):ad(r,t)}var Ds=new Float32Array([-0]),Le=new Uint8Array(Ds.buffer);function Ec(r,t,e){Ds[0]=r,t[e]=Le[0],t[e+1]=Le[1],t[e+2]=Le[2],t[e+3]=Le[3]}function Sc(r,t){return Le[0]=r[t],Le[1]=r[t+1],Le[2]=r[t+2],Le[3]=r[t+3],Ds[0]}var Us=new Float64Array([-0]),Tt=new Uint8Array(Us.buffer);function Ac(r,t,e){Us[0]=r,t[e]=Tt[0],t[e+1]=Tt[1],t[e+2]=Tt[2],t[e+3]=Tt[3],t[e+4]=Tt[4],t[e+5]=Tt[5],t[e+6]=Tt[6],t[e+7]=Tt[7]}function vc(r,t){return Tt[0]=r[t],Tt[1]=r[t+1],Tt[2]=r[t+2],Tt[3]=r[t+3],Tt[4]=r[t+4],Tt[5]=r[t+5],Tt[6]=r[t+6],Tt[7]=r[t+7],Us[0]}var cd=BigInt(Number.MAX_SAFE_INTEGER),ld=BigInt(Number.MIN_SAFE_INTEGER),Mt=class r{lo;hi;constructor(t,e){this.lo=t|0,this.hi=e|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(e+n*4294967296)}return this.lo+this.hi*4294967296}toBigInt(t=!1){if(t)return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n);if(this.hi>>>31){let e=~this.lo+1>>>0,n=~this.hi>>>0;return e===0&&(n=n+1>>>0),-(BigInt(e)+(BigInt(n)<<32n))}return BigInt(this.lo>>>0)+(BigInt(this.hi>>>0)<<32n)}toString(t=!1){return this.toBigInt(t).toString()}zzEncode(){let t=this.hi>>31;return this.hi=((this.hi<<1|this.lo>>>31)^t)>>>0,this.lo=(this.lo<<1^t)>>>0,this}zzDecode(){let t=-(this.lo&1);return this.lo=((this.lo>>>1|this.hi<<31)^t)>>>0,this.hi=(this.hi>>>1^t)>>>0,this}length(){let t=this.lo,e=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?e===0?t<16384?t<128?1:2:t<2097152?3:4:e<16384?e<128?5:6:e<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Fe;if(t<cd&&t>ld)return this.fromNumber(Number(t));let e=t<0n;e&&(t=-t);let n=t>>32n,o=t-(n<<32n);return e&&(n=~n|0n,o=~o|0n,++o>Ic&&(o=0n,++n>Ic&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Fe;let e=t<0;e&&(t=-t);let n=t>>>0,o=(t-n)/4294967296>>>0;return e&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new r(n,o)}static from(t){return typeof t=="number"?r.fromNumber(t):typeof t=="bigint"?r.fromBigInt(t):typeof t=="string"?r.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new r(t.low>>>0,t.high>>>0):Fe}},Fe=new Mt(0,0);Fe.toBigInt=function(){return 0n};Fe.zzEncode=Fe.zzDecode=function(){return this};Fe.length=function(){return 1};var Ic=4294967296n;function Lc(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function Tc(r,t,e){if(e-t<1)return"";let o,s=[],i=0,a;for(;t<e;)a=r[t++],a<128?s[i++]=a:a>191&&a<224?s[i++]=(a&31)<<6|r[t++]&63:a>239&&a<365?(a=((a&7)<<18|(r[t++]&63)<<12|(r[t++]&63)<<6|r[t++]&63)-65536,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&15)<<12|(r[t++]&63)<<6|r[t++]&63,i>8191&&((o??(o=[])).push(String.fromCharCode.apply(String,s)),i=0);return o!=null?(i>0&&o.push(String.fromCharCode.apply(String,s.slice(0,i))),o.join("")):String.fromCharCode.apply(String,s.slice(0,i))}function ks(r,t,e){let n=e,o,s;for(let i=0;i<r.length;++i)o=r.charCodeAt(i),o<128?t[e++]=o:o<2048?(t[e++]=o>>6|192,t[e++]=o&63|128):(o&64512)===55296&&((s=r.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,t[e++]=o>>18|240,t[e++]=o>>12&63|128,t[e++]=o>>6&63|128,t[e++]=o&63|128):(t[e++]=o>>12|224,t[e++]=o>>6&63|128,t[e++]=o&63|128);return e-n}function Xt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function kn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Os=class{buf;pos;len;_slice=Uint8Array.prototype.subarray;constructor(t){this.buf=t,this.pos=0,this.len=t.length}uint32(){let t=4294967295;if(t=(this.buf[this.pos]&127)>>>0,this.buf[this.pos++]<128||(t=(t|(this.buf[this.pos]&127)<<7)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<14)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&127)<<21)>>>0,this.buf[this.pos++]<128)||(t=(t|(this.buf[this.pos]&15)<<28)>>>0,this.buf[this.pos++]<128))return t;if((this.pos+=5)>this.len)throw this.pos=this.len,Xt(this,10);return t}int32(){return this.uint32()|0}sint32(){let t=this.uint32();return t>>>1^-(t&1)|0}bool(){return this.uint32()!==0}fixed32(){if(this.pos+4>this.len)throw Xt(this,4);return kn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Xt(this,4);return kn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Xt(this,4);let t=Sc(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Xt(this,4);let t=vc(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),e=this.pos,n=this.pos+t;if(n>this.len)throw Xt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Tc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Xt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Xt(this);while((this.buf[this.pos++]&128)!==0);return this}skipType(t){switch(t){case 0:this.skip();break;case 1:this.skip(8);break;case 2:this.skip(this.uint32());break;case 3:for(;(t=this.uint32()&7)!==4;)this.skipType(t);break;case 5:this.skip(4);break;default:throw Error(`invalid wire type ${t} at offset ${this.pos}`)}return this}readLongVarint(){let t=new Mt(0,0),e=0;if(this.len-this.pos>4){for(;e<4;++e)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t;if(t.lo=(t.lo|(this.buf[this.pos]&127)<<28)>>>0,t.hi=(t.hi|(this.buf[this.pos]&127)>>4)>>>0,this.buf[this.pos++]<128)return t;e=0}else{for(;e<3;++e){if(this.pos>=this.len)throw Xt(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<e*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<e*7)>>>0,t}if(this.len-this.pos>4){for(;e<5;++e)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;e<5;++e){if(this.pos>=this.len)throw Xt(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<e*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Xt(this,8);let t=kn(this.buf,this.pos+=4),e=kn(this.buf,this.pos+=4);return new Mt(t,e)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=Ps(this.buf,this.pos);return this.pos+=Y(t),t}uint64String(){return this.readLongVarint().toString(!0)}sint64(){return this.readLongVarint().zzDecode().toBigInt()}sint64Number(){return this.readLongVarint().zzDecode().toNumber()}sint64String(){return this.readLongVarint().zzDecode().toString()}fixed64(){return this.readFixed64().toBigInt()}fixed64Number(){return this.readFixed64().toNumber()}fixed64String(){return this.readFixed64().toString()}sfixed64(){return this.readFixed64().toBigInt()}sfixed64Number(){return this.readFixed64().toNumber()}sfixed64String(){return this.readFixed64().toString()}};function Ms(r){return new Os(r instanceof Uint8Array?r:r.subarray())}function Zt(r,t,e){let n=Ms(r);return t.decode(n,void 0,e)}var Ks={};vt(Ks,{base10:()=>ud});var ud=ye({prefix:"9",name:"base10",alphabet:"0123456789"});var Fs={};vt(Fs,{base16:()=>fd,base16upper:()=>hd});var fd=ht({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),hd=ht({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Hs={};vt(Hs,{base2:()=>dd});var dd=ht({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Vs={};vt(Vs,{base256emoji:()=>wd});var Bc=Array.from("\u{1F680}\u{1FA90}\u2604\u{1F6F0}\u{1F30C}\u{1F311}\u{1F312}\u{1F313}\u{1F314}\u{1F315}\u{1F316}\u{1F317}\u{1F318}\u{1F30D}\u{1F30F}\u{1F30E}\u{1F409}\u2600\u{1F4BB}\u{1F5A5}\u{1F4BE}\u{1F4BF}\u{1F602}\u2764\u{1F60D}\u{1F923}\u{1F60A}\u{1F64F}\u{1F495}\u{1F62D}\u{1F618}\u{1F44D}\u{1F605}\u{1F44F}\u{1F601}\u{1F525}\u{1F970}\u{1F494}\u{1F496}\u{1F499}\u{1F622}\u{1F914}\u{1F606}\u{1F644}\u{1F4AA}\u{1F609}\u263A\u{1F44C}\u{1F917}\u{1F49C}\u{1F614}\u{1F60E}\u{1F607}\u{1F339}\u{1F926}\u{1F389}\u{1F49E}\u270C\u2728\u{1F937}\u{1F631}\u{1F60C}\u{1F338}\u{1F64C}\u{1F60B}\u{1F497}\u{1F49A}\u{1F60F}\u{1F49B}\u{1F642}\u{1F493}\u{1F929}\u{1F604}\u{1F600}\u{1F5A4}\u{1F603}\u{1F4AF}\u{1F648}\u{1F447}\u{1F3B6}\u{1F612}\u{1F92D}\u2763\u{1F61C}\u{1F48B}\u{1F440}\u{1F62A}\u{1F611}\u{1F4A5}\u{1F64B}\u{1F61E}\u{1F629}\u{1F621}\u{1F92A}\u{1F44A}\u{1F973}\u{1F625}\u{1F924}\u{1F449}\u{1F483}\u{1F633}\u270B\u{1F61A}\u{1F61D}\u{1F634}\u{1F31F}\u{1F62C}\u{1F643}\u{1F340}\u{1F337}\u{1F63B}\u{1F613}\u2B50\u2705\u{1F97A}\u{1F308}\u{1F608}\u{1F918}\u{1F4A6}\u2714\u{1F623}\u{1F3C3}\u{1F490}\u2639\u{1F38A}\u{1F498}\u{1F620}\u261D\u{1F615}\u{1F33A}\u{1F382}\u{1F33B}\u{1F610}\u{1F595}\u{1F49D}\u{1F64A}\u{1F639}\u{1F5E3}\u{1F4AB}\u{1F480}\u{1F451}\u{1F3B5}\u{1F91E}\u{1F61B}\u{1F534}\u{1F624}\u{1F33C}\u{1F62B}\u26BD\u{1F919}\u2615\u{1F3C6}\u{1F92B}\u{1F448}\u{1F62E}\u{1F646}\u{1F37B}\u{1F343}\u{1F436}\u{1F481}\u{1F632}\u{1F33F}\u{1F9E1}\u{1F381}\u26A1\u{1F31E}\u{1F388}\u274C\u270A\u{1F44B}\u{1F630}\u{1F928}\u{1F636}\u{1F91D}\u{1F6B6}\u{1F4B0}\u{1F353}\u{1F4A2}\u{1F91F}\u{1F641}\u{1F6A8}\u{1F4A8}\u{1F92C}\u2708\u{1F380}\u{1F37A}\u{1F913}\u{1F619}\u{1F49F}\u{1F331}\u{1F616}\u{1F476}\u{1F974}\u25B6\u27A1\u2753\u{1F48E}\u{1F4B8}\u2B07\u{1F628}\u{1F31A}\u{1F98B}\u{1F637}\u{1F57A}\u26A0\u{1F645}\u{1F61F}\u{1F635}\u{1F44E}\u{1F932}\u{1F920}\u{1F927}\u{1F4CC}\u{1F535}\u{1F485}\u{1F9D0}\u{1F43E}\u{1F352}\u{1F617}\u{1F911}\u{1F30A}\u{1F92F}\u{1F437}\u260E\u{1F4A7}\u{1F62F}\u{1F486}\u{1F446}\u{1F3A4}\u{1F647}\u{1F351}\u2744\u{1F334}\u{1F4A3}\u{1F438}\u{1F48C}\u{1F4CD}\u{1F940}\u{1F922}\u{1F445}\u{1F4A1}\u{1F4A9}\u{1F450}\u{1F4F8}\u{1F47B}\u{1F910}\u{1F92E}\u{1F3BC}\u{1F975}\u{1F6A9}\u{1F34E}\u{1F34A}\u{1F47C}\u{1F48D}\u{1F4E3}\u{1F942}"),pd=Bc.reduce((r,t,e)=>(r[e]=t,r),[]),md=Bc.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function gd(r){return r.reduce((t,e)=>(t+=pd[e],t),"")}function yd(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=md[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var wd=Qe({prefix:"\u{1F680}",name:"base256emoji",encode:gd,decode:yd});var qs={};vt(qs,{base64:()=>xd,base64pad:()=>bd,base64url:()=>Or,base64urlpad:()=>Ed});var xd=ht({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),bd=ht({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Or=ht({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Ed=ht({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Gs={};vt(Gs,{base8:()=>Sd});var Sd=ht({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ws={};vt(Ws,{identity:()=>Ad});var Ad=Qe({prefix:"\0",name:"identity",encode:r=>Ma(r),decode:r=>Oa(r)});var Kg=new TextEncoder,Fg=new TextDecoder;var Xs={};vt(Xs,{sha256:()=>fe,sha512:()=>Ld});function $s({name:r,code:t,encode:e}){return new zs(r,t,e)}var zs=class{name;code;encode;constructor(t,e,n){this.name=t,this.code=e,this.encode=n}digest(t){if(t instanceof Uint8Array){let e=this.encode(t);return e instanceof Uint8Array?It(this.code,e):e.then(n=>It(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Rc(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var fe=$s({name:"sha2-256",code:18,encode:Rc("SHA-256")}),Ld=$s({name:"sha2-512",code:19,encode:Rc("SHA-512")});var He={...Ws,...Hs,...Gs,...Ks,...Fs,...rs,...ns,...es,...qs,...Vs},Jg={...Xs,...as};function Pc(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Nc=Pc("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Zs=Pc("ascii","a",r=>{let t="a";for(let e=0;e<r.length;e++)t+=String.fromCharCode(r[e]);return t},r=>{r=r.substring(1);let t=dt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Td={utf8:Nc,"utf-8":Nc,hex:He.base16,latin1:Zs,ascii:Zs,binary:Zs,...He},On=Td;function tt(r,t="utf8"){let e=On[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function js(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return dt(i);o+i>t&&(n=dt(t),o=0);let a=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),a}}var Ve=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function Ys(){}var Qs=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},Cd=js();function Bd(r){return globalThis.Buffer!=null?dt(r):Cd(r)}var Kr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ve(Ys,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ve(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new ti((t=t>>>0)<128?1:t<16384?2:t<2097152?3:t<268435456?4:5,t)).len,this}int32(t){return t<0?this._push(Mn,10,Mt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Mt.fromBigInt(t);return this._push(Mn,e.length(),e)}uint64Number(t){return this._push(Ns,Y(t),t)}uint64String(t){return this.uint64(BigInt(t))}int64(t){return this.uint64(t)}int64Number(t){return this.uint64Number(t)}int64String(t){return this.uint64String(t)}sint64(t){let e=Mt.fromBigInt(t).zzEncode();return this._push(Mn,e.length(),e)}sint64Number(t){let e=Mt.fromNumber(t).zzEncode();return this._push(Mn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Js,1,t?1:0)}fixed32(t){return this._push(Mr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Mt.fromBigInt(t);return this._push(Mr,4,e.lo)._push(Mr,4,e.hi)}fixed64Number(t){let e=Mt.fromNumber(t);return this._push(Mr,4,e.lo)._push(Mr,4,e.hi)}fixed64String(t){return this.fixed64(BigInt(t))}sfixed64(t){return this.fixed64(t)}sfixed64Number(t){return this.fixed64Number(t)}sfixed64String(t){return this.fixed64String(t)}float(t){return this._push(Ec,4,t)}double(t){return this._push(Ac,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Js,1,0):this.uint32(e)._push(Rd,e,t)}string(t){let e=Lc(t);return e!==0?this.uint32(e)._push(ks,e,t):this._push(Js,1,0)}fork(){return this.states=new Qs(this),this.head=this.tail=new Ve(Ys,0,0),this.len=0,this}reset(){return this.states!=null?(this.head=this.states.head,this.tail=this.states.tail,this.len=this.states.len,this.states=this.states.next):(this.head=this.tail=new Ve(Ys,0,0),this.len=0),this}ldelim(){let t=this.head,e=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=e,this.len+=n),this}finish(){let t=this.head.next,e=Bd(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Js(r,t,e){t[e]=r&255}function _d(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var ti=class extends Ve{next;constructor(t,e){super(_d,t,e),this.next=void 0}};function Mn(r,t,e){for(;r.hi!==0;)t[e++]=r.lo&127|128,r.lo=(r.lo>>>7|r.hi<<25)>>>0,r.hi>>>=7;for(;r.lo>127;)t[e++]=r.lo&127|128,r.lo=r.lo>>>7;t[e++]=r.lo}function Mr(r,t,e){t[e]=r&255,t[e+1]=r>>>8&255,t[e+2]=r>>>16&255,t[e+3]=r>>>24}function Rd(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Kr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Nd,t,r),this},Kr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Pd,t,r),this});function Nd(r,t,e){t.set(r,e)}function Pd(r,t,e){r.length<40?ks(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(tt(r),e)}function ei(){return new Kr}function jt(r,t){let e=ei();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var lr;(function(r){r[r.VARINT=0]="VARINT",r[r.BIT64=1]="BIT64",r[r.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",r[r.START_GROUP=3]="START_GROUP",r[r.END_GROUP=4]="END_GROUP",r[r.BIT32=5]="BIT32"})(lr||(lr={}));function Kn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function qe(r){function t(o){if(r[o.toString()]==null)throw new Error("Invalid enum value");return r[o]}let e=function(s,i){let a=t(s);i.int32(a)},n=function(s){let i=s.int32();return t(i)};return Kn("enum",lr.VARINT,e,n)}function Yt(r,t){return Kn("message",lr.LENGTH_DELIMITED,r,t)}var yt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(yt||(yt={}));var ri;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(ri||(ri={}));(function(r){r.codec=()=>qe(ri)})(yt||(yt={}));var Qt;(function(r){let t;r.codec=()=>(t==null&&(t=Yt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),yt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.Type=yt.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>jt(e,r.codec()),r.decode=(e,n)=>Zt(e,r.codec(),n)})(Qt||(Qt={}));var ni;(function(r){let t;r.codec=()=>(t==null&&(t=Yt((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),yt.codec().encode(e.Type,n)),e.Data!=null&&(n.uint32(18),n.bytes(e.Data)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.Type=yt.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>jt(e,r.codec()),r.decode=(e,n)=>Zt(e,r.codec(),n)})(ni||(ni={}));var Vr={};vt(Vr,{MAX_RSA_KEY_SIZE:()=>ci,generateRSAKeyPair:()=>Xc,jwkToJWKKeyPair:()=>Zc,jwkToPkcs1:()=>zd,jwkToPkix:()=>ui,jwkToRSAPrivateKey:()=>$c,pkcs1ToJwk:()=>Gc,pkcs1ToRSAPrivateKey:()=>zc,pkixToJwk:()=>Wc,pkixToRSAPublicKey:()=>fi});var Dd=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]),Te=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Ce=new Uint32Array(64),oi=class extends sr{constructor(){super(64,32,8,!1),this.A=Te[0]|0,this.B=Te[1]|0,this.C=Te[2]|0,this.D=Te[3]|0,this.E=Te[4]|0,this.F=Te[5]|0,this.G=Te[6]|0,this.H=Te[7]|0}get(){let{A:t,B:e,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[t,e,n,o,s,i,a,c]}set(t,e,n,o,s,i,a,c){this.A=t|0,this.B=e|0,this.C=n|0,this.D=o|0,this.E=s|0,this.F=i|0,this.G=a|0,this.H=c|0}process(t,e){for(let f=0;f<16;f++,e+=4)Ce[f]=t.getUint32(e,!1);for(let f=16;f<64;f++){let d=Ce[f-15],g=Ce[f-2],x=Gt(d,7)^Gt(d,18)^d>>>3,m=Gt(g,17)^Gt(g,19)^g>>>10;Ce[f]=m+Ce[f-7]+x+Ce[f-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:l,H:u}=this;for(let f=0;f<64;f++){let d=Gt(a,6)^Gt(a,11)^Gt(a,25),g=u+d+Ja(a,c,l)+Dd[f]+Ce[f]|0,m=(Gt(n,2)^Gt(n,13)^Gt(n,22))+Qa(n,o,s)|0;u=l,l=c,c=a,a=i+g|0,i=s,s=o,o=n,n=g+m|0}n=n+this.A|0,o=o+this.B|0,s=s+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,u=u+this.H|0,this.set(n,o,s,i,a,c,l,u)}roundClean(){Ce.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var te=vn(()=>new oi);function G(r,t="utf8"){let e=On[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function wt(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=dt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var kc=Symbol.for("@achingbrain/uint8arraylist");function Uc(r,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let e=0;for(let n of r){let o=e+n.byteLength;if(t<o)return{buf:n,index:t-e};e=o}throw new RangeError("index is out of bounds")}function Fn(r){return!!r?.[kc]}var V=class r{bufs;length;[kc]=!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(Fn(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(Fn(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=Uc(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Uc(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(Fn(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:o}=this._subList(t,e);return wt(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:wt(n,o)}sublist(t,e){let{bufs:n,length:o}=this._subList(t,e),s=new r;return s.length=o,s.bufs=[...n],s}_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=[],o=0;for(let s=0;s<this.bufs.length;s++){let i=this.bufs[s],a=o,c=a+i.byteLength;if(o=c,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(!Fn(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 o=n.byteLength;if(o===0)throw new TypeError("search must be at least 1 byte long");let s=256,i=new Int32Array(s);for(let f=0;f<s;f++)i[f]=-1;for(let f=0;f<o;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 d=l;d>=0;d--){let g=this.get(f+d);if(n[d]!==g){u=Math.max(1,d-a[g]);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=dt(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 o=gt(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,e,n),this.write(o,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 o=gt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,e,n),this.write(o,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 o=gt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,e,n),this.write(o,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=dt(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 o=gt(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,e,n),this.write(o,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 o=gt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,e,n),this.write(o,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 o=gt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,e,n),this.write(o,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 o=gt(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,e,n),this.write(o,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 o=gt(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,e,n),this.write(o,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(!Nt(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((o,s)=>o+s.byteLength,0)),n.length=e,n}};var kd=parseInt("11111",2),ii=parseInt("10000000",2),Od=parseInt("01111111",2),Oc={2:Md,3:Hd,5:Fd,6:Kd,16:si,22:si,48:si};function Fr(r,t={offset:0}){let e=r[t.offset]&kd;if(t.offset++,Oc[e]!=null)return Oc[e](r,t);throw new Error("No decoder for tag "+e)}function Hn(r,t){let e=0;if((r[t.offset]&ii)===ii){let n=r[t.offset]&Od,o="0x";t.offset++;for(let s=0;s<n;s++,t.offset++)o+=r[t.offset].toString(16).padStart(2,"0");e=parseInt(o,16)}else e=r[t.offset],t.offset++;return e}function si(r,t){Hn(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Fr(r,t);if(n===null)break;e.push(n)}return e}function Md(r,t){let e=Hn(r,t),n=t.offset,o=t.offset+e,s=[];for(let i=n;i<o;i++)i===n&&r[i]===0||s.push(r[i]);return t.offset+=e,Uint8Array.from(s)}function Kd(r,t){let e=Hn(r,t);return t.offset+=e,["oid-unimplemented"]}function Fd(r,t){return t.offset++,null}function Hd(r,t){let e=Hn(r,t),n=r[t.offset];t.offset++;let o=r.subarray(t.offset,t.offset+e);if(t.offset+=e,n!==0)throw new Error("Unused bits in bit string is unimplemented");return Fr(o,{offset:0})}function Vd(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new V;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function ai(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=Vd(r.byteLength);return new V(Uint8Array.from([t.byteLength|ii]),t)}function Vt(r){let t=new V,e=parseInt("10000000",2);return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new V(Uint8Array.from([2]),ai(t),t)}function Mc(r){let t=Uint8Array.from([0]),e=new V(t,r);return new V(Uint8Array.from([3]),ai(e),e)}function Vn(r){let t=new V;for(let e of r)t.append(e);return new V(Uint8Array.from([48]),ai(t),t)}var Hr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},qn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Kc={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new qn("Missing Web Crypto API. The most likely cause of this error is that this page is being accessed from an insecure context (i.e. not HTTPS). For more information and possible resolutions see https://github.com/libp2p/js-libp2p/blob/main/packages/crypto/README.md#web-crypto-api");return t}};var Be=Kc;async function Fc(r){let t=await Be.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 qd(t);return{privateKey:e[0],publicKey:e[1]}}async function Hc(r,t){let e=await Be.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Be.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function Vc(r,t,e){let n=await Be.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Be.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function qd(r){if(r.privateKey==null||r.publicKey==null)throw new nt("Private and public key are required");return Promise.all([Be.get().subtle.exportKey("jwk",r.privateKey),Be.get().subtle.exportKey("jwk",r.publicKey)])}function qc(r){if(r.kty!=="RSA")throw new nt("invalid key type");if(r.n==null)throw new nt("invalid key modulus");return tt(r.n,"base64url").length*8}var ur=class{type="RSA";_key;_raw;_multihash;constructor(t,e){this._key=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Vr.jwkToPkix(this._key)),this._raw}toMultihash(){return this._multihash}toCID(){return pt.createV1(114,this._multihash)}toString(){return ot.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Nt(this.raw,t.raw)}verify(t,e){return Vc(this._key,e,t)}},qr=class{type="RSA";_key;_raw;publicKey;constructor(t,e){this._key=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Vr.jwkToPkcs1(this._key)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Nt(this.raw,t.raw)}sign(t){return Hc(this._key,t)}};var ci=8192,li=18,Gd=1062,Wd=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function Gc(r){let t=Fr(r);return{n:G(t[1],"base64url"),e:G(t[2],"base64url"),d:G(t[3],"base64url"),p:G(t[4],"base64url"),q:G(t[5],"base64url"),dp:G(t[6],"base64url"),dq:G(t[7],"base64url"),qi:G(t[8],"base64url"),kty:"RSA"}}function zd(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 nt("JWK was missing components");return Vn([Vt(Uint8Array.from([0])),Vt(tt(r.n,"base64url")),Vt(tt(r.e,"base64url")),Vt(tt(r.d,"base64url")),Vt(tt(r.p,"base64url")),Vt(tt(r.q,"base64url")),Vt(tt(r.dp,"base64url")),Vt(tt(r.dq,"base64url")),Vt(tt(r.qi,"base64url"))]).subarray()}function Wc(r){let t=Fr(r,{offset:0});return{kty:"RSA",n:G(t[1][0],"base64url"),e:G(t[1][1],"base64url")}}function ui(r){if(r.n==null||r.e==null)throw new nt("JWK was missing components");return Vn([Wd,Mc(Vn([Vt(tt(r.n,"base64url")),Vt(tt(r.e,"base64url"))]))]).subarray()}function zc(r){let t=Gc(r);return $c(t)}function fi(r,t){if(r.byteLength>=Gd)throw new je("Key size is too large");let e=Wc(r);if(t==null){let n=te(Qt.encode({Type:yt.RSA,Data:r}));t=It(li,n)}return new ur(e,t)}function $c(r){if(qc(r)>ci)throw new nt("Key size is too large");let t=Zc(r),e=te(Qt.encode({Type:yt.RSA,Data:ui(t.publicKey)})),n=It(li,e);return new qr(t.privateKey,new ur(t.publicKey,n))}async function Xc(r){if(r>ci)throw new nt("Key size is too large");let t=await Fc(r),e=te(Qt.encode({Type:yt.RSA,Data:ui(t.publicKey)})),n=It(li,e);return new qr(t.privateKey,new ur(t.publicKey,n))}function Zc(r){if(r==null)throw new nt("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var Gn=class extends or{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,_r(t);let n=xe(e);if(this.iHash=t.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let o=this.blockLen,s=new Uint8Array(o);s.set(n.length>o?t.create().update(n).digest():n);for(let i=0;i<s.length;i++)s[i]^=54;this.iHash.update(s),this.oHash=t.create();for(let i=0;i<s.length;i++)s[i]^=106;this.oHash.update(s),s.fill(0)}update(t){return nr(this),this.iHash.update(t),this}digestInto(t){nr(this),rr(t,this.outputLen),this.finished=!0,this.iHash.digestInto(t),this.oHash.update(t),this.oHash.digestInto(t),this.destroy()}digest(){let t=new Uint8Array(this.oHash.outputLen);return this.digestInto(t),t}_cloneInto(t){t||(t=Object.create(Object.getPrototypeOf(this),{}));let{oHash:e,iHash:n,finished:o,destroyed:s,blockLen:i,outputLen:a}=this;return t=t,t.finished=o,t.destroyed=s,t.blockLen=i,t.outputLen=a,t.oHash=e._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},fr=(r,t,e)=>new Gn(r,t).update(e).digest();fr.create=(r,t)=>new Gn(r,t);function jc(r){r.lowS!==void 0&&Wt("lowS",r.lowS),r.prehash!==void 0&&Wt("prehash",r.prehash)}function $d(r){let t=Dr(r);Ht(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:o}=t;if(e){if(!n.eql(o,n.ZERO))throw new Error("invalid 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("invalid endomorphism, expected beta: bigint and splitScalar: function")}return Object.freeze({...t})}var{bytesToNumberBE:Xd,hexToBytes:Zd}=Cn,hi=class extends Error{constructor(t=""){super(t)}},he={Err:hi,_tlv:{encode:(r,t)=>{let{Err:e}=he;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length&1)throw new e("tlv.encode: unpadded data");let n=t.length/2,o=ke(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?ke(o.length/2|128):"";return ke(r)+s+o+t},decode(r,t){let{Err:e}=he,n=0;if(r<0||r>256)throw new e("tlv.encode: wrong tag");if(t.length<2||t[n++]!==r)throw new e("tlv.decode: wrong tlv");let o=t[n++],s=!!(o&128),i=0;if(!s)i=o;else{let c=o&127;if(!c)throw new e("tlv.decode(long): indefinite length not supported");if(c>4)throw new e("tlv.decode(long): byte length is too big");let l=t.subarray(n,n+c);if(l.length!==c)throw new e("tlv.decode: length bytes not complete");if(l[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let u of l)i=i<<8|u;if(n+=c,i<128)throw new e("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new e("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(r){let{Err:t}=he;if(r<de)throw new t("integer: negative integers are not allowed");let e=ke(r);if(Number.parseInt(e[0],16)&8&&(e="00"+e),e.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return e},decode(r){let{Err:t}=he;if(r[0]&128)throw new t("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return Xd(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=he,o=typeof r=="string"?Zd(r):r;ir(o);let{v:s,l:i}=n.decode(48,o);if(i.length)throw new t("invalid signature: left bytes after parsing");let{v:a,l:c}=n.decode(2,s),{v:l,l:u}=n.decode(2,c);if(u.length)throw new t("invalid signature: left bytes after parsing");return{r:e.decode(a),s:e.decode(l)}},hexFromSig(r){let{_tlv:t,_int:e}=he,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}},de=BigInt(0),xt=BigInt(1),xw=BigInt(2),Yc=BigInt(3),bw=BigInt(4);function jd(r){let t=$d(r),{Fp:e}=t,n=ve(t.n,t.nBitLength),o=t.toBytes||((m,h,w)=>{let b=h.toAffine();return ue(Uint8Array.from([4]),e.toBytes(b.x),e.toBytes(b.y))}),s=t.fromBytes||(m=>{let h=m.subarray(1),w=e.fromBytes(h.subarray(0,e.BYTES)),b=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x:w,y:b}});function i(m){let{a:h,b:w}=t,b=e.sqr(m),p=e.mul(b,m);return e.add(e.add(p,e.mul(m,h)),w)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return Nr(m,xt,t.n)}function c(m){let{allowedPrivateKeyLengths:h,nByteLength:w,wrapPrivateKey:b,n:p}=t;if(h&&typeof m!="bigint"){if(Se(m)&&(m=ae(m)),typeof m!="string"||!h.includes(m.length))throw new Error("invalid private key");m=m.padStart(w*2,"0")}let I;try{I=typeof m=="bigint"?m:ce(st("private key",m,w))}catch{throw new Error("invalid private key, expected hex or "+w+" bytes, got "+typeof m)}return b&&(I=j(I,p)),Et("private key",I,xt,p),I}function l(m){if(!(m instanceof d))throw new Error("ProjectivePoint expected")}let u=Me((m,h)=>{let{px:w,py:b,pz:p}=m;if(e.eql(p,e.ONE))return{x:w,y:b};let I=m.is0();h==null&&(h=I?e.ONE:e.inv(p));let R=e.mul(w,h),_=e.mul(b,h),v=e.mul(p,h);if(I)return{x:e.ZERO,y:e.ZERO};if(!e.eql(v,e.ONE))throw new Error("invZ was invalid");return{x:R,y:_}}),f=Me(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:h,y:w}=m.toAffine();if(!e.isValid(h)||!e.isValid(w))throw new Error("bad point: x or y not FE");let b=e.sqr(w),p=i(h);if(!e.eql(b,p))throw new Error("bad point: equation left != right");if(!m.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class d{constructor(h,w,b){if(this.px=h,this.py=w,this.pz=b,h==null||!e.isValid(h))throw new Error("x required");if(w==null||!e.isValid(w))throw new Error("y required");if(b==null||!e.isValid(b))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x:w,y:b}=h||{};if(!h||!e.isValid(w)||!e.isValid(b))throw new Error("invalid affine point");if(h instanceof d)throw new Error("projective point not allowed");let p=I=>e.eql(I,e.ZERO);return p(w)&&p(b)?d.ZERO:new d(w,b,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let w=e.invertBatch(h.map(b=>b.pz));return h.map((b,p)=>b.toAffine(w[p])).map(d.fromAffine)}static fromHex(h){let w=d.fromAffine(s(st("pointHex",h)));return w.assertValidity(),w}static fromPrivateKey(h){return d.BASE.multiply(c(h))}static msm(h,w){return Nn(d,n,h,w)}_setWindowSize(h){x.setWindowSize(this,h)}assertValidity(){f(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){l(h);let{px:w,py:b,pz:p}=this,{px:I,py:R,pz:_}=h,v=e.eql(e.mul(w,_),e.mul(I,p)),B=e.eql(e.mul(b,_),e.mul(R,p));return v&&B}negate(){return new d(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:w}=t,b=e.mul(w,Yc),{px:p,py:I,pz:R}=this,_=e.ZERO,v=e.ZERO,B=e.ZERO,T=e.mul(p,p),M=e.mul(I,I),D=e.mul(R,R),O=e.mul(p,I);return O=e.add(O,O),B=e.mul(p,R),B=e.add(B,B),_=e.mul(h,B),v=e.mul(b,D),v=e.add(_,v),_=e.sub(M,v),v=e.add(M,v),v=e.mul(_,v),_=e.mul(O,_),B=e.mul(b,B),D=e.mul(h,D),O=e.sub(T,D),O=e.mul(h,O),O=e.add(O,B),B=e.add(T,T),T=e.add(B,T),T=e.add(T,D),T=e.mul(T,O),v=e.add(v,T),D=e.mul(I,R),D=e.add(D,D),T=e.mul(D,O),_=e.sub(_,T),B=e.mul(D,M),B=e.add(B,B),B=e.add(B,B),new d(_,v,B)}add(h){l(h);let{px:w,py:b,pz:p}=this,{px:I,py:R,pz:_}=h,v=e.ZERO,B=e.ZERO,T=e.ZERO,M=t.a,D=e.mul(t.b,Yc),O=e.mul(w,I),F=e.mul(b,R),L=e.mul(p,_),C=e.add(w,b),E=e.add(I,R);C=e.mul(C,E),E=e.add(O,F),C=e.sub(C,E),E=e.add(w,p);let y=e.add(I,_);return E=e.mul(E,y),y=e.add(O,L),E=e.sub(E,y),y=e.add(b,p),v=e.add(R,_),y=e.mul(y,v),v=e.add(F,L),y=e.sub(y,v),T=e.mul(M,E),v=e.mul(D,L),T=e.add(v,T),v=e.sub(F,T),T=e.add(F,T),B=e.mul(v,T),F=e.add(O,O),F=e.add(F,O),L=e.mul(M,L),E=e.mul(D,E),F=e.add(F,L),L=e.sub(O,L),L=e.mul(M,L),E=e.add(E,L),O=e.mul(F,E),B=e.add(B,O),O=e.mul(y,E),v=e.mul(C,v),v=e.sub(v,O),O=e.mul(C,F),T=e.mul(y,T),T=e.add(T,O),new d(v,B,T)}subtract(h){return this.add(h.negate())}is0(){return this.equals(d.ZERO)}wNAF(h){return x.wNAFCached(this,h,d.normalizeZ)}multiplyUnsafe(h){let{endo:w,n:b}=t;Et("scalar",h,de,b);let p=d.ZERO;if(h===de)return p;if(this.is0()||h===xt)return this;if(!w||x.hasPrecomputes(this))return x.wNAFCachedUnsafe(this,h,d.normalizeZ);let{k1neg:I,k1:R,k2neg:_,k2:v}=w.splitScalar(h),B=p,T=p,M=this;for(;R>de||v>de;)R&xt&&(B=B.add(M)),v&xt&&(T=T.add(M)),M=M.double(),R>>=xt,v>>=xt;return I&&(B=B.negate()),_&&(T=T.negate()),T=new d(e.mul(T.px,w.beta),T.py,T.pz),B.add(T)}multiply(h){let{endo:w,n:b}=t;Et("scalar",h,xt,b);let p,I;if(w){let{k1neg:R,k1:_,k2neg:v,k2:B}=w.splitScalar(h),{p:T,f:M}=this.wNAF(_),{p:D,f:O}=this.wNAF(B);T=x.constTimeNegate(R,T),D=x.constTimeNegate(v,D),D=new d(e.mul(D.px,w.beta),D.py,D.pz),p=T.add(D),I=M.add(O)}else{let{p:R,f:_}=this.wNAF(h);p=R,I=_}return d.normalizeZ([p,I])[0]}multiplyAndAddUnsafe(h,w,b){let p=d.BASE,I=(_,v)=>v===de||v===xt||!_.equals(p)?_.multiplyUnsafe(v):_.multiply(v),R=I(this,w).add(I(h,b));return R.is0()?void 0:R}toAffine(h){return u(this,h)}isTorsionFree(){let{h,isTorsionFree:w}=t;if(h===xt)return!0;if(w)return w(d,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:w}=t;return h===xt?this:w?w(d,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return Wt("isCompressed",h),this.assertValidity(),o(d,this,h)}toHex(h=!0){return Wt("isCompressed",h),ae(this.toRawBytes(h))}}d.BASE=new d(t.Gx,t.Gy,e.ONE),d.ZERO=new d(e.ZERO,e.ONE,e.ZERO);let g=t.nBitLength,x=Rn(d,t.endo?Math.ceil(g/2):g);return{CURVE:t,ProjectivePoint:d,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function Yd(r){let t=Dr(r);return Ht(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function Jc(r){let t=Yd(r),{Fp:e,n}=t,o=e.BYTES+1,s=2*e.BYTES+1;function i(L){return j(L,n)}function a(L){return Bn(L,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:l,weierstrassEquation:u,isWithinCurveOrder:f}=jd({...t,toBytes(L,C,E){let y=C.toAffine(),A=e.toBytes(y.x),S=ue;return Wt("isCompressed",E),E?S(Uint8Array.from([C.hasEvenY()?2:3]),A):S(Uint8Array.from([4]),A,e.toBytes(y.y))},fromBytes(L){let C=L.length,E=L[0],y=L.subarray(1);if(C===o&&(E===2||E===3)){let A=ce(y);if(!Nr(A,xt,e.ORDER))throw new Error("Point is not on curve");let S=u(A),N;try{N=e.sqrt(S)}catch(H){let K=H instanceof Error?": "+H.message:"";throw new Error("Point is not on curve"+K)}let P=(N&xt)===xt;return(E&1)===1!==P&&(N=e.neg(N)),{x:A,y:N}}else if(C===s&&E===4){let A=e.fromBytes(y.subarray(0,e.BYTES)),S=e.fromBytes(y.subarray(e.BYTES,2*e.BYTES));return{x:A,y:S}}else{let A=o,S=s;throw new Error("invalid Point, expected length of "+A+", or uncompressed "+S+", got "+C)}}}),d=L=>ae(Ae(L,t.nByteLength));function g(L){let C=n>>xt;return L>C}function x(L){return g(L)?i(-L):L}let m=(L,C,E)=>ce(L.slice(C,E));class h{constructor(C,E,y){this.r=C,this.s=E,this.recovery=y,this.assertValidity()}static fromCompact(C){let E=t.nByteLength;return C=st("compactSignature",C,E*2),new h(m(C,0,E),m(C,E,2*E))}static fromDER(C){let{r:E,s:y}=he.toSig(st("DER",C));return new h(E,y)}assertValidity(){Et("r",this.r,xt,n),Et("s",this.s,xt,n)}addRecoveryBit(C){return new h(this.r,this.s,C)}recoverPublicKey(C){let{r:E,s:y,recovery:A}=this,S=_(st("msgHash",C));if(A==null||![0,1,2,3].includes(A))throw new Error("recovery id invalid");let N=A===2||A===3?E+t.n:E;if(N>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let P=(A&1)===0?"02":"03",k=c.fromHex(P+d(N)),H=a(N),K=i(-S*H),W=i(y*H),X=c.BASE.multiplyAndAddUnsafe(k,K,W);if(!X)throw new Error("point at infinify");return X.assertValidity(),X}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new h(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return Oe(this.toDERHex())}toDERHex(){return he.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return Oe(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}let w={isValidPrivateKey(L){try{return l(L),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let L=bs(t.n);return cc(t.randomBytes(L),t.n)},precompute(L=8,C=c.BASE){return C._setWindowSize(L),C.multiply(BigInt(3)),C}};function b(L,C=!0){return c.fromPrivateKey(L).toRawBytes(C)}function p(L){let C=Se(L),E=typeof L=="string",y=(C||E)&&L.length;return C?y===o||y===s:E?y===2*o||y===2*s:L instanceof c}function I(L,C,E=!0){if(p(L))throw new Error("first arg must be private key");if(!p(C))throw new Error("second arg must be public key");return c.fromHex(C).multiply(l(L)).toRawBytes(E)}let R=t.bits2int||function(L){if(L.length>8192)throw new Error("input is too large");let C=ce(L),E=L.length*8-t.nBitLength;return E>0?C>>BigInt(E):C},_=t.bits2int_modN||function(L){return i(R(L))},v=Pr(t.nBitLength);function B(L){return Et("num < 2^"+t.nBitLength,L,de,v),Ae(L,t.nByteLength)}function T(L,C,E=M){if(["recovered","canonical"].some(at=>at in E))throw new Error("sign() legacy options not supported");let{hash:y,randomBytes:A}=t,{lowS:S,prehash:N,extraEntropy:P}=E;S==null&&(S=!0),L=st("msgHash",L),jc(E),N&&(L=st("prehashed msgHash",y(L)));let k=_(L),H=l(C),K=[B(H),B(k)];if(P!=null&&P!==!1){let at=P===!0?A(e.BYTES):P;K.push(st("extraEntropy",at))}let W=ue(...K),X=k;function it(at){let ut=R(at);if(!f(ut))return;let At=a(ut),Dt=c.BASE.multiply(ut).toAffine(),Rt=i(Dt.x);if(Rt===de)return;let Jt=i(At*i(X+Rt*H));if(Jt===de)return;let re=(Dt.x===Rt?0:2)|Number(Dt.y&xt),Ir=Jt;return S&&g(Jt)&&(Ir=x(Jt),re^=1),new h(Rt,Ir,re)}return{seed:W,k2sig:it}}let M={lowS:t.lowS,prehash:!1},D={lowS:t.lowS,prehash:!1};function O(L,C,E=M){let{seed:y,k2sig:A}=T(L,C,E),S=t;return ms(S.hash.outputLen,S.nByteLength,S.hmac)(y,A)}c.BASE._setWindowSize(8);function F(L,C,E,y=D){let A=L;C=st("msgHash",C),E=st("publicKey",E);let{lowS:S,prehash:N,format:P}=y;if(jc(y),"strict"in y)throw new Error("options.strict was renamed to lowS");if(P!==void 0&&P!=="compact"&&P!=="der")throw new Error("format must be compact or der");let k=typeof A=="string"||Se(A),H=!k&&!P&&typeof A=="object"&&A!==null&&typeof A.r=="bigint"&&typeof A.s=="bigint";if(!k&&!H)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let K,W;try{if(H&&(K=new h(A.r,A.s)),k){try{P!=="compact"&&(K=h.fromDER(A))}catch(re){if(!(re instanceof he.Err))throw re}!K&&P!=="der"&&(K=h.fromCompact(A))}W=c.fromHex(E)}catch{return!1}if(!K||S&&K.hasHighS())return!1;N&&(C=t.hash(C));let{r:X,s:it}=K,at=_(C),ut=a(it),At=i(at*ut),Dt=i(X*ut),Rt=c.BASE.multiplyAndAddUnsafe(W,At,Dt)?.toAffine();return Rt?i(Rt.x)===X:!1}return{CURVE:t,getPublicKey:b,getSharedSecret:I,sign:O,verify:F,ProjectivePoint:c,Signature:h,utils:w}}function Jd(r){return{hash:r,hmac:(t,...e)=>fr(r,t,cs(...e)),randomBytes:Rr}}function Qc(r,t){let e=n=>Jc({...r,...Jd(n)});return{...e(t),create:e}}var rl=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),tl=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Qd=BigInt(1),di=BigInt(2),el=(r,t)=>(r+t/di)/t;function tp(r){let t=rl,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%t,u=l*l*r%t,f=ct(u,e,t)*u%t,d=ct(f,e,t)*u%t,g=ct(d,di,t)*l%t,x=ct(g,o,t)*g%t,m=ct(x,s,t)*x%t,h=ct(m,a,t)*m%t,w=ct(h,c,t)*h%t,b=ct(w,a,t)*m%t,p=ct(b,e,t)*u%t,I=ct(p,i,t)*x%t,R=ct(I,n,t)*l%t,_=ct(R,di,t);if(!pi.eql(pi.sqr(_),r))throw new Error("Cannot find square root");return _}var pi=ve(rl,void 0,void 0,{sqrt:tp}),Ge=Qc({a:BigInt(0),b:BigInt(7),Fp:pi,n:tl,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=tl,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Qd*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=el(s*r,t),c=el(-n*r,t),l=j(r-a*e-c*o,t),u=j(-a*n-c*s,t),f=l>i,d=u>i;if(f&&(l=t-l),d&&(u=t-u),l>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:f,k1:l,k2neg:d,k2:u}}}},te),Bw=BigInt(0);var _w=Ge.ProjectivePoint;function nl(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function ol(r,t,e){let n=fe.digest(e instanceof Uint8Array?e:e.subarray());if(nl(n))return n.then(({digest:o})=>Ge.verify(t,o,r)).catch(o=>{throw new Hr(String(o))});try{return Ge.verify(t,n.digest,r)}catch(o){throw new Hr(String(o))}}var Wn=class{type="secp256k1";raw;_key;constructor(t){this._key=il(t),this.raw=sl(this._key)}toMultihash(){return se.digest(cr(this))}toCID(){return pt.createV1(114,this.toMultihash())}toString(){return ot.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:Nt(this.raw,t.raw)}verify(t,e){return ol(this._key,e,t)}};function mi(r){return new Wn(r)}function sl(r){return Ge.ProjectivePoint.fromHex(r).toRawBytes(!0)}function il(r){try{return Ge.ProjectivePoint.fromHex(r),r}catch(t){throw new je(String(t))}}function Gr(r,t){let{Type:e,Data:n}=Qt.decode(r),o=n??new Uint8Array;switch(e){case yt.RSA:return fi(o,t);case yt.Ed25519:return Ts(o);case yt.secp256k1:return mi(o);default:throw new Pe}}function al(r){let{Type:t,Data:e}=Qt.decode(r.digest),n=e??new Uint8Array;switch(t){case yt.Ed25519:return Ts(n);case yt.secp256k1:return mi(n);default:throw new Pe}}function cr(r){return Qt.encode({Type:yt[r.type],Data:r.raw})}var cl=Symbol.for("nodejs.util.inspect.custom"),ep=114,Wr=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[jo]=!0;toString(){return this.string==null&&(this.string=ot.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return pt.createV1(ep,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return Nt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return Nt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[cl](){return`PeerId(${this.toString()})`}},zr=class extends Wr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},$r=class extends Wr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Xr=class extends Wr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},rp=2336,Zr=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=se.digest(tt(this.url))}[cl](){return`PeerId(${this.url})`}[jo]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return pt.createV1(rp,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=G(t)),t.toString()===this.toString())}};var np=114,ll=2336;function hr(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=we(ot.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return op(pt.parse(r));if(t==null)throw new nt('Please pass a multibase decoder for strings that do not start with "1" or "Q"');e=we(t.decode(r))}return ul(e)}function gi(r){if(r.type==="Ed25519")return new $r({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Xr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new zr({multihash:r.toCID().multihash,publicKey:r});throw new Pe}function ul(r){if(ip(r))return new zr({multihash:r});if(sp(r))try{let t=al(r);if(t.type==="Ed25519")return new $r({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Xr({multihash:r,publicKey:t})}catch{let e=G(r.digest);return new Zr(new URL(e))}throw new wn("Supplied PeerID Multihash is invalid")}function op(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==np&&r.code!==ll)throw new yn("Supplied PeerID CID is invalid");if(r.code===ll){let t=G(r.multihash.digest);return new Zr(new URL(t))}return ul(r.multihash)}function sp(r){return r.code===se.code}function ip(r){return r.code===fe.code}var zn=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,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",l=2**(8*o)-1;for(;;){let u=this.readAtomically(()=>{let f=this.readChar();if(f===void 0)return;let d=Number.parseInt(f,t);if(!Number.isNaN(d))return d});if(u===void 0)break;if(s*=t,s+=u,s>l||(i+=1,e!==void 0&&i>e))return}if(i!==0)return!n&&c&&i>1?void 0:s})}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 o=n*2;if(n<e.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return e[o]=i[0],e[o+1]=i[1],e[o+2]=i[2],e[o+3]=i[3],[o+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[o,!1];e[o]=s>>8,e[o+1]=s&255}return[e.length,!1]};return this.readAtomically(()=>{let e=new Uint8Array(16),[n,o]=t(e);if(n===16)return e;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=t(s.subarray(0,i));return e.set(s.subarray(0,a),16-a),e})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var fl=45,ap=15,dr=new zn;function yi(r){if(!(r.length>ap))return dr.new(r).parseWith(()=>dr.readIPv4Addr())}function wi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>fl))return dr.new(r).parseWith(()=>dr.readIPv6Addr())}function $n(r,t=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>fl)return;let e=dr.new(r).parseWith(()=>dr.readIPAddr());if(e)return t&&e.length===4?Uint8Array.from([0,0,0,0,0,0,0,0,0,0,255,255,e[0],e[1],e[2],e[3]]):e}var Fx=parseInt("0xFFFF",16),Hx=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);function Xn(r){return!!yi(r)}function Zn(r){return!!wi(r)}function jn(r){return!!$n(r)}var pl=Xn,hp=Zn,xi=function(r){let t=0;if(r=r.toString().trim(),pl(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(hp(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=pl(e[n]),i;s&&(i=xi(e[n]),e[n]=G(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,G(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 s=[n,1];for(n=9-e.length;n>0;n--)s.push("0");e.splice.apply(e,s)}let o=new Uint8Array(t+16);for(n=0;n<e.length;n++){let s=parseInt(e[n],16);o[t++]=s>>8&255,o[t++]=s&255}return o}throw new Error("invalid ip address")},ml=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let o=[];for(let s=0;s<e;s++)o.push(r[t+s]);return o.join(".")}if(e===16){let o=[];for(let s=0;s<e;s+=2)o.push(n.getUint16(t+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var pr={},bi={},pp=[[4,32,"ip4"],[6,16,"tcp"],[33,16,"dccp"],[41,128,"ip6"],[42,-1,"ip6zone"],[43,8,"ipcidr"],[53,-1,"dns",!0],[54,-1,"dns4",!0],[55,-1,"dns6",!0],[56,-1,"dnsaddr",!0],[132,16,"sctp"],[273,16,"udp"],[275,0,"p2p-webrtc-star"],[276,0,"p2p-webrtc-direct"],[277,0,"p2p-stardust"],[280,0,"webrtc-direct"],[281,0,"webrtc"],[290,0,"p2p-circuit"],[301,0,"udt"],[302,0,"utp"],[400,-1,"unix",!1,!0],[421,-1,"ipfs"],[421,-1,"p2p"],[443,0,"https"],[444,96,"onion"],[445,296,"onion3"],[446,-1,"garlic64"],[448,0,"tls"],[449,-1,"sni"],[460,0,"quic"],[461,0,"quic-v1"],[465,0,"webtransport"],[466,-1,"certhash"],[477,0,"ws"],[478,0,"wss"],[479,0,"p2p-websocket-star"],[480,0,"http"],[481,-1,"http-path"],[777,-1,"memory"]];pp.forEach(r=>{let t=mp(...r);bi[t.code]=t,pr[t.name]=t});function mp(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function rt(r){if(typeof r=="number"){if(bi[r]!=null)return bi[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(pr[r]!=null)return pr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var vb=rt("ip4"),Ib=rt("ip6"),Lb=rt("ipcidr");function vi(r,t){switch(rt(r).code){case 4:case 41:return yp(t);case 42:return Ai(t);case 43:return G(t,"base10");case 6:case 273:case 33:case 132:return wl(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ai(t);case 421:return Ep(t);case 444:return yl(t);case 445:return yl(t);case 466:return bp(t);case 481:return globalThis.encodeURIComponent(Ai(t));default:return G(t,"base16")}}function Ii(r,t){switch(rt(r).code){case 4:return gl(t);case 41:return gl(t);case 42:return Si(t);case 43:return tt(t,"base10");case 6:case 273:case 33:case 132:return Li(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Si(t);case 421:return wp(t);case 444:return Sp(t);case 445:return Ap(t);case 466:return xp(t);case 481:return Si(globalThis.decodeURIComponent(t));default:return tt(t,"base16")}}var Ei=Object.values(He).map(r=>r.decoder),gp=function(){let r=Ei[0].or(Ei[1]);return Ei.slice(2).forEach(t=>r=r.or(t)),r}();function gl(r){if(!jn(r))throw new Error("invalid ip address");return xi(r)}function yp(r){let t=ml(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!jn(t))throw new Error("invalid ip address");return t}function Li(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function wl(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Si(r){let t=tt(r),e=Uint8Array.from(kt(t.length));return wt([e,t],e.length+t.length)}function Ai(r){let t=Pt(r);if(r=r.slice(Y(t)),r.length!==t)throw new Error("inconsistent lengths");return G(r)}function wp(r){let t;r[0]==="Q"||r[0]==="1"?t=we(ot.decode(`z${r}`)).bytes:t=pt.parse(r).multihash.bytes;let e=Uint8Array.from(kt(t.length));return wt([e,t],e.length+t.length)}function xp(r){let t=gp.decode(r),e=Uint8Array.from(kt(t.length));return wt([e,t],e.length+t.length)}function bp(r){let t=Pt(r),e=r.slice(Y(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+G(e,"base64url")}function Ep(r){let t=Pt(r),e=r.slice(Y(t));if(e.length!==t)throw new Error("inconsistent lengths");return G(e,"base58btc")}function Sp(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=oe.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 o=Li(n);return wt([e,o],e.length+o.length)}function Ap(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=oe.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 o=Li(n);return wt([e,o],e.length+o.length)}function yl(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=G(t,"base32"),o=wl(e);return`${n}:${o}`}function xl(r){r=Ti(r);let t=[],e=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=rt(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw new Yn("invalid address: "+r);if(a.path===!0){n=Ti(o.slice(s).join("/")),t.push([a.code,Ii(a.code,n)]),e.push([a.code,n]);break}let c=Ii(a.code,o[s]);t.push([a.code,c]),e.push([a.code,vi(a.code,c)])}return{string:bl(e),bytes:Jn(t),tuples:t,stringTuples:e,path:n}}function Ci(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=Pt(r,o),i=Y(s),a=rt(s),c=vp(a,r.slice(o+i));if(c===0){t.push([s]),e.push([s]),o+=i;continue}let l=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw new Yn("Invalid address Uint8Array: "+G(r,"base16"));t.push([s,l]);let u=vi(s,l);if(e.push([s,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:bl(e),tuples:t,stringTuples:e,path:n}}function bl(r){let t=[];return r.map(e=>{let n=rt(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Ti(t.join("/"))}function Jn(r){return wt(r.map(t=>{let e=rt(t[0]),n=Uint8Array.from(kt(e.code));return t.length>1&&t[1]!=null&&(n=wt([n,t[1]])),n}))}function vp(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Pt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+Y(e)}}function Ti(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}var Yn=class extends Error{static name="ParseError";name="ParseError";constructor(t){super(`Error parsing address: ${t}`)}};var Ip=Symbol.for("nodejs.util.inspect.custom"),_i=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Lp=[rt("dns").code,rt("dns4").code,rt("dns6").code,rt("dnsaddr").code],Bi=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},Qn=class r{bytes;#t;#e;#r;#n;[_i]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Ci(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=xl(t)}else if(Sl(t))e=Ci(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#t=e.string,this.#e=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#t}toJSON(){return this.toString()}toOptions(){let t,e,n,o,s="",i=rt("tcp"),a=rt("udp"),c=rt("ip4"),l=rt("ip6"),u=rt("dns6"),f=rt("ip6zone");for(let[g,x]of this.stringTuples())g===f.code&&(s=`%${x??""}`),Lp.includes(g)&&(e=i.name==="tcp"?"tcp":"udp",o=443,n=`${x??""}${s}`,t=g===u.code?6:4),(g===i.code||g===a.code)&&(e=rt(g).name==="tcp"?"tcp":"udp",o=parseInt(x??"")),(g===c.code||g===l.code)&&(e=rt(g).name==="tcp"?"tcp":"udp",n=`${x??""}${s}`,t=g===l.code?6:4);if(t==null||e==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:e,port:o}}protos(){return this.#e.map(([t])=>Object.assign({},rt(t)))}protoCodes(){return this.#e.map(([t])=>t)}protoNames(){return this.#e.map(([t])=>rt(t).name)}tuples(){return this.#e.map(([t,e])=>e==null?[t]:[t,e])}stringTuples(){return this.#r.map(([t,e])=>e==null?[t]:[t,e])}encapsulate(t){return t=new r(t),new r(this.toString()+t.toString())}decapsulate(t){let e=t.toString(),n=this.toString(),o=n.lastIndexOf(e);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new r(n.slice(0,o))}decapsulateCode(t){let e=this.tuples();for(let n=e.length-1;n>=0;n--)if(e[n][0]===t)return new r(Jn(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===pr.p2p.code&&t.push([n,o]),n===pr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?G(ot.decode(`z${n}`),"base58btc"):G(pt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return Nt(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=El.get(e.name);if(n==null)throw new Bi(`no available resolver for ${e.name}`);return(await n(this,t)).map(s=>ee(s))}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)}[Ip](){return`Multiaddr(${this.#t})`}};var El=new Map;function Sl(r){return!!r?.[_i]}function ee(r){return new Qn(r)}var Tp=r=>r.toString().split("/").slice(1),mr=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),z=r=>({match:t=>mr(e=>e===r).match(t),pattern:r}),We=()=>({match:r=>mr(t=>typeof t=="string").match(r),pattern:"{string}"}),jr=()=>({match:r=>mr(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),et=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{ot.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),Yr=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Or.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),J=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),Ct=(...r)=>({match:t=>{let e;for(let n of r){let o=n.match(t);o!==!1&&(e==null||o.length<e.length)&&(e=o)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),$=(...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 lt(...r){function t(o){let s=Tp(o);for(let i of r){let a=i.match(s);if(a===!1)return!1;s=a}return s}function e(o){return t(o)!==!1}function n(o){let s=t(o);return s===!1?!1:s.length===0}return{matchers:r,matches:e,exactMatch:n}}var eo=$(z("dns4"),We()),ro=$(z("dns6"),We()),no=$(z("dnsaddr"),We()),Ni=$(z("dns"),We()),n1=lt(eo,J(et())),o1=lt(ro,J(et())),s1=lt(no,J(et())),i1=lt(Ct(Ni,no,eo,ro),J(et())),Al=$(z("ip4"),mr(Xn)),vl=$(z("ip6"),mr(Zn)),Pi=Ct(Al,vl),pe=Ct(Pi,Ni,eo,ro,no),a1=lt(Ct(Pi,$(Ct(Ni,no,eo,ro),J(et())))),c1=lt(Al),l1=lt(vl),u1=lt(Pi),Di=$(pe,z("tcp"),jr()),Jr=$(pe,z("udp"),jr()),f1=lt($(Di,J(et()))),h1=lt(Jr),Ui=$(Jr,z("quic"),J(et())),oo=$(Jr,z("quic-v1"),J(et())),Cp=Ct(Ui,oo),d1=lt(Ui),p1=lt(oo),Ri=Ct(pe,Di,Jr,Ui,oo),Il=Ct($(Ri,z("ws"),J(et()))),m1=lt(Il),Ll=Ct($(Ri,z("wss"),J(et())),$(Ri,z("tls"),J($(z("sni"),We())),z("ws"),J(et()))),g1=lt(Ll),Tl=$(Jr,z("webrtc-direct"),J(Yr()),J(Yr()),J(et())),Cl=lt(Tl),Bl=$(oo,z("webtransport"),J(Yr()),J(Yr()),J(et())),y1=lt(Bl),to=Ct(Il,Ll,$(Di,J(et())),$(Cp,J(et())),$(pe,J(et())),Tl,Bl,et()),_l=lt(to),Bp=$(to,z("p2p-circuit"),et()),w1=lt(Bp),_p=Ct($(to,z("p2p-circuit"),z("webrtc"),J(et())),$(to,z("webrtc"),J(et())),$(z("webrtc"),J(et()))),Rl=lt(_p),Rp=Ct($(pe,z("tcp"),jr(),z("http"),J(et())),$(pe,z("http"),J(et()))),x1=lt(Rp),Np=Ct($(pe,z("tcp"),Ct($(z("443"),z("http")),$(jr(),z("https"))),J(et())),$(pe,z("tls"),z("http"),J(et())),$(pe,z("https"),J(et()))),b1=lt(Np),Pp=Ct($(z("memory"),We(),J(et()))),E1=lt(Pp);var Bt;(function(r){let t;(function(o){o.FIN="FIN",o.STOP_SENDING="STOP_SENDING",o.RESET="RESET",o.FIN_ACK="FIN_ACK"})(t=r.Flag||(r.Flag={}));let e;(function(o){o[o.FIN=0]="FIN",o[o.STOP_SENDING=1]="STOP_SENDING",o[o.RESET=2]="RESET",o[o.FIN_ACK=3]="FIN_ACK"})(e||(e={})),function(o){o.codec=()=>qe(e)}(t=r.Flag||(r.Flag={}));let n;r.codec=()=>(n==null&&(n=Yt((o,s,i={})=>{i.lengthDelimited!==!1&&s.fork(),o.flag!=null&&(s.uint32(8),r.Flag.codec().encode(o.flag,s)),o.message!=null&&(s.uint32(18),s.bytes(o.message)),i.lengthDelimited!==!1&&s.ldelim()},(o,s,i={})=>{let a={},c=s==null?o.len:o.pos+s;for(;o.pos<c;){let l=o.uint32();switch(l>>>3){case 1:{a.flag=r.Flag.codec().decode(o);break}case 2:{a.message=o.bytes();break}default:{o.skipType(l&7);break}}}return a})),n),r.encode=o=>jt(o,r.codec()),r.decode=(o,s)=>Zt(o,r.codec(),s)})(Bt||(Bt={}));var Nl=["stun:stun.l.google.com:19302","stun:global.stun.twilio.com:3478","stun:stun.cloudflare.com:3478","stun:stun.services.mozilla.com:3478"],ki=Array.from("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890"),Pl="libp2p+webrtc+v1/";var Dl=466,Ul=2*1024*1024,kl=30*1e3,gr=16*1024;function Dp(r=gr){let t=Y(r-Y(r)),e=1+Y(Object.keys(Bt.Flag).length-1),n=1,o=r-t-e-n,s=Y(o);return t+e+n+s}var Ol=Dp(),Ml=5e3,Kl=5e3,Fl=3e4,Oi="/webrtc",Qr="/webrtc-signaling/0.0.1";var Hl=function(r,t,e){if(e||arguments.length===2)for(var n=0,o=t.length,s;n<o;n++)(s||!(n in t))&&(s||(s=Array.prototype.slice.call(t,0,n)),s[n]=t[n]);return r.concat(s||Array.prototype.slice.call(t))},Up=function(){function r(t,e,n){this.name=t,this.version=e,this.os=n,this.type="browser"}return r}();var kp=function(){function r(t){this.version=t,this.type="node",this.name="node",this.os=process.platform}return r}();var Op=function(){function r(t,e,n,o){this.name=t,this.version=e,this.os=n,this.bot=o,this.type="bot-device"}return r}();var Mp=function(){function r(){this.type="bot",this.bot=!0,this.name="bot",this.version=null,this.os=null}return r}();var Kp=function(){function r(){this.type="react-native",this.name="react-native",this.version=null,this.os=null}return r}();var Fp=/alexa|bot|crawl(er|ing)|facebookexternalhit|feedburner|google web preview|nagios|postrank|pingdom|slurp|spider|yahoo!|yandex/,Hp=/(nuhk|curl|Googlebot|Yammybot|Openbot|Slurp|MSNBot|Ask\ Jeeves\/Teoma|ia_archiver)/,Vl=3,Vp=[["aol",/AOLShield\/([0-9\._]+)/],["edge",/Edge\/([0-9\._]+)/],["edge-ios",/EdgiOS\/([0-9\._]+)/],["yandexbrowser",/YaBrowser\/([0-9\._]+)/],["kakaotalk",/KAKAOTALK\s([0-9\.]+)/],["samsung",/SamsungBrowser\/([0-9\.]+)/],["silk",/\bSilk\/([0-9._-]+)\b/],["miui",/MiuiBrowser\/([0-9\.]+)$/],["beaker",/BeakerBrowser\/([0-9\.]+)/],["edge-chromium",/EdgA?\/([0-9\.]+)/],["chromium-webview",/(?!Chrom.*OPR)wv\).*Chrom(?:e|ium)\/([0-9\.]+)(:?\s|$)/],["chrome",/(?!Chrom.*OPR)Chrom(?:e|ium)\/([0-9\.]+)(:?\s|$)/],["phantomjs",/PhantomJS\/([0-9\.]+)(:?\s|$)/],["crios",/CriOS\/([0-9\.]+)(:?\s|$)/],["firefox",/Firefox\/([0-9\.]+)(?:\s|$)/],["fxios",/FxiOS\/([0-9\.]+)/],["opera-mini",/Opera Mini.*Version\/([0-9\.]+)/],["opera",/Opera\/([0-9\.]+)(?:\s|$)/],["opera",/OPR\/([0-9\.]+)(:?\s|$)/],["pie",/^Microsoft Pocket Internet Explorer\/(\d+\.\d+)$/],["pie",/^Mozilla\/\d\.\d+\s\(compatible;\s(?:MSP?IE|MSInternet Explorer) (\d+\.\d+);.*Windows CE.*\)$/],["netfront",/^Mozilla\/\d\.\d+.*NetFront\/(\d.\d)/],["ie",/Trident\/7\.0.*rv\:([0-9\.]+).*\).*Gecko$/],["ie",/MSIE\s([0-9\.]+);.*Trident\/[4-7].0/],["ie",/MSIE\s(7\.0)/],["bb10",/BB10;\sTouch.*Version\/([0-9\.]+)/],["android",/Android\s([0-9\.]+)/],["ios",/Version\/([0-9\._]+).*Mobile.*Safari.*/],["safari",/Version\/([0-9\._]+).*Safari/],["facebook",/FB[AS]V\/([0-9\.]+)/],["instagram",/Instagram\s([0-9\.]+)/],["ios-webview",/AppleWebKit\/([0-9\.]+).*Mobile/],["ios-webview",/AppleWebKit\/([0-9\.]+).*Gecko\)$/],["curl",/^curl\/([0-9\.]+)$/],["searchbot",Fp]],ql=[["iOS",/iP(hone|od|ad)/],["Android OS",/Android/],["BlackBerry OS",/BlackBerry|BB10/],["Windows Mobile",/IEMobile/],["Amazon OS",/Kindle/],["Windows 3.11",/Win16/],["Windows 95",/(Windows 95)|(Win95)|(Windows_95)/],["Windows 98",/(Windows 98)|(Win98)/],["Windows 2000",/(Windows NT 5.0)|(Windows 2000)/],["Windows XP",/(Windows NT 5.1)|(Windows XP)/],["Windows Server 2003",/(Windows NT 5.2)/],["Windows Vista",/(Windows NT 6.0)/],["Windows 7",/(Windows NT 6.1)/],["Windows 8",/(Windows NT 6.2)/],["Windows 8.1",/(Windows NT 6.3)/],["Windows 10",/(Windows NT 10.0)/],["Windows ME",/Windows ME/],["Windows CE",/Windows CE|WinCE|Microsoft Pocket Internet Explorer/],["Open BSD",/OpenBSD/],["Sun OS",/SunOS/],["Chrome OS",/CrOS/],["Linux",/(Linux)|(X11)/],["Mac OS",/(Mac_PowerPC)|(Macintosh)/],["QNX",/QNX/],["BeOS",/BeOS/],["OS/2",/OS\/2/]];function Wl(r){return r?Gl(r):typeof document>"u"&&typeof navigator<"u"&&navigator.product==="ReactNative"?new Kp:typeof navigator<"u"?Gl(navigator.userAgent):Wp()}function qp(r){return r!==""&&Vp.reduce(function(t,e){var n=e[0],o=e[1];if(t)return t;var s=o.exec(r);return!!s&&[n,s]},!1)}function Gl(r){var t=qp(r);if(!t)return null;var e=t[0],n=t[1];if(e==="searchbot")return new Mp;var o=n[1]&&n[1].split(".").join("_").split("_").slice(0,3);o?o.length<Vl&&(o=Hl(Hl([],o,!0),zp(Vl-o.length),!0)):o=[];var s=o.join("."),i=Gp(r),a=Hp.exec(r);return a&&a[1]?new Op(e,s,i,a[1]):new Up(e,s,i)}function Gp(r){for(var t=0,e=ql.length;t<e;t++){var n=ql[t],o=n[0],s=n[1],i=s.exec(r);if(i)return o}return null}function Wp(){var r=typeof process<"u"&&process.version;return r?new kp(process.version.slice(1)):null}function zp(r){for(var t=[],e=0;e<r;e++)t.push("0");return t}function Z(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Mi=class extends Error{constructor(t){super(t),this.name="TimeoutError"}},Ki=class extends Error{constructor(t){super(),this.name="AbortError",this.message=t}},zl=r=>globalThis.DOMException===void 0?new Ki(r):new DOMException(r),$l=r=>{let t=r.reason===void 0?zl("This operation was aborted."):r.reason;return t instanceof Error?t:zl(t)};function tn(r,t){let{milliseconds:e,fallback:n,message:o,customTimers:s={setTimeout,clearTimeout}}=t,i,a,l=new Promise((u,f)=>{if(typeof e!="number"||Math.sign(e)!==1)throw new TypeError(`Expected \`milliseconds\` to be a positive number, got \`${e}\``);if(t.signal){let{signal:g}=t;g.aborted&&f($l(g)),a=()=>{f($l(g))},g.addEventListener("abort",a,{once:!0})}if(e===Number.POSITIVE_INFINITY){r.then(u,f);return}let d=new Mi;i=s.setTimeout.call(void 0,()=>{if(n){try{u(n())}catch(g){f(g)}return}typeof r.cancel=="function"&&r.cancel(),o===!1?u():o instanceof Error?f(o):(d.message=o??`Promise timed out after ${e} milliseconds`,f(d))},e),(async()=>{try{u(await r)}catch(g){f(g)}})()}).finally(()=>{l.clear(),a&&t.signal&&t.signal.removeEventListener("abort",a)});return l.clear=()=>{s.clearTimeout.call(void 0,i),i=void 0},l}var Xl=Wl(),en=Xl!=null&&Xl.name==="firefox",so=async function*(){},io=async r=>{};function Zl(r,t,e=Fl,n){r.readyState==="open"&&Promise.resolve().then(async()=>{if(r.bufferedAmount>0){n.log("%s drain channel with %d buffered bytes",t,r.bufferedAmount);let o=Z(),s=!1;r.bufferedAmountLowThreshold=0;let i=()=>{s||(n.log("%s drain channel closed before drain",t),o.resolve())};r.addEventListener("close",i,{once:!0}),r.addEventListener("bufferedamountlow",()=>{s=!0,r.removeEventListener("close",i),o.resolve()}),await tn(o.promise,{milliseconds:e})}}).then(async()=>{r.readyState==="open"&&r.close()}).catch(o=>{n.log.error("error closing outbound stream",o)})}async function Fi(r){return r=r??{},typeof r=="function"&&(r=await r()),r.iceServers=r.iceServers??Nl.map(t=>({urls:[t]})),r}var jl=(r=32)=>Pl+[...Array(r)].map(()=>ki.at(Math.floor(Math.random()*ki.length))).join("");var ze=class{log;peerConnection;remoteAddr;timeline;metrics;source=so();sink=io;constructor(t,e){this.log=t.logger.forComponent("libp2p:webrtc:maconn"),this.remoteAddr=e.remoteAddr,this.timeline=e.timeline,this.peerConnection=e.peerConnection;let n=this.peerConnection,o=n.connectionState;this.peerConnection.onconnectionstatechange=()=>{this.log.trace("peer connection state change",n.connectionState,"initial state",o),(n.connectionState==="disconnected"||n.connectionState==="failed"||n.connectionState==="closed")&&(this.timeline.close=Date.now())}}async close(t){this.log.trace("closing connection"),this.peerConnection.close(),this.timeline.close=Date.now(),this.metrics?.increment({close:!0})}abort(t){this.log.error("closing connection due to error",t),this.peerConnection.close(),this.timeline.close=Date.now(),this.metrics?.increment({abort:!0})}};var ao=class{buffer;mask;top;btm;next;constructor(t){if(!(t>0)||(t-1&t)!==0)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}},yr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new ao(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 ao(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 Hi=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function wr(r={}){return $p(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 $p(r,t){t=t??{};let e=t.onEnd,n=new yr,o,s,i,a=Z(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((h,w)=>{s=b=>{s=null,n.push(b);try{h(r(n))}catch(p){w(p)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Z()})}},l=h=>s!=null?s(h):(n.push(h),o),u=h=>(n=new yr,s!=null?s({error:h}):(n.push({error:h}),o)),f=h=>{if(i)return o;if(t?.objectMode!==!0&&h?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return l({done:!1,value:h})},d=h=>i?o:(i=!0,h!=null?u(h):l({done:!0})),g=()=>(n=new yr,d(),{done:!0}),x=h=>(d(h),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:g,throw:x,push:f,end:d,get readableLength(){return n.size},onEmpty:async h=>{let w=h?.signal;if(w?.throwIfAborted(),n.isEmpty())return;let b,p;w!=null&&(b=new Promise((I,R)=>{p=()=>{R(new Hi)},w.addEventListener("abort",p)}));try{await Promise.race([a.promise,b])}finally{p!=null&&w!=null&&w?.removeEventListener("abort",p)}}},e==null)return o;let m=o;return o={[Symbol.asyncIterator](){return this},next(){return m.next()},throw(h){return m.throw(h),e!=null&&(e(h),e=void 0),{done:!0}},return(){return m.return(),e!=null&&(e(),e=void 0),{done:!0}},push:f,end(h){return m.end(h),e!=null&&(e(h),e=void 0),o},get readableLength(){return m.readableLength},onEmpty:h=>m.onEmpty(h)},o}var co=class extends Error{type;code;constructor(t,e,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=e??"ABORT_ERR"}};async function bt(r,t,e){if(t==null)return r;if(t.aborted)return r.catch(()=>{}),Promise.reject(new co(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new co(e?.errorMessage,e?.errorCode,e?.errorName);try{return await Promise.race([r,new Promise((s,i)=>{n=()=>{i(o)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}function Yl(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 Jl(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Ql(r,t){let e=Yl(r).return?.();Jl(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var Xp=5e3;function Vi(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=Z(),this.closed=Z(),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??Xp,this.onEnd=t.onEnd,this.onCloseRead=t?.onCloseRead,this.onCloseWrite=t?.onCloseWrite,this.onReset=t?.onReset,this.onAbort=t?.onAbort,this.source=this.streamSource=wr({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 Ne(`writable end state is "${this.writeStatus}" not "ready"`);try{this.writeStatus="writing";let e={signal:this.sinkController.signal};if(this.direction==="outbound"){let o=this.sendNewStream(e);Vi(o)&&await o}let n=()=>{Ql(t,this.log)};try{this.sinkController.signal.addEventListener("abort",n),this.log.trace("sink reading from source");for await(let o of t){o=o instanceof Uint8Array?new V(o):o;let s=this.sendData(o,e);Vi(s)&&(this.sendingData=Z(),await s,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.status==="open"&&(this.log.trace("closing gracefully"),this.status="closing",await bt(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 bt(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await bt(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await bt(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();Vi(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 gn("stream reset");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}};function qi(r){let t=new globalThis.AbortController;function e(){t.abort();for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",e)}for(let s of r){if(s?.aborted===!0){e();break}s?.addEventListener!=null&&s.addEventListener("abort",e)}function n(){for(let s of r)s?.removeEventListener!=null&&s.removeEventListener("abort",e)}let o=t.signal;return o.clear=n,o}var uo=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},xr=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},fo=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},rn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function ho(r){return r[Symbol.asyncIterator]!=null}function tu(r,t){if(r.byteLength>t)throw new xr("Message length too long")}var mo=r=>{let t=Y(r),e=dt(t);return kt(r,e),mo.bytes=t,e};mo.bytes=0;function nn(r,t){t=t??{};let e=t.lengthEncoder??mo,n=t?.maxDataLength??4194304;function*o(s){tu(s,n);let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return ho(r)?async function*(){for await(let s of r)yield*o(s)}():function*(){for(let s of r)yield*o(s)}()}nn.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??mo,n=t?.maxDataLength??4194304;return tu(r,n),new V(e(r.byteLength),r)};var $e;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})($e||($e={}));var Gi=r=>{let t=Pt(r);return Gi.bytes=Y(t),t};Gi.bytes=0;function on(r,t){let e=new V,n=$e.LENGTH,o=-1,s=t?.lengthDecoder??Gi,i=t?.maxLengthLength??8,a=t?.maxDataLength??4194304;function*c(){for(;e.byteLength>0;){if(n===$e.LENGTH)try{if(o=s(e),o<0)throw new uo("Invalid message length");if(o>a)throw new xr("Message length too long");let l=s.bytes;e.consume(l),t?.onLength!=null&&t.onLength(o),n=$e.DATA}catch(l){if(l instanceof RangeError){if(e.byteLength>i)throw new fo("Message length length too long");break}throw l}if(n===$e.DATA){if(e.byteLength<o)break;let l=e.sublist(0,o);e.consume(o),t?.onData!=null&&t.onData(l),yield l,n=$e.LENGTH}}}return ho(r)?async function*(){for await(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new rn("Unexpected end of input")}():function*(){for(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new rn("Unexpected end of input")}()}on.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:s,value:i}=await r.next(e);if(s===!0)return;i!=null&&(yield i)}catch(s){if(s.code==="ERR_UNDER_READ")return{done:!0,value:null};throw s}finally{e=1}}();return on(n,{...t??{},onLength:s=>{e=s}})};var Wi=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 sn(r,t,e,n){let o=new Wi(n?.errorMessage,n?.errorCode);return e?.aborted===!0?Promise.reject(o):new Promise((s,i)=>{function a(){e?.removeEventListener("abort",u),r.removeEventListener(t,c),n?.errorEvent!=null&&r.removeEventListener(n.errorEvent,l)}let c=f=>{try{if(n?.filter?.(f)===!1)return}catch(d){a(),i(d);return}a(),s(f)},l=f=>{a(),i(f.detail)},u=()=>{a(),i(o)};e?.addEventListener("abort",u),r.addEventListener(t,c),n?.errorEvent!=null&&r.addEventListener(n.errorEvent,l)})}var zi=class extends lo{channel;incomingData;maxBufferedAmount;bufferedAmountLowEventTimeout;maxMessageSize;receiveFinAck;finAckTimeout;openTimeout;closeController;constructor(t){let e=t.onEnd;switch(t.onEnd=o=>{this.log.trace("readable and writeable ends closed",this.status),Promise.resolve(async()=>{if(!(this.timeline.abort!=null||this.timeline.reset!==null))try{await tn(this.receiveFinAck.promise,{milliseconds:this.finAckTimeout})}catch(s){this.log.error("error receiving FIN_ACK",s)}}).then(()=>{this.incomingData.end(),this.channel.close(),e?.(o)}).catch(s=>{this.log.error("error ending stream",s)})},super(t),this.channel=t.channel,this.channel.binaryType="arraybuffer",this.incomingData=wr(),this.bufferedAmountLowEventTimeout=t.bufferedAmountLowEventTimeout??kl,this.maxBufferedAmount=t.maxBufferedAmount??Ul,this.maxMessageSize=(t.maxMessageSize??gr)-Ol,this.receiveFinAck=Z(),this.finAckTimeout=t.closeTimeout??Ml,this.openTimeout=t.openTimeout??Kl,this.closeController=new AbortController,this.channel.readyState){case"open":this.timeline.open=new Date().getTime();break;case"closed":case"closing":(this.timeline.close===void 0||this.timeline.close===0)&&(this.timeline.close=Date.now());break;case"connecting":break;default:throw this.log.error("unknown datachannel state %s",this.channel.readyState),new Ne("Unknown datachannel state")}this.channel.onopen=o=>{this.timeline.open=new Date().getTime()},this.channel.onclose=o=>{this.log.trace("received onclose event"),this.closeController.abort(),this.receiveFinAck.resolve(),this.close().catch(s=>{this.log.error("error closing stream after channel closed",s)})},this.channel.onerror=o=>{this.log.trace("received onerror event"),this.closeController.abort();let s=o.error;this.abort(s)},this.channel.onmessage=async o=>{let{data:s}=o;s===null||s.byteLength===0||this.incomingData.push(new Uint8Array(s,0,s.byteLength))};let n=this;Promise.resolve().then(async()=>{for await(let o of on(this.incomingData)){let s=n.processIncomingProtobuf(o);s!=null&&n.sourcePush(new V(s))}}).catch(o=>{this.log.error("error processing incoming data channel messages",o)})}sendNewStream(){}async _sendMessage(t,e=!0){if(this.channel.readyState==="closed"||this.channel.readyState==="closing")throw new Ne(`Invalid datachannel state - ${this.channel.readyState}`);if(this.channel.readyState!=="open"){let n=AbortSignal.timeout(this.openTimeout),o=qi([this.closeController.signal,n]);try{this.log('channel state is "%s" and not "open", waiting for "open" event before sending data',this.channel.readyState),await sn(this.channel,"open",o)}finally{o.clear()}this.log('channel state is now "%s", sending data',this.channel.readyState)}if(e&&this.channel.bufferedAmount>this.maxBufferedAmount){let n=AbortSignal.timeout(this.bufferedAmountLowEventTimeout),o=qi([this.closeController.signal,n]);try{this.log('channel buffer is %d, wait for "bufferedamountlow" event',this.channel.bufferedAmount),await sn(this.channel,"bufferedamountlow",o)}catch(s){throw n.aborted?new bn(`Timed out waiting for DataChannel buffer to clear after ${this.bufferedAmountLowEventTimeout}ms`):s}finally{o.clear()}}try{this.channel.send(t.subarray())}catch(n){this.log.error("error while sending message",n)}}async sendData(t){for(this.log.trace("-> will send %d bytes",t.byteLength),t=t.sublist();t.byteLength>0;){let e=Math.min(t.byteLength,this.maxMessageSize),n=t.subarray(0,e),o=Bt.encode({message:n}),s=nn.single(o);this.log.trace("-> sending message %s",this.channel.readyState),await this._sendMessage(s),this.log.trace("-> sent message %s",this.channel.readyState),t.consume(e)}this.log.trace("-> sent data %s",this.channel.readyState)}async sendReset(){try{await this._sendFlag(Bt.Flag.RESET)}catch(t){this.log.error("failed to send reset - %e",t)}}async sendCloseWrite(t){if(this.channel.readyState!=="open"){this.receiveFinAck.resolve();return}if(await this._sendFlag(Bt.Flag.FIN)){this.log.trace("awaiting FIN_ACK");try{await bt(this.receiveFinAck.promise,t?.signal,{errorMessage:"sending close-write was aborted before FIN_ACK was received",errorName:"FinAckNotReceivedError"})}catch(n){this.log.error("failed to await FIN_ACK",n)}}else this.log.trace("sending FIN failed, not awaiting FIN_ACK");this.receiveFinAck.resolve()}async sendCloseRead(){this.channel.readyState==="open"&&await this._sendFlag(Bt.Flag.STOP_SENDING)}processIncomingProtobuf(t){let e=Bt.decode(t);if(e.flag!==void 0&&(this.log.trace('incoming flag %s, write status "%s", read status "%s"',e.flag,this.writeStatus,this.readStatus),e.flag===Bt.Flag.FIN&&(this.remoteCloseWrite(),this.log.trace("sending FIN_ACK"),this._sendFlag(Bt.Flag.FIN_ACK).catch(n=>{this.log.error("error sending FIN_ACK immediately",n)})),e.flag===Bt.Flag.RESET&&this.reset(),e.flag===Bt.Flag.STOP_SENDING&&this.remoteCloseRead(),e.flag===Bt.Flag.FIN_ACK&&(this.log.trace("received FIN_ACK"),this.receiveFinAck.resolve())),this.readStatus==="ready")return e.message}async _sendFlag(t){if(this.channel.readyState!=="open")return this.log.trace('not sending flag %s because channel is "%s" and not "open"',this.channel.readyState,t.toString()),!1;this.log.trace("sending flag %s",t.toString());let e=Bt.encode({flag:t}),n=nn.single(e);try{return await this._sendMessage(n,!1),!0}catch(o){this.log.error("could not send flag %s - %e",t.toString(),o)}return!1}};function br(r){let{channel:t,direction:e}=r;return new zi({id:e==="inbound"?`i${t.id}`:`r${t.id}`,log:r.logger.forComponent(`libp2p:webrtc:stream:${e}:${t.id}`),...r})}var _e=class{protocol;peerConnection;bufferedStreams=[];metrics;dataChannelOptions;components;log;constructor(t,e){this.components=t,this.peerConnection=e.peerConnection,this.metrics=e.metrics,this.protocol=e.protocol??Oi,this.dataChannelOptions=e.dataChannelOptions??{},this.log=t.logger.forComponent("libp2p:webrtc:muxerfactory"),this.peerConnection.ondatachannel=({channel:n})=>{if(this.log.trace('incoming early datachannel with channel id %d and label "%s"',n.id),n.label==="init"){this.log.trace("closing early init channel"),n.close();return}let o={},s=br({channel:n,direction:"inbound",onEnd:i=>{o.onEnd(i)},logger:t.logger,...this.dataChannelOptions});o.stream=s,o.channel=n,o.onEnd=()=>{this.bufferedStreams=this.bufferedStreams.filter(i=>i.stream.id!==s.id)},this.bufferedStreams.push(o)}}createStreamMuxer(t){return new $i(this.components,{...t,peerConnection:this.peerConnection,dataChannelOptions:this.dataChannelOptions,metrics:this.metrics,streams:this.bufferedStreams,protocol:this.protocol})}},$i=class{init;streams;protocol;log;peerConnection;dataChannelOptions;metrics;logger;constructor(t,e){this.init=e,this.log=t.logger.forComponent("libp2p:webrtc:muxer"),this.logger=t.logger,this.streams=e.streams.map(n=>n.stream),this.peerConnection=e.peerConnection,this.protocol=e.protocol??Oi,this.metrics=e.metrics,this.dataChannelOptions=e.dataChannelOptions??{},this.peerConnection.ondatachannel=({channel:n})=>{if(this.log.trace("incoming datachannel with channel id %d",n.id),n.label==="init"){this.log.trace("closing init channel"),n.close();return}let o=n.id,s=br({channel:n,direction:"inbound",onEnd:()=>{this.#t(s,n),this.log("incoming channel %s ended",o)},logger:this.logger,...this.dataChannelOptions});this.streams.push(s),this.metrics?.increment({incoming_stream:!0}),e?.onIncomingStream?.(s)},this.init.streams.length>0&&queueMicrotask(()=>{this.init.streams.forEach(n=>{n.onEnd=()=>{this.log("incoming early channel %s ended with state %s",n.channel.id,n.channel.readyState),this.#t(n.stream,n.channel)},this.metrics?.increment({incoming_stream:!0}),this.init?.onIncomingStream?.(n.stream)})})}#t(t,e){this.log.trace("stream %s %s %s onEnd",t.direction,t.id,t.protocol),Zl(e,`${t.direction} ${t.id} ${t.protocol}`,this.dataChannelOptions.drainTimeout,{log:this.log}),this.streams=this.streams.filter(n=>n.id!==t.id),this.metrics?.increment({stream_end:!0}),this.init?.onStreamEnd?.(t)}async close(t){try{await Promise.all(this.streams.map(async e=>e.close(t)))}catch(e){this.abort(e)}}abort(t){for(let e of this.streams)e.abort(t)}source=so();sink=io;newStream(){let t=this.peerConnection.createDataChannel(""),e=t.id;this.log.trace("opened outgoing datachannel with channel id %s",e);let n=br({channel:t,direction:"outbound",onEnd:()=>{this.#t(n,t),this.log("outgoing channel %s ended",e)},logger:this.logger,...this.dataChannelOptions});return this.streams.push(n),this.metrics?.increment({outgoing_stream:!0}),n}};var go=globalThis.RTCPeerConnection,yo=globalThis.RTCSessionDescription,eu=globalThis.RTCIceCandidate;var Xi=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=Z(),this.haveNext=Z()}[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=Z(),t}async throw(t){return this.ended=!0,this.error=t,t!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(t)),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return this.ended=!0,this.nextResult=t,this.haveNext.resolve(),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 this.error??new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Z(),await bt(this.readNext.promise,e?.signal,e)}};function ru(){return new Xi}var wo=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function nu(r,t){let e=ru();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 o=new V;return{read:async i=>{if(i?.signal?.throwIfAborted(),i?.bytes==null){let{done:c,value:l}=await bt(n.next(),i?.signal);return c===!0?null:l}for(;o.byteLength<i.bytes;){let{value:c,done:l}=await bt(n.next(),i?.signal);if(l===!0)throw new wo("unexpected end of input");o.append(c)}let a=o.sublist(0,i.bytes);return o.consume(i.bytes),a},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await e.push(i,a):await e.push(i.subarray(),a)},unwrap:()=>{if(o.byteLength>0){let i=r.source;r.source=async function*(){t?.yieldBytes===!1?yield o:yield*o,yield*i}()}return r}}}var xo=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},bo=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Eo=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function ou(r,t={}){let e=nu(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=Y(t.maxDataLength));let n=t?.lengthDecoder??Pt,o=t?.lengthEncoder??kt;return{read:async i=>{let a=-1,c=new V;for(;;){c.append(await e.read({...i,bytes:1}));try{a=n(c)}catch(l){if(l instanceof RangeError)continue;throw l}if(a<0)throw new xo("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Eo("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new bo("message length too long");return e.read({...i,bytes:a})},write:async(i,a)=>{await e.write(new V(o(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new V(...i.flatMap(l=>[o(l.byteLength),l]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function So(r,t){let e=ou(r,t),n={read:async(o,s)=>{let i=await e.read(s);return o.decode(i)},write:async(o,s,i)=>{await e.write(s.encode(o),i)},writeV:async(o,s,i)=>{await e.writeV(o.map(a=>s.encode(a)),i)},pb:o=>({read:async s=>n.read(o,s),write:async(s,i)=>n.write(s,o,i),writeV:async(s,i)=>n.writeV(s,o,i),unwrap:()=>n}),unwrap:()=>e.unwrap()};return n}var Kt=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};var Re=class extends Error{constructor(t){super(`WebRTC transport error: ${t}`),this.name="WebRTCTransportError"}},qt=class extends Re{constructor(t="SDP handshake failed"){super(t),this.name="SDPHandshakeFailedError"}};var Ao=class extends Re{constructor(t,e){super(`Invalid fingerprint "${t}" within ${e}`),this.name="WebRTC/InvalidFingerprintError"}};var vo=class extends Re{constructor(t){super(`A method (${t}) was called though it has been intentionally left unimplemented.`),this.name="WebRTC/UnimplementedError"}},Io=class extends Re{constructor(t){super(`unsupported hash algorithm code: ${t} please see the codes at https://github.com/multiformats/multicodec/blob/master/table.csv `),this.name="WebRTC/UnsupportedHashAlgorithmError"}};var Ot;(function(r){let t;(function(o){o.SDP_OFFER="SDP_OFFER",o.SDP_ANSWER="SDP_ANSWER",o.ICE_CANDIDATE="ICE_CANDIDATE"})(t=r.Type||(r.Type={}));let e;(function(o){o[o.SDP_OFFER=0]="SDP_OFFER",o[o.SDP_ANSWER=1]="SDP_ANSWER",o[o.ICE_CANDIDATE=2]="ICE_CANDIDATE"})(e||(e={})),function(o){o.codec=()=>qe(e)}(t=r.Type||(r.Type={}));let n;r.codec=()=>(n==null&&(n=Yt((o,s,i={})=>{i.lengthDelimited!==!1&&s.fork(),o.type!=null&&(s.uint32(8),r.Type.codec().encode(o.type,s)),o.data!=null&&(s.uint32(18),s.string(o.data)),i.lengthDelimited!==!1&&s.ldelim()},(o,s,i={})=>{let a={},c=s==null?o.len:o.pos+s;for(;o.pos<c;){let l=o.uint32();switch(l>>>3){case 1:{a.type=r.Type.codec().decode(o);break}case 2:{a.data=o.string();break}default:{o.skipType(l&7);break}}}return a})),n),r.encode=o=>jt(o,r.codec()),r.decode=(o,s)=>Zt(o,r.codec(),s)})(Ot||(Ot={}));var Lo=async(r,t,e)=>{try{let n=Z();for(Yp(r,n);;){let o=await Promise.race([n.promise,t.read({signal:e.signal}).catch(()=>{})]);if(o==null){e.signal?.throwIfAborted();break}if(o.type!==Ot.Type.ICE_CANDIDATE)throw new xn("ICE candidate message expected");let s=JSON.parse(o.data??"null");if(s===""||s===null){e.onProgress?.(new Kt("webrtc:end-of-ice-candidates")),e.log.trace("end-of-candidates received");continue}let i=new eu(s);e.log.trace("%s received new ICE candidate %o",e.direction,s);try{e.onProgress?.(new Kt("webrtc:add-ice-candidate",i.candidate)),await r.addIceCandidate(i)}catch(a){e.log.error("%s bad candidate received",e.direction,s,a)}}}catch(n){if(e.log.error("%s error parsing ICE candidate",e.direction,n),e.signal?.aborted===!0&&To(r)!=="connected")throw n}};function To(r){return en?r.iceConnectionState:r.connectionState}function Yp(r,t){r[en?"oniceconnectionstatechange":"onconnectionstatechange"]=e=>{switch(To(r)){case"connected":t.resolve();break;case"failed":case"disconnected":case"closed":t.reject(new mn("RTCPeerConnection was closed"));break;default:break}}}async function su({rtcConfiguration:r,dataChannel:t,signal:e,metrics:n,multiaddr:o,connectionManager:s,transportManager:i,log:a,logger:c,onProgress:l}){let{baseAddr:u}=iu(o);n?.dialerEvents.increment({open:!0}),a.trace("dialing base address: %a",u);let f=u.getPeerId();if(f==null)throw new nt("Relay peer was missing");let d=s.getConnections(hr(f)),g,x=!1;d.length===0?(l?.(new Kt("webrtc:dial-relay")),g=await i.dial(u,{signal:e,onProgress:l}),x=!0):(l?.(new Kt("webrtc:reuse-relay-connection")),g=d[0]);try{l?.(new Kt("webrtc:open-signaling-stream"));let m=await g.newStream(Qr,{signal:e,runOnLimitedConnection:!0}),h=So(m).pb(Ot),w=new go(r),b=new _e({logger:c},{peerConnection:w,dataChannelOptions:t});try{let p=w.createDataChannel("init");w.onicecandidate=({candidate:v})=>{let B=JSON.stringify(v?.toJSON()??null);a.trace("initiator sending ICE candidate %o",v),h.write({type:Ot.Type.ICE_CANDIDATE,data:B},{signal:e}).catch(T=>{a.error("error sending ICE candidate",T)})},w.onicecandidateerror=v=>{a.error("initiator ICE candidate error",v)};let I=await w.createOffer().catch(v=>{throw a.error("could not execute createOffer",v),new qt("Failed to set createOffer")});a.trace("initiator send SDP offer %s",I.sdp),l?.(new Kt("webrtc:send-sdp-offer")),await h.write({type:Ot.Type.SDP_OFFER,data:I.sdp},{signal:e}),await w.setLocalDescription(I).catch(v=>{throw a.error("could not execute setLocalDescription",v),new qt("Failed to set localDescription")}),l?.(new Kt("webrtc:read-sdp-answer")),a.trace("initiator read SDP answer");let R=await h.read({signal:e});if(R.type!==Ot.Type.SDP_ANSWER)throw new qt("Remote should send an SDP answer");a.trace("initiator received SDP answer %s",R.data);let _=new yo({type:"answer",sdp:R.data});return await w.setRemoteDescription(_).catch(v=>{throw a.error("could not execute setRemoteDescription",v),new qt("Failed to set remoteDescription")}),a.trace("initiator read candidates until connected"),l?.(new Kt("webrtc:read-ice-candidates")),await Lo(w,h,{direction:"initiator",signal:e,log:a,onProgress:l}),a.trace("initiator connected, closing init channel"),p.close(),l?.(new Kt("webrtc:close-signaling-stream")),a.trace("closing signaling channel"),await m.close({signal:e}),a.trace("initiator connected to remote address %s",o),{remoteAddress:o,peerConnection:w,muxerFactory:b}}catch(p){throw a.error("outgoing signaling error",p),w.close(),m.abort(p),p}finally{w.onicecandidate=null,w.onicecandidateerror=null}}finally{if(x)try{await g.close({signal:e})}catch(m){g.abort(m)}}}var au=lt(_l.matchers[0],z("p2p-circuit")),Co=class r extends Ye{transportManager;shutdownController;events;constructor(t,e){super(),this.transportManager=t.transportManager,this.events=t.events,this.shutdownController=e.shutdownController,this.onTransportListening=this.onTransportListening.bind(this)}async listen(){this.events.addEventListener("transport:listening",this.onTransportListening)}onTransportListening(t){t.detail.getAddrs().filter(n=>au.exactMatch(n)).map(n=>n.encapsulate("/webrtc")).length>0&&this.safeDispatchEvent("listening")}getAddrs(){return this.transportManager.getListeners().filter(t=>!(t instanceof r)).map(t=>t.getAddrs().filter(e=>au.exactMatch(e)).map(e=>e.encapsulate("/webrtc"))).flat()}updateAnnounceAddrs(){}async close(){this.events.removeEventListener("transport:listening",this.onTransportListening),this.shutdownController.abort(),queueMicrotask(()=>{this.safeDispatchEvent("close")})}};async function cu({peerConnection:r,stream:t,signal:e,connection:n,log:o}){o.trace("new inbound signaling stream");let s=So(t).pb(Ot);try{r.onicecandidate=({candidate:u})=>{let f=JSON.stringify(u?.toJSON()??null);o.trace("recipient sending ICE candidate %s",f),s.write({type:Ot.Type.ICE_CANDIDATE,data:f},{signal:e}).catch(d=>{o.error("error sending ICE candidate",d)})},o.trace("recipient read SDP offer");let a=await s.read({signal:e});if(a.type!==Ot.Type.SDP_OFFER)throw new qt(`expected message type SDP_OFFER, received: ${a.type??"undefined"} `);o.trace("recipient received SDP offer %s",a.data);let c=new yo({type:"offer",sdp:a.data});await r.setRemoteDescription(c).catch(u=>{throw o.error("could not execute setRemoteDescription",u),new qt("Failed to set remoteDescription")});let l=await r.createAnswer().catch(u=>{throw o.error("could not execute createAnswer",u),new qt("Failed to create answer")});o.trace("recipient send SDP answer %s",l.sdp),await s.write({type:Ot.Type.SDP_ANSWER,data:l.sdp},{signal:e}),await r.setLocalDescription(l).catch(u=>{throw o.error("could not execute setLocalDescription",u),new qt("Failed to set localDescription")}),o.trace("recipient read candidates until connected"),await Lo(r,s,{direction:"recipient",signal:e,log:o})}catch(a){if(To(r)!=="connected")throw o.error("error while handling signaling stream from peer %a",n.remoteAddr,a),r.close(),a;o("error while handling signaling stream from peer %a, ignoring as the RTCPeerConnection is already connected",n.remoteAddr,a)}let i=ee(`/webrtc/p2p/${n.remoteAddr.getPeerId()}`);return o.trace("recipient connected to remote address %s",i),{remoteAddress:i}}var Bo=class{components;init;log;_started=!1;metrics;shutdownController;constructor(t,e={}){this.components=t,this.init=e,this.log=t.logger.forComponent("libp2p:webrtc"),this.shutdownController=new AbortController,this.shutdownController.signal,t.metrics!=null&&(this.metrics={dialerEvents:t.metrics.registerCounterGroup("libp2p_webrtc_dialer_events_total",{label:"event",help:"Total count of WebRTC dialer events by type"}),listenerEvents:t.metrics.registerCounterGroup("libp2p_webrtc_listener_events_total",{label:"event",help:"Total count of WebRTC listener events by type"})})}[dn]=!0;[Symbol.toStringTag]="@libp2p/webrtc";[Je]=["@libp2p/transport"];[Ua]=["@libp2p/identify","@libp2p/circuit-relay-v2-transport"];isStarted(){return this._started}async start(){await this.components.registrar.handle(Qr,t=>{let e=this.components.upgrader.createInboundAbortSignal(this.shutdownController.signal);this._onProtocol(t,e).catch(n=>{this.log.error("failed to handle incoming connect from %p",t.connection.remotePeer,n)}).finally(()=>{e.clear()})},{runOnLimitedConnection:!0}),this._started=!0}async stop(){await this.components.registrar.unhandle(Qr),this._started=!1}createListener(t){return new Co(this.components,{shutdownController:this.shutdownController})}listenFilter(t){return t.filter(Rl.exactMatch)}dialFilter(t){return this.listenFilter(t)}async dial(t,e){this.log.trace("dialing address: %a",t);let{remoteAddress:n,peerConnection:o,muxerFactory:s}=await su({rtcConfiguration:await Fi(this.init.rtcConfiguration),dataChannel:this.init.dataChannel,multiaddr:t,dataChannelOptions:this.init.dataChannel,signal:e.signal,connectionManager:this.components.connectionManager,transportManager:this.components.transportManager,log:this.log,logger:this.components.logger,onProgress:e.onProgress}),i=new ze(this.components,{peerConnection:o,timeline:{open:Date.now()},remoteAddr:n,metrics:this.metrics?.dialerEvents}),a=await e.upgrader.upgradeOutbound(i,{skipProtection:!0,skipEncryption:!0,muxerFactory:s,onProgress:e.onProgress,signal:e.signal});return this._closeOnShutdown(o,i),a}async _onProtocol({connection:t,stream:e},n){let o=new go(await Fi(this.init.rtcConfiguration)),s=new _e(this.components,{peerConnection:o,dataChannelOptions:this.init.dataChannel});try{let{remoteAddress:i}=await cu({peerConnection:o,connection:t,stream:e,signal:n,log:this.log});await e.close({signal:n});let a=new ze(this.components,{peerConnection:o,timeline:{open:new Date().getTime()},remoteAddr:i,metrics:this.metrics?.listenerEvents});await this.components.upgrader.upgradeInbound(a,{skipEncryption:!0,skipProtection:!0,muxerFactory:s,signal:n}),this._closeOnShutdown(o,a)}catch(i){throw this.log.error("incoming signaling error",i),o.close(),e.abort(i),i}}_closeOnShutdown(t,e){let n=()=>{e.close().catch(o=>{this.log.error("could not close WebRTCMultiaddrConnection",o)})};this.shutdownController.signal.addEventListener("abort",n),t.addEventListener("close",()=>{this.shutdownController.signal.removeEventListener("abort",n)})}};function iu(r){let t=r.toString().split("/webrtc/");if(t.length!==2)throw new nt("webrtc protocol was not present in multiaddr");if(!t[0].includes("/p2p-circuit"))throw new nt("p2p-circuit protocol was not present in multiaddr");let e=ee(t[0]),o=ee("/"+t[1]).getPeerId();if(o==null)throw new nt("destination peer id was missing");let s=e.protos().pop();if(s===void 0)throw new nt("invalid multiaddr");return s.name!=="p2p"&&(e=e.encapsulate(`/p2p/${o}`)),{baseAddr:e,peerId:hr(o)}}var _o=class extends Ye{async listen(){throw new vo("WebRTCTransport.createListener")}getAddrs(){return[]}updateAnnounceAddrs(){}async close(){}};function Ro(r){return r[Symbol.asyncIterator]!=null}var No=r=>{let t=Y(r),e=dt(t);return kt(r,e),No.bytes=t,e};No.bytes=0;function lu(r,t){t=t??{};let e=t.lengthEncoder??No;function*n(o){let s=e(o.byteLength);s instanceof Uint8Array?yield s:yield*s,o instanceof Uint8Array?yield o:yield*o}return Ro(r)?async function*(){for await(let o of r)yield*n(o)}():function*(){for(let o of r)yield*n(o)}()}lu.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??No;return new V(e(r.byteLength),r)};var Po=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Do=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Uo=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},an=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Jp=8,Qp=1024*1024*4,Xe;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Xe||(Xe={}));var Zi=r=>{let t=Pt(r);return Zi.bytes=Y(t),t};Zi.bytes=0;function cn(r,t){let e=new V,n=Xe.LENGTH,o=-1,s=t?.lengthDecoder??Zi,i=t?.maxLengthLength??Jp,a=t?.maxDataLength??Qp;function*c(){for(;e.byteLength>0;){if(n===Xe.LENGTH)try{if(o=s(e),o<0)throw new Po("Invalid message length");if(o>a)throw new Do("Message length too long");let l=s.bytes;e.consume(l),t?.onLength!=null&&t.onLength(o),n=Xe.DATA}catch(l){if(l instanceof RangeError){if(e.byteLength>i)throw new Uo("Message length length too long");break}throw l}if(n===Xe.DATA){if(e.byteLength<o)break;let l=e.sublist(0,o);e.consume(o),t?.onData!=null&&t.onData(l),yield l,n=Xe.LENGTH}}}return Ro(r)?async function*(){for await(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new an("Unexpected end of input")}():function*(){for(let l of r)e.append(l),yield*c();if(e.byteLength>0)throw new an("Unexpected end of input")}()}cn.fromReader=(r,t)=>{let e=1,n=async function*(){for(;;)try{let{done:s,value:i}=await r.next(e);if(s===!0)return;i!=null&&(yield i)}catch(s){if(s.code==="ERR_UNDER_READ")return{done:!0,value:null};throw s}finally{e=1}}();return cn(n,{...t??{},onLength:s=>{e=s}})};var ji=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=Z(),this.haveNext=Z()}[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=Z(),t}async throw(t){return this.ended=!0,t!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(t)),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return this.ended=!0,this.nextResult=t,this.haveNext.resolve(),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");for(;this.nextResult!=null;)await this.readNext.promise;t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Z(),await bt(this.readNext.promise,e?.signal,e)}};function uu(){return new ji}var ko=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Yi=class extends Error{code;constructor(t,e){super(t),this.code=e}},Ji=class extends Yi{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function fu(r,t){let e=uu();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 o=new V;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,l=new Promise((u,f)=>{c=()=>{f(new Ji("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:f,value:d}=await Promise.race([n.next(),l]);return f===!0?new V:d}for(;o.byteLength<i;){let{value:f,done:d}=await Promise.race([n.next(),l]);if(d===!0)throw new ko("unexpected end of input");o.append(f)}let u=o.sublist(0,i);return o.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(o.byteLength>0){let i=r.source;r.source=async function*(){t?.yieldBytes===!1?yield o:yield*o,yield*i}()}return r}}}var Oo=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Mo=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Ko=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Qi(r,t={}){let e=fu(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=Y(t.maxDataLength));let n=t?.lengthDecoder??Pt,o=t?.lengthEncoder??kt;return{read:async i=>{let a=-1,c=new V;for(;;){c.append(await e.read(1,i));try{a=n(c)}catch(l){if(l instanceof RangeError)continue;throw l}if(a<0)throw new Oo("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Ko("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Mo("message length too long");return e.read(a,i)},write:async(i,a)=>{await e.write(new V(o(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new V(...i.flatMap(l=>[o(l.byteLength),l]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function ta(){let r=Z(),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 hu(){let r=ta(),t=ta();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var ea=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=Z(),this.haveNext=Z()}[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=Z(),t}async throw(t){return this.ended=!0,this.error=t,t!=null&&(this.haveNext.promise.catch(()=>{}),this.haveNext.reject(t)),{done:!0,value:void 0}}async return(){let t={done:!0,value:void 0};return this.ended=!0,this.nextResult=t,this.haveNext.resolve(),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 this.error??new Error("Cannot push value onto an ended pushable");for(;this.nextResult!=null;)await this.readNext.promise;t!=null?this.nextResult={done:!1,value:t}:(this.ended=!0,this.nextResult={done:!0,value:void 0}),this.haveNext.resolve(),this.haveNext=Z(),await bt(this.readNext.promise,e?.signal,e)}};function du(){return new ea}function tm(r){return r[Symbol.asyncIterator]!=null}async function em(r,t){try{await Promise.all(r.map(async e=>{for await(let n of e)await t.push(n)})),await t.end()}catch(e){await t.end(e).catch(()=>{})}}async function*rm(r){let t=du();em(r,t).catch(()=>{}),yield*t}function*nm(r){for(let t of r)yield*t}function om(...r){let t=[];for(let e of r)tm(e)||t.push(e);return t.length===r.length?nm(t):rm(r)}var pu=om;function mu(r,...t){if(r==null)throw new Error("Empty pipeline");if(ra(r)){let n=r;r=()=>n.source}else if(yu(r)||gu(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&ra(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++)ra(e[n])&&(e[n]=im(e[n]));return sm(...e)}var sm=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},gu=r=>r?.[Symbol.asyncIterator]!=null,yu=r=>r?.[Symbol.iterator]!=null,ra=r=>r==null?!1:r.sink!=null&&r.source!=null,im=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=wr({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let o,s=r.source;if(gu(s))o=async function*(){yield*s,n.end()};else if(yu(s))o=function*(){yield*s,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return pu(n,o())}return r.source};var Er=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function Fo(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function na(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function _t(r,...t){if(!na(r))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(r.length))throw new Error("Uint8Array expected of length "+t+", got length="+r.length)}function oa(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 wu(r,t){_t(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function sa(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}var me=r=>new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4)),xu=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),am=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!am)throw new Error("Non little-endian hardware is not supported");function cm(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Ho(r){if(typeof r=="string")r=cm(r);else if(na(r))r=Vo(r);else throw new Error("Uint8Array expected, got "+typeof r);return r}function bu(r,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(r,t)}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 ia=(r,t)=>{function e(n,...o){if(_t(n),r.nonceLength!==void 0){let u=o[0];if(!u)throw new Error("nonce / iv required");r.varSizeNonce?_t(u):_t(u,r.nonceLength)}let s=r.tagLength;s&&o[1]!==void 0&&_t(o[1]);let i=t(n,...o),a=(u,f)=>{if(f!==void 0){if(u!==2)throw new Error("cipher output not supported");_t(f)}},c=!1;return{encrypt(u,f){if(c)throw new Error("cannot encrypt() twice with same key + nonce");return c=!0,_t(u),a(i.encrypt.length,f),i.encrypt(u,f)},decrypt(u,f){if(_t(u),s&&u.length<s)throw new Error("invalid ciphertext length: smaller than tagLength="+s);return a(i.decrypt.length,f),i.decrypt(u,f)}}}return Object.assign(e,r),e};function aa(r,t,e=!0){if(t===void 0)return new Uint8Array(r);if(t.length!==r)throw new Error("invalid output length, expected "+r+", got: "+t.length);if(e&&!lm(t))throw new Error("invalid output, must be aligned");return t}function ca(r,t,e,n){if(typeof r.setBigUint64=="function")return r.setBigUint64(t,e,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(e>>o&s),a=Number(e&s),c=n?4:0,l=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+l,a,n)}function lm(r){return r.byteOffset%4===0}function Vo(r){return Uint8Array.from(r)}function ge(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}var Au=r=>Uint8Array.from(r.split("").map(t=>t.charCodeAt(0))),um=Au("expand 16-byte k"),fm=Au("expand 32-byte k"),hm=me(um),dm=me(fm);function U(r,t){return r<<t|r>>>32-t}function la(r){return r.byteOffset%4===0}var qo=64,pm=16,vu=2**32-1,Su=new Uint32Array;function mm(r,t,e,n,o,s,i,a){let c=o.length,l=new Uint8Array(qo),u=me(l),f=la(o)&&la(s),d=f?me(o):Su,g=f?me(s):Su;for(let x=0;x<c;i++){if(r(t,e,n,u,i,a),i>=vu)throw new Error("arx: counter overflow");let m=Math.min(qo,c-x);if(f&&m===qo){let h=x/4;if(x%4!==0)throw new Error("arx: invalid block position");for(let w=0,b;w<pm;w++)b=h+w,g[b]=d[b]^u[w];x+=qo;continue}for(let h=0,w;h<m;h++)w=x+h,s[w]=o[w]^l[h];x+=m}}function ua(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:o,counterRight:s,rounds:i}=bu({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Fo(o),Fo(i),sa(s),sa(e),(a,c,l,u,f=0)=>{_t(a),_t(c),_t(l);let d=l.length;if(u===void 0&&(u=new Uint8Array(d)),_t(u),Fo(f),f<0||f>=vu)throw new Error("arx: counter overflow");if(u.length<d)throw new Error(`arx: output (${u.length}) is shorter than data (${d})`);let g=[],x=a.length,m,h;if(x===32)g.push(m=Vo(a)),h=dm;else if(x===16&&e)m=new Uint8Array(32),m.set(a),m.set(a,16),h=hm,g.push(m);else throw new Error(`arx: invalid 32-byte key, got length=${x}`);la(c)||g.push(c=Vo(c));let w=me(m);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(h,w,me(c.subarray(0,16)),w),c=c.subarray(16)}let b=16-o;if(b!==c.length)throw new Error(`arx: nonce must be ${b} or 16 bytes`);if(b!==12){let I=new Uint8Array(12);I.set(c,s?0:12-c.length),c=I,g.push(c)}let p=me(c);return mm(r,h,w,p,l,u,f,i),ge(...g),u}}var St=(r,t)=>r[t++]&255|(r[t++]&255)<<8,fa=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=Ho(t),_t(t,32);let e=St(t,0),n=St(t,2),o=St(t,4),s=St(t,6),i=St(t,8),a=St(t,10),c=St(t,12),l=St(t,14);this.r[0]=e&8191,this.r[1]=(e>>>13|n<<3)&8191,this.r[2]=(n>>>10|o<<6)&7939,this.r[3]=(o>>>7|s<<9)&8191,this.r[4]=(s>>>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]=St(t,16+2*u)}process(t,e,n=!1){let o=n?0:2048,{h:s,r:i}=this,a=i[0],c=i[1],l=i[2],u=i[3],f=i[4],d=i[5],g=i[6],x=i[7],m=i[8],h=i[9],w=St(t,e+0),b=St(t,e+2),p=St(t,e+4),I=St(t,e+6),R=St(t,e+8),_=St(t,e+10),v=St(t,e+12),B=St(t,e+14),T=s[0]+(w&8191),M=s[1]+((w>>>13|b<<3)&8191),D=s[2]+((b>>>10|p<<6)&8191),O=s[3]+((p>>>7|I<<9)&8191),F=s[4]+((I>>>4|R<<12)&8191),L=s[5]+(R>>>1&8191),C=s[6]+((R>>>14|_<<2)&8191),E=s[7]+((_>>>11|v<<5)&8191),y=s[8]+((v>>>8|B<<8)&8191),A=s[9]+(B>>>5|o),S=0,N=S+T*a+M*(5*h)+D*(5*m)+O*(5*x)+F*(5*g);S=N>>>13,N&=8191,N+=L*(5*d)+C*(5*f)+E*(5*u)+y*(5*l)+A*(5*c),S+=N>>>13,N&=8191;let P=S+T*c+M*a+D*(5*h)+O*(5*m)+F*(5*x);S=P>>>13,P&=8191,P+=L*(5*g)+C*(5*d)+E*(5*f)+y*(5*u)+A*(5*l),S+=P>>>13,P&=8191;let k=S+T*l+M*c+D*a+O*(5*h)+F*(5*m);S=k>>>13,k&=8191,k+=L*(5*x)+C*(5*g)+E*(5*d)+y*(5*f)+A*(5*u),S+=k>>>13,k&=8191;let H=S+T*u+M*l+D*c+O*a+F*(5*h);S=H>>>13,H&=8191,H+=L*(5*m)+C*(5*x)+E*(5*g)+y*(5*d)+A*(5*f),S+=H>>>13,H&=8191;let K=S+T*f+M*u+D*l+O*c+F*a;S=K>>>13,K&=8191,K+=L*(5*h)+C*(5*m)+E*(5*x)+y*(5*g)+A*(5*d),S+=K>>>13,K&=8191;let W=S+T*d+M*f+D*u+O*l+F*c;S=W>>>13,W&=8191,W+=L*a+C*(5*h)+E*(5*m)+y*(5*x)+A*(5*g),S+=W>>>13,W&=8191;let X=S+T*g+M*d+D*f+O*u+F*l;S=X>>>13,X&=8191,X+=L*c+C*a+E*(5*h)+y*(5*m)+A*(5*x),S+=X>>>13,X&=8191;let it=S+T*x+M*g+D*d+O*f+F*u;S=it>>>13,it&=8191,it+=L*l+C*c+E*a+y*(5*h)+A*(5*m),S+=it>>>13,it&=8191;let at=S+T*m+M*x+D*g+O*d+F*f;S=at>>>13,at&=8191,at+=L*u+C*l+E*c+y*a+A*(5*h),S+=at>>>13,at&=8191;let ut=S+T*h+M*m+D*x+O*g+F*d;S=ut>>>13,ut&=8191,ut+=L*f+C*u+E*l+y*c+A*a,S+=ut>>>13,ut&=8191,S=(S<<2)+S|0,S=S+N|0,N=S&8191,S=S>>>13,P+=S,s[0]=N,s[1]=P,s[2]=k,s[3]=H,s[4]=K,s[5]=W,s[6]=X,s[7]=it,s[8]=at,s[9]=ut}finalize(){let{h:t,pad:e}=this,n=new Uint16Array(10),o=t[1]>>>13;t[1]&=8191;for(let a=2;a<10;a++)t[a]+=o,o=t[a]>>>13,t[a]&=8191;t[0]+=o*5,o=t[0]>>>13,t[0]&=8191,t[1]+=o,o=t[1]>>>13,t[1]&=8191,t[2]+=o,n[0]=t[0]+5,o=n[0]>>>13,n[0]&=8191;for(let a=1;a<10;a++)n[a]=t[a]+o,o=n[a]>>>13,n[a]&=8191;n[9]-=8192;let s=(o^1)-1;for(let a=0;a<10;a++)n[a]&=s;s=~s;for(let a=0;a<10;a++)t[a]=t[a]&s|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;ge(n)}update(t){oa(this);let{buffer:e,blockLen:n}=this;t=Ho(t);let o=t.length;for(let s=0;s<o;){let i=Math.min(n-this.pos,o-s);if(i===n){for(;n<=o-s;s+=n)this.process(t,s);continue}e.set(t.subarray(s,s+i),this.pos),this.pos+=i,s+=i,this.pos===n&&(this.process(e,0,!1),this.pos=0)}return this}destroy(){ge(this.h,this.r,this.buffer,this.pad)}digestInto(t){oa(this),wu(t,this),this.finished=!0;let{buffer:e,h:n}=this,{pos:o}=this;if(o){for(e[o++]=1;o<16;o++)e[o]=0;this.process(e,0,!0)}this.finalize();let s=0;for(let i=0;i<8;i++)t[s++]=n[i]>>>0,t[s++]=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 gm(r){let t=(n,o)=>r(o).update(Ho(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var Iu=gm(r=>new fa(r));function Cu(r,t,e,n,o,s=20){let i=r[0],a=r[1],c=r[2],l=r[3],u=t[0],f=t[1],d=t[2],g=t[3],x=t[4],m=t[5],h=t[6],w=t[7],b=o,p=e[0],I=e[1],R=e[2],_=i,v=a,B=c,T=l,M=u,D=f,O=d,F=g,L=x,C=m,E=h,y=w,A=b,S=p,N=I,P=R;for(let H=0;H<s;H+=2)_=_+M|0,A=U(A^_,16),L=L+A|0,M=U(M^L,12),_=_+M|0,A=U(A^_,8),L=L+A|0,M=U(M^L,7),v=v+D|0,S=U(S^v,16),C=C+S|0,D=U(D^C,12),v=v+D|0,S=U(S^v,8),C=C+S|0,D=U(D^C,7),B=B+O|0,N=U(N^B,16),E=E+N|0,O=U(O^E,12),B=B+O|0,N=U(N^B,8),E=E+N|0,O=U(O^E,7),T=T+F|0,P=U(P^T,16),y=y+P|0,F=U(F^y,12),T=T+F|0,P=U(P^T,8),y=y+P|0,F=U(F^y,7),_=_+D|0,P=U(P^_,16),E=E+P|0,D=U(D^E,12),_=_+D|0,P=U(P^_,8),E=E+P|0,D=U(D^E,7),v=v+O|0,A=U(A^v,16),y=y+A|0,O=U(O^y,12),v=v+O|0,A=U(A^v,8),y=y+A|0,O=U(O^y,7),B=B+F|0,S=U(S^B,16),L=L+S|0,F=U(F^L,12),B=B+F|0,S=U(S^B,8),L=L+S|0,F=U(F^L,7),T=T+M|0,N=U(N^T,16),C=C+N|0,M=U(M^C,12),T=T+M|0,N=U(N^T,8),C=C+N|0,M=U(M^C,7);let k=0;n[k++]=i+_|0,n[k++]=a+v|0,n[k++]=c+B|0,n[k++]=l+T|0,n[k++]=u+M|0,n[k++]=f+D|0,n[k++]=d+O|0,n[k++]=g+F|0,n[k++]=x+L|0,n[k++]=m+C|0,n[k++]=h+E|0,n[k++]=w+y|0,n[k++]=b+A|0,n[k++]=p+S|0,n[k++]=I+N|0,n[k++]=R+P|0}function ym(r,t,e,n){let o=r[0],s=r[1],i=r[2],a=r[3],c=t[0],l=t[1],u=t[2],f=t[3],d=t[4],g=t[5],x=t[6],m=t[7],h=e[0],w=e[1],b=e[2],p=e[3];for(let R=0;R<20;R+=2)o=o+c|0,h=U(h^o,16),d=d+h|0,c=U(c^d,12),o=o+c|0,h=U(h^o,8),d=d+h|0,c=U(c^d,7),s=s+l|0,w=U(w^s,16),g=g+w|0,l=U(l^g,12),s=s+l|0,w=U(w^s,8),g=g+w|0,l=U(l^g,7),i=i+u|0,b=U(b^i,16),x=x+b|0,u=U(u^x,12),i=i+u|0,b=U(b^i,8),x=x+b|0,u=U(u^x,7),a=a+f|0,p=U(p^a,16),m=m+p|0,f=U(f^m,12),a=a+f|0,p=U(p^a,8),m=m+p|0,f=U(f^m,7),o=o+l|0,p=U(p^o,16),x=x+p|0,l=U(l^x,12),o=o+l|0,p=U(p^o,8),x=x+p|0,l=U(l^x,7),s=s+u|0,h=U(h^s,16),m=m+h|0,u=U(u^m,12),s=s+u|0,h=U(h^s,8),m=m+h|0,u=U(u^m,7),i=i+f|0,w=U(w^i,16),d=d+w|0,f=U(f^d,12),i=i+f|0,w=U(w^i,8),d=d+w|0,f=U(f^d,7),a=a+c|0,b=U(b^a,16),g=g+b|0,c=U(c^g,12),a=a+c|0,b=U(b^a,8),g=g+b|0,c=U(c^g,7);let I=0;n[I++]=o,n[I++]=s,n[I++]=i,n[I++]=a,n[I++]=h,n[I++]=w,n[I++]=b,n[I++]=p}var wm=ua(Cu,{counterRight:!1,counterLength:4,allowShortKeys:!1}),xm=ua(Cu,{counterRight:!1,counterLength:8,extendNonceFn:ym,allowShortKeys:!1});var bm=new Uint8Array(16),Lu=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(bm.subarray(e))},Em=new Uint8Array(32);function Tu(r,t,e,n,o){let s=r(t,e,Em),i=Iu.create(s);o&&Lu(i,o),Lu(i,n);let a=new Uint8Array(16),c=xu(a);ca(c,0,BigInt(o?o.length:0),!0),ca(c,8,BigInt(n.length),!0),i.update(a);let l=i.digest();return ge(s,a),l}var Bu=r=>(t,e,n)=>({encrypt(s,i){let a=s.length;i=aa(a+16,i,!1),i.set(s);let c=i.subarray(0,-16);r(t,e,c,c,1);let l=Tu(r,t,e,c,n);return i.set(l,a),ge(l),i},decrypt(s,i){i=aa(s.length-16,i,!1);let a=s.subarray(0,-16),c=s.subarray(-16),l=Tu(r,t,e,a,n);if(!Eu(c,l))throw new Error("invalid tag");return i.set(s.subarray(0,-16)),r(t,e,i,i,1),ge(l),i}}),ha=ia({blockSize:64,nonceLength:12,tagLength:16},Bu(wm)),XS=ia({blockSize:64,nonceLength:24,tagLength:16},Bu(xm));function Ru(r,t,e){return _r(r),e===void 0&&(e=new Uint8Array(r.outputLen)),fr(r,xe(e),xe(t))}var da=new Uint8Array([0]),_u=new Uint8Array;function Nu(r,t,e,n=32){if(_r(r),Sn(n),n>255*r.outputLen)throw new Error("Length should be <= 255*HashLen");let o=Math.ceil(n/r.outputLen);e===void 0&&(e=_u);let s=new Uint8Array(o*r.outputLen),i=fr.create(r,t),a=i._cloneInto(),c=new Uint8Array(i.outputLen);for(let l=0;l<o;l++)da[0]=l+1,a.update(l===0?_u:c).update(e).update(da).digestInto(c),s.set(c,r.outputLen*l),i._cloneInto(a);return i.destroy(),a.destroy(),c.fill(0),da.fill(0),s.slice(0,n)}var pa={hashSHA256(r){return te(r.subarray())},getHKDF(r,t){let e=Ru(te,t,r),o=Nu(te,e,void 0,96),s=o.subarray(0,32),i=o.subarray(32,64),a=o.subarray(64,96);return[s,i,a]},generateX25519KeyPair(){let r=kr.utils.randomPrivateKey();return{publicKey:kr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:kr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return kr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return ha(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,o){return ha(n,t,e).decrypt(r.subarray(),o)}};var Pu=pa;function Du(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 Sr=r=>{let t=dt(2);return t[0]=r>>8,t[1]=r,t};Sr.bytes=2;var ln=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)};ln.bytes=2;function Uu(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 ma(r,t){!t.enabled||!Er||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${G(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${G(r.privateKey,"hex")}`)):t("Missing local static keys."))}function ga(r,t){!t.enabled||!Er||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${G(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${G(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function ku(r,t){!t.enabled||!Er||t(r?`REMOTE_STATIC_PUBLIC_KEY ${G(r.subarray(),"hex")}`:"Missing remote static public key.")}function ya(r,t){!t.enabled||!Er||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${G(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function wa(r,t,e){!e.enabled||!Er||(e(`CIPHER_STATE_1 ${r.n.getUint64()} ${r.k&&G(r.k,"hex")}`),e(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&G(t.k,"hex")}`))}var Ar=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var Sm=0,Am=4294967295,vm="Cipherstate has reached maximum n, a new handshake must be performed",Go=class{n;bytes;view;constructor(t=Sm){this.n=t,this.bytes=gt(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>Am)throw new Error(vm)}};var Ze=gt(0),vr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new Go(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 o=this.crypto.decrypt(e,this.n.getBytes(),t,this.k,n);return this.n.increment(),o}},xa=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=tt(e,"utf-8");this.h=Im(t,n),this.ck=this.h,this.cs=new vr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new vr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new V(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,Ze);return[new vr(this.crypto,t),new vr(this.crypto,e)]}},ba=class{ss;s;e;rs;re;initiator;crypto;constructor(t){let{crypto:e,protocolName:n,prologue:o,initiator:s,s:i,e:a,rs:c,re:l}=t;this.crypto=e,this.ss=new xa(e,n),this.ss.mixHash(o),this.initiator=s,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 o=t.sublist(e,e+n);return this.rs=this.ss.decryptAndHash(o),n}readEE(){this.writeEE()}readES(){this.writeES()}readSE(){this.writeSE()}},un=class extends ba{writeMessageA(t){return new V(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new V(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new V(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new Ar(`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 Ar(`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 Ar(`handshake stage 2 validation fail: ${e.message}`)}}};function Im(r,t){if(t.length<=32){let e=gt(32);return e.set(t),e}else return r.hash(t)}var Wo;(function(r){let t;r.codec=()=>(t==null&&(t=Yt((e,n,o={})=>{if(o.lengthDelimited!==!1&&n.fork(),e.webtransportCerthashes!=null)for(let s of e.webtransportCerthashes)n.uint32(10),n.bytes(s);o.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let o={webtransportCerthashes:[]},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let i=e.uint32();switch(i>>>3){case 1:{o.webtransportCerthashes.push(e.bytes());break}default:{e.skipType(i&7);break}}}return o})),t),r.encode=e=>jt(e,r.codec()),r.decode=e=>Zt(e,r.codec())})(Wo||(Wo={}));var fn;(function(r){let t;r.codec=()=>(t==null&&(t=Yt((e,n,o={})=>{o.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),Wo.codec().encode(e.extensions,n)),o.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let o={identityKey:gt(0),identitySig:gt(0)},s=n==null?e.len:e.pos+n;for(;e.pos<s;){let i=e.uint32();switch(i>>>3){case 1:{o.identityKey=e.bytes();break}case 2:{o.identitySig=e.bytes();break}case 4:{o.extensions=Wo.codec().decode(e,e.uint32());break}default:{e.skipType(i&7);break}}}return o})),t),r.encode=e=>jt(e,r.codec()),r.decode=e=>Zt(e,r.codec())})(fn||(fn={}));async function Ea(r,t,e){let n=await r.sign(Ou(t));return fn.encode({identityKey:cr(r.publicKey),identitySig:n,extensions:e})}async function Sa(r,t,e){try{let n=fn.decode(r),o=Gr(n.identityKey);if(e?.equals(o)===!1)throw new Error(`Payload identity key ${o} does not match expected remote identity key ${e}`);if(!t)throw new Error("Remote static does not exist");let s=Ou(t);if(!await o.verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new pn(n.message)}}function Ou(r){let t=tt("noise-libp2p-static-key:");return r instanceof Uint8Array?wt([t,r],t.length+r.length):(r.prepend(t),r)}async function Mu(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:l}=r,u=await Ea(s,a.publicKey,l),f=new un({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:i,s:a});ma(f.s,e),e.trace("Stage 0 - Initiator starting to send first message."),await n.write(f.writeMessageA(Ze),t),e.trace("Stage 0 - Initiator finished sending first message."),ga(f.e,e),e.trace("Stage 1 - Initiator waiting to receive first message from responder...");let d=f.readMessageB(await n.read(t));e.trace("Stage 1 - Initiator received the message."),ya(f.re,e),ku(f.rs,e),e.trace("Initiator going to check remote's signature...");let g=await Sa(d,f.rs,c);e.trace("All good with the signature!"),e.trace("Stage 2 - Initiator sending third handshake message."),await n.write(f.writeMessageC(u),t),e.trace("Stage 2 - Initiator sent message with signed payload.");let[x,m]=f.ss.split();return wa(x,m,e),{payload:g,encrypt:h=>x.encryptWithAd(Ze,h),decrypt:(h,w)=>m.decryptWithAd(Ze,h,w)}}async function Ku(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:l}=r,u=await Ea(s,a.publicKey,l),f=new un({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:i,s:a});ma(f.s,e),e.trace("Stage 0 - Responder waiting to receive first message."),f.readMessageA(await n.read(t)),e.trace("Stage 0 - Responder received first message."),ya(f.re,e),e.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await n.write(f.writeMessageB(u),t),e.trace("Stage 1 - Responder sent the second handshake message with signed payload."),ga(f.e,e),e.trace("Stage 2 - Responder waiting for third handshake message...");let d=f.readMessageC(await n.read(t));e.trace("Stage 2 - Responder received the message, finished handshake.");let g=await Sa(d,f.rs,c),[x,m]=f.ss.split();return wa(x,m,e),{payload:g,encrypt:h=>m.encryptWithAd(Ze,h),decrypt:(h,w)=>x.decryptWithAd(Ze,h,w)}}var Hu=16;function Vu(r,t){return async function*(e){for await(let n of e)for(let o=0;o<n.length;o+=65519){let s=o+65519;s>n.length&&(s=n.length);let i;n instanceof Uint8Array?i=r.encrypt(n.subarray(o,s)):i=r.encrypt(n.sublist(o,s)),t?.encryptedPackets.increment(),yield new V(Sr(i.byteLength),i)}}}function qu(r,t){return async function*(e){for await(let n of e)for(let o=0;o<n.length;o+=65535){let s=o+65535;if(s>n.length&&(s=n.length),s-Hu<o)throw new Error("Invalid chunk");let i=n.sublist(o,s),a=n.subarray(o,s-Hu);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var zo=class{protocol="/noise";crypto;prologue;staticKey;extensions;metrics;components;constructor(t,e={}){let{staticNoiseKey:n,extensions:o,crypto:s,prologueBytes:i}=e,{metrics:a}=t;this.components=t;let c=s??Pu;this.crypto=Du(c),this.extensions=o,this.metrics=a?Uu(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??gt(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[Je]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(t,e){let n=Qi(t,{lengthEncoder:Sr,lengthDecoder:ln,maxDataLength:65535}),o=await this.performHandshakeInitiator(n,this.components.privateKey,e?.remotePeer?.publicKey,e),s=await this.createSecureConnection(n,o);t.source=s.source,t.sink=s.sink;let i=Gr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:gi(i)}}async secureInbound(t,e){let n=Qi(t,{lengthEncoder:Sr,lengthDecoder:ln,maxDataLength:65535}),o=await this.performHandshakeResponder(n,this.components.privateKey,e?.remotePeer?.publicKey,e),s=await this.createSecureConnection(n,o);t.source=s.source,t.sink=s.sink;let i=Gr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:gi(i)}}async performHandshakeInitiator(t,e,n,o){let s;try{s=await Mu({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},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(i){throw this.metrics?.xxHandshakeErrors.increment(),i}return s}async performHandshakeResponder(t,e,n,o){let s;try{s=await Ku({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},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(i){throw this.metrics?.xxHandshakeErrors.increment(),i}return s}async createSecureConnection(t,e){let[n,o]=hu(),s=t.unwrap();return await mu(n,Vu(e,this.metrics),s,i=>cn(i,{lengthDecoder:ln}),qu(e,this.metrics),n),o}};function Gu(r={}){return t=>new zo(t,r)}var Aa=Object.values(He).map(r=>r.decoder).reduce((r,t)=>r.or(t)),Lm=/^a=fingerprint:(?:\w+-[0-9]+)\s(?<fingerprint>(:?[0-9a-fA-F]{2})+)$/m;function Wu(r){return r?.match(Lm)?.groups?.fingerprint}function va(r){let e=r.stringTuples().filter(n=>n[0]===Dl).map(n=>n[1])[0];if(e===void 0||e==="")throw new nt(`Couldn't find a certhash component of multiaddr: ${r.toString()}`);return e}function Tm(r){return Ft.decode(Aa.decode(r))}function Cm(r){let t=Tm(va(r)),e=Bm(t.code),n=t.digest.reduce((s,i)=>s+i.toString(16).padStart(2,"0"),""),o=n.match(/.{1,2}/g);if(o==null)throw new Ao(n,r.toString());return`${e} ${o.join(":").toUpperCase()}`}function zu(r){let t=r.split(":").map(o=>parseInt(o,16)),e=Uint8Array.from(t),n=It(fe.code,e);return ee(`/certhash/${Or.encode(n.bytes)}`)}function Bm(r){switch(r){case 17:return"sha-1";case 18:return"sha-256";case 19:return"sha-512";default:throw new Io(r)}}function $u(r,t){let{host:e,port:n,family:o}=r.toOptions(),s=Cm(r);return{type:"answer",sdp:`v=0
3
3
  o=- 0 0 IN IP${o} ${e}
4
4
  s=-
5
5
  t=0 0
@@ -13,10 +13,10 @@ a=ice-pwd:${t}
13
13
  a=fingerprint:${s}
14
14
  a=setup:passive
15
15
  a=sctp-port:5000
16
- a=max-message-size:${yr}
16
+ a=max-message-size:${gr}
17
17
  a=candidate:1467250027 1 UDP 1467250027 ${e} ${n} typ host
18
18
  a=end-of-candidates
19
- `}}function Mu(r,t){let{host:e,port:n,family:o}=r.toOptions();return{type:"offer",sdp:`v=0
19
+ `}}function Xu(r,t){let{host:e,port:n,family:o}=r.toOptions();return{type:"offer",sdp:`v=0
20
20
  o=- 0 0 IN IP${o} ${e}
21
21
  s=-
22
22
  c=IN IP${o} ${e}
@@ -29,15 +29,15 @@ a=ice-ufrag:${t}
29
29
  a=ice-pwd:${t}
30
30
  a=fingerprint:sha-256 00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00
31
31
  a=sctp-port:5000
32
- a=max-message-size:${yr}
32
+ a=max-message-size:${gr}
33
33
  a=candidate:1467250027 1 UDP 1467250027 ${e} ${n} typ host
34
34
  a=end-of-candidates
35
- `}}function ba(r,t){if(r.sdp===void 0)throw new rt("Can't munge a missing SDP");let e=r.sdp.includes(`\r
35
+ `}}function Ia(r,t){if(r.sdp===void 0)throw new nt("Can't munge a missing SDP");let e=r.sdp.includes(`\r
36
36
  `)?`\r
37
37
  `:`
38
38
  `;return r.sdp=r.sdp.replace(/\na=ice-ufrag:[^\n]*\n/,`
39
39
  a=ice-ufrag:`+t+e).replace(/\na=ice-pwd:[^\n]*\n/,`
40
- a=ice-pwd:`+t+e),r}var xa=J("libp2p-webrtc-noise:");function Fu(r,t,e){let n=r.trim().toLowerCase().replaceAll(":",""),o=J(n,"hex"),s=vt(fe.code,o),i=ya.decode(wa(t)),a=xa.byteLength+s.bytes.byteLength+i.byteLength;return e==="server"?wt([xa,i,s.bytes],a):wt([xa,s.bytes,i],a)}var xm=en?"iceconnectionstatechange":"connectionstatechange";async function Hu(r,t,e){let n=r.createDataChannel("",{negotiated:!0,id:0});if(e.role==="client"){e.log.trace("client creating local offer");let d=await r.createOffer();e.log.trace("client created local offer %s",d.sdp);let g=ba(d,t);e.log.trace("client setting local offer %s",g.sdp),await r.setLocalDescription(g);let b=Ou(e.remoteAddr,t);e.log.trace("client setting server description %s",b.sdp),await r.setRemoteDescription(b)}else{let d=Mu(e.remoteAddr,t);e.log.trace("server setting client %s %s",d.type,d.sdp),await r.setRemoteDescription(d),e.log.trace("server creating local answer");let g=await r.createAnswer();e.log.trace("server created local answer");let b=ba(g,t);e.log.trace("server setting local description %s",g.sdp),await r.setLocalDescription(b)}if(e.log.trace("%s wait for handshake channel to open",e.role),await sn(n,"open",e.signal),e.log.trace("%s handshake channel opened",e.role),e.role==="server"){let d=r.remoteFingerprint()?.value??"";e.remoteAddr=e.remoteAddr.encapsulate(ku(d))}let o=Uu(r.localDescription?.sdp);if(o==null)throw new Re("Could not get fingerprint from local description sdp");e.log.trace("%s performing noise handshake",e.role);let s=Fu(o,e.remoteAddr,e.role),i=Nu({prologueBytes:s})(e),a=xr({channel:n,direction:"inbound",logger:e.logger,...e.dataChannel??{}}),c={...a,sink:a.sink.bind(a),source:async function*(){for await(let d of a.source)for(let g of d)yield g}()},l=new $e(e,{peerConnection:r,remoteAddr:e.remoteAddr,timeline:{open:Date.now()},metrics:e.events});r.addEventListener(xm,()=>{switch(r.connectionState){case"failed":case"disconnected":case"closed":l.close().catch(d=>{e.log.error("error closing connection",d),l.abort(d)});break;default:break}}),e.events?.increment({peer_connection:!0});let u=new _e(e,{peerConnection:r,metrics:e.events,dataChannelOptions:e.dataChannel});if(e.role==="client")return e.log.trace("%s secure inbound",e.role),await i.secureInbound(c,{remotePeer:e.remotePeerId,signal:e.signal}),e.log.trace("%s upgrade outbound",e.role),e.upgrader.upgradeOutbound(l,{skipProtection:!0,skipEncryption:!0,muxerFactory:u,signal:e.signal});e.log.trace("%s secure outbound",e.role);let f=await i.secureOutbound(c,{remotePeer:e.remotePeerId,signal:e.signal});l.remoteAddr=l.remoteAddr.encapsulate(`/p2p/${f.remotePeer}`),e.log.trace("%s upgrade inbound",e.role),await e.upgrader.upgradeInbound(l,{skipProtection:!0,skipEncryption:!0,muxerFactory:u,signal:e.signal})}async function Vu(r,t,e,n){n==null&&(n=await RTCPeerConnection.generateCertificate({name:"ECDSA",namedCurve:"P-256"}));let o=typeof e=="function"?await e():e;return new RTCPeerConnection({...o??{},certificates:[n]})}var Go=class{log;metrics;components;init;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:webrtc-direct"),this.components=t,this.init=e,t.metrics!=null&&(this.metrics={dialerEvents:t.metrics.registerCounterGroup("libp2p_webrtc-direct_dialer_events_total",{label:"event",help:"Total count of WebRTC-direct dial events by type"})})}[pn]=!0;[Symbol.toStringTag]="@libp2p/webrtc-direct";[Qe]=["@libp2p/transport"];async dial(t,e){let n=await this._connect(t,e);return this.log("dialing address: %a",t),n}createListener(t){return new Ro(this.components,{...this.init,...t})}listenFilter(t){return t.filter(Sl.exactMatch)}dialFilter(t){return this.listenFilter(t)}async _connect(t,e){e.signal.throwIfAborted();let n,o=t.getPeerId();o!=null&&(n=dr(o));let s=Gl(),i=await Vu("client",s,typeof this.init.rtcConfiguration=="function"?await this.init.rtcConfiguration():this.init.rtcConfiguration??{});try{return await Yt(Hu(i,s,{role:"client",log:this.log,logger:this.components.logger,metrics:this.components.metrics,events:this.metrics?.dialerEvents,signal:e.signal,remoteAddr:t,dataChannel:this.init.dataChannel,upgrader:e.upgrader,peerId:this.components.peerId,remotePeerId:n,privateKey:this.components.privateKey}),e.signal)}catch(a){throw i.close(),a}}};function Em(r){return t=>new Go(t,r)}function Sm(r){return t=>new _o(t,r)}return ef(Am);})();
40
+ a=ice-pwd:`+t+e),r}var La=tt("libp2p-webrtc-noise:");function ju(r,t,e){let n=r.trim().toLowerCase().replaceAll(":",""),o=tt(n,"hex"),s=It(fe.code,o),i=Aa.decode(va(t)),a=La.byteLength+s.bytes.byteLength+i.byteLength;return e==="server"?wt([La,i,s.bytes],a):wt([La,s.bytes,i],a)}var _m=en?"iceconnectionstatechange":"connectionstatechange";async function Yu(r,t,e){let n=r.createDataChannel("",{negotiated:!0,id:0});if(e.role==="client"){e.log.trace("client creating local offer");let d=await r.createOffer();e.log.trace("client created local offer %s",d.sdp);let g=Ia(d,t);e.log.trace("client setting local offer %s",g.sdp),await r.setLocalDescription(g);let x=$u(e.remoteAddr,t);e.log.trace("client setting server description %s",x.sdp),await r.setRemoteDescription(x)}else{let d=Xu(e.remoteAddr,t);e.log.trace("server setting client %s %s",d.type,d.sdp),await r.setRemoteDescription(d),e.log.trace("server creating local answer");let g=await r.createAnswer();e.log.trace("server created local answer");let x=Ia(g,t);e.log.trace("server setting local description %s",g.sdp),await r.setLocalDescription(x)}if(e.log.trace("%s wait for handshake channel to open",e.role),await sn(n,"open",e.signal),e.log.trace("%s handshake channel opened",e.role),e.role==="server"){let d=r.remoteFingerprint()?.value??"";e.remoteAddr=e.remoteAddr.encapsulate(zu(d))}let o=Wu(r.localDescription?.sdp);if(o==null)throw new Re("Could not get fingerprint from local description sdp");e.log.trace("%s performing noise handshake",e.role);let s=ju(o,e.remoteAddr,e.role),i=Gu({prologueBytes:s})(e),a=br({channel:n,direction:"inbound",logger:e.logger,...e.dataChannel??{}}),c={...a,sink:a.sink.bind(a),source:async function*(){for await(let d of a.source)for(let g of d)yield g}()},l=new ze(e,{peerConnection:r,remoteAddr:e.remoteAddr,timeline:{open:Date.now()},metrics:e.events});r.addEventListener(_m,()=>{switch(r.connectionState){case"failed":case"disconnected":case"closed":l.close().catch(d=>{e.log.error("error closing connection",d),l.abort(d)});break;default:break}}),e.events?.increment({peer_connection:!0});let u=new _e(e,{peerConnection:r,metrics:e.events,dataChannelOptions:e.dataChannel});if(e.role==="client")return e.log.trace("%s secure inbound",e.role),await i.secureInbound(c,{remotePeer:e.remotePeerId,signal:e.signal}),e.log.trace("%s upgrade outbound",e.role),e.upgrader.upgradeOutbound(l,{skipProtection:!0,skipEncryption:!0,muxerFactory:u,signal:e.signal});e.log.trace("%s secure outbound",e.role);let f=await i.secureOutbound(c,{remotePeer:e.remotePeerId,signal:e.signal});l.remoteAddr=l.remoteAddr.encapsulate(`/p2p/${f.remotePeer}`),e.log.trace("%s upgrade inbound",e.role),await e.upgrader.upgradeInbound(l,{skipProtection:!0,skipEncryption:!0,muxerFactory:u,signal:e.signal})}async function Ju(r,t,e,n){n==null&&(n=await RTCPeerConnection.generateCertificate({name:"ECDSA",namedCurve:"P-256"}));let o=typeof e=="function"?await e():e;return new RTCPeerConnection({...o??{},certificates:[n]})}var $o=class{log;metrics;components;init;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:webrtc-direct"),this.components=t,this.init=e,t.metrics!=null&&(this.metrics={dialerEvents:t.metrics.registerCounterGroup("libp2p_webrtc-direct_dialer_events_total",{label:"event",help:"Total count of WebRTC-direct dial events by type"})})}[dn]=!0;[Symbol.toStringTag]="@libp2p/webrtc-direct";[Je]=["@libp2p/transport"];async dial(t,e){let n=await this._connect(t,e);return this.log("dialing address: %a",t),n}createListener(t){return new _o(this.components,{...this.init,...t})}listenFilter(t){return t.filter(Cl.exactMatch)}dialFilter(t){return this.listenFilter(t)}async _connect(t,e){e.signal.throwIfAborted();let n,o=t.getPeerId();o!=null&&(n=hr(o));let s=jl(),i=await Ju("client",s,typeof this.init.rtcConfiguration=="function"?await this.init.rtcConfiguration():this.init.rtcConfiguration??{});try{return await bt(Yu(i,s,{role:"client",log:this.log,logger:this.components.logger,metrics:this.components.metrics,events:this.metrics?.dialerEvents,signal:e.signal,remoteAddr:t,dataChannel:this.init.dataChannel,upgrader:e.upgrader,peerId:this.components.peerId,remotePeerId:n,privateKey:this.components.privateKey}),e.signal)}catch(a){throw i.close(),a}}};function Rm(r){return t=>new $o(t,r)}function Nm(r){return t=>new Bo(t,r)}return hf(Pm);})();
41
41
  /*! Bundled license information:
42
42
 
43
43
  @noble/hashes/esm/utils.js: