@libp2p/webtransport 5.0.37-b2124c2db → 5.0.37-da4e9da82

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.Libp2PWebtransport = factory()}(typeof self !== 'undefined' ? self : this, function () {
2
- "use strict";var Libp2PWebtransport=(()=>{var no=Object.defineProperty;var Tu=Object.getOwnPropertyDescriptor;var _u=Object.getOwnPropertyNames;var Ru=Object.prototype.hasOwnProperty;var vt=(r,t)=>{for(var e in t)no(r,e,{get:t[e],enumerable:!0})},Cu=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of _u(t))!Ru.call(r,o)&&o!==e&&no(r,o,{get:()=>t[o],enumerable:!(n=Tu(t,o))||n.enumerable});return r};var Uu=r=>Cu(no({},"__esModule",{value:!0}),r);var Nd={};vt(Nd,{webTransport:()=>Pd});var oo=Symbol.for("@libp2p/peer-id");var Ki=Symbol.for("@libp2p/transport");var Di;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Di||(Di={}));var qr=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}},Vr=class extends Error{static name="InvalidCryptoExchangeError";constructor(t="Invalid crypto exchange"){super(t),this.name="InvalidCryptoExchangeError"}},gt=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Oe=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var Fr=class extends Error{static name="StreamResetError";constructor(t="The stream has been reset"){super(t),this.name="StreamResetError"}},zr=class extends Error{static name="StreamStateError";constructor(t="The stream is in an invalid state"){super(t),this.name="StreamStateError"}};var Gr=class extends Error{static name="InvalidMultiaddrError";constructor(t="Invalid multiaddr"){super(t),this.name="InvalidMultiaddrError"}},Wr=class extends Error{static name="InvalidCIDError";constructor(t="Invalid CID"){super(t),this.name="InvalidCIDError"}},$r=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var be=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var Zr=Symbol.for("@libp2p/service-capabilities"),Md=Symbol.for("@libp2p/service-dependencies");var uo={};vt(uo,{base58btc:()=>et,base58flickr:()=>Ou});var cp=new Uint8Array(0);function Oi(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 jt(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 Mi(r){return new TextEncoder().encode(r)}function Hi(r){return new TextDecoder().decode(r)}function Pu(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),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(w){if(w instanceof Uint8Array||(ArrayBuffer.isView(w)?w=new Uint8Array(w.buffer,w.byteOffset,w.byteLength):Array.isArray(w)&&(w=Uint8Array.from(w))),!(w instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(w.length===0)return"";for(var m=0,h=0,x=0,E=w.length;x!==E&&w[x]===0;)x++,m++;for(var p=(E-x)*u+1>>>0,I=new Uint8Array(p);x!==E;){for(var C=w[x],R=0,T=p-1;(C!==0||R<h)&&T!==-1;T--,R++)C+=256*I[T]>>>0,I[T]=C%a>>>0,C=C/a>>>0;if(C!==0)throw new Error("Non-zero carry");h=R,x++}for(var _=p-h;_!==p&&I[_]===0;)_++;for(var B=c.repeat(m);_<p;++_)B+=r.charAt(I[_]);return B}function d(w){if(typeof w!="string")throw new TypeError("Expected String");if(w.length===0)return new Uint8Array;var m=0;if(w[m]!==" "){for(var h=0,x=0;w[m]===c;)h++,m++;for(var E=(w.length-m)*f+1>>>0,p=new Uint8Array(E);w[m];){var I=e[w.charCodeAt(m)];if(I===255)return;for(var C=0,R=E-1;(I!==0||C<x)&&R!==-1;R--,C++)I+=a*p[R]>>>0,p[R]=I%256>>>0,I=I/256>>>0;if(I!==0)throw new Error("Non-zero carry");x=C,m++}if(w[m]!==" "){for(var T=E-x;T!==E&&p[T]===0;)T++;for(var _=new Uint8Array(h+(E-T)),B=h;T!==E;)_[B++]=p[T++];return _}}}function g(w){var m=d(w);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:d,decode:g}}var Nu=Pu,ku=Nu,Vi=ku;var so=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")}},io=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 Fi(this,t)}},ao=class{decoders;constructor(t){this.decoders=t}or(t){return Fi(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 Fi(r,t){return new ao({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var co=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 so(t,e,n),this.decoder=new io(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Me({name:r,prefix:t,encode:e,decode:n}){return new co(r,t,e,n)}function ce({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Vi(e,r);return Me({prefix:t,name:r,encode:n,decode:s=>jt(o(s))})}function Du(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,f=0;for(let u=0;u<s;++u){let l=o[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|l,a+=e,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=e||(255&c<<8-a)!==0)throw new SyntaxError("Unexpected end of data");return i}function Ku(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 ut({name:r,prefix:t,bitsPerChar:e,alphabet:n}){return Me({prefix:t,name:r,encode(o){return Ku(o,n,e)},decode(o){return Du(o,n,e,r)}})}var et=ce({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Ou=ce({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var fo={};vt(fo,{base32:()=>Xt,base32hex:()=>Vu,base32hexpad:()=>zu,base32hexpadupper:()=>Gu,base32hexupper:()=>Fu,base32pad:()=>Hu,base32padupper:()=>qu,base32upper:()=>Mu,base32z:()=>Wu});var Xt=ut({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Mu=ut({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Hu=ut({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),qu=ut({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),Vu=ut({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),Fu=ut({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),zu=ut({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),Gu=ut({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),Wu=ut({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var lo={};vt(lo,{base36:()=>ar,base36upper:()=>$u});var ar=ce({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),$u=ce({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var zt={};vt(zt,{Digest:()=>Ee,create:()=>Nt,decode:()=>ue,equals:()=>po,hasCode:()=>df});var Zu=Wi,zi=128,ju=127,Xu=~ju,Yu=Math.pow(2,31);function Wi(r,t,e){t=t||[],e=e||0;for(var n=e;r>=Yu;)t[e++]=r&255|zi,r/=128;for(;r&Xu;)t[e++]=r&255|zi,r>>>=7;return t[e]=r|0,Wi.bytes=e-n+1,t}var Ju=ho,Qu=128,Gi=127;function ho(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw ho.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&Gi)<<o:(i&Gi)*Math.pow(2,o),o+=7}while(i>=Qu);return ho.bytes=s-n,e}var tf=Math.pow(2,7),ef=Math.pow(2,14),rf=Math.pow(2,21),nf=Math.pow(2,28),of=Math.pow(2,35),sf=Math.pow(2,42),af=Math.pow(2,49),cf=Math.pow(2,56),uf=Math.pow(2,63),ff=function(r){return r<tf?1:r<ef?2:r<rf?3:r<nf?4:r<of?5:r<sf?6:r<af?7:r<cf?8:r<uf?9:10},lf={encode:Zu,decode:Ju,encodingLength:ff},hf=lf,cr=hf;function ur(r,t=0){return[cr.decode(r,t),cr.decode.bytes]}function He(r,t,e=0){return cr.encode(r,t,e),t}function qe(r){return cr.encodingLength(r)}function Nt(r,t){let e=t.byteLength,n=qe(r),o=n+qe(e),s=new Uint8Array(o+e);return He(r,s,0),He(e,s,n),s.set(t,o),new Ee(r,e,t,s)}function ue(r){let t=jt(r),[e,n]=ur(t),[o,s]=ur(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Ee(e,o,i,t)}function po(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Oi(r.bytes,e.bytes)}}var Ee=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function df(r,t){return r.code===t}function $i(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return mf(e,mo(r),t??et.encoder);default:return yf(e,mo(r),t??Xt.encoder)}}var Zi=new WeakMap;function mo(r){let t=Zi.get(r);if(t==null){let e=new Map;return Zi.set(r,e),e}return t}var ht=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!==fr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==gf)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=Nt(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&&po(t.multihash,n.multihash)}toString(t){return $i(this,t)}toJSON(){return{"/":$i(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??ji(n,o,s.bytes))}else if(e[wf]===!0){let{version:n,multihash:o,code:s}=e,i=ue(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!==fr)throw new Error(`Version 0 CID must use dag-pb (code: ${fr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=ji(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,fr,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=jt(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 Ee(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[l,d]=ur(t.subarray(e));return e+=d,l},o=n(),s=fr;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(),f=e+c,u=f-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(t,e){let[n,o]=pf(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 mo(s).set(n,t),s}};function pf(r,t){switch(r[0]){case"Q":{let e=t??et;return[et.prefix,e.decode(`${et.prefix}${r}`)]}case et.prefix:{let e=t??et;return[et.prefix,e.decode(r)]}case Xt.prefix:{let e=t??Xt;return[Xt.prefix,e.decode(r)]}case ar.prefix:{let e=t??ar;return[ar.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!==et.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 yf(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 fr=112,gf=18;function ji(r,t,e){let n=qe(r),o=n+qe(t),s=new Uint8Array(o+e.byteLength);return He(r,s,0),He(t,s,n),s.set(e,o),s}var wf=Symbol.for("@ipld/js-cid/CID");var yo={};vt(yo,{identity:()=>Yt});var Xi=0,xf="identity",Yi=jt;function bf(r){return Nt(Xi,Yi(r))}var Yt={code:Xi,name:xf,encode:Yi,digest:bf};function xt(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 Xr(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Ef(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Ve(r,...t){if(!Ef(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 lr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.wrapConstructor");Xr(r.outputLen),Xr(r.blockLen)}function Fe(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 Ji(r,t){Ve(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Se=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Yr(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Kt(r,t){return r<<32-t|r>>>t}function Qi(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function fe(r){return typeof r=="string"&&(r=Qi(r)),Ve(r),r}function go(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Ve(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 ze=class{clone(){return this._cloneInto()}};function Jr(r){let t=n=>r().update(fe(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function hr(r=32){if(Se&&typeof Se.getRandomValues=="function")return Se.getRandomValues(new Uint8Array(r));if(Se&&typeof Se.randomBytes=="function")return Se.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function Sf(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,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function ta(r,t,e){return r&t^~r&e}function ea(r,t,e){return r&t^r&e^t&e}var Ge=class extends ze{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=Yr(this.buffer)}update(t){Fe(this);let{view:e,buffer:n,blockLen:o}=this;t=fe(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=Yr(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){Fe(this),Ji(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 l=i;l<o;l++)e[l]=0;Sf(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=Yr(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],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 Qr=BigInt(4294967295),wo=BigInt(32);function ra(r,t=!1){return t?{h:Number(r&Qr),l:Number(r>>wo&Qr)}:{h:Number(r>>wo&Qr)|0,l:Number(r&Qr)|0}}function Af(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}=ra(r[o],t);[e[o],n[o]]=[s,i]}return[e,n]}var vf=(r,t)=>BigInt(r>>>0)<<wo|BigInt(t>>>0),Bf=(r,t,e)=>r>>>e,If=(r,t,e)=>r<<32-e|t>>>e,Lf=(r,t,e)=>r>>>e|t<<32-e,Tf=(r,t,e)=>r<<32-e|t>>>e,_f=(r,t,e)=>r<<64-e|t>>>e-32,Rf=(r,t,e)=>r>>>e-32|t<<64-e,Cf=(r,t)=>t,Uf=(r,t)=>r,Pf=(r,t,e)=>r<<e|t>>>32-e,Nf=(r,t,e)=>t<<e|r>>>32-e,kf=(r,t,e)=>t<<e-32|r>>>64-e,Df=(r,t,e)=>r<<e-32|t>>>64-e;function Kf(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var Of=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Mf=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Hf=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),qf=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,Vf=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),Ff=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var zf={fromBig:ra,split:Af,toBig:vf,shrSH:Bf,shrSL:If,rotrSH:Lf,rotrSL:Tf,rotrBH:_f,rotrBL:Rf,rotr32H:Cf,rotr32L:Uf,rotlSH:Pf,rotlSL:Nf,rotlBH:kf,rotlBL:Df,add:Kf,add3L:Of,add3H:Mf,add4L:Hf,add4H:qf,add5H:Ff,add5L:Vf},V=zf;var[Gf,Wf]=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))),le=new Uint32Array(80),he=new Uint32Array(80),xo=class extends Ge{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:f,El:u,Fh:l,Fl:d,Gh:g,Gl:w,Hh:m,Hl:h}=this;return[t,e,n,o,s,i,a,c,f,u,l,d,g,w,m,h]}set(t,e,n,o,s,i,a,c,f,u,l,d,g,w,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=f|0,this.El=u|0,this.Fh=l|0,this.Fl=d|0,this.Gh=g|0,this.Gl=w|0,this.Hh=m|0,this.Hl=h|0}process(t,e){for(let p=0;p<16;p++,e+=4)le[p]=t.getUint32(e),he[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let I=le[p-15]|0,C=he[p-15]|0,R=V.rotrSH(I,C,1)^V.rotrSH(I,C,8)^V.shrSH(I,C,7),T=V.rotrSL(I,C,1)^V.rotrSL(I,C,8)^V.shrSL(I,C,7),_=le[p-2]|0,B=he[p-2]|0,O=V.rotrSH(_,B,19)^V.rotrBH(_,B,61)^V.shrSH(_,B,6),N=V.rotrSL(_,B,19)^V.rotrBL(_,B,61)^V.shrSL(_,B,6),K=V.add4L(T,N,he[p-7],he[p-16]),H=V.add4H(K,R,O,le[p-7],le[p-16]);le[p]=H|0,he[p]=K|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:d,Fh:g,Fl:w,Gh:m,Gl:h,Hh:x,Hl:E}=this;for(let p=0;p<80;p++){let I=V.rotrSH(l,d,14)^V.rotrSH(l,d,18)^V.rotrBH(l,d,41),C=V.rotrSL(l,d,14)^V.rotrSL(l,d,18)^V.rotrBL(l,d,41),R=l&g^~l&m,T=d&w^~d&h,_=V.add5L(E,C,T,Wf[p],he[p]),B=V.add5H(_,x,I,R,Gf[p],le[p]),O=_|0,N=V.rotrSH(n,o,28)^V.rotrBH(n,o,34)^V.rotrBH(n,o,39),K=V.rotrSL(n,o,28)^V.rotrBL(n,o,34)^V.rotrBL(n,o,39),H=n&s^n&a^s&a,v=o&i^o&c^i&c;x=m|0,E=h|0,m=g|0,h=w|0,g=l|0,w=d|0,{h:l,l:d}=V.add(f|0,u|0,B|0,O|0),f=a|0,u=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let L=V.add3L(O,K,v);n=V.add3H(L,B,N,H),o=L|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:f,l:u}=V.add(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:d}=V.add(this.Eh|0,this.El|0,l|0,d|0),{h:g,l:w}=V.add(this.Fh|0,this.Fl|0,g|0,w|0),{h:m,l:h}=V.add(this.Gh|0,this.Gl|0,m|0,h|0),{h:x,l:E}=V.add(this.Hh|0,this.Hl|0,x|0,E|0),this.set(n,o,s,i,a,c,f,u,l,d,g,w,m,h,x,E)}roundClean(){le.fill(0),he.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 na=Jr(()=>new xo);var rn={};vt(rn,{aInRange:()=>bt,abool:()=>Ot,abytes:()=>We,bitGet:()=>Jf,bitLen:()=>Ao,bitMask:()=>pr,bitSet:()=>Qf,bytesToHex:()=>Qt,bytesToNumberBE:()=>te,bytesToNumberLE:()=>Mt,concatBytes:()=>re,createHmacDrbg:()=>vo,ensureBytes:()=>rt,equalBytes:()=>Xf,hexToBytes:()=>ve,hexToNumber:()=>So,inRange:()=>dr,isBytes:()=>de,memoized:()=>Be,notImplemented:()=>el,numberToBytesBE:()=>pe,numberToBytesLE:()=>ee,numberToHexUnpadded:()=>Ae,numberToVarBytesBE:()=>jf,utf8ToBytes:()=>Yf,validateObject:()=>kt});var tn=BigInt(0),en=BigInt(1),$f=BigInt(2);function de(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function We(r){if(!de(r))throw new Error("Uint8Array expected")}function Ot(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var Zf=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function Qt(r){We(r);let t="";for(let e=0;e<r.length;e++)t+=Zf[r[e]];return t}function Ae(r){let t=r.toString(16);return t.length&1?"0"+t:t}function So(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?tn:BigInt("0x"+r)}var Jt={_0:48,_9:57,A:65,F:70,a:97,f:102};function oa(r){if(r>=Jt._0&&r<=Jt._9)return r-Jt._0;if(r>=Jt.A&&r<=Jt.F)return r-(Jt.A-10);if(r>=Jt.a&&r<=Jt.f)return r-(Jt.a-10)}function ve(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=oa(r.charCodeAt(s)),a=oa(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 te(r){return So(Qt(r))}function Mt(r){return We(r),So(Qt(Uint8Array.from(r).reverse()))}function pe(r,t){return ve(r.toString(16).padStart(t*2,"0"))}function ee(r,t){return pe(r,t).reverse()}function jf(r){return ve(Ae(r))}function rt(r,t,e){let n;if(typeof t=="string")try{n=ve(t)}catch(s){throw new Error(r+" must be hex string or Uint8Array, cause: "+s)}else if(de(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 re(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];We(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 Xf(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 Yf(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var bo=r=>typeof r=="bigint"&&tn<=r;function dr(r,t,e){return bo(r)&&bo(t)&&bo(e)&&t<=r&&r<e}function bt(r,t,e,n){if(!dr(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Ao(r){let t;for(t=0;r>tn;r>>=en,t+=1);return t}function Jf(r,t){return r>>BigInt(t)&en}function Qf(r,t,e){return r|(e?en:tn)<<BigInt(t)}var pr=r=>($f<<BigInt(r-1))-en,Eo=r=>new Uint8Array(r),sa=r=>Uint8Array.from(r);function vo(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=Eo(r),o=Eo(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>e(o,n,...l),c=(l=Eo())=>{o=a(sa([0]),l),n=a(),l.length!==0&&(o=a(sa([1]),l),n=a())},f=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,d=[];for(;l<t;){n=a();let g=n.slice();d.push(g),l+=n.length}return re(...d)};return(l,d)=>{i(),c(l);let g;for(;!(g=d(f()));)c();return i(),g}}var tl={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"||de(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=tl[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 el=()=>{throw new Error("not implemented")};function Be(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 dt=BigInt(0),at=BigInt(1),Ie=BigInt(2),rl=BigInt(3),Bo=BigInt(4),ia=BigInt(5),aa=BigInt(8),nl=BigInt(9),ol=BigInt(16);function j(r,t){let e=r%t;return e>=dt?e:t+e}function Io(r,t,e){if(t<dt)throw new Error("invalid exponent, negatives unsupported");if(e<=dt)throw new Error("invalid modulus");if(e===at)return dt;let n=at;for(;t>dt;)t&at&&(n=n*r%e),r=r*r%e,t>>=at;return n}function st(r,t,e){let n=r;for(;t-- >dt;)n*=n,n%=e;return n}function nn(r,t){if(r===dt)throw new Error("invert: expected non-zero number");if(t<=dt)throw new Error("invert: expected positive modulus, got "+t);let e=j(r,t),n=t,o=dt,s=at,i=at,a=dt;for(;e!==dt;){let f=n/e,u=n%e,l=o-i*f,d=s-a*f;n=e,e=u,o=i,s=a,i=l,a=d}if(n!==at)throw new Error("invert: does not exist");return j(o,t)}function sl(r){let t=(r-at)/Ie,e,n,o;for(e=r-at,n=0;e%Ie===dt;e/=Ie,n++);for(o=Ie;o<r&&Io(o,t,r)!==r-at;o++)if(o>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let i=(r+at)/Bo;return function(c,f){let u=c.pow(f,i);if(!c.eql(c.sqr(u),f))throw new Error("Cannot find square root");return u}}let s=(e+at)/Ie;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,u=a.pow(a.mul(a.ONE,o),e),l=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<f&&!a.eql(m,a.ONE);g++)m=a.sqr(m);let w=a.pow(u,at<<BigInt(f-g-1));u=a.sqr(w),l=a.mul(l,w),d=a.mul(d,u),f=g}return l}}function il(r){if(r%Bo===rl){let t=(r+at)/Bo;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%aa===ia){let t=(r-ia)/aa;return function(n,o){let s=n.mul(o,Ie),i=n.pow(s,t),a=n.mul(o,i),c=n.mul(n.mul(a,Ie),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),o))throw new Error("Cannot find square root");return f}}return r%ol,sl(r)}var ca=(r,t)=>(j(r,t)&at)===at,al=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Lo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=al.reduce((n,o)=>(n[o]="function",n),t);return kt(r,e)}function cl(r,t,e){if(e<dt)throw new Error("invalid exponent, negatives unsupported");if(e===dt)return r.ONE;if(e===at)return t;let n=r.ONE,o=t;for(;e>dt;)e&at&&(n=r.mul(n,o)),o=r.sqr(o),e>>=at;return n}function ul(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 To(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function me(r,t,e=!1,n={}){if(r<=dt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:o,nByteLength:s}=To(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:dt,ONE:at,create:c=>j(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return dt<=c&&c<r},is0:c=>c===dt,isOdd:c=>(c&at)===at,neg:c=>j(-c,r),eql:(c,f)=>c===f,sqr:c=>j(c*c,r),add:(c,f)=>j(c+f,r),sub:(c,f)=>j(c-f,r),mul:(c,f)=>j(c*f,r),pow:(c,f)=>cl(a,c,f),div:(c,f)=>j(c*nn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>nn(c,r),sqrt:n.sqrt||(c=>(i||(i=il(r)),i(a,c))),invertBatch:c=>ul(a,c),cmov:(c,f,u)=>u?f:c,toBytes:c=>e?ee(c,s):pe(c,s),fromBytes:c=>{if(c.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+c.length);return e?Mt(c):te(c)}});return Object.freeze(a)}function ua(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 _o(r){let t=ua(r);return t+Math.ceil(t/2)}function fa(r,t,e=!1){let n=r.length,o=ua(t),s=_o(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?Mt(r):te(r),a=j(i,t-at)+at;return e?ee(a,o):pe(a,o)}var la=BigInt(0),on=BigInt(1);function Ro(r,t){let e=t.negate();return r?e:t}function ha(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function Co(r,t){ha(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function fl(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 ll(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 Uo=new WeakMap,da=new WeakMap;function Po(r){return da.get(r)||1}function sn(r,t){return{constTimeNegate:Ro,hasPrecomputes(e){return Po(e)!==1},unsafeLadder(e,n,o=r.ZERO){let s=e;for(;n>la;)n&on&&(o=o.add(s)),s=s.double(),n>>=on;return o},precomputeWindow(e,n){let{windows:o,windowSize:s}=Co(n,t),i=[],a=e,c=a;for(let f=0;f<o;f++){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}=Co(e,t),a=r.ZERO,c=r.BASE,f=BigInt(2**e-1),u=2**e,l=BigInt(e);for(let d=0;d<s;d++){let g=d*i,w=Number(o&f);o>>=l,w>i&&(w-=u,o+=on);let m=g,h=g+Math.abs(w)-1,x=d%2!==0,E=w<0;w===0?c=c.add(Ro(x,n[m])):a=a.add(Ro(E,n[h]))}return{p:a,f:c}},wNAFUnsafe(e,n,o,s=r.ZERO){let{windows:i,windowSize:a}=Co(e,t),c=BigInt(2**e-1),f=2**e,u=BigInt(e);for(let l=0;l<i;l++){let d=l*a;if(o===la)break;let g=Number(o&c);if(o>>=u,g>a&&(g-=f,o+=on),g===0)continue;let w=n[d+Math.abs(g)-1];g<0&&(w=w.negate()),s=s.add(w)}return s},getPrecomputes(e,n,o){let s=Uo.get(n);return s||(s=this.precomputeWindow(n,e),e!==1&&Uo.set(n,o(s))),s},wNAFCached(e,n,o){let s=Po(e);return this.wNAF(s,this.getPrecomputes(s,e,o),n)},wNAFCachedUnsafe(e,n,o,s){let i=Po(e);return i===1?this.unsafeLadder(e,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,e,o),n,s)},setWindowSize(e,n){ha(n,t),da.set(e,n),Uo.delete(e)}}}function an(r,t,e,n){if(fl(e,r),ll(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let o=r.ZERO,s=Ao(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),f=Math.floor((t.BITS-1)/i)*i,u=o;for(let l=f;l>=0;l-=i){c.fill(o);for(let g=0;g<n.length;g++){let w=n[g],m=Number(w>>BigInt(l)&BigInt(a));c[m]=c[m].add(e[g])}let d=o;for(let g=c.length-1,w=o;g>0;g--)w=w.add(c[g]),d=d.add(w);if(u=u.add(d),l!==0)for(let g=0;g<i;g++)u=u.double()}return u}function mr(r){return Lo(r.Fp),kt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...To(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Ht=BigInt(0),Ut=BigInt(1),cn=BigInt(2),hl=BigInt(8),dl={zip215:!0};function pl(r){let t=mr(r);return kt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function pa(r){let t=pl(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,f=cn<<BigInt(a*8)-Ut,u=e.create,l=me(t.n,t.nBitLength),d=t.uvRatio||((b,y)=>{try{return{isValid:!0,value:e.sqrt(b*e.inv(y))}}catch{return{isValid:!1,value:Ht}}}),g=t.adjustScalarBytes||(b=>b),w=t.domain||((b,y,A)=>{if(Ot("phflag",A),y.length||A)throw new Error("Contexts/pre-hash are not supported");return b});function m(b,y){bt("coordinate "+b,y,Ht,f)}function h(b){if(!(b instanceof p))throw new Error("ExtendedPoint expected")}let x=Be((b,y)=>{let{ex:A,ey:S,ez:U}=b,P=b.is0();y==null&&(y=P?hl:e.inv(U));let D=u(A*y),q=u(S*y),M=u(U*y);if(P)return{x:Ht,y:Ut};if(M!==Ut)throw new Error("invZ was invalid");return{x:D,y:q}}),E=Be(b=>{let{a:y,d:A}=t;if(b.is0())throw new Error("bad point: ZERO");let{ex:S,ey:U,ez:P,et:D}=b,q=u(S*S),M=u(U*U),z=u(P*P),$=u(z*z),nt=u(q*y),ot=u(z*u(nt+M)),it=u($+u(A*u(q*M)));if(ot!==it)throw new Error("bad point: equation left != right (1)");let At=u(S*U),Ct=u(P*D);if(At!==Ct)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(y,A,S,U){this.ex=y,this.ey=A,this.ez=S,this.et=U,m("x",y),m("y",A),m("z",S),m("t",U),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,U)=>S.toAffine(A[U])).map(p.fromAffine)}static msm(y,A){return an(p,l,y,A)}_setWindowSize(y){R.setWindowSize(this,y)}assertValidity(){E(this)}equals(y){h(y);let{ex:A,ey:S,ez:U}=this,{ex:P,ey:D,ez:q}=y,M=u(A*q),z=u(P*U),$=u(S*q),nt=u(D*U);return M===z&&$===nt}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:U}=this,P=u(A*A),D=u(S*S),q=u(cn*u(U*U)),M=u(y*P),z=A+S,$=u(u(z*z)-P-D),nt=M+D,ot=nt-q,it=M-D,At=u($*ot),Ct=u(nt*it),Rt=u($*it),Ft=u(ot*nt);return new p(At,Ct,Ft,Rt)}add(y){h(y);let{a:A,d:S}=t,{ex:U,ey:P,ez:D,et:q}=this,{ex:M,ey:z,ez:$,et:nt}=y;if(A===BigInt(-1)){let _i=u((P-U)*(z+M)),Ri=u((P+U)*(z-M)),ro=u(Ri-_i);if(ro===Ht)return this.double();let Ci=u(D*cn*nt),Ui=u(q*cn*$),Pi=Ui+Ci,Ni=Ri+_i,ki=Ui-Ci,vu=u(Pi*ro),Bu=u(Ni*ki),Iu=u(Pi*ki),Lu=u(ro*Ni);return new p(vu,Bu,Lu,Iu)}let ot=u(U*M),it=u(P*z),At=u(q*S*nt),Ct=u(D*$),Rt=u((U+P)*(M+z)-ot-it),Ft=Ct-At,Zt=Ct+At,ir=u(it-A*ot),bu=u(Rt*Ft),Eu=u(Zt*ir),Su=u(Rt*ir),Au=u(Ft*Zt);return new p(bu,Eu,Au,Su)}subtract(y){return this.add(y.negate())}wNAF(y){return R.wNAFCached(this,y,p.normalizeZ)}multiply(y){let A=y;bt("scalar",A,Ut,n);let{p:S,f:U}=this.wNAF(A);return p.normalizeZ([S,U])[0]}multiplyUnsafe(y,A=p.ZERO){let S=y;return bt("scalar",S,Ht,n),S===Ht?C:this.is0()||S===Ut?this:R.wNAFCachedUnsafe(this,S,p.normalizeZ,A)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return R.unsafeLadder(this,n).is0()}toAffine(y){return x(this,y)}clearCofactor(){let{h:y}=t;return y===Ut?this:this.multiplyUnsafe(y)}static fromHex(y,A=!1){let{d:S,a:U}=t,P=e.BYTES;y=rt("pointHex",y,P),Ot("zip215",A);let D=y.slice(),q=y[P-1];D[P-1]=q&-129;let M=Mt(D),z=A?f:e.ORDER;bt("pointHex.y",M,Ht,z);let $=u(M*M),nt=u($-Ut),ot=u(S*$-U),{isValid:it,value:At}=d(nt,ot);if(!it)throw new Error("Point.fromHex: invalid y coordinate");let Ct=(At&Ut)===Ut,Rt=(q&128)!==0;if(!A&&At===Ht&&Rt)throw new Error("Point.fromHex: x=0 and x_0=1");return Rt!==Ct&&(At=u(-At)),p.fromAffine({x:At,y:M})}static fromPrivateKey(y){return B(y).point}toRawBytes(){let{x:y,y:A}=this.toAffine(),S=ee(A,e.BYTES);return S[S.length-1]|=y&Ut?128:0,S}toHex(){return Qt(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,Ut,u(t.Gx*t.Gy)),p.ZERO=new p(Ht,Ut,Ut,Ht);let{BASE:I,ZERO:C}=p,R=sn(p,a*8);function T(b){return j(b,n)}function _(b){return T(Mt(b))}function B(b){let y=e.BYTES;b=rt("private key",b,y);let A=rt("hashed private key",s(b),2*y),S=g(A.slice(0,y)),U=A.slice(y,2*y),P=_(S),D=I.multiply(P),q=D.toRawBytes();return{head:S,prefix:U,scalar:P,point:D,pointBytes:q}}function O(b){return B(b).pointBytes}function N(b=new Uint8Array,...y){let A=re(...y);return _(s(w(A,rt("context",b),!!o)))}function K(b,y,A={}){b=rt("message",b),o&&(b=o(b));let{prefix:S,scalar:U,pointBytes:P}=B(y),D=N(A.context,S,b),q=I.multiply(D).toRawBytes(),M=N(A.context,q,P,b),z=T(D+M*U);bt("signature.s",z,Ht,n);let $=re(q,ee(z,e.BYTES));return rt("result",$,e.BYTES*2)}let H=dl;function v(b,y,A,S=H){let{context:U,zip215:P}=S,D=e.BYTES;b=rt("signature",b,2*D),y=rt("message",y),A=rt("publicKey",A,D),P!==void 0&&Ot("zip215",P),o&&(y=o(y));let q=Mt(b.slice(D,2*D)),M,z,$;try{M=p.fromHex(A,P),z=p.fromHex(b.slice(0,D),P),$=I.multiplyUnsafe(q)}catch{return!1}if(!P&&M.isSmallOrder())return!1;let nt=N(U,z.toRawBytes(),M.toRawBytes(),y);return z.add(M.multiplyUnsafe(nt)).subtract($).clearCofactor().equals(p.ZERO)}return I._setWindowSize(8),{CURVE:t,getPublicKey:O,sign:K,verify:v,ExtendedPoint:p,utils:{getExtendedPublicKey:B,randomPrivateKey:()=>i(e.BYTES),precompute(b=8,y=p.BASE){return y._setWindowSize(b),y.multiply(BigInt(3)),y}}}}var $e=BigInt(0),No=BigInt(1);function ml(r){return kt(r,{a:"bigint"},{montgomeryBits:"isSafeInteger",nByteLength:"isSafeInteger",adjustScalarBytes:"function",domain:"function",powPminus2:"function",Gu:"bigint"}),Object.freeze({...r})}function ma(r){let t=ml(r),{P:e}=t,n=E=>j(E,e),o=t.montgomeryBits,s=Math.ceil(o/8),i=t.nByteLength,a=t.adjustScalarBytes||(E=>E),c=t.powPminus2||(E=>Io(E,e-BigInt(2),e));function f(E,p,I){let C=n(E*(p-I));return p=n(p-C),I=n(I+C),[p,I]}let u=(t.a-BigInt(2))/BigInt(4);function l(E,p){bt("u",E,$e,e),bt("scalar",p,$e,e);let I=p,C=E,R=No,T=$e,_=E,B=No,O=$e,N;for(let H=BigInt(o-1);H>=$e;H--){let v=I>>H&No;O^=v,N=f(O,R,_),R=N[0],_=N[1],N=f(O,T,B),T=N[0],B=N[1],O=v;let L=R+T,b=n(L*L),y=R-T,A=n(y*y),S=b-A,U=_+B,P=_-B,D=n(P*L),q=n(U*y),M=D+q,z=D-q;_=n(M*M),B=n(C*n(z*z)),R=n(b*A),T=n(S*(b+n(u*S)))}N=f(O,R,_),R=N[0],_=N[1],N=f(O,T,B),T=N[0],B=N[1];let K=c(T);return n(R*K)}function d(E){return ee(n(E),s)}function g(E){let p=rt("u coordinate",E,s);return i===32&&(p[31]&=127),Mt(p)}function w(E){let p=rt("scalar",E),I=p.length;if(I!==s&&I!==i){let C=""+s+" or "+i;throw new Error("invalid scalar, expected "+C+" bytes, got "+I)}return Mt(a(p))}function m(E,p){let I=g(p),C=w(E),R=l(I,C);if(R===$e)throw new Error("invalid private or public key received");return d(R)}let h=d(t.Gu);function x(E){return m(E,h)}return{scalarMult:m,scalarMultBase:x,getSharedSecret:(E,p)=>m(E,p),getPublicKey:E=>x(E),utils:{randomPrivateKey:()=>t.randomBytes(t.nByteLength)},GuBytes:h}}var yr=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),ya=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),o0=BigInt(0),yl=BigInt(1),ga=BigInt(2),gl=BigInt(3),wl=BigInt(5),xl=BigInt(8);function wa(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=yr,a=r*r%s*r%s,c=st(a,ga,s)*a%s,f=st(c,yl,s)*r%s,u=st(f,wl,s)*f%s,l=st(u,t,s)*u%s,d=st(l,e,s)*l%s,g=st(d,n,s)*d%s,w=st(g,o,s)*g%s,m=st(w,o,s)*g%s,h=st(m,t,s)*u%s;return{pow_p_5_8:st(h,ga,s)*r%s,b2:a}}function xa(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function bl(r,t){let e=yr,n=j(t*t*t,e),o=j(n*n*t,e),s=wa(r*o).pow_p_5_8,i=j(r*n*s,e),a=j(t*i*i,e),c=i,f=j(i*ya,e),u=a===r,l=a===j(-r,e),d=a===j(-r*ya,e);return u&&(i=c),(l||d)&&(i=f),ca(i,e)&&(i=j(-i,e)),{isValid:u||l,value:i}}var El=me(yr,void 0,!0),Sl={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:El,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:xl,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:na,randomBytes:hr,adjustScalarBytes:xa,uvRatio:bl},ba=pa(Sl);var gr=ma({P:yr,a:BigInt(486662),montgomeryBits:255,nByteLength:32,Gu:BigInt(9),powPminus2:r=>{let t=yr,{pow_p_5_8:e,b2:n}=wa(r);return j(st(e,gl,t)*n,t)},adjustScalarBytes:xa,randomBytes:hr});var un=32;function Ea(r,t,e){return ba.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var fn=class{type="Ed25519";raw;constructor(t){this.raw=ko(t,un)}toMultihash(){return Yt.digest(Ze(this))}toCID(){return ht.createV1(114,this.toMultihash())}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return Ea(this.raw,e,t)}};function Do(r){return r=ko(r,un),new fn(r)}function ko(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new gt(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}function pt(r=0){return new Uint8Array(r)}function mt(r=0){return new Uint8Array(r)}var vl=Math.pow(2,7),Bl=Math.pow(2,14),Il=Math.pow(2,21),Ko=Math.pow(2,28),Oo=Math.pow(2,35),Mo=Math.pow(2,42),Ho=Math.pow(2,49),Y=128,Bt=127;function lt(r){if(r<vl)return 1;if(r<Bl)return 2;if(r<Il)return 3;if(r<Ko)return 4;if(r<Oo)return 5;if(r<Mo)return 6;if(r<Ho)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function qo(r,t,e=0){switch(lt(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 Ll(r,t,e=0){switch(lt(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 Vo(r,t){let e=r[t],n=0;if(n+=e&Bt,e<Y||(e=r[t+1],n+=(e&Bt)<<7,e<Y)||(e=r[t+2],n+=(e&Bt)<<14,e<Y)||(e=r[t+3],n+=(e&Bt)<<21,e<Y)||(e=r[t+4],n+=(e&Bt)*Ko,e<Y)||(e=r[t+5],n+=(e&Bt)*Oo,e<Y)||(e=r[t+6],n+=(e&Bt)*Mo,e<Y)||(e=r[t+7],n+=(e&Bt)*Ho,e<Y))return n;throw new RangeError("Could not decode varint")}function Tl(r,t){let e=r.get(t),n=0;if(n+=e&Bt,e<Y||(e=r.get(t+1),n+=(e&Bt)<<7,e<Y)||(e=r.get(t+2),n+=(e&Bt)<<14,e<Y)||(e=r.get(t+3),n+=(e&Bt)<<21,e<Y)||(e=r.get(t+4),n+=(e&Bt)*Ko,e<Y)||(e=r.get(t+5),n+=(e&Bt)*Oo,e<Y)||(e=r.get(t+6),n+=(e&Bt)*Mo,e<Y)||(e=r.get(t+7),n+=(e&Bt)*Ho,e<Y))return n;throw new RangeError("Could not decode varint")}function Gt(r,t,e=0){return t==null&&(t=mt(lt(r))),t instanceof Uint8Array?qo(r,t,e):Ll(r,t,e)}function qt(r,t=0){return r instanceof Uint8Array?Vo(r,t):Tl(r,t)}var Fo=new Float32Array([-0]),ye=new Uint8Array(Fo.buffer);function Aa(r,t,e){Fo[0]=r,t[e]=ye[0],t[e+1]=ye[1],t[e+2]=ye[2],t[e+3]=ye[3]}function va(r,t){return ye[0]=r[t],ye[1]=r[t+1],ye[2]=r[t+2],ye[3]=r[t+3],Fo[0]}var zo=new Float64Array([-0]),It=new Uint8Array(zo.buffer);function Ba(r,t,e){zo[0]=r,t[e]=It[0],t[e+1]=It[1],t[e+2]=It[2],t[e+3]=It[3],t[e+4]=It[4],t[e+5]=It[5],t[e+6]=It[6],t[e+7]=It[7]}function Ia(r,t){return It[0]=r[t],It[1]=r[t+1],It[2]=r[t+2],It[3]=r[t+3],It[4]=r[t+4],It[5]=r[t+5],It[6]=r[t+6],It[7]=r[t+7],zo[0]}var _l=BigInt(Number.MAX_SAFE_INTEGER),Rl=BigInt(Number.MIN_SAFE_INTEGER),Pt=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 Le;if(t<_l&&t>Rl)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>La&&(o=0n,++n>La&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Le;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):Le}},Le=new Pt(0,0);Le.toBigInt=function(){return 0n};Le.zzEncode=Le.zzDecode=function(){return this};Le.length=function(){return 1};var La=4294967296n;function Ta(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 _a(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 Go(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 Vt(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function ln(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Wo=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,Vt(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 Vt(this,4);return ln(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Vt(this,4);return ln(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Vt(this,4);let t=va(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Vt(this,4);let t=Ia(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 Vt(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return _a(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Vt(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Vt(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 Pt(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 Vt(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 Vt(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 Vt(this,8);let t=ln(this.buf,this.pos+=4),e=ln(this.buf,this.pos+=4);return new Pt(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=Vo(this.buf,this.pos);return this.pos+=lt(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 $o(r){return new Wo(r instanceof Uint8Array?r:r.subarray())}function Te(r,t,e){let n=$o(r);return t.decode(n,void 0,e)}var Zo={};vt(Zo,{base10:()=>Cl});var Cl=ce({prefix:"9",name:"base10",alphabet:"0123456789"});var jo={};vt(jo,{base16:()=>Ul,base16upper:()=>Pl});var Ul=ut({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Pl=ut({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Xo={};vt(Xo,{base2:()=>Nl});var Nl=ut({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Yo={};vt(Yo,{base256emoji:()=>Ml});var Ca=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}"),kl=Ca.reduce((r,t,e)=>(r[e]=t,r),[]),Dl=Ca.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function Kl(r){return r.reduce((t,e)=>(t+=kl[e],t),"")}function Ol(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=Dl[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var Ml=Me({prefix:"\u{1F680}",name:"base256emoji",encode:Kl,decode:Ol});var Qo={};vt(Qo,{base64:()=>Hl,base64pad:()=>ql,base64url:()=>Jo,base64urlpad:()=>Vl});var Hl=ut({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),ql=ut({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Jo=ut({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Vl=ut({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var ts={};vt(ts,{base8:()=>Fl});var Fl=ut({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var es={};vt(es,{identity:()=>zl});var zl=Me({prefix:"\0",name:"identity",encode:r=>Hi(r),decode:r=>Mi(r)});var H0=new TextEncoder,q0=new TextDecoder;var os={};vt(os,{sha256:()=>xr,sha512:()=>$l});function ns({name:r,code:t,encode:e}){return new rs(r,t,e)}var rs=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?Nt(this.code,e):e.then(n=>Nt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function Pa(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var xr=ns({name:"sha2-256",code:18,encode:Pa("SHA-256")}),$l=ns({name:"sha2-512",code:19,encode:Pa("SHA-512")});var _e={...es,...Xo,...ts,...Zo,...jo,...fo,...lo,...uo,...Qo,...Yo},Q0={...os,...yo};function ka(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var Na=ka("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),ss=ka("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=mt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Zl={utf8:Na,"utf-8":Na,hex:_e.base16,latin1:ss,ascii:ss,binary:ss,..._e},hn=Zl;function tt(r,t="utf8"){let e=hn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function is(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return mt(i);o+i>t&&(n=mt(t),o=0);let a=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),a}}var Re=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function as(){}var us=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},jl=is();function Xl(r){return globalThis.Buffer!=null?mt(r):jl(r)}var Er=class{len;head;tail;states;constructor(){this.len=0,this.head=new Re(as,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Re(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new fs((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(dn,10,Pt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let e=Pt.fromBigInt(t);return this._push(dn,e.length(),e)}uint64Number(t){return this._push(qo,lt(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=Pt.fromBigInt(t).zzEncode();return this._push(dn,e.length(),e)}sint64Number(t){let e=Pt.fromNumber(t).zzEncode();return this._push(dn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(cs,1,t?1:0)}fixed32(t){return this._push(br,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Pt.fromBigInt(t);return this._push(br,4,e.lo)._push(br,4,e.hi)}fixed64Number(t){let e=Pt.fromNumber(t);return this._push(br,4,e.lo)._push(br,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(Aa,4,t)}double(t){return this._push(Ba,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(cs,1,0):this.uint32(e)._push(Jl,e,t)}string(t){let e=Ta(t);return e!==0?this.uint32(e)._push(Go,e,t):this._push(cs,1,0)}fork(){return this.states=new us(this),this.head=this.tail=new Re(as,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 Re(as,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=Xl(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function cs(r,t,e){t[e]=r&255}function Yl(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var fs=class extends Re{next;constructor(t,e){super(Yl,t,e),this.next=void 0}};function dn(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 br(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 Jl(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Er.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(Ql,t,r),this},Er.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(th,t,r),this});function Ql(r,t,e){t.set(r,e)}function th(r,t,e){r.length<40?Go(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(tt(r),e)}function ls(){return new Er}function Ce(r,t){let e=ls();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var je;(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"})(je||(je={}));function pn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function hs(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 pn("enum",je.VARINT,e,n)}function Ue(r,t){return pn("message",je.LENGTH_DELIMITED,r,t)}var yt;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1"})(yt||(yt={}));var ds;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1"})(ds||(ds={}));(function(r){r.codec=()=>hs(ds)})(yt||(yt={}));var Wt;(function(r){let t;r.codec=()=>(t==null&&(t=Ue((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=>Ce(e,r.codec()),r.decode=(e,n)=>Te(e,r.codec(),n)})(Wt||(Wt={}));var ps;(function(r){let t;r.codec=()=>(t==null&&(t=Ue((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=>Ce(e,r.codec()),r.decode=(e,n)=>Te(e,r.codec(),n)})(ps||(ps={}));var vr={};vt(vr,{MAX_RSA_KEY_SIZE:()=>xs,generateRSAKeyPair:()=>Xa,jwkToJWKKeyPair:()=>Ya,jwkToPkcs1:()=>dh,jwkToPkix:()=>Es,jwkToRSAPrivateKey:()=>ja,pkcs1ToJwk:()=>Wa,pkcs1ToRSAPrivateKey:()=>Za,pkixToJwk:()=>$a,pkixToRSAPublicKey:()=>Ss});var eh=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]),ge=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),we=new Uint32Array(64),ms=class extends Ge{constructor(){super(64,32,8,!1),this.A=ge[0]|0,this.B=ge[1]|0,this.C=ge[2]|0,this.D=ge[3]|0,this.E=ge[4]|0,this.F=ge[5]|0,this.G=ge[6]|0,this.H=ge[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 l=0;l<16;l++,e+=4)we[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let d=we[l-15],g=we[l-2],w=Kt(d,7)^Kt(d,18)^d>>>3,m=Kt(g,17)^Kt(g,19)^g>>>10;we[l]=m+we[l-7]+w+we[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let d=Kt(a,6)^Kt(a,11)^Kt(a,25),g=u+d+ta(a,c,f)+eh[l]+we[l]|0,m=(Kt(n,2)^Kt(n,13)^Kt(n,22))+ea(n,o,s)|0;u=f,f=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,f=f+this.G|0,u=u+this.H|0,this.set(n,o,s,i,a,c,f,u)}roundClean(){we.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var $t=Jr(()=>new ms);function F(r,t="utf8"){let e=hn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}function Lt(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=mt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var Oa=Symbol.for("@achingbrain/uint8arraylist");function Ka(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 mn(r){return!!r?.[Oa]}var Z=class r{bufs;length;[Oa]=!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(mn(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(mn(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=Ka(this.bufs,t);return e.buf[e.index]}set(t,e){let n=Ka(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(mn(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 Lt(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:Lt(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 f=t>=a&&t<c,u=e>a&&e<=c;if(f&&u){if(t===a&&e===c){n.push(i);break}let l=t-a;n.push(i.subarray(l,l+(e-t)));break}if(f){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(!mn(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 l=0;l<s;l++)i[l]=-1;for(let l=0;l<o;l++)i[n[l]]=l;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,u;for(let l=e;l<=c;l+=u){u=0;for(let d=f;d>=0;d--){let g=this.get(l+d);if(n[d]!==g){u=Math.max(1,d-a[g]);break}}if(u===0)return l}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=mt(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=pt(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=pt(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=pt(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=mt(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=pt(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=pt(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=pt(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=pt(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=pt(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(!xt(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 nh=parseInt("11111",2),gs=parseInt("10000000",2),oh=parseInt("01111111",2),Ma={2:sh,3:ch,5:ah,6:ih,16:ys,22:ys,48:ys};function Sr(r,t={offset:0}){let e=r[t.offset]&nh;if(t.offset++,Ma[e]!=null)return Ma[e](r,t);throw new Error("No decoder for tag "+e)}function yn(r,t){let e=0;if((r[t.offset]&gs)===gs){let n=r[t.offset]&oh,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 ys(r,t){yn(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Sr(r,t);if(n===null)break;e.push(n)}return e}function sh(r,t){let e=yn(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 ih(r,t){let e=yn(r,t);return t.offset+=e,["oid-unimplemented"]}function ah(r,t){return t.offset++,null}function ch(r,t){let e=yn(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 Sr(o,{offset:0})}function uh(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 ws(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=uh(r.byteLength);return new Z(Uint8Array.from([t.byteLength|gs]),t)}function Dt(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]),ws(t),t)}function Ha(r){let t=Uint8Array.from([0]),e=new Z(t,r);return new Z(Uint8Array.from([3]),ws(e),e)}function gn(r){let t=new Z;for(let e of r)t.append(e);return new Z(Uint8Array.from([48]),ws(t),t)}var Ar=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},wn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var qa={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new wn("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 xe=qa;async function Va(r){let t=await xe.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 fh(t);return{privateKey:e[0],publicKey:e[1]}}async function Fa(r,t){let e=await xe.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await xe.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function za(r,t,e){let n=await xe.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return xe.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function fh(r){if(r.privateKey==null||r.publicKey==null)throw new gt("Private and public key are required");return Promise.all([xe.get().subtle.exportKey("jwk",r.privateKey),xe.get().subtle.exportKey("jwk",r.publicKey)])}function Ga(r){if(r.kty!=="RSA")throw new gt("invalid key type");if(r.n==null)throw new gt("invalid key modulus");return tt(r.n,"base64url").length*8}var Xe=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 ht.createV1(114,this._multihash)}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return za(this._key,e,t)}},Br=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:xt(this.raw,t.raw)}sign(t){return Fa(this._key,t)}};var xs=8192,bs=18,lh=1062,hh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function Wa(r){let t=Sr(r);return{n:F(t[1],"base64url"),e:F(t[2],"base64url"),d:F(t[3],"base64url"),p:F(t[4],"base64url"),q:F(t[5],"base64url"),dp:F(t[6],"base64url"),dq:F(t[7],"base64url"),qi:F(t[8],"base64url"),kty:"RSA"}}function dh(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 gt("JWK was missing components");return gn([Dt(Uint8Array.from([0])),Dt(tt(r.n,"base64url")),Dt(tt(r.e,"base64url")),Dt(tt(r.d,"base64url")),Dt(tt(r.p,"base64url")),Dt(tt(r.q,"base64url")),Dt(tt(r.dp,"base64url")),Dt(tt(r.dq,"base64url")),Dt(tt(r.qi,"base64url"))]).subarray()}function $a(r){let t=Sr(r,{offset:0});return{kty:"RSA",n:F(t[1][0],"base64url"),e:F(t[1][1],"base64url")}}function Es(r){if(r.n==null||r.e==null)throw new gt("JWK was missing components");return gn([hh,Ha(gn([Dt(tt(r.n,"base64url")),Dt(tt(r.e,"base64url"))]))]).subarray()}function Za(r){let t=Wa(r);return ja(t)}function Ss(r,t){if(r.byteLength>=lh)throw new Oe("Key size is too large");let e=$a(r);if(t==null){let n=$t(Wt.encode({Type:yt.RSA,Data:r}));t=Nt(bs,n)}return new Xe(e,t)}function ja(r){if(Ga(r)>xs)throw new gt("Key size is too large");let t=Ya(r),e=$t(Wt.encode({Type:yt.RSA,Data:Es(t.publicKey)})),n=Nt(bs,e);return new Br(t.privateKey,new Xe(t.publicKey,n))}async function Xa(r){if(r>xs)throw new gt("Key size is too large");let t=await Va(r),e=$t(Wt.encode({Type:yt.RSA,Data:Es(t.publicKey)})),n=Nt(bs,e);return new Br(t.privateKey,new Xe(t.publicKey,n))}function Ya(r){if(r==null)throw new gt("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}var xn=class extends ze{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,lr(t);let n=fe(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 Fe(this),this.iHash.update(t),this}digestInto(t){Fe(this),Ve(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()}},Ye=(r,t,e)=>new xn(r,t).update(e).digest();Ye.create=(r,t)=>new xn(r,t);function Ja(r){r.lowS!==void 0&&Ot("lowS",r.lowS),r.prehash!==void 0&&Ot("prehash",r.prehash)}function ph(r){let t=mr(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:mh,hexToBytes:yh}=rn,As=class extends Error{constructor(t=""){super(t)}},ne={Err:As,_tlv:{encode:(r,t)=>{let{Err:e}=ne;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=Ae(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?Ae(o.length/2|128):"";return Ae(r)+s+o+t},decode(r,t){let{Err:e}=ne,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 f=t.subarray(n,n+c);if(f.length!==c)throw new e("tlv.decode: length bytes not complete");if(f[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let u of f)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}=ne;if(r<oe)throw new t("integer: negative integers are not allowed");let e=Ae(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}=ne;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 mh(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=ne,o=typeof r=="string"?yh(r):r;We(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:f,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(f)}},hexFromSig(r){let{_tlv:t,_int:e}=ne,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}},oe=BigInt(0),wt=BigInt(1),by=BigInt(2),Qa=BigInt(3),Ey=BigInt(4);function gh(r){let t=ph(r),{Fp:e}=t,n=me(t.n,t.nBitLength),o=t.toBytes||((m,h,x)=>{let E=h.toAffine();return re(Uint8Array.from([4]),e.toBytes(E.x),e.toBytes(E.y))}),s=t.fromBytes||(m=>{let h=m.subarray(1),x=e.fromBytes(h.subarray(0,e.BYTES)),E=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x,y:E}});function i(m){let{a:h,b:x}=t,E=e.sqr(m),p=e.mul(E,m);return e.add(e.add(p,e.mul(m,h)),x)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return dr(m,wt,t.n)}function c(m){let{allowedPrivateKeyLengths:h,nByteLength:x,wrapPrivateKey:E,n:p}=t;if(h&&typeof m!="bigint"){if(de(m)&&(m=Qt(m)),typeof m!="string"||!h.includes(m.length))throw new Error("invalid private key");m=m.padStart(x*2,"0")}let I;try{I=typeof m=="bigint"?m:te(rt("private key",m,x))}catch{throw new Error("invalid private key, expected hex or "+x+" bytes, got "+typeof m)}return E&&(I=j(I,p)),bt("private key",I,wt,p),I}function f(m){if(!(m instanceof d))throw new Error("ProjectivePoint expected")}let u=Be((m,h)=>{let{px:x,py:E,pz:p}=m;if(e.eql(p,e.ONE))return{x,y:E};let I=m.is0();h==null&&(h=I?e.ONE:e.inv(p));let C=e.mul(x,h),R=e.mul(E,h),T=e.mul(p,h);if(I)return{x:e.ZERO,y:e.ZERO};if(!e.eql(T,e.ONE))throw new Error("invZ was invalid");return{x:C,y:R}}),l=Be(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:h,y:x}=m.toAffine();if(!e.isValid(h)||!e.isValid(x))throw new Error("bad point: x or y not FE");let E=e.sqr(x),p=i(h);if(!e.eql(E,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,x,E){if(this.px=h,this.py=x,this.pz=E,h==null||!e.isValid(h))throw new Error("x required");if(x==null||!e.isValid(x))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x,y:E}=h||{};if(!h||!e.isValid(x)||!e.isValid(E))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(x)&&p(E)?d.ZERO:new d(x,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let x=e.invertBatch(h.map(E=>E.pz));return h.map((E,p)=>E.toAffine(x[p])).map(d.fromAffine)}static fromHex(h){let x=d.fromAffine(s(rt("pointHex",h)));return x.assertValidity(),x}static fromPrivateKey(h){return d.BASE.multiply(c(h))}static msm(h,x){return an(d,n,h,x)}_setWindowSize(h){w.setWindowSize(this,h)}assertValidity(){l(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){f(h);let{px:x,py:E,pz:p}=this,{px:I,py:C,pz:R}=h,T=e.eql(e.mul(x,R),e.mul(I,p)),_=e.eql(e.mul(E,R),e.mul(C,p));return T&&_}negate(){return new d(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:x}=t,E=e.mul(x,Qa),{px:p,py:I,pz:C}=this,R=e.ZERO,T=e.ZERO,_=e.ZERO,B=e.mul(p,p),O=e.mul(I,I),N=e.mul(C,C),K=e.mul(p,I);return K=e.add(K,K),_=e.mul(p,C),_=e.add(_,_),R=e.mul(h,_),T=e.mul(E,N),T=e.add(R,T),R=e.sub(O,T),T=e.add(O,T),T=e.mul(R,T),R=e.mul(K,R),_=e.mul(E,_),N=e.mul(h,N),K=e.sub(B,N),K=e.mul(h,K),K=e.add(K,_),_=e.add(B,B),B=e.add(_,B),B=e.add(B,N),B=e.mul(B,K),T=e.add(T,B),N=e.mul(I,C),N=e.add(N,N),B=e.mul(N,K),R=e.sub(R,B),_=e.mul(N,O),_=e.add(_,_),_=e.add(_,_),new d(R,T,_)}add(h){f(h);let{px:x,py:E,pz:p}=this,{px:I,py:C,pz:R}=h,T=e.ZERO,_=e.ZERO,B=e.ZERO,O=t.a,N=e.mul(t.b,Qa),K=e.mul(x,I),H=e.mul(E,C),v=e.mul(p,R),L=e.add(x,E),b=e.add(I,C);L=e.mul(L,b),b=e.add(K,H),L=e.sub(L,b),b=e.add(x,p);let y=e.add(I,R);return b=e.mul(b,y),y=e.add(K,v),b=e.sub(b,y),y=e.add(E,p),T=e.add(C,R),y=e.mul(y,T),T=e.add(H,v),y=e.sub(y,T),B=e.mul(O,b),T=e.mul(N,v),B=e.add(T,B),T=e.sub(H,B),B=e.add(H,B),_=e.mul(T,B),H=e.add(K,K),H=e.add(H,K),v=e.mul(O,v),b=e.mul(N,b),H=e.add(H,v),v=e.sub(K,v),v=e.mul(O,v),b=e.add(b,v),K=e.mul(H,b),_=e.add(_,K),K=e.mul(y,b),T=e.mul(L,T),T=e.sub(T,K),K=e.mul(L,H),B=e.mul(y,B),B=e.add(B,K),new d(T,_,B)}subtract(h){return this.add(h.negate())}is0(){return this.equals(d.ZERO)}wNAF(h){return w.wNAFCached(this,h,d.normalizeZ)}multiplyUnsafe(h){let{endo:x,n:E}=t;bt("scalar",h,oe,E);let p=d.ZERO;if(h===oe)return p;if(this.is0()||h===wt)return this;if(!x||w.hasPrecomputes(this))return w.wNAFCachedUnsafe(this,h,d.normalizeZ);let{k1neg:I,k1:C,k2neg:R,k2:T}=x.splitScalar(h),_=p,B=p,O=this;for(;C>oe||T>oe;)C&wt&&(_=_.add(O)),T&wt&&(B=B.add(O)),O=O.double(),C>>=wt,T>>=wt;return I&&(_=_.negate()),R&&(B=B.negate()),B=new d(e.mul(B.px,x.beta),B.py,B.pz),_.add(B)}multiply(h){let{endo:x,n:E}=t;bt("scalar",h,wt,E);let p,I;if(x){let{k1neg:C,k1:R,k2neg:T,k2:_}=x.splitScalar(h),{p:B,f:O}=this.wNAF(R),{p:N,f:K}=this.wNAF(_);B=w.constTimeNegate(C,B),N=w.constTimeNegate(T,N),N=new d(e.mul(N.px,x.beta),N.py,N.pz),p=B.add(N),I=O.add(K)}else{let{p:C,f:R}=this.wNAF(h);p=C,I=R}return d.normalizeZ([p,I])[0]}multiplyAndAddUnsafe(h,x,E){let p=d.BASE,I=(R,T)=>T===oe||T===wt||!R.equals(p)?R.multiplyUnsafe(T):R.multiply(T),C=I(this,x).add(I(h,E));return C.is0()?void 0:C}toAffine(h){return u(this,h)}isTorsionFree(){let{h,isTorsionFree:x}=t;if(h===wt)return!0;if(x)return x(d,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:x}=t;return h===wt?this:x?x(d,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return Ot("isCompressed",h),this.assertValidity(),o(d,this,h)}toHex(h=!0){return Ot("isCompressed",h),Qt(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,w=sn(d,t.endo?Math.ceil(g/2):g);return{CURVE:t,ProjectivePoint:d,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function wh(r){let t=mr(r);return kt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function tc(r){let t=wh(r),{Fp:e,n}=t,o=e.BYTES+1,s=2*e.BYTES+1;function i(v){return j(v,n)}function a(v){return nn(v,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:u,isWithinCurveOrder:l}=gh({...t,toBytes(v,L,b){let y=L.toAffine(),A=e.toBytes(y.x),S=re;return Ot("isCompressed",b),b?S(Uint8Array.from([L.hasEvenY()?2:3]),A):S(Uint8Array.from([4]),A,e.toBytes(y.y))},fromBytes(v){let L=v.length,b=v[0],y=v.subarray(1);if(L===o&&(b===2||b===3)){let A=te(y);if(!dr(A,wt,e.ORDER))throw new Error("Point is not on curve");let S=u(A),U;try{U=e.sqrt(S)}catch(q){let M=q instanceof Error?": "+q.message:"";throw new Error("Point is not on curve"+M)}let P=(U&wt)===wt;return(b&1)===1!==P&&(U=e.neg(U)),{x:A,y:U}}else if(L===s&&b===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 "+L)}}}),d=v=>Qt(pe(v,t.nByteLength));function g(v){let L=n>>wt;return v>L}function w(v){return g(v)?i(-v):v}let m=(v,L,b)=>te(v.slice(L,b));class h{constructor(L,b,y){this.r=L,this.s=b,this.recovery=y,this.assertValidity()}static fromCompact(L){let b=t.nByteLength;return L=rt("compactSignature",L,b*2),new h(m(L,0,b),m(L,b,2*b))}static fromDER(L){let{r:b,s:y}=ne.toSig(rt("DER",L));return new h(b,y)}assertValidity(){bt("r",this.r,wt,n),bt("s",this.s,wt,n)}addRecoveryBit(L){return new h(this.r,this.s,L)}recoverPublicKey(L){let{r:b,s:y,recovery:A}=this,S=R(rt("msgHash",L));if(A==null||![0,1,2,3].includes(A))throw new Error("recovery id invalid");let U=A===2||A===3?b+t.n:b;if(U>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let P=(A&1)===0?"02":"03",D=c.fromHex(P+d(U)),q=a(U),M=i(-S*q),z=i(y*q),$=c.BASE.multiplyAndAddUnsafe(D,M,z);if(!$)throw new Error("point at infinify");return $.assertValidity(),$}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new h(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return ve(this.toDERHex())}toDERHex(){return ne.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return ve(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}let x={isValidPrivateKey(v){try{return f(v),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let v=_o(t.n);return fa(t.randomBytes(v),t.n)},precompute(v=8,L=c.BASE){return L._setWindowSize(v),L.multiply(BigInt(3)),L}};function E(v,L=!0){return c.fromPrivateKey(v).toRawBytes(L)}function p(v){let L=de(v),b=typeof v=="string",y=(L||b)&&v.length;return L?y===o||y===s:b?y===2*o||y===2*s:v instanceof c}function I(v,L,b=!0){if(p(v))throw new Error("first arg must be private key");if(!p(L))throw new Error("second arg must be public key");return c.fromHex(L).multiply(f(v)).toRawBytes(b)}let C=t.bits2int||function(v){if(v.length>8192)throw new Error("input is too large");let L=te(v),b=v.length*8-t.nBitLength;return b>0?L>>BigInt(b):L},R=t.bits2int_modN||function(v){return i(C(v))},T=pr(t.nBitLength);function _(v){return bt("num < 2^"+t.nBitLength,v,oe,T),pe(v,t.nByteLength)}function B(v,L,b=O){if(["recovered","canonical"].some(ot=>ot in b))throw new Error("sign() legacy options not supported");let{hash:y,randomBytes:A}=t,{lowS:S,prehash:U,extraEntropy:P}=b;S==null&&(S=!0),v=rt("msgHash",v),Ja(b),U&&(v=rt("prehashed msgHash",y(v)));let D=R(v),q=f(L),M=[_(q),_(D)];if(P!=null&&P!==!1){let ot=P===!0?A(e.BYTES):P;M.push(rt("extraEntropy",ot))}let z=re(...M),$=D;function nt(ot){let it=C(ot);if(!l(it))return;let At=a(it),Ct=c.BASE.multiply(it).toAffine(),Rt=i(Ct.x);if(Rt===oe)return;let Ft=i(At*i($+Rt*q));if(Ft===oe)return;let Zt=(Ct.x===Rt?0:2)|Number(Ct.y&wt),ir=Ft;return S&&g(Ft)&&(ir=w(Ft),Zt^=1),new h(Rt,ir,Zt)}return{seed:z,k2sig:nt}}let O={lowS:t.lowS,prehash:!1},N={lowS:t.lowS,prehash:!1};function K(v,L,b=O){let{seed:y,k2sig:A}=B(v,L,b),S=t;return vo(S.hash.outputLen,S.nByteLength,S.hmac)(y,A)}c.BASE._setWindowSize(8);function H(v,L,b,y=N){let A=v;L=rt("msgHash",L),b=rt("publicKey",b);let{lowS:S,prehash:U,format:P}=y;if(Ja(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 D=typeof A=="string"||de(A),q=!D&&!P&&typeof A=="object"&&A!==null&&typeof A.r=="bigint"&&typeof A.s=="bigint";if(!D&&!q)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let M,z;try{if(q&&(M=new h(A.r,A.s)),D){try{P!=="compact"&&(M=h.fromDER(A))}catch(Zt){if(!(Zt instanceof ne.Err))throw Zt}!M&&P!=="der"&&(M=h.fromCompact(A))}z=c.fromHex(b)}catch{return!1}if(!M||S&&M.hasHighS())return!1;U&&(L=t.hash(L));let{r:$,s:nt}=M,ot=R(L),it=a(nt),At=i(ot*it),Ct=i($*it),Rt=c.BASE.multiplyAndAddUnsafe(z,At,Ct)?.toAffine();return Rt?i(Rt.x)===$:!1}return{CURVE:t,getPublicKey:E,getSharedSecret:I,sign:K,verify:H,ProjectivePoint:c,Signature:h,utils:x}}function xh(r){return{hash:r,hmac:(t,...e)=>Ye(r,t,go(...e)),randomBytes:hr}}function ec(r,t){let e=n=>tc({...r,...xh(n)});return{...e(t),create:e}}var oc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),rc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),bh=BigInt(1),vs=BigInt(2),nc=(r,t)=>(r+t/vs)/t;function Eh(r){let t=oc,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,u=f*f*r%t,l=st(u,e,t)*u%t,d=st(l,e,t)*u%t,g=st(d,vs,t)*f%t,w=st(g,o,t)*g%t,m=st(w,s,t)*w%t,h=st(m,a,t)*m%t,x=st(h,c,t)*h%t,E=st(x,a,t)*m%t,p=st(E,e,t)*u%t,I=st(p,i,t)*w%t,C=st(I,n,t)*f%t,R=st(C,vs,t);if(!Bs.eql(Bs.sqr(R),r))throw new Error("Cannot find square root");return R}var Bs=me(oc,void 0,void 0,{sqrt:Eh}),Pe=ec({a:BigInt(0),b:BigInt(7),Fp:Bs,n:rc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=rc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-bh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=nc(s*r,t),c=nc(-n*r,t),f=j(r-a*e-c*o,t),u=j(-a*n-c*s,t),l=f>i,d=u>i;if(l&&(f=t-f),d&&(u=t-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:d,k2:u}}}},$t),Ry=BigInt(0);var Cy=Pe.ProjectivePoint;function sc(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function ic(r,t,e){let n=xr.digest(e instanceof Uint8Array?e:e.subarray());if(sc(n))return n.then(({digest:o})=>Pe.verify(t,o,r)).catch(o=>{throw new Ar(String(o))});try{return Pe.verify(t,n.digest,r)}catch(o){throw new Ar(String(o))}}var bn=class{type="secp256k1";raw;_key;constructor(t){this._key=cc(t),this.raw=ac(this._key)}toMultihash(){return Yt.digest(Ze(this))}toCID(){return ht.createV1(114,this.toMultihash())}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:xt(this.raw,t.raw)}verify(t,e){return ic(this._key,e,t)}};function Is(r){return new bn(r)}function ac(r){return Pe.ProjectivePoint.fromHex(r).toRawBytes(!0)}function cc(r){try{return Pe.ProjectivePoint.fromHex(r),r}catch(t){throw new Oe(String(t))}}function Ir(r,t){let{Type:e,Data:n}=Wt.decode(r),o=n??new Uint8Array;switch(e){case yt.RSA:return Ss(o,t);case yt.Ed25519:return Do(o);case yt.secp256k1:return Is(o);default:throw new be}}function uc(r){let{Type:t,Data:e}=Wt.decode(r.digest),n=e??new Uint8Array;switch(t){case yt.Ed25519:return Do(n);case yt.secp256k1:return Is(n);default:throw new be}}function Ze(r){return Wt.encode({Type:yt[r.type],Data:r.raw})}var fc=Symbol.for("nodejs.util.inspect.custom"),Sh=114,Lr=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()})`}[oo]=!0;toString(){return this.string==null&&(this.string=et.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return ht.createV1(Sh,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return xt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return xt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[fc](){return`PeerId(${this.toString()})`}},Tr=class extends Lr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},_r=class extends Lr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Rr=class extends Lr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},Ah=2336,Cr=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Yt.digest(tt(this.url))}[fc](){return`PeerId(${this.url})`}[oo]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return ht.createV1(Ah,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=F(t)),t.toString()===this.toString())}};var vh=114,lc=2336;function hc(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=ue(et.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return Bh(ht.parse(r));if(t==null)throw new gt('Please pass a multibase decoder for strings that do not start with "1" or "Q"');e=ue(t.decode(r))}return dc(e)}function Ls(r){if(r.type==="Ed25519")return new _r({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Rr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new Tr({multihash:r.toCID().multihash,publicKey:r});throw new be}function dc(r){if(Lh(r))return new Tr({multihash:r});if(Ih(r))try{let t=uc(r);if(t.type==="Ed25519")return new _r({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Rr({multihash:r,publicKey:t})}catch{let e=F(r.digest);return new Cr(new URL(e))}throw new $r("Supplied PeerID Multihash is invalid")}function Bh(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==vh&&r.code!==lc)throw new Wr("Supplied PeerID CID is invalid");if(r.code===lc){let t=F(r.multihash.digest);return new Cr(new URL(t))}return dc(r.multihash)}function Ih(r){return r.code===Yt.code}function Lh(r){return r.code===xr.code}function En(r){return r[Symbol.asyncIterator]!=null}var Sn=r=>{let t=lt(r),e=mt(t);return Gt(r,e),Sn.bytes=t,e};Sn.bytes=0;function pc(r,t){t=t??{};let e=t.lengthEncoder??Sn;function*n(o){let s=e(o.byteLength);s instanceof Uint8Array?yield s:yield*s,o instanceof Uint8Array?yield o:yield*o}return En(r)?async function*(){for await(let o of r)yield*n(o)}():function*(){for(let o of r)yield*n(o)}()}pc.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Sn;return new Z(e(r.byteLength),r)};var An=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},vn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Bn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},Ur=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Th=8,_h=1024*1024*4,Ne;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Ne||(Ne={}));var Ts=r=>{let t=qt(r);return Ts.bytes=lt(t),t};Ts.bytes=0;function Pr(r,t){let e=new Z,n=Ne.LENGTH,o=-1,s=t?.lengthDecoder??Ts,i=t?.maxLengthLength??Th,a=t?.maxDataLength??_h;function*c(){for(;e.byteLength>0;){if(n===Ne.LENGTH)try{if(o=s(e),o<0)throw new An("Invalid message length");if(o>a)throw new vn("Message length too long");let f=s.bytes;e.consume(f),t?.onLength!=null&&t.onLength(o),n=Ne.DATA}catch(f){if(f instanceof RangeError){if(e.byteLength>i)throw new Bn("Message length length too long");break}throw f}if(n===Ne.DATA){if(e.byteLength<o)break;let f=e.sublist(0,o);e.consume(o),t?.onData!=null&&t.onData(f),yield f,n=Ne.LENGTH}}}return En(r)?async function*(){for await(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new Ur("Unexpected end of input")}():function*(){for(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new Ur("Unexpected end of input")}()}Pr.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 Pr(n,{...t??{},onLength:s=>{e=s}})};function ft(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var In=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 Et(r,t,e){if(t==null)return r;if(t.aborted)return r.catch(()=>{}),Promise.reject(new In(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new In(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)}}var _s=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=ft(),this.haveNext=ft()}[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=ft(),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=ft(),await Et(this.readNext.promise,e?.signal,e)}};function mc(){return new _s}var Ln=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Rs=class extends Error{code;constructor(t,e){super(t),this.code=e}},Cs=class extends Rs{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function yc(r,t){let e=mc();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,f=new Promise((u,l)=>{c=()=>{l(new Cs("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:l,value:d}=await Promise.race([n.next(),f]);return l===!0?new Z:d}for(;o.byteLength<i;){let{value:l,done:d}=await Promise.race([n.next(),f]);if(d===!0)throw new Ln("unexpected end of input");o.append(l)}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 Tn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},_n=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Rn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Us(r,t={}){let e=yc(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=lt(t.maxDataLength));let n=t?.lengthDecoder??qt,o=t?.lengthEncoder??Gt;return{read:async i=>{let a=-1,c=new Z;for(;;){c.append(await e.read(1,i));try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(a<0)throw new Tn("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Rn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new _n("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(f=>[o(f.byteLength),f]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Ps(){let r=ft(),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 gc(){let r=Ps(),t=Ps();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var Cn=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}},Je=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Cn(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 Cn(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 Ns=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Un(r={}){return Rh(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 Rh(r,t){t=t??{};let e=t.onEnd,n=new Je,o,s,i,a=ft(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((h,x)=>{s=E=>{s=null,n.push(E);try{h(r(n))}catch(p){x(p)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=ft()})}},f=h=>s!=null?s(h):(n.push(h),o),u=h=>(n=new Je,s!=null?s({error:h}):(n.push({error:h}),o)),l=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 f({done:!1,value:h})},d=h=>i?o:(i=!0,h!=null?u(h):f({done:!0})),g=()=>(n=new Je,d(),{done:!0}),w=h=>(d(h),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:g,throw:w,push:l,end:d,get readableLength(){return n.size},onEmpty:async h=>{let x=h?.signal;if(x?.throwIfAborted(),n.isEmpty())return;let E,p;x!=null&&(E=new Promise((I,C)=>{p=()=>{C(new Ns)},x.addEventListener("abort",p)}));try{await Promise.race([a.promise,E])}finally{p!=null&&x!=null&&x?.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:l,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 ks=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=ft(),this.haveNext=ft()}[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=ft(),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=ft(),await Et(this.readNext.promise,e?.signal,e)}};function wc(){return new ks}function Ch(r){return r[Symbol.asyncIterator]!=null}async function Uh(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*Ph(r){let t=wc();Uh(r,t).catch(()=>{}),yield*t}function*Nh(r){for(let t of r)yield*t}function kh(...r){let t=[];for(let e of r)Ch(e)||t.push(e);return t.length===r.length?Nh(t):Ph(r)}var xc=kh;function bc(r,...t){if(r==null)throw new Error("Empty pipeline");if(Ds(r)){let n=r;r=()=>n.source}else if(Sc(r)||Ec(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Ds(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++)Ds(e[n])&&(e[n]=Kh(e[n]));return Dh(...e)}var Dh=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},Ec=r=>r?.[Symbol.asyncIterator]!=null,Sc=r=>r?.[Symbol.iterator]!=null,Ds=r=>r==null?!1:r.sink!=null&&r.source!=null,Kh=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Un({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let o,s=r.source;if(Ec(s))o=async function*(){yield*s,n.end()};else if(Sc(s))o=function*(){yield*s,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return xc(n,o())}return r.source};var Qe=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function Pn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Ks(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Tt(r,...t){if(!Ks(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 Os(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 Ac(r,t){Tt(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function Ms(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}var se=r=>new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4)),vc=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),Oh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!Oh)throw new Error("Non little-endian hardware is not supported");function Mh(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Nn(r){if(typeof r=="string")r=Mh(r);else if(Ks(r))r=kn(r);else throw new Error("Uint8Array expected, got "+typeof r);return r}function Bc(r,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(r,t)}function Ic(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 Hs=(r,t)=>{function e(n,...o){if(Tt(n),r.nonceLength!==void 0){let u=o[0];if(!u)throw new Error("nonce / iv required");r.varSizeNonce?Tt(u):Tt(u,r.nonceLength)}let s=r.tagLength;s&&o[1]!==void 0&&Tt(o[1]);let i=t(n,...o),a=(u,l)=>{if(l!==void 0){if(u!==2)throw new Error("cipher output not supported");Tt(l)}},c=!1;return{encrypt(u,l){if(c)throw new Error("cannot encrypt() twice with same key + nonce");return c=!0,Tt(u),a(i.encrypt.length,l),i.encrypt(u,l)},decrypt(u,l){if(Tt(u),s&&u.length<s)throw new Error("invalid ciphertext length: smaller than tagLength="+s);return a(i.decrypt.length,l),i.decrypt(u,l)}}}return Object.assign(e,r),e};function qs(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&&!Hh(t))throw new Error("invalid output, must be aligned");return t}function Vs(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,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function Hh(r){return r.byteOffset%4===0}function kn(r){return Uint8Array.from(r)}function ie(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}var Tc=r=>Uint8Array.from(r.split("").map(t=>t.charCodeAt(0))),qh=Tc("expand 16-byte k"),Vh=Tc("expand 32-byte k"),Fh=se(qh),zh=se(Vh);function k(r,t){return r<<t|r>>>32-t}function Fs(r){return r.byteOffset%4===0}var Dn=64,Gh=16,_c=2**32-1,Lc=new Uint32Array;function Wh(r,t,e,n,o,s,i,a){let c=o.length,f=new Uint8Array(Dn),u=se(f),l=Fs(o)&&Fs(s),d=l?se(o):Lc,g=l?se(s):Lc;for(let w=0;w<c;i++){if(r(t,e,n,u,i,a),i>=_c)throw new Error("arx: counter overflow");let m=Math.min(Dn,c-w);if(l&&m===Dn){let h=w/4;if(w%4!==0)throw new Error("arx: invalid block position");for(let x=0,E;x<Gh;x++)E=h+x,g[E]=d[E]^u[x];w+=Dn;continue}for(let h=0,x;h<m;h++)x=w+h,s[x]=o[x]^f[h];w+=m}}function zs(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:o,counterRight:s,rounds:i}=Bc({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Pn(o),Pn(i),Ms(s),Ms(e),(a,c,f,u,l=0)=>{Tt(a),Tt(c),Tt(f);let d=f.length;if(u===void 0&&(u=new Uint8Array(d)),Tt(u),Pn(l),l<0||l>=_c)throw new Error("arx: counter overflow");if(u.length<d)throw new Error(`arx: output (${u.length}) is shorter than data (${d})`);let g=[],w=a.length,m,h;if(w===32)g.push(m=kn(a)),h=zh;else if(w===16&&e)m=new Uint8Array(32),m.set(a),m.set(a,16),h=Fh,g.push(m);else throw new Error(`arx: invalid 32-byte key, got length=${w}`);Fs(c)||g.push(c=kn(c));let x=se(m);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(h,x,se(c.subarray(0,16)),x),c=c.subarray(16)}let E=16-o;if(E!==c.length)throw new Error(`arx: nonce must be ${E} or 16 bytes`);if(E!==12){let I=new Uint8Array(12);I.set(c,s?0:12-c.length),c=I,g.push(c)}let p=se(c);return Wh(r,h,x,p,f,u,l,i),ie(...g),u}}var St=(r,t)=>r[t++]&255|(r[t++]&255)<<8,Gs=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=Nn(t),Tt(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),f=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|f<<8)&8191,this.r[9]=f>>>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],f=i[2],u=i[3],l=i[4],d=i[5],g=i[6],w=i[7],m=i[8],h=i[9],x=St(t,e+0),E=St(t,e+2),p=St(t,e+4),I=St(t,e+6),C=St(t,e+8),R=St(t,e+10),T=St(t,e+12),_=St(t,e+14),B=s[0]+(x&8191),O=s[1]+((x>>>13|E<<3)&8191),N=s[2]+((E>>>10|p<<6)&8191),K=s[3]+((p>>>7|I<<9)&8191),H=s[4]+((I>>>4|C<<12)&8191),v=s[5]+(C>>>1&8191),L=s[6]+((C>>>14|R<<2)&8191),b=s[7]+((R>>>11|T<<5)&8191),y=s[8]+((T>>>8|_<<8)&8191),A=s[9]+(_>>>5|o),S=0,U=S+B*a+O*(5*h)+N*(5*m)+K*(5*w)+H*(5*g);S=U>>>13,U&=8191,U+=v*(5*d)+L*(5*l)+b*(5*u)+y*(5*f)+A*(5*c),S+=U>>>13,U&=8191;let P=S+B*c+O*a+N*(5*h)+K*(5*m)+H*(5*w);S=P>>>13,P&=8191,P+=v*(5*g)+L*(5*d)+b*(5*l)+y*(5*u)+A*(5*f),S+=P>>>13,P&=8191;let D=S+B*f+O*c+N*a+K*(5*h)+H*(5*m);S=D>>>13,D&=8191,D+=v*(5*w)+L*(5*g)+b*(5*d)+y*(5*l)+A*(5*u),S+=D>>>13,D&=8191;let q=S+B*u+O*f+N*c+K*a+H*(5*h);S=q>>>13,q&=8191,q+=v*(5*m)+L*(5*w)+b*(5*g)+y*(5*d)+A*(5*l),S+=q>>>13,q&=8191;let M=S+B*l+O*u+N*f+K*c+H*a;S=M>>>13,M&=8191,M+=v*(5*h)+L*(5*m)+b*(5*w)+y*(5*g)+A*(5*d),S+=M>>>13,M&=8191;let z=S+B*d+O*l+N*u+K*f+H*c;S=z>>>13,z&=8191,z+=v*a+L*(5*h)+b*(5*m)+y*(5*w)+A*(5*g),S+=z>>>13,z&=8191;let $=S+B*g+O*d+N*l+K*u+H*f;S=$>>>13,$&=8191,$+=v*c+L*a+b*(5*h)+y*(5*m)+A*(5*w),S+=$>>>13,$&=8191;let nt=S+B*w+O*g+N*d+K*l+H*u;S=nt>>>13,nt&=8191,nt+=v*f+L*c+b*a+y*(5*h)+A*(5*m),S+=nt>>>13,nt&=8191;let ot=S+B*m+O*w+N*g+K*d+H*l;S=ot>>>13,ot&=8191,ot+=v*u+L*f+b*c+y*a+A*(5*h),S+=ot>>>13,ot&=8191;let it=S+B*h+O*m+N*w+K*g+H*d;S=it>>>13,it&=8191,it+=v*l+L*u+b*f+y*c+A*a,S+=it>>>13,it&=8191,S=(S<<2)+S|0,S=S+U|0,U=S&8191,S=S>>>13,P+=S,s[0]=U,s[1]=P,s[2]=D,s[3]=q,s[4]=M,s[5]=z,s[6]=$,s[7]=nt,s[8]=ot,s[9]=it}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;ie(n)}update(t){Os(this);let{buffer:e,blockLen:n}=this;t=Nn(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(){ie(this.h,this.r,this.buffer,this.pad)}digestInto(t){Os(this),Ac(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 $h(r){let t=(n,o)=>r(o).update(Nn(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var Rc=$h(r=>new Gs(r));function Pc(r,t,e,n,o,s=20){let i=r[0],a=r[1],c=r[2],f=r[3],u=t[0],l=t[1],d=t[2],g=t[3],w=t[4],m=t[5],h=t[6],x=t[7],E=o,p=e[0],I=e[1],C=e[2],R=i,T=a,_=c,B=f,O=u,N=l,K=d,H=g,v=w,L=m,b=h,y=x,A=E,S=p,U=I,P=C;for(let q=0;q<s;q+=2)R=R+O|0,A=k(A^R,16),v=v+A|0,O=k(O^v,12),R=R+O|0,A=k(A^R,8),v=v+A|0,O=k(O^v,7),T=T+N|0,S=k(S^T,16),L=L+S|0,N=k(N^L,12),T=T+N|0,S=k(S^T,8),L=L+S|0,N=k(N^L,7),_=_+K|0,U=k(U^_,16),b=b+U|0,K=k(K^b,12),_=_+K|0,U=k(U^_,8),b=b+U|0,K=k(K^b,7),B=B+H|0,P=k(P^B,16),y=y+P|0,H=k(H^y,12),B=B+H|0,P=k(P^B,8),y=y+P|0,H=k(H^y,7),R=R+N|0,P=k(P^R,16),b=b+P|0,N=k(N^b,12),R=R+N|0,P=k(P^R,8),b=b+P|0,N=k(N^b,7),T=T+K|0,A=k(A^T,16),y=y+A|0,K=k(K^y,12),T=T+K|0,A=k(A^T,8),y=y+A|0,K=k(K^y,7),_=_+H|0,S=k(S^_,16),v=v+S|0,H=k(H^v,12),_=_+H|0,S=k(S^_,8),v=v+S|0,H=k(H^v,7),B=B+O|0,U=k(U^B,16),L=L+U|0,O=k(O^L,12),B=B+O|0,U=k(U^B,8),L=L+U|0,O=k(O^L,7);let D=0;n[D++]=i+R|0,n[D++]=a+T|0,n[D++]=c+_|0,n[D++]=f+B|0,n[D++]=u+O|0,n[D++]=l+N|0,n[D++]=d+K|0,n[D++]=g+H|0,n[D++]=w+v|0,n[D++]=m+L|0,n[D++]=h+b|0,n[D++]=x+y|0,n[D++]=E+A|0,n[D++]=p+S|0,n[D++]=I+U|0,n[D++]=C+P|0}function Zh(r,t,e,n){let o=r[0],s=r[1],i=r[2],a=r[3],c=t[0],f=t[1],u=t[2],l=t[3],d=t[4],g=t[5],w=t[6],m=t[7],h=e[0],x=e[1],E=e[2],p=e[3];for(let C=0;C<20;C+=2)o=o+c|0,h=k(h^o,16),d=d+h|0,c=k(c^d,12),o=o+c|0,h=k(h^o,8),d=d+h|0,c=k(c^d,7),s=s+f|0,x=k(x^s,16),g=g+x|0,f=k(f^g,12),s=s+f|0,x=k(x^s,8),g=g+x|0,f=k(f^g,7),i=i+u|0,E=k(E^i,16),w=w+E|0,u=k(u^w,12),i=i+u|0,E=k(E^i,8),w=w+E|0,u=k(u^w,7),a=a+l|0,p=k(p^a,16),m=m+p|0,l=k(l^m,12),a=a+l|0,p=k(p^a,8),m=m+p|0,l=k(l^m,7),o=o+f|0,p=k(p^o,16),w=w+p|0,f=k(f^w,12),o=o+f|0,p=k(p^o,8),w=w+p|0,f=k(f^w,7),s=s+u|0,h=k(h^s,16),m=m+h|0,u=k(u^m,12),s=s+u|0,h=k(h^s,8),m=m+h|0,u=k(u^m,7),i=i+l|0,x=k(x^i,16),d=d+x|0,l=k(l^d,12),i=i+l|0,x=k(x^i,8),d=d+x|0,l=k(l^d,7),a=a+c|0,E=k(E^a,16),g=g+E|0,c=k(c^g,12),a=a+c|0,E=k(E^a,8),g=g+E|0,c=k(c^g,7);let I=0;n[I++]=o,n[I++]=s,n[I++]=i,n[I++]=a,n[I++]=h,n[I++]=x,n[I++]=E,n[I++]=p}var jh=zs(Pc,{counterRight:!1,counterLength:4,allowShortKeys:!1}),Xh=zs(Pc,{counterRight:!1,counterLength:8,extendNonceFn:Zh,allowShortKeys:!1});var Yh=new Uint8Array(16),Cc=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(Yh.subarray(e))},Jh=new Uint8Array(32);function Uc(r,t,e,n,o){let s=r(t,e,Jh),i=Rc.create(s);o&&Cc(i,o),Cc(i,n);let a=new Uint8Array(16),c=vc(a);Vs(c,0,BigInt(o?o.length:0),!0),Vs(c,8,BigInt(n.length),!0),i.update(a);let f=i.digest();return ie(s,a),f}var Nc=r=>(t,e,n)=>({encrypt(s,i){let a=s.length;i=qs(a+16,i,!1),i.set(s);let c=i.subarray(0,-16);r(t,e,c,c,1);let f=Uc(r,t,e,c,n);return i.set(f,a),ie(f),i},decrypt(s,i){i=qs(s.length-16,i,!1);let a=s.subarray(0,-16),c=s.subarray(-16),f=Uc(r,t,e,a,n);if(!Ic(c,f))throw new Error("invalid tag");return i.set(s.subarray(0,-16)),r(t,e,i,i,1),ie(f),i}}),Ws=Hs({blockSize:64,nonceLength:12,tagLength:16},Nc(jh)),Dw=Hs({blockSize:64,nonceLength:24,tagLength:16},Nc(Xh));function Dc(r,t,e){return lr(r),e===void 0&&(e=new Uint8Array(r.outputLen)),Ye(r,fe(e),fe(t))}var $s=new Uint8Array([0]),kc=new Uint8Array;function Kc(r,t,e,n=32){if(lr(r),Xr(n),n>255*r.outputLen)throw new Error("Length should be <= 255*HashLen");let o=Math.ceil(n/r.outputLen);e===void 0&&(e=kc);let s=new Uint8Array(o*r.outputLen),i=Ye.create(r,t),a=i._cloneInto(),c=new Uint8Array(i.outputLen);for(let f=0;f<o;f++)$s[0]=f+1,a.update(f===0?kc:c).update(e).update($s).digestInto(c),s.set(c,r.outputLen*f),i._cloneInto(a);return i.destroy(),a.destroy(),c.fill(0),$s.fill(0),s.slice(0,n)}var Zs={hashSHA256(r){return $t(r.subarray())},getHKDF(r,t){let e=Dc($t,t,r),o=Kc($t,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=gr.utils.randomPrivateKey();return{publicKey:gr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:gr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return gr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return Ws(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,o){return Ws(n,t,e).decrypt(r.subarray(),o)}};var Oc=Zs;function Mc(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 tr=r=>{let t=mt(2);return t[0]=r>>8,t[1]=r,t};tr.bytes=2;var Nr=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)};Nr.bytes=2;function Hc(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 js(r,t){!t.enabled||!Qe||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${F(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${F(r.privateKey,"hex")}`)):t("Missing local static keys."))}function Xs(r,t){!t.enabled||!Qe||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${F(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${F(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function qc(r,t){!t.enabled||!Qe||t(r?`REMOTE_STATIC_PUBLIC_KEY ${F(r.subarray(),"hex")}`:"Missing remote static public key.")}function Ys(r,t){!t.enabled||!Qe||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${F(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function Js(r,t,e){!e.enabled||!Qe||(e(`CIPHER_STATE_1 ${r.n.getUint64()} ${r.k&&F(r.k,"hex")}`),e(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&F(t.k,"hex")}`))}var er=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var Qh=0,td=4294967295,ed="Cipherstate has reached maximum n, a new handshake must be performed",Kn=class{n;bytes;view;constructor(t=Qh){this.n=t,this.bytes=pt(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>td)throw new Error(ed)}};var ke=pt(0),rr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new Kn(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}},Qs=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=tt(e,"utf-8");this.h=rd(t,n),this.ck=this.h,this.cs=new rr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new rr(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,ke);return[new rr(this.crypto,t),new rr(this.crypto,e)]}},ti=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:f}=t;this.crypto=e,this.ss=new Qs(e,n),this.ss.mixHash(o),this.initiator=s,this.s=i,this.e=a,this.rs=c,this.re=f}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()}},kr=class extends ti{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 er(`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 er(`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 er(`handshake stage 2 validation fail: ${e.message}`)}}};function rd(r,t){if(t.length<=32){let e=pt(32);return e.set(t),e}else return r.hash(t)}var On;(function(r){let t;r.codec=()=>(t==null&&(t=Ue((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=>Ce(e,r.codec()),r.decode=e=>Te(e,r.codec())})(On||(On={}));var Dr;(function(r){let t;r.codec=()=>(t==null&&(t=Ue((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),On.codec().encode(e.extensions,n)),o.lengthDelimited!==!1&&n.ldelim()},(e,n)=>{let o={identityKey:pt(0),identitySig:pt(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=On.codec().decode(e,e.uint32());break}default:{e.skipType(i&7);break}}}return o})),t),r.encode=e=>Ce(e,r.codec()),r.decode=e=>Te(e,r.codec())})(Dr||(Dr={}));async function ei(r,t,e){let n=await r.sign(Vc(t));return Dr.encode({identityKey:Ze(r.publicKey),identitySig:n,extensions:e})}async function ri(r,t,e){try{let n=Dr.decode(r),o=Ir(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=Vc(t);if(!await o.verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new qr(n.message)}}function Vc(r){let t=tt("noise-libp2p-static-key:");return r instanceof Uint8Array?Lt([t,r],t.length+r.length):(r.prepend(t),r)}async function Fc(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:f}=r,u=await ei(s,a.publicKey,f),l=new kr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:i,s:a});js(l.s,e),e.trace("Stage 0 - Initiator starting to send first message."),await n.write(l.writeMessageA(ke),t),e.trace("Stage 0 - Initiator finished sending first message."),Xs(l.e,e),e.trace("Stage 1 - Initiator waiting to receive first message from responder...");let d=l.readMessageB(await n.read(t));e.trace("Stage 1 - Initiator received the message."),Ys(l.re,e),qc(l.rs,e),e.trace("Initiator going to check remote's signature...");let g=await ri(d,l.rs,c);e.trace("All good with the signature!"),e.trace("Stage 2 - Initiator sending third handshake message."),await n.write(l.writeMessageC(u),t),e.trace("Stage 2 - Initiator sent message with signed payload.");let[w,m]=l.ss.split();return Js(w,m,e),{payload:g,encrypt:h=>w.encryptWithAd(ke,h),decrypt:(h,x)=>m.decryptWithAd(ke,h,x)}}async function zc(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:f}=r,u=await ei(s,a.publicKey,f),l=new kr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:i,s:a});js(l.s,e),e.trace("Stage 0 - Responder waiting to receive first message."),l.readMessageA(await n.read(t)),e.trace("Stage 0 - Responder received first message."),Ys(l.re,e),e.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await n.write(l.writeMessageB(u),t),e.trace("Stage 1 - Responder sent the second handshake message with signed payload."),Xs(l.e,e),e.trace("Stage 2 - Responder waiting for third handshake message...");let d=l.readMessageC(await n.read(t));e.trace("Stage 2 - Responder received the message, finished handshake.");let g=await ri(d,l.rs,c),[w,m]=l.ss.split();return Js(w,m,e),{payload:g,encrypt:h=>m.encryptWithAd(ke,h),decrypt:(h,x)=>w.decryptWithAd(ke,h,x)}}var Wc=16;function $c(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(tr(i.byteLength),i)}}}function Zc(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-Wc<o)throw new Error("Invalid chunk");let i=n.sublist(o,s),a=n.subarray(o,s-Wc);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var Mn=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??Oc;this.crypto=Mc(c),this.extensions=o,this.metrics=a?Hc(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??pt(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[Zr]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(t,e){let n=Us(t,{lengthEncoder:tr,lengthDecoder:Nr,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=Ir(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:Ls(i)}}async secureInbound(t,e){let n=Us(t,{lengthEncoder:tr,lengthDecoder:Nr,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=Ir(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:Ls(i)}}async performHandshakeInitiator(t,e,n,o){let s;try{s=await Fc({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 zc({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]=gc(),s=t.unwrap();return await bc(n,$c(e,this.metrics),s,i=>Pr(i,{lengthDecoder:Nr}),Zc(e,this.metrics),n),o}};function jc(r={}){return t=>new Mn(t,r)}var Hn=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",f=2**(8*o)-1;for(;;){let u=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let d=Number.parseInt(l,t);if(!Number.isNaN(d))return d});if(u===void 0)break;if(s*=t,s+=u,s>f||(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 Xc=45,nd=15,nr=new Hn;function ni(r){if(!(r.length>nd))return nr.new(r).parseWith(()=>nr.readIPv4Addr())}function oi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Xc))return nr.new(r).parseWith(()=>nr.readIPv6Addr())}function qn(r,t=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>Xc)return;let e=nr.new(r).parseWith(()=>nr.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}function Vn(r){return!!ni(r)}function Fn(r){return!!oi(r)}function zn(r){return!!qn(r)}var od=r=>r.toString().split("/").slice(1),or=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),G=r=>({match:t=>or(e=>e===r).match(t),pattern:r}),De=()=>({match:r=>or(t=>typeof t=="string").match(r),pattern:"{string}"}),Or=()=>({match:r=>or(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),Q=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{et.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),Mr=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Jo.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),X=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),_t=(...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(", ")})`}),W=(...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=od(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 Wn=W(G("dns4"),De()),$n=W(G("dns6"),De()),Zn=W(G("dnsaddr"),De()),ii=W(G("dns"),De()),wb=ct(Wn,X(Q())),xb=ct($n,X(Q())),bb=ct(Zn,X(Q())),Eb=ct(_t(ii,Zn,Wn,$n),X(Q())),Yc=W(G("ip4"),or(Vn)),Jc=W(G("ip6"),or(Fn)),ai=_t(Yc,Jc),ae=_t(ai,ii,Wn,$n,Zn),Sb=ct(_t(ai,W(_t(ii,Zn,Wn,$n),X(Q())))),Ab=ct(Yc),vb=ct(Jc),Bb=ct(ai),ci=W(ae,G("tcp"),Or()),Hr=W(ae,G("udp"),Or()),Ib=ct(W(ci,X(Q()))),Lb=ct(Hr),ui=W(Hr,G("quic"),X(Q())),jn=W(Hr,G("quic-v1"),X(Q())),sd=_t(ui,jn),Tb=ct(ui),_b=ct(jn),si=_t(ae,ci,Hr,ui,jn),Qc=_t(W(si,G("ws"),X(Q()))),Rb=ct(Qc),tu=_t(W(si,G("wss"),X(Q())),W(si,G("tls"),X(W(G("sni"),De())),G("ws"),X(Q()))),Cb=ct(tu),eu=W(Hr,G("webrtc-direct"),X(Mr()),X(Mr()),X(Q())),Ub=ct(eu),ru=W(jn,G("webtransport"),X(Mr()),X(Mr()),X(Q())),Xn=ct(ru),Gn=_t(Qc,tu,W(ci,X(Q())),W(sd,X(Q())),W(ae,X(Q())),eu,ru,Q()),Pb=ct(Gn),id=W(Gn,G("p2p-circuit"),Q()),Nb=ct(id),ad=_t(W(Gn,G("p2p-circuit"),G("webrtc"),X(Q())),W(Gn,G("webrtc"),X(Q())),W(G("webrtc"),X(Q()))),kb=ct(ad),cd=_t(W(ae,G("tcp"),Or(),G("http"),X(Q())),W(ae,G("http"),X(Q()))),Db=ct(cd),ud=_t(W(ae,G("tcp"),_t(W(G("443"),G("http")),W(Or(),G("https"))),X(Q())),W(ae,G("tls"),G("http"),X(Q())),W(ae,G("https"),X(Q()))),Kb=ct(ud),fd=_t(W(G("memory"),De(),X(Q()))),Ob=ct(fd);var Ke=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};function fi(r){throw new Error("Not implemented")}function nu(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 ou(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function su(r,t){let e=nu(r).return?.();ou(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var ld=5e3;function li(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var Yn=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=ft(),this.closed=ft(),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??ld,this.onEnd=t.onEnd,this.onCloseRead=t?.onCloseRead,this.onCloseWrite=t?.onCloseWrite,this.onReset=t?.onReset,this.onAbort=t?.onAbort,this.source=this.streamSource=Un({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 zr(`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);li(o)&&await o}let n=()=>{su(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);li(s)&&(this.sendingData=ft(),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 Et(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 Et(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await Et(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await Et(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();li(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 Fr("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}};var hi=class extends Yn{writer;reader;constructor(t){super(t),this.writer=t.bidiStream.writable.getWriter(),this.reader=t.bidiStream.readable.getReader(),Promise.resolve().then(async()=>{for(;;){let e=await this.reader.read();if(e.done){t.log("remote closed write");return}e.value!=null&&this.sourcePush(new Z(e.value))}}).catch(e=>{t.log.error("error reading from stream",e),this.abort(e)}).finally(()=>{this.remoteCloseWrite()}),this.writer.closed.then(()=>{t.log("writer closed")}).catch(e=>{t.log("writer close promise rejected",e)}).finally(()=>{this.remoteCloseRead()})}sendNewStream(t){}async sendData(t,e){for await(let n of t)this.log("sendData waiting for writer to be ready"),await Et(this.writer.ready,e?.signal),this.writer.write(n).catch(o=>{this.log.error("error sending stream data",o)})}async sendReset(t){this.log("sendReset aborting writer"),await Et(this.writer.abort(),t?.signal),this.log("sendReset aborted writer")}async sendCloseWrite(t){this.log("sendCloseWrite closing writer"),await Et(this.writer.close(),t?.signal),this.log("sendCloseWrite closed writer")}async sendCloseRead(t){this.log("sendCloseRead cancelling reader"),await Et(this.reader.cancel(),t?.signal),this.log("sendCloseRead cancelled reader")}};async function di(r,t,e,n,o,s){let i=s.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=new hi({bidiStream:r,id:t,direction:e,log:i,onEnd:()=>{let c=n.findIndex(f=>f===a);c!==-1&&n.splice(c,1),o?.(a)}});return a}function Jn(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function iu(r,t,e,n){let o=0,s=e.forComponent("libp2p:webtransport:muxer");return{protocol:"webtransport",createStreamMuxer:i=>{typeof i=="function"&&(i={onIncomingStream:i});let a=[];Promise.resolve().then(async()=>{for(;;){let{done:f,value:u}=await t.read();if(f)break;if(a.length>=n.maxInboundStreams)s(`too many inbound streams open - ${a.length}/${n.maxInboundStreams}, closing new incoming stream`),u.writable.close().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)}),u.readable.cancel().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)});else{let l=await di(u,String(o++),"inbound",a,i?.onStreamEnd,e);a.push(l),i?.onIncomingStream?.(l)}}}).catch(f=>{s.error("could not create a new stream",f)});let c={protocol:"webtransport",streams:a,newStream:async f=>{s("new outgoing stream",f);let u=await r.createBidirectionalStream(),l=await di(u,String(o++),i?.direction??"outbound",a,i?.onStreamEnd,e);return a.push(l),l},close:async()=>{s("closing webtransport muxer gracefully");try{r.close()}catch(f){c.abort(f)}},abort:f=>{s("closing webtransport muxer with err:",f);try{r.close()}catch(u){s.error("webtransport session threw error during close",u)}},...Jn()};return c}}}function au(r,t){return t.filter(n=>!!r.find(o=>xt(n,o))).length===t.length}var g1=parseInt("0xFFFF",16),w1=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var fu=Vn,yd=Fn,pi=function(r){let t=0;if(r=r.toString().trim(),fu(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(yd(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=fu(e[n]),i;s&&(i=pi(e[n]),e[n]=F(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,F(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")},lu=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 sr={},mi={},wd=[[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"]];wd.forEach(r=>{let t=xd(...r);mi[t.code]=t,sr[t.name]=t});function xd(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function J(r){if(typeof r=="number"){if(mi[r]!=null)return mi[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(sr[r]!=null)return sr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var Q1=J("ip4"),t2=J("ip6"),e2=J("ipcidr");function xi(r,t){switch(J(r).code){case 4:case 41:return Ed(t);case 42:return wi(t);case 43:return F(t,"base10");case 6:case 273:case 33:case 132:return pu(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return wi(t);case 421:return Bd(t);case 444:return du(t);case 445:return du(t);case 466:return vd(t);case 481:return globalThis.encodeURIComponent(wi(t));default:return F(t,"base16")}}function bi(r,t){switch(J(r).code){case 4:return hu(t);case 41:return hu(t);case 42:return gi(t);case 43:return tt(t,"base10");case 6:case 273:case 33:case 132:return Ei(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return gi(t);case 421:return Sd(t);case 444:return Id(t);case 445:return Ld(t);case 466:return Ad(t);case 481:return gi(globalThis.decodeURIComponent(t));default:return tt(t,"base16")}}var yi=Object.values(_e).map(r=>r.decoder),bd=function(){let r=yi[0].or(yi[1]);return yi.slice(2).forEach(t=>r=r.or(t)),r}();function hu(r){if(!zn(r))throw new Error("invalid ip address");return pi(r)}function Ed(r){let t=lu(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!zn(t))throw new Error("invalid ip address");return t}function Ei(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function pu(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function gi(r){let t=tt(r),e=Uint8Array.from(Gt(t.length));return Lt([e,t],e.length+t.length)}function wi(r){let t=qt(r);if(r=r.slice(lt(t)),r.length!==t)throw new Error("inconsistent lengths");return F(r)}function Sd(r){let t;r[0]==="Q"||r[0]==="1"?t=ue(et.decode(`z${r}`)).bytes:t=ht.parse(r).multihash.bytes;let e=Uint8Array.from(Gt(t.length));return Lt([e,t],e.length+t.length)}function Ad(r){let t=bd.decode(r),e=Uint8Array.from(Gt(t.length));return Lt([e,t],e.length+t.length)}function vd(r){let t=qt(r),e=r.slice(lt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+F(e,"base64url")}function Bd(r){let t=qt(r),e=r.slice(lt(t));if(e.length!==t)throw new Error("inconsistent lengths");return F(e,"base58btc")}function Id(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=Xt.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=Ei(n);return Lt([e,o],e.length+o.length)}function Ld(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=Xt.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=Ei(n);return Lt([e,o],e.length+o.length)}function du(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=F(t,"base32"),o=pu(e);return`${n}:${o}`}function mu(r){r=Si(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=J(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw new Qn("invalid address: "+r);if(a.path===!0){n=Si(o.slice(s).join("/")),t.push([a.code,bi(a.code,n)]),e.push([a.code,n]);break}let c=bi(a.code,o[s]);t.push([a.code,c]),e.push([a.code,xi(a.code,c)])}return{string:yu(e),bytes:to(t),tuples:t,stringTuples:e,path:n}}function Ai(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=qt(r,o),i=lt(s),a=J(s),c=Td(a,r.slice(o+i));if(c===0){t.push([s]),e.push([s]),o+=i;continue}let f=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw new Qn("Invalid address Uint8Array: "+F(r,"base16"));t.push([s,f]);let u=xi(s,f);if(e.push([s,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:yu(e),tuples:t,stringTuples:e,path:n}}function yu(r){let t=[];return r.map(e=>{let n=J(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Si(t.join("/"))}function to(r){return Lt(r.map(t=>{let e=J(t[0]),n=Uint8Array.from(Gt(e.code));return t.length>1&&t[1]!=null&&(n=Lt([n,t[1]])),n}))}function Td(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=qt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+lt(e)}}function Si(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}var Qn=class extends Error{static name="ParseError";name="ParseError";constructor(t){super(`Error parsing address: ${t}`)}};var _d=Symbol.for("nodejs.util.inspect.custom"),Bi=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Rd=[J("dns").code,J("dns4").code,J("dns6").code,J("dnsaddr").code],vi=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},eo=class r{bytes;#e;#t;#r;#n;[Bi]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Ai(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=mu(t)}else if(wu(t))e=Ai(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#e=e.string,this.#t=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let t,e,n,o,s="",i=J("tcp"),a=J("udp"),c=J("ip4"),f=J("ip6"),u=J("dns6"),l=J("ip6zone");for(let[g,w]of this.stringTuples())g===l.code&&(s=`%${w??""}`),Rd.includes(g)&&(e=i.name==="tcp"?"tcp":"udp",o=443,n=`${w??""}${s}`,t=g===u.code?6:4),(g===i.code||g===a.code)&&(e=J(g).name==="tcp"?"tcp":"udp",o=parseInt(w??"")),(g===c.code||g===f.code)&&(e=J(g).name==="tcp"?"tcp":"udp",n=`${w??""}${s}`,t=g===f.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.#t.map(([t])=>Object.assign({},J(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>J(t).name)}tuples(){return this.#t.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(to(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===sr.p2p.code&&t.push([n,o]),n===sr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?F(et.decode(`z${n}`),"base58btc"):F(ht.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return xt(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=gu.get(e.name);if(n==null)throw new vi(`no available resolver for ${e.name}`);return(await n(this,t)).map(s=>Ii(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)}[_d](){return`Multiaddr(${this.#e})`}};var gu=new Map;function wu(r){return!!r?.[Bi]}function Ii(r){return new eo(r)}var Cd=Object.values(_e).map(r=>r.decoder).reduce((r,t)=>r.or(t));function Ud(r){return zt.decode(Cd.decode(r))}function Li(r){if(!Xn.matches(r))throw new Gr("Invalid multiaddr, was not a WebTransport address");let t=r.stringTuples(),e=t.filter(([i,a])=>i===J("certhash").code).map(([i,a])=>Ud(a??"")),n=t.filter(([i,a])=>i===J("p2p").code).map(([i,a])=>hc(a??""))[0],o=r.toOptions(),s=o.host;return o.family===6&&s?.includes(":")&&(s=`[${s}]`),{url:`https://${s}:${o.port}`,certhashes:e,remotePeer:n}}var xu=globalThis.WebTransport;var Ti=class{log;components;config;metrics;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:webtransport"),this.components=t,this.config={...e,maxInboundStreams:e.maxInboundStreams??1e3,certificates:e.certificates??[]},t.metrics!=null&&(this.metrics={dialerEvents:t.metrics.registerCounterGroup("libp2p_webtransport_dialer_events_total",{label:"event",help:"Total count of WebTransport dialer events by type"})})}[Symbol.toStringTag]="@libp2p/webtransport";[Ki]=!0;[Zr]=["@libp2p/transport"];async dial(t,e){e.signal.throwIfAborted(),this.log("dialing %s",t),e=e??{};let{url:n,certhashes:o,remotePeer:s}=Li(t),i,a,c=()=>{},f=!1,u=!1,l=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let d=new xu(`${n}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(g=>({algorithm:"sha-256",value:g.digest}))});if(c=g=>{if(!f)try{this.metrics?.dialerEvents.increment({[g]:!0}),d.close()}catch(w){this.log.error("error closing wt session",w)}finally{a!=null&&(a.timeline.close=Date.now()),f=!0}},i=()=>{c(u?"noise_timeout":"ready_timeout")},e.signal.addEventListener("abort",i,{once:!0}),this.log("wait for session to be ready"),e.onProgress?.(new Ke("webtransport:wait-for-session")),await Promise.race([d.closed,d.ready]),this.log("session became ready"),u=!0,this.metrics?.dialerEvents.increment({ready:!0}),d.closed.catch(g=>{this.log.error("error on remote wt session close",g)}).finally(()=>{c("remote_close")}),l=await Et(this.authenticateWebTransport({wt:d,remotePeer:s,certhashes:o,...e}),e.signal),!l)throw new Vr("Failed to authenticate webtransport");return this.metrics?.dialerEvents.increment({open:!0}),a={close:async()=>{this.log("closing webtransport"),c("close")},abort:g=>{this.log("aborting webtransport due to passed err",g),c("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...Jn()},await e.upgrader.upgradeOutbound(a,{...e,skipEncryption:!0,muxerFactory:iu(d,d.incomingBidirectionalStreams.getReader(),this.components.logger,this.config),skipProtection:!0})}catch(d){throw this.log.error("caught wt session err",d),c(l?"upgrade_error":u?"noise_error":"ready_error"),d}finally{i!=null&&e.signal?.removeEventListener("abort",i)}}async authenticateWebTransport({wt:t,remotePeer:e,certhashes:n,onProgress:o,signal:s}){s?.throwIfAborted(),o?.(new Ke("webtransport:open-authentication-stream"));let i=await t.createBidirectionalStream(),a=i.writable.getWriter(),c=i.readable.getReader(),f={source:async function*(){for(;;){let d=await c.read();if(d.value!=null&&(yield d.value),d.done)break}}(),sink:async d=>{for await(let g of d){await Et(a.ready,s);let w=g instanceof Uint8Array?g:g.subarray();a.write(w).catch(m=>{this.log.error("could not write chunk during authentication of WebTransport stream",m)})}}},u=jc()(this.components);o?.(new Ke("webtransport:secure-outbound-connection"));let{remoteExtensions:l}=await u.secureOutbound(f,{signal:s,remotePeer:e});if(o?.(new Ke("webtransport:close-authentication-stream")),a.close().catch(d=>{this.log.error(`Failed to close authentication stream writer: ${d.message}`)}),c.cancel().catch(d=>{this.log.error(`Failed to close authentication stream reader: ${d.message}`)}),!au(l?.webtransportCerthashes??[],n.map(d=>d.bytes)))throw new gt("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return fi(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return globalThis.WebTransport==null?[]:t.filter(e=>{if(!Xn.exactMatch(e))return!1;let{url:n,certhashes:o}=Li(e);return n!=null&&o.length>0})}};function Pd(r={}){return t=>new Ti(t,r)}return Uu(Nd);})();
2
+ "use strict";var Libp2PWebtransport=(()=>{var co=Object.defineProperty;var qu=Object.getOwnPropertyDescriptor;var Vu=Object.getOwnPropertyNames;var Fu=Object.prototype.hasOwnProperty;var vt=(r,t)=>{for(var e in t)co(r,e,{get:t[e],enumerable:!0})},zu=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Vu(t))!Fu.call(r,o)&&o!==e&&co(r,o,{get:()=>t[o],enumerable:!(n=qu(t,o))||n.enumerable});return r};var Gu=r=>zu(co({},"__esModule",{value:!0}),r);var np={};vt(np,{webTransport:()=>rp});var uo=Symbol.for("@libp2p/peer-id");var Yi=Symbol.for("@libp2p/transport");var Zi;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Zi||(Zi={}));var $r=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}},qe=class extends Error{static name="InvalidCryptoExchangeError";constructor(t="Invalid crypto exchange"){super(t),this.name="InvalidCryptoExchangeError"}},ut=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Ve=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var Zr=class extends Error{static name="StreamResetError";constructor(t="The stream has been reset"){super(t),this.name="StreamResetError"}},Yr=class extends Error{static name="StreamStateError";constructor(t="The stream is in an invalid state"){super(t),this.name="StreamStateError"}};var Xr=class extends Error{static name="InvalidMultiaddrError";constructor(t="Invalid multiaddr"){super(t),this.name="InvalidMultiaddrError"}},Jr=class extends Error{static name="InvalidCIDError";constructor(t="Invalid CID"){super(t),this.name="InvalidCIDError"}},Qr=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var Ae=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var tn=Symbol.for("@libp2p/service-capabilities"),cp=Symbol.for("@libp2p/service-dependencies");var mo={};vt(mo,{base58btc:()=>et,base58flickr:()=>Xu});var Pp=new Uint8Array(0);function Xi(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 Yt(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 Ji(r){return new TextEncoder().encode(r)}function Qi(r){return new TextDecoder().decode(r)}function Wu(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),f=Math.log(a)/Math.log(256),u=Math.log(256)/Math.log(a);function l(w){if(w instanceof Uint8Array||(ArrayBuffer.isView(w)?w=new Uint8Array(w.buffer,w.byteOffset,w.byteLength):Array.isArray(w)&&(w=Uint8Array.from(w))),!(w instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(w.length===0)return"";for(var m=0,h=0,x=0,E=w.length;x!==E&&w[x]===0;)x++,m++;for(var p=(E-x)*u+1>>>0,B=new Uint8Array(p);x!==E;){for(var P=w[x],C=0,_=p-1;(P!==0||C<h)&&_!==-1;_--,C++)P+=256*B[_]>>>0,B[_]=P%a>>>0,P=P/a>>>0;if(P!==0)throw new Error("Non-zero carry");h=C,x++}for(var T=p-h;T!==p&&B[T]===0;)T++;for(var I=c.repeat(m);T<p;++T)I+=r.charAt(B[T]);return I}function d(w){if(typeof w!="string")throw new TypeError("Expected String");if(w.length===0)return new Uint8Array;var m=0;if(w[m]!==" "){for(var h=0,x=0;w[m]===c;)h++,m++;for(var E=(w.length-m)*f+1>>>0,p=new Uint8Array(E);w[m];){var B=e[w.charCodeAt(m)];if(B===255)return;for(var P=0,C=E-1;(B!==0||P<x)&&C!==-1;C--,P++)B+=a*p[C]>>>0,p[C]=B%256>>>0,B=B/256>>>0;if(B!==0)throw new Error("Non-zero carry");x=P,m++}if(w[m]!==" "){for(var _=E-x;_!==E&&p[_]===0;)_++;for(var T=new Uint8Array(h+(E-_)),I=h;_!==E;)T[I++]=p[_++];return T}}}function g(w){var m=d(w);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:d,decode:g}}var ju=Wu,$u=ju,ea=$u;var fo=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")}},lo=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 ra(this,t)}},ho=class{decoders;constructor(t){this.decoders=t}or(t){return ra(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 ra(r,t){return new ho({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var po=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 fo(t,e,n),this.decoder=new lo(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Fe({name:r,prefix:t,encode:e,decode:n}){return new po(r,t,e,n)}function ue({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=ea(e,r);return Fe({prefix:t,name:r,encode:n,decode:s=>Yt(o(s))})}function Zu(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,f=0;for(let u=0;u<s;++u){let l=o[r[u]];if(l===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<e|l,a+=e,a>=8&&(a-=8,i[f++]=255&c>>a)}if(a>=e||(255&c<<8-a)!==0)throw new SyntaxError("Unexpected end of data");return i}function Yu(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 Fe({prefix:t,name:r,encode(o){return Yu(o,n,e)},decode(o){return Zu(o,n,e,r)}})}var et=ue({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Xu=ue({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var yo={};vt(yo,{base32:()=>Xt,base32hex:()=>ef,base32hexpad:()=>nf,base32hexpadupper:()=>of,base32hexupper:()=>rf,base32pad:()=>Qu,base32padupper:()=>tf,base32upper:()=>Ju,base32z:()=>sf});var Xt=ft({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Ju=ft({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Qu=ft({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),tf=ft({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),ef=ft({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),rf=ft({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),nf=ft({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),of=ft({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),sf=ft({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var go={};vt(go,{base36:()=>hr,base36upper:()=>af});var hr=ue({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),af=ue({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Gt={};vt(Gt,{Digest:()=>ve,create:()=>Dt,decode:()=>fe,equals:()=>xo,hasCode:()=>Bf});var cf=sa,na=128,uf=127,ff=~uf,lf=Math.pow(2,31);function sa(r,t,e){t=t||[],e=e||0;for(var n=e;r>=lf;)t[e++]=r&255|na,r/=128;for(;r&ff;)t[e++]=r&255|na,r>>>=7;return t[e]=r|0,sa.bytes=e-n+1,t}var hf=wo,df=128,oa=127;function wo(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw wo.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>=df);return wo.bytes=s-n,e}var pf=Math.pow(2,7),mf=Math.pow(2,14),yf=Math.pow(2,21),gf=Math.pow(2,28),wf=Math.pow(2,35),xf=Math.pow(2,42),bf=Math.pow(2,49),Ef=Math.pow(2,56),Sf=Math.pow(2,63),Af=function(r){return r<pf?1:r<mf?2:r<yf?3:r<gf?4:r<wf?5:r<xf?6:r<bf?7:r<Ef?8:r<Sf?9:10},vf={encode:cf,decode:hf,encodingLength:Af},If=vf,dr=If;function pr(r,t=0){return[dr.decode(r,t),dr.decode.bytes]}function ze(r,t,e=0){return dr.encode(r,t,e),t}function Ge(r){return dr.encodingLength(r)}function Dt(r,t){let e=t.byteLength,n=Ge(r),o=n+Ge(e),s=new Uint8Array(o+e);return ze(r,s,0),ze(e,s,n),s.set(t,o),new ve(r,e,t,s)}function fe(r){let t=Yt(r),[e,n]=pr(t),[o,s]=pr(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new ve(e,o,i,t)}function xo(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Xi(r.bytes,e.bytes)}}var ve=class{code;size;digest;bytes;constructor(t,e,n,o){this.code=t,this.size=e,this.digest=n,this.bytes=o}};function Bf(r,t){return r.code===t}function ia(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return _f(e,bo(r),t??et.encoder);default:return Tf(e,bo(r),t??Xt.encoder)}}var aa=new WeakMap;function bo(r){let t=aa.get(r);if(t==null){let e=new Map;return aa.set(r,e),e}return t}var lt=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!==mr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Cf)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=Dt(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&&xo(t.multihash,n.multihash)}toString(t){return ia(this,t)}toJSON(){return{"/":ia(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??ca(n,o,s.bytes))}else if(e[Pf]===!0){let{version:n,multihash:o,code:s}=e,i=fe(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!==mr)throw new Error(`Version 0 CID must use dag-pb (code: ${mr}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=ca(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,mr,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=Yt(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 ve(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[l,d]=pr(t.subarray(e));return e+=d,l},o=n(),s=mr;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(),f=e+c,u=f-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:u,size:f}}static parse(t,e){let[n,o]=Lf(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 bo(s).set(n,t),s}};function Lf(r,t){switch(r[0]){case"Q":{let e=t??et;return[et.prefix,e.decode(`${et.prefix}${r}`)]}case et.prefix:{let e=t??et;return[et.prefix,e.decode(r)]}case Xt.prefix:{let e=t??Xt;return[Xt.prefix,e.decode(r)]}case hr.prefix:{let e=t??hr;return[hr.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 _f(r,t,e){let{prefix:n}=e;if(n!==et.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 Tf(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 mr=112,Cf=18;function ca(r,t,e){let n=Ge(r),o=n+Ge(t),s=new Uint8Array(o+e.byteLength);return ze(r,s,0),ze(t,s,n),s.set(e,o),s}var Pf=Symbol.for("@ipld/js-cid/CID");var Eo={};vt(Eo,{identity:()=>Nt});var ua=0,Rf="identity",fa=Yt;function Uf(r){return Dt(ua,fa(r))}var Nt={code:ua,name:Rf,encode:fa,digest:Uf};function mt(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 yt(r=0){return new Uint8Array(r)}function gt(r=0){return new Uint8Array(r)}function It(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=gt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var ha=Symbol.for("@achingbrain/uint8arraylist");function la(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 rn(r){return!!r?.[ha]}var G=class r{bufs;length;[ha]=!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(rn(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(rn(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=la(this.bufs,t);return e.buf[e.index]}set(t,e){let n=la(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(rn(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 It(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:It(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 f=t>=a&&t<c,u=e>a&&e<=c;if(f&&u){if(t===a&&e===c){n.push(i);break}let l=t-a;n.push(i.subarray(l,l+(e-t)));break}if(f){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(!rn(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 l=0;l<s;l++)i[l]=-1;for(let l=0;l<o;l++)i[n[l]]=l;let a=i,c=this.byteLength-n.byteLength,f=n.byteLength-1,u;for(let l=e;l<=c;l+=u){u=0;for(let d=f;d>=0;d--){let g=this.get(l+d);if(n[d]!==g){u=Math.max(1,d-a[g]);break}}if(u===0)return l}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=gt(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=yt(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=yt(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=yt(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=gt(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=yt(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=yt(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=yt(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=yt(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=yt(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(!mt(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 So={};vt(So,{base10:()=>Df});var Df=ue({prefix:"9",name:"base10",alphabet:"0123456789"});var Ao={};vt(Ao,{base16:()=>Kf,base16upper:()=>Nf});var Kf=ft({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Nf=ft({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var vo={};vt(vo,{base2:()=>Mf});var Mf=ft({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Io={};vt(Io,{base256emoji:()=>Ff});var da=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}"),Of=da.reduce((r,t,e)=>(r[e]=t,r),[]),Hf=da.reduce((r,t,e)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return r[n]=e,r},[]);function qf(r){return r.reduce((t,e)=>(t+=Of[e],t),"")}function Vf(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=Hf[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var Ff=Fe({prefix:"\u{1F680}",name:"base256emoji",encode:qf,decode:Vf});var Lo={};vt(Lo,{base64:()=>zf,base64pad:()=>Gf,base64url:()=>Bo,base64urlpad:()=>Wf});var zf=ft({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Gf=ft({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Bo=ft({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Wf=ft({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var _o={};vt(_o,{base8:()=>jf});var jf=ft({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var To={};vt(To,{identity:()=>$f});var $f=Fe({prefix:"\0",name:"identity",encode:r=>Qi(r),decode:r=>Ji(r)});var d0=new TextEncoder,p0=new TextDecoder;var Ro={};vt(Ro,{sha256:()=>yr,sha512:()=>Xf});function Po({name:r,code:t,encode:e}){return new Co(r,t,e)}var Co=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?Dt(this.code,e):e.then(n=>Dt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function ma(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var yr=Po({name:"sha2-256",code:18,encode:ma("SHA-256")}),Xf=Po({name:"sha2-512",code:19,encode:ma("SHA-512")});var Ie={...To,...vo,..._o,...So,...Ao,...yo,...go,...mo,...Lo,...Io},B0={...Ro,...Eo};function ga(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var ya=ga("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Uo=ga("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=gt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),Jf={utf8:ya,"utf-8":ya,hex:Ie.base16,latin1:Uo,ascii:Uo,binary:Uo,...Ie},nn=Jf;function X(r,t="utf8"){let e=nn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function q(r,t="utf8"){let e=nn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var Qf=parseInt("11111",2),ko=parseInt("10000000",2),tl=parseInt("01111111",2),wa={0:gr,1:gr,2:el,3:ol,4:sl,5:nl,6:rl,16:gr,22:gr,48:gr};function Jt(r,t={offset:0}){let e=r[t.offset]&Qf;if(t.offset++,wa[e]!=null)return wa[e](r,t);throw new Error("No decoder for tag "+e)}function wr(r,t){let e=0;if((r[t.offset]&ko)===ko){let n=r[t.offset]&tl,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 gr(r,t){wr(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=Jt(r,t);if(n===null)break;e.push(n)}return e}function el(r,t){let e=wr(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 rl(r,t){let e=wr(r,t),n=t.offset+e,o=r[t.offset];t.offset++;let s=0,i=0;o<40?(s=0,i=o):o<80?(s=1,i=o-40):(s=2,i=o-80);let a=`${s}.${i}`,c=[];for(;t.offset<n;){let f=r[t.offset];if(t.offset++,c.push(f&127),f<128){c.reverse();let u=0;for(let l=0;l<c.length;l++)u+=c[l]<<l*7;a+=`.${u}`,c=[]}}return a}function nl(r,t){return t.offset++,null}function ol(r,t){let e=wr(r,t),n=r[t.offset];t.offset++;let o=r.subarray(t.offset,t.offset+e-1);if(t.offset+=e,n!==0)throw new Error("Unused bits in bit string is unimplemented");return o}function sl(r,t){let e=wr(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function il(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new G;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function Do(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=il(r.byteLength);return new G(Uint8Array.from([t.byteLength|ko]),t)}function Rt(r){let t=new G,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new G(Uint8Array.from([2]),Do(t),t)}function on(r){let t=Uint8Array.from([0]),e=new G(t,r);return new G(Uint8Array.from([3]),Do(e),e)}function le(r,t=48){let e=new G;for(let n of r)e.append(n);return new G(Uint8Array.from([t]),Do(e),e)}async function xa(r,t,e){let n=await crypto.subtle.importKey("jwk",r,{name:"ECDSA",namedCurve:r.crv??"P-256"},!1,["verify"]);return crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},n,t,e.subarray())}var al=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),cl=Uint8Array.from([6,5,43,129,4,0,34]),ul=Uint8Array.from([6,5,43,129,4,0,35]),fl={ext:!0,kty:"EC",crv:"P-256"},ll={ext:!0,kty:"EC",crv:"P-384"},hl={ext:!0,kty:"EC",crv:"P-521"},Ko=32,No=48,Mo=66;function Oo(r){let t=Jt(r);return ba(t)}function ba(r){let t=r[1][1][0],e=1,n,o;if(t.byteLength===Ko*2+1)return n=q(t.subarray(e,e+Ko),"base64url"),o=q(t.subarray(e+Ko),"base64url"),new We({...fl,key_ops:["verify"],x:n,y:o});if(t.byteLength===No*2+1)return n=q(t.subarray(e,e+No),"base64url"),o=q(t.subarray(e+No),"base64url"),new We({...ll,key_ops:["verify"],x:n,y:o});if(t.byteLength===Mo*2+1)return n=q(t.subarray(e,e+Mo),"base64url"),o=q(t.subarray(e+Mo),"base64url"),new We({...hl,key_ops:["verify"],x:n,y:o});throw new ut(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function Ea(r){return le([Rt(Uint8Array.from([1])),le([dl(r.crv)],160),le([on(new G(Uint8Array.from([4]),X(r.x??"","base64url"),X(r.y??"","base64url")))],161)]).subarray()}function dl(r){if(r==="P-256")return al;if(r==="P-384")return cl;if(r==="P-521")return ul;throw new ut(`Invalid curve ${r}`)}var We=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=Ea(this.jwk)),this._raw}toMultihash(){return Nt.digest(he(this))}toCID(){return lt.createV1(114,this.toMultihash())}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}async verify(t,e){return xa(this.jwk,e,t)}};function sn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function pl(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function je(r,...t){if(!pl(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 xr(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 $e(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 Sa(r,t){je(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}var Be=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function an(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Mt(r,t){return r<<32-t|r>>>t}function Aa(r){if(typeof r!="string")throw new Error("utf8ToBytes expected string, got "+typeof r);return new Uint8Array(new TextEncoder().encode(r))}function de(r){return typeof r=="string"&&(r=Aa(r)),je(r),r}function Ho(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];je(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 Ze=class{clone(){return this._cloneInto()}};function cn(r){let t=n=>r().update(de(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function br(r=32){if(Be&&typeof Be.getRandomValues=="function")return Be.getRandomValues(new Uint8Array(r));if(Be&&typeof Be.randomBytes=="function")return Be.randomBytes(r);throw new Error("crypto.getRandomValues must be defined")}function ml(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,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function va(r,t,e){return r&t^~r&e}function Ia(r,t,e){return r&t^r&e^t&e}var Ye=class extends Ze{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){$e(this);let{view:e,buffer:n,blockLen:o}=this;t=de(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){$e(this),Sa(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 l=i;l<o;l++)e[l]=0;ml(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 f=c/4,u=this.get();if(f>u.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<f;l++)a.setUint32(4*l,u[l],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 un=BigInt(4294967295),qo=BigInt(32);function Ba(r,t=!1){return t?{h:Number(r&un),l:Number(r>>qo&un)}:{h:Number(r>>qo&un)|0,l:Number(r&un)|0}}function yl(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}=Ba(r[o],t);[e[o],n[o]]=[s,i]}return[e,n]}var gl=(r,t)=>BigInt(r>>>0)<<qo|BigInt(t>>>0),wl=(r,t,e)=>r>>>e,xl=(r,t,e)=>r<<32-e|t>>>e,bl=(r,t,e)=>r>>>e|t<<32-e,El=(r,t,e)=>r<<32-e|t>>>e,Sl=(r,t,e)=>r<<64-e|t>>>e-32,Al=(r,t,e)=>r>>>e-32|t<<64-e,vl=(r,t)=>t,Il=(r,t)=>r,Bl=(r,t,e)=>r<<e|t>>>32-e,Ll=(r,t,e)=>t<<e|r>>>32-e,_l=(r,t,e)=>t<<e-32|r>>>64-e,Tl=(r,t,e)=>r<<e-32|t>>>64-e;function Cl(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var Pl=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),Rl=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Ul=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),kl=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,Dl=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),Kl=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var Nl={fromBig:Ba,split:yl,toBig:gl,shrSH:wl,shrSL:xl,rotrSH:bl,rotrSL:El,rotrBH:Sl,rotrBL:Al,rotr32H:vl,rotr32L:Il,rotlSH:Bl,rotlSL:Ll,rotlBH:_l,rotlBL:Tl,add:Cl,add3L:Pl,add3H:Rl,add4L:Ul,add4H:kl,add5H:Kl,add5L:Dl},F=Nl;var[Ml,Ol]=F.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))),pe=new Uint32Array(80),me=new Uint32Array(80),Vo=class extends Ye{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:f,El:u,Fh:l,Fl:d,Gh:g,Gl:w,Hh:m,Hl:h}=this;return[t,e,n,o,s,i,a,c,f,u,l,d,g,w,m,h]}set(t,e,n,o,s,i,a,c,f,u,l,d,g,w,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=f|0,this.El=u|0,this.Fh=l|0,this.Fl=d|0,this.Gh=g|0,this.Gl=w|0,this.Hh=m|0,this.Hl=h|0}process(t,e){for(let p=0;p<16;p++,e+=4)pe[p]=t.getUint32(e),me[p]=t.getUint32(e+=4);for(let p=16;p<80;p++){let B=pe[p-15]|0,P=me[p-15]|0,C=F.rotrSH(B,P,1)^F.rotrSH(B,P,8)^F.shrSH(B,P,7),_=F.rotrSL(B,P,1)^F.rotrSL(B,P,8)^F.shrSL(B,P,7),T=pe[p-2]|0,I=me[p-2]|0,M=F.rotrSH(T,I,19)^F.rotrBH(T,I,61)^F.shrSH(T,I,6),k=F.rotrSL(T,I,19)^F.rotrBL(T,I,61)^F.shrSL(T,I,6),N=F.add4L(_,k,me[p-7],me[p-16]),H=F.add4H(N,C,M,pe[p-7],pe[p-16]);pe[p]=H|0,me[p]=N|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:d,Fh:g,Fl:w,Gh:m,Gl:h,Hh:x,Hl:E}=this;for(let p=0;p<80;p++){let B=F.rotrSH(l,d,14)^F.rotrSH(l,d,18)^F.rotrBH(l,d,41),P=F.rotrSL(l,d,14)^F.rotrSL(l,d,18)^F.rotrBL(l,d,41),C=l&g^~l&m,_=d&w^~d&h,T=F.add5L(E,P,_,Ol[p],me[p]),I=F.add5H(T,x,B,C,Ml[p],pe[p]),M=T|0,k=F.rotrSH(n,o,28)^F.rotrBH(n,o,34)^F.rotrBH(n,o,39),N=F.rotrSL(n,o,28)^F.rotrBL(n,o,34)^F.rotrBL(n,o,39),H=n&s^n&a^s&a,v=o&i^o&c^i&c;x=m|0,E=h|0,m=g|0,h=w|0,g=l|0,w=d|0,{h:l,l:d}=F.add(f|0,u|0,I|0,M|0),f=a|0,u=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let L=F.add3L(M,N,v);n=F.add3H(L,I,k,H),o=L|0}({h:n,l:o}=F.add(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=F.add(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=F.add(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:u}=F.add(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:d}=F.add(this.Eh|0,this.El|0,l|0,d|0),{h:g,l:w}=F.add(this.Fh|0,this.Fl|0,g|0,w|0),{h:m,l:h}=F.add(this.Gh|0,this.Gl|0,m|0,h|0),{h:x,l:E}=F.add(this.Hh|0,this.Hl|0,x|0,E|0),this.set(n,o,s,i,a,c,f,u,l,d,g,w,m,h,x,E)}roundClean(){pe.fill(0),me.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 La=cn(()=>new Vo);var hn={};vt(hn,{aInRange:()=>bt,abool:()=>Ot,abytes:()=>Xe,bitGet:()=>Gl,bitLen:()=>Wo,bitMask:()=>Sr,bitSet:()=>Wl,bytesToHex:()=>te,bytesToNumberBE:()=>ee,bytesToNumberLE:()=>Ht,concatBytes:()=>ne,createHmacDrbg:()=>jo,ensureBytes:()=>rt,equalBytes:()=>Fl,hexToBytes:()=>_e,hexToNumber:()=>Go,inRange:()=>Er,isBytes:()=>ye,memoized:()=>Te,notImplemented:()=>$l,numberToBytesBE:()=>ge,numberToBytesLE:()=>re,numberToHexUnpadded:()=>Le,numberToVarBytesBE:()=>Vl,utf8ToBytes:()=>zl,validateObject:()=>Kt});var fn=BigInt(0),ln=BigInt(1),Hl=BigInt(2);function ye(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Xe(r){if(!ye(r))throw new Error("Uint8Array expected")}function Ot(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}var ql=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function te(r){Xe(r);let t="";for(let e=0;e<r.length;e++)t+=ql[r[e]];return t}function Le(r){let t=r.toString(16);return t.length&1?"0"+t:t}function Go(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?fn:BigInt("0x"+r)}var Qt={_0:48,_9:57,A:65,F:70,a:97,f:102};function _a(r){if(r>=Qt._0&&r<=Qt._9)return r-Qt._0;if(r>=Qt.A&&r<=Qt.F)return r-(Qt.A-10);if(r>=Qt.a&&r<=Qt.f)return r-(Qt.a-10)}function _e(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=_a(r.charCodeAt(s)),a=_a(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 ee(r){return Go(te(r))}function Ht(r){return Xe(r),Go(te(Uint8Array.from(r).reverse()))}function ge(r,t){return _e(r.toString(16).padStart(t*2,"0"))}function re(r,t){return ge(r,t).reverse()}function Vl(r){return _e(Le(r))}function rt(r,t,e){let n;if(typeof t=="string")try{n=_e(t)}catch(s){throw new Error(r+" must be hex string or Uint8Array, cause: "+s)}else if(ye(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 ne(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Xe(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 Fl(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 zl(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}var Fo=r=>typeof r=="bigint"&&fn<=r;function Er(r,t,e){return Fo(r)&&Fo(t)&&Fo(e)&&t<=r&&r<e}function bt(r,t,e,n){if(!Er(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Wo(r){let t;for(t=0;r>fn;r>>=ln,t+=1);return t}function Gl(r,t){return r>>BigInt(t)&ln}function Wl(r,t,e){return r|(e?ln:fn)<<BigInt(t)}var Sr=r=>(Hl<<BigInt(r-1))-ln,zo=r=>new Uint8Array(r),Ta=r=>Uint8Array.from(r);function jo(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=zo(r),o=zo(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>e(o,n,...l),c=(l=zo())=>{o=a(Ta([0]),l),n=a(),l.length!==0&&(o=a(Ta([1]),l),n=a())},f=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,d=[];for(;l<t;){n=a();let g=n.slice();d.push(g),l+=n.length}return ne(...d)};return(l,d)=>{i(),c(l);let g;for(;!(g=d(f()));)c();return i(),g}}var jl={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"||ye(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=jl[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 $l=()=>{throw new Error("not implemented")};function Te(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 wt=BigInt(0),at=BigInt(1),Ce=BigInt(2),Zl=BigInt(3),$o=BigInt(4),Ca=BigInt(5),Pa=BigInt(8),Yl=BigInt(9),Xl=BigInt(16);function Z(r,t){let e=r%t;return e>=wt?e:t+e}function Zo(r,t,e){if(t<wt)throw new Error("invalid exponent, negatives unsupported");if(e<=wt)throw new Error("invalid modulus");if(e===at)return wt;let n=at;for(;t>wt;)t&at&&(n=n*r%e),r=r*r%e,t>>=at;return n}function st(r,t,e){let n=r;for(;t-- >wt;)n*=n,n%=e;return n}function dn(r,t){if(r===wt)throw new Error("invert: expected non-zero number");if(t<=wt)throw new Error("invert: expected positive modulus, got "+t);let e=Z(r,t),n=t,o=wt,s=at,i=at,a=wt;for(;e!==wt;){let f=n/e,u=n%e,l=o-i*f,d=s-a*f;n=e,e=u,o=i,s=a,i=l,a=d}if(n!==at)throw new Error("invert: does not exist");return Z(o,t)}function Jl(r){let t=(r-at)/Ce,e,n,o;for(e=r-at,n=0;e%Ce===wt;e/=Ce,n++);for(o=Ce;o<r&&Zo(o,t,r)!==r-at;o++)if(o>1e3)throw new Error("Cannot find square root: likely non-prime P");if(n===1){let i=(r+at)/$o;return function(c,f){let u=c.pow(f,i);if(!c.eql(c.sqr(u),f))throw new Error("Cannot find square root");return u}}let s=(e+at)/Ce;return function(a,c){if(a.pow(c,t)===a.neg(a.ONE))throw new Error("Cannot find square root");let f=n,u=a.pow(a.mul(a.ONE,o),e),l=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<f&&!a.eql(m,a.ONE);g++)m=a.sqr(m);let w=a.pow(u,at<<BigInt(f-g-1));u=a.sqr(w),l=a.mul(l,w),d=a.mul(d,u),f=g}return l}}function Ql(r){if(r%$o===Zl){let t=(r+at)/$o;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%Pa===Ca){let t=(r-Ca)/Pa;return function(n,o){let s=n.mul(o,Ce),i=n.pow(s,t),a=n.mul(o,i),c=n.mul(n.mul(a,Ce),i),f=n.mul(a,n.sub(c,n.ONE));if(!n.eql(n.sqr(f),o))throw new Error("Cannot find square root");return f}}return r%Xl,Jl(r)}var Ra=(r,t)=>(Z(r,t)&at)===at,th=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Yo(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=th.reduce((n,o)=>(n[o]="function",n),t);return Kt(r,e)}function eh(r,t,e){if(e<wt)throw new Error("invalid exponent, negatives unsupported");if(e===wt)return r.ONE;if(e===at)return t;let n=r.ONE,o=t;for(;e>wt;)e&at&&(n=r.mul(n,o)),o=r.sqr(o),e>>=at;return n}function rh(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 Xo(r,t){let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function we(r,t,e=!1,n={}){if(r<=wt)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:o,nByteLength:s}=Xo(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:Sr(o),ZERO:wt,ONE:at,create:c=>Z(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return wt<=c&&c<r},is0:c=>c===wt,isOdd:c=>(c&at)===at,neg:c=>Z(-c,r),eql:(c,f)=>c===f,sqr:c=>Z(c*c,r),add:(c,f)=>Z(c+f,r),sub:(c,f)=>Z(c-f,r),mul:(c,f)=>Z(c*f,r),pow:(c,f)=>eh(a,c,f),div:(c,f)=>Z(c*dn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>dn(c,r),sqrt:n.sqrt||(c=>(i||(i=Ql(r)),i(a,c))),invertBatch:c=>rh(a,c),cmov:(c,f,u)=>u?f:c,toBytes:c=>e?re(c,s):ge(c,s),fromBytes:c=>{if(c.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+c.length);return e?Ht(c):ee(c)}});return Object.freeze(a)}function Ua(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 Jo(r){let t=Ua(r);return t+Math.ceil(t/2)}function ka(r,t,e=!1){let n=r.length,o=Ua(t),s=Jo(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?Ht(r):ee(r),a=Z(i,t-at)+at;return e?re(a,o):ge(a,o)}var Da=BigInt(0),pn=BigInt(1);function Qo(r,t){let e=t.negate();return r?e:t}function Ka(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function ts(r,t){Ka(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1);return{windows:e,windowSize:n}}function nh(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 oh(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 es=new WeakMap,Na=new WeakMap;function rs(r){return Na.get(r)||1}function mn(r,t){return{constTimeNegate:Qo,hasPrecomputes(e){return rs(e)!==1},unsafeLadder(e,n,o=r.ZERO){let s=e;for(;n>Da;)n&pn&&(o=o.add(s)),s=s.double(),n>>=pn;return o},precomputeWindow(e,n){let{windows:o,windowSize:s}=ts(n,t),i=[],a=e,c=a;for(let f=0;f<o;f++){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}=ts(e,t),a=r.ZERO,c=r.BASE,f=BigInt(2**e-1),u=2**e,l=BigInt(e);for(let d=0;d<s;d++){let g=d*i,w=Number(o&f);o>>=l,w>i&&(w-=u,o+=pn);let m=g,h=g+Math.abs(w)-1,x=d%2!==0,E=w<0;w===0?c=c.add(Qo(x,n[m])):a=a.add(Qo(E,n[h]))}return{p:a,f:c}},wNAFUnsafe(e,n,o,s=r.ZERO){let{windows:i,windowSize:a}=ts(e,t),c=BigInt(2**e-1),f=2**e,u=BigInt(e);for(let l=0;l<i;l++){let d=l*a;if(o===Da)break;let g=Number(o&c);if(o>>=u,g>a&&(g-=f,o+=pn),g===0)continue;let w=n[d+Math.abs(g)-1];g<0&&(w=w.negate()),s=s.add(w)}return s},getPrecomputes(e,n,o){let s=es.get(n);return s||(s=this.precomputeWindow(n,e),e!==1&&es.set(n,o(s))),s},wNAFCached(e,n,o){let s=rs(e);return this.wNAF(s,this.getPrecomputes(s,e,o),n)},wNAFCachedUnsafe(e,n,o,s){let i=rs(e);return i===1?this.unsafeLadder(e,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,e,o),n,s)},setWindowSize(e,n){Ka(n,t),Na.set(e,n),es.delete(e)}}}function yn(r,t,e,n){if(nh(e,r),oh(n,t),e.length!==n.length)throw new Error("arrays of points and scalars must have equal length");let o=r.ZERO,s=Wo(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),f=Math.floor((t.BITS-1)/i)*i,u=o;for(let l=f;l>=0;l-=i){c.fill(o);for(let g=0;g<n.length;g++){let w=n[g],m=Number(w>>BigInt(l)&BigInt(a));c[m]=c[m].add(e[g])}let d=o;for(let g=c.length-1,w=o;g>0;g--)w=w.add(c[g]),d=d.add(w);if(u=u.add(d),l!==0)for(let g=0;g<i;g++)u=u.double()}return u}function Ar(r){return Yo(r.Fp),Kt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...Xo(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var qt=BigInt(0),Ut=BigInt(1),gn=BigInt(2),sh=BigInt(8),ih={zip215:!0};function ah(r){let t=Ar(r);return Kt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Ma(r){let t=ah(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,f=gn<<BigInt(a*8)-Ut,u=e.create,l=we(t.n,t.nBitLength),d=t.uvRatio||((b,y)=>{try{return{isValid:!0,value:e.sqrt(b*e.inv(y))}}catch{return{isValid:!1,value:qt}}}),g=t.adjustScalarBytes||(b=>b),w=t.domain||((b,y,A)=>{if(Ot("phflag",A),y.length||A)throw new Error("Contexts/pre-hash are not supported");return b});function m(b,y){bt("coordinate "+b,y,qt,f)}function h(b){if(!(b instanceof p))throw new Error("ExtendedPoint expected")}let x=Te((b,y)=>{let{ex:A,ey:S,ez:R}=b,U=b.is0();y==null&&(y=U?sh:e.inv(R));let K=u(A*y),V=u(S*y),O=u(R*y);if(U)return{x:qt,y:Ut};if(O!==Ut)throw new Error("invZ was invalid");return{x:K,y:V}}),E=Te(b=>{let{a:y,d:A}=t;if(b.is0())throw new Error("bad point: ZERO");let{ex:S,ey:R,ez:U,et:K}=b,V=u(S*S),O=u(R*R),z=u(U*U),$=u(z*z),nt=u(V*y),ot=u(z*u(nt+O)),it=u($+u(A*u(V*O)));if(ot!==it)throw new Error("bad point: equation left != right (1)");let At=u(S*R),Pt=u(U*K);if(At!==Pt)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(y,A,S,R){this.ex=y,this.ey=A,this.ez=S,this.et=R,m("x",y),m("y",A),m("z",S),m("t",R),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,R)=>S.toAffine(A[R])).map(p.fromAffine)}static msm(y,A){return yn(p,l,y,A)}_setWindowSize(y){C.setWindowSize(this,y)}assertValidity(){E(this)}equals(y){h(y);let{ex:A,ey:S,ez:R}=this,{ex:U,ey:K,ez:V}=y,O=u(A*V),z=u(U*R),$=u(S*V),nt=u(K*R);return O===z&&$===nt}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:R}=this,U=u(A*A),K=u(S*S),V=u(gn*u(R*R)),O=u(y*U),z=A+S,$=u(u(z*z)-U-K),nt=O+K,ot=nt-V,it=O-K,At=u($*ot),Pt=u(nt*it),Ct=u($*it),zt=u(ot*nt);return new p(At,Pt,zt,Ct)}add(y){h(y);let{a:A,d:S}=t,{ex:R,ey:U,ez:K,et:V}=this,{ex:O,ey:z,ez:$,et:nt}=y;if(A===BigInt(-1)){let Vi=u((U-R)*(z+O)),Fi=u((U+R)*(z-O)),ao=u(Fi-Vi);if(ao===qt)return this.double();let zi=u(K*gn*nt),Gi=u(V*gn*$),Wi=Gi+zi,ji=Fi+Vi,$i=Gi-zi,Nu=u(Wi*ao),Mu=u(ji*$i),Ou=u(Wi*$i),Hu=u(ao*ji);return new p(Nu,Mu,Hu,Ou)}let ot=u(R*O),it=u(U*z),At=u(V*S*nt),Pt=u(K*$),Ct=u((R+U)*(O+z)-ot-it),zt=Pt-At,Zt=Pt+At,lr=u(it-A*ot),Uu=u(Ct*zt),ku=u(Zt*lr),Du=u(Ct*lr),Ku=u(zt*Zt);return new p(Uu,ku,Ku,Du)}subtract(y){return this.add(y.negate())}wNAF(y){return C.wNAFCached(this,y,p.normalizeZ)}multiply(y){let A=y;bt("scalar",A,Ut,n);let{p:S,f:R}=this.wNAF(A);return p.normalizeZ([S,R])[0]}multiplyUnsafe(y,A=p.ZERO){let S=y;return bt("scalar",S,qt,n),S===qt?P:this.is0()||S===Ut?this:C.wNAFCachedUnsafe(this,S,p.normalizeZ,A)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return C.unsafeLadder(this,n).is0()}toAffine(y){return x(this,y)}clearCofactor(){let{h:y}=t;return y===Ut?this:this.multiplyUnsafe(y)}static fromHex(y,A=!1){let{d:S,a:R}=t,U=e.BYTES;y=rt("pointHex",y,U),Ot("zip215",A);let K=y.slice(),V=y[U-1];K[U-1]=V&-129;let O=Ht(K),z=A?f:e.ORDER;bt("pointHex.y",O,qt,z);let $=u(O*O),nt=u($-Ut),ot=u(S*$-R),{isValid:it,value:At}=d(nt,ot);if(!it)throw new Error("Point.fromHex: invalid y coordinate");let Pt=(At&Ut)===Ut,Ct=(V&128)!==0;if(!A&&At===qt&&Ct)throw new Error("Point.fromHex: x=0 and x_0=1");return Ct!==Pt&&(At=u(-At)),p.fromAffine({x:At,y:O})}static fromPrivateKey(y){return I(y).point}toRawBytes(){let{x:y,y:A}=this.toAffine(),S=re(A,e.BYTES);return S[S.length-1]|=y&Ut?128:0,S}toHex(){return te(this.toRawBytes())}}p.BASE=new p(t.Gx,t.Gy,Ut,u(t.Gx*t.Gy)),p.ZERO=new p(qt,Ut,Ut,qt);let{BASE:B,ZERO:P}=p,C=mn(p,a*8);function _(b){return Z(b,n)}function T(b){return _(Ht(b))}function I(b){let y=e.BYTES;b=rt("private key",b,y);let A=rt("hashed private key",s(b),2*y),S=g(A.slice(0,y)),R=A.slice(y,2*y),U=T(S),K=B.multiply(U),V=K.toRawBytes();return{head:S,prefix:R,scalar:U,point:K,pointBytes:V}}function M(b){return I(b).pointBytes}function k(b=new Uint8Array,...y){let A=ne(...y);return T(s(w(A,rt("context",b),!!o)))}function N(b,y,A={}){b=rt("message",b),o&&(b=o(b));let{prefix:S,scalar:R,pointBytes:U}=I(y),K=k(A.context,S,b),V=B.multiply(K).toRawBytes(),O=k(A.context,V,U,b),z=_(K+O*R);bt("signature.s",z,qt,n);let $=ne(V,re(z,e.BYTES));return rt("result",$,e.BYTES*2)}let H=ih;function v(b,y,A,S=H){let{context:R,zip215:U}=S,K=e.BYTES;b=rt("signature",b,2*K),y=rt("message",y),A=rt("publicKey",A,K),U!==void 0&&Ot("zip215",U),o&&(y=o(y));let V=Ht(b.slice(K,2*K)),O,z,$;try{O=p.fromHex(A,U),z=p.fromHex(b.slice(0,K),U),$=B.multiplyUnsafe(V)}catch{return!1}if(!U&&O.isSmallOrder())return!1;let nt=k(R,z.toRawBytes(),O.toRawBytes(),y);return z.add(O.multiplyUnsafe(nt)).subtract($).clearCofactor().equals(p.ZERO)}return B._setWindowSize(8),{CURVE:t,getPublicKey:M,sign:N,verify:v,ExtendedPoint:p,utils:{getExtendedPublicKey:I,randomPrivateKey:()=>i(e.BYTES),precompute(b=8,y=p.BASE){return y._setWindowSize(b),y.multiply(BigInt(3)),y}}}}var Je=BigInt(0),ns=BigInt(1);function ch(r){return Kt(r,{a:"bigint"},{montgomeryBits:"isSafeInteger",nByteLength:"isSafeInteger",adjustScalarBytes:"function",domain:"function",powPminus2:"function",Gu:"bigint"}),Object.freeze({...r})}function Oa(r){let t=ch(r),{P:e}=t,n=E=>Z(E,e),o=t.montgomeryBits,s=Math.ceil(o/8),i=t.nByteLength,a=t.adjustScalarBytes||(E=>E),c=t.powPminus2||(E=>Zo(E,e-BigInt(2),e));function f(E,p,B){let P=n(E*(p-B));return p=n(p-P),B=n(B+P),[p,B]}let u=(t.a-BigInt(2))/BigInt(4);function l(E,p){bt("u",E,Je,e),bt("scalar",p,Je,e);let B=p,P=E,C=ns,_=Je,T=E,I=ns,M=Je,k;for(let H=BigInt(o-1);H>=Je;H--){let v=B>>H&ns;M^=v,k=f(M,C,T),C=k[0],T=k[1],k=f(M,_,I),_=k[0],I=k[1],M=v;let L=C+_,b=n(L*L),y=C-_,A=n(y*y),S=b-A,R=T+I,U=T-I,K=n(U*L),V=n(R*y),O=K+V,z=K-V;T=n(O*O),I=n(P*n(z*z)),C=n(b*A),_=n(S*(b+n(u*S)))}k=f(M,C,T),C=k[0],T=k[1],k=f(M,_,I),_=k[0],I=k[1];let N=c(_);return n(C*N)}function d(E){return re(n(E),s)}function g(E){let p=rt("u coordinate",E,s);return i===32&&(p[31]&=127),Ht(p)}function w(E){let p=rt("scalar",E),B=p.length;if(B!==s&&B!==i){let P=""+s+" or "+i;throw new Error("invalid scalar, expected "+P+" bytes, got "+B)}return Ht(a(p))}function m(E,p){let B=g(p),P=w(E),C=l(B,P);if(C===Je)throw new Error("invalid private or public key received");return d(C)}let h=d(t.Gu);function x(E){return m(E,h)}return{scalarMult:m,scalarMultBase:x,getSharedSecret:(E,p)=>m(E,p),getPublicKey:E=>x(E),utils:{randomPrivateKey:()=>t.randomBytes(t.nByteLength)},GuBytes:h}}var vr=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ha=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),km=BigInt(0),uh=BigInt(1),qa=BigInt(2),fh=BigInt(3),lh=BigInt(5),hh=BigInt(8);function Va(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=vr,a=r*r%s*r%s,c=st(a,qa,s)*a%s,f=st(c,uh,s)*r%s,u=st(f,lh,s)*f%s,l=st(u,t,s)*u%s,d=st(l,e,s)*l%s,g=st(d,n,s)*d%s,w=st(g,o,s)*g%s,m=st(w,o,s)*g%s,h=st(m,t,s)*u%s;return{pow_p_5_8:st(h,qa,s)*r%s,b2:a}}function Fa(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function dh(r,t){let e=vr,n=Z(t*t*t,e),o=Z(n*n*t,e),s=Va(r*o).pow_p_5_8,i=Z(r*n*s,e),a=Z(t*i*i,e),c=i,f=Z(i*Ha,e),u=a===r,l=a===Z(-r,e),d=a===Z(-r*Ha,e);return u&&(i=c),(l||d)&&(i=f),Ra(i,e)&&(i=Z(-i,e)),{isValid:u||l,value:i}}var ph=we(vr,void 0,!0),mh={a:BigInt(-1),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:ph,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:hh,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:La,randomBytes:br,adjustScalarBytes:Fa,uvRatio:dh},za=Ma(mh);var Ir=Oa({P:vr,a:BigInt(486662),montgomeryBits:255,nByteLength:32,Gu:BigInt(9),powPminus2:r=>{let t=vr,{pow_p_5_8:e,b2:n}=Va(r);return Z(st(e,fh,t)*n,t)},adjustScalarBytes:Fa,randomBytes:br});var wn=32;function Ga(r,t,e){return za.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var xn=class{type="Ed25519";raw;constructor(t){this.raw=os(t,wn)}toMultihash(){return Nt.digest(he(this))}toCID(){return lt.createV1(114,this.toMultihash())}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return Ga(this.raw,e,t)}};function ss(r){return r=os(r,wn),new xn(r)}function os(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new ut(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var gh=Math.pow(2,7),wh=Math.pow(2,14),xh=Math.pow(2,21),is=Math.pow(2,28),as=Math.pow(2,35),cs=Math.pow(2,42),us=Math.pow(2,49),J=128,Bt=127;function pt(r){if(r<gh)return 1;if(r<wh)return 2;if(r<xh)return 3;if(r<is)return 4;if(r<as)return 5;if(r<cs)return 6;if(r<us)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function fs(r,t,e=0){switch(pt(r)){case 8:t[e++]=r&255|J,r/=128;case 7:t[e++]=r&255|J,r/=128;case 6:t[e++]=r&255|J,r/=128;case 5:t[e++]=r&255|J,r/=128;case 4:t[e++]=r&255|J,r>>>=7;case 3:t[e++]=r&255|J,r>>>=7;case 2:t[e++]=r&255|J,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function bh(r,t,e=0){switch(pt(r)){case 8:t.set(e++,r&255|J),r/=128;case 7:t.set(e++,r&255|J),r/=128;case 6:t.set(e++,r&255|J),r/=128;case 5:t.set(e++,r&255|J),r/=128;case 4:t.set(e++,r&255|J),r>>>=7;case 3:t.set(e++,r&255|J),r>>>=7;case 2:t.set(e++,r&255|J),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function ls(r,t){let e=r[t],n=0;if(n+=e&Bt,e<J||(e=r[t+1],n+=(e&Bt)<<7,e<J)||(e=r[t+2],n+=(e&Bt)<<14,e<J)||(e=r[t+3],n+=(e&Bt)<<21,e<J)||(e=r[t+4],n+=(e&Bt)*is,e<J)||(e=r[t+5],n+=(e&Bt)*as,e<J)||(e=r[t+6],n+=(e&Bt)*cs,e<J)||(e=r[t+7],n+=(e&Bt)*us,e<J))return n;throw new RangeError("Could not decode varint")}function Eh(r,t){let e=r.get(t),n=0;if(n+=e&Bt,e<J||(e=r.get(t+1),n+=(e&Bt)<<7,e<J)||(e=r.get(t+2),n+=(e&Bt)<<14,e<J)||(e=r.get(t+3),n+=(e&Bt)<<21,e<J)||(e=r.get(t+4),n+=(e&Bt)*is,e<J)||(e=r.get(t+5),n+=(e&Bt)*as,e<J)||(e=r.get(t+6),n+=(e&Bt)*cs,e<J)||(e=r.get(t+7),n+=(e&Bt)*us,e<J))return n;throw new RangeError("Could not decode varint")}function Wt(r,t,e=0){return t==null&&(t=gt(pt(r))),t instanceof Uint8Array?fs(r,t,e):bh(r,t,e)}function Vt(r,t=0){return r instanceof Uint8Array?ls(r,t):Eh(r,t)}var hs=new Float32Array([-0]),xe=new Uint8Array(hs.buffer);function ja(r,t,e){hs[0]=r,t[e]=xe[0],t[e+1]=xe[1],t[e+2]=xe[2],t[e+3]=xe[3]}function $a(r,t){return xe[0]=r[t],xe[1]=r[t+1],xe[2]=r[t+2],xe[3]=r[t+3],hs[0]}var ds=new Float64Array([-0]),Lt=new Uint8Array(ds.buffer);function Za(r,t,e){ds[0]=r,t[e]=Lt[0],t[e+1]=Lt[1],t[e+2]=Lt[2],t[e+3]=Lt[3],t[e+4]=Lt[4],t[e+5]=Lt[5],t[e+6]=Lt[6],t[e+7]=Lt[7]}function Ya(r,t){return Lt[0]=r[t],Lt[1]=r[t+1],Lt[2]=r[t+2],Lt[3]=r[t+3],Lt[4]=r[t+4],Lt[5]=r[t+5],Lt[6]=r[t+6],Lt[7]=r[t+7],ds[0]}var Sh=BigInt(Number.MAX_SAFE_INTEGER),Ah=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 Pe;if(t<Sh&&t>Ah)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>Xa&&(o=0n,++n>Xa&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Pe;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):Pe}},Pe=new kt(0,0);Pe.toBigInt=function(){return 0n};Pe.zzEncode=Pe.zzDecode=function(){return this};Pe.length=function(){return 1};var Xa=4294967296n;function Ja(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 Qa(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 ps(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 Ft(r,t){return RangeError(`index out of range: ${r.pos} + ${t??1} > ${r.len}`)}function bn(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var ms=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,Ft(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 Ft(this,4);return bn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ft(this,4);return bn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ft(this,4);let t=$a(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ft(this,4);let t=Ya(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 Ft(this,t);return this.pos+=t,e===n?new Uint8Array(0):this.buf.subarray(e,n)}string(){let t=this.bytes();return Qa(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ft(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ft(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 Ft(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 Ft(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 Ft(this,8);let t=bn(this.buf,this.pos+=4),e=bn(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=ls(this.buf,this.pos);return this.pos+=pt(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 ys(r){return new ms(r instanceof Uint8Array?r:r.subarray())}function Re(r,t,e){let n=ys(r);return t.decode(n,void 0,e)}function gs(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return gt(i);o+i>t&&(n=gt(t),o=0);let a=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),a}}var Ue=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function ws(){}var bs=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},vh=gs();function Ih(r){return globalThis.Buffer!=null?gt(r):vh(r)}var _r=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ue(ws,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ue(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new Es((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(En,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(En,e.length(),e)}uint64Number(t){return this._push(fs,pt(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(En,e.length(),e)}sint64Number(t){let e=kt.fromNumber(t).zzEncode();return this._push(En,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(xs,1,t?1:0)}fixed32(t){return this._push(Lr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=kt.fromBigInt(t);return this._push(Lr,4,e.lo)._push(Lr,4,e.hi)}fixed64Number(t){let e=kt.fromNumber(t);return this._push(Lr,4,e.lo)._push(Lr,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(ja,4,t)}double(t){return this._push(Za,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(xs,1,0):this.uint32(e)._push(Lh,e,t)}string(t){let e=Ja(t);return e!==0?this.uint32(e)._push(ps,e,t):this._push(xs,1,0)}fork(){return this.states=new bs(this),this.head=this.tail=new Ue(ws,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 Ue(ws,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=Ih(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function xs(r,t,e){t[e]=r&255}function Bh(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var Es=class extends Ue{next;constructor(t,e){super(Bh,t,e),this.next=void 0}};function En(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 Lr(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 Lh(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(_r.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(_h,t,r),this},_r.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(Th,t,r),this});function _h(r,t,e){t.set(r,e)}function Th(r,t,e){r.length<40?ps(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(X(r),e)}function Ss(){return new _r}function ke(r,t){let e=Ss();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var Qe;(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"})(Qe||(Qe={}));function Sn(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function As(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 Sn("enum",Qe.VARINT,e,n)}function De(r,t){return Sn("message",Qe.LENGTH_DELIMITED,r,t)}var Tr=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var ht;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(ht||(ht={}));var vs;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(vs||(vs={}));(function(r){r.codec=()=>As(vs)})(ht||(ht={}));var jt;(function(r){let t;r.codec=()=>(t==null&&(t=De((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ht.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=ht.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>ke(e,r.codec()),r.decode=(e,n)=>Re(e,r.codec(),n)})(jt||(jt={}));var Is;(function(r){let t;r.codec=()=>(t==null&&(t=De((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ht.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=ht.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>ke(e,r.codec()),r.decode=(e,n)=>Re(e,r.codec(),n)})(Is||(Is={}));var Cr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},An=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var rc={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new An("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=rc;var Rr={};vt(Rr,{MAX_RSA_KEY_SIZE:()=>Ls,generateRSAKeyPair:()=>ic,jwkToJWKKeyPair:()=>ac,jwkToPkcs1:()=>kh,jwkToPkix:()=>Ps,jwkToRSAPrivateKey:()=>Ds,pkcs1MessageToJwk:()=>Ts,pkcs1MessageToRSAPrivateKey:()=>Rs,pkcs1ToJwk:()=>Uh,pkcs1ToRSAPrivateKey:()=>sc,pkixMessageToJwk:()=>Cs,pkixMessageToRSAPublicKey:()=>ks,pkixToJwk:()=>Dh,pkixToRSAPublicKey:()=>Us});var Ch=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]),Ee=new Uint32Array([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Se=new Uint32Array(64),Bs=class extends Ye{constructor(){super(64,32,8,!1),this.A=Ee[0]|0,this.B=Ee[1]|0,this.C=Ee[2]|0,this.D=Ee[3]|0,this.E=Ee[4]|0,this.F=Ee[5]|0,this.G=Ee[6]|0,this.H=Ee[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 l=0;l<16;l++,e+=4)Se[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let d=Se[l-15],g=Se[l-2],w=Mt(d,7)^Mt(d,18)^d>>>3,m=Mt(g,17)^Mt(g,19)^g>>>10;Se[l]=m+Se[l-7]+w+Se[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:f,H:u}=this;for(let l=0;l<64;l++){let d=Mt(a,6)^Mt(a,11)^Mt(a,25),g=u+d+va(a,c,f)+Ch[l]+Se[l]|0,m=(Mt(n,2)^Mt(n,13)^Mt(n,22))+Ia(n,o,s)|0;u=f,f=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,f=f+this.G|0,u=u+this.H|0,this.set(n,o,s,i,a,c,f,u)}roundClean(){Se.fill(0)}destroy(){this.set(0,0,0,0,0,0,0,0),this.buffer.fill(0)}};var $t=cn(()=>new Bs);var tr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Rr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return lt.createV1(114,this._multihash)}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return oc(this.jwk,e,t)}},Pr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Rr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}sign(t){return nc(this.jwk,t)}};var Ls=8192,_s=18,Ph=1062,Rh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function Uh(r){let t=Jt(r);return Ts(t)}function Ts(r){return{n:q(r[1],"base64url"),e:q(r[2],"base64url"),d:q(r[3],"base64url"),p:q(r[4],"base64url"),q:q(r[5],"base64url"),dp:q(r[6],"base64url"),dq:q(r[7],"base64url"),qi:q(r[8],"base64url"),kty:"RSA"}}function kh(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 ut("JWK was missing components");return le([Rt(Uint8Array.from([0])),Rt(X(r.n,"base64url")),Rt(X(r.e,"base64url")),Rt(X(r.d,"base64url")),Rt(X(r.p,"base64url")),Rt(X(r.q,"base64url")),Rt(X(r.dp,"base64url")),Rt(X(r.dq,"base64url")),Rt(X(r.qi,"base64url"))]).subarray()}function Dh(r){let t=Jt(r,{offset:0});return Cs(t)}function Cs(r){let t=Jt(r[1],{offset:0});return{kty:"RSA",n:q(t[0],"base64url"),e:q(t[1],"base64url")}}function Ps(r){if(r.n==null||r.e==null)throw new ut("JWK was missing components");return le([Rh,on(le([Rt(X(r.n,"base64url")),Rt(X(r.e,"base64url"))]))]).subarray()}function sc(r){let t=Jt(r);return Rs(t)}function Rs(r){let t=Ts(r);return Ds(t)}function Us(r,t){if(r.byteLength>=Ph)throw new Ve("Key size is too large");let e=Jt(r,{offset:0});return ks(e,r,t)}function ks(r,t,e){let n=Cs(r);if(e==null){let o=$t(jt.encode({Type:ht.RSA,Data:t}));e=Dt(_s,o)}return new tr(n,e)}function Ds(r){if(uc(r)>Ls)throw new ut("Key size is too large");let t=ac(r),e=$t(jt.encode({Type:ht.RSA,Data:Ps(t.publicKey)})),n=Dt(_s,e);return new Pr(t.privateKey,new tr(t.publicKey,n))}async function ic(r){if(r>Ls)throw new ut("Key size is too large");let t=await cc(r),e=$t(jt.encode({Type:ht.RSA,Data:Ps(t.publicKey)})),n=Dt(_s,e);return new Pr(t.privateKey,new tr(t.publicKey,n))}function ac(r){if(r==null)throw new ut("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function cc(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 Kh(t);return{privateKey:e[0],publicKey:e[1]}}async function nc(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 oc(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 Kh(r){if(r.privateKey==null||r.publicKey==null)throw new ut("Private and public key are required");return Promise.all([be.get().subtle.exportKey("jwk",r.privateKey),be.get().subtle.exportKey("jwk",r.publicKey)])}function uc(r){if(r.kty!=="RSA")throw new ut("invalid key type");if(r.n==null)throw new ut("invalid key modulus");return X(r.n,"base64url").length*8}var vn=class extends Ze{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,xr(t);let n=de(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 $e(this),this.iHash.update(t),this}digestInto(t){$e(this),je(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()}},er=(r,t,e)=>new vn(r,t).update(e).digest();er.create=(r,t)=>new vn(r,t);function fc(r){r.lowS!==void 0&&Ot("lowS",r.lowS),r.prehash!==void 0&&Ot("prehash",r.prehash)}function Nh(r){let t=Ar(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:Mh,hexToBytes:Oh}=hn,Ks=class extends Error{constructor(t=""){super(t)}},oe={Err:Ks,_tlv:{encode:(r,t)=>{let{Err:e}=oe;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=Le(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?Le(o.length/2|128):"";return Le(r)+s+o+t},decode(r,t){let{Err:e}=oe,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 f=t.subarray(n,n+c);if(f.length!==c)throw new e("tlv.decode: length bytes not complete");if(f[0]===0)throw new e("tlv.decode(long): zero leftmost byte");for(let u of f)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}=oe;if(r<se)throw new t("integer: negative integers are not allowed");let e=Le(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}=oe;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 Mh(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=oe,o=typeof r=="string"?Oh(r):r;Xe(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:f,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(f)}},hexFromSig(r){let{_tlv:t,_int:e}=oe,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}},se=BigInt(0),xt=BigInt(1),ug=BigInt(2),lc=BigInt(3),fg=BigInt(4);function Hh(r){let t=Nh(r),{Fp:e}=t,n=we(t.n,t.nBitLength),o=t.toBytes||((m,h,x)=>{let E=h.toAffine();return ne(Uint8Array.from([4]),e.toBytes(E.x),e.toBytes(E.y))}),s=t.fromBytes||(m=>{let h=m.subarray(1),x=e.fromBytes(h.subarray(0,e.BYTES)),E=e.fromBytes(h.subarray(e.BYTES,2*e.BYTES));return{x,y:E}});function i(m){let{a:h,b:x}=t,E=e.sqr(m),p=e.mul(E,m);return e.add(e.add(p,e.mul(m,h)),x)}if(!e.eql(e.sqr(t.Gy),i(t.Gx)))throw new Error("bad generator point: equation left != right");function a(m){return Er(m,xt,t.n)}function c(m){let{allowedPrivateKeyLengths:h,nByteLength:x,wrapPrivateKey:E,n:p}=t;if(h&&typeof m!="bigint"){if(ye(m)&&(m=te(m)),typeof m!="string"||!h.includes(m.length))throw new Error("invalid private key");m=m.padStart(x*2,"0")}let B;try{B=typeof m=="bigint"?m:ee(rt("private key",m,x))}catch{throw new Error("invalid private key, expected hex or "+x+" bytes, got "+typeof m)}return E&&(B=Z(B,p)),bt("private key",B,xt,p),B}function f(m){if(!(m instanceof d))throw new Error("ProjectivePoint expected")}let u=Te((m,h)=>{let{px:x,py:E,pz:p}=m;if(e.eql(p,e.ONE))return{x,y:E};let B=m.is0();h==null&&(h=B?e.ONE:e.inv(p));let P=e.mul(x,h),C=e.mul(E,h),_=e.mul(p,h);if(B)return{x:e.ZERO,y:e.ZERO};if(!e.eql(_,e.ONE))throw new Error("invZ was invalid");return{x:P,y:C}}),l=Te(m=>{if(m.is0()){if(t.allowInfinityPoint&&!e.is0(m.py))return;throw new Error("bad point: ZERO")}let{x:h,y:x}=m.toAffine();if(!e.isValid(h)||!e.isValid(x))throw new Error("bad point: x or y not FE");let E=e.sqr(x),p=i(h);if(!e.eql(E,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,x,E){if(this.px=h,this.py=x,this.pz=E,h==null||!e.isValid(h))throw new Error("x required");if(x==null||!e.isValid(x))throw new Error("y required");if(E==null||!e.isValid(E))throw new Error("z required");Object.freeze(this)}static fromAffine(h){let{x,y:E}=h||{};if(!h||!e.isValid(x)||!e.isValid(E))throw new Error("invalid affine point");if(h instanceof d)throw new Error("projective point not allowed");let p=B=>e.eql(B,e.ZERO);return p(x)&&p(E)?d.ZERO:new d(x,E,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(h){let x=e.invertBatch(h.map(E=>E.pz));return h.map((E,p)=>E.toAffine(x[p])).map(d.fromAffine)}static fromHex(h){let x=d.fromAffine(s(rt("pointHex",h)));return x.assertValidity(),x}static fromPrivateKey(h){return d.BASE.multiply(c(h))}static msm(h,x){return yn(d,n,h,x)}_setWindowSize(h){w.setWindowSize(this,h)}assertValidity(){l(this)}hasEvenY(){let{y:h}=this.toAffine();if(e.isOdd)return!e.isOdd(h);throw new Error("Field doesn't support isOdd")}equals(h){f(h);let{px:x,py:E,pz:p}=this,{px:B,py:P,pz:C}=h,_=e.eql(e.mul(x,C),e.mul(B,p)),T=e.eql(e.mul(E,C),e.mul(P,p));return _&&T}negate(){return new d(this.px,e.neg(this.py),this.pz)}double(){let{a:h,b:x}=t,E=e.mul(x,lc),{px:p,py:B,pz:P}=this,C=e.ZERO,_=e.ZERO,T=e.ZERO,I=e.mul(p,p),M=e.mul(B,B),k=e.mul(P,P),N=e.mul(p,B);return N=e.add(N,N),T=e.mul(p,P),T=e.add(T,T),C=e.mul(h,T),_=e.mul(E,k),_=e.add(C,_),C=e.sub(M,_),_=e.add(M,_),_=e.mul(C,_),C=e.mul(N,C),T=e.mul(E,T),k=e.mul(h,k),N=e.sub(I,k),N=e.mul(h,N),N=e.add(N,T),T=e.add(I,I),I=e.add(T,I),I=e.add(I,k),I=e.mul(I,N),_=e.add(_,I),k=e.mul(B,P),k=e.add(k,k),I=e.mul(k,N),C=e.sub(C,I),T=e.mul(k,M),T=e.add(T,T),T=e.add(T,T),new d(C,_,T)}add(h){f(h);let{px:x,py:E,pz:p}=this,{px:B,py:P,pz:C}=h,_=e.ZERO,T=e.ZERO,I=e.ZERO,M=t.a,k=e.mul(t.b,lc),N=e.mul(x,B),H=e.mul(E,P),v=e.mul(p,C),L=e.add(x,E),b=e.add(B,P);L=e.mul(L,b),b=e.add(N,H),L=e.sub(L,b),b=e.add(x,p);let y=e.add(B,C);return b=e.mul(b,y),y=e.add(N,v),b=e.sub(b,y),y=e.add(E,p),_=e.add(P,C),y=e.mul(y,_),_=e.add(H,v),y=e.sub(y,_),I=e.mul(M,b),_=e.mul(k,v),I=e.add(_,I),_=e.sub(H,I),I=e.add(H,I),T=e.mul(_,I),H=e.add(N,N),H=e.add(H,N),v=e.mul(M,v),b=e.mul(k,b),H=e.add(H,v),v=e.sub(N,v),v=e.mul(M,v),b=e.add(b,v),N=e.mul(H,b),T=e.add(T,N),N=e.mul(y,b),_=e.mul(L,_),_=e.sub(_,N),N=e.mul(L,H),I=e.mul(y,I),I=e.add(I,N),new d(_,T,I)}subtract(h){return this.add(h.negate())}is0(){return this.equals(d.ZERO)}wNAF(h){return w.wNAFCached(this,h,d.normalizeZ)}multiplyUnsafe(h){let{endo:x,n:E}=t;bt("scalar",h,se,E);let p=d.ZERO;if(h===se)return p;if(this.is0()||h===xt)return this;if(!x||w.hasPrecomputes(this))return w.wNAFCachedUnsafe(this,h,d.normalizeZ);let{k1neg:B,k1:P,k2neg:C,k2:_}=x.splitScalar(h),T=p,I=p,M=this;for(;P>se||_>se;)P&xt&&(T=T.add(M)),_&xt&&(I=I.add(M)),M=M.double(),P>>=xt,_>>=xt;return B&&(T=T.negate()),C&&(I=I.negate()),I=new d(e.mul(I.px,x.beta),I.py,I.pz),T.add(I)}multiply(h){let{endo:x,n:E}=t;bt("scalar",h,xt,E);let p,B;if(x){let{k1neg:P,k1:C,k2neg:_,k2:T}=x.splitScalar(h),{p:I,f:M}=this.wNAF(C),{p:k,f:N}=this.wNAF(T);I=w.constTimeNegate(P,I),k=w.constTimeNegate(_,k),k=new d(e.mul(k.px,x.beta),k.py,k.pz),p=I.add(k),B=M.add(N)}else{let{p:P,f:C}=this.wNAF(h);p=P,B=C}return d.normalizeZ([p,B])[0]}multiplyAndAddUnsafe(h,x,E){let p=d.BASE,B=(C,_)=>_===se||_===xt||!C.equals(p)?C.multiplyUnsafe(_):C.multiply(_),P=B(this,x).add(B(h,E));return P.is0()?void 0:P}toAffine(h){return u(this,h)}isTorsionFree(){let{h,isTorsionFree:x}=t;if(h===xt)return!0;if(x)return x(d,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h,clearCofactor:x}=t;return h===xt?this:x?x(d,this):this.multiplyUnsafe(t.h)}toRawBytes(h=!0){return Ot("isCompressed",h),this.assertValidity(),o(d,this,h)}toHex(h=!0){return Ot("isCompressed",h),te(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,w=mn(d,t.endo?Math.ceil(g/2):g);return{CURVE:t,ProjectivePoint:d,normPrivateKeyToScalar:c,weierstrassEquation:i,isWithinCurveOrder:a}}function qh(r){let t=Ar(r);return Kt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function hc(r){let t=qh(r),{Fp:e,n}=t,o=e.BYTES+1,s=2*e.BYTES+1;function i(v){return Z(v,n)}function a(v){return dn(v,n)}let{ProjectivePoint:c,normPrivateKeyToScalar:f,weierstrassEquation:u,isWithinCurveOrder:l}=Hh({...t,toBytes(v,L,b){let y=L.toAffine(),A=e.toBytes(y.x),S=ne;return Ot("isCompressed",b),b?S(Uint8Array.from([L.hasEvenY()?2:3]),A):S(Uint8Array.from([4]),A,e.toBytes(y.y))},fromBytes(v){let L=v.length,b=v[0],y=v.subarray(1);if(L===o&&(b===2||b===3)){let A=ee(y);if(!Er(A,xt,e.ORDER))throw new Error("Point is not on curve");let S=u(A),R;try{R=e.sqrt(S)}catch(V){let O=V instanceof Error?": "+V.message:"";throw new Error("Point is not on curve"+O)}let U=(R&xt)===xt;return(b&1)===1!==U&&(R=e.neg(R)),{x:A,y:R}}else if(L===s&&b===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 "+L)}}}),d=v=>te(ge(v,t.nByteLength));function g(v){let L=n>>xt;return v>L}function w(v){return g(v)?i(-v):v}let m=(v,L,b)=>ee(v.slice(L,b));class h{constructor(L,b,y){this.r=L,this.s=b,this.recovery=y,this.assertValidity()}static fromCompact(L){let b=t.nByteLength;return L=rt("compactSignature",L,b*2),new h(m(L,0,b),m(L,b,2*b))}static fromDER(L){let{r:b,s:y}=oe.toSig(rt("DER",L));return new h(b,y)}assertValidity(){bt("r",this.r,xt,n),bt("s",this.s,xt,n)}addRecoveryBit(L){return new h(this.r,this.s,L)}recoverPublicKey(L){let{r:b,s:y,recovery:A}=this,S=C(rt("msgHash",L));if(A==null||![0,1,2,3].includes(A))throw new Error("recovery id invalid");let R=A===2||A===3?b+t.n:b;if(R>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let U=(A&1)===0?"02":"03",K=c.fromHex(U+d(R)),V=a(R),O=i(-S*V),z=i(y*V),$=c.BASE.multiplyAndAddUnsafe(K,O,z);if(!$)throw new Error("point at infinify");return $.assertValidity(),$}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new h(this.r,i(-this.s),this.recovery):this}toDERRawBytes(){return _e(this.toDERHex())}toDERHex(){return oe.hexFromSig({r:this.r,s:this.s})}toCompactRawBytes(){return _e(this.toCompactHex())}toCompactHex(){return d(this.r)+d(this.s)}}let x={isValidPrivateKey(v){try{return f(v),!0}catch{return!1}},normPrivateKeyToScalar:f,randomPrivateKey:()=>{let v=Jo(t.n);return ka(t.randomBytes(v),t.n)},precompute(v=8,L=c.BASE){return L._setWindowSize(v),L.multiply(BigInt(3)),L}};function E(v,L=!0){return c.fromPrivateKey(v).toRawBytes(L)}function p(v){let L=ye(v),b=typeof v=="string",y=(L||b)&&v.length;return L?y===o||y===s:b?y===2*o||y===2*s:v instanceof c}function B(v,L,b=!0){if(p(v))throw new Error("first arg must be private key");if(!p(L))throw new Error("second arg must be public key");return c.fromHex(L).multiply(f(v)).toRawBytes(b)}let P=t.bits2int||function(v){if(v.length>8192)throw new Error("input is too large");let L=ee(v),b=v.length*8-t.nBitLength;return b>0?L>>BigInt(b):L},C=t.bits2int_modN||function(v){return i(P(v))},_=Sr(t.nBitLength);function T(v){return bt("num < 2^"+t.nBitLength,v,se,_),ge(v,t.nByteLength)}function I(v,L,b=M){if(["recovered","canonical"].some(ot=>ot in b))throw new Error("sign() legacy options not supported");let{hash:y,randomBytes:A}=t,{lowS:S,prehash:R,extraEntropy:U}=b;S==null&&(S=!0),v=rt("msgHash",v),fc(b),R&&(v=rt("prehashed msgHash",y(v)));let K=C(v),V=f(L),O=[T(V),T(K)];if(U!=null&&U!==!1){let ot=U===!0?A(e.BYTES):U;O.push(rt("extraEntropy",ot))}let z=ne(...O),$=K;function nt(ot){let it=P(ot);if(!l(it))return;let At=a(it),Pt=c.BASE.multiply(it).toAffine(),Ct=i(Pt.x);if(Ct===se)return;let zt=i(At*i($+Ct*V));if(zt===se)return;let Zt=(Pt.x===Ct?0:2)|Number(Pt.y&xt),lr=zt;return S&&g(zt)&&(lr=w(zt),Zt^=1),new h(Ct,lr,Zt)}return{seed:z,k2sig:nt}}let M={lowS:t.lowS,prehash:!1},k={lowS:t.lowS,prehash:!1};function N(v,L,b=M){let{seed:y,k2sig:A}=I(v,L,b),S=t;return jo(S.hash.outputLen,S.nByteLength,S.hmac)(y,A)}c.BASE._setWindowSize(8);function H(v,L,b,y=k){let A=v;L=rt("msgHash",L),b=rt("publicKey",b);let{lowS:S,prehash:R,format:U}=y;if(fc(y),"strict"in y)throw new Error("options.strict was renamed to lowS");if(U!==void 0&&U!=="compact"&&U!=="der")throw new Error("format must be compact or der");let K=typeof A=="string"||ye(A),V=!K&&!U&&typeof A=="object"&&A!==null&&typeof A.r=="bigint"&&typeof A.s=="bigint";if(!K&&!V)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let O,z;try{if(V&&(O=new h(A.r,A.s)),K){try{U!=="compact"&&(O=h.fromDER(A))}catch(Zt){if(!(Zt instanceof oe.Err))throw Zt}!O&&U!=="der"&&(O=h.fromCompact(A))}z=c.fromHex(b)}catch{return!1}if(!O||S&&O.hasHighS())return!1;R&&(L=t.hash(L));let{r:$,s:nt}=O,ot=C(L),it=a(nt),At=i(ot*it),Pt=i($*it),Ct=c.BASE.multiplyAndAddUnsafe(z,At,Pt)?.toAffine();return Ct?i(Ct.x)===$:!1}return{CURVE:t,getPublicKey:E,getSharedSecret:B,sign:N,verify:H,ProjectivePoint:c,Signature:h,utils:x}}function Vh(r){return{hash:r,hmac:(t,...e)=>er(r,t,Ho(...e)),randomBytes:br}}function dc(r,t){let e=n=>hc({...r,...Vh(n)});return{...e(t),create:e}}var yc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),pc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Fh=BigInt(1),Ns=BigInt(2),mc=(r,t)=>(r+t/Ns)/t;function zh(r){let t=yc,e=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),f=r*r*r%t,u=f*f*r%t,l=st(u,e,t)*u%t,d=st(l,e,t)*u%t,g=st(d,Ns,t)*f%t,w=st(g,o,t)*g%t,m=st(w,s,t)*w%t,h=st(m,a,t)*m%t,x=st(h,c,t)*h%t,E=st(x,a,t)*m%t,p=st(E,e,t)*u%t,B=st(p,i,t)*w%t,P=st(B,n,t)*f%t,C=st(P,Ns,t);if(!Ms.eql(Ms.sqr(C),r))throw new Error("Cannot find square root");return C}var Ms=we(yc,void 0,void 0,{sqrt:zh}),Ke=dc({a:BigInt(0),b:BigInt(7),Fp:Ms,n:pc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=pc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Fh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=mc(s*r,t),c=mc(-n*r,t),f=Z(r-a*e-c*o,t),u=Z(-a*n-c*s,t),l=f>i,d=u>i;if(l&&(f=t-f),d&&(u=t-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:d,k2:u}}}},$t),xg=BigInt(0);var bg=Ke.ProjectivePoint;function gc(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function wc(r,t,e){let n=yr.digest(e instanceof Uint8Array?e:e.subarray());if(gc(n))return n.then(({digest:o})=>Ke.verify(t,o,r)).catch(o=>{throw new Cr(String(o))});try{return Ke.verify(t,n.digest,r)}catch(o){throw new Cr(String(o))}}var In=class{type="secp256k1";raw;_key;constructor(t){this._key=bc(t),this.raw=xc(this._key)}toMultihash(){return Nt.digest(he(this))}toCID(){return lt.createV1(114,this.toMultihash())}toString(){return et.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:mt(this.raw,t.raw)}verify(t,e){return wc(this._key,e,t)}};function Os(r){return new In(r)}function xc(r){return Ke.ProjectivePoint.fromHex(r).toRawBytes(!0)}function bc(r){try{return Ke.ProjectivePoint.fromHex(r),r}catch(t){throw new Ve(String(t))}}function Ur(r,t){let{Type:e,Data:n}=jt.decode(r),o=n??new Uint8Array;switch(e){case ht.RSA:return Us(o,t);case ht.Ed25519:return ss(o);case ht.secp256k1:return Os(o);case ht.ECDSA:return Oo(o);default:throw new Ae}}function Ec(r){let{Type:t,Data:e}=jt.decode(r.digest),n=e??new Uint8Array;switch(t){case ht.Ed25519:return ss(n);case ht.secp256k1:return Os(n);case ht.ECDSA:return Oo(n);default:throw new Ae}}function he(r){return jt.encode({Type:ht[r.type],Data:r.raw})}var Sc=Symbol.for("nodejs.util.inspect.custom"),Gh=114,kr=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()})`}[uo]=!0;toString(){return this.string==null&&(this.string=et.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return lt.createV1(Gh,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return mt(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return mt(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Sc](){return`PeerId(${this.toString()})`}},Dr=class extends kr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Kr=class extends kr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Nr=class extends kr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},Wh=2336,Mr=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Nt.digest(X(this.url))}[Sc](){return`PeerId(${this.url})`}[uo]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return lt.createV1(Wh,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=q(t)),t.toString()===this.toString())}};var jh=114,Ac=2336;function vc(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=fe(et.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return $h(lt.parse(r));if(t==null)throw new ut('Please pass a multibase decoder for strings that do not start with "1" or "Q"');e=fe(t.decode(r))}return Ic(e)}function Hs(r){if(r.type==="Ed25519")return new Kr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Nr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new Dr({multihash:r.toCID().multihash,publicKey:r});throw new Ae}function Ic(r){if(Yh(r))return new Dr({multihash:r});if(Zh(r))try{let t=Ec(r);if(t.type==="Ed25519")return new Kr({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Nr({multihash:r,publicKey:t})}catch{let e=q(r.digest);return new Mr(new URL(e))}throw new Qr("Supplied PeerID Multihash is invalid")}function $h(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==jh&&r.code!==Ac)throw new Jr("Supplied PeerID CID is invalid");if(r.code===Ac){let t=q(r.multihash.digest);return new Mr(new URL(t))}return Ic(r.multihash)}function Zh(r){return r.code===Nt.code}function Yh(r){return r.code===yr.code}var Bn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},rr=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Ln=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},Or=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function _n(r){return r[Symbol.asyncIterator]!=null}function Bc(r,t){if(r.byteLength>t)throw new rr("Message length too long")}var Cn=r=>{let t=pt(r),e=gt(t);return Wt(r,e),Cn.bytes=t,e};Cn.bytes=0;function Lc(r,t){t=t??{};let e=t.lengthEncoder??Cn,n=t?.maxDataLength??4194304;function*o(s){Bc(s,n);let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return _n(r)?async function*(){for await(let s of r)yield*o(s)}():function*(){for(let s of r)yield*o(s)}()}Lc.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Cn,n=t?.maxDataLength??4194304;return Bc(r,n),new G(e(r.byteLength),r)};var Ne;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Ne||(Ne={}));var qs=r=>{let t=Vt(r);return qs.bytes=pt(t),t};qs.bytes=0;function Hr(r,t){let e=new G,n=Ne.LENGTH,o=-1,s=t?.lengthDecoder??qs,i=t?.maxLengthLength??8,a=t?.maxDataLength??4194304;function*c(){for(;e.byteLength>0;){if(n===Ne.LENGTH)try{if(o=s(e),o<0)throw new Bn("Invalid message length");if(o>a)throw new rr("Message length too long");let f=s.bytes;e.consume(f),t?.onLength!=null&&t.onLength(o),n=Ne.DATA}catch(f){if(f instanceof RangeError){if(e.byteLength>i)throw new Ln("Message length length too long");break}throw f}if(n===Ne.DATA){if(e.byteLength<o)break;let f=e.sublist(0,o);e.consume(o),t?.onData!=null&&t.onData(f),yield f,n=Ne.LENGTH}}}return _n(r)?async function*(){for await(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new Or("Unexpected end of input")}():function*(){for(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new Or("Unexpected end of input")}()}Hr.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 Hr(n,{...t??{},onLength:s=>{e=s}})};function dt(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Pn=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 Et(r,t,e){if(t==null)return r;if(t.aborted)return r.catch(()=>{}),Promise.reject(new Pn(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new Pn(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)}}var Vs=class{readNext;haveNext;ended;nextResult;constructor(){this.ended=!1,this.readNext=dt(),this.haveNext=dt()}[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=dt(),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=dt(),await Et(this.readNext.promise,e?.signal,e)}};function _c(){return new Vs}var Rn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};var Fs=class extends Error{code;constructor(t,e){super(t),this.code=e}},zs=class extends Fs{type;constructor(t){super(t,"ABORT_ERR"),this.type="aborted",this.name="AbortError"}};function Tc(r,t){let e=_c();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 G;return{read:async(i,a)=>{a?.signal?.throwIfAborted();let c,f=new Promise((u,l)=>{c=()=>{l(new zs("Read aborted"))},a?.signal?.addEventListener("abort",c)});try{if(i==null){let{done:l,value:d}=await Promise.race([n.next(),f]);return l===!0?new G:d}for(;o.byteLength<i;){let{value:l,done:d}=await Promise.race([n.next(),f]);if(d===!0)throw new Rn("unexpected end of input");o.append(l)}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 Un=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},kn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Dn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Gs(r,t={}){let e=Tc(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=pt(t.maxDataLength));let n=t?.lengthDecoder??Vt,o=t?.lengthEncoder??Wt;return{read:async i=>{let a=-1,c=new G;for(;;){c.append(await e.read(1,i));try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(a<0)throw new Un("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Dn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new kn("message length too long");return e.read(a,i)},write:async(i,a)=>{await e.write(new G(o(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new G(...i.flatMap(f=>[o(f.byteLength),f]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Ws(){let r=dt(),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 Cc(){let r=Ws(),t=Ws();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var Kn=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}},nr=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Kn(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 Kn(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 js=class extends Error{type;code;constructor(t,e){super(t??"The operation was aborted"),this.type="aborted",this.code=e??"ABORT_ERR"}};function Nn(r={}){return Jh(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 Jh(r,t){t=t??{};let e=t.onEnd,n=new nr,o,s,i,a=dt(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((h,x)=>{s=E=>{s=null,n.push(E);try{h(r(n))}catch(p){x(p)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=dt()})}},f=h=>s!=null?s(h):(n.push(h),o),u=h=>(n=new nr,s!=null?s({error:h}):(n.push({error:h}),o)),l=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 f({done:!1,value:h})},d=h=>i?o:(i=!0,h!=null?u(h):f({done:!0})),g=()=>(n=new nr,d(),{done:!0}),w=h=>(d(h),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:g,throw:w,push:l,end:d,get readableLength(){return n.size},onEmpty:async h=>{let x=h?.signal;if(x?.throwIfAborted(),n.isEmpty())return;let E,p;x!=null&&(E=new Promise((B,P)=>{p=()=>{P(new js)},x.addEventListener("abort",p)}));try{await Promise.race([a.promise,E])}finally{p!=null&&x!=null&&x?.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:l,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 $s=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=dt(),this.haveNext=dt()}[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=dt(),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=dt(),await Et(this.readNext.promise,e?.signal,e)}};function Pc(){return new $s}function Qh(r){return r[Symbol.asyncIterator]!=null}async function td(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*ed(r){let t=Pc();td(r,t).catch(()=>{}),yield*t}function*rd(r){for(let t of r)yield*t}function nd(...r){let t=[];for(let e of r)Qh(e)||t.push(e);return t.length===r.length?rd(t):ed(r)}var Rc=nd;function Uc(r,...t){if(r==null)throw new Error("Empty pipeline");if(Zs(r)){let n=r;r=()=>n.source}else if(Dc(r)||kc(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Zs(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++)Zs(e[n])&&(e[n]=sd(e[n]));return od(...e)}var od=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},kc=r=>r?.[Symbol.asyncIterator]!=null,Dc=r=>r?.[Symbol.iterator]!=null,Zs=r=>r==null?!1:r.sink!=null&&r.source!=null,sd=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=Nn({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let o,s=r.source;if(kc(s))o=async function*(){yield*s,n.end()};else if(Dc(s))o=function*(){yield*s,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return Rc(n,o())}return r.source};var or=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function Mn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Ys(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function _t(r,...t){if(!Ys(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 Xs(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 Kc(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 Js(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}var ie=r=>new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4)),Nc=r=>new DataView(r.buffer,r.byteOffset,r.byteLength),id=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;if(!id)throw new Error("Non little-endian hardware is not supported");function ad(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function On(r){if(typeof r=="string")r=ad(r);else if(Ys(r))r=Hn(r);else throw new Error("Uint8Array expected, got "+typeof r);return r}function Mc(r,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(r,t)}function Oc(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 Qs=(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,l)=>{if(l!==void 0){if(u!==2)throw new Error("cipher output not supported");_t(l)}},c=!1;return{encrypt(u,l){if(c)throw new Error("cannot encrypt() twice with same key + nonce");return c=!0,_t(u),a(i.encrypt.length,l),i.encrypt(u,l)},decrypt(u,l){if(_t(u),s&&u.length<s)throw new Error("invalid ciphertext length: smaller than tagLength="+s);return a(i.decrypt.length,l),i.decrypt(u,l)}}}return Object.assign(e,r),e};function ti(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&&!cd(t))throw new Error("invalid output, must be aligned");return t}function ei(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,f=n?0:4;r.setUint32(t+c,i,n),r.setUint32(t+f,a,n)}function cd(r){return r.byteOffset%4===0}function Hn(r){return Uint8Array.from(r)}function ae(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}var qc=r=>Uint8Array.from(r.split("").map(t=>t.charCodeAt(0))),ud=qc("expand 16-byte k"),fd=qc("expand 32-byte k"),ld=ie(ud),hd=ie(fd);function D(r,t){return r<<t|r>>>32-t}function ri(r){return r.byteOffset%4===0}var qn=64,dd=16,Vc=2**32-1,Hc=new Uint32Array;function pd(r,t,e,n,o,s,i,a){let c=o.length,f=new Uint8Array(qn),u=ie(f),l=ri(o)&&ri(s),d=l?ie(o):Hc,g=l?ie(s):Hc;for(let w=0;w<c;i++){if(r(t,e,n,u,i,a),i>=Vc)throw new Error("arx: counter overflow");let m=Math.min(qn,c-w);if(l&&m===qn){let h=w/4;if(w%4!==0)throw new Error("arx: invalid block position");for(let x=0,E;x<dd;x++)E=h+x,g[E]=d[E]^u[x];w+=qn;continue}for(let h=0,x;h<m;h++)x=w+h,s[x]=o[x]^f[h];w+=m}}function ni(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:o,counterRight:s,rounds:i}=Mc({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Mn(o),Mn(i),Js(s),Js(e),(a,c,f,u,l=0)=>{_t(a),_t(c),_t(f);let d=f.length;if(u===void 0&&(u=new Uint8Array(d)),_t(u),Mn(l),l<0||l>=Vc)throw new Error("arx: counter overflow");if(u.length<d)throw new Error(`arx: output (${u.length}) is shorter than data (${d})`);let g=[],w=a.length,m,h;if(w===32)g.push(m=Hn(a)),h=hd;else if(w===16&&e)m=new Uint8Array(32),m.set(a),m.set(a,16),h=ld,g.push(m);else throw new Error(`arx: invalid 32-byte key, got length=${w}`);ri(c)||g.push(c=Hn(c));let x=ie(m);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(h,x,ie(c.subarray(0,16)),x),c=c.subarray(16)}let E=16-o;if(E!==c.length)throw new Error(`arx: nonce must be ${E} or 16 bytes`);if(E!==12){let B=new Uint8Array(12);B.set(c,s?0:12-c.length),c=B,g.push(c)}let p=ie(c);return pd(r,h,x,p,f,u,l,i),ae(...g),u}}var St=(r,t)=>r[t++]&255|(r[t++]&255)<<8,oi=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=On(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),f=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|f<<8)&8191,this.r[9]=f>>>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],f=i[2],u=i[3],l=i[4],d=i[5],g=i[6],w=i[7],m=i[8],h=i[9],x=St(t,e+0),E=St(t,e+2),p=St(t,e+4),B=St(t,e+6),P=St(t,e+8),C=St(t,e+10),_=St(t,e+12),T=St(t,e+14),I=s[0]+(x&8191),M=s[1]+((x>>>13|E<<3)&8191),k=s[2]+((E>>>10|p<<6)&8191),N=s[3]+((p>>>7|B<<9)&8191),H=s[4]+((B>>>4|P<<12)&8191),v=s[5]+(P>>>1&8191),L=s[6]+((P>>>14|C<<2)&8191),b=s[7]+((C>>>11|_<<5)&8191),y=s[8]+((_>>>8|T<<8)&8191),A=s[9]+(T>>>5|o),S=0,R=S+I*a+M*(5*h)+k*(5*m)+N*(5*w)+H*(5*g);S=R>>>13,R&=8191,R+=v*(5*d)+L*(5*l)+b*(5*u)+y*(5*f)+A*(5*c),S+=R>>>13,R&=8191;let U=S+I*c+M*a+k*(5*h)+N*(5*m)+H*(5*w);S=U>>>13,U&=8191,U+=v*(5*g)+L*(5*d)+b*(5*l)+y*(5*u)+A*(5*f),S+=U>>>13,U&=8191;let K=S+I*f+M*c+k*a+N*(5*h)+H*(5*m);S=K>>>13,K&=8191,K+=v*(5*w)+L*(5*g)+b*(5*d)+y*(5*l)+A*(5*u),S+=K>>>13,K&=8191;let V=S+I*u+M*f+k*c+N*a+H*(5*h);S=V>>>13,V&=8191,V+=v*(5*m)+L*(5*w)+b*(5*g)+y*(5*d)+A*(5*l),S+=V>>>13,V&=8191;let O=S+I*l+M*u+k*f+N*c+H*a;S=O>>>13,O&=8191,O+=v*(5*h)+L*(5*m)+b*(5*w)+y*(5*g)+A*(5*d),S+=O>>>13,O&=8191;let z=S+I*d+M*l+k*u+N*f+H*c;S=z>>>13,z&=8191,z+=v*a+L*(5*h)+b*(5*m)+y*(5*w)+A*(5*g),S+=z>>>13,z&=8191;let $=S+I*g+M*d+k*l+N*u+H*f;S=$>>>13,$&=8191,$+=v*c+L*a+b*(5*h)+y*(5*m)+A*(5*w),S+=$>>>13,$&=8191;let nt=S+I*w+M*g+k*d+N*l+H*u;S=nt>>>13,nt&=8191,nt+=v*f+L*c+b*a+y*(5*h)+A*(5*m),S+=nt>>>13,nt&=8191;let ot=S+I*m+M*w+k*g+N*d+H*l;S=ot>>>13,ot&=8191,ot+=v*u+L*f+b*c+y*a+A*(5*h),S+=ot>>>13,ot&=8191;let it=S+I*h+M*m+k*w+N*g+H*d;S=it>>>13,it&=8191,it+=v*l+L*u+b*f+y*c+A*a,S+=it>>>13,it&=8191,S=(S<<2)+S|0,S=S+R|0,R=S&8191,S=S>>>13,U+=S,s[0]=R,s[1]=U,s[2]=K,s[3]=V,s[4]=O,s[5]=z,s[6]=$,s[7]=nt,s[8]=ot,s[9]=it}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;ae(n)}update(t){Xs(this);let{buffer:e,blockLen:n}=this;t=On(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(){ae(this.h,this.r,this.buffer,this.pad)}digestInto(t){Xs(this),Kc(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 md(r){let t=(n,o)=>r(o).update(On(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var Fc=md(r=>new oi(r));function Wc(r,t,e,n,o,s=20){let i=r[0],a=r[1],c=r[2],f=r[3],u=t[0],l=t[1],d=t[2],g=t[3],w=t[4],m=t[5],h=t[6],x=t[7],E=o,p=e[0],B=e[1],P=e[2],C=i,_=a,T=c,I=f,M=u,k=l,N=d,H=g,v=w,L=m,b=h,y=x,A=E,S=p,R=B,U=P;for(let V=0;V<s;V+=2)C=C+M|0,A=D(A^C,16),v=v+A|0,M=D(M^v,12),C=C+M|0,A=D(A^C,8),v=v+A|0,M=D(M^v,7),_=_+k|0,S=D(S^_,16),L=L+S|0,k=D(k^L,12),_=_+k|0,S=D(S^_,8),L=L+S|0,k=D(k^L,7),T=T+N|0,R=D(R^T,16),b=b+R|0,N=D(N^b,12),T=T+N|0,R=D(R^T,8),b=b+R|0,N=D(N^b,7),I=I+H|0,U=D(U^I,16),y=y+U|0,H=D(H^y,12),I=I+H|0,U=D(U^I,8),y=y+U|0,H=D(H^y,7),C=C+k|0,U=D(U^C,16),b=b+U|0,k=D(k^b,12),C=C+k|0,U=D(U^C,8),b=b+U|0,k=D(k^b,7),_=_+N|0,A=D(A^_,16),y=y+A|0,N=D(N^y,12),_=_+N|0,A=D(A^_,8),y=y+A|0,N=D(N^y,7),T=T+H|0,S=D(S^T,16),v=v+S|0,H=D(H^v,12),T=T+H|0,S=D(S^T,8),v=v+S|0,H=D(H^v,7),I=I+M|0,R=D(R^I,16),L=L+R|0,M=D(M^L,12),I=I+M|0,R=D(R^I,8),L=L+R|0,M=D(M^L,7);let K=0;n[K++]=i+C|0,n[K++]=a+_|0,n[K++]=c+T|0,n[K++]=f+I|0,n[K++]=u+M|0,n[K++]=l+k|0,n[K++]=d+N|0,n[K++]=g+H|0,n[K++]=w+v|0,n[K++]=m+L|0,n[K++]=h+b|0,n[K++]=x+y|0,n[K++]=E+A|0,n[K++]=p+S|0,n[K++]=B+R|0,n[K++]=P+U|0}function yd(r,t,e,n){let o=r[0],s=r[1],i=r[2],a=r[3],c=t[0],f=t[1],u=t[2],l=t[3],d=t[4],g=t[5],w=t[6],m=t[7],h=e[0],x=e[1],E=e[2],p=e[3];for(let P=0;P<20;P+=2)o=o+c|0,h=D(h^o,16),d=d+h|0,c=D(c^d,12),o=o+c|0,h=D(h^o,8),d=d+h|0,c=D(c^d,7),s=s+f|0,x=D(x^s,16),g=g+x|0,f=D(f^g,12),s=s+f|0,x=D(x^s,8),g=g+x|0,f=D(f^g,7),i=i+u|0,E=D(E^i,16),w=w+E|0,u=D(u^w,12),i=i+u|0,E=D(E^i,8),w=w+E|0,u=D(u^w,7),a=a+l|0,p=D(p^a,16),m=m+p|0,l=D(l^m,12),a=a+l|0,p=D(p^a,8),m=m+p|0,l=D(l^m,7),o=o+f|0,p=D(p^o,16),w=w+p|0,f=D(f^w,12),o=o+f|0,p=D(p^o,8),w=w+p|0,f=D(f^w,7),s=s+u|0,h=D(h^s,16),m=m+h|0,u=D(u^m,12),s=s+u|0,h=D(h^s,8),m=m+h|0,u=D(u^m,7),i=i+l|0,x=D(x^i,16),d=d+x|0,l=D(l^d,12),i=i+l|0,x=D(x^i,8),d=d+x|0,l=D(l^d,7),a=a+c|0,E=D(E^a,16),g=g+E|0,c=D(c^g,12),a=a+c|0,E=D(E^a,8),g=g+E|0,c=D(c^g,7);let B=0;n[B++]=o,n[B++]=s,n[B++]=i,n[B++]=a,n[B++]=h,n[B++]=x,n[B++]=E,n[B++]=p}var gd=ni(Wc,{counterRight:!1,counterLength:4,allowShortKeys:!1}),wd=ni(Wc,{counterRight:!1,counterLength:8,extendNonceFn:yd,allowShortKeys:!1});var xd=new Uint8Array(16),zc=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(xd.subarray(e))},bd=new Uint8Array(32);function Gc(r,t,e,n,o){let s=r(t,e,bd),i=Fc.create(s);o&&zc(i,o),zc(i,n);let a=new Uint8Array(16),c=Nc(a);ei(c,0,BigInt(o?o.length:0),!0),ei(c,8,BigInt(n.length),!0),i.update(a);let f=i.digest();return ae(s,a),f}var jc=r=>(t,e,n)=>({encrypt(s,i){let a=s.length;i=ti(a+16,i,!1),i.set(s);let c=i.subarray(0,-16);r(t,e,c,c,1);let f=Gc(r,t,e,c,n);return i.set(f,a),ae(f),i},decrypt(s,i){i=ti(s.length-16,i,!1);let a=s.subarray(0,-16),c=s.subarray(-16),f=Gc(r,t,e,a,n);if(!Oc(c,f))throw new Error("invalid tag");return i.set(s.subarray(0,-16)),r(t,e,i,i,1),ae(f),i}}),si=Qs({blockSize:64,nonceLength:12,tagLength:16},jc(gd)),Ux=Qs({blockSize:64,nonceLength:24,tagLength:16},jc(wd));function Zc(r,t,e){return xr(r),e===void 0&&(e=new Uint8Array(r.outputLen)),er(r,de(e),de(t))}var ii=new Uint8Array([0]),$c=new Uint8Array;function Yc(r,t,e,n=32){if(xr(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=$c);let s=new Uint8Array(o*r.outputLen),i=er.create(r,t),a=i._cloneInto(),c=new Uint8Array(i.outputLen);for(let f=0;f<o;f++)ii[0]=f+1,a.update(f===0?$c:c).update(e).update(ii).digestInto(c),s.set(c,r.outputLen*f),i._cloneInto(a);return i.destroy(),a.destroy(),c.fill(0),ii.fill(0),s.slice(0,n)}var ai={hashSHA256(r){return $t(r.subarray())},getHKDF(r,t){let e=Zc($t,t,r),o=Yc($t,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=Ir.utils.randomPrivateKey();return{publicKey:Ir.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:Ir.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return Ir.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return si(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,o){return si(n,t,e).decrypt(r.subarray(),o)}};var Xc=ai;function Jc(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=gt(2);return t[0]=r>>8,t[1]=r,t};sr.bytes=2;var qr=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)};qr.bytes=2;function Qc(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 ci(r,t){!t.enabled||!or||(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 ui(r,t){!t.enabled||!or||(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||!or||t(r?`REMOTE_STATIC_PUBLIC_KEY ${q(r.subarray(),"hex")}`:"Missing remote static public key.")}function fi(r,t){!t.enabled||!or||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${q(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function li(r,t,e){!e.enabled||!or||(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 ir=class r extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=r.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var Ed=0,Sd=4294967295,Ad="Cipherstate has reached maximum n, a new handshake must be performed",Vn=class{n;bytes;view;constructor(t=Ed){this.n=t,this.bytes=yt(12),this.view=new DataView(this.bytes.buffer,this.bytes.byteOffset,this.bytes.byteLength),this.view.setUint32(4,t,!0)}increment(){this.n++,this.view.setUint32(4,this.n,!0)}getBytes(){return this.bytes}getUint64(){return this.n}assertValue(){if(this.n>Sd)throw new Error(Ad)}};var Me=yt(0),ar=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new Vn(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}},hi=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=X(e,"utf-8");this.h=vd(t,n),this.ck=this.h,this.cs=new ar(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new ar(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new G(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,Me);return[new ar(this.crypto,t),new ar(this.crypto,e)]}},di=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:f}=t;this.crypto=e,this.ss=new hi(e,n),this.ss.mixHash(o),this.initiator=s,this.s=i,this.e=a,this.rs=c,this.re=f}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()}},Vr=class extends di{writeMessageA(t){return new G(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new G(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new G(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new ir(`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 ir(`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 ir(`handshake stage 2 validation fail: ${e.message}`)}}};function vd(r,t){if(t.length<=32){let e=yt(32);return e.set(t),e}else return r.hash(t)}var Fn;(function(r){let t;r.codec=()=>(t==null&&(t=De((e,n,o={})=>{if(o.lengthDelimited!==!1&&n.fork(),e.webtransportCerthashes!=null)for(let s of e.webtransportCerthashes)n.uint32(10),n.bytes(s);if(e.streamMuxers!=null)for(let s of e.streamMuxers)n.uint32(18),n.string(s);o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={webtransportCerthashes:[],streamMuxers:[]},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{if(o.limits?.webtransportCerthashes!=null&&s.webtransportCerthashes.length===o.limits.webtransportCerthashes)throw new Tr('Decode error - map field "webtransportCerthashes" had too many elements');s.webtransportCerthashes.push(e.bytes());break}case 2:{if(o.limits?.streamMuxers!=null&&s.streamMuxers.length===o.limits.streamMuxers)throw new Tr('Decode error - map field "streamMuxers" had too many elements');s.streamMuxers.push(e.string());break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>ke(e,r.codec()),r.decode=(e,n)=>Re(e,r.codec(),n)})(Fn||(Fn={}));var Fr;(function(r){let t;r.codec=()=>(t==null&&(t=De((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),Fn.codec().encode(e.extensions,n)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={identityKey:yt(0),identitySig:yt(0)},i=n==null?e.len:e.pos+n;for(;e.pos<i;){let a=e.uint32();switch(a>>>3){case 1:{s.identityKey=e.bytes();break}case 2:{s.identitySig=e.bytes();break}case 4:{s.extensions=Fn.codec().decode(e,e.uint32(),{limits:o.limits?.extensions});break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>ke(e,r.codec()),r.decode=(e,n)=>Re(e,r.codec(),n)})(Fr||(Fr={}));async function pi(r,t,e){let n=await r.sign(eu(t));return Fr.encode({identityKey:he(r.publicKey),identitySig:n,extensions:e})}async function mi(r,t,e){try{let n=Fr.decode(r),o=Ur(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=eu(t);if(!await o.verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new $r(n.message)}}function eu(r){let t=X("noise-libp2p-static-key:");return r instanceof Uint8Array?It([t,r],t.length+r.length):(r.prepend(t),r)}async function ru(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:f}=r,u=await pi(s,a.publicKey,f),l=new Vr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:i,s:a});ci(l.s,e),e.trace("Stage 0 - Initiator starting to send first message."),await n.write(l.writeMessageA(Me),t),e.trace("Stage 0 - Initiator finished sending first message."),ui(l.e,e),e.trace("Stage 1 - Initiator waiting to receive first message from responder...");let d=l.readMessageB(await n.read(t));e.trace("Stage 1 - Initiator received the message."),fi(l.re,e),tu(l.rs,e),e.trace("Initiator going to check remote's signature...");let g=await mi(d,l.rs,c);e.trace("All good with the signature!"),e.trace("Stage 2 - Initiator sending third handshake message."),await n.write(l.writeMessageC(u),t),e.trace("Stage 2 - Initiator sent message with signed payload.");let[w,m]=l.ss.split();return li(w,m,e),{payload:g,encrypt:h=>w.encryptWithAd(Me,h),decrypt:(h,x)=>m.decryptWithAd(Me,h,x)}}async function nu(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:f}=r,u=await pi(s,a.publicKey,f),l=new Vr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:i,s:a});ci(l.s,e),e.trace("Stage 0 - Responder waiting to receive first message."),l.readMessageA(await n.read(t)),e.trace("Stage 0 - Responder received first message."),fi(l.re,e),e.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await n.write(l.writeMessageB(u),t),e.trace("Stage 1 - Responder sent the second handshake message with signed payload."),ui(l.e,e),e.trace("Stage 2 - Responder waiting for third handshake message...");let d=l.readMessageC(await n.read(t));e.trace("Stage 2 - Responder received the message, finished handshake.");let g=await mi(d,l.rs,c),[w,m]=l.ss.split();return li(w,m,e),{payload:g,encrypt:h=>m.encryptWithAd(Me,h),decrypt:(h,x)=>w.decryptWithAd(Me,h,x)}}var su=16;function iu(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 G(sr(i.byteLength),i)}}}function au(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-su<o)throw new Error("Invalid chunk");let i=n.sublist(o,s),a=n.subarray(o,s-su);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var zn=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??Xc;this.crypto=Jc(c),this.extensions={webtransportCerthashes:[],...o},this.metrics=a?Qc(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??yt(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[tn]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(t,e){let n=Gs(t,{lengthEncoder:sr,lengthDecoder:qr,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=Ur(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:Hs(i),streamMuxer:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}getStreamMuxer(t){if(t==null)return;let e=this.components.upgrader.getStreamMuxers();if(e!=null)for(let n of t){let o=e.get(n);if(o!=null)return o}if(t.length)throw new qe("Early muxer negotiation was requested but the initiator and responder had no common muxers")}async secureInbound(t,e){let n=Gs(t,{lengthEncoder:sr,lengthDecoder:qr,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=Ur(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:Hs(i),streamMuxer:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}async performHandshakeInitiator(t,e,n,o){let s;try{s=await ru({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:{streamMuxers:[...this.components.upgrader.getStreamMuxers().keys()],webtransportCerthashes:[],...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 nu({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:{streamMuxers:[...this.components.upgrader.getStreamMuxers().keys()],webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(i){throw this.metrics?.xxHandshakeErrors.increment(),i}return s}async createSecureConnection(t,e){let[n,o]=Cc(),s=t.unwrap();return await Uc(n,iu(e,this.metrics),s,i=>Hr(i,{lengthDecoder:qr}),au(e,this.metrics),n),o}};function cu(r={}){return t=>new zn(t,r)}var Gn=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",f=2**(8*o)-1;for(;;){let u=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let d=Number.parseInt(l,t);if(!Number.isNaN(d))return d});if(u===void 0)break;if(s*=t,s+=u,s>f||(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 uu=45,Id=15,cr=new Gn;function yi(r){if(!(r.length>Id))return cr.new(r).parseWith(()=>cr.readIPv4Addr())}function gi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>uu))return cr.new(r).parseWith(()=>cr.readIPv6Addr())}function Wn(r,t=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>uu)return;let e=cr.new(r).parseWith(()=>cr.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}function jn(r){return!!yi(r)}function $n(r){return!!gi(r)}function Zn(r){return!!Wn(r)}var Bd=r=>r.toString().split("/").slice(1),ur=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),W=r=>({match:t=>ur(e=>e===r).match(t),pattern:r}),Oe=()=>({match:r=>ur(t=>typeof t=="string").match(r),pattern:"{string}"}),Gr=()=>({match:r=>ur(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{et.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),Wr=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Bo.decode(r[1])}catch{return!1}return r.slice(2)},pattern:"/certhash/{certhash}"}),Y=r=>({match:t=>{let e=r.match(t);return e===!1?t:e},pattern:`optional(${r.pattern})`}),Tt=(...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(", ")})`}),j=(...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=Bd(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 Ld=tt(),m1=ct(Ld),Xn=j(W("dns4"),Oe()),Jn=j(W("dns6"),Oe()),Qn=j(W("dnsaddr"),Oe()),xi=j(W("dns"),Oe()),y1=ct(Xn,Y(tt())),g1=ct(Jn,Y(tt())),w1=ct(Qn,Y(tt())),x1=ct(Tt(xi,Qn,Xn,Jn),Y(tt())),fu=j(W("ip4"),ur(jn)),lu=j(W("ip6"),ur($n)),bi=Tt(fu,lu),ce=Tt(bi,xi,Xn,Jn,Qn),b1=ct(Tt(bi,j(Tt(xi,Qn,Xn,Jn),Y(tt())))),E1=ct(fu),S1=ct(lu),A1=ct(bi),Ei=j(ce,W("tcp"),Gr()),jr=j(ce,W("udp"),Gr()),v1=ct(j(Ei,Y(tt()))),I1=ct(jr),Si=j(jr,W("quic"),Y(tt())),to=j(jr,W("quic-v1"),Y(tt())),_d=Tt(Si,to),B1=ct(Si),L1=ct(to),wi=Tt(ce,Ei,jr,Si,to),hu=Tt(j(wi,W("ws"),Y(tt()))),_1=ct(hu),du=Tt(j(wi,W("wss"),Y(tt())),j(wi,W("tls"),Y(j(W("sni"),Oe())),W("ws"),Y(tt()))),T1=ct(du),pu=j(jr,W("webrtc-direct"),Y(Wr()),Y(Wr()),Y(tt())),C1=ct(pu),mu=j(to,W("webtransport"),Y(Wr()),Y(Wr()),Y(tt())),eo=ct(mu),Yn=Tt(hu,du,j(Ei,Y(tt())),j(_d,Y(tt())),j(ce,Y(tt())),pu,mu,tt()),P1=ct(Yn),Td=j(Yn,W("p2p-circuit"),tt()),R1=ct(Td),Cd=Tt(j(Yn,W("p2p-circuit"),W("webrtc"),Y(tt())),j(Yn,W("webrtc"),Y(tt())),j(W("webrtc"),Y(tt()))),U1=ct(Cd),Pd=Tt(j(ce,W("tcp"),Gr(),W("http"),Y(tt())),j(ce,W("http"),Y(tt()))),k1=ct(Pd),Rd=Tt(j(ce,W("tcp"),Tt(j(W("443"),W("http")),j(Gr(),W("https"))),Y(tt())),j(ce,W("tls"),W("http"),Y(tt())),j(ce,W("https"),Y(tt()))),D1=ct(Rd),Ud=Tt(j(W("memory"),Oe(),Y(tt()))),K1=ct(Ud);var He=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};function Ai(r){throw new Error("Not implemented")}function yu(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 gu(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function wu(r,t){let e=yu(r).return?.();gu(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var kd=5e3;function vi(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var ro=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=dt(),this.closed=dt(),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??kd,this.onEnd=t.onEnd,this.onCloseRead=t?.onCloseRead,this.onCloseWrite=t?.onCloseWrite,this.onReset=t?.onReset,this.onAbort=t?.onAbort,this.source=this.streamSource=Nn({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 Yr(`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=()=>{wu(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 G(o):o;let s=this.sendData(o,e);vi(s)&&(this.sendingData=dt(),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 Et(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 Et(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await Et(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await Et(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 Zr("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}};var Ii=class extends ro{writer;reader;constructor(t){super(t),this.writer=t.bidiStream.writable.getWriter(),this.reader=t.bidiStream.readable.getReader(),Promise.resolve().then(async()=>{for(;;){let e=await this.reader.read();if(e.done){t.log("remote closed write");return}e.value!=null&&this.sourcePush(new G(e.value))}}).catch(e=>{t.log.error("error reading from stream",e),this.abort(e)}).finally(()=>{this.remoteCloseWrite()}),this.writer.closed.then(()=>{t.log("writer closed")}).catch(e=>{t.log("writer close promise rejected",e)}).finally(()=>{this.remoteCloseRead()})}sendNewStream(t){}async sendData(t,e){for await(let n of t)this.log("sendData waiting for writer to be ready"),await Et(this.writer.ready,e?.signal),this.writer.write(n).catch(o=>{this.log.error("error sending stream data",o)})}async sendReset(t){this.log("sendReset aborting writer"),await Et(this.writer.abort(),t?.signal),this.log("sendReset aborted writer")}async sendCloseWrite(t){this.log("sendCloseWrite closing writer"),await Et(this.writer.close(),t?.signal),this.log("sendCloseWrite closed writer")}async sendCloseRead(t){this.log("sendCloseRead cancelling reader"),await Et(this.reader.cancel(),t?.signal),this.log("sendCloseRead cancelled reader")}};async function Bi(r,t,e,n,o,s){let i=s.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=new Ii({bidiStream:r,id:t,direction:e,log:i,onEnd:()=>{let c=n.findIndex(f=>f===a);c!==-1&&n.splice(c,1),o?.(a)}});return a}function no(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function xu(r,t,e,n){let o=0,s=e.forComponent("libp2p:webtransport:muxer");return{protocol:"webtransport",createStreamMuxer:i=>{typeof i=="function"&&(i={onIncomingStream:i});let a=[];Promise.resolve().then(async()=>{for(;;){let{done:f,value:u}=await t.read();if(f)break;if(a.length>=n.maxInboundStreams)s(`too many inbound streams open - ${a.length}/${n.maxInboundStreams}, closing new incoming stream`),u.writable.close().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)}),u.readable.cancel().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)});else{let l=await Bi(u,String(o++),"inbound",a,i?.onStreamEnd,e);a.push(l),i?.onIncomingStream?.(l)}}}).catch(f=>{s.error("could not create a new stream",f)});let c={protocol:"webtransport",streams:a,newStream:async f=>{s("new outgoing stream",f);let u=await r.createBidirectionalStream(),l=await Bi(u,String(o++),i?.direction??"outbound",a,i?.onStreamEnd,e);return a.push(l),l},close:async()=>{s("closing webtransport muxer gracefully");try{r.close()}catch(f){c.abort(f)}},abort:f=>{s("closing webtransport muxer with err:",f);try{r.close()}catch(u){s.error("webtransport session threw error during close",u)}},...no()};return c}}}function bu(r,t){return t.filter(n=>!!r.find(o=>mt(n,o))).length===t.length}var m2=parseInt("0xFFFF",16),y2=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Au=jn,Od=$n,Li=function(r){let t=0;if(r=r.toString().trim(),Au(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(Od(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=Au(e[n]),i;s&&(i=Li(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")},vu=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 fr={},_i={},qd=[[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"]];qd.forEach(r=>{let t=Vd(...r);_i[t.code]=t,fr[t.name]=t});function Vd(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function Q(r){if(typeof r=="number"){if(_i[r]!=null)return _i[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(fr[r]!=null)return fr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var X2=Q("ip4"),J2=Q("ip6"),Q2=Q("ipcidr");function Ri(r,t){switch(Q(r).code){case 4:case 41:return zd(t);case 42:return Pi(t);case 43:return q(t,"base10");case 6:case 273:case 33:case 132:return Lu(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Pi(t);case 421:return $d(t);case 444:return Bu(t);case 445:return Bu(t);case 466:return jd(t);case 481:return globalThis.encodeURIComponent(Pi(t));default:return q(t,"base16")}}function Ui(r,t){switch(Q(r).code){case 4:return Iu(t);case 41:return Iu(t);case 42:return Ci(t);case 43:return X(t,"base10");case 6:case 273:case 33:case 132:return ki(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ci(t);case 421:return Gd(t);case 444:return Zd(t);case 445:return Yd(t);case 466:return Wd(t);case 481:return Ci(globalThis.decodeURIComponent(t));default:return X(t,"base16")}}var Ti=Object.values(Ie).map(r=>r.decoder),Fd=function(){let r=Ti[0].or(Ti[1]);return Ti.slice(2).forEach(t=>r=r.or(t)),r}();function Iu(r){if(!Zn(r))throw new Error("invalid ip address");return Li(r)}function zd(r){let t=vu(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!Zn(t))throw new Error("invalid ip address");return t}function ki(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Lu(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Ci(r){let t=X(r),e=Uint8Array.from(Wt(t.length));return It([e,t],e.length+t.length)}function Pi(r){let t=Vt(r);if(r=r.slice(pt(t)),r.length!==t)throw new Error("inconsistent lengths");return q(r)}function Gd(r){let t;r[0]==="Q"||r[0]==="1"?t=fe(et.decode(`z${r}`)).bytes:t=lt.parse(r).multihash.bytes;let e=Uint8Array.from(Wt(t.length));return It([e,t],e.length+t.length)}function Wd(r){let t=Fd.decode(r),e=Uint8Array.from(Wt(t.length));return It([e,t],e.length+t.length)}function jd(r){let t=Vt(r),e=r.slice(pt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+q(e,"base64url")}function $d(r){let t=Vt(r),e=r.slice(pt(t));if(e.length!==t)throw new Error("inconsistent lengths");return q(e,"base58btc")}function Zd(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=Xt.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=ki(n);return It([e,o],e.length+o.length)}function Yd(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=Xt.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=ki(n);return It([e,o],e.length+o.length)}function Bu(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=q(t,"base32"),o=Lu(e);return`${n}:${o}`}function _u(r){r=Di(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=Q(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw new oo("invalid address: "+r);if(a.path===!0){n=Di(o.slice(s).join("/")),t.push([a.code,Ui(a.code,n)]),e.push([a.code,n]);break}let c=Ui(a.code,o[s]);t.push([a.code,c]),e.push([a.code,Ri(a.code,c)])}return{string:Tu(e),bytes:so(t),tuples:t,stringTuples:e,path:n}}function Ki(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=Vt(r,o),i=pt(s),a=Q(s),c=Xd(a,r.slice(o+i));if(c===0){t.push([s]),e.push([s]),o+=i;continue}let f=r.slice(o+i,o+i+c);if(o+=c+i,o>r.length)throw new oo("Invalid address Uint8Array: "+q(r,"base16"));t.push([s,f]);let u=Ri(s,f);if(e.push([s,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:Tu(e),tuples:t,stringTuples:e,path:n}}function Tu(r){let t=[];return r.map(e=>{let n=Q(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Di(t.join("/"))}function so(r){return It(r.map(t=>{let e=Q(t[0]),n=Uint8Array.from(Wt(e.code));return t.length>1&&t[1]!=null&&(n=It([n,t[1]])),n}))}function Xd(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=Vt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+pt(e)}}function Di(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}var oo=class extends Error{static name="ParseError";name="ParseError";constructor(t){super(`Error parsing address: ${t}`)}};var Jd=Symbol.for("nodejs.util.inspect.custom"),Mi=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Qd=[Q("dns").code,Q("dns4").code,Q("dns6").code,Q("dnsaddr").code],Ni=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},io=class r{bytes;#e;#t;#r;#n;[Mi]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Ki(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=_u(t)}else if(Pu(t))e=Ki(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=e.bytes,this.#e=e.string,this.#t=e.tuples,this.#r=e.stringTuples,this.#n=e.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let t,e,n,o,s="",i=Q("tcp"),a=Q("udp"),c=Q("ip4"),f=Q("ip6"),u=Q("dns6"),l=Q("ip6zone");for(let[g,w]of this.stringTuples())g===l.code&&(s=`%${w??""}`),Qd.includes(g)&&(e=i.name==="tcp"?"tcp":"udp",o=443,n=`${w??""}${s}`,t=g===u.code?6:4),(g===i.code||g===a.code)&&(e=Q(g).name==="tcp"?"tcp":"udp",o=parseInt(w??"")),(g===c.code||g===f.code)&&(e=Q(g).name==="tcp"?"tcp":"udp",n=`${w??""}${s}`,t=g===f.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.#t.map(([t])=>Object.assign({},Q(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>Q(t).name)}tuples(){return this.#t.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(so(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===fr.p2p.code&&t.push([n,o]),n===fr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?q(et.decode(`z${n}`),"base58btc"):q(lt.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return mt(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=Cu.get(e.name);if(n==null)throw new Ni(`no available resolver for ${e.name}`);return(await n(this,t)).map(s=>Oi(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)}[Jd](){return`Multiaddr(${this.#e})`}};var Cu=new Map;function Pu(r){return!!r?.[Mi]}function Oi(r){return new io(r)}var tp=Object.values(Ie).map(r=>r.decoder).reduce((r,t)=>r.or(t));function ep(r){return Gt.decode(tp.decode(r))}function Hi(r){if(!eo.matches(r))throw new Xr("Invalid multiaddr, was not a WebTransport address");let t=r.stringTuples(),e=t.filter(([i,a])=>i===Q("certhash").code).map(([i,a])=>ep(a??"")),n=t.filter(([i,a])=>i===Q("p2p").code).map(([i,a])=>vc(a??""))[0],o=r.toOptions(),s=o.host;return o.family===6&&s?.includes(":")&&(s=`[${s}]`),{url:`https://${s}:${o.port}`,certhashes:e,remotePeer:n}}var Ru=globalThis.WebTransport;var qi=class{log;components;config;metrics;constructor(t,e={}){this.log=t.logger.forComponent("libp2p:webtransport"),this.components=t,this.config={...e,maxInboundStreams:e.maxInboundStreams??1e3,certificates:e.certificates??[]},t.metrics!=null&&(this.metrics={dialerEvents:t.metrics.registerCounterGroup("libp2p_webtransport_dialer_events_total",{label:"event",help:"Total count of WebTransport dialer events by type"})})}[Symbol.toStringTag]="@libp2p/webtransport";[Yi]=!0;[tn]=["@libp2p/transport"];async dial(t,e){e.signal.throwIfAborted(),this.log("dialing %s",t),e=e??{};let{url:n,certhashes:o,remotePeer:s}=Hi(t),i,a,c=()=>{},f=!1,u=!1,l=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let d=new Ru(`${n}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(g=>({algorithm:"sha-256",value:g.digest}))});if(c=g=>{if(!f)try{this.metrics?.dialerEvents.increment({[g]:!0}),d.close()}catch(w){this.log.error("error closing wt session",w)}finally{a!=null&&(a.timeline.close=Date.now()),f=!0}},i=()=>{c(u?"noise_timeout":"ready_timeout")},e.signal.addEventListener("abort",i,{once:!0}),this.log("wait for session to be ready"),e.onProgress?.(new He("webtransport:wait-for-session")),await Promise.race([d.closed,d.ready]),this.log("session became ready"),u=!0,this.metrics?.dialerEvents.increment({ready:!0}),d.closed.catch(g=>{this.log.error("error on remote wt session close",g)}).finally(()=>{c("remote_close")}),l=await Et(this.authenticateWebTransport({wt:d,remotePeer:s,certhashes:o,...e}),e.signal),!l)throw new qe("Failed to authenticate webtransport");return this.metrics?.dialerEvents.increment({open:!0}),a={close:async()=>{this.log("closing webtransport"),c("close")},abort:g=>{this.log("aborting webtransport due to passed err",g),c("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...no()},await e.upgrader.upgradeOutbound(a,{...e,skipEncryption:!0,muxerFactory:xu(d,d.incomingBidirectionalStreams.getReader(),this.components.logger,this.config),skipProtection:!0})}catch(d){throw this.log.error("caught wt session err",d),c(l?"upgrade_error":u?"noise_error":"ready_error"),d}finally{i!=null&&e.signal?.removeEventListener("abort",i)}}async authenticateWebTransport({wt:t,remotePeer:e,certhashes:n,onProgress:o,signal:s}){s?.throwIfAborted(),o?.(new He("webtransport:open-authentication-stream"));let i=await t.createBidirectionalStream(),a=i.writable.getWriter(),c=i.readable.getReader(),f={source:async function*(){for(;;){let d=await c.read();if(d.value!=null&&(yield d.value),d.done)break}}(),sink:async d=>{for await(let g of d){await Et(a.ready,s);let w=g instanceof Uint8Array?g:g.subarray();a.write(w).catch(m=>{this.log.error("could not write chunk during authentication of WebTransport stream",m)})}}},u=cu()(this.components);o?.(new He("webtransport:secure-outbound-connection"));let{remoteExtensions:l}=await u.secureOutbound(f,{signal:s,remotePeer:e});if(o?.(new He("webtransport:close-authentication-stream")),a.close().catch(d=>{this.log.error(`Failed to close authentication stream writer: ${d.message}`)}),c.cancel().catch(d=>{this.log.error(`Failed to close authentication stream reader: ${d.message}`)}),!bu(l?.webtransportCerthashes??[],n.map(d=>d.bytes)))throw new ut("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return Ai(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return globalThis.WebTransport==null?[]:t.filter(e=>{if(!eo.exactMatch(e))return!1;let{url:n,certhashes:o}=Hi(e);return n!=null&&o.length>0})}};function rp(r={}){return t=>new qi(t,r)}return Gu(np);})();
3
3
  //! TODO unclear how to add backpressure here?
4
4
  /*! Bundled license information:
5
5
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@libp2p/webtransport",
3
- "version": "5.0.37-b2124c2db",
3
+ "version": "5.0.37-da4e9da82",
4
4
  "description": "JavaScript implementation of the WebTransport module that libp2p uses and that implements the interface-transport spec",
5
5
  "license": "Apache-2.0 OR MIT",
6
6
  "homepage": "https://github.com/libp2p/js-libp2p/tree/main/packages/transport-webtransport#readme",
@@ -51,9 +51,9 @@
51
51
  },
52
52
  "dependencies": {
53
53
  "@chainsafe/libp2p-noise": "^16.0.0",
54
- "@libp2p/interface": "2.7.0-b2124c2db",
55
- "@libp2p/peer-id": "5.1.0-b2124c2db",
56
- "@libp2p/utils": "6.6.0-b2124c2db",
54
+ "@libp2p/interface": "2.7.0-da4e9da82",
55
+ "@libp2p/peer-id": "5.1.0-da4e9da82",
56
+ "@libp2p/utils": "6.6.0-da4e9da82",
57
57
  "@multiformats/multiaddr": "^12.3.3",
58
58
  "@multiformats/multiaddr-matcher": "^1.6.0",
59
59
  "it-stream-types": "^2.0.2",
@@ -64,17 +64,17 @@
64
64
  "uint8arrays": "^5.1.0"
65
65
  },
66
66
  "devDependencies": {
67
- "@libp2p/crypto": "5.0.15-b2124c2db",
67
+ "@libp2p/crypto": "5.0.15-da4e9da82",
68
68
  "@libp2p/daemon-client": "^9.0.5",
69
- "@libp2p/logger": "5.1.13-b2124c2db",
70
- "@libp2p/ping": "2.0.27-b2124c2db",
69
+ "@libp2p/logger": "5.1.13-da4e9da82",
70
+ "@libp2p/ping": "2.0.27-da4e9da82",
71
71
  "@noble/hashes": "^1.6.1",
72
72
  "aegir": "^45.1.1",
73
73
  "execa": "^9.5.1",
74
74
  "go-libp2p": "^1.6.0",
75
75
  "it-map": "^3.1.1",
76
76
  "it-to-buffer": "^4.0.7",
77
- "libp2p": "2.8.2-b2124c2db",
77
+ "libp2p": "2.8.2-da4e9da82",
78
78
  "p-defer": "^4.0.1",
79
79
  "p-wait-for": "^5.0.2",
80
80
  "sinon-ts": "^2.0.0"