@libp2p/webtransport 5.0.43 → 5.0.44-ae595d8db

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,12 +1,12 @@
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 mo=Object.defineProperty;var Zu=Object.getOwnPropertyDescriptor;var Yu=Object.getOwnPropertyNames;var Xu=Object.prototype.hasOwnProperty;var Tt=(r,t)=>{for(var e in t)mo(r,e,{get:t[e],enumerable:!0})},Ju=(r,t,e,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Yu(t))!Xu.call(r,o)&&o!==e&&mo(r,o,{get:()=>t[o],enumerable:!(n=Zu(t,o))||n.enumerable});return r};var Qu=r=>Ju(mo({},"__esModule",{value:!0}),r);var Nd={};Tt(Nd,{webTransport:()=>Kd});var yo=Symbol.for("@libp2p/peer-id");var Gi=Symbol.for("@libp2p/transport");var Fi;(function(r){r[r.FATAL_ALL=0]="FATAL_ALL",r[r.NO_FATAL=1]="NO_FATAL"})(Fi||(Fi={}));var rn=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}},ze=class extends Error{static name="InvalidCryptoExchangeError";constructor(t="Invalid crypto exchange"){super(t),this.name="InvalidCryptoExchangeError"}},at=class extends Error{static name="InvalidParametersError";constructor(t="Invalid parameters"){super(t),this.name="InvalidParametersError"}},Fe=class extends Error{static name="InvalidPublicKeyError";constructor(t="Invalid public key"){super(t),this.name="InvalidPublicKeyError"}};var nn=class extends Error{static name="StreamResetError";constructor(t="The stream has been reset"){super(t),this.name="StreamResetError"}},on=class extends Error{static name="StreamStateError";constructor(t="The stream is in an invalid state"){super(t),this.name="StreamStateError"}};var sn=class extends Error{static name="InvalidMultiaddrError";constructor(t="Invalid multiaddr"){super(t),this.name="InvalidMultiaddrError"}},an=class extends Error{static name="InvalidCIDError";constructor(t="Invalid CID"){super(t),this.name="InvalidCIDError"}},cn=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var ve=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var un=Symbol.for("@libp2p/service-capabilities"),qd=Symbol.for("@libp2p/service-dependencies");var Eo={};Tt(Eo,{base58btc:()=>nt,base58flickr:()=>af});var lp=new Uint8Array(0);function Wi(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 ji(r){return new TextEncoder().encode(r)}function $i(r){return new TextDecoder().decode(r)}function tf(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(y){if(y instanceof Uint8Array||(ArrayBuffer.isView(y)?y=new Uint8Array(y.buffer,y.byteOffset,y.byteLength):Array.isArray(y)&&(y=Uint8Array.from(y))),!(y instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(y.length===0)return"";for(var m=0,x=0,_=0,M=y.length;_!==M&&y[_]===0;)_++,m++;for(var S=(M-_)*u+1>>>0,d=new Uint8Array(S);_!==M;){for(var I=y[_],U=0,B=S-1;(I!==0||U<x)&&B!==-1;B--,U++)I+=256*d[B]>>>0,d[B]=I%a>>>0,I=I/a>>>0;if(I!==0)throw new Error("Non-zero carry");x=U,_++}for(var L=S-x;L!==S&&d[L]===0;)L++;for(var k=c.repeat(m);L<S;++L)k+=r.charAt(d[L]);return k}function p(y){if(typeof y!="string")throw new TypeError("Expected String");if(y.length===0)return new Uint8Array;var m=0;if(y[m]!==" "){for(var x=0,_=0;y[m]===c;)x++,m++;for(var M=(y.length-m)*f+1>>>0,S=new Uint8Array(M);y[m];){var d=e[y.charCodeAt(m)];if(d===255)return;for(var I=0,U=M-1;(d!==0||I<_)&&U!==-1;U--,I++)d+=a*S[U]>>>0,S[U]=d%256>>>0,d=d/256>>>0;if(d!==0)throw new Error("Non-zero carry");_=I,m++}if(y[m]!==" "){for(var B=M-_;B!==M&&S[B]===0;)B++;for(var L=new Uint8Array(x+(M-B)),k=x;B!==M;)L[k++]=S[B++];return L}}}function w(y){var m=p(y);if(m)return m;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:p,decode:w}}var ef=tf,rf=ef,Yi=rf;var go=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")}},xo=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 Xi(this,t)}},wo=class{decoders;constructor(t){this.decoders=t}or(t){return Xi(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 Xi(r,t){return new wo({...r.decoders??{[r.prefix]:r},...t.decoders??{[t.prefix]:t}})}var bo=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 go(t,e,n),this.decoder=new xo(t,e,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function Ge({name:r,prefix:t,encode:e,decode:n}){return new bo(r,t,e,n)}function fe({name:r,prefix:t,alphabet:e}){let{encode:n,decode:o}=Yi(e,r);return Ge({prefix:t,name:r,encode:n,decode:s=>Jt(o(s))})}function nf(r,t,e,n){let o=r.length;for(;r[o-1]==="=";)--o;let s=new Uint8Array(o*e/8|0),i=0,a=0,c=0;for(let f=0;f<o;++f){let u=t[r[f]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<e|u,i+=e,i>=8&&(i-=8,s[c++]=255&a>>i)}if(i>=e||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function of(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 sf(r){let t={};for(let e=0;e<r.length;++e)t[r[e]]=e;return t}function ct({name:r,prefix:t,bitsPerChar:e,alphabet:n}){let o=sf(n);return Ge({prefix:t,name:r,encode(s){return of(s,n,e)},decode(s){return nf(s,o,e,r)}})}var nt=fe({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),af=fe({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var So={};Tt(So,{base32:()=>Qt,base32hex:()=>lf,base32hexpad:()=>df,base32hexpadupper:()=>pf,base32hexupper:()=>hf,base32pad:()=>uf,base32padupper:()=>ff,base32upper:()=>cf,base32z:()=>mf});var Qt=ct({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),cf=ct({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),uf=ct({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),ff=ct({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),lf=ct({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),hf=ct({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),df=ct({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),pf=ct({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),mf=ct({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ao={};Tt(Ao,{base36:()=>gr,base36upper:()=>yf});var gr=fe({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),yf=fe({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var Gt={};Tt(Gt,{Digest:()=>Ie,create:()=>Nt,decode:()=>le,equals:()=>Io,hasCode:()=>Df});var gf=ta,Ji=128,xf=127,wf=~xf,bf=Math.pow(2,31);function ta(r,t,e){t=t||[],e=e||0;for(var n=e;r>=bf;)t[e++]=r&255|Ji,r/=128;for(;r&wf;)t[e++]=r&255|Ji,r>>>=7;return t[e]=r|0,ta.bytes=e-n+1,t}var Ef=vo,Sf=128,Qi=127;function vo(r,n){var e=0,n=n||0,o=0,s=n,i,a=r.length;do{if(s>=a)throw vo.bytes=0,new RangeError("Could not decode varint");i=r[s++],e+=o<28?(i&Qi)<<o:(i&Qi)*Math.pow(2,o),o+=7}while(i>=Sf);return vo.bytes=s-n,e}var Af=Math.pow(2,7),vf=Math.pow(2,14),If=Math.pow(2,21),Bf=Math.pow(2,28),_f=Math.pow(2,35),Lf=Math.pow(2,42),Tf=Math.pow(2,49),Cf=Math.pow(2,56),Pf=Math.pow(2,63),Uf=function(r){return r<Af?1:r<vf?2:r<If?3:r<Bf?4:r<_f?5:r<Lf?6:r<Tf?7:r<Cf?8:r<Pf?9:10},kf={encode:gf,decode:Ef,encodingLength:Uf},Rf=kf,xr=Rf;function wr(r,t=0){return[xr.decode(r,t),xr.decode.bytes]}function We(r,t,e=0){return xr.encode(r,t,e),t}function je(r){return xr.encodingLength(r)}function Nt(r,t){let e=t.byteLength,n=je(r),o=n+je(e),s=new Uint8Array(o+e);return We(r,s,0),We(e,s,n),s.set(t,o),new Ie(r,e,t,s)}function le(r){let t=Jt(r),[e,n]=wr(t),[o,s]=wr(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new Ie(e,o,i,t)}function Io(r,t){if(r===t)return!0;{let e=t;return r.code===e.code&&r.size===e.size&&e.bytes instanceof Uint8Array&&Wi(r.bytes,e.bytes)}}var Ie=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 ea(r,t){let{bytes:e,version:n}=r;switch(n){case 0:return Nf(e,Bo(r),t??nt.encoder);default:return Mf(e,Bo(r),t??Qt.encoder)}}var ra=new WeakMap;function Bo(r){let t=ra.get(r);if(t==null){let e=new Map;return ra.set(r,e),e}return t}var ut=class r{code;version;multihash;bytes;"/";constructor(t,e,n,o){this.code=e,this.version=t,this.multihash=n,this.bytes=o,this["/"]=o}get asCID(){return this}get byteOffset(){return this.bytes.byteOffset}get byteLength(){return this.bytes.byteLength}toV0(){switch(this.version){case 0:return this;case 1:{let{code:t,multihash:e}=this;if(t!==br)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(e.code!==Of)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&&Io(t.multihash,n.multihash)}toString(t){return ea(this,t)}toJSON(){return{"/":ea(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??na(n,o,s.bytes))}else if(e[Hf]===!0){let{version:n,multihash:o,code:s}=e,i=le(o);return r.create(n,s,i)}else return null}static create(t,e,n){if(typeof e!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(e!==br)throw new Error(`Version 0 CID must use dag-pb (code: ${br}) block encoding`);return new r(t,e,n,n.bytes)}case 1:{let o=na(t,e,n.bytes);return new r(t,e,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return r.create(0,br,t)}static createV1(t,e){return r.create(1,t,e)}static decode(t){let[e,n]=r.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return e}static decodeFirst(t){let e=r.inspectBytes(t),n=e.size-e.multihashSize,o=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 Ie(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,p]=wr(t.subarray(e));return e+=p,l},o=n(),s=br;if(o===18?(o=0,e=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=e,a=n(),c=n(),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]=Kf(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 Kf(r,t){switch(r[0]){case"Q":{let e=t??nt;return[nt.prefix,e.decode(`${nt.prefix}${r}`)]}case nt.prefix:{let e=t??nt;return[nt.prefix,e.decode(r)]}case Qt.prefix:{let e=t??Qt;return[Qt.prefix,e.decode(r)]}case gr.prefix:{let e=t??gr;return[gr.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 Nf(r,t,e){let{prefix:n}=e;if(n!==nt.prefix)throw Error(`Cannot string encode V0 in ${e.name} encoding`);let o=t.get(n);if(o==null){let s=e.encode(r).slice(1);return t.set(n,s),s}else return o}function Mf(r,t,e){let{prefix:n}=e,o=t.get(n);if(o==null){let s=e.encode(r);return t.set(n,s),s}else return o}var br=112,Of=18;function na(r,t,e){let n=je(r),o=n+je(t),s=new Uint8Array(o+e.byteLength);return We(r,s,0),We(t,s,n),s.set(e,o),s}var Hf=Symbol.for("@ipld/js-cid/CID");var _o={};Tt(_o,{identity:()=>Ot});var oa=0,Vf="identity",sa=Jt;function qf(r){return Nt(oa,sa(r))}var Ot={code:oa,name:Vf,encode:sa,digest:qf};function ht(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 dt(r=0){return new Uint8Array(r)}function pt(r=0){return new Uint8Array(r)}function At(r,t){t==null&&(t=r.reduce((o,s)=>o+s.length,0));let e=pt(t),n=0;for(let o of r)e.set(o,n),n+=o.length;return e}var aa=Symbol.for("@achingbrain/uint8arraylist");function ia(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 ln(r){return!!r?.[aa]}var $=class r{bufs;length;[aa]=!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(ln(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(ln(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=ia(this.bufs,t);return e.buf[e.index]}set(t,e){let n=ia(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(ln(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 At(n,o)}subarray(t,e){let{bufs:n,length:o}=this._subList(t,e);return n.length===1?n[0]:At(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(!ln(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 p=f;p>=0;p--){let w=this.get(l+p);if(n[p]!==w){u=Math.max(1,p-a[w]);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=pt(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=dt(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=dt(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=dt(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=pt(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=dt(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=dt(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=dt(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=dt(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=dt(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(!ht(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 Lo={};Tt(Lo,{base10:()=>Ff});var Ff=fe({prefix:"9",name:"base10",alphabet:"0123456789"});var To={};Tt(To,{base16:()=>Gf,base16upper:()=>Wf});var Gf=ct({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Wf=ct({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Co={};Tt(Co,{base2:()=>jf});var jf=ct({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Po={};Tt(Po,{base256emoji:()=>Jf});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}"),$f=ca.reduce((r,t,e)=>(r[e]=t,r),[]),Zf=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 Yf(r){return r.reduce((t,e)=>(t+=$f[e],t),"")}function Xf(r){let t=[];for(let e of r){let n=e.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${e}`);let o=Zf[n];if(o==null)throw new Error(`Non-base256emoji character: ${e}`);t.push(o)}return new Uint8Array(t)}var Jf=Ge({prefix:"\u{1F680}",name:"base256emoji",encode:Yf,decode:Xf});var ko={};Tt(ko,{base64:()=>Qf,base64pad:()=>tl,base64url:()=>Uo,base64urlpad:()=>el});var Qf=ct({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),tl=ct({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Uo=ct({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),el=ct({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Ro={};Tt(Ro,{base8:()=>rl});var rl=ct({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Do={};Tt(Do,{identity:()=>nl});var nl=Ge({prefix:"\0",name:"identity",encode:r=>$i(r),decode:r=>ji(r)});var jp=new TextEncoder,$p=new TextDecoder;var Mo={};Tt(Mo,{sha256:()=>Er,sha512:()=>il});function No({name:r,code:t,encode:e}){return new Ko(r,t,e)}var Ko=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 fa(r){return async t=>new Uint8Array(await crypto.subtle.digest(r,t))}var Er=No({name:"sha2-256",code:18,encode:fa("SHA-256")}),il=No({name:"sha2-512",code:19,encode:fa("SHA-512")});var Be={...Do,...Co,...Ro,...Lo,...To,...So,...Ao,...Eo,...ko,...Po},i0={...Mo,..._o};function ha(r,t,e,n){return{name:r,prefix:t,encoder:{name:r,prefix:t,encode:e},decoder:{decode:n}}}var la=ha("utf8","u",r=>"u"+new TextDecoder("utf8").decode(r),r=>new TextEncoder().encode(r.substring(1))),Oo=ha("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=pt(r.length);for(let e=0;e<r.length;e++)t[e]=r.charCodeAt(e);return t}),al={utf8:la,"utf-8":la,hex:Be.base16,latin1:Oo,ascii:Oo,binary:Oo,...Be},hn=al;function Q(r,t="utf8"){let e=hn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.decoder.decode(`${e.prefix}${r}`)}function V(r,t="utf8"){let e=hn[t];if(e==null)throw new Error(`Unsupported encoding "${t}"`);return e.encoder.encode(r).substring(1)}var cl=parseInt("11111",2),Ho=parseInt("10000000",2),ul=parseInt("01111111",2),da={0:Sr,1:Sr,2:fl,3:dl,4:pl,5:hl,6:ll,16:Sr,22:Sr,48:Sr};function te(r,t={offset:0}){let e=r[t.offset]&cl;if(t.offset++,da[e]!=null)return da[e](r,t);throw new Error("No decoder for tag "+e)}function Ar(r,t){let e=0;if((r[t.offset]&Ho)===Ho){let n=r[t.offset]&ul,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 Sr(r,t){Ar(r,t);let e=[];for(;!(t.offset>=r.byteLength);){let n=te(r,t);if(n===null)break;e.push(n)}return e}function fl(r,t){let e=Ar(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 ll(r,t){let e=Ar(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 hl(r,t){return t.offset++,null}function dl(r,t){let e=Ar(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 pl(r,t){let e=Ar(r,t),n=r.subarray(t.offset,t.offset+e);return t.offset+=e,n}function ml(r){let t=r.toString(16);t.length%2===1&&(t="0"+t);let e=new $;for(let n=0;n<t.length;n+=2)e.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return e}function Vo(r){if(r.byteLength<128)return Uint8Array.from([r.byteLength]);let t=ml(r.byteLength);return new $(Uint8Array.from([t.byteLength|Ho]),t)}function Rt(r){let t=new $,e=128;return(r.subarray()[0]&e)===e&&t.append(Uint8Array.from([0])),t.append(r),new $(Uint8Array.from([2]),Vo(t),t)}function dn(r){let t=Uint8Array.from([0]),e=new $(t,r);return new $(Uint8Array.from([3]),Vo(e),e)}function he(r,t=48){let e=new $;for(let n of r)e.append(n);return new $(Uint8Array.from([t]),Vo(e),e)}async function pa(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 yl=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),gl=Uint8Array.from([6,5,43,129,4,0,34]),xl=Uint8Array.from([6,5,43,129,4,0,35]),wl={ext:!0,kty:"EC",crv:"P-256"},bl={ext:!0,kty:"EC",crv:"P-384"},El={ext:!0,kty:"EC",crv:"P-521"},qo=32,zo=48,Fo=66;function Go(r){let t=te(r);return ma(t)}function ma(r){let t=r[1][1][0],e=1,n,o;if(t.byteLength===qo*2+1)return n=V(t.subarray(e,e+qo),"base64url"),o=V(t.subarray(e+qo),"base64url"),new $e({...wl,key_ops:["verify"],x:n,y:o});if(t.byteLength===zo*2+1)return n=V(t.subarray(e,e+zo),"base64url"),o=V(t.subarray(e+zo),"base64url"),new $e({...bl,key_ops:["verify"],x:n,y:o});if(t.byteLength===Fo*2+1)return n=V(t.subarray(e,e+Fo),"base64url"),o=V(t.subarray(e+Fo),"base64url"),new $e({...El,key_ops:["verify"],x:n,y:o});throw new at(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function ya(r){return he([Rt(Uint8Array.from([1])),he([Sl(r.crv)],160),he([dn(new $(Uint8Array.from([4]),Q(r.x??"","base64url"),Q(r.y??"","base64url")))],161)]).subarray()}function Sl(r){if(r==="P-256")return yl;if(r==="P-384")return gl;if(r==="P-521")return xl;throw new at(`Invalid curve ${r}`)}var $e=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=ya(this.jwk)),this._raw}toMultihash(){return Ot.digest(de(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}async verify(t,e){return pa(this.jwk,e,t)}};var _e=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Al(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Ze(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function Le(r,...t){if(!Al(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 vr(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");Ze(r.outputLen),Ze(r.blockLen)}function Xe(r,t=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(t&&r.finished)throw new Error("Hash#digest() has already been called")}function ga(r,t){Le(r);let e=t.outputLen;if(r.length<e)throw new Error("digestInto() expects output buffer of length at least "+e)}function Ht(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function pn(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function Vt(r,t){return r<<32-t|r>>>t}function xa(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function pe(r){return typeof r=="string"&&(r=xa(r)),Le(r),r}function Wo(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];Le(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 Ye=class{};function jo(r){let t=n=>r().update(pe(n)).digest(),e=r();return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=()=>r(),t}function Ir(r=32){if(_e&&typeof _e.getRandomValues=="function")return _e.getRandomValues(new Uint8Array(r));if(_e&&typeof _e.randomBytes=="function")return Uint8Array.from(_e.randomBytes(r));throw new Error("crypto.getRandomValues must be defined")}function vl(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 wa(r,t,e){return r&t^~r&e}function ba(r,t,e){return r&t^r&e^t&e}var Br=class extends Ye{constructor(t,e,n,o){super(),this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=t,this.outputLen=e,this.padOffset=n,this.isLE=o,this.buffer=new Uint8Array(t),this.view=pn(this.buffer)}update(t){Xe(this),t=pe(t),Le(t);let{view:e,buffer:n,blockLen:o}=this,s=t.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=pn(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){Xe(this),ga(t,this),this.finished=!0;let{buffer:e,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;e[i++]=128,Ht(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)e[l]=0;vl(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=pn(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.destroyed=i,t.finished=s,t.length=o,t.pos=a,o%e&&t.buffer.set(n),t}clone(){return this._cloneInto()}},ee=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var bt=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var mn=BigInt(4294967295),Ea=BigInt(32);function Il(r,t=!1){return t?{h:Number(r&mn),l:Number(r>>Ea&mn)}:{h:Number(r>>Ea&mn)|0,l:Number(r&mn)|0}}function Sa(r,t=!1){let e=r.length,n=new Uint32Array(e),o=new Uint32Array(e);for(let s=0;s<e;s++){let{h:i,l:a}=Il(r[s],t);[n[s],o[s]]=[i,a]}return[n,o]}var $o=(r,t,e)=>r>>>e,Zo=(r,t,e)=>r<<32-e|t>>>e,Te=(r,t,e)=>r>>>e|t<<32-e,Ce=(r,t,e)=>r<<32-e|t>>>e,_r=(r,t,e)=>r<<64-e|t>>>e-32,Lr=(r,t,e)=>r>>>e-32|t<<64-e;function Wt(r,t,e,n){let o=(t>>>0)+(n>>>0);return{h:r+e+(o/2**32|0)|0,l:o|0}}var Aa=(r,t,e)=>(r>>>0)+(t>>>0)+(e>>>0),va=(r,t,e,n)=>t+e+n+(r/2**32|0)|0,Ia=(r,t,e,n)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0),Ba=(r,t,e,n,o)=>t+e+n+o+(r/2**32|0)|0,_a=(r,t,e,n,o)=>(r>>>0)+(t>>>0)+(e>>>0)+(n>>>0)+(o>>>0),La=(r,t,e,n,o,s)=>t+e+n+o+s+(r/2**32|0)|0;var _l=Uint32Array.from([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]),me=new Uint32Array(64),yn=class extends Br{constructor(t=32){super(64,t,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)me[l]=t.getUint32(e,!1);for(let l=16;l<64;l++){let p=me[l-15],w=me[l-2],y=Vt(p,7)^Vt(p,18)^p>>>3,m=Vt(w,17)^Vt(w,19)^w>>>10;me[l]=m+me[l-7]+y+me[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 p=Vt(a,6)^Vt(a,11)^Vt(a,25),w=u+p+wa(a,c,f)+_l[l]+me[l]|0,m=(Vt(n,2)^Vt(n,13)^Vt(n,22))+ba(n,o,s)|0;u=f,f=c,c=a,a=i+w|0,i=s,s=o,o=n,n=w+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(){Ht(me)}destroy(){this.set(0,0,0,0,0,0,0,0),Ht(this.buffer)}};var Ta=Sa(["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))),Ll=Ta[0],Tl=Ta[1],ye=new Uint32Array(80),ge=new Uint32Array(80),Yo=class extends Br{constructor(t=64){super(128,t,16,!1),this.Ah=bt[0]|0,this.Al=bt[1]|0,this.Bh=bt[2]|0,this.Bl=bt[3]|0,this.Ch=bt[4]|0,this.Cl=bt[5]|0,this.Dh=bt[6]|0,this.Dl=bt[7]|0,this.Eh=bt[8]|0,this.El=bt[9]|0,this.Fh=bt[10]|0,this.Fl=bt[11]|0,this.Gh=bt[12]|0,this.Gl=bt[13]|0,this.Hh=bt[14]|0,this.Hl=bt[15]|0}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:p,Gh:w,Gl:y,Hh:m,Hl:x}=this;return[t,e,n,o,s,i,a,c,f,u,l,p,w,y,m,x]}set(t,e,n,o,s,i,a,c,f,u,l,p,w,y,m,x){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=p|0,this.Gh=w|0,this.Gl=y|0,this.Hh=m|0,this.Hl=x|0}process(t,e){for(let S=0;S<16;S++,e+=4)ye[S]=t.getUint32(e),ge[S]=t.getUint32(e+=4);for(let S=16;S<80;S++){let d=ye[S-15]|0,I=ge[S-15]|0,U=Te(d,I,1)^Te(d,I,8)^$o(d,I,7),B=Ce(d,I,1)^Ce(d,I,8)^Zo(d,I,7),L=ye[S-2]|0,k=ge[S-2]|0,K=Te(L,k,19)^_r(L,k,61)^$o(L,k,6),T=Ce(L,k,19)^Lr(L,k,61)^Zo(L,k,6),D=Ia(B,T,ge[S-7],ge[S-16]),C=Ba(D,U,K,ye[S-7],ye[S-16]);ye[S]=C|0,ge[S]=D|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:f,Dl:u,Eh:l,El:p,Fh:w,Fl:y,Gh:m,Gl:x,Hh:_,Hl:M}=this;for(let S=0;S<80;S++){let d=Te(l,p,14)^Te(l,p,18)^_r(l,p,41),I=Ce(l,p,14)^Ce(l,p,18)^Lr(l,p,41),U=l&w^~l&m,B=p&y^~p&x,L=_a(M,I,B,Tl[S],ge[S]),k=La(L,_,d,U,Ll[S],ye[S]),K=L|0,T=Te(n,o,28)^_r(n,o,34)^_r(n,o,39),D=Ce(n,o,28)^Lr(n,o,34)^Lr(n,o,39),C=n&s^n&a^s&a,H=o&i^o&c^i&c;_=m|0,M=x|0,m=w|0,x=y|0,w=l|0,y=p|0,{h:l,l:p}=Wt(f|0,u|0,k|0,K|0),f=a|0,u=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let E=Aa(K,D,H);n=va(E,k,T,C),o=E|0}({h:n,l:o}=Wt(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=Wt(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=Wt(this.Ch|0,this.Cl|0,a|0,c|0),{h:f,l:u}=Wt(this.Dh|0,this.Dl|0,f|0,u|0),{h:l,l:p}=Wt(this.Eh|0,this.El|0,l|0,p|0),{h:w,l:y}=Wt(this.Fh|0,this.Fl|0,w|0,y|0),{h:m,l:x}=Wt(this.Gh|0,this.Gl|0,m|0,x|0),{h:_,l:M}=Wt(this.Hh|0,this.Hl|0,_|0,M|0),this.set(n,o,s,i,a,c,f,u,l,p,w,y,m,x,_,M)}roundClean(){Ht(ye,ge)}destroy(){Ht(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var gn=jo(()=>new yn);var Ca=jo(()=>new Yo);var ts=BigInt(0),Qo=BigInt(1);function Je(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function es(r){if(!Je(r))throw new Error("Uint8Array expected")}function jt(r,t){if(typeof t!="boolean")throw new Error(r+" boolean expected, got "+t)}function Tr(r){let t=r.toString(16);return t.length&1?"0"+t:t}function ka(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?ts:BigInt("0x"+r)}var Ra=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Cl=Array.from({length:256},(r,t)=>t.toString(16).padStart(2,"0"));function xe(r){if(es(r),Ra)return r.toHex();let t="";for(let e=0;e<r.length;e++)t+=Cl[r[e]];return t}var re={_0:48,_9:57,A:65,F:70,a:97,f:102};function Pa(r){if(r>=re._0&&r<=re._9)return r-re._0;if(r>=re.A&&r<=re.F)return r-(re.A-10);if(r>=re.a&&r<=re.f)return r-(re.a-10)}function Cr(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(Ra)return Uint8Array.fromHex(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=Pa(r.charCodeAt(s)),a=Pa(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 ne(r){return ka(xe(r))}function $t(r){return es(r),ka(xe(Uint8Array.from(r).reverse()))}function Pe(r,t){return Cr(r.toString(16).padStart(t*2,"0"))}function we(r,t){return Pe(r,t).reverse()}function ot(r,t,e){let n;if(typeof t=="string")try{n=Cr(t)}catch(s){throw new Error(r+" must be hex string or Uint8Array, cause: "+s)}else if(Je(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 be(...r){let t=0;for(let n=0;n<r.length;n++){let o=r[n];es(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 Xo=r=>typeof r=="bigint"&&ts<=r;function xn(r,t,e){return Xo(r)&&Xo(t)&&Xo(e)&&t<=r&&r<e}function vt(r,t,e,n){if(!xn(t,e,n))throw new Error("expected valid "+r+": "+e+" <= n < "+n+", got "+t)}function Da(r){let t;for(t=0;r>ts;r>>=Qo,t+=1);return t}var Ue=r=>(Qo<<BigInt(r))-Qo,Jo=r=>new Uint8Array(r),Ua=r=>Uint8Array.from(r);function Ka(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=Jo(r),o=Jo(r),s=0,i=()=>{n.fill(1),o.fill(0),s=0},a=(...l)=>e(o,n,...l),c=(l=Jo(0))=>{o=a(Ua([0]),l),n=a(),l.length!==0&&(o=a(Ua([1]),l),n=a())},f=()=>{if(s++>=1e3)throw new Error("drbg: tried 1000 values");let l=0,p=[];for(;l<t;){n=a();let w=n.slice();p.push(w),l+=n.length}return be(...p)};return(l,p)=>{i(),c(l);let w;for(;!(w=p(f()));)c();return i(),w}}var Pl={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"||Je(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 qt(r,t,e={}){let n=(o,s,i)=>{let a=Pl[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}function Qe(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 Ct=BigInt(0),yt=BigInt(1),ke=BigInt(2),Ul=BigInt(3),Ma=BigInt(4),Oa=BigInt(5),Ha=BigInt(8);function Y(r,t){let e=r%t;return e>=Ct?e:t+e}function st(r,t,e){let n=r;for(;t-- >Ct;)n*=n,n%=e;return n}function wn(r,t){if(r===Ct)throw new Error("invert: expected non-zero number");if(t<=Ct)throw new Error("invert: expected positive modulus, got "+t);let e=Y(r,t),n=t,o=Ct,s=yt,i=yt,a=Ct;for(;e!==Ct;){let f=n/e,u=n%e,l=o-i*f,p=s-a*f;n=e,e=u,o=i,s=a,i=l,a=p}if(n!==yt)throw new Error("invert: does not exist");return Y(o,t)}function Va(r,t){let e=(r.ORDER+yt)/Ma,n=r.pow(t,e);if(!r.eql(r.sqr(n),t))throw new Error("Cannot find square root");return n}function kl(r,t){let e=(r.ORDER-Oa)/Ha,n=r.mul(t,ke),o=r.pow(n,e),s=r.mul(t,o),i=r.mul(r.mul(s,ke),o),a=r.mul(s,r.sub(i,r.ONE));if(!r.eql(r.sqr(a),t))throw new Error("Cannot find square root");return a}function Rl(r){if(r<BigInt(3))throw new Error("sqrt is not defined for small field");let t=r-yt,e=0;for(;t%ke===Ct;)t/=ke,e++;let n=ke,o=oe(r);for(;Na(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(e===1)return Va;let s=o.pow(n,t),i=(t+yt)/ke;return function(c,f){if(c.is0(f))return f;if(Na(c,f)!==1)throw new Error("Cannot find square root");let u=e,l=c.mul(c.ONE,s),p=c.pow(f,t),w=c.pow(f,i);for(;!c.eql(p,c.ONE);){if(c.is0(p))return c.ZERO;let y=1,m=c.sqr(p);for(;!c.eql(m,c.ONE);)if(y++,m=c.sqr(m),y===u)throw new Error("Cannot find square root");let x=yt<<BigInt(u-y-1),_=c.pow(l,x);u=y,l=c.sqr(_),p=c.mul(p,l),w=c.mul(w,_)}return w}}function Dl(r){return r%Ma===Ul?Va:r%Ha===Oa?kl:Rl(r)}var qa=(r,t)=>(Y(r,t)&yt)===yt,Kl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function rs(r){let t={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},e=Kl.reduce((n,o)=>(n[o]="function",n),t);return qt(r,e)}function Nl(r,t,e){if(e<Ct)throw new Error("invalid exponent, negatives unsupported");if(e===Ct)return r.ONE;if(e===yt)return t;let n=r.ONE,o=t;for(;e>Ct;)e&yt&&(n=r.mul(n,o)),o=r.sqr(o),e>>=yt;return n}function tr(r,t,e=!1){let n=new Array(t.length).fill(e?r.ZERO:void 0),o=t.reduce((i,a,c)=>r.is0(a)?i:(n[c]=i,r.mul(i,a)),r.ONE),s=r.inv(o);return t.reduceRight((i,a,c)=>r.is0(a)?i:(n[c]=r.mul(i,n[c]),r.mul(i,a)),s),n}function Na(r,t){let e=(r.ORDER-yt)/ke,n=r.pow(t,e),o=r.eql(n,r.ONE),s=r.eql(n,r.ZERO),i=r.eql(n,r.neg(r.ONE));if(!o&&!s&&!i)throw new Error("invalid Legendre symbol result");return o?1:s?0:-1}function ns(r,t){t!==void 0&&Ze(t);let e=t!==void 0?t:r.toString(2).length,n=Math.ceil(e/8);return{nBitLength:e,nByteLength:n}}function oe(r,t,e=!1,n={}){if(r<=Ct)throw new Error("invalid field: expected ORDER > 0, got "+r);let{nBitLength:o,nByteLength:s}=ns(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:Ue(o),ZERO:Ct,ONE:yt,create:c=>Y(c,r),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return Ct<=c&&c<r},is0:c=>c===Ct,isOdd:c=>(c&yt)===yt,neg:c=>Y(-c,r),eql:(c,f)=>c===f,sqr:c=>Y(c*c,r),add:(c,f)=>Y(c+f,r),sub:(c,f)=>Y(c-f,r),mul:(c,f)=>Y(c*f,r),pow:(c,f)=>Nl(a,c,f),div:(c,f)=>Y(c*wn(f,r),r),sqrN:c=>c*c,addN:(c,f)=>c+f,subN:(c,f)=>c-f,mulN:(c,f)=>c*f,inv:c=>wn(c,r),sqrt:n.sqrt||(c=>(i||(i=Dl(r)),i(a,c))),toBytes:c=>e?we(c,s):Pe(c,s),fromBytes:c=>{if(c.length!==s)throw new Error("Field.fromBytes: expected "+s+" bytes, got "+c.length);return e?$t(c):ne(c)},invertBatch:c=>tr(a,c),cmov:(c,f,u)=>u?f:c});return Object.freeze(a)}function za(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 os(r){let t=za(r);return t+Math.ceil(t/2)}function Fa(r,t,e=!1){let n=r.length,o=za(t),s=os(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=e?$t(r):ne(r),a=Y(i,t-yt)+yt;return e?we(a,o):Pe(a,o)}var Ga=BigInt(0),us=BigInt(1);function ss(r,t){let e=t.negate();return r?e:t}function ja(r,t){if(!Number.isSafeInteger(r)||r<=0||r>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+r)}function is(r,t){ja(r,t);let e=Math.ceil(t/r)+1,n=2**(r-1),o=2**r,s=Ue(r),i=BigInt(r);return{windows:e,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function Wa(r,t,e){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=e,a=Number(r&o),c=r>>i;a>n&&(a-=s,c+=us);let f=t*n,u=f+Math.abs(a)-1,l=a===0,p=a<0,w=t%2!==0;return{nextN:c,offset:u,isZero:l,isNeg:p,isNegF:w,offsetF:f}}function Ml(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 Ol(r,t){if(!Array.isArray(r))throw new Error("array of scalars expected");r.forEach((e,n)=>{if(!t.isValid(e))throw new Error("invalid scalar at index "+n)})}var as=new WeakMap,$a=new WeakMap;function cs(r){return $a.get(r)||1}function bn(r,t){return{constTimeNegate:ss,hasPrecomputes(e){return cs(e)!==1},unsafeLadder(e,n,o=r.ZERO){let s=e;for(;n>Ga;)n&us&&(o=o.add(s)),s=s.double(),n>>=us;return o},precomputeWindow(e,n){let{windows:o,windowSize:s}=is(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 s=r.ZERO,i=r.BASE,a=is(e,t);for(let c=0;c<a.windows;c++){let{nextN:f,offset:u,isZero:l,isNeg:p,isNegF:w,offsetF:y}=Wa(o,c,a);o=f,l?i=i.add(ss(w,n[y])):s=s.add(ss(p,n[u]))}return{p:s,f:i}},wNAFUnsafe(e,n,o,s=r.ZERO){let i=is(e,t);for(let a=0;a<i.windows&&o!==Ga;a++){let{nextN:c,offset:f,isZero:u,isNeg:l}=Wa(o,a,i);if(o=c,!u){let p=n[f];s=s.add(l?p.negate():p)}}return s},getPrecomputes(e,n,o){let s=as.get(n);return s||(s=this.precomputeWindow(n,e),e!==1&&as.set(n,o(s))),s},wNAFCached(e,n,o){let s=cs(e);return this.wNAF(s,this.getPrecomputes(s,e,o),n)},wNAFCachedUnsafe(e,n,o,s){let i=cs(e);return i===1?this.unsafeLadder(e,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,e,o),n,s)},setWindowSize(e,n){ja(n,t),$a.set(e,n),as.delete(e)}}}function En(r,t,e,n){Ml(e,r),Ol(n,t);let o=e.length,s=n.length;if(o!==s)throw new Error("arrays of points and scalars must have equal length");let i=r.ZERO,a=Da(BigInt(o)),c=1;a>12?c=a-3:a>4?c=a-2:a>0&&(c=2);let f=Ue(c),u=new Array(Number(f)+1).fill(i),l=Math.floor((t.BITS-1)/c)*c,p=i;for(let w=l;w>=0;w-=c){u.fill(i);for(let m=0;m<s;m++){let x=n[m],_=Number(x>>BigInt(w)&f);u[_]=u[_].add(e[m])}let y=i;for(let m=u.length-1,x=i;m>0;m--)x=x.add(u[m]),y=y.add(x);if(p=p.add(y),w!==0)for(let m=0;m<c;m++)p=p.double()}return p}function Pr(r){return rs(r.Fp),qt(r,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...ns(r.n,r.nBitLength),...r,p:r.Fp.ORDER})}var Zt=BigInt(0),Pt=BigInt(1),Za=BigInt(2),Hl=BigInt(8),Vl={zip215:!0};function ql(r){let t=Pr(r);return qt(r,{hash:"function",a:"bigint",d:"bigint",randomBytes:"function"},{adjustScalarBytes:"function",domain:"function",uvRatio:"function",mapToCurve:"function"}),Object.freeze({...t})}function Ya(r){let t=ql(r),{Fp:e,n,prehash:o,hash:s,randomBytes:i,nByteLength:a,h:c}=t,f=Za<<BigInt(a*8)-Pt,u=e.create,l=oe(t.n,t.nBitLength);function p(b,h){let g=e.sqr(b),v=e.sqr(h),R=e.add(e.mul(t.a,g),v),O=e.add(e.ONE,e.mul(t.d,e.mul(g,v)));return e.eql(R,O)}if(!p(t.Gx,t.Gy))throw new Error("bad curve params: generator point");let w=t.uvRatio||((b,h)=>{try{return{isValid:!0,value:e.sqrt(b*e.inv(h))}}catch{return{isValid:!1,value:Zt}}}),y=t.adjustScalarBytes||(b=>b),m=t.domain||((b,h,g)=>{if(jt("phflag",g),h.length||g)throw new Error("Contexts/pre-hash are not supported");return b});function x(b,h,g=!1){let v=g?Pt:Zt;vt("coordinate "+b,h,v,f)}function _(b){if(!(b instanceof d))throw new Error("ExtendedPoint expected")}let M=Qe((b,h)=>{let{ex:g,ey:v,ez:R}=b,O=b.is0();h==null&&(h=O?Hl:e.inv(R));let q=u(g*h),z=u(v*h),F=u(R*h);if(O)return{x:Zt,y:Pt};if(F!==Pt)throw new Error("invZ was invalid");return{x:q,y:z}}),S=Qe(b=>{let{a:h,d:g}=t;if(b.is0())throw new Error("bad point: ZERO");let{ex:v,ey:R,ez:O,et:q}=b,z=u(v*v),F=u(R*R),G=u(O*O),J=u(G*G),Z=u(z*h),wt=u(G*u(Z+F)),kt=u(J+u(g*u(z*F)));if(wt!==kt)throw new Error("bad point: equation left != right (1)");let mt=u(v*R),St=u(O*q);if(mt!==St)throw new Error("bad point: equation left != right (2)");return!0});class d{constructor(h,g,v,R){x("x",h),x("y",g),x("z",v,!0),x("t",R),this.ex=h,this.ey=g,this.ez=v,this.et=R,Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(h){if(h instanceof d)throw new Error("extended point not allowed");let{x:g,y:v}=h||{};return x("x",g),x("y",v),new d(g,v,Pt,u(g*v))}static normalizeZ(h){let g=tr(e,h.map(v=>v.ez));return h.map((v,R)=>v.toAffine(g[R])).map(d.fromAffine)}static msm(h,g){return En(d,l,h,g)}_setWindowSize(h){B.setWindowSize(this,h)}assertValidity(){S(this)}equals(h){_(h);let{ex:g,ey:v,ez:R}=this,{ex:O,ey:q,ez:z}=h,F=u(g*z),G=u(O*R),J=u(v*z),Z=u(q*R);return F===G&&J===Z}is0(){return this.equals(d.ZERO)}negate(){return new d(u(-this.ex),this.ey,this.ez,u(-this.et))}double(){let{a:h}=t,{ex:g,ey:v,ez:R}=this,O=u(g*g),q=u(v*v),z=u(Za*u(R*R)),F=u(h*O),G=g+v,J=u(u(G*G)-O-q),Z=F+q,wt=Z-z,kt=F-q,mt=u(J*wt),St=u(Z*kt),Dt=u(J*kt),Mt=u(wt*Z);return new d(mt,St,Mt,Dt)}add(h){_(h);let{a:g,d:v}=t,{ex:R,ey:O,ez:q,et:z}=this,{ex:F,ey:G,ez:J,et:Z}=h,wt=u(R*F),kt=u(O*G),mt=u(z*v*Z),St=u(q*J),Dt=u((R+O)*(F+G)-wt-kt),Mt=St-mt,yr=St+mt,zi=u(kt-g*wt),Gu=u(Dt*Mt),Wu=u(yr*zi),ju=u(Dt*zi),$u=u(Mt*yr);return new d(Gu,Wu,$u,ju)}subtract(h){return this.add(h.negate())}wNAF(h){return B.wNAFCached(this,h,d.normalizeZ)}multiply(h){let g=h;vt("scalar",g,Pt,n);let{p:v,f:R}=this.wNAF(g);return d.normalizeZ([v,R])[0]}multiplyUnsafe(h,g=d.ZERO){let v=h;return vt("scalar",v,Zt,n),v===Zt?U:this.is0()||v===Pt?this:B.wNAFCachedUnsafe(this,v,d.normalizeZ,g)}isSmallOrder(){return this.multiplyUnsafe(c).is0()}isTorsionFree(){return B.unsafeLadder(this,n).is0()}toAffine(h){return M(this,h)}clearCofactor(){let{h}=t;return h===Pt?this:this.multiplyUnsafe(h)}static fromHex(h,g=!1){let{d:v,a:R}=t,O=e.BYTES;h=ot("pointHex",h,O),jt("zip215",g);let q=h.slice(),z=h[O-1];q[O-1]=z&-129;let F=$t(q),G=g?f:e.ORDER;vt("pointHex.y",F,Zt,G);let J=u(F*F),Z=u(J-Pt),wt=u(v*J-R),{isValid:kt,value:mt}=w(Z,wt);if(!kt)throw new Error("Point.fromHex: invalid y coordinate");let St=(mt&Pt)===Pt,Dt=(z&128)!==0;if(!g&&mt===Zt&&Dt)throw new Error("Point.fromHex: x=0 and x_0=1");return Dt!==St&&(mt=u(-mt)),d.fromAffine({x:mt,y:F})}static fromPrivateKey(h){let{scalar:g}=K(h);return I.multiply(g)}toRawBytes(){let{x:h,y:g}=this.toAffine(),v=we(g,e.BYTES);return v[v.length-1]|=h&Pt?128:0,v}toHex(){return xe(this.toRawBytes())}}d.BASE=new d(t.Gx,t.Gy,Pt,u(t.Gx*t.Gy)),d.ZERO=new d(Zt,Pt,Pt,Zt);let{BASE:I,ZERO:U}=d,B=bn(d,a*8);function L(b){return Y(b,n)}function k(b){return L($t(b))}function K(b){let h=e.BYTES;b=ot("private key",b,h);let g=ot("hashed private key",s(b),2*h),v=y(g.slice(0,h)),R=g.slice(h,2*h),O=k(v);return{head:v,prefix:R,scalar:O}}function T(b){let{head:h,prefix:g,scalar:v}=K(b),R=I.multiply(v),O=R.toRawBytes();return{head:h,prefix:g,scalar:v,point:R,pointBytes:O}}function D(b){return T(b).pointBytes}function C(b=Uint8Array.of(),...h){let g=be(...h);return k(s(m(g,ot("context",b),!!o)))}function H(b,h,g={}){b=ot("message",b),o&&(b=o(b));let{prefix:v,scalar:R,pointBytes:O}=T(h),q=C(g.context,v,b),z=I.multiply(q).toRawBytes(),F=C(g.context,z,O,b),G=L(q+F*R);vt("signature.s",G,Zt,n);let J=be(z,we(G,e.BYTES));return ot("result",J,e.BYTES*2)}let E=Vl;function A(b,h,g,v=E){let{context:R,zip215:O}=v,q=e.BYTES;b=ot("signature",b,2*q),h=ot("message",h),g=ot("publicKey",g,q),O!==void 0&&jt("zip215",O),o&&(h=o(h));let z=$t(b.slice(q,2*q)),F,G,J;try{F=d.fromHex(g,O),G=d.fromHex(b.slice(0,q),O),J=I.multiplyUnsafe(z)}catch{return!1}if(!O&&F.isSmallOrder())return!1;let Z=C(R,G.toRawBytes(),F.toRawBytes(),h);return G.add(F.multiplyUnsafe(Z)).subtract(J).clearCofactor().equals(d.ZERO)}return I._setWindowSize(8),{CURVE:t,getPublicKey:D,sign:H,verify:A,ExtendedPoint:d,utils:{getExtendedPublicKey:T,randomPrivateKey:()=>i(e.BYTES),precompute(b=8,h=d.BASE){return h._setWindowSize(b),h.multiply(BigInt(3)),h}}}}var Ur=BigInt(0),er=BigInt(1),Sn=BigInt(2);function zl(r){return qt(r,{adjustScalarBytes:"function",powPminus2:"function"}),Object.freeze({...r})}function Xa(r){let t=zl(r),{P:e,type:n,adjustScalarBytes:o,powPminus2:s}=t,i=n==="x25519";if(!i&&n!=="x448")throw new Error("invalid type");let a=i?255:448,c=i?32:56,f=BigInt(i?9:5),u=BigInt(i?121665:39081),l=i?Sn**BigInt(254):Sn**BigInt(447),p=i?BigInt(8)*Sn**BigInt(251)-er:BigInt(4)*Sn**BigInt(445)-er,w=l+p+er,y=B=>Y(B,e),m=x(f);function x(B){return we(y(B),c)}function _(B){let L=ot("u coordinate",B,c);return i&&(L[31]&=127),y($t(L))}function M(B){return $t(o(ot("scalar",B,c)))}function S(B,L){let k=U(_(L),M(B));if(k===Ur)throw new Error("invalid private or public key received");return x(k)}function d(B){return S(B,m)}function I(B,L,k){let K=y(B*(L-k));return L=y(L-K),k=y(k+K),{x_2:L,x_3:k}}function U(B,L){vt("u",B,Ur,e),vt("scalar",L,l,w);let k=L,K=B,T=er,D=Ur,C=B,H=er,E=Ur;for(let P=BigInt(a-1);P>=Ur;P--){let b=k>>P&er;E^=b,{x_2:T,x_3:C}=I(E,T,C),{x_2:D,x_3:H}=I(E,D,H),E=b;let h=T+D,g=y(h*h),v=T-D,R=y(v*v),O=g-R,q=C+H,z=C-H,F=y(z*h),G=y(q*v),J=F+G,Z=F-G;C=y(J*J),H=y(K*y(Z*Z)),T=y(g*R),D=y(O*(g+y(u*O)))}({x_2:T,x_3:C}=I(E,T,C)),{x_2:D,x_3:H}=I(E,D,H);let A=s(D);return y(T*A)}return{scalarMult:S,scalarMultBase:d,getSharedSecret:(B,L)=>S(B,L),getPublicKey:B=>d(B),utils:{randomPrivateKey:()=>t.randomBytes(c)},GuBytes:m.slice()}}var kr=BigInt("57896044618658097711785492504343953926634992332820282019728792003956564819949"),Ja=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752"),dm=BigInt(0),Fl=BigInt(1),Qa=BigInt(2),Gl=BigInt(3),Wl=BigInt(5),jl=BigInt(8);function ec(r){let t=BigInt(10),e=BigInt(20),n=BigInt(40),o=BigInt(80),s=kr,a=r*r%s*r%s,c=st(a,Qa,s)*a%s,f=st(c,Fl,s)*r%s,u=st(f,Wl,s)*f%s,l=st(u,t,s)*u%s,p=st(l,e,s)*l%s,w=st(p,n,s)*p%s,y=st(w,o,s)*w%s,m=st(y,o,s)*w%s,x=st(m,t,s)*u%s;return{pow_p_5_8:st(x,Qa,s)*r%s,b2:a}}function rc(r){return r[0]&=248,r[31]&=127,r[31]|=64,r}function $l(r,t){let e=kr,n=Y(t*t*t,e),o=Y(n*n*t,e),s=ec(r*o).pow_p_5_8,i=Y(r*n*s,e),a=Y(t*i*i,e),c=i,f=Y(i*Ja,e),u=a===r,l=a===Y(-r,e),p=a===Y(-r*Ja,e);return u&&(i=c),(l||p)&&(i=f),qa(i,e)&&(i=Y(-i,e)),{isValid:u||l,value:i}}var tc=oe(kr,void 0,!0),Zl={a:tc.create(BigInt(-1)),d:BigInt("37095705934669439343138083508754565189542113879843219016388785533085940283555"),Fp:tc,n:BigInt("7237005577332262213973186563042994240857116359379907606001950938285454250989"),h:jl,Gx:BigInt("15112221349535400772501151409588531511454012693041857206046113283949847762202"),Gy:BigInt("46316835694926478169428394003475163141307993866256225615783033603165251855960"),hash:Ca,randomBytes:Ir,adjustScalarBytes:rc,uvRatio:$l},nc=Ya(Zl);var Rr=Xa({P:kr,type:"x25519",powPminus2:r=>{let t=kr,{pow_p_5_8:e,b2:n}=ec(r);return Y(st(e,Gl,t)*n,t)},adjustScalarBytes:rc,randomBytes:Ir});var An=32;function oc(r,t,e){return nc.verify(t,e instanceof Uint8Array?e:e.subarray(),r)}var vn=class{type="Ed25519";raw;constructor(t){this.raw=fs(t,An)}toMultihash(){return Ot.digest(de(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}verify(t,e){return oc(this.raw,e,t)}};function ls(r){return r=fs(r,An),new vn(r)}function fs(r,t){if(r=Uint8Array.from(r??[]),r.length!==t)throw new at(`Key must be a Uint8Array of length ${t}, got ${r.length}`);return r}var Xl=Math.pow(2,7),Jl=Math.pow(2,14),Ql=Math.pow(2,21),hs=Math.pow(2,28),ds=Math.pow(2,35),ps=Math.pow(2,42),ms=Math.pow(2,49),tt=128,It=127;function lt(r){if(r<Xl)return 1;if(r<Jl)return 2;if(r<Ql)return 3;if(r<hs)return 4;if(r<ds)return 5;if(r<ps)return 6;if(r<ms)return 7;if(Number.MAX_SAFE_INTEGER!=null&&r>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function ys(r,t,e=0){switch(lt(r)){case 8:t[e++]=r&255|tt,r/=128;case 7:t[e++]=r&255|tt,r/=128;case 6:t[e++]=r&255|tt,r/=128;case 5:t[e++]=r&255|tt,r/=128;case 4:t[e++]=r&255|tt,r>>>=7;case 3:t[e++]=r&255|tt,r>>>=7;case 2:t[e++]=r&255|tt,r>>>=7;case 1:{t[e++]=r&255,r>>>=7;break}default:throw new Error("unreachable")}return t}function th(r,t,e=0){switch(lt(r)){case 8:t.set(e++,r&255|tt),r/=128;case 7:t.set(e++,r&255|tt),r/=128;case 6:t.set(e++,r&255|tt),r/=128;case 5:t.set(e++,r&255|tt),r/=128;case 4:t.set(e++,r&255|tt),r>>>=7;case 3:t.set(e++,r&255|tt),r>>>=7;case 2:t.set(e++,r&255|tt),r>>>=7;case 1:{t.set(e++,r&255),r>>>=7;break}default:throw new Error("unreachable")}return t}function gs(r,t){let e=r[t],n=0;if(n+=e&It,e<tt||(e=r[t+1],n+=(e&It)<<7,e<tt)||(e=r[t+2],n+=(e&It)<<14,e<tt)||(e=r[t+3],n+=(e&It)<<21,e<tt)||(e=r[t+4],n+=(e&It)*hs,e<tt)||(e=r[t+5],n+=(e&It)*ds,e<tt)||(e=r[t+6],n+=(e&It)*ps,e<tt)||(e=r[t+7],n+=(e&It)*ms,e<tt))return n;throw new RangeError("Could not decode varint")}function eh(r,t){let e=r.get(t),n=0;if(n+=e&It,e<tt||(e=r.get(t+1),n+=(e&It)<<7,e<tt)||(e=r.get(t+2),n+=(e&It)<<14,e<tt)||(e=r.get(t+3),n+=(e&It)<<21,e<tt)||(e=r.get(t+4),n+=(e&It)*hs,e<tt)||(e=r.get(t+5),n+=(e&It)*ds,e<tt)||(e=r.get(t+6),n+=(e&It)*ps,e<tt)||(e=r.get(t+7),n+=(e&It)*ms,e<tt))return n;throw new RangeError("Could not decode varint")}function Yt(r,t,e=0){return t==null&&(t=pt(lt(r))),t instanceof Uint8Array?ys(r,t,e):th(r,t,e)}function zt(r,t=0){return r instanceof Uint8Array?gs(r,t):eh(r,t)}var xs=new Float32Array([-0]),Ee=new Uint8Array(xs.buffer);function ic(r,t,e){xs[0]=r,t[e]=Ee[0],t[e+1]=Ee[1],t[e+2]=Ee[2],t[e+3]=Ee[3]}function ac(r,t){return Ee[0]=r[t],Ee[1]=r[t+1],Ee[2]=r[t+2],Ee[3]=r[t+3],xs[0]}var ws=new Float64Array([-0]),Bt=new Uint8Array(ws.buffer);function cc(r,t,e){ws[0]=r,t[e]=Bt[0],t[e+1]=Bt[1],t[e+2]=Bt[2],t[e+3]=Bt[3],t[e+4]=Bt[4],t[e+5]=Bt[5],t[e+6]=Bt[6],t[e+7]=Bt[7]}function uc(r,t){return Bt[0]=r[t],Bt[1]=r[t+1],Bt[2]=r[t+2],Bt[3]=r[t+3],Bt[4]=r[t+4],Bt[5]=r[t+5],Bt[6]=r[t+6],Bt[7]=r[t+7],ws[0]}var rh=BigInt(Number.MAX_SAFE_INTEGER),nh=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 Re;if(t<rh&&t>nh)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>fc&&(o=0n,++n>fc&&(n=0n))),new r(Number(o),Number(n))}static fromNumber(t){if(t===0)return Re;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):Re}},Re=new Kt(0,0);Re.toBigInt=function(){return 0n};Re.zzEncode=Re.zzDecode=function(){return this};Re.length=function(){return 1};var fc=4294967296n;function lc(r){let t=0,e=0;for(let n=0;n<r.length;++n)e=r.charCodeAt(n),e<128?t+=1:e<2048?t+=2:(e&64512)===55296&&(r.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function hc(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 bs(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 In(r,t){return(r[t-4]|r[t-3]<<8|r[t-2]<<16|r[t-1]<<24)>>>0}var Es=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 In(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ft(this,4);return In(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ft(this,4);let t=ac(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ft(this,4);let t=uc(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 hc(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=In(this.buf,this.pos+=4),e=In(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=gs(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 Ss(r){return new Es(r instanceof Uint8Array?r:r.subarray())}function De(r,t,e){let n=Ss(r);return t.decode(n,void 0,e)}function As(r){let t=r??8192,e=t>>>1,n,o=t;return function(i){if(i<1||i>e)return pt(i);o+i>t&&(n=pt(t),o=0);let a=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),a}}var Ke=class{fn;len;next;val;constructor(t,e,n){this.fn=t,this.len=e,this.next=void 0,this.val=n}};function vs(){}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}},oh=As();function sh(r){return globalThis.Buffer!=null?pt(r):oh(r)}var Nr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ke(vs,0,0),this.tail=this.head,this.states=null}_push(t,e,n){return this.tail=this.tail.next=new Ke(t,e,n),this.len+=e,this}uint32(t){return this.len+=(this.tail=this.tail.next=new _s((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(Bn,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(Bn,e.length(),e)}uint64Number(t){return this._push(ys,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=Kt.fromBigInt(t).zzEncode();return this._push(Bn,e.length(),e)}sint64Number(t){let e=Kt.fromNumber(t).zzEncode();return this._push(Bn,e.length(),e)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Is,1,t?1:0)}fixed32(t){return this._push(Kr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let e=Kt.fromBigInt(t);return this._push(Kr,4,e.lo)._push(Kr,4,e.hi)}fixed64Number(t){let e=Kt.fromNumber(t);return this._push(Kr,4,e.lo)._push(Kr,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(ic,4,t)}double(t){return this._push(cc,8,t)}bytes(t){let e=t.length>>>0;return e===0?this._push(Is,1,0):this.uint32(e)._push(ah,e,t)}string(t){let e=lc(t);return e!==0?this.uint32(e)._push(bs,e,t):this._push(Is,1,0)}fork(){return this.states=new Bs(this),this.head=this.tail=new Ke(vs,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 Ke(vs,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=sh(this.len),n=0;for(;t!=null;)t.fn(t.val,e,n),n+=t.len,t=t.next;return e}};function Is(r,t,e){t[e]=r&255}function ih(r,t,e){for(;r>127;)t[e++]=r&127|128,r>>>=7;t[e]=r}var _s=class extends Ke{next;constructor(t,e){super(ih,t,e),this.next=void 0}};function Bn(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 Kr(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 ah(r,t,e){t.set(r,e)}globalThis.Buffer!=null&&(Nr.prototype.bytes=function(r){let t=r.length>>>0;return this.uint32(t),t>0&&this._push(ch,t,r),this},Nr.prototype.string=function(r){let t=globalThis.Buffer.byteLength(r);return this.uint32(t),t>0&&this._push(uh,t,r),this});function ch(r,t,e){t.set(r,e)}function uh(r,t,e){r.length<40?bs(r,t,e):t.utf8Write!=null?t.utf8Write(r,e):t.set(Q(r),e)}function Ls(){return new Nr}function Ne(r,t){let e=Ls();return t.encode(r,e,{lengthDelimited:!1}),e.finish()}var rr;(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"})(rr||(rr={}));function _n(r,t,e,n){return{name:r,type:t,encode:e,decode:n}}function Ts(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 _n("enum",rr.VARINT,e,n)}function Me(r,t){return _n("message",rr.LENGTH_DELIMITED,r,t)}var Mr=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var ft;(function(r){r.RSA="RSA",r.Ed25519="Ed25519",r.secp256k1="secp256k1",r.ECDSA="ECDSA"})(ft||(ft={}));var Cs;(function(r){r[r.RSA=0]="RSA",r[r.Ed25519=1]="Ed25519",r[r.secp256k1=2]="secp256k1",r[r.ECDSA=3]="ECDSA"})(Cs||(Cs={}));(function(r){r.codec=()=>Ts(Cs)})(ft||(ft={}));var Xt;(function(r){let t;r.codec=()=>(t==null&&(t=Me((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ft.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=ft.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Xt||(Xt={}));var Ps;(function(r){let t;r.codec=()=>(t==null&&(t=Me((e,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),e.Type!=null&&(n.uint32(8),ft.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=ft.codec().decode(e);break}case 2:{s.Data=e.bytes();break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Ps||(Ps={}));var Or=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},Ln=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var mc={get(r=globalThis){let t=r.crypto;if(t?.subtle==null)throw new Ln("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 Se=mc;var Vr={};Tt(Vr,{MAX_RSA_KEY_SIZE:()=>Us,generateRSAKeyPair:()=>wc,jwkToJWKKeyPair:()=>bc,jwkToPkcs1:()=>dh,jwkToPkix:()=>Ks,jwkToRSAPrivateKey:()=>Hs,pkcs1MessageToJwk:()=>Rs,pkcs1MessageToRSAPrivateKey:()=>Ns,pkcs1ToJwk:()=>hh,pkcs1ToRSAPrivateKey:()=>xc,pkixMessageToJwk:()=>Ds,pkixMessageToRSAPublicKey:()=>Os,pkixToJwk:()=>ph,pkixToRSAPublicKey:()=>Ms});var Ae=gn;var nr=class{type="RSA";jwk;_raw;_multihash;constructor(t,e){this.jwk=t,this._multihash=e}get raw(){return this._raw==null&&(this._raw=Vr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return ut.createV1(114,this._multihash)}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}verify(t,e){return gc(this.jwk,e,t)}},Hr=class{type="RSA";jwk;_raw;publicKey;constructor(t,e){this.jwk=t,this.publicKey=e}get raw(){return this._raw==null&&(this._raw=Vr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}sign(t){return yc(this.jwk,t)}};var Us=8192,ks=18,fh=1062,lh=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function hh(r){let t=te(r);return Rs(t)}function Rs(r){return{n:V(r[1],"base64url"),e:V(r[2],"base64url"),d:V(r[3],"base64url"),p:V(r[4],"base64url"),q:V(r[5],"base64url"),dp:V(r[6],"base64url"),dq:V(r[7],"base64url"),qi:V(r[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 at("JWK was missing components");return he([Rt(Uint8Array.from([0])),Rt(Q(r.n,"base64url")),Rt(Q(r.e,"base64url")),Rt(Q(r.d,"base64url")),Rt(Q(r.p,"base64url")),Rt(Q(r.q,"base64url")),Rt(Q(r.dp,"base64url")),Rt(Q(r.dq,"base64url")),Rt(Q(r.qi,"base64url"))]).subarray()}function ph(r){let t=te(r,{offset:0});return Ds(t)}function Ds(r){let t=te(r[1],{offset:0});return{kty:"RSA",n:V(t[0],"base64url"),e:V(t[1],"base64url")}}function Ks(r){if(r.n==null||r.e==null)throw new at("JWK was missing components");return he([lh,dn(he([Rt(Q(r.n,"base64url")),Rt(Q(r.e,"base64url"))]))]).subarray()}function xc(r){let t=te(r);return Ns(t)}function Ns(r){let t=Rs(r);return Hs(t)}function Ms(r,t){if(r.byteLength>=fh)throw new Fe("Key size is too large");let e=te(r,{offset:0});return Os(e,r,t)}function Os(r,t,e){let n=Ds(r);if(e==null){let o=Ae(Xt.encode({Type:ft.RSA,Data:t}));e=Nt(ks,o)}return new nr(n,e)}function Hs(r){if(Sc(r)>Us)throw new at("Key size is too large");let t=bc(r),e=Ae(Xt.encode({Type:ft.RSA,Data:Ks(t.publicKey)})),n=Nt(ks,e);return new Hr(t.privateKey,new nr(t.publicKey,n))}async function wc(r){if(r>Us)throw new at("Key size is too large");let t=await Ec(r),e=Ae(Xt.encode({Type:ft.RSA,Data:Ks(t.publicKey)})),n=Nt(ks,e);return new Hr(t.privateKey,new nr(t.publicKey,n))}function bc(r){if(r==null)throw new at("Missing key parameter");return{privateKey:r,publicKey:{kty:r.kty,n:r.n,e:r.e}}}async function Ec(r){let t=await Se.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 mh(t);return{privateKey:e[0],publicKey:e[1]}}async function yc(r,t){let e=await Se.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]),n=await Se.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},e,t instanceof Uint8Array?t:t.subarray());return new Uint8Array(n,0,n.byteLength)}async function gc(r,t,e){let n=await Se.get().subtle.importKey("jwk",r,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);return Se.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},n,t,e instanceof Uint8Array?e:e.subarray())}async function mh(r){if(r.privateKey==null||r.publicKey==null)throw new at("Private and public key are required");return Promise.all([Se.get().subtle.exportKey("jwk",r.privateKey),Se.get().subtle.exportKey("jwk",r.publicKey)])}function Sc(r){if(r.kty!=="RSA")throw new at("invalid key type");if(r.n==null)throw new at("invalid key modulus");return Q(r.n,"base64url").length*8}var Tn=class extends Ye{constructor(t,e){super(),this.finished=!1,this.destroyed=!1,vr(t);let n=pe(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),Ht(s)}update(t){return Xe(this),this.iHash.update(t),this}digestInto(t){Xe(this),Le(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}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},or=(r,t,e)=>new Tn(r,t).update(e).digest();or.create=(r,t)=>new Tn(r,t);function Ac(r){r.lowS!==void 0&&jt("lowS",r.lowS),r.prehash!==void 0&&jt("prehash",r.prehash)}function yh(r){let t=Pr(r);qt(t,{a:"field",b:"field"},{allowInfinityPoint:"boolean",allowedPrivateKeyLengths:"array",clearCofactor:"function",fromBytes:"function",isTorsionFree:"function",toBytes:"function",wrapPrivateKey:"boolean"});let{endo:e,Fp:n,a:o}=t;if(e){if(!n.eql(o,n.ZERO))throw new Error("invalid endo: CURVE.a must be 0");if(typeof e!="object"||typeof e.beta!="bigint"||typeof e.splitScalar!="function")throw new Error('invalid endo: expected "beta": bigint and "splitScalar": function')}return Object.freeze({...t})}var zs=class extends Error{constructor(t=""){super(t)}},se={Err:zs,_tlv:{encode:(r,t)=>{let{Err:e}=se;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=Tr(n);if(o.length/2&128)throw new e("tlv.encode: long form length too big");let s=n>127?Tr(o.length/2|128):"";return Tr(r)+s+o+t},decode(r,t){let{Err:e}=se,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}=se;if(r<ie)throw new t("integer: negative integers are not allowed");let e=Tr(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}=se;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 ne(r)}},toSig(r){let{Err:t,_int:e,_tlv:n}=se,o=ot("signature",r),{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}=se,n=t.encode(2,e.encode(r.r)),o=t.encode(2,e.encode(r.s)),s=n+o;return t.encode(48,s)}};function Vs(r,t){return xe(Pe(r,t))}var ie=BigInt(0),gt=BigInt(1),Hy=BigInt(2),qs=BigInt(3),gh=BigInt(4);function xh(r){let t=yh(r),{Fp:e}=t,n=oe(t.n,t.nBitLength),o=t.toBytes||((S,d,I)=>{let U=d.toAffine();return be(Uint8Array.from([4]),e.toBytes(U.x),e.toBytes(U.y))}),s=t.fromBytes||(S=>{let d=S.subarray(1),I=e.fromBytes(d.subarray(0,e.BYTES)),U=e.fromBytes(d.subarray(e.BYTES,2*e.BYTES));return{x:I,y:U}});function i(S){let{a:d,b:I}=t,U=e.sqr(S),B=e.mul(U,S);return e.add(e.add(B,e.mul(S,d)),I)}function a(S,d){let I=e.sqr(d),U=i(S);return e.eql(I,U)}if(!a(t.Gx,t.Gy))throw new Error("bad curve params: generator point");let c=e.mul(e.pow(t.a,qs),gh),f=e.mul(e.sqr(t.b),BigInt(27));if(e.is0(e.add(c,f)))throw new Error("bad curve params: a or b");function u(S){return xn(S,gt,t.n)}function l(S){let{allowedPrivateKeyLengths:d,nByteLength:I,wrapPrivateKey:U,n:B}=t;if(d&&typeof S!="bigint"){if(Je(S)&&(S=xe(S)),typeof S!="string"||!d.includes(S.length))throw new Error("invalid private key");S=S.padStart(I*2,"0")}let L;try{L=typeof S=="bigint"?S:ne(ot("private key",S,I))}catch{throw new Error("invalid private key, expected hex or "+I+" bytes, got "+typeof S)}return U&&(L=Y(L,B)),vt("private key",L,gt,B),L}function p(S){if(!(S instanceof m))throw new Error("ProjectivePoint expected")}let w=Qe((S,d)=>{let{px:I,py:U,pz:B}=S;if(e.eql(B,e.ONE))return{x:I,y:U};let L=S.is0();d==null&&(d=L?e.ONE:e.inv(B));let k=e.mul(I,d),K=e.mul(U,d),T=e.mul(B,d);if(L)return{x:e.ZERO,y:e.ZERO};if(!e.eql(T,e.ONE))throw new Error("invZ was invalid");return{x:k,y:K}}),y=Qe(S=>{if(S.is0()){if(t.allowInfinityPoint&&!e.is0(S.py))return;throw new Error("bad point: ZERO")}let{x:d,y:I}=S.toAffine();if(!e.isValid(d)||!e.isValid(I))throw new Error("bad point: x or y not FE");if(!a(d,I))throw new Error("bad point: equation left != right");if(!S.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class m{constructor(d,I,U){if(d==null||!e.isValid(d))throw new Error("x required");if(I==null||!e.isValid(I)||e.is0(I))throw new Error("y required");if(U==null||!e.isValid(U))throw new Error("z required");this.px=d,this.py=I,this.pz=U,Object.freeze(this)}static fromAffine(d){let{x:I,y:U}=d||{};if(!d||!e.isValid(I)||!e.isValid(U))throw new Error("invalid affine point");if(d instanceof m)throw new Error("projective point not allowed");let B=L=>e.eql(L,e.ZERO);return B(I)&&B(U)?m.ZERO:new m(I,U,e.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){let I=tr(e,d.map(U=>U.pz));return d.map((U,B)=>U.toAffine(I[B])).map(m.fromAffine)}static fromHex(d){let I=m.fromAffine(s(ot("pointHex",d)));return I.assertValidity(),I}static fromPrivateKey(d){return m.BASE.multiply(l(d))}static msm(d,I){return En(m,n,d,I)}_setWindowSize(d){M.setWindowSize(this,d)}assertValidity(){y(this)}hasEvenY(){let{y:d}=this.toAffine();if(e.isOdd)return!e.isOdd(d);throw new Error("Field doesn't support isOdd")}equals(d){p(d);let{px:I,py:U,pz:B}=this,{px:L,py:k,pz:K}=d,T=e.eql(e.mul(I,K),e.mul(L,B)),D=e.eql(e.mul(U,K),e.mul(k,B));return T&&D}negate(){return new m(this.px,e.neg(this.py),this.pz)}double(){let{a:d,b:I}=t,U=e.mul(I,qs),{px:B,py:L,pz:k}=this,K=e.ZERO,T=e.ZERO,D=e.ZERO,C=e.mul(B,B),H=e.mul(L,L),E=e.mul(k,k),A=e.mul(B,L);return A=e.add(A,A),D=e.mul(B,k),D=e.add(D,D),K=e.mul(d,D),T=e.mul(U,E),T=e.add(K,T),K=e.sub(H,T),T=e.add(H,T),T=e.mul(K,T),K=e.mul(A,K),D=e.mul(U,D),E=e.mul(d,E),A=e.sub(C,E),A=e.mul(d,A),A=e.add(A,D),D=e.add(C,C),C=e.add(D,C),C=e.add(C,E),C=e.mul(C,A),T=e.add(T,C),E=e.mul(L,k),E=e.add(E,E),C=e.mul(E,A),K=e.sub(K,C),D=e.mul(E,H),D=e.add(D,D),D=e.add(D,D),new m(K,T,D)}add(d){p(d);let{px:I,py:U,pz:B}=this,{px:L,py:k,pz:K}=d,T=e.ZERO,D=e.ZERO,C=e.ZERO,H=t.a,E=e.mul(t.b,qs),A=e.mul(I,L),P=e.mul(U,k),b=e.mul(B,K),h=e.add(I,U),g=e.add(L,k);h=e.mul(h,g),g=e.add(A,P),h=e.sub(h,g),g=e.add(I,B);let v=e.add(L,K);return g=e.mul(g,v),v=e.add(A,b),g=e.sub(g,v),v=e.add(U,B),T=e.add(k,K),v=e.mul(v,T),T=e.add(P,b),v=e.sub(v,T),C=e.mul(H,g),T=e.mul(E,b),C=e.add(T,C),T=e.sub(P,C),C=e.add(P,C),D=e.mul(T,C),P=e.add(A,A),P=e.add(P,A),b=e.mul(H,b),g=e.mul(E,g),P=e.add(P,b),b=e.sub(A,b),b=e.mul(H,b),g=e.add(g,b),A=e.mul(P,g),D=e.add(D,A),A=e.mul(v,g),T=e.mul(h,T),T=e.sub(T,A),A=e.mul(h,P),C=e.mul(v,C),C=e.add(C,A),new m(T,D,C)}subtract(d){return this.add(d.negate())}is0(){return this.equals(m.ZERO)}wNAF(d){return M.wNAFCached(this,d,m.normalizeZ)}multiplyUnsafe(d){let{endo:I,n:U}=t;vt("scalar",d,ie,U);let B=m.ZERO;if(d===ie)return B;if(this.is0()||d===gt)return this;if(!I||M.hasPrecomputes(this))return M.wNAFCachedUnsafe(this,d,m.normalizeZ);let{k1neg:L,k1:k,k2neg:K,k2:T}=I.splitScalar(d),D=B,C=B,H=this;for(;k>ie||T>ie;)k&gt&&(D=D.add(H)),T&gt&&(C=C.add(H)),H=H.double(),k>>=gt,T>>=gt;return L&&(D=D.negate()),K&&(C=C.negate()),C=new m(e.mul(C.px,I.beta),C.py,C.pz),D.add(C)}multiply(d){let{endo:I,n:U}=t;vt("scalar",d,gt,U);let B,L;if(I){let{k1neg:k,k1:K,k2neg:T,k2:D}=I.splitScalar(d),{p:C,f:H}=this.wNAF(K),{p:E,f:A}=this.wNAF(D);C=M.constTimeNegate(k,C),E=M.constTimeNegate(T,E),E=new m(e.mul(E.px,I.beta),E.py,E.pz),B=C.add(E),L=H.add(A)}else{let{p:k,f:K}=this.wNAF(d);B=k,L=K}return m.normalizeZ([B,L])[0]}multiplyAndAddUnsafe(d,I,U){let B=m.BASE,L=(K,T)=>T===ie||T===gt||!K.equals(B)?K.multiplyUnsafe(T):K.multiply(T),k=L(this,I).add(L(d,U));return k.is0()?void 0:k}toAffine(d){return w(this,d)}isTorsionFree(){let{h:d,isTorsionFree:I}=t;if(d===gt)return!0;if(I)return I(m,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){let{h:d,clearCofactor:I}=t;return d===gt?this:I?I(m,this):this.multiplyUnsafe(t.h)}toRawBytes(d=!0){return jt("isCompressed",d),this.assertValidity(),o(m,this,d)}toHex(d=!0){return jt("isCompressed",d),xe(this.toRawBytes(d))}}m.BASE=new m(t.Gx,t.Gy,e.ONE),m.ZERO=new m(e.ZERO,e.ONE,e.ZERO);let{endo:x,nBitLength:_}=t,M=bn(m,x?Math.ceil(_/2):_);return{CURVE:t,ProjectivePoint:m,normPrivateKeyToScalar:l,weierstrassEquation:i,isWithinCurveOrder:u}}function wh(r){let t=Pr(r);return qt(t,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...t})}function vc(r){let t=wh(r),{Fp:e,n,nByteLength:o,nBitLength:s}=t,i=e.BYTES+1,a=2*e.BYTES+1;function c(E){return Y(E,n)}function f(E){return wn(E,n)}let{ProjectivePoint:u,normPrivateKeyToScalar:l,weierstrassEquation:p,isWithinCurveOrder:w}=xh({...t,toBytes(E,A,P){let b=A.toAffine(),h=e.toBytes(b.x),g=be;return jt("isCompressed",P),P?g(Uint8Array.from([A.hasEvenY()?2:3]),h):g(Uint8Array.from([4]),h,e.toBytes(b.y))},fromBytes(E){let A=E.length,P=E[0],b=E.subarray(1);if(A===i&&(P===2||P===3)){let h=ne(b);if(!xn(h,gt,e.ORDER))throw new Error("Point is not on curve");let g=p(h),v;try{v=e.sqrt(g)}catch(q){let z=q instanceof Error?": "+q.message:"";throw new Error("Point is not on curve"+z)}let R=(v&gt)===gt;return(P&1)===1!==R&&(v=e.neg(v)),{x:h,y:v}}else if(A===a&&P===4){let h=e.fromBytes(b.subarray(0,e.BYTES)),g=e.fromBytes(b.subarray(e.BYTES,2*e.BYTES));return{x:h,y:g}}else{let h=i,g=a;throw new Error("invalid Point, expected length of "+h+", or uncompressed "+g+", got "+A)}}});function y(E){let A=n>>gt;return E>A}function m(E){return y(E)?c(-E):E}let x=(E,A,P)=>ne(E.slice(A,P));class _{constructor(A,P,b){vt("r",A,gt,n),vt("s",P,gt,n),this.r=A,this.s=P,b!=null&&(this.recovery=b),Object.freeze(this)}static fromCompact(A){let P=o;return A=ot("compactSignature",A,P*2),new _(x(A,0,P),x(A,P,2*P))}static fromDER(A){let{r:P,s:b}=se.toSig(ot("DER",A));return new _(P,b)}assertValidity(){}addRecoveryBit(A){return new _(this.r,this.s,A)}recoverPublicKey(A){let{r:P,s:b,recovery:h}=this,g=B(ot("msgHash",A));if(h==null||![0,1,2,3].includes(h))throw new Error("recovery id invalid");let v=h===2||h===3?P+t.n:P;if(v>=e.ORDER)throw new Error("recovery id 2 or 3 invalid");let R=(h&1)===0?"02":"03",O=u.fromHex(R+Vs(v,e.BYTES)),q=f(v),z=c(-g*q),F=c(b*q),G=u.BASE.multiplyAndAddUnsafe(O,z,F);if(!G)throw new Error("point at infinify");return G.assertValidity(),G}hasHighS(){return y(this.s)}normalizeS(){return this.hasHighS()?new _(this.r,c(-this.s),this.recovery):this}toDERRawBytes(){return Cr(this.toDERHex())}toDERHex(){return se.hexFromSig(this)}toCompactRawBytes(){return Cr(this.toCompactHex())}toCompactHex(){let A=o;return Vs(this.r,A)+Vs(this.s,A)}}let M={isValidPrivateKey(E){try{return l(E),!0}catch{return!1}},normPrivateKeyToScalar:l,randomPrivateKey:()=>{let E=os(t.n);return Fa(t.randomBytes(E),t.n)},precompute(E=8,A=u.BASE){return A._setWindowSize(E),A.multiply(BigInt(3)),A}};function S(E,A=!0){return u.fromPrivateKey(E).toRawBytes(A)}function d(E){if(typeof E=="bigint")return!1;if(E instanceof u)return!0;let P=ot("key",E).length,b=e.BYTES,h=b+1,g=2*b+1;if(!(t.allowedPrivateKeyLengths||o===h))return P===h||P===g}function I(E,A,P=!0){if(d(E)===!0)throw new Error("first arg must be private key");if(d(A)===!1)throw new Error("second arg must be public key");return u.fromHex(A).multiply(l(E)).toRawBytes(P)}let U=t.bits2int||function(E){if(E.length>8192)throw new Error("input is too large");let A=ne(E),P=E.length*8-s;return P>0?A>>BigInt(P):A},B=t.bits2int_modN||function(E){return c(U(E))},L=Ue(s);function k(E){return vt("num < 2^"+s,E,ie,L),Pe(E,o)}function K(E,A,P=T){if(["recovered","canonical"].some(Z=>Z in P))throw new Error("sign() legacy options not supported");let{hash:b,randomBytes:h}=t,{lowS:g,prehash:v,extraEntropy:R}=P;g==null&&(g=!0),E=ot("msgHash",E),Ac(P),v&&(E=ot("prehashed msgHash",b(E)));let O=B(E),q=l(A),z=[k(q),k(O)];if(R!=null&&R!==!1){let Z=R===!0?h(e.BYTES):R;z.push(ot("extraEntropy",Z))}let F=be(...z),G=O;function J(Z){let wt=U(Z);if(!w(wt))return;let kt=f(wt),mt=u.BASE.multiply(wt).toAffine(),St=c(mt.x);if(St===ie)return;let Dt=c(kt*c(G+St*q));if(Dt===ie)return;let Mt=(mt.x===St?0:2)|Number(mt.y&gt),yr=Dt;return g&&y(Dt)&&(yr=m(Dt),Mt^=1),new _(St,yr,Mt)}return{seed:F,k2sig:J}}let T={lowS:t.lowS,prehash:!1},D={lowS:t.lowS,prehash:!1};function C(E,A,P=T){let{seed:b,k2sig:h}=K(E,A,P),g=t;return Ka(g.hash.outputLen,g.nByteLength,g.hmac)(b,h)}u.BASE._setWindowSize(8);function H(E,A,P,b=D){let h=E;A=ot("msgHash",A),P=ot("publicKey",P);let{lowS:g,prehash:v,format:R}=b;if(Ac(b),"strict"in b)throw new Error("options.strict was renamed to lowS");if(R!==void 0&&R!=="compact"&&R!=="der")throw new Error("format must be compact or der");let O=typeof h=="string"||Je(h),q=!O&&!R&&typeof h=="object"&&h!==null&&typeof h.r=="bigint"&&typeof h.s=="bigint";if(!O&&!q)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let z,F;try{if(q&&(z=new _(h.r,h.s)),O){try{R!=="compact"&&(z=_.fromDER(h))}catch(Mt){if(!(Mt instanceof se.Err))throw Mt}!z&&R!=="der"&&(z=_.fromCompact(h))}F=u.fromHex(P)}catch{return!1}if(!z||g&&z.hasHighS())return!1;v&&(A=t.hash(A));let{r:G,s:J}=z,Z=B(A),wt=f(J),kt=c(Z*wt),mt=c(G*wt),St=u.BASE.multiplyAndAddUnsafe(F,kt,mt)?.toAffine();return St?c(St.x)===G:!1}return{CURVE:t,getPublicKey:S,getSharedSecret:I,sign:C,verify:H,ProjectivePoint:u,Signature:_,utils:M}}function bh(r){return{hash:r,hmac:(t,...e)=>or(r,t,Wo(...e)),randomBytes:Ir}}function Ic(r,t){let e=n=>vc({...r,...bh(n)});return{...e(t),create:e}}var Lc=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),Bc=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),Eh=BigInt(0),Sh=BigInt(1),Fs=BigInt(2),_c=(r,t)=>(r+t/Fs)/t;function Ah(r){let t=Lc,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,p=st(l,e,t)*u%t,w=st(p,Fs,t)*f%t,y=st(w,o,t)*w%t,m=st(y,s,t)*y%t,x=st(m,a,t)*m%t,_=st(x,c,t)*x%t,M=st(_,a,t)*m%t,S=st(M,e,t)*u%t,d=st(S,i,t)*y%t,I=st(d,n,t)*f%t,U=st(I,Fs,t);if(!Gs.eql(Gs.sqr(U),r))throw new Error("Cannot find square root");return U}var Gs=oe(Lc,void 0,void 0,{sqrt:Ah}),sr=Ic({a:Eh,b:BigInt(7),Fp:Gs,n:Bc,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:r=>{let t=Bc,e=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-Sh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=e,i=BigInt("0x100000000000000000000000000000000"),a=_c(s*r,t),c=_c(-n*r,t),f=Y(r-a*e-c*o,t),u=Y(-a*n-c*s,t),l=f>i,p=u>i;if(l&&(f=t-f),p&&(u=t-u),f>i||u>i)throw new Error("splitScalar: Endomorphism failed, k="+r);return{k1neg:l,k1:f,k2neg:p,k2:u}}}},gn);function Tc(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Cc(r,t,e){let n=Er.digest(e instanceof Uint8Array?e:e.subarray());if(Tc(n))return n.then(({digest:o})=>sr.verify(t,o,r)).catch(o=>{throw new Or(String(o))});try{return sr.verify(t,n.digest,r)}catch(o){throw new Or(String(o))}}var Cn=class{type="secp256k1";raw;_key;constructor(t){this._key=Uc(t),this.raw=Pc(this._key)}toMultihash(){return Ot.digest(de(this))}toCID(){return ut.createV1(114,this.toMultihash())}toString(){return nt.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ht(this.raw,t.raw)}verify(t,e){return Cc(this._key,e,t)}};function Ws(r){return new Cn(r)}function Pc(r){return sr.ProjectivePoint.fromHex(r).toRawBytes(!0)}function Uc(r){try{return sr.ProjectivePoint.fromHex(r),r}catch(t){throw new Fe(String(t))}}function qr(r,t){let{Type:e,Data:n}=Xt.decode(r),o=n??new Uint8Array;switch(e){case ft.RSA:return Ms(o,t);case ft.Ed25519:return ls(o);case ft.secp256k1:return Ws(o);case ft.ECDSA:return Go(o);default:throw new ve}}function kc(r){let{Type:t,Data:e}=Xt.decode(r.digest),n=e??new Uint8Array;switch(t){case ft.Ed25519:return ls(n);case ft.secp256k1:return Ws(n);case ft.ECDSA:return Go(n);default:throw new ve}}function de(r){return Xt.encode({Type:ft[r.type],Data:r.raw})}var Rc=Symbol.for("nodejs.util.inspect.custom"),vh=114,zr=class{type;multihash;publicKey;string;constructor(t){this.type=t.type,this.multihash=t.multihash,Object.defineProperty(this,"string",{enumerable:!1,writable:!0})}get[Symbol.toStringTag](){return`PeerId(${this.toString()})`}[yo]=!0;toString(){return this.string==null&&(this.string=nt.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return ut.createV1(vh,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return ht(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return ht(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Rc](){return`PeerId(${this.toString()})`}},Fr=class extends zr{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},Gr=class extends zr{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Wr=class extends zr{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},Ih=2336,jr=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Ot.digest(Q(this.url))}[Rc](){return`PeerId(${this.url})`}[yo]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return ut.createV1(Ih,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=V(t)),t.toString()===this.toString())}};var Bh=114,Dc=2336;function Kc(r,t){let e;if(r.charAt(0)==="1"||r.charAt(0)==="Q")e=le(nt.decode(`z${r}`));else{if(r.startsWith("k51qzi5uqu5")||r.startsWith("kzwfwjn5ji4")||r.startsWith("k2k4r8")||r.startsWith("bafz"))return _h(ut.parse(r));if(t==null)throw new at('Please pass a multibase decoder for strings that do not start with "1" or "Q"');e=le(t.decode(r))}return Nc(e)}function js(r){if(r.type==="Ed25519")return new Gr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="secp256k1")return new Wr({multihash:r.toCID().multihash,publicKey:r});if(r.type==="RSA")return new Fr({multihash:r.toCID().multihash,publicKey:r});throw new ve}function Nc(r){if(Th(r))return new Fr({multihash:r});if(Lh(r))try{let t=kc(r);if(t.type==="Ed25519")return new Gr({multihash:r,publicKey:t});if(t.type==="secp256k1")return new Wr({multihash:r,publicKey:t})}catch{let e=V(r.digest);return new jr(new URL(e))}throw new cn("Supplied PeerID Multihash is invalid")}function _h(r){if(r?.multihash==null||r.version==null||r.version===1&&r.code!==Bh&&r.code!==Dc)throw new an("Supplied PeerID CID is invalid");if(r.code===Dc){let t=V(r.multihash.digest);return new jr(new URL(t))}return Nc(r.multihash)}function Lh(r){return r.code===Ot.code}function Th(r){return r.code===Er.code}var Pn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},ir=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Un=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},$r=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function kn(r){return r[Symbol.asyncIterator]!=null}function Mc(r,t){if(r.byteLength>t)throw new ir("Message length too long")}var Dn=r=>{let t=lt(r),e=pt(t);return Yt(r,e),Dn.bytes=t,e};Dn.bytes=0;function Oc(r,t){t=t??{};let e=t.lengthEncoder??Dn,n=t?.maxDataLength??4194304;function*o(s){Mc(s,n);let i=e(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return kn(r)?async function*(){for await(let s of r)yield*o(s)}():function*(){for(let s of r)yield*o(s)}()}Oc.single=(r,t)=>{t=t??{};let e=t.lengthEncoder??Dn,n=t?.maxDataLength??4194304;return Mc(r,n),new $(e(r.byteLength),r)};var Oe;(function(r){r[r.LENGTH=0]="LENGTH",r[r.DATA=1]="DATA"})(Oe||(Oe={}));var $s=r=>{let t=zt(r);return $s.bytes=lt(t),t};$s.bytes=0;function Zr(r,t){let e=new $,n=Oe.LENGTH,o=-1,s=t?.lengthDecoder??$s,i=t?.maxLengthLength??8,a=t?.maxDataLength??4194304;function*c(){for(;e.byteLength>0;){if(n===Oe.LENGTH)try{if(o=s(e),o<0)throw new Pn("Invalid message length");if(o>a)throw new ir("Message length too long");let f=s.bytes;e.consume(f),t?.onLength!=null&&t.onLength(o),n=Oe.DATA}catch(f){if(f instanceof RangeError){if(e.byteLength>i)throw new Un("Message length length too long");break}throw f}if(n===Oe.DATA){if(e.byteLength<o)break;let f=e.sublist(0,o);e.consume(o),t?.onData!=null&&t.onData(f),yield f,n=Oe.LENGTH}}}return kn(r)?async function*(){for await(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new $r("Unexpected end of input")}():function*(){for(let f of r)e.append(f),yield*c();if(e.byteLength>0)throw new $r("Unexpected end of input")}()}Zr.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 Zr(n,{...t??{},onLength:s=>{e=s}})};function Ut(){let r={};return r.promise=new Promise((t,e)=>{r.resolve=t,r.reject=e}),r}var Kn=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 xt(r,t,e){if(t==null)return r;if(t.aborted)return r.catch(()=>{}),Promise.reject(new Kn(e?.errorMessage,e?.errorCode,e?.errorName));let n,o=new Kn(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 Zs=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=Ut(),this.haveNext=Ut()}[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=Ut(),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=Ut(),await xt(this.readNext.promise,e?.signal,e)}};function Nn(){return new Zs}var Mn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function Hc(r,t){let e=Nn();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 $;return{read:async i=>{if(i?.signal?.throwIfAborted(),i?.bytes==null){let{done:c,value:f}=await xt(n.next(),i?.signal);return c===!0?null:f}for(;o.byteLength<i.bytes;){let{value:c,done:f}=await xt(n.next(),i?.signal);if(f===!0)throw new Mn("unexpected end of input");o.append(c)}let a=o.sublist(0,i.bytes);return o.consume(i.bytes),a},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await e.push(i,a):await e.push(i.subarray(),a)},unwrap:()=>{if(o.byteLength>0){let i=r.source;r.source=async function*(){t?.yieldBytes===!1?yield o:yield*o,yield*i}()}return r}}}var On=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Hn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Vn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Ys(r,t={}){let e=Hc(r,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=lt(t.maxDataLength));let n=t?.lengthDecoder??zt,o=t?.lengthEncoder??Yt;return{read:async i=>{let a=-1,c=new $;for(;;){c.append(await e.read({...i,bytes:1}));try{a=n(c)}catch(f){if(f instanceof RangeError)continue;throw f}if(a<0)throw new On("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new Vn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Hn("message length too long");return e.read({...i,bytes:a})},write:async(i,a)=>{await e.write(new $(o(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new $(...i.flatMap(f=>[o(f.byteLength),f]));await e.write(c,a)},unwrap:()=>e.unwrap()}}function Xs(){let r=Ut(),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 Vc(){let r=Xs(),t=Xs();return[{source:r.source,sink:t.sink},{source:t.source,sink:r.sink}]}var qn=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}},ar=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new qn(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 qn(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 zn(r={}){return Ph(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 Ph(r,t){t=t??{};let e=t.onEnd,n=new ar,o,s,i,a=Ut(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((x,_)=>{s=M=>{s=null,n.push(M);try{x(r(n))}catch(S){_(S)}return o}}):r(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Ut()})}},f=x=>s!=null?s(x):(n.push(x),o),u=x=>(n=new ar,s!=null?s({error:x}):(n.push({error:x}),o)),l=x=>{if(i)return o;if(t?.objectMode!==!0&&x?.byteLength==null)throw new Error("objectMode was not true but tried to push non-Uint8Array value");return f({done:!1,value:x})},p=x=>i?o:(i=!0,x!=null?u(x):f({done:!0})),w=()=>(n=new ar,p(),{done:!0}),y=x=>(p(x),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:w,throw:y,push:l,end:p,get readableLength(){return n.size},onEmpty:async x=>{let _=x?.signal;if(_?.throwIfAborted(),n.isEmpty())return;let M,S;_!=null&&(M=new Promise((d,I)=>{S=()=>{I(new Js)},_.addEventListener("abort",S)}));try{await Promise.race([a.promise,M])}finally{S!=null&&_!=null&&_?.removeEventListener("abort",S)}}},e==null)return o;let m=o;return o={[Symbol.asyncIterator](){return this},next(){return m.next()},throw(x){return m.throw(x),e!=null&&(e(x),e=void 0),{done:!0}},return(){return m.return(),e!=null&&(e(),e=void 0),{done:!0}},push:l,end(x){return m.end(x),e!=null&&(e(x),e=void 0),o},get readableLength(){return m.readableLength},onEmpty:x=>m.onEmpty(x)},o}function Uh(r){return r[Symbol.asyncIterator]!=null}async function kh(r,t,e){try{await Promise.all(r.map(async n=>{for await(let o of n)await t.push(o,{signal:e}),e.throwIfAborted()})),await t.end(void 0,{signal:e})}catch(n){await t.end(n,{signal:e}).catch(()=>{})}}async function*Rh(r){let t=new AbortController,e=Nn();kh(r,e,t.signal).catch(()=>{});try{yield*e}finally{t.abort()}}function*Dh(r){for(let t of r)yield*t}function Kh(...r){let t=[];for(let e of r)Uh(e)||t.push(e);return t.length===r.length?Dh(t):Rh(r)}var qc=Kh;function zc(r,...t){if(r==null)throw new Error("Empty pipeline");if(Qs(r)){let n=r;r=()=>n.source}else if(Gc(r)||Fc(r)){let n=r;r=()=>n}let e=[r,...t];if(e.length>1&&Qs(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++)Qs(e[n])&&(e[n]=Mh(e[n]));return Nh(...e)}var Nh=(...r)=>{let t;for(;r.length>0;)t=r.shift()(t);return t},Fc=r=>r?.[Symbol.asyncIterator]!=null,Gc=r=>r?.[Symbol.iterator]!=null,Qs=r=>r==null?!1:r.sink!=null&&r.source!=null,Mh=r=>t=>{let e=r.sink(t);if(e?.then!=null){let n=zn({objectMode:!0});e.then(()=>{n.end()},i=>{n.end(i)});let o,s=r.source;if(Fc(s))o=async function*(){yield*s,n.end()};else if(Gc(s))o=function*(){yield*s,n.end()};else throw new Error("Unknown duplex source type - must be Iterable or AsyncIterable");return qc(n,o())}return r.source};var cr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function jc(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function Fn(r){if(typeof r!="boolean")throw new Error(`boolean expected, not ${r}`)}function Gn(r){if(!Number.isSafeInteger(r)||r<0)throw new Error("positive integer expected, got "+r)}function _t(r,...t){if(!jc(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 ti(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 $c(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 ae(r){return new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4))}function ce(...r){for(let t=0;t<r.length;t++)r[t].fill(0)}function Oh(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}var Hh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Vh(r){if(typeof r!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(r))}function Wn(r){if(typeof r=="string")r=Vh(r);else if(jc(r))r=jn(r);else throw new Error("Uint8Array expected, got "+typeof r);return r}function Zc(r,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(r,t)}function Yc(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 ei=(r,t)=>{function e(n,...o){if(_t(n),!Hh)throw new Error("Non little-endian hardware is not yet supported");if(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 ri(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&&!qh(t))throw new Error("invalid output, must be aligned");return t}function Wc(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 Xc(r,t,e){Fn(e);let n=new Uint8Array(16),o=Oh(n);return Wc(o,0,BigInt(t),e),Wc(o,8,BigInt(r),e),n}function qh(r){return r.byteOffset%4===0}function jn(r){return Uint8Array.from(r)}var Qc=r=>Uint8Array.from(r.split("").map(t=>t.charCodeAt(0))),zh=Qc("expand 16-byte k"),Fh=Qc("expand 32-byte k"),Gh=ae(zh),Wh=ae(Fh);function N(r,t){return r<<t|r>>>32-t}function ni(r){return r.byteOffset%4===0}var $n=64,jh=16,tu=2**32-1,Jc=new Uint32Array;function $h(r,t,e,n,o,s,i,a){let c=o.length,f=new Uint8Array($n),u=ae(f),l=ni(o)&&ni(s),p=l?ae(o):Jc,w=l?ae(s):Jc;for(let y=0;y<c;i++){if(r(t,e,n,u,i,a),i>=tu)throw new Error("arx: counter overflow");let m=Math.min($n,c-y);if(l&&m===$n){let x=y/4;if(y%4!==0)throw new Error("arx: invalid block position");for(let _=0,M;_<jh;_++)M=x+_,w[M]=p[M]^u[_];y+=$n;continue}for(let x=0,_;x<m;x++)_=y+x,s[_]=o[_]^f[x];y+=m}}function oi(r,t){let{allowShortKeys:e,extendNonceFn:n,counterLength:o,counterRight:s,rounds:i}=Zc({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof r!="function")throw new Error("core must be a function");return Gn(o),Gn(i),Fn(s),Fn(e),(a,c,f,u,l=0)=>{_t(a),_t(c),_t(f);let p=f.length;if(u===void 0&&(u=new Uint8Array(p)),_t(u),Gn(l),l<0||l>=tu)throw new Error("arx: counter overflow");if(u.length<p)throw new Error(`arx: output (${u.length}) is shorter than data (${p})`);let w=[],y=a.length,m,x;if(y===32)w.push(m=jn(a)),x=Wh;else if(y===16&&e)m=new Uint8Array(32),m.set(a),m.set(a,16),x=Gh,w.push(m);else throw new Error(`arx: invalid 32-byte key, got length=${y}`);ni(c)||w.push(c=jn(c));let _=ae(m);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(x,_,ae(c.subarray(0,16)),_),c=c.subarray(16)}let M=16-o;if(M!==c.length)throw new Error(`arx: nonce must be ${M} or 16 bytes`);if(M!==12){let d=new Uint8Array(12);d.set(c,s?0:12-c.length),c=d,w.push(c)}let S=ae(c);return $h(r,x,_,S,f,u,l,i),ce(...w),u}}var Et=(r,t)=>r[t++]&255|(r[t++]&255)<<8,si=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=Wn(t),_t(t,32);let e=Et(t,0),n=Et(t,2),o=Et(t,4),s=Et(t,6),i=Et(t,8),a=Et(t,10),c=Et(t,12),f=Et(t,14);this.r[0]=e&8191,this.r[1]=(e>>>13|n<<3)&8191,this.r[2]=(n>>>10|o<<6)&7939,this.r[3]=(o>>>7|s<<9)&8191,this.r[4]=(s>>>4|i<<12)&255,this.r[5]=i>>>1&8190,this.r[6]=(i>>>14|a<<2)&8191,this.r[7]=(a>>>11|c<<5)&8065,this.r[8]=(c>>>8|f<<8)&8191,this.r[9]=f>>>5&127;for(let u=0;u<8;u++)this.pad[u]=Et(t,16+2*u)}process(t,e,n=!1){let o=n?0:2048,{h:s,r:i}=this,a=i[0],c=i[1],f=i[2],u=i[3],l=i[4],p=i[5],w=i[6],y=i[7],m=i[8],x=i[9],_=Et(t,e+0),M=Et(t,e+2),S=Et(t,e+4),d=Et(t,e+6),I=Et(t,e+8),U=Et(t,e+10),B=Et(t,e+12),L=Et(t,e+14),k=s[0]+(_&8191),K=s[1]+((_>>>13|M<<3)&8191),T=s[2]+((M>>>10|S<<6)&8191),D=s[3]+((S>>>7|d<<9)&8191),C=s[4]+((d>>>4|I<<12)&8191),H=s[5]+(I>>>1&8191),E=s[6]+((I>>>14|U<<2)&8191),A=s[7]+((U>>>11|B<<5)&8191),P=s[8]+((B>>>8|L<<8)&8191),b=s[9]+(L>>>5|o),h=0,g=h+k*a+K*(5*x)+T*(5*m)+D*(5*y)+C*(5*w);h=g>>>13,g&=8191,g+=H*(5*p)+E*(5*l)+A*(5*u)+P*(5*f)+b*(5*c),h+=g>>>13,g&=8191;let v=h+k*c+K*a+T*(5*x)+D*(5*m)+C*(5*y);h=v>>>13,v&=8191,v+=H*(5*w)+E*(5*p)+A*(5*l)+P*(5*u)+b*(5*f),h+=v>>>13,v&=8191;let R=h+k*f+K*c+T*a+D*(5*x)+C*(5*m);h=R>>>13,R&=8191,R+=H*(5*y)+E*(5*w)+A*(5*p)+P*(5*l)+b*(5*u),h+=R>>>13,R&=8191;let O=h+k*u+K*f+T*c+D*a+C*(5*x);h=O>>>13,O&=8191,O+=H*(5*m)+E*(5*y)+A*(5*w)+P*(5*p)+b*(5*l),h+=O>>>13,O&=8191;let q=h+k*l+K*u+T*f+D*c+C*a;h=q>>>13,q&=8191,q+=H*(5*x)+E*(5*m)+A*(5*y)+P*(5*w)+b*(5*p),h+=q>>>13,q&=8191;let z=h+k*p+K*l+T*u+D*f+C*c;h=z>>>13,z&=8191,z+=H*a+E*(5*x)+A*(5*m)+P*(5*y)+b*(5*w),h+=z>>>13,z&=8191;let F=h+k*w+K*p+T*l+D*u+C*f;h=F>>>13,F&=8191,F+=H*c+E*a+A*(5*x)+P*(5*m)+b*(5*y),h+=F>>>13,F&=8191;let G=h+k*y+K*w+T*p+D*l+C*u;h=G>>>13,G&=8191,G+=H*f+E*c+A*a+P*(5*x)+b*(5*m),h+=G>>>13,G&=8191;let J=h+k*m+K*y+T*w+D*p+C*l;h=J>>>13,J&=8191,J+=H*u+E*f+A*c+P*a+b*(5*x),h+=J>>>13,J&=8191;let Z=h+k*x+K*m+T*y+D*w+C*p;h=Z>>>13,Z&=8191,Z+=H*l+E*u+A*f+P*c+b*a,h+=Z>>>13,Z&=8191,h=(h<<2)+h|0,h=h+g|0,g=h&8191,h=h>>>13,v+=h,s[0]=g,s[1]=v,s[2]=R,s[3]=O,s[4]=q,s[5]=z,s[6]=F,s[7]=G,s[8]=J,s[9]=Z}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;ce(n)}update(t){ti(this),t=Wn(t),_t(t);let{buffer:e,blockLen:n}=this,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(){ce(this.h,this.r,this.buffer,this.pad)}digestInto(t){ti(this),$c(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 Zh(r){let t=(n,o)=>r(o).update(Wn(n)).digest(),e=r(new Uint8Array(32));return t.outputLen=e.outputLen,t.blockLen=e.blockLen,t.create=n=>r(n),t}var eu=Zh(r=>new si(r));function ou(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],p=t[2],w=t[3],y=t[4],m=t[5],x=t[6],_=t[7],M=o,S=e[0],d=e[1],I=e[2],U=i,B=a,L=c,k=f,K=u,T=l,D=p,C=w,H=y,E=m,A=x,P=_,b=M,h=S,g=d,v=I;for(let O=0;O<s;O+=2)U=U+K|0,b=N(b^U,16),H=H+b|0,K=N(K^H,12),U=U+K|0,b=N(b^U,8),H=H+b|0,K=N(K^H,7),B=B+T|0,h=N(h^B,16),E=E+h|0,T=N(T^E,12),B=B+T|0,h=N(h^B,8),E=E+h|0,T=N(T^E,7),L=L+D|0,g=N(g^L,16),A=A+g|0,D=N(D^A,12),L=L+D|0,g=N(g^L,8),A=A+g|0,D=N(D^A,7),k=k+C|0,v=N(v^k,16),P=P+v|0,C=N(C^P,12),k=k+C|0,v=N(v^k,8),P=P+v|0,C=N(C^P,7),U=U+T|0,v=N(v^U,16),A=A+v|0,T=N(T^A,12),U=U+T|0,v=N(v^U,8),A=A+v|0,T=N(T^A,7),B=B+D|0,b=N(b^B,16),P=P+b|0,D=N(D^P,12),B=B+D|0,b=N(b^B,8),P=P+b|0,D=N(D^P,7),L=L+C|0,h=N(h^L,16),H=H+h|0,C=N(C^H,12),L=L+C|0,h=N(h^L,8),H=H+h|0,C=N(C^H,7),k=k+K|0,g=N(g^k,16),E=E+g|0,K=N(K^E,12),k=k+K|0,g=N(g^k,8),E=E+g|0,K=N(K^E,7);let R=0;n[R++]=i+U|0,n[R++]=a+B|0,n[R++]=c+L|0,n[R++]=f+k|0,n[R++]=u+K|0,n[R++]=l+T|0,n[R++]=p+D|0,n[R++]=w+C|0,n[R++]=y+H|0,n[R++]=m+E|0,n[R++]=x+A|0,n[R++]=_+P|0,n[R++]=M+b|0,n[R++]=S+h|0,n[R++]=d+g|0,n[R++]=I+v|0}function Yh(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],p=t[4],w=t[5],y=t[6],m=t[7],x=e[0],_=e[1],M=e[2],S=e[3];for(let I=0;I<20;I+=2)o=o+c|0,x=N(x^o,16),p=p+x|0,c=N(c^p,12),o=o+c|0,x=N(x^o,8),p=p+x|0,c=N(c^p,7),s=s+f|0,_=N(_^s,16),w=w+_|0,f=N(f^w,12),s=s+f|0,_=N(_^s,8),w=w+_|0,f=N(f^w,7),i=i+u|0,M=N(M^i,16),y=y+M|0,u=N(u^y,12),i=i+u|0,M=N(M^i,8),y=y+M|0,u=N(u^y,7),a=a+l|0,S=N(S^a,16),m=m+S|0,l=N(l^m,12),a=a+l|0,S=N(S^a,8),m=m+S|0,l=N(l^m,7),o=o+f|0,S=N(S^o,16),y=y+S|0,f=N(f^y,12),o=o+f|0,S=N(S^o,8),y=y+S|0,f=N(f^y,7),s=s+u|0,x=N(x^s,16),m=m+x|0,u=N(u^m,12),s=s+u|0,x=N(x^s,8),m=m+x|0,u=N(u^m,7),i=i+l|0,_=N(_^i,16),p=p+_|0,l=N(l^p,12),i=i+l|0,_=N(_^i,8),p=p+_|0,l=N(l^p,7),a=a+c|0,M=N(M^a,16),w=w+M|0,c=N(c^w,12),a=a+c|0,M=N(M^a,8),w=w+M|0,c=N(c^w,7);let d=0;n[d++]=o,n[d++]=s,n[d++]=i,n[d++]=a,n[d++]=x,n[d++]=_,n[d++]=M,n[d++]=S}var Xh=oi(ou,{counterRight:!1,counterLength:4,allowShortKeys:!1}),Jh=oi(ou,{counterRight:!1,counterLength:8,extendNonceFn:Yh,allowShortKeys:!1});var Qh=new Uint8Array(16),ru=(r,t)=>{r.update(t);let e=t.length%16;e&&r.update(Qh.subarray(e))},td=new Uint8Array(32);function nu(r,t,e,n,o){let s=r(t,e,td),i=eu.create(s);o&&ru(i,o),ru(i,n);let a=Xc(n.length,o?o.length:0,!0);i.update(a);let c=i.digest();return ce(s,a),c}var su=r=>(t,e,n)=>({encrypt(s,i){let a=s.length;i=ri(a+16,i,!1),i.set(s);let c=i.subarray(0,-16);r(t,e,c,c,1);let f=nu(r,t,e,c,n);return i.set(f,a),ce(f),i},decrypt(s,i){i=ri(s.length-16,i,!1);let a=s.subarray(0,-16),c=s.subarray(-16),f=nu(r,t,e,a,n);if(!Yc(c,f))throw new Error("invalid tag");return i.set(s.subarray(0,-16)),r(t,e,i,i,1),ce(f),i}}),ii=ei({blockSize:64,nonceLength:12,tagLength:16},su(Xh)),ew=ei({blockSize:64,nonceLength:24,tagLength:16},su(Jh));function au(r,t,e){return vr(r),e===void 0&&(e=new Uint8Array(r.outputLen)),or(r,pe(e),pe(t))}var ai=Uint8Array.from([0]),iu=Uint8Array.of();function cu(r,t,e,n=32){vr(r),Ze(n);let o=r.outputLen;if(n>255*o)throw new Error("Length should be <= 255*HashLen");let s=Math.ceil(n/o);e===void 0&&(e=iu);let i=new Uint8Array(s*o),a=or.create(r,t),c=a._cloneInto(),f=new Uint8Array(a.outputLen);for(let u=0;u<s;u++)ai[0]=u+1,c.update(u===0?iu:f).update(e).update(ai).digestInto(f),i.set(f,o*u),a._cloneInto(c);return a.destroy(),c.destroy(),Ht(f,ai),i.slice(0,n)}var ci={hashSHA256(r){return Ae(r.subarray())},getHKDF(r,t){let e=au(Ae,t,r),o=cu(Ae,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=Rr.utils.randomPrivateKey();return{publicKey:Rr.getPublicKey(r),privateKey:r}},generateX25519KeyPairFromSeed(r){return{publicKey:Rr.getPublicKey(r),privateKey:r}},generateX25519SharedKey(r,t){return Rr.getSharedSecret(r.subarray(),t.subarray())},chaCha20Poly1305Encrypt(r,t,e,n){return ii(n,t,e).encrypt(r.subarray())},chaCha20Poly1305Decrypt(r,t,e,n,o){return ii(n,t,e).decrypt(r.subarray(),o)}};var uu=ci;function fu(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 ur=r=>{let t=pt(2);return t[0]=r>>8,t[1]=r,t};ur.bytes=2;var Yr=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)};Yr.bytes=2;function lu(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 ui(r,t){!t.enabled||!cr||(r?(t(`LOCAL_STATIC_PUBLIC_KEY ${V(r.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${V(r.privateKey,"hex")}`)):t("Missing local static keys."))}function fi(r,t){!t.enabled||!cr||(r?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${V(r.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${V(r.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function hu(r,t){!t.enabled||!cr||t(r?`REMOTE_STATIC_PUBLIC_KEY ${V(r.subarray(),"hex")}`:"Missing remote static public key.")}function li(r,t){!t.enabled||!cr||t(r?`REMOTE_EPHEMERAL_PUBLIC_KEY ${V(r.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function hi(r,t,e){!e.enabled||!cr||(e(`CIPHER_STATE_1 ${r.n.getUint64()} ${r.k&&V(r.k,"hex")}`),e(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&V(t.k,"hex")}`))}var fr=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,rd=4294967295,nd="Cipherstate has reached maximum n, a new handshake must be performed",Zn=class{n;bytes;view;constructor(t=ed){this.n=t,this.bytes=dt(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>rd)throw new Error(nd)}};var He=dt(0),lr=class{k;n;crypto;constructor(t,e=void 0,n=0){this.crypto=t,this.k=e,this.n=new Zn(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}},di=class{cs;ck;h;crypto;constructor(t,e){this.crypto=t;let n=Q(e,"utf-8");this.h=od(t,n),this.ck=this.h,this.cs=new lr(t)}mixKey(t){let[e,n]=this.crypto.hkdf(this.ck,t);this.ck=e,this.cs=new lr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new $(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,He);return[new lr(this.crypto,t),new lr(this.crypto,e)]}},pi=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 di(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()}},Xr=class extends pi{writeMessageA(t){return new $(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let e=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new $(e,n,this.ss.encryptAndHash(t))}writeMessageC(t){let e=this.writeS();return this.writeSE(),new $(e,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(e){throw new fr(`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 fr(`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 fr(`handshake stage 2 validation fail: ${e.message}`)}}};function od(r,t){if(t.length<=32){let e=dt(32);return e.set(t),e}else return r.hash(t)}var Yn;(function(r){let t;r.codec=()=>(t==null&&(t=Me((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 Mr('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 Mr('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=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Yn||(Yn={}));var Jr;(function(r){let t;r.codec=()=>(t==null&&(t=Me((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),Yn.codec().encode(e.extensions,n)),o.lengthDelimited!==!1&&n.ldelim()},(e,n,o={})=>{let s={identityKey:dt(0),identitySig:dt(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=Yn.codec().decode(e,e.uint32(),{limits:o.limits?.extensions});break}default:{e.skipType(a&7);break}}}return s})),t),r.encode=e=>Ne(e,r.codec()),r.decode=(e,n)=>De(e,r.codec(),n)})(Jr||(Jr={}));async function mi(r,t,e){let n=await r.sign(du(t));return Jr.encode({identityKey:de(r.publicKey),identitySig:n,extensions:e})}async function yi(r,t,e){try{let n=Jr.decode(r),o=qr(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=du(t);if(!await o.verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new rn(n.message)}}function du(r){let t=Q("noise-libp2p-static-key:");return r instanceof Uint8Array?At([t,r],t.length+r.length):(r.prepend(t),r)}async function pu(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:f}=r,u=await mi(s,a.publicKey,f),l=new Xr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:i,s:a});ui(l.s,e),e.trace("Stage 0 - Initiator starting to send first message."),await n.write(l.writeMessageA(He),t),e.trace("Stage 0 - Initiator finished sending first message."),fi(l.e,e),e.trace("Stage 1 - Initiator waiting to receive first message from responder...");let p=l.readMessageB(await n.read(t));e.trace("Stage 1 - Initiator received the message."),li(l.re,e),hu(l.rs,e),e.trace("Initiator going to check remote's signature...");let w=await yi(p,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[y,m]=l.ss.split();return hi(y,m,e),{payload:w,encrypt:x=>y.encryptWithAd(He,x),decrypt:(x,_)=>m.decryptWithAd(He,x,_)}}async function mu(r,t){let{log:e,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:f}=r,u=await mi(s,a.publicKey,f),l=new Xr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:i,s:a});ui(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."),li(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."),fi(l.e,e),e.trace("Stage 2 - Responder waiting for third handshake message...");let p=l.readMessageC(await n.read(t));e.trace("Stage 2 - Responder received the message, finished handshake.");let w=await yi(p,l.rs,c),[y,m]=l.ss.split();return hi(y,m,e),{payload:w,encrypt:x=>m.encryptWithAd(He,x),decrypt:(x,_)=>y.decryptWithAd(He,x,_)}}var gu=16;function xu(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 $(ur(i.byteLength),i)}}}function wu(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-gu<o)throw new Error("Invalid chunk");let i=n.sublist(o,s),a=n.subarray(o,s-gu);try{let c=r.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var Xn=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??uu;this.crypto=fu(c),this.extensions={webtransportCerthashes:[],...o},this.metrics=a?lu(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??dt(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[un]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(t,e){let n=Ys(t,{lengthEncoder:ur,lengthDecoder:Yr,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=qr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:js(i),streamMuxer:e?.skipStreamMuxerNegotiation===!0?void 0:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}getStreamMuxer(t){if(t==null||t.length===0)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 ze("Early muxer negotiation was requested but the initiator and responder had no common muxers")}async secureInbound(t,e){let n=Ys(t,{lengthEncoder:ur,lengthDecoder:Yr,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=qr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:js(i),streamMuxer:e?.skipStreamMuxerNegotiation===!0?void 0:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}async performHandshakeInitiator(t,e,n,o){let s,i=o?.skipStreamMuxerNegotiation===!0?[]:[...this.components.upgrader.getStreamMuxers().keys()];try{s=await pu({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:i,webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(a){throw this.metrics?.xxHandshakeErrors.increment(),a}return s}async performHandshakeResponder(t,e,n,o){let s,i=o?.skipStreamMuxerNegotiation===!0?[]:[...this.components.upgrader.getStreamMuxers().keys()];try{s=await mu({connection:t,privateKey:e,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:{streamMuxers:i,webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(a){throw this.metrics?.xxHandshakeErrors.increment(),a}return s}async createSecureConnection(t,e){let[n,o]=Vc(),s=t.unwrap();return await zc(n,xu(e,this.metrics),s,i=>Zr(i,{lengthDecoder:Yr}),wu(e,this.metrics),n),o}};function bu(r={}){return t=>new Xn(t,r)}var Jn=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 p=Number.parseInt(l,t);if(!Number.isNaN(p))return p});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 Eu=45,sd=15,hr=new Jn;function gi(r){if(!(r.length>sd))return hr.new(r).parseWith(()=>hr.readIPv4Addr())}function xi(r){if(r.includes("%")&&(r=r.split("%")[0]),!(r.length>Eu))return hr.new(r).parseWith(()=>hr.readIPv6Addr())}function Qn(r,t=!1){if(r.includes("%")&&(r=r.split("%")[0]),r.length>Eu)return;let e=hr.new(r).parseWith(()=>hr.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 to(r){return!!gi(r)}function eo(r){return!!xi(r)}function ro(r){return!!Qn(r)}var id=r=>r.toString().split("/").slice(1),dr=r=>({match:t=>t.length<1?!1:r(t[0])?t.slice(1):!1,pattern:"fn"}),W=r=>({match:t=>dr(e=>e===r).match(t),pattern:r}),Ve=()=>({match:r=>dr(t=>typeof t=="string").match(r),pattern:"{string}"}),pr=()=>({match:r=>dr(t=>!isNaN(parseInt(t))).match(r),pattern:"{number}"}),rt=()=>({match:r=>{if(r.length<2||r[0]!=="p2p"&&r[0]!=="ipfs")return!1;if(r[1].startsWith("Q")||r[1].startsWith("1"))try{nt.decode(`z${r[1]}`)}catch{return!1}else return!1;return r.slice(2)},pattern:"/p2p/{peerid}"}),tn=()=>({match:r=>{if(r.length<2||r[0]!=="certhash")return!1;try{Uo.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})`}),Lt=(...r)=>({match:t=>{let e;for(let n of r){let o=n.match(t);o!==!1&&(e==null||o.length<e.length)&&(e=o)}return e??!1},pattern:`or(${r.map(t=>t.pattern).join(", ")})`}),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 it(...r){function t(o){let s=id(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 ad=rt(),Kb=it(ad),oo=j(W("dns4"),Ve()),so=j(W("dns6"),Ve()),io=j(W("dnsaddr"),Ve()),bi=j(W("dns"),Ve()),Nb=it(oo,X(rt())),Mb=it(so,X(rt())),Ob=it(io,X(rt())),Hb=it(Lt(bi,io,oo,so),X(rt())),Su=j(W("ip4"),dr(to)),Au=j(W("ip6"),dr(eo)),Ei=Lt(Su,Au),ue=Lt(Ei,bi,oo,so,io),Vb=it(Lt(Ei,j(Lt(bi,io,oo,so),X(rt())))),qb=it(Su),zb=it(Au),Fb=it(Ei),Si=j(ue,W("tcp"),pr()),en=j(ue,W("udp"),pr()),Gb=it(j(Si,X(rt()))),Wb=it(en),Ai=j(en,W("quic"),X(rt())),ao=j(en,W("quic-v1"),X(rt())),cd=Lt(Ai,ao),jb=it(Ai),$b=it(ao),wi=Lt(ue,Si,en,Ai,ao),vu=Lt(j(wi,W("ws"),X(rt()))),Zb=it(vu),Iu=Lt(j(wi,W("wss"),X(rt())),j(wi,W("tls"),X(j(W("sni"),Ve())),W("ws"),X(rt()))),Yb=it(Iu),Bu=j(en,W("webrtc-direct"),X(tn()),X(tn()),X(rt())),Xb=it(Bu),_u=j(ao,W("webtransport"),X(tn()),X(tn()),X(rt())),co=it(_u),no=Lt(vu,Iu,j(Si,X(rt())),j(cd,X(rt())),j(ue,X(rt())),Bu,_u,rt()),Jb=it(no),ud=j(no,W("p2p-circuit"),rt()),Qb=it(ud),fd=Lt(j(no,W("p2p-circuit"),W("webrtc"),X(rt())),j(no,W("webrtc"),X(rt())),j(W("webrtc"),X(rt()))),t1=it(fd),ld=Lt(j(ue,W("tcp"),pr(),W("http"),X(rt())),j(ue,W("http"),X(rt()))),e1=it(ld),hd=Lt(j(ue,W("tcp"),Lt(j(W("443"),W("http")),j(pr(),W("https")),j(pr(),W("tls"),W("http"))),X(rt())),j(ue,W("tls"),W("http"),X(rt())),j(ue,W("https"),X(rt()))),r1=it(hd),dd=Lt(j(W("memory"),Ve(),X(rt()))),n1=it(dd);var qe=class extends Event{type;detail;constructor(t,e){super(t),this.type=t,this.detail=e}};function vi(r){throw new Error("Not implemented")}function Lu(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 Tu(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}function Cu(r,t){let e=Lu(r).return?.();Tu(e)&&e.catch(n=>{t.error("could not cause iterator to return",n)})}var pd=5e3;function Ii(r){return r==null?!1:typeof r.then=="function"&&typeof r.catch=="function"&&typeof r.finally=="function"}var uo=class{id;direction;timeline;protocol;metadata;source;status;readStatus;writeStatus;log;sinkController;sinkEnd;closed;endErr;streamSource;onEnd;onCloseRead;onCloseWrite;onReset;onAbort;sendCloseWriteTimeout;sendingData;constructor(t){this.sinkController=new AbortController,this.sinkEnd=Ut(),this.closed=Ut(),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??pd,this.onEnd=t.onEnd,this.onCloseRead=t.onCloseRead,this.onCloseWrite=t.onCloseWrite,this.onReset=t.onReset,this.onAbort=t.onAbort,this.source=this.streamSource=zn({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 on(`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);Ii(o)&&await o}let n=()=>{Cu(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 $(o):o;let s=this.sendData(o,e);Ii(s)&&(this.sendingData=Ut(),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 xt(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 xt(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await xt(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await xt(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();Ii(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 nn("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 Bi=class extends uo{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 $(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(let n of t)this.log("sendData waiting for writer to be ready"),await xt(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 xt(this.writer.abort(),t?.signal),this.log("sendReset aborted writer")}async sendCloseWrite(t){this.log("sendCloseWrite closing writer"),await xt(this.writer.close(),t?.signal),this.log("sendCloseWrite closed writer")}async sendCloseRead(t){this.log("sendCloseRead cancelling reader"),await xt(this.reader.cancel(),t?.signal),this.log("sendCloseRead cancelled reader")}};async function _i(r,t,e,n,o,s){let i=s.forComponent(`libp2p:webtransport:stream:${e}:${t}`),a=new Bi({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 fo(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async r=>new Promise(()=>{})}}function Pu(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 _i(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 _i(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)}},...fo()};return c}}}function Uu(r,t){return t.filter(n=>!!r.find(o=>ht(n,o))).length===t.length}var D1=parseInt("0xFFFF",16),K1=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Du=to,wd=eo,Li=function(r){let t=0;if(r=r.toString().trim(),Du(r)){let e=new Uint8Array(t+4);return r.split(/\./g).forEach(n=>{e[t++]=parseInt(n,10)&255}),e}if(wd(r)){let e=r.split(":",8),n;for(n=0;n<e.length;n++){let s=Du(e[n]),i;s&&(i=Li(e[n]),e[n]=V(i.slice(0,2),"base16")),i!=null&&++n<8&&e.splice(n,0,V(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")},Ku=function(r,t=0,e){t=~~t,e=e??r.length-t;let n=new DataView(r.buffer);if(e===4){let o=[];for(let s=0;s<e;s++)o.push(r[t+s]);return o.join(".")}if(e===16){let o=[];for(let s=0;s<e;s+=2)o.push(n.getUint16(t+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var mr={},Ti={},Ed=[[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"]];Ed.forEach(r=>{let t=Sd(...r);Ti[t.code]=t,mr[t.name]=t});function Sd(r,t,e,n,o){return{code:r,size:t,name:e,resolvable:!!n,path:!!o}}function et(r){if(typeof r=="number"){if(Ti[r]!=null)return Ti[r];throw new Error(`no protocol with code: ${r}`)}else if(typeof r=="string"){if(mr[r]!=null)return mr[r];throw new Error(`no protocol with name: ${r}`)}throw new Error(`invalid protocol id type: ${typeof r}`)}var g2=et("ip4"),x2=et("ip6"),w2=et("ipcidr");function ki(r,t){switch(et(r).code){case 4:case 41:return vd(t);case 42:return Ui(t);case 43:return V(t,"base10");case 6:case 273:case 33:case 132:return Ou(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ui(t);case 421:return Ld(t);case 444:return Mu(t);case 445:return Mu(t);case 466:return _d(t);case 481:return globalThis.encodeURIComponent(Ui(t));default:return V(t,"base16")}}function Ri(r,t){switch(et(r).code){case 4:return Nu(t);case 41:return Nu(t);case 42:return Pi(t);case 43:return Q(t,"base10");case 6:case 273:case 33:case 132:return Di(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Pi(t);case 421:return Id(t);case 444:return Td(t);case 445:return Cd(t);case 466:return Bd(t);case 481:return Pi(globalThis.decodeURIComponent(t));default:return Q(t,"base16")}}var Ci=Object.values(Be).map(r=>r.decoder),Ad=function(){let r=Ci[0].or(Ci[1]);return Ci.slice(2).forEach(t=>r=r.or(t)),r}();function Nu(r){if(!ro(r))throw new Error("invalid ip address");return Li(r)}function vd(r){let t=Ku(r,0,r.length);if(t==null)throw new Error("ipBuff is required");if(!ro(t))throw new Error("invalid ip address");return t}function Di(r){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,r),new Uint8Array(t)}function Ou(r){return new DataView(r.buffer).getUint16(r.byteOffset)}function Pi(r){let t=Q(r),e=Uint8Array.from(Yt(t.length));return At([e,t],e.length+t.length)}function Ui(r){let t=zt(r);if(r=r.slice(lt(t)),r.length!==t)throw new Error("inconsistent lengths");return V(r)}function Id(r){let t;r[0]==="Q"||r[0]==="1"?t=le(nt.decode(`z${r}`)).bytes:t=ut.parse(r).multihash.bytes;let e=Uint8Array.from(Yt(t.length));return At([e,t],e.length+t.length)}function Bd(r){let t=Ad.decode(r),e=Uint8Array.from(Yt(t.length));return At([e,t],e.length+t.length)}function _d(r){let t=zt(r),e=r.slice(lt(t));if(e.length!==t)throw new Error("inconsistent lengths");return"u"+V(e,"base64url")}function Ld(r){let t=zt(r),e=r.slice(lt(t));if(e.length!==t)throw new Error("inconsistent lengths");return V(e,"base58btc")}function Td(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=Qt.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=Di(n);return At([e,o],e.length+o.length)}function Cd(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=Qt.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=Di(n);return At([e,o],e.length+o.length)}function Mu(r){let t=r.slice(0,r.length-2),e=r.slice(r.length-2),n=V(t,"base32"),o=Ou(e);return`${n}:${o}`}function Hu(r){r=Ki(r);let t=[],e=[],n=null,o=r.split("/").slice(1);if(o.length===1&&o[0]==="")return{bytes:new Uint8Array,string:"/",tuples:[],stringTuples:[],path:null};for(let s=0;s<o.length;s++){let i=o[s],a=et(i);if(a.size===0){t.push([a.code]),e.push([a.code]);continue}if(s++,s>=o.length)throw new lo("invalid address: "+r);if(a.path===!0){n=Ki(o.slice(s).join("/")),t.push([a.code,Ri(a.code,n)]),e.push([a.code,n]);break}let c=Ri(a.code,o[s]);t.push([a.code,c]),e.push([a.code,ki(a.code,c)])}return{string:Vu(e),bytes:ho(t),tuples:t,stringTuples:e,path:n}}function Ni(r){let t=[],e=[],n=null,o=0;for(;o<r.length;){let s=zt(r,o),i=lt(s),a=et(s),c=Pd(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 lo("Invalid address Uint8Array: "+V(r,"base16"));t.push([s,f]);let u=ki(s,f);if(e.push([s,u]),a.path===!0){n=u;break}}return{bytes:Uint8Array.from(r),string:Vu(e),tuples:t,stringTuples:e,path:n}}function Vu(r){let t=[];return r.map(e=>{let n=et(e[0]);return t.push(n.name),e.length>1&&e[1]!=null&&t.push(e[1]),null}),Ki(t.join("/"))}function ho(r){return At(r.map(t=>{let e=et(t[0]),n=Uint8Array.from(Yt(e.code));return t.length>1&&t[1]!=null&&(n=At([n,t[1]])),n}))}function Pd(r,t){if(r.size>0)return r.size/8;if(r.size===0)return 0;{let e=zt(t instanceof Uint8Array?t:Uint8Array.from(t));return e+lt(e)}}function Ki(r){return"/"+r.trim().split("/").filter(t=>t).join("/")}var lo=class extends Error{static name="ParseError";name="ParseError";constructor(t){super(`Error parsing address: ${t}`)}};var Ud=Symbol.for("nodejs.util.inspect.custom"),Oi=Symbol.for("@multiformats/js-multiaddr/multiaddr"),kd=[et("dns").code,et("dns4").code,et("dns6").code,et("dnsaddr").code],Mi=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},po=class r{bytes;#e;#t;#r;#n;[Oi]=!0;constructor(t){t==null&&(t="");let e;if(t instanceof Uint8Array)e=Ni(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);e=Hu(t)}else if(zu(t))e=Ni(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=et("tcp"),a=et("udp"),c=et("ip4"),f=et("ip6"),u=et("dns6"),l=et("ip6zone");for(let[w,y]of this.stringTuples())w===l.code&&(s=`%${y??""}`),kd.includes(w)&&(e=i.name==="tcp"?"tcp":"udp",o=443,n=`${y??""}${s}`,t=w===u.code?6:4),(w===i.code||w===a.code)&&(e=et(w).name==="tcp"?"tcp":"udp",o=parseInt(y??"")),(w===c.code||w===f.code)&&(e=et(w).name==="tcp"?"tcp":"udp",n=`${y??""}${s}`,t=w===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({},et(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>et(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(ho(e.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===mr.p2p.code&&t.push([n,o]),n===mr["p2p-circuit"].code&&(t=[])});let e=t.pop();if(e?.[1]!=null){let n=e[1];return n[0]==="Q"||n[0]==="1"?V(nt.decode(`z${n}`),"base58btc"):V(ut.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return ht(this.bytes,t.bytes)}async resolve(t){let e=this.protos().find(s=>s.resolvable);if(e==null)return[this];let n=qu.get(e.name);if(n==null)throw new Mi(`no available resolver for ${e.name}`);return(await n(this,t)).map(s=>Hi(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)}[Ud](){return`Multiaddr(${this.#e})`}};var qu=new Map;function zu(r){return!!r?.[Oi]}function Hi(r){return new po(r)}var Rd=Object.values(Be).map(r=>r.decoder).reduce((r,t)=>r.or(t));function Dd(r){return Gt.decode(Rd.decode(r))}function Vi(r){if(!co.matches(r))throw new sn("Invalid multiaddr, was not a WebTransport address");let t=r.stringTuples(),e=t.filter(([i,a])=>i===et("certhash").code).map(([i,a])=>Dd(a??"")),n=t.filter(([i,a])=>i===et("p2p").code).map(([i,a])=>Kc(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 Fu=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";[Gi]=!0;[un]=["@libp2p/transport"];async dial(t,e){e.signal.throwIfAborted(),this.log("dialing %s",t),e=e??{};let{url:n,certhashes:o,remotePeer:s}=Vi(t),i,a,c=()=>{},f=!1,u=!1,l=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let p=new Fu(`${n}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(w=>({algorithm:"sha-256",value:w.digest}))});if(c=w=>{if(!f)try{this.metrics?.dialerEvents.increment({[w]:!0}),p.close()}catch(y){this.log.error("error closing wt session",y)}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 qe("webtransport:wait-for-session")),await Promise.race([p.closed,p.ready]),this.log("session became ready"),u=!0,this.metrics?.dialerEvents.increment({ready:!0}),p.closed.catch(w=>{this.log.error("error on remote wt session close",w)}).finally(()=>{c("remote_close")}),l=await xt(this.authenticateWebTransport({wt:p,remotePeer:s,certhashes:o,...e}),e.signal),!l)throw new ze("Failed to authenticate webtransport");return this.metrics?.dialerEvents.increment({open:!0}),a={close:async()=>{this.log("closing webtransport"),c("close")},abort:w=>{this.log("aborting webtransport due to passed err",w),c("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...fo()},await e.upgrader.upgradeOutbound(a,{...e,skipEncryption:!0,muxerFactory:Pu(p,p.incomingBidirectionalStreams.getReader(),this.components.logger,this.config),skipProtection:!0})}catch(p){throw this.log.error("caught wt session err",p),c(l?"upgrade_error":u?"noise_error":"ready_error"),p}finally{i!=null&&e.signal?.removeEventListener("abort",i)}}async authenticateWebTransport({wt:t,remotePeer:e,certhashes:n,onProgress:o,signal:s}){s?.throwIfAborted(),o?.(new qe("webtransport:open-authentication-stream"));let i=await t.createBidirectionalStream(),a=i.writable.getWriter(),c=i.readable.getReader(),f={source:async function*(){for(;;){let p=await c.read();if(p.value!=null&&(yield p.value),p.done)break}}(),sink:async p=>{for await(let w of p){await xt(a.ready,s);let y=w instanceof Uint8Array?w:w.subarray();a.write(y).catch(m=>{this.log.error("could not write chunk during authentication of WebTransport stream",m)})}}},u=bu()(this.components);o?.(new qe("webtransport:secure-outbound-connection"));let{remoteExtensions:l}=await u.secureOutbound(f,{signal:s,remotePeer:e,skipStreamMuxerNegotiation:!0});if(o?.(new qe("webtransport:close-authentication-stream")),a.close().catch(p=>{this.log.error(`Failed to close authentication stream writer: ${p.message}`)}),c.cancel().catch(p=>{this.log.error(`Failed to close authentication stream reader: ${p.message}`)}),!Uu(l?.webtransportCerthashes??[],n.map(p=>p.bytes)))throw new at("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return vi(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return globalThis.WebTransport==null?[]:t.filter(e=>{if(!co.exactMatch(e))return!1;let{url:n,certhashes:o}=Vi(e);return n!=null&&o.length>0})}};function Kd(r={}){return t=>new qi(t,r)}return Qu(Nd);})();
2
+ "use strict";var Libp2PWebtransport=(()=>{var mo=Object.defineProperty;var Hf=Object.getOwnPropertyDescriptor;var qf=Object.getOwnPropertyNames;var Vf=Object.prototype.hasOwnProperty;var vt=(e,t)=>{for(var r in t)mo(e,r,{get:t[r],enumerable:!0})},zf=(e,t,r,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of qf(t))!Vf.call(e,o)&&o!==r&&mo(e,o,{get:()=>t[o],enumerable:!(n=Hf(t,o))||n.enumerable});return e};var Ff=e=>zf(mo({},"__esModule",{value:!0}),e);var Kd={};vt(Kd,{webTransport:()=>Ud});var yo=Symbol.for("@libp2p/peer-id");var Mi=Symbol.for("@libp2p/transport");var Ni;(function(e){e[e.FATAL_ALL=0]="FATAL_ALL",e[e.NO_FATAL=1]="NO_FATAL"})(Ni||(Ni={}));var Jr=class extends Error{static name="UnexpectedPeerError";constructor(t="Unexpected Peer"){super(t),this.name="UnexpectedPeerError"}},Me=class extends Error{static name="InvalidCryptoExchangeError";constructor(t="Invalid crypto exchange"){super(t),this.name="InvalidCryptoExchangeError"}},ot=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 Qr=class extends Error{static name="StreamResetError";constructor(t="The stream has been reset"){super(t),this.name="StreamResetError"}},tn=class extends Error{static name="StreamStateError";constructor(t="The stream is in an invalid state"){super(t),this.name="StreamStateError"}};var en=class extends Error{static name="InvalidMultiaddrError";constructor(t="Invalid multiaddr"){super(t),this.name="InvalidMultiaddrError"}},rn=class extends Error{static name="InvalidCIDError";constructor(t="Invalid CID"){super(t),this.name="InvalidCIDError"}},nn=class extends Error{static name="InvalidMultihashError";constructor(t="Invalid Multihash"){super(t),this.name="InvalidMultihashError"}};var ge=class extends Error{static name="UnsupportedKeyTypeError";constructor(t="Unsupported key type"){super(t),this.name="UnsupportedKeyTypeError"}};var on=Symbol.for("@libp2p/service-capabilities"),Hd=Symbol.for("@libp2p/service-dependencies");var Eo={};vt(Eo,{base58btc:()=>X,base58flickr:()=>Xf});var cp=new Uint8Array(0);function Oi(e,t){if(e===t)return!0;if(e.byteLength!==t.byteLength)return!1;for(let r=0;r<e.byteLength;r++)if(e[r]!==t[r])return!1;return!0}function Yt(e){if(e instanceof Uint8Array&&e.constructor.name==="Uint8Array")return e;if(e instanceof ArrayBuffer)return new Uint8Array(e);if(ArrayBuffer.isView(e))return new Uint8Array(e.buffer,e.byteOffset,e.byteLength);throw new Error("Unknown type, must be binary type")}function Hi(e){return new TextEncoder().encode(e)}function qi(e){return new TextDecoder().decode(e)}function Gf(e,t){if(e.length>=255)throw new TypeError("Alphabet too long");for(var r=new Uint8Array(256),n=0;n<r.length;n++)r[n]=255;for(var o=0;o<e.length;o++){var s=e.charAt(o),i=s.charCodeAt(0);if(r[i]!==255)throw new TypeError(s+" is ambiguous");r[i]=o}var a=e.length,c=e.charAt(0),u=Math.log(a)/Math.log(256),f=Math.log(256)/Math.log(a);function l(g){if(g instanceof Uint8Array||(ArrayBuffer.isView(g)?g=new Uint8Array(g.buffer,g.byteOffset,g.byteLength):Array.isArray(g)&&(g=Uint8Array.from(g))),!(g instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(g.length===0)return"";for(var w=0,h=0,E=0,B=g.length;E!==B&&g[E]===0;)E++,w++;for(var _=(B-E)*f+1>>>0,K=new Uint8Array(_);E!==B;){for(var S=g[E],k=0,C=_-1;(S!==0||k<h)&&C!==-1;C--,k++)S+=256*K[C]>>>0,K[C]=S%a>>>0,S=S/a>>>0;if(S!==0)throw new Error("Non-zero carry");h=k,E++}for(var T=_-h;T!==_&&K[T]===0;)T++;for(var d=c.repeat(w);T<_;++T)d+=e.charAt(K[T]);return d}function m(g){if(typeof g!="string")throw new TypeError("Expected String");if(g.length===0)return new Uint8Array;var w=0;if(g[w]!==" "){for(var h=0,E=0;g[w]===c;)h++,w++;for(var B=(g.length-w)*u+1>>>0,_=new Uint8Array(B);g[w];){var K=r[g.charCodeAt(w)];if(K===255)return;for(var S=0,k=B-1;(K!==0||S<E)&&k!==-1;k--,S++)K+=a*_[k]>>>0,_[k]=K%256>>>0,K=K/256>>>0;if(K!==0)throw new Error("Non-zero carry");E=S,w++}if(g[w]!==" "){for(var C=B-E;C!==B&&_[C]===0;)C++;for(var T=new Uint8Array(h+(B-C)),d=h;C!==B;)T[d++]=_[C++];return T}}}function p(g){var w=m(g);if(w)return w;throw new Error(`Non-${t} character`)}return{encode:l,decodeUnsafe:m,decode:p}}var Wf=Gf,jf=Wf,zi=jf;var go=class{name;prefix;baseEncode;constructor(t,r,n){this.name=t,this.prefix=r,this.baseEncode=n}encode(t){if(t instanceof Uint8Array)return`${this.prefix}${this.baseEncode(t)}`;throw Error("Unknown type, must be binary type")}},wo=class{name;prefix;baseDecode;prefixCodePoint;constructor(t,r,n){this.name=t,this.prefix=r;let o=r.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)}},xo=class{decoders;constructor(t){this.decoders=t}or(t){return Fi(this,t)}decode(t){let r=t[0],n=this.decoders[r];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(e,t){return new xo({...e.decoders??{[e.prefix]:e},...t.decoders??{[t.prefix]:t}})}var bo=class{name;prefix;baseEncode;baseDecode;encoder;decoder;constructor(t,r,n,o){this.name=t,this.prefix=r,this.baseEncode=n,this.baseDecode=o,this.encoder=new go(t,r,n),this.decoder=new wo(t,r,o)}encode(t){return this.encoder.encode(t)}decode(t){return this.decoder.decode(t)}};function He({name:e,prefix:t,encode:r,decode:n}){return new bo(e,t,r,n)}function ie({name:e,prefix:t,alphabet:r}){let{encode:n,decode:o}=zi(r,e);return He({prefix:t,name:e,encode:n,decode:s=>Yt(o(s))})}function $f(e,t,r,n){let o=e.length;for(;e[o-1]==="=";)--o;let s=new Uint8Array(o*r/8|0),i=0,a=0,c=0;for(let u=0;u<o;++u){let f=t[e[u]];if(f===void 0)throw new SyntaxError(`Non-${n} character`);a=a<<r|f,i+=r,i>=8&&(i-=8,s[c++]=255&a>>i)}if(i>=r||(255&a<<8-i)!==0)throw new SyntaxError("Unexpected end of data");return s}function Zf(e,t,r){let n=t[t.length-1]==="=",o=(1<<r)-1,s="",i=0,a=0;for(let c=0;c<e.length;++c)for(a=a<<8|e[c],i+=8;i>r;)i-=r,s+=t[o&a>>i];if(i!==0&&(s+=t[o&a<<r-i]),n)for(;(s.length*r&7)!==0;)s+="=";return s}function Yf(e){let t={};for(let r=0;r<e.length;++r)t[e[r]]=r;return t}function st({name:e,prefix:t,bitsPerChar:r,alphabet:n}){let o=Yf(n);return He({prefix:t,name:e,encode(s){return Zf(s,n,r)},decode(s){return $f(s,o,r,e)}})}var X=ie({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),Xf=ie({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var So={};vt(So,{base32:()=>Xt,base32hex:()=>eu,base32hexpad:()=>nu,base32hexpadupper:()=>ou,base32hexupper:()=>ru,base32pad:()=>Qf,base32padupper:()=>tu,base32upper:()=>Jf,base32z:()=>su});var Xt=st({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),Jf=st({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),Qf=st({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),tu=st({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),eu=st({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),ru=st({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),nu=st({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),ou=st({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),su=st({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var Ao={};vt(Ao,{base36:()=>dr,base36upper:()=>iu});var dr=ie({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),iu=ie({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var qt={};vt(qt,{Digest:()=>we,create:()=>Dt,decode:()=>ae,equals:()=>Io,hasCode:()=>Iu});var au=ji,Gi=128,cu=127,fu=~cu,uu=Math.pow(2,31);function ji(e,t,r){t=t||[],r=r||0;for(var n=r;e>=uu;)t[r++]=e&255|Gi,e/=128;for(;e&fu;)t[r++]=e&255|Gi,e>>>=7;return t[r]=e|0,ji.bytes=r-n+1,t}var lu=vo,hu=128,Wi=127;function vo(e,n){var r=0,n=n||0,o=0,s=n,i,a=e.length;do{if(s>=a)throw vo.bytes=0,new RangeError("Could not decode varint");i=e[s++],r+=o<28?(i&Wi)<<o:(i&Wi)*Math.pow(2,o),o+=7}while(i>=hu);return vo.bytes=s-n,r}var du=Math.pow(2,7),pu=Math.pow(2,14),mu=Math.pow(2,21),yu=Math.pow(2,28),gu=Math.pow(2,35),wu=Math.pow(2,42),xu=Math.pow(2,49),bu=Math.pow(2,56),Eu=Math.pow(2,63),Su=function(e){return e<du?1:e<pu?2:e<mu?3:e<yu?4:e<gu?5:e<wu?6:e<xu?7:e<bu?8:e<Eu?9:10},Au={encode:au,decode:lu,encodingLength:Su},vu=Au,pr=vu;function mr(e,t=0){return[pr.decode(e,t),pr.decode.bytes]}function qe(e,t,r=0){return pr.encode(e,t,r),t}function Ve(e){return pr.encodingLength(e)}function Dt(e,t){let r=t.byteLength,n=Ve(e),o=n+Ve(r),s=new Uint8Array(o+r);return qe(e,s,0),qe(r,s,n),s.set(t,o),new we(e,r,t,s)}function ae(e){let t=Yt(e),[r,n]=mr(t),[o,s]=mr(t.subarray(n)),i=t.subarray(n+s);if(i.byteLength!==o)throw new Error("Incorrect length");return new we(r,o,i,t)}function Io(e,t){if(e===t)return!0;{let r=t;return e.code===r.code&&e.size===r.size&&r.bytes instanceof Uint8Array&&Oi(e.bytes,r.bytes)}}var we=class{code;size;digest;bytes;constructor(t,r,n,o){this.code=t,this.size=r,this.digest=n,this.bytes=o}};function Iu(e,t){return e.code===t}function $i(e,t){let{bytes:r,version:n}=e;switch(n){case 0:return Bu(r,_o(e),t??X.encoder);default:return Lu(r,_o(e),t??Xt.encoder)}}var Zi=new WeakMap;function _o(e){let t=Zi.get(e);if(t==null){let r=new Map;return Zi.set(e,r),r}return t}var it=class e{code;version;multihash;bytes;"/";constructor(t,r,n,o){this.code=r,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:r}=this;if(t!==yr)throw new Error("Cannot convert a non dag-pb CID to CIDv0");if(r.code!==Tu)throw new Error("Cannot convert non sha2-256 multihash CID to CIDv0");return e.createV0(r)}default:throw Error(`Can not convert CID version ${this.version} to version 0. This is a bug please report`)}}toV1(){switch(this.version){case 0:{let{code:t,digest:r}=this.multihash,n=Dt(t,r);return e.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 e.equals(this,t)}static equals(t,r){let n=r;return n!=null&&t.code===n.code&&t.version===n.version&&Io(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 r=t;if(r instanceof e)return r;if(r["/"]!=null&&r["/"]===r.bytes||r.asCID===r){let{version:n,code:o,multihash:s,bytes:i}=r;return new e(n,o,s,i??Yi(n,o,s.bytes))}else if(r[Cu]===!0){let{version:n,multihash:o,code:s}=r,i=ae(o);return e.create(n,s,i)}else return null}static create(t,r,n){if(typeof r!="number")throw new Error("String codecs are no longer supported");if(!(n.bytes instanceof Uint8Array))throw new Error("Invalid digest");switch(t){case 0:{if(r!==yr)throw new Error(`Version 0 CID must use dag-pb (code: ${yr}) block encoding`);return new e(t,r,n,n.bytes)}case 1:{let o=Yi(t,r,n.bytes);return new e(t,r,n,o)}default:throw new Error("Invalid version")}}static createV0(t){return e.create(0,yr,t)}static createV1(t,r){return e.create(1,t,r)}static decode(t){let[r,n]=e.decodeFirst(t);if(n.length!==0)throw new Error("Incorrect length");return r}static decodeFirst(t){let r=e.inspectBytes(t),n=r.size-r.multihashSize,o=Yt(t.subarray(n,n+r.multihashSize));if(o.byteLength!==r.multihashSize)throw new Error("Incorrect length");let s=o.subarray(r.multihashSize-r.digestSize),i=new we(r.multihashCode,r.digestSize,s,o);return[r.version===0?e.createV0(i):e.createV1(r.codec,i),t.subarray(r.size)]}static inspectBytes(t){let r=0,n=()=>{let[l,m]=mr(t.subarray(r));return r+=m,l},o=n(),s=yr;if(o===18?(o=0,r=0):s=n(),o!==0&&o!==1)throw new RangeError(`Invalid CID version ${o}`);let i=r,a=n(),c=n(),u=r+c,f=u-i;return{version:o,codec:s,multihashCode:a,digestSize:c,multihashSize:f,size:u}}static parse(t,r){let[n,o]=_u(t,r),s=e.decode(o);if(s.version===0&&t[0]!=="Q")throw Error("Version 0 CID string must not include multibase prefix");return _o(s).set(n,t),s}};function _u(e,t){switch(e[0]){case"Q":{let r=t??X;return[X.prefix,r.decode(`${X.prefix}${e}`)]}case X.prefix:{let r=t??X;return[X.prefix,r.decode(e)]}case Xt.prefix:{let r=t??Xt;return[Xt.prefix,r.decode(e)]}case dr.prefix:{let r=t??dr;return[dr.prefix,r.decode(e)]}default:{if(t==null)throw Error("To parse non base32, base36 or base58btc encoded CID multibase decoder must be provided");return[e[0],t.decode(e)]}}}function Bu(e,t,r){let{prefix:n}=r;if(n!==X.prefix)throw Error(`Cannot string encode V0 in ${r.name} encoding`);let o=t.get(n);if(o==null){let s=r.encode(e).slice(1);return t.set(n,s),s}else return o}function Lu(e,t,r){let{prefix:n}=r,o=t.get(n);if(o==null){let s=r.encode(e);return t.set(n,s),s}else return o}var yr=112,Tu=18;function Yi(e,t,r){let n=Ve(e),o=n+Ve(t),s=new Uint8Array(o+r.byteLength);return qe(e,s,0),qe(t,s,n),s.set(r,o),s}var Cu=Symbol.for("@ipld/js-cid/CID");var Bo={};vt(Bo,{identity:()=>Ut});var Xi=0,Pu="identity",Ji=Yt;function Du(e){return Dt(Xi,Ji(e))}var Ut={code:Xi,name:Pu,encode:Ji,digest:Du};function ft(e,t){if(e===t)return!0;if(e.byteLength!==t.byteLength)return!1;for(let r=0;r<e.byteLength;r++)if(e[r]!==t[r])return!1;return!0}function ut(e=0){return new Uint8Array(e)}function lt(e=0){return new Uint8Array(e)}function wt(e,t){t==null&&(t=e.reduce((o,s)=>o+s.length,0));let r=lt(t),n=0;for(let o of e)r.set(o,n),n+=o.length;return r}var ta=Symbol.for("@achingbrain/uint8arraylist");function Qi(e,t){if(t==null||t<0)throw new RangeError("index is out of bounds");let r=0;for(let n of e){let o=r+n.byteLength;if(t<o)return{buf:n,index:t-r};r=o}throw new RangeError("index is out of bounds")}function an(e){return!!e?.[ta]}var F=class e{bufs;length;[ta]=!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 r=0;for(let n of t)if(n instanceof Uint8Array)r+=n.byteLength,this.bufs.push(n);else if(an(n))r+=n.byteLength,this.bufs.push(...n.bufs);else throw new Error("Could not append value, must be an Uint8Array or a Uint8ArrayList");this.length+=r}prepend(...t){this.prependAll(t)}prependAll(t){let r=0;for(let n of t.reverse())if(n instanceof Uint8Array)r+=n.byteLength,this.bufs.unshift(n);else if(an(n))r+=n.byteLength,this.bufs.unshift(...n.bufs);else throw new Error("Could not prepend value, must be an Uint8Array or a Uint8ArrayList");this.length+=r}get(t){let r=Qi(this.bufs,t);return r.buf[r.index]}set(t,r){let n=Qi(this.bufs,t);n.buf[n.index]=r}write(t,r=0){if(t instanceof Uint8Array)for(let n=0;n<t.length;n++)this.set(r+n,t[n]);else if(an(t))for(let n=0;n<t.length;n++)this.set(r+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,r){let{bufs:n,length:o}=this._subList(t,r);return wt(n,o)}subarray(t,r){let{bufs:n,length:o}=this._subList(t,r);return n.length===1?n[0]:wt(n,o)}sublist(t,r){let{bufs:n,length:o}=this._subList(t,r),s=new e;return s.length=o,s.bufs=[...n],s}_subList(t,r){if(t=t??0,r=r??this.length,t<0&&(t=this.length+t),r<0&&(r=this.length+r),t<0||r>this.length)throw new RangeError("index is out of bounds");if(t===r)return{bufs:[],length:0};if(t===0&&r===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 u=t>=a&&t<c,f=r>a&&r<=c;if(u&&f){if(t===a&&r===c){n.push(i);break}let l=t-a;n.push(i.subarray(l,l+(r-t)));break}if(u){if(t===0){n.push(i);continue}n.push(i.subarray(t-a));continue}if(f){if(r===c){n.push(i);break}n.push(i.subarray(0,r-a));break}n.push(i)}return{bufs:n,length:r-t}}indexOf(t,r=0){if(!an(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(r=Number(r??0),isNaN(r)&&(r=0),r<0&&(r=this.length+r),r<0&&(r=0),t.length===0)return r>this.length?this.length:r;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,u=n.byteLength-1,f;for(let l=r;l<=c;l+=f){f=0;for(let m=u;m>=0;m--){let p=this.get(l+m);if(n[m]!==p){f=Math.max(1,m-a[p]);break}}if(f===0)return l}return-1}getInt8(t){let r=this.subarray(t,t+1);return new DataView(r.buffer,r.byteOffset,r.byteLength).getInt8(0)}setInt8(t,r){let n=lt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setInt8(0,r),this.write(n,t)}getInt16(t,r){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt16(0,r)}setInt16(t,r,n){let o=ut(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt16(0,r,n),this.write(o,t)}getInt32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getInt32(0,r)}setInt32(t,r,n){let o=ut(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setInt32(0,r,n),this.write(o,t)}getBigInt64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigInt64(0,r)}setBigInt64(t,r,n){let o=ut(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigInt64(0,r,n),this.write(o,t)}getUint8(t){let r=this.subarray(t,t+1);return new DataView(r.buffer,r.byteOffset,r.byteLength).getUint8(0)}setUint8(t,r){let n=lt(1);new DataView(n.buffer,n.byteOffset,n.byteLength).setUint8(0,r),this.write(n,t)}getUint16(t,r){let n=this.subarray(t,t+2);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint16(0,r)}setUint16(t,r,n){let o=ut(2);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint16(0,r,n),this.write(o,t)}getUint32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getUint32(0,r)}setUint32(t,r,n){let o=ut(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setUint32(0,r,n),this.write(o,t)}getBigUint64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getBigUint64(0,r)}setBigUint64(t,r,n){let o=ut(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setBigUint64(0,r,n),this.write(o,t)}getFloat32(t,r){let n=this.subarray(t,t+4);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat32(0,r)}setFloat32(t,r,n){let o=ut(4);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat32(0,r,n),this.write(o,t)}getFloat64(t,r){let n=this.subarray(t,t+8);return new DataView(n.buffer,n.byteOffset,n.byteLength).getFloat64(0,r)}setFloat64(t,r,n){let o=ut(8);new DataView(o.buffer,o.byteOffset,o.byteLength).setFloat64(0,r,n),this.write(o,t)}equals(t){if(t==null||!(t instanceof e)||t.bufs.length!==this.bufs.length)return!1;for(let r=0;r<this.bufs.length;r++)if(!ft(this.bufs[r],t.bufs[r]))return!1;return!0}static fromUint8Arrays(t,r){let n=new e;return n.bufs=t,r==null&&(r=t.reduce((o,s)=>o+s.byteLength,0)),n.length=r,n}};var Lo={};vt(Lo,{base10:()=>Uu});var Uu=ie({prefix:"9",name:"base10",alphabet:"0123456789"});var To={};vt(To,{base16:()=>Ku,base16upper:()=>Ru});var Ku=st({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),Ru=st({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var Co={};vt(Co,{base2:()=>Nu});var Nu=st({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var Po={};vt(Po,{base256emoji:()=>Vu});var ea=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}"),Mu=ea.reduce((e,t,r)=>(e[r]=t,e),[]),Ou=ea.reduce((e,t,r)=>{let n=t.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${t}`);return e[n]=r,e},[]);function Hu(e){return e.reduce((t,r)=>(t+=Mu[r],t),"")}function qu(e){let t=[];for(let r of e){let n=r.codePointAt(0);if(n==null)throw new Error(`Invalid character: ${r}`);let o=Ou[n];if(o==null)throw new Error(`Non-base256emoji character: ${r}`);t.push(o)}return new Uint8Array(t)}var Vu=He({prefix:"\u{1F680}",name:"base256emoji",encode:Hu,decode:qu});var ko={};vt(ko,{base64:()=>zu,base64pad:()=>Fu,base64url:()=>Do,base64urlpad:()=>Gu});var zu=st({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),Fu=st({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),Do=st({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),Gu=st({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var Uo={};vt(Uo,{base8:()=>Wu});var Wu=st({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var Ko={};vt(Ko,{identity:()=>ju});var ju=He({prefix:"\0",name:"identity",encode:e=>qi(e),decode:e=>Hi(e)});var Fp=new TextEncoder,Gp=new TextDecoder;var Mo={};vt(Mo,{sha256:()=>gr,sha512:()=>Yu});function No({name:e,code:t,encode:r}){return new Ro(e,t,r)}var Ro=class{name;code;encode;constructor(t,r,n){this.name=t,this.code=r,this.encode=n}digest(t){if(t instanceof Uint8Array){let r=this.encode(t);return r instanceof Uint8Array?Dt(this.code,r):r.then(n=>Dt(this.code,n))}else throw Error("Unknown type, must be binary type")}};function na(e){return async t=>new Uint8Array(await crypto.subtle.digest(e,t))}var gr=No({name:"sha2-256",code:18,encode:na("SHA-256")}),Yu=No({name:"sha2-512",code:19,encode:na("SHA-512")});var xe={...Ko,...Co,...Uo,...Lo,...To,...So,...Ao,...Eo,...ko,...Po},n0={...Mo,...Bo};function sa(e,t,r,n){return{name:e,prefix:t,encoder:{name:e,prefix:t,encode:r},decoder:{decode:n}}}var oa=sa("utf8","u",e=>"u"+new TextDecoder("utf8").decode(e),e=>new TextEncoder().encode(e.substring(1))),Oo=sa("ascii","a",e=>{let t="a";for(let r=0;r<e.length;r++)t+=String.fromCharCode(e[r]);return t},e=>{e=e.substring(1);let t=lt(e.length);for(let r=0;r<e.length;r++)t[r]=e.charCodeAt(r);return t}),Xu={utf8:oa,"utf-8":oa,hex:xe.base16,latin1:Oo,ascii:Oo,binary:Oo,...xe},cn=Xu;function j(e,t="utf8"){let r=cn[t];if(r==null)throw new Error(`Unsupported encoding "${t}"`);return r.decoder.decode(`${r.prefix}${e}`)}function O(e,t="utf8"){let r=cn[t];if(r==null)throw new Error(`Unsupported encoding "${t}"`);return r.encoder.encode(e).substring(1)}var Ju=parseInt("11111",2),Ho=parseInt("10000000",2),Qu=parseInt("01111111",2),ia={0:wr,1:wr,2:tl,3:nl,4:ol,5:rl,6:el,16:wr,22:wr,48:wr};function Jt(e,t={offset:0}){let r=e[t.offset]&Ju;if(t.offset++,ia[r]!=null)return ia[r](e,t);throw new Error("No decoder for tag "+r)}function xr(e,t){let r=0;if((e[t.offset]&Ho)===Ho){let n=e[t.offset]&Qu,o="0x";t.offset++;for(let s=0;s<n;s++,t.offset++)o+=e[t.offset].toString(16).padStart(2,"0");r=parseInt(o,16)}else r=e[t.offset],t.offset++;return r}function wr(e,t){xr(e,t);let r=[];for(;!(t.offset>=e.byteLength);){let n=Jt(e,t);if(n===null)break;r.push(n)}return r}function tl(e,t){let r=xr(e,t),n=t.offset,o=t.offset+r,s=[];for(let i=n;i<o;i++)i===n&&e[i]===0||s.push(e[i]);return t.offset+=r,Uint8Array.from(s)}function el(e,t){let r=xr(e,t),n=t.offset+r,o=e[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 u=e[t.offset];if(t.offset++,c.push(u&127),u<128){c.reverse();let f=0;for(let l=0;l<c.length;l++)f+=c[l]<<l*7;a+=`.${f}`,c=[]}}return a}function rl(e,t){return t.offset++,null}function nl(e,t){let r=xr(e,t),n=e[t.offset];t.offset++;let o=e.subarray(t.offset,t.offset+r-1);if(t.offset+=r,n!==0)throw new Error("Unused bits in bit string is unimplemented");return o}function ol(e,t){let r=xr(e,t),n=e.subarray(t.offset,t.offset+r);return t.offset+=r,n}function sl(e){let t=e.toString(16);t.length%2===1&&(t="0"+t);let r=new F;for(let n=0;n<t.length;n+=2)r.append(Uint8Array.from([parseInt(`${t[n]}${t[n+1]}`,16)]));return r}function qo(e){if(e.byteLength<128)return Uint8Array.from([e.byteLength]);let t=sl(e.byteLength);return new F(Uint8Array.from([t.byteLength|Ho]),t)}function Tt(e){let t=new F,r=128;return(e.subarray()[0]&r)===r&&t.append(Uint8Array.from([0])),t.append(e),new F(Uint8Array.from([2]),qo(t),t)}function fn(e){let t=Uint8Array.from([0]),r=new F(t,e);return new F(Uint8Array.from([3]),qo(r),r)}function ce(e,t=48){let r=new F;for(let n of e)r.append(n);return new F(Uint8Array.from([t]),qo(r),r)}async function aa(e,t,r,n){let o=await crypto.subtle.importKey("jwk",e,{name:"ECDSA",namedCurve:e.crv??"P-256"},!1,["verify"]);n?.signal?.throwIfAborted();let s=await crypto.subtle.verify({name:"ECDSA",hash:{name:"SHA-256"}},o,t,r.subarray());return n?.signal?.throwIfAborted(),s}var il=Uint8Array.from([6,8,42,134,72,206,61,3,1,7]),al=Uint8Array.from([6,5,43,129,4,0,34]),cl=Uint8Array.from([6,5,43,129,4,0,35]),fl={ext:!0,kty:"EC",crv:"P-256"},ul={ext:!0,kty:"EC",crv:"P-384"},ll={ext:!0,kty:"EC",crv:"P-521"},Vo=32,zo=48,Fo=66;function Go(e){let t=Jt(e);return ca(t)}function ca(e){let t=e[1][1][0],r=1,n,o;if(t.byteLength===Vo*2+1)return n=O(t.subarray(r,r+Vo),"base64url"),o=O(t.subarray(r+Vo),"base64url"),new ze({...fl,key_ops:["verify"],x:n,y:o});if(t.byteLength===zo*2+1)return n=O(t.subarray(r,r+zo),"base64url"),o=O(t.subarray(r+zo),"base64url"),new ze({...ul,key_ops:["verify"],x:n,y:o});if(t.byteLength===Fo*2+1)return n=O(t.subarray(r,r+Fo),"base64url"),o=O(t.subarray(r+Fo),"base64url"),new ze({...ll,key_ops:["verify"],x:n,y:o});throw new ot(`coordinates were wrong length, got ${t.byteLength}, expected 65, 97 or 133`)}function fa(e){return ce([Tt(Uint8Array.from([1])),ce([hl(e.crv)],160),ce([fn(new F(Uint8Array.from([4]),j(e.x??"","base64url"),j(e.y??"","base64url")))],161)]).subarray()}function hl(e){if(e==="P-256")return il;if(e==="P-384")return al;if(e==="P-521")return cl;throw new ot(`Invalid curve ${e}`)}var ze=class{type="ECDSA";jwk;_raw;constructor(t){this.jwk=t}get raw(){return this._raw==null&&(this._raw=fa(this.jwk)),this._raw}toMultihash(){return Ut.digest(fe(this))}toCID(){return it.createV1(114,this.toMultihash())}toString(){return X.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ft(this.raw,t.raw)}async verify(t,r,n){return aa(this.jwk,r,t,n)}};var be=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Ge(e){return e instanceof Uint8Array||ArrayBuffer.isView(e)&&e.constructor.name==="Uint8Array"}function Ee(e){if(!Number.isSafeInteger(e)||e<0)throw new Error("positive integer expected, got "+e)}function xt(e,...t){if(!Ge(e))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(e.length))throw new Error("Uint8Array expected of length "+t+", got length="+e.length)}function br(e){if(typeof e!="function"||typeof e.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");Ee(e.outputLen),Ee(e.blockLen)}function We(e,t=!0){if(e.destroyed)throw new Error("Hash instance has been destroyed");if(t&&e.finished)throw new Error("Hash#digest() has already been called")}function la(e,t){xt(e);let r=t.outputLen;if(e.length<r)throw new Error("digestInto() expects output buffer of length at least "+r)}function Kt(...e){for(let t=0;t<e.length;t++)e[t].fill(0)}function un(e){return new DataView(e.buffer,e.byteOffset,e.byteLength)}function Rt(e,t){return e<<32-t|e>>>t}var ha=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",dl=Array.from({length:256},(e,t)=>t.toString(16).padStart(2,"0"));function Vt(e){if(xt(e),ha)return e.toHex();let t="";for(let r=0;r<e.length;r++)t+=dl[e[r]];return t}var Qt={_0:48,_9:57,A:65,F:70,a:97,f:102};function ua(e){if(e>=Qt._0&&e<=Qt._9)return e-Qt._0;if(e>=Qt.A&&e<=Qt.F)return e-(Qt.A-10);if(e>=Qt.a&&e<=Qt.f)return e-(Qt.a-10)}function je(e){if(typeof e!="string")throw new Error("hex string expected, got "+typeof e);if(ha)return Uint8Array.fromHex(e);let t=e.length,r=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let n=new Uint8Array(r);for(let o=0,s=0;o<r;o++,s+=2){let i=ua(e.charCodeAt(s)),a=ua(e.charCodeAt(s+1));if(i===void 0||a===void 0){let c=e[s]+e[s+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+s)}n[o]=i*16+a}return n}function da(e){if(typeof e!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(e))}function ue(e){return typeof e=="string"&&(e=da(e)),xt(e),e}function Ct(...e){let t=0;for(let n=0;n<e.length;n++){let o=e[n];xt(o),t+=o.length}let r=new Uint8Array(t);for(let n=0,o=0;n<e.length;n++){let s=e[n];r.set(s,o),o+=s.length}return r}var Fe=class{};function Wo(e){let t=n=>e().update(ue(n)).digest(),r=e();return t.outputLen=r.outputLen,t.blockLen=r.blockLen,t.create=()=>e(),t}function Se(e=32){if(be&&typeof be.getRandomValues=="function")return be.getRandomValues(new Uint8Array(e));if(be&&typeof be.randomBytes=="function")return Uint8Array.from(be.randomBytes(e));throw new Error("crypto.getRandomValues must be defined")}function pl(e,t,r,n){if(typeof e.setBigUint64=="function")return e.setBigUint64(t,r,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(r>>o&s),a=Number(r&s),c=n?4:0,u=n?0:4;e.setUint32(t+c,i,n),e.setUint32(t+u,a,n)}function pa(e,t,r){return e&t^~e&r}function ma(e,t,r){return e&t^e&r^t&r}var Er=class extends Fe{constructor(t,r,n,o){super(),this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=t,this.outputLen=r,this.padOffset=n,this.isLE=o,this.buffer=new Uint8Array(t),this.view=un(this.buffer)}update(t){We(this),t=ue(t),xt(t);let{view:r,buffer:n,blockLen:o}=this,s=t.length;for(let i=0;i<s;){let a=Math.min(o-this.pos,s-i);if(a===o){let c=un(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(r,0),this.pos=0)}return this.length+=t.length,this.roundClean(),this}digestInto(t){We(this),la(t,this),this.finished=!0;let{buffer:r,view:n,blockLen:o,isLE:s}=this,{pos:i}=this;r[i++]=128,Kt(this.buffer.subarray(i)),this.padOffset>o-i&&(this.process(n,0),i=0);for(let l=i;l<o;l++)r[l]=0;pl(n,o-8,BigInt(this.length*8),s),this.process(n,0);let a=un(t),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");let u=c/4,f=this.get();if(u>f.length)throw new Error("_sha2: outputLen bigger than state");for(let l=0;l<u;l++)a.setUint32(4*l,f[l],s)}digest(){let{buffer:t,outputLen:r}=this;this.digestInto(t);let n=t.slice(0,r);return this.destroy(),n}_cloneInto(t){t||(t=new this.constructor),t.set(...this.get());let{blockLen:r,buffer:n,length:o,finished:s,destroyed:i,pos:a}=this;return t.destroyed=i,t.finished=s,t.length=o,t.pos=a,o%r&&t.buffer.set(n),t}clone(){return this._cloneInto()}},te=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var mt=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]);var ln=BigInt(4294967295),ya=BigInt(32);function ml(e,t=!1){return t?{h:Number(e&ln),l:Number(e>>ya&ln)}:{h:Number(e>>ya&ln)|0,l:Number(e&ln)|0}}function ga(e,t=!1){let r=e.length,n=new Uint32Array(r),o=new Uint32Array(r);for(let s=0;s<r;s++){let{h:i,l:a}=ml(e[s],t);[n[s],o[s]]=[i,a]}return[n,o]}var jo=(e,t,r)=>e>>>r,$o=(e,t,r)=>e<<32-r|t>>>r,Ae=(e,t,r)=>e>>>r|t<<32-r,ve=(e,t,r)=>e<<32-r|t>>>r,Sr=(e,t,r)=>e<<64-r|t>>>r-32,Ar=(e,t,r)=>e>>>r-32|t<<64-r;function zt(e,t,r,n){let o=(t>>>0)+(n>>>0);return{h:e+r+(o/2**32|0)|0,l:o|0}}var wa=(e,t,r)=>(e>>>0)+(t>>>0)+(r>>>0),xa=(e,t,r,n)=>t+r+n+(e/2**32|0)|0,ba=(e,t,r,n)=>(e>>>0)+(t>>>0)+(r>>>0)+(n>>>0),Ea=(e,t,r,n,o)=>t+r+n+o+(e/2**32|0)|0,Sa=(e,t,r,n,o)=>(e>>>0)+(t>>>0)+(r>>>0)+(n>>>0)+(o>>>0),Aa=(e,t,r,n,o,s)=>t+r+n+o+s+(e/2**32|0)|0;var gl=Uint32Array.from([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]),le=new Uint32Array(64),hn=class extends Er{constructor(t=32){super(64,t,8,!1),this.A=te[0]|0,this.B=te[1]|0,this.C=te[2]|0,this.D=te[3]|0,this.E=te[4]|0,this.F=te[5]|0,this.G=te[6]|0,this.H=te[7]|0}get(){let{A:t,B:r,C:n,D:o,E:s,F:i,G:a,H:c}=this;return[t,r,n,o,s,i,a,c]}set(t,r,n,o,s,i,a,c){this.A=t|0,this.B=r|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,r){for(let l=0;l<16;l++,r+=4)le[l]=t.getUint32(r,!1);for(let l=16;l<64;l++){let m=le[l-15],p=le[l-2],g=Rt(m,7)^Rt(m,18)^m>>>3,w=Rt(p,17)^Rt(p,19)^p>>>10;le[l]=w+le[l-7]+g+le[l-16]|0}let{A:n,B:o,C:s,D:i,E:a,F:c,G:u,H:f}=this;for(let l=0;l<64;l++){let m=Rt(a,6)^Rt(a,11)^Rt(a,25),p=f+m+pa(a,c,u)+gl[l]+le[l]|0,w=(Rt(n,2)^Rt(n,13)^Rt(n,22))+ma(n,o,s)|0;f=u,u=c,c=a,a=i+p|0,i=s,s=o,o=n,n=p+w|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,u=u+this.G|0,f=f+this.H|0,this.set(n,o,s,i,a,c,u,f)}roundClean(){Kt(le)}destroy(){this.set(0,0,0,0,0,0,0,0),Kt(this.buffer)}};var va=ga(["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(e=>BigInt(e))),wl=va[0],xl=va[1],he=new Uint32Array(80),de=new Uint32Array(80),Zo=class extends Er{constructor(t=64){super(128,t,16,!1),this.Ah=mt[0]|0,this.Al=mt[1]|0,this.Bh=mt[2]|0,this.Bl=mt[3]|0,this.Ch=mt[4]|0,this.Cl=mt[5]|0,this.Dh=mt[6]|0,this.Dl=mt[7]|0,this.Eh=mt[8]|0,this.El=mt[9]|0,this.Fh=mt[10]|0,this.Fl=mt[11]|0,this.Gh=mt[12]|0,this.Gl=mt[13]|0,this.Hh=mt[14]|0,this.Hl=mt[15]|0}get(){let{Ah:t,Al:r,Bh:n,Bl:o,Ch:s,Cl:i,Dh:a,Dl:c,Eh:u,El:f,Fh:l,Fl:m,Gh:p,Gl:g,Hh:w,Hl:h}=this;return[t,r,n,o,s,i,a,c,u,f,l,m,p,g,w,h]}set(t,r,n,o,s,i,a,c,u,f,l,m,p,g,w,h){this.Ah=t|0,this.Al=r|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=u|0,this.El=f|0,this.Fh=l|0,this.Fl=m|0,this.Gh=p|0,this.Gl=g|0,this.Hh=w|0,this.Hl=h|0}process(t,r){for(let _=0;_<16;_++,r+=4)he[_]=t.getUint32(r),de[_]=t.getUint32(r+=4);for(let _=16;_<80;_++){let K=he[_-15]|0,S=de[_-15]|0,k=Ae(K,S,1)^Ae(K,S,8)^jo(K,S,7),C=ve(K,S,1)^ve(K,S,8)^$o(K,S,7),T=he[_-2]|0,d=de[_-2]|0,x=Ae(T,d,19)^Sr(T,d,61)^jo(T,d,6),y=ve(T,d,19)^Ar(T,d,61)^$o(T,d,6),b=ba(C,y,de[_-7],de[_-16]),A=Ea(b,k,x,he[_-7],he[_-16]);he[_]=A|0,de[_]=b|0}let{Ah:n,Al:o,Bh:s,Bl:i,Ch:a,Cl:c,Dh:u,Dl:f,Eh:l,El:m,Fh:p,Fl:g,Gh:w,Gl:h,Hh:E,Hl:B}=this;for(let _=0;_<80;_++){let K=Ae(l,m,14)^Ae(l,m,18)^Sr(l,m,41),S=ve(l,m,14)^ve(l,m,18)^Ar(l,m,41),k=l&p^~l&w,C=m&g^~m&h,T=Sa(B,S,C,xl[_],de[_]),d=Aa(T,E,K,k,wl[_],he[_]),x=T|0,y=Ae(n,o,28)^Sr(n,o,34)^Sr(n,o,39),b=ve(n,o,28)^Ar(n,o,34)^Ar(n,o,39),A=n&s^n&a^s&a,I=o&i^o&c^i&c;E=w|0,B=h|0,w=p|0,h=g|0,p=l|0,g=m|0,{h:l,l:m}=zt(u|0,f|0,d|0,x|0),u=a|0,f=c|0,a=s|0,c=i|0,s=n|0,i=o|0;let v=wa(x,b,I);n=xa(v,d,y,A),o=v|0}({h:n,l:o}=zt(this.Ah|0,this.Al|0,n|0,o|0)),{h:s,l:i}=zt(this.Bh|0,this.Bl|0,s|0,i|0),{h:a,l:c}=zt(this.Ch|0,this.Cl|0,a|0,c|0),{h:u,l:f}=zt(this.Dh|0,this.Dl|0,u|0,f|0),{h:l,l:m}=zt(this.Eh|0,this.El|0,l|0,m|0),{h:p,l:g}=zt(this.Fh|0,this.Fl|0,p|0,g|0),{h:w,l:h}=zt(this.Gh|0,this.Gl|0,w|0,h|0),{h:E,l:B}=zt(this.Hh|0,this.Hl|0,E|0,B|0),this.set(n,o,s,i,a,c,u,f,l,m,p,g,w,h,E,B)}roundClean(){Kt(he,de)}destroy(){Kt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};var dn=Wo(()=>new hn);var Ia=Wo(()=>new Zo);var Jo=BigInt(0),Xo=BigInt(1);function ee(e,t){if(typeof t!="boolean")throw new Error(e+" boolean expected, got "+t)}function vr(e){let t=e.toString(16);return t.length&1?"0"+t:t}function _a(e){if(typeof e!="string")throw new Error("hex string expected, got "+typeof e);return e===""?Jo:BigInt("0x"+e)}function $e(e){return _a(Vt(e))}function Ft(e){return xt(e),_a(Vt(Uint8Array.from(e).reverse()))}function pn(e,t){return je(e.toString(16).padStart(t*2,"0"))}function pe(e,t){return pn(e,t).reverse()}function J(e,t,r){let n;if(typeof t=="string")try{n=je(t)}catch(s){throw new Error(e+" must be hex string or Uint8Array, cause: "+s)}else if(Ge(t))n=Uint8Array.from(t);else throw new Error(e+" must be hex string or Uint8Array");let o=n.length;if(typeof r=="number"&&o!==r)throw new Error(e+" of length "+r+" expected, got "+o);return n}var Yo=e=>typeof e=="bigint"&&Jo<=e;function Ba(e,t,r){return Yo(e)&&Yo(t)&&Yo(r)&&t<=e&&e<r}function Nt(e,t,r,n){if(!Ba(t,r,n))throw new Error("expected valid "+e+": "+r+" <= n < "+n+", got "+t)}function La(e){let t;for(t=0;e>Jo;e>>=Xo,t+=1);return t}var Ie=e=>(Xo<<BigInt(e))-Xo;function Ta(e,t,r){if(typeof e!="number"||e<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 r!="function")throw new Error("hmacFn must be a function");let n=p=>new Uint8Array(p),o=p=>Uint8Array.of(p),s=n(e),i=n(e),a=0,c=()=>{s.fill(1),i.fill(0),a=0},u=(...p)=>r(i,s,...p),f=(p=n(0))=>{i=u(o(0),p),s=u(),p.length!==0&&(i=u(o(1),p),s=u())},l=()=>{if(a++>=1e3)throw new Error("drbg: tried 1000 values");let p=0,g=[];for(;p<t;){s=u();let w=s.slice();g.push(w),p+=s.length}return Ct(...g)};return(p,g)=>{c(),f(p);let w;for(;!(w=g(l()));)f();return c(),w}}function Gt(e,t,r={}){if(!e||typeof e!="object")throw new Error("expected valid options object");function n(o,s,i){let a=e[o];if(i&&a===void 0)return;let c=typeof a;if(c!==s||a===null)throw new Error(`param "${o}" is invalid: expected ${s}, got ${c}`)}Object.entries(t).forEach(([o,s])=>n(o,s,!1)),Object.entries(r).forEach(([o,s])=>n(o,s,!0))}function Ze(e){let t=new WeakMap;return(r,...n)=>{let o=t.get(r);if(o!==void 0)return o;let s=e(r,...n);return t.set(r,s),s}}var It=BigInt(0),ht=BigInt(1),_e=BigInt(2),bl=BigInt(3),Da=BigInt(4),ka=BigInt(5),Ua=BigInt(8);function tt(e,t){let r=e%t;return r>=It?r:t+r}function et(e,t,r){let n=e;for(;t-- >It;)n*=n,n%=r;return n}function Ca(e,t){if(e===It)throw new Error("invert: expected non-zero number");if(t<=It)throw new Error("invert: expected positive modulus, got "+t);let r=tt(e,t),n=t,o=It,s=ht,i=ht,a=It;for(;r!==It;){let u=n/r,f=n%r,l=o-i*u,m=s-a*u;n=r,r=f,o=i,s=a,i=l,a=m}if(n!==ht)throw new Error("invert: does not exist");return tt(o,t)}function Ka(e,t){let r=(e.ORDER+ht)/Da,n=e.pow(t,r);if(!e.eql(e.sqr(n),t))throw new Error("Cannot find square root");return n}function El(e,t){let r=(e.ORDER-ka)/Ua,n=e.mul(t,_e),o=e.pow(n,r),s=e.mul(t,o),i=e.mul(e.mul(s,_e),o),a=e.mul(s,e.sub(i,e.ONE));if(!e.eql(e.sqr(a),t))throw new Error("Cannot find square root");return a}function Sl(e){if(e<BigInt(3))throw new Error("sqrt is not defined for small field");let t=e-ht,r=0;for(;t%_e===It;)t/=_e,r++;let n=_e,o=Mt(e);for(;Pa(o,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(r===1)return Ka;let s=o.pow(n,t),i=(t+ht)/_e;return function(c,u){if(c.is0(u))return u;if(Pa(c,u)!==1)throw new Error("Cannot find square root");let f=r,l=c.mul(c.ONE,s),m=c.pow(u,t),p=c.pow(u,i);for(;!c.eql(m,c.ONE);){if(c.is0(m))return c.ZERO;let g=1,w=c.sqr(m);for(;!c.eql(w,c.ONE);)if(g++,w=c.sqr(w),g===f)throw new Error("Cannot find square root");let h=ht<<BigInt(f-g-1),E=c.pow(l,h);f=g,l=c.sqr(E),m=c.mul(m,l),p=c.mul(p,E)}return p}}function Al(e){return e%Da===bl?Ka:e%Ua===ka?El:Sl(e)}var Ra=(e,t)=>(tt(e,t)&ht)===ht,vl=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Qo(e){let t={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},r=vl.reduce((n,o)=>(n[o]="function",n),t);return Gt(e,r),e}function Il(e,t,r){if(r<It)throw new Error("invalid exponent, negatives unsupported");if(r===It)return e.ONE;if(r===ht)return t;let n=e.ONE,o=t;for(;r>It;)r&ht&&(n=e.mul(n,o)),o=e.sqr(o),r>>=ht;return n}function Ir(e,t,r=!1){let n=new Array(t.length).fill(r?e.ZERO:void 0),o=t.reduce((i,a,c)=>e.is0(a)?i:(n[c]=i,e.mul(i,a)),e.ONE),s=e.inv(o);return t.reduceRight((i,a,c)=>e.is0(a)?i:(n[c]=e.mul(i,n[c]),e.mul(i,a)),s),n}function Pa(e,t){let r=(e.ORDER-ht)/_e,n=e.pow(t,r),o=e.eql(n,e.ONE),s=e.eql(n,e.ZERO),i=e.eql(n,e.neg(e.ONE));if(!o&&!s&&!i)throw new Error("invalid Legendre symbol result");return o?1:s?0:-1}function Na(e,t){t!==void 0&&Ee(t);let r=t!==void 0?t:e.toString(2).length,n=Math.ceil(r/8);return{nBitLength:r,nByteLength:n}}function Mt(e,t,r=!1,n={}){if(e<=It)throw new Error("invalid field: expected ORDER > 0, got "+e);let o,s;if(typeof t=="object"&&t!=null){if(n.sqrt||r)throw new Error("cannot specify opts in two arguments");let f=t;f.BITS&&(o=f.BITS),f.sqrt&&(s=f.sqrt),typeof f.isLE=="boolean"&&(r=f.isLE)}else typeof t=="number"&&(o=t),n.sqrt&&(s=n.sqrt);let{nBitLength:i,nByteLength:a}=Na(e,o);if(a>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let c,u=Object.freeze({ORDER:e,isLE:r,BITS:i,BYTES:a,MASK:Ie(i),ZERO:It,ONE:ht,create:f=>tt(f,e),isValid:f=>{if(typeof f!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof f);return It<=f&&f<e},is0:f=>f===It,isValidNot0:f=>!u.is0(f)&&u.isValid(f),isOdd:f=>(f&ht)===ht,neg:f=>tt(-f,e),eql:(f,l)=>f===l,sqr:f=>tt(f*f,e),add:(f,l)=>tt(f+l,e),sub:(f,l)=>tt(f-l,e),mul:(f,l)=>tt(f*l,e),pow:(f,l)=>Il(u,f,l),div:(f,l)=>tt(f*Ca(l,e),e),sqrN:f=>f*f,addN:(f,l)=>f+l,subN:(f,l)=>f-l,mulN:(f,l)=>f*l,inv:f=>Ca(f,e),sqrt:s||(f=>(c||(c=Al(e)),c(u,f))),toBytes:f=>r?pe(f,a):pn(f,a),fromBytes:f=>{if(f.length!==a)throw new Error("Field.fromBytes: expected "+a+" bytes, got "+f.length);return r?Ft(f):$e(f)},invertBatch:f=>Ir(u,f),cmov:(f,l,m)=>m?l:f});return Object.freeze(u)}function Ma(e){if(typeof e!="bigint")throw new Error("field order must be bigint");let t=e.toString(2).length;return Math.ceil(t/8)}function ts(e){let t=Ma(e);return t+Math.ceil(t/2)}function Oa(e,t,r=!1){let n=e.length,o=Ma(t),s=ts(t);if(n<16||n<s||n>1024)throw new Error("expected "+s+"-1024 bytes of input, got "+n);let i=r?Ft(e):$e(e),a=tt(i,t-ht)+ht;return r?pe(a,o):pn(a,o)}var Xe=BigInt(0),Be=BigInt(1);function Ye(e,t){let r=t.negate();return e?r:t}function mn(e,t,r){let n=t==="pz"?i=>i.pz:i=>i.ez,o=Ir(e.Fp,r.map(n));return r.map((i,a)=>i.toAffine(o[a])).map(e.fromAffine)}function za(e,t){if(!Number.isSafeInteger(e)||e<=0||e>t)throw new Error("invalid window size, expected [1.."+t+"], got W="+e)}function es(e,t){za(e,t);let r=Math.ceil(t/e)+1,n=2**(e-1),o=2**e,s=Ie(e),i=BigInt(e);return{windows:r,windowSize:n,mask:s,maxNumber:o,shiftBy:i}}function Ha(e,t,r){let{windowSize:n,mask:o,maxNumber:s,shiftBy:i}=r,a=Number(e&o),c=e>>i;a>n&&(a-=s,c+=Be);let u=t*n,f=u+Math.abs(a)-1,l=a===0,m=a<0,p=t%2!==0;return{nextN:c,offset:f,isZero:l,isNeg:m,isNegF:p,offsetF:u}}function _l(e,t){if(!Array.isArray(e))throw new Error("array expected");e.forEach((r,n)=>{if(!(r instanceof t))throw new Error("invalid point at index "+n)})}function Bl(e,t){if(!Array.isArray(e))throw new Error("array of scalars expected");e.forEach((r,n)=>{if(!t.isValid(r))throw new Error("invalid scalar at index "+n)})}var rs=new WeakMap,Fa=new WeakMap;function ns(e){return Fa.get(e)||1}function qa(e){if(e!==Xe)throw new Error("invalid wNAF")}function yn(e,t){return{constTimeNegate:Ye,hasPrecomputes(r){return ns(r)!==1},unsafeLadder(r,n,o=e.ZERO){let s=r;for(;n>Xe;)n&Be&&(o=o.add(s)),s=s.double(),n>>=Be;return o},precomputeWindow(r,n){let{windows:o,windowSize:s}=es(n,t),i=[],a=r,c=a;for(let u=0;u<o;u++){c=a,i.push(c);for(let f=1;f<s;f++)c=c.add(a),i.push(c);a=c.double()}return i},wNAF(r,n,o){let s=e.ZERO,i=e.BASE,a=es(r,t);for(let c=0;c<a.windows;c++){let{nextN:u,offset:f,isZero:l,isNeg:m,isNegF:p,offsetF:g}=Ha(o,c,a);o=u,l?i=i.add(Ye(p,n[g])):s=s.add(Ye(m,n[f]))}return qa(o),{p:s,f:i}},wNAFUnsafe(r,n,o,s=e.ZERO){let i=es(r,t);for(let a=0;a<i.windows&&o!==Xe;a++){let{nextN:c,offset:u,isZero:f,isNeg:l}=Ha(o,a,i);if(o=c,!f){let m=n[u];s=s.add(l?m.negate():m)}}return qa(o),s},getPrecomputes(r,n,o){let s=rs.get(n);return s||(s=this.precomputeWindow(n,r),r!==1&&(typeof o=="function"&&(s=o(s)),rs.set(n,s))),s},wNAFCached(r,n,o){let s=ns(r);return this.wNAF(s,this.getPrecomputes(s,r,o),n)},wNAFCachedUnsafe(r,n,o,s){let i=ns(r);return i===1?this.unsafeLadder(r,n,s):this.wNAFUnsafe(i,this.getPrecomputes(i,r,o),n,s)},setWindowSize(r,n){za(n,t),Fa.set(r,n),rs.delete(r)}}}function Ga(e,t,r,n){let o=t,s=e.ZERO,i=e.ZERO;for(;r>Xe||n>Xe;)r&Be&&(s=s.add(o)),n&Be&&(i=i.add(o)),o=o.double(),r>>=Be,n>>=Be;return{p1:s,p2:i}}function gn(e,t,r,n){_l(r,e),Bl(n,t);let o=r.length,s=n.length;if(o!==s)throw new Error("arrays of points and scalars must have equal length");let i=e.ZERO,a=La(BigInt(o)),c=1;a>12?c=a-3:a>4?c=a-2:a>0&&(c=2);let u=Ie(c),f=new Array(Number(u)+1).fill(i),l=Math.floor((t.BITS-1)/c)*c,m=i;for(let p=l;p>=0;p-=c){f.fill(i);for(let w=0;w<s;w++){let h=n[w],E=Number(h>>BigInt(p)&u);f[E]=f[E].add(r[w])}let g=i;for(let w=f.length-1,h=i;w>0;w--)h=h.add(f[w]),g=g.add(h);if(m=m.add(g),p!==0)for(let w=0;w<c;w++)m=m.double()}return m}function Va(e,t){if(t){if(t.ORDER!==e)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Qo(t),t}else return Mt(e)}function wn(e,t,r={}){if(!t||typeof t!="object")throw new Error(`expected valid ${e} CURVE object`);for(let a of["p","n","h"]){let c=t[a];if(!(typeof c=="bigint"&&c>Xe))throw new Error(`CURVE.${a} must be positive bigint`)}let n=Va(t.p,r.Fp),o=Va(t.n,r.Fn),i=["Gx","Gy","a",e==="weierstrass"?"b":"d"];for(let a of i)if(!n.isValid(t[a]))throw new Error(`CURVE.${a} must be valid field element of CURVE.Fp`);return{Fp:n,Fn:o}}var Wt=BigInt(0),_t=BigInt(1),os=BigInt(2),Ll=BigInt(8),Tl={zip215:!0};function Cl(e,t,r,n){let o=e.sqr(r),s=e.sqr(n),i=e.add(e.mul(t.a,o),s),a=e.add(e.ONE,e.mul(t.d,e.mul(o,s)));return e.eql(i,a)}function Pl(e,t={}){let{Fp:r,Fn:n}=wn("edwards",e,t),{h:o,n:s}=e;Gt(t,{},{uvRatio:"function"});let i=os<<BigInt(n.BYTES*8)-_t,a=w=>r.create(w),c=t.uvRatio||((w,h)=>{try{return{isValid:!0,value:r.sqrt(r.div(w,h))}}catch{return{isValid:!1,value:Wt}}});if(!Cl(r,e,e.Gx,e.Gy))throw new Error("bad curve params: generator point");function u(w,h,E=!1){let B=E?_t:Wt;return Nt("coordinate "+w,h,B,i),h}function f(w){if(!(w instanceof p))throw new Error("ExtendedPoint expected")}let l=Ze((w,h)=>{let{ex:E,ey:B,ez:_}=w,K=w.is0();h==null&&(h=K?Ll:r.inv(_));let S=a(E*h),k=a(B*h),C=a(_*h);if(K)return{x:Wt,y:_t};if(C!==_t)throw new Error("invZ was invalid");return{x:S,y:k}}),m=Ze(w=>{let{a:h,d:E}=e;if(w.is0())throw new Error("bad point: ZERO");let{ex:B,ey:_,ez:K,et:S}=w,k=a(B*B),C=a(_*_),T=a(K*K),d=a(T*T),x=a(k*h),y=a(T*a(x+C)),b=a(d+a(E*a(k*C)));if(y!==b)throw new Error("bad point: equation left != right (1)");let A=a(B*_),I=a(K*S);if(A!==I)throw new Error("bad point: equation left != right (2)");return!0});class p{constructor(h,E,B,_){this.ex=u("x",h),this.ey=u("y",E),this.ez=u("z",B,!0),this.et=u("t",_),Object.freeze(this)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static fromAffine(h){if(h instanceof p)throw new Error("extended point not allowed");let{x:E,y:B}=h||{};return u("x",E),u("y",B),new p(E,B,_t,a(E*B))}static normalizeZ(h){return mn(p,"ez",h)}static msm(h,E){return gn(p,n,h,E)}_setWindowSize(h){this.precompute(h)}precompute(h=8,E=!0){return g.setWindowSize(this,h),E||this.multiply(os),this}assertValidity(){m(this)}equals(h){f(h);let{ex:E,ey:B,ez:_}=this,{ex:K,ey:S,ez:k}=h,C=a(E*k),T=a(K*_),d=a(B*k),x=a(S*_);return C===T&&d===x}is0(){return this.equals(p.ZERO)}negate(){return new p(a(-this.ex),this.ey,this.ez,a(-this.et))}double(){let{a:h}=e,{ex:E,ey:B,ez:_}=this,K=a(E*E),S=a(B*B),k=a(os*a(_*_)),C=a(h*K),T=E+B,d=a(a(T*T)-K-S),x=C+S,y=x-k,b=C-S,A=a(d*y),I=a(x*b),v=a(d*b),L=a(y*x);return new p(A,I,L,v)}add(h){f(h);let{a:E,d:B}=e,{ex:_,ey:K,ez:S,et:k}=this,{ex:C,ey:T,ez:d,et:x}=h,y=a(_*C),b=a(K*T),A=a(k*B*x),I=a(S*d),v=a((_+K)*(C+T)-y-b),L=I-A,P=I+A,U=a(b-E*y),D=a(v*L),M=a(P*U),R=a(v*U),H=a(L*P);return new p(D,M,H,R)}subtract(h){return this.add(h.negate())}multiply(h){let E=h;Nt("scalar",E,_t,s);let{p:B,f:_}=g.wNAFCached(this,E,p.normalizeZ);return p.normalizeZ([B,_])[0]}multiplyUnsafe(h,E=p.ZERO){let B=h;return Nt("scalar",B,Wt,s),B===Wt?p.ZERO:this.is0()||B===_t?this:g.wNAFCachedUnsafe(this,B,p.normalizeZ,E)}isSmallOrder(){return this.multiplyUnsafe(o).is0()}isTorsionFree(){return g.wNAFCachedUnsafe(this,s).is0()}toAffine(h){return l(this,h)}clearCofactor(){return o===_t?this:this.multiplyUnsafe(o)}static fromBytes(h,E=!1){return xt(h),this.fromHex(h,E)}static fromHex(h,E=!1){let{d:B,a:_}=e,K=r.BYTES;h=J("pointHex",h,K),ee("zip215",E);let S=h.slice(),k=h[K-1];S[K-1]=k&-129;let C=Ft(S),T=E?i:r.ORDER;Nt("pointHex.y",C,Wt,T);let d=a(C*C),x=a(d-_t),y=a(B*d-_),{isValid:b,value:A}=c(x,y);if(!b)throw new Error("Point.fromHex: invalid y coordinate");let I=(A&_t)===_t,v=(k&128)!==0;if(!E&&A===Wt&&v)throw new Error("Point.fromHex: x=0 and x_0=1");return v!==I&&(A=a(-A)),p.fromAffine({x:A,y:C})}static fromPrivateScalar(h){return p.BASE.multiply(h)}toBytes(){let{x:h,y:E}=this.toAffine(),B=pe(E,r.BYTES);return B[B.length-1]|=h&_t?128:0,B}toRawBytes(){return this.toBytes()}toHex(){return Vt(this.toBytes())}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}p.BASE=new p(e.Gx,e.Gy,_t,a(e.Gx*e.Gy)),p.ZERO=new p(Wt,_t,_t,Wt),p.Fp=r,p.Fn=n;let g=yn(p,n.BYTES*8);return p}function Dl(e,t){Gt(t,{hash:"function"},{adjustScalarBytes:"function",randomBytes:"function",domain:"function",prehash:"function",mapToCurve:"function"});let{prehash:r,hash:n}=t,{BASE:o,Fp:s,Fn:i}=e,a=i.ORDER,c=t.randomBytes||Se,u=t.adjustScalarBytes||(S=>S),f=t.domain||((S,k,C)=>{if(ee("phflag",C),k.length||C)throw new Error("Contexts/pre-hash are not supported");return S});function l(S){return i.create(S)}function m(S){return l(Ft(S))}function p(S){let k=s.BYTES;S=J("private key",S,k);let C=J("hashed private key",n(S),2*k),T=u(C.slice(0,k)),d=C.slice(k,2*k),x=m(T);return{head:T,prefix:d,scalar:x}}function g(S){let{head:k,prefix:C,scalar:T}=p(S),d=o.multiply(T),x=d.toBytes();return{head:k,prefix:C,scalar:T,point:d,pointBytes:x}}function w(S){return g(S).pointBytes}function h(S=Uint8Array.of(),...k){let C=Ct(...k);return m(n(f(C,J("context",S),!!r)))}function E(S,k,C={}){S=J("message",S),r&&(S=r(S));let{prefix:T,scalar:d,pointBytes:x}=g(k),y=h(C.context,T,S),b=o.multiply(y).toBytes(),A=h(C.context,b,x,S),I=l(y+A*d);Nt("signature.s",I,Wt,a);let v=s.BYTES,L=Ct(b,pe(I,v));return J("result",L,v*2)}let B=Tl;function _(S,k,C,T=B){let{context:d,zip215:x}=T,y=s.BYTES;S=J("signature",S,2*y),k=J("message",k),C=J("publicKey",C,y),x!==void 0&&ee("zip215",x),r&&(k=r(k));let b=Ft(S.slice(y,2*y)),A,I,v;try{A=e.fromHex(C,x),I=e.fromHex(S.slice(0,y),x),v=o.multiplyUnsafe(b)}catch{return!1}if(!x&&A.isSmallOrder())return!1;let L=h(d,I.toBytes(),A.toBytes(),k);return I.add(A.multiplyUnsafe(L)).subtract(v).clearCofactor().is0()}return o.precompute(8),{getPublicKey:w,sign:E,verify:_,utils:{getExtendedPublicKey:g,randomPrivateKey:()=>c(s.BYTES),precompute(S=8,k=e.BASE){return k.precompute(S,!1)}},Point:e}}function kl(e){let t={a:e.a,d:e.d,p:e.Fp.ORDER,n:e.n,h:e.h,Gx:e.Gx,Gy:e.Gy},r=e.Fp,n=Mt(t.n,e.nBitLength,!0),o={Fp:r,Fn:n,uvRatio:e.uvRatio},s={hash:e.hash,randomBytes:e.randomBytes,adjustScalarBytes:e.adjustScalarBytes,domain:e.domain,prehash:e.prehash,mapToCurve:e.mapToCurve};return{CURVE:t,curveOpts:o,eddsaOpts:s}}function Ul(e,t){return Object.assign({},t,{ExtendedPoint:t.Point,CURVE:e})}function Wa(e){let{CURVE:t,curveOpts:r,eddsaOpts:n}=kl(e),o=Pl(t,r),s=Dl(o,n);return Ul(e,s)}var _r=BigInt(0),Je=BigInt(1),xn=BigInt(2);function Kl(e){return Gt(e,{adjustScalarBytes:"function",powPminus2:"function"}),Object.freeze({...e})}function ja(e){let t=Kl(e),{P:r,type:n,adjustScalarBytes:o,powPminus2:s,randomBytes:i}=t,a=n==="x25519";if(!a&&n!=="x448")throw new Error("invalid type");let c=i||Se,u=a?255:448,f=a?32:56,l=BigInt(a?9:5),m=BigInt(a?121665:39081),p=a?xn**BigInt(254):xn**BigInt(447),g=a?BigInt(8)*xn**BigInt(251)-Je:BigInt(4)*xn**BigInt(445)-Je,w=p+g+Je,h=d=>tt(d,r),E=B(l);function B(d){return pe(h(d),f)}function _(d){let x=J("u coordinate",d,f);return a&&(x[31]&=127),h(Ft(x))}function K(d){return Ft(o(J("scalar",d,f)))}function S(d,x){let y=T(_(x),K(d));if(y===_r)throw new Error("invalid private or public key received");return B(y)}function k(d){return S(d,E)}function C(d,x,y){let b=h(d*(x-y));return x=h(x-b),y=h(y+b),{x_2:x,x_3:y}}function T(d,x){Nt("u",d,_r,r),Nt("scalar",x,p,w);let y=x,b=d,A=Je,I=_r,v=d,L=Je,P=_r;for(let D=BigInt(u-1);D>=_r;D--){let M=y>>D&Je;P^=M,{x_2:A,x_3:v}=C(P,A,v),{x_2:I,x_3:L}=C(P,I,L),P=M;let R=A+I,H=h(R*R),G=A-I,Q=h(G*G),V=H-Q,rt=v+L,Lt=v-L,gt=h(Lt*R),pt=h(rt*G),Ne=gt+pt,Zt=gt-pt;v=h(Ne*Ne),L=h(b*h(Zt*Zt)),A=h(H*Q),I=h(V*(H+h(m*V)))}({x_2:A,x_3:v}=C(P,A,v)),{x_2:I,x_3:L}=C(P,I,L);let U=s(I);return h(A*U)}return{scalarMult:S,scalarMultBase:k,getSharedSecret:(d,x)=>S(d,x),getPublicKey:d=>k(d),utils:{randomPrivateKey:()=>c(f)},GuBytes:E.slice()}}var hm=BigInt(0),Rl=BigInt(1),$a=BigInt(2),Nl=BigInt(3),Ml=BigInt(5),Ol=BigInt(8),Br={p:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),h:Ol,a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function Ya(e){let t=BigInt(10),r=BigInt(20),n=BigInt(40),o=BigInt(80),s=Br.p,a=e*e%s*e%s,c=et(a,$a,s)*a%s,u=et(c,Rl,s)*e%s,f=et(u,Ml,s)*u%s,l=et(f,t,s)*f%s,m=et(l,r,s)*l%s,p=et(m,n,s)*m%s,g=et(p,o,s)*p%s,w=et(g,o,s)*p%s,h=et(w,t,s)*f%s;return{pow_p_5_8:et(h,$a,s)*e%s,b2:a}}function Xa(e){return e[0]&=248,e[31]&=127,e[31]|=64,e}var Za=BigInt("19681161376707505956807079304988542015446066515923890162744021073123829784752");function Hl(e,t){let r=Br.p,n=tt(t*t*t,r),o=tt(n*n*t,r),s=Ya(e*o).pow_p_5_8,i=tt(e*n*s,r),a=tt(t*i*i,r),c=i,u=tt(i*Za,r),f=a===e,l=a===tt(-e,r),m=a===tt(-e*Za,r);return f&&(i=c),(l||m)&&(i=u),Ra(i,r)&&(i=tt(-i,r)),{isValid:f||l,value:i}}var ql=Mt(Br.p,void 0,!0),Vl={...Br,Fp:ql,hash:Ia,adjustScalarBytes:Xa,uvRatio:Hl},Ja=Wa(Vl);var Lr=(()=>{let e=Br.p;return ja({P:e,type:"x25519",powPminus2:t=>{let{pow_p_5_8:r,b2:n}=Ya(t);return tt(et(r,Nl,e)*n,e)},adjustScalarBytes:Xa})})();var Tr=class extends Error{constructor(t="An error occurred while verifying a message"){super(t),this.name="VerificationError"}},bn=class extends Error{constructor(t="Missing Web Crypto API"){super(t),this.name="WebCryptoMissingError"}};var Qa={get(e=globalThis){let t=e.crypto;if(t?.subtle==null)throw new bn("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 kt=Qa;var En=32;var ss,zl=(async()=>{try{return await kt.get().subtle.generateKey({name:"Ed25519"},!0,["sign","verify"]),!0}catch{return!1}})();async function Fl(e,t,r){if(e.buffer instanceof ArrayBuffer){let n=await kt.get().subtle.importKey("raw",e.buffer,{name:"Ed25519"},!1,["verify"]);return await kt.get().subtle.verify({name:"Ed25519"},n,t,r instanceof Uint8Array?r:r.subarray())}throw new TypeError("WebCrypto does not support SharedArrayBuffer for Ed25519 keys")}function Gl(e,t,r){return Ja.verify(t,r instanceof Uint8Array?r:r.subarray(),e)}async function tc(e,t,r){return ss==null&&(ss=await zl),ss?Fl(e,t,r):Gl(e,t,r)}function Sn(e){return e==null?!1:typeof e.then=="function"&&typeof e.catch=="function"&&typeof e.finally=="function"}var An=class{type="Ed25519";raw;constructor(t){this.raw=is(t,En)}toMultihash(){return Ut.digest(fe(this))}toCID(){return it.createV1(114,this.toMultihash())}toString(){return X.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ft(this.raw,t.raw)}verify(t,r,n){n?.signal?.throwIfAborted();let o=tc(this.raw,r,t);return Sn(o)?o.then(s=>(n?.signal?.throwIfAborted(),s)):o}};function as(e){return e=is(e,En),new An(e)}function is(e,t){if(e=Uint8Array.from(e??[]),e.length!==t)throw new ot(`Key must be a Uint8Array of length ${t}, got ${e.length}`);return e}var jl=Math.pow(2,7),$l=Math.pow(2,14),Zl=Math.pow(2,21),cs=Math.pow(2,28),fs=Math.pow(2,35),us=Math.pow(2,42),ls=Math.pow(2,49),$=128,bt=127;function ct(e){if(e<jl)return 1;if(e<$l)return 2;if(e<Zl)return 3;if(e<cs)return 4;if(e<fs)return 5;if(e<us)return 6;if(e<ls)return 7;if(Number.MAX_SAFE_INTEGER!=null&&e>Number.MAX_SAFE_INTEGER)throw new RangeError("Could not encode varint");return 8}function hs(e,t,r=0){switch(ct(e)){case 8:t[r++]=e&255|$,e/=128;case 7:t[r++]=e&255|$,e/=128;case 6:t[r++]=e&255|$,e/=128;case 5:t[r++]=e&255|$,e/=128;case 4:t[r++]=e&255|$,e>>>=7;case 3:t[r++]=e&255|$,e>>>=7;case 2:t[r++]=e&255|$,e>>>=7;case 1:{t[r++]=e&255,e>>>=7;break}default:throw new Error("unreachable")}return t}function Yl(e,t,r=0){switch(ct(e)){case 8:t.set(r++,e&255|$),e/=128;case 7:t.set(r++,e&255|$),e/=128;case 6:t.set(r++,e&255|$),e/=128;case 5:t.set(r++,e&255|$),e/=128;case 4:t.set(r++,e&255|$),e>>>=7;case 3:t.set(r++,e&255|$),e>>>=7;case 2:t.set(r++,e&255|$),e>>>=7;case 1:{t.set(r++,e&255),e>>>=7;break}default:throw new Error("unreachable")}return t}function ds(e,t){let r=e[t],n=0;if(n+=r&bt,r<$||(r=e[t+1],n+=(r&bt)<<7,r<$)||(r=e[t+2],n+=(r&bt)<<14,r<$)||(r=e[t+3],n+=(r&bt)<<21,r<$)||(r=e[t+4],n+=(r&bt)*cs,r<$)||(r=e[t+5],n+=(r&bt)*fs,r<$)||(r=e[t+6],n+=(r&bt)*us,r<$)||(r=e[t+7],n+=(r&bt)*ls,r<$))return n;throw new RangeError("Could not decode varint")}function Xl(e,t){let r=e.get(t),n=0;if(n+=r&bt,r<$||(r=e.get(t+1),n+=(r&bt)<<7,r<$)||(r=e.get(t+2),n+=(r&bt)<<14,r<$)||(r=e.get(t+3),n+=(r&bt)<<21,r<$)||(r=e.get(t+4),n+=(r&bt)*cs,r<$)||(r=e.get(t+5),n+=(r&bt)*fs,r<$)||(r=e.get(t+6),n+=(r&bt)*us,r<$)||(r=e.get(t+7),n+=(r&bt)*ls,r<$))return n;throw new RangeError("Could not decode varint")}function jt(e,t,r=0){return t==null&&(t=lt(ct(e))),t instanceof Uint8Array?hs(e,t,r):Yl(e,t,r)}function Ot(e,t=0){return e instanceof Uint8Array?ds(e,t):Xl(e,t)}var ps=new Float32Array([-0]),me=new Uint8Array(ps.buffer);function rc(e,t,r){ps[0]=e,t[r]=me[0],t[r+1]=me[1],t[r+2]=me[2],t[r+3]=me[3]}function nc(e,t){return me[0]=e[t],me[1]=e[t+1],me[2]=e[t+2],me[3]=e[t+3],ps[0]}var ms=new Float64Array([-0]),Et=new Uint8Array(ms.buffer);function oc(e,t,r){ms[0]=e,t[r]=Et[0],t[r+1]=Et[1],t[r+2]=Et[2],t[r+3]=Et[3],t[r+4]=Et[4],t[r+5]=Et[5],t[r+6]=Et[6],t[r+7]=Et[7]}function sc(e,t){return Et[0]=e[t],Et[1]=e[t+1],Et[2]=e[t+2],Et[3]=e[t+3],Et[4]=e[t+4],Et[5]=e[t+5],Et[6]=e[t+6],Et[7]=e[t+7],ms[0]}var Jl=BigInt(Number.MAX_SAFE_INTEGER),Ql=BigInt(Number.MIN_SAFE_INTEGER),Pt=class e{lo;hi;constructor(t,r){this.lo=t|0,this.hi=r|0}toNumber(t=!1){if(!t&&this.hi>>>31>0){let r=~this.lo+1>>>0,n=~this.hi>>>0;return r===0&&(n=n+1>>>0),-(r+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 r=~this.lo+1>>>0,n=~this.hi>>>0;return r===0&&(n=n+1>>>0),-(BigInt(r)+(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,r=(this.lo>>>28|this.hi<<4)>>>0,n=this.hi>>>24;return n===0?r===0?t<16384?t<128?1:2:t<2097152?3:4:r<16384?r<128?5:6:r<2097152?7:8:n<128?9:10}static fromBigInt(t){if(t===0n)return Le;if(t<Jl&&t>Ql)return this.fromNumber(Number(t));let r=t<0n;r&&(t=-t);let n=t>>32n,o=t-(n<<32n);return r&&(n=~n|0n,o=~o|0n,++o>ic&&(o=0n,++n>ic&&(n=0n))),new e(Number(o),Number(n))}static fromNumber(t){if(t===0)return Le;let r=t<0;r&&(t=-t);let n=t>>>0,o=(t-n)/4294967296>>>0;return r&&(o=~o>>>0,n=~n>>>0,++n>4294967295&&(n=0,++o>4294967295&&(o=0))),new e(n,o)}static from(t){return typeof t=="number"?e.fromNumber(t):typeof t=="bigint"?e.fromBigInt(t):typeof t=="string"?e.fromBigInt(BigInt(t)):t.low!=null||t.high!=null?new e(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 ic=4294967296n;function ac(e){let t=0,r=0;for(let n=0;n<e.length;++n)r=e.charCodeAt(n),r<128?t+=1:r<2048?t+=2:(r&64512)===55296&&(e.charCodeAt(n+1)&64512)===56320?(++n,t+=4):t+=3;return t}function cc(e,t,r){if(r-t<1)return"";let o,s=[],i=0,a;for(;t<r;)a=e[t++],a<128?s[i++]=a:a>191&&a<224?s[i++]=(a&31)<<6|e[t++]&63:a>239&&a<365?(a=((a&7)<<18|(e[t++]&63)<<12|(e[t++]&63)<<6|e[t++]&63)-65536,s[i++]=55296+(a>>10),s[i++]=56320+(a&1023)):s[i++]=(a&15)<<12|(e[t++]&63)<<6|e[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 ys(e,t,r){let n=r,o,s;for(let i=0;i<e.length;++i)o=e.charCodeAt(i),o<128?t[r++]=o:o<2048?(t[r++]=o>>6|192,t[r++]=o&63|128):(o&64512)===55296&&((s=e.charCodeAt(i+1))&64512)===56320?(o=65536+((o&1023)<<10)+(s&1023),++i,t[r++]=o>>18|240,t[r++]=o>>12&63|128,t[r++]=o>>6&63|128,t[r++]=o&63|128):(t[r++]=o>>12|224,t[r++]=o>>6&63|128,t[r++]=o&63|128);return r-n}function Ht(e,t){return RangeError(`index out of range: ${e.pos} + ${t??1} > ${e.len}`)}function vn(e,t){return(e[t-4]|e[t-3]<<8|e[t-2]<<16|e[t-1]<<24)>>>0}var gs=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,Ht(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 Ht(this,4);return vn(this.buf,this.pos+=4)}sfixed32(){if(this.pos+4>this.len)throw Ht(this,4);return vn(this.buf,this.pos+=4)|0}float(){if(this.pos+4>this.len)throw Ht(this,4);let t=nc(this.buf,this.pos);return this.pos+=4,t}double(){if(this.pos+8>this.len)throw Ht(this,4);let t=sc(this.buf,this.pos);return this.pos+=8,t}bytes(){let t=this.uint32(),r=this.pos,n=this.pos+t;if(n>this.len)throw Ht(this,t);return this.pos+=t,r===n?new Uint8Array(0):this.buf.subarray(r,n)}string(){let t=this.bytes();return cc(t,0,t.length)}skip(t){if(typeof t=="number"){if(this.pos+t>this.len)throw Ht(this,t);this.pos+=t}else do if(this.pos>=this.len)throw Ht(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),r=0;if(this.len-this.pos>4){for(;r<4;++r)if(t.lo=(t.lo|(this.buf[this.pos]&127)<<r*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;r=0}else{for(;r<3;++r){if(this.pos>=this.len)throw Ht(this);if(t.lo=(t.lo|(this.buf[this.pos]&127)<<r*7)>>>0,this.buf[this.pos++]<128)return t}return t.lo=(t.lo|(this.buf[this.pos++]&127)<<r*7)>>>0,t}if(this.len-this.pos>4){for(;r<5;++r)if(t.hi=(t.hi|(this.buf[this.pos]&127)<<r*7+3)>>>0,this.buf[this.pos++]<128)return t}else for(;r<5;++r){if(this.pos>=this.len)throw Ht(this);if(t.hi=(t.hi|(this.buf[this.pos]&127)<<r*7+3)>>>0,this.buf[this.pos++]<128)return t}throw Error("invalid varint encoding")}readFixed64(){if(this.pos+8>this.len)throw Ht(this,8);let t=vn(this.buf,this.pos+=4),r=vn(this.buf,this.pos+=4);return new Pt(t,r)}int64(){return this.readLongVarint().toBigInt()}int64Number(){return this.readLongVarint().toNumber()}int64String(){return this.readLongVarint().toString()}uint64(){return this.readLongVarint().toBigInt(!0)}uint64Number(){let t=ds(this.buf,this.pos);return this.pos+=ct(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 ws(e){return new gs(e instanceof Uint8Array?e:e.subarray())}function Te(e,t,r){let n=ws(e);return t.decode(n,void 0,r)}function xs(e){let t=e??8192,r=t>>>1,n,o=t;return function(i){if(i<1||i>r)return lt(i);o+i>t&&(n=lt(t),o=0);let a=n.subarray(o,o+=i);return(o&7)!==0&&(o=(o|7)+1),a}}var Ce=class{fn;len;next;val;constructor(t,r,n){this.fn=t,this.len=r,this.next=void 0,this.val=n}};function bs(){}var Ss=class{head;tail;len;next;constructor(t){this.head=t.head,this.tail=t.tail,this.len=t.len,this.next=t.states}},th=xs();function eh(e){return globalThis.Buffer!=null?lt(e):th(e)}var Dr=class{len;head;tail;states;constructor(){this.len=0,this.head=new Ce(bs,0,0),this.tail=this.head,this.states=null}_push(t,r,n){return this.tail=this.tail.next=new Ce(t,r,n),this.len+=r,this}uint32(t){return this.len+=(this.tail=this.tail.next=new As((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(In,10,Pt.fromNumber(t)):this.uint32(t)}sint32(t){return this.uint32((t<<1^t>>31)>>>0)}uint64(t){let r=Pt.fromBigInt(t);return this._push(In,r.length(),r)}uint64Number(t){return this._push(hs,ct(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 r=Pt.fromBigInt(t).zzEncode();return this._push(In,r.length(),r)}sint64Number(t){let r=Pt.fromNumber(t).zzEncode();return this._push(In,r.length(),r)}sint64String(t){return this.sint64(BigInt(t))}bool(t){return this._push(Es,1,t?1:0)}fixed32(t){return this._push(Pr,4,t>>>0)}sfixed32(t){return this.fixed32(t)}fixed64(t){let r=Pt.fromBigInt(t);return this._push(Pr,4,r.lo)._push(Pr,4,r.hi)}fixed64Number(t){let r=Pt.fromNumber(t);return this._push(Pr,4,r.lo)._push(Pr,4,r.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(rc,4,t)}double(t){return this._push(oc,8,t)}bytes(t){let r=t.length>>>0;return r===0?this._push(Es,1,0):this.uint32(r)._push(nh,r,t)}string(t){let r=ac(t);return r!==0?this.uint32(r)._push(ys,r,t):this._push(Es,1,0)}fork(){return this.states=new Ss(this),this.head=this.tail=new Ce(bs,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 Ce(bs,0,0),this.len=0),this}ldelim(){let t=this.head,r=this.tail,n=this.len;return this.reset().uint32(n),n!==0&&(this.tail.next=t.next,this.tail=r,this.len+=n),this}finish(){let t=this.head.next,r=eh(this.len),n=0;for(;t!=null;)t.fn(t.val,r,n),n+=t.len,t=t.next;return r}};function Es(e,t,r){t[r]=e&255}function rh(e,t,r){for(;e>127;)t[r++]=e&127|128,e>>>=7;t[r]=e}var As=class extends Ce{next;constructor(t,r){super(rh,t,r),this.next=void 0}};function In(e,t,r){for(;e.hi!==0;)t[r++]=e.lo&127|128,e.lo=(e.lo>>>7|e.hi<<25)>>>0,e.hi>>>=7;for(;e.lo>127;)t[r++]=e.lo&127|128,e.lo=e.lo>>>7;t[r++]=e.lo}function Pr(e,t,r){t[r]=e&255,t[r+1]=e>>>8&255,t[r+2]=e>>>16&255,t[r+3]=e>>>24}function nh(e,t,r){t.set(e,r)}globalThis.Buffer!=null&&(Dr.prototype.bytes=function(e){let t=e.length>>>0;return this.uint32(t),t>0&&this._push(oh,t,e),this},Dr.prototype.string=function(e){let t=globalThis.Buffer.byteLength(e);return this.uint32(t),t>0&&this._push(sh,t,e),this});function oh(e,t,r){t.set(e,r)}function sh(e,t,r){e.length<40?ys(e,t,r):t.utf8Write!=null?t.utf8Write(e,r):t.set(j(e),r)}function vs(){return new Dr}function Pe(e,t){let r=vs();return t.encode(e,r,{lengthDelimited:!1}),r.finish()}var Qe;(function(e){e[e.VARINT=0]="VARINT",e[e.BIT64=1]="BIT64",e[e.LENGTH_DELIMITED=2]="LENGTH_DELIMITED",e[e.START_GROUP=3]="START_GROUP",e[e.END_GROUP=4]="END_GROUP",e[e.BIT32=5]="BIT32"})(Qe||(Qe={}));function _n(e,t,r,n){return{name:e,type:t,encode:r,decode:n}}function Is(e){function t(o){if(e[o.toString()]==null)throw new Error("Invalid enum value");return e[o]}let r=function(s,i){let a=t(s);i.int32(a)},n=function(s){let i=s.int32();return t(i)};return _n("enum",Qe.VARINT,r,n)}function De(e,t){return _n("message",Qe.LENGTH_DELIMITED,e,t)}var kr=class extends Error{code="ERR_MAX_LENGTH";name="MaxLengthError"};var at;(function(e){e.RSA="RSA",e.Ed25519="Ed25519",e.secp256k1="secp256k1",e.ECDSA="ECDSA"})(at||(at={}));var _s;(function(e){e[e.RSA=0]="RSA",e[e.Ed25519=1]="Ed25519",e[e.secp256k1=2]="secp256k1",e[e.ECDSA=3]="ECDSA"})(_s||(_s={}));(function(e){e.codec=()=>Is(_s)})(at||(at={}));var $t;(function(e){let t;e.codec=()=>(t==null&&(t=De((r,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),r.Type!=null&&(n.uint32(8),at.codec().encode(r.Type,n)),r.Data!=null&&(n.uint32(18),n.bytes(r.Data)),o.lengthDelimited!==!1&&n.ldelim()},(r,n,o={})=>{let s={},i=n==null?r.len:r.pos+n;for(;r.pos<i;){let a=r.uint32();switch(a>>>3){case 1:{s.Type=at.codec().decode(r);break}case 2:{s.Data=r.bytes();break}default:{r.skipType(a&7);break}}}return s})),t),e.encode=r=>Pe(r,e.codec()),e.decode=(r,n)=>Te(r,e.codec(),n)})($t||($t={}));var Bs;(function(e){let t;e.codec=()=>(t==null&&(t=De((r,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),r.Type!=null&&(n.uint32(8),at.codec().encode(r.Type,n)),r.Data!=null&&(n.uint32(18),n.bytes(r.Data)),o.lengthDelimited!==!1&&n.ldelim()},(r,n,o={})=>{let s={},i=n==null?r.len:r.pos+n;for(;r.pos<i;){let a=r.uint32();switch(a>>>3){case 1:{s.Type=at.codec().decode(r);break}case 2:{s.Data=r.bytes();break}default:{r.skipType(a&7);break}}}return s})),t),e.encode=r=>Pe(r,e.codec()),e.decode=(r,n)=>Te(r,e.codec(),n)})(Bs||(Bs={}));var Kr={};vt(Kr,{MAX_RSA_KEY_SIZE:()=>Ls,generateRSAKeyPair:()=>pc,jwkToJWKKeyPair:()=>mc,jwkToPkcs1:()=>fh,jwkToPkix:()=>Ds,jwkToRSAPrivateKey:()=>Rs,pkcs1MessageToJwk:()=>Cs,pkcs1MessageToRSAPrivateKey:()=>ks,pkcs1ToJwk:()=>ch,pkcs1ToRSAPrivateKey:()=>dc,pkixMessageToJwk:()=>Ps,pkixMessageToRSAPublicKey:()=>Ks,pkixToJwk:()=>uh,pkixToRSAPublicKey:()=>Us});var ye=dn;var tr=class{type="RSA";jwk;_raw;_multihash;constructor(t,r){this.jwk=t,this._multihash=r}get raw(){return this._raw==null&&(this._raw=Kr.jwkToPkix(this.jwk)),this._raw}toMultihash(){return this._multihash}toCID(){return it.createV1(114,this._multihash)}toString(){return X.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ft(this.raw,t.raw)}verify(t,r,n){return hc(this.jwk,r,t,n)}},Ur=class{type="RSA";jwk;_raw;publicKey;constructor(t,r){this.jwk=t,this.publicKey=r}get raw(){return this._raw==null&&(this._raw=Kr.jwkToPkcs1(this.jwk)),this._raw}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ft(this.raw,t.raw)}sign(t,r){return lc(this.jwk,t,r)}};var Ls=8192,Ts=18,ih=1062,ah=Uint8Array.from([48,13,6,9,42,134,72,134,247,13,1,1,1,5,0]);function ch(e){let t=Jt(e);return Cs(t)}function Cs(e){return{n:O(e[1],"base64url"),e:O(e[2],"base64url"),d:O(e[3],"base64url"),p:O(e[4],"base64url"),q:O(e[5],"base64url"),dp:O(e[6],"base64url"),dq:O(e[7],"base64url"),qi:O(e[8],"base64url"),kty:"RSA"}}function fh(e){if(e.n==null||e.e==null||e.d==null||e.p==null||e.q==null||e.dp==null||e.dq==null||e.qi==null)throw new ot("JWK was missing components");return ce([Tt(Uint8Array.from([0])),Tt(j(e.n,"base64url")),Tt(j(e.e,"base64url")),Tt(j(e.d,"base64url")),Tt(j(e.p,"base64url")),Tt(j(e.q,"base64url")),Tt(j(e.dp,"base64url")),Tt(j(e.dq,"base64url")),Tt(j(e.qi,"base64url"))]).subarray()}function uh(e){let t=Jt(e,{offset:0});return Ps(t)}function Ps(e){let t=Jt(e[1],{offset:0});return{kty:"RSA",n:O(t[0],"base64url"),e:O(t[1],"base64url")}}function Ds(e){if(e.n==null||e.e==null)throw new ot("JWK was missing components");return ce([ah,fn(ce([Tt(j(e.n,"base64url")),Tt(j(e.e,"base64url"))]))]).subarray()}function dc(e){let t=Jt(e);return ks(t)}function ks(e){let t=Cs(e);return Rs(t)}function Us(e,t){if(e.byteLength>=ih)throw new Oe("Key size is too large");let r=Jt(e,{offset:0});return Ks(r,e,t)}function Ks(e,t,r){let n=Ps(e);if(r==null){let o=ye($t.encode({Type:at.RSA,Data:t}));r=Dt(Ts,o)}return new tr(n,r)}function Rs(e){if(gc(e)>Ls)throw new ot("Key size is too large");let t=mc(e),r=ye($t.encode({Type:at.RSA,Data:Ds(t.publicKey)})),n=Dt(Ts,r);return new Ur(t.privateKey,new tr(t.publicKey,n))}async function pc(e){if(e>Ls)throw new ot("Key size is too large");let t=await yc(e),r=ye($t.encode({Type:at.RSA,Data:Ds(t.publicKey)})),n=Dt(Ts,r);return new Ur(t.privateKey,new tr(t.publicKey,n))}function mc(e){if(e==null)throw new ot("Missing key parameter");return{privateKey:e,publicKey:{kty:e.kty,n:e.n,e:e.e}}}async function yc(e,t){let r=await kt.get().subtle.generateKey({name:"RSASSA-PKCS1-v1_5",modulusLength:e,publicExponent:new Uint8Array([1,0,1]),hash:{name:"SHA-256"}},!0,["sign","verify"]);t?.signal?.throwIfAborted();let n=await lh(r,t);return{privateKey:n[0],publicKey:n[1]}}async function lc(e,t,r){let n=await kt.get().subtle.importKey("jwk",e,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["sign"]);r?.signal?.throwIfAborted();let o=await kt.get().subtle.sign({name:"RSASSA-PKCS1-v1_5"},n,t instanceof Uint8Array?t:t.subarray());return r?.signal?.throwIfAborted(),new Uint8Array(o,0,o.byteLength)}async function hc(e,t,r,n){let o=await kt.get().subtle.importKey("jwk",e,{name:"RSASSA-PKCS1-v1_5",hash:{name:"SHA-256"}},!1,["verify"]);n?.signal?.throwIfAborted();let s=await kt.get().subtle.verify({name:"RSASSA-PKCS1-v1_5"},o,t,r instanceof Uint8Array?r:r.subarray());return n?.signal?.throwIfAborted(),s}async function lh(e,t){if(e.privateKey==null||e.publicKey==null)throw new ot("Private and public key are required");let r=await Promise.all([kt.get().subtle.exportKey("jwk",e.privateKey),kt.get().subtle.exportKey("jwk",e.publicKey)]);return t?.signal?.throwIfAborted(),r}function gc(e){if(e.kty!=="RSA")throw new ot("invalid key type");if(e.n==null)throw new ot("invalid key modulus");return j(e.n,"base64url").length*8}var Bn=class extends Fe{constructor(t,r){super(),this.finished=!1,this.destroyed=!1,br(t);let n=ue(r);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),Kt(s)}update(t){return We(this),this.iHash.update(t),this}digestInto(t){We(this),xt(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:r,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=r._cloneInto(t.oHash),t.iHash=n._cloneInto(t.iHash),t}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}},er=(e,t,r)=>new Bn(e,t).update(r).digest();er.create=(e,t)=>new Bn(e,t);function wc(e){e.lowS!==void 0&&ee("lowS",e.lowS),e.prehash!==void 0&&ee("prehash",e.prehash)}var Ns=class extends Error{constructor(t=""){super(t)}},re={Err:Ns,_tlv:{encode:(e,t)=>{let{Err:r}=re;if(e<0||e>256)throw new r("tlv.encode: wrong tag");if(t.length&1)throw new r("tlv.encode: unpadded data");let n=t.length/2,o=vr(n);if(o.length/2&128)throw new r("tlv.encode: long form length too big");let s=n>127?vr(o.length/2|128):"";return vr(e)+s+o+t},decode(e,t){let{Err:r}=re,n=0;if(e<0||e>256)throw new r("tlv.encode: wrong tag");if(t.length<2||t[n++]!==e)throw new r("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 r("tlv.decode(long): indefinite length not supported");if(c>4)throw new r("tlv.decode(long): byte length is too big");let u=t.subarray(n,n+c);if(u.length!==c)throw new r("tlv.decode: length bytes not complete");if(u[0]===0)throw new r("tlv.decode(long): zero leftmost byte");for(let f of u)i=i<<8|f;if(n+=c,i<128)throw new r("tlv.decode(long): not minimal encoding")}let a=t.subarray(n,n+i);if(a.length!==i)throw new r("tlv.decode: wrong value length");return{v:a,l:t.subarray(n+i)}}},_int:{encode(e){let{Err:t}=re;if(e<Rr)throw new t("integer: negative integers are not allowed");let r=vr(e);if(Number.parseInt(r[0],16)&8&&(r="00"+r),r.length&1)throw new t("unexpected DER parsing assertion: unpadded hex");return r},decode(e){let{Err:t}=re;if(e[0]&128)throw new t("invalid signature integer: negative");if(e[0]===0&&!(e[1]&128))throw new t("invalid signature integer: unnecessary leading zero");return $e(e)}},toSig(e){let{Err:t,_int:r,_tlv:n}=re,o=J("signature",e),{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:u,l:f}=n.decode(2,c);if(f.length)throw new t("invalid signature: left bytes after parsing");return{r:r.decode(a),s:r.decode(u)}},hexFromSig(e){let{_tlv:t,_int:r}=re,n=t.encode(2,r.encode(e.r)),o=t.encode(2,r.encode(e.s)),s=n+o;return t.encode(48,s)}},Rr=BigInt(0),Nr=BigInt(1),hh=BigInt(2),Ln=BigInt(3),dh=BigInt(4);function ph(e,t,r){function n(o){let s=e.sqr(o),i=e.mul(s,o);return e.add(e.add(i,e.mul(o,t)),r)}return n}function xc(e,t,r){let{BYTES:n}=e;function o(s){let i;if(typeof s=="bigint")i=s;else{let a=J("private key",s);if(t){if(!t.includes(a.length*2))throw new Error("invalid private key");let c=new Uint8Array(n);c.set(a,c.length-a.length),a=c}try{i=e.fromBytes(a)}catch{throw new Error(`invalid private key: expected ui8a of size ${n}, got ${typeof s}`)}}if(r&&(i=e.create(i)),!e.isValidNot0(i))throw new Error("invalid private key: out of range [1..N-1]");return i}return o}function mh(e,t={}){let{Fp:r,Fn:n}=wn("weierstrass",e,t),{h:o,n:s}=e;Gt(t,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});let{endo:i}=t;if(i&&(!r.is0(e.a)||typeof i.beta!="bigint"||typeof i.splitScalar!="function"))throw new Error('invalid endo: expected "beta": bigint and "splitScalar": function');function a(){if(!r.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function c(T,d,x){let{x:y,y:b}=d.toAffine(),A=r.toBytes(y);if(ee("isCompressed",x),x){a();let I=!r.isOdd(b);return Ct(bc(I),A)}else return Ct(Uint8Array.of(4),A,r.toBytes(b))}function u(T){xt(T);let d=r.BYTES,x=d+1,y=2*d+1,b=T.length,A=T[0],I=T.subarray(1);if(b===x&&(A===2||A===3)){let v=r.fromBytes(I);if(!r.isValid(v))throw new Error("bad point: is not on curve, wrong x");let L=m(v),P;try{P=r.sqrt(L)}catch(M){let R=M instanceof Error?": "+M.message:"";throw new Error("bad point: is not on curve, sqrt error"+R)}a();let U=r.isOdd(P);return(A&1)===1!==U&&(P=r.neg(P)),{x:v,y:P}}else if(b===y&&A===4){let v=r.fromBytes(I.subarray(d*0,d*1)),L=r.fromBytes(I.subarray(d*1,d*2));if(!p(v,L))throw new Error("bad point: is not on curve");return{x:v,y:L}}else throw new Error(`bad point: got length ${b}, expected compressed=${x} or uncompressed=${y}`)}let f=t.toBytes||c,l=t.fromBytes||u,m=ph(r,e.a,e.b);function p(T,d){let x=r.sqr(d),y=m(T);return r.eql(x,y)}if(!p(e.Gx,e.Gy))throw new Error("bad curve params: generator point");let g=r.mul(r.pow(e.a,Ln),dh),w=r.mul(r.sqr(e.b),BigInt(27));if(r.is0(r.add(g,w)))throw new Error("bad curve params: a or b");function h(T,d,x=!1){if(!r.isValid(d)||x&&r.is0(d))throw new Error(`bad point coordinate ${T}`);return d}function E(T){if(!(T instanceof S))throw new Error("ProjectivePoint expected")}let B=Ze((T,d)=>{let{px:x,py:y,pz:b}=T;if(r.eql(b,r.ONE))return{x,y};let A=T.is0();d==null&&(d=A?r.ONE:r.inv(b));let I=r.mul(x,d),v=r.mul(y,d),L=r.mul(b,d);if(A)return{x:r.ZERO,y:r.ZERO};if(!r.eql(L,r.ONE))throw new Error("invZ was invalid");return{x:I,y:v}}),_=Ze(T=>{if(T.is0()){if(t.allowInfinityPoint&&!r.is0(T.py))return;throw new Error("bad point: ZERO")}let{x:d,y:x}=T.toAffine();if(!r.isValid(d)||!r.isValid(x))throw new Error("bad point: x or y not field elements");if(!p(d,x))throw new Error("bad point: equation left != right");if(!T.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function K(T,d,x,y,b){return x=new S(r.mul(x.px,T),x.py,x.pz),d=Ye(y,d),x=Ye(b,x),d.add(x)}class S{constructor(d,x,y){this.px=h("x",d),this.py=h("y",x,!0),this.pz=h("z",y),Object.freeze(this)}static fromAffine(d){let{x,y}=d||{};if(!d||!r.isValid(x)||!r.isValid(y))throw new Error("invalid affine point");if(d instanceof S)throw new Error("projective point not allowed");return r.is0(x)&&r.is0(y)?S.ZERO:new S(x,y,r.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(d){return mn(S,"pz",d)}static fromBytes(d){return xt(d),S.fromHex(d)}static fromHex(d){let x=S.fromAffine(l(J("pointHex",d)));return x.assertValidity(),x}static fromPrivateKey(d){let x=xc(n,t.allowedPrivateKeyLengths,t.wrapPrivateKey);return S.BASE.multiply(x(d))}static msm(d,x){return gn(S,n,d,x)}precompute(d=8,x=!0){return C.setWindowSize(this,d),x||this.multiply(Ln),this}_setWindowSize(d){this.precompute(d)}assertValidity(){_(this)}hasEvenY(){let{y:d}=this.toAffine();if(!r.isOdd)throw new Error("Field doesn't support isOdd");return!r.isOdd(d)}equals(d){E(d);let{px:x,py:y,pz:b}=this,{px:A,py:I,pz:v}=d,L=r.eql(r.mul(x,v),r.mul(A,b)),P=r.eql(r.mul(y,v),r.mul(I,b));return L&&P}negate(){return new S(this.px,r.neg(this.py),this.pz)}double(){let{a:d,b:x}=e,y=r.mul(x,Ln),{px:b,py:A,pz:I}=this,v=r.ZERO,L=r.ZERO,P=r.ZERO,U=r.mul(b,b),D=r.mul(A,A),M=r.mul(I,I),R=r.mul(b,A);return R=r.add(R,R),P=r.mul(b,I),P=r.add(P,P),v=r.mul(d,P),L=r.mul(y,M),L=r.add(v,L),v=r.sub(D,L),L=r.add(D,L),L=r.mul(v,L),v=r.mul(R,v),P=r.mul(y,P),M=r.mul(d,M),R=r.sub(U,M),R=r.mul(d,R),R=r.add(R,P),P=r.add(U,U),U=r.add(P,U),U=r.add(U,M),U=r.mul(U,R),L=r.add(L,U),M=r.mul(A,I),M=r.add(M,M),U=r.mul(M,R),v=r.sub(v,U),P=r.mul(M,D),P=r.add(P,P),P=r.add(P,P),new S(v,L,P)}add(d){E(d);let{px:x,py:y,pz:b}=this,{px:A,py:I,pz:v}=d,L=r.ZERO,P=r.ZERO,U=r.ZERO,D=e.a,M=r.mul(e.b,Ln),R=r.mul(x,A),H=r.mul(y,I),G=r.mul(b,v),Q=r.add(x,y),V=r.add(A,I);Q=r.mul(Q,V),V=r.add(R,H),Q=r.sub(Q,V),V=r.add(x,b);let rt=r.add(A,v);return V=r.mul(V,rt),rt=r.add(R,G),V=r.sub(V,rt),rt=r.add(y,b),L=r.add(I,v),rt=r.mul(rt,L),L=r.add(H,G),rt=r.sub(rt,L),U=r.mul(D,V),L=r.mul(M,G),U=r.add(L,U),L=r.sub(H,U),U=r.add(H,U),P=r.mul(L,U),H=r.add(R,R),H=r.add(H,R),G=r.mul(D,G),V=r.mul(M,V),H=r.add(H,G),G=r.sub(R,G),G=r.mul(D,G),V=r.add(V,G),R=r.mul(H,V),P=r.add(P,R),R=r.mul(rt,V),L=r.mul(Q,L),L=r.sub(L,R),R=r.mul(Q,H),U=r.mul(rt,U),U=r.add(U,R),new S(L,P,U)}subtract(d){return this.add(d.negate())}is0(){return this.equals(S.ZERO)}multiply(d){let{endo:x}=t;if(!n.isValidNot0(d))throw new Error("invalid scalar: out of range");let y,b,A=I=>C.wNAFCached(this,I,S.normalizeZ);if(x){let{k1neg:I,k1:v,k2neg:L,k2:P}=x.splitScalar(d),{p:U,f:D}=A(v),{p:M,f:R}=A(P);b=D.add(R),y=K(x.beta,U,M,I,L)}else{let{p:I,f:v}=A(d);y=I,b=v}return S.normalizeZ([y,b])[0]}multiplyUnsafe(d){let{endo:x}=t,y=this;if(!n.isValid(d))throw new Error("invalid scalar: out of range");if(d===Rr||y.is0())return S.ZERO;if(d===Nr)return y;if(C.hasPrecomputes(this))return this.multiply(d);if(x){let{k1neg:b,k1:A,k2neg:I,k2:v}=x.splitScalar(d),{p1:L,p2:P}=Ga(S,y,A,v);return K(x.beta,L,P,b,I)}else return C.wNAFCachedUnsafe(y,d)}multiplyAndAddUnsafe(d,x,y){let b=this.multiplyUnsafe(x).add(d.multiplyUnsafe(y));return b.is0()?void 0:b}toAffine(d){return B(this,d)}isTorsionFree(){let{isTorsionFree:d}=t;return o===Nr?!0:d?d(S,this):C.wNAFCachedUnsafe(this,s).is0()}clearCofactor(){let{clearCofactor:d}=t;return o===Nr?this:d?d(S,this):this.multiplyUnsafe(o)}toBytes(d=!0){return ee("isCompressed",d),this.assertValidity(),f(S,this,d)}toRawBytes(d=!0){return this.toBytes(d)}toHex(d=!0){return Vt(this.toBytes(d))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}}S.BASE=new S(e.Gx,e.Gy,r.ONE),S.ZERO=new S(r.ZERO,r.ONE,r.ZERO),S.Fp=r,S.Fn=n;let k=n.BITS,C=yn(S,t.endo?Math.ceil(k/2):k);return S}function bc(e){return Uint8Array.of(e?2:3)}function yh(e,t,r={}){Gt(t,{hash:"function"},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});let n=t.randomBytes||Se,o=t.hmac||((y,...b)=>er(t.hash,y,Ct(...b))),{Fp:s,Fn:i}=e,{ORDER:a,BITS:c}=i;function u(y){let b=a>>Nr;return y>b}function f(y){return u(y)?i.neg(y):y}function l(y,b){if(!i.isValidNot0(b))throw new Error(`invalid signature ${y}: out of range 1..CURVE.n`)}class m{constructor(b,A,I){l("r",b),l("s",A),this.r=b,this.s=A,I!=null&&(this.recovery=I),Object.freeze(this)}static fromCompact(b){let A=i.BYTES,I=J("compactSignature",b,A*2);return new m(i.fromBytes(I.subarray(0,A)),i.fromBytes(I.subarray(A,A*2)))}static fromDER(b){let{r:A,s:I}=re.toSig(J("DER",b));return new m(A,I)}assertValidity(){}addRecoveryBit(b){return new m(this.r,this.s,b)}recoverPublicKey(b){let A=s.ORDER,{r:I,s:v,recovery:L}=this;if(L==null||![0,1,2,3].includes(L))throw new Error("recovery id invalid");if(a*hh<A&&L>1)throw new Error("recovery id is ambiguous for h>1 curve");let U=L===2||L===3?I+a:I;if(!s.isValid(U))throw new Error("recovery id 2 or 3 invalid");let D=s.toBytes(U),M=e.fromHex(Ct(bc((L&1)===0),D)),R=i.inv(U),H=_(J("msgHash",b)),G=i.create(-H*R),Q=i.create(v*R),V=e.BASE.multiplyUnsafe(G).add(M.multiplyUnsafe(Q));if(V.is0())throw new Error("point at infinify");return V.assertValidity(),V}hasHighS(){return u(this.s)}normalizeS(){return this.hasHighS()?new m(this.r,i.neg(this.s),this.recovery):this}toBytes(b){if(b==="compact")return Ct(i.toBytes(this.r),i.toBytes(this.s));if(b==="der")return je(re.hexFromSig(this));throw new Error("invalid format")}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return Vt(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return Vt(this.toBytes("compact"))}}let p=xc(i,r.allowedPrivateKeyLengths,r.wrapPrivateKey),g={isValidPrivateKey(y){try{return p(y),!0}catch{return!1}},normPrivateKeyToScalar:p,randomPrivateKey:()=>{let y=a;return Oa(n(ts(y)),y)},precompute(y=8,b=e.BASE){return b.precompute(y,!1)}};function w(y,b=!0){return e.fromPrivateKey(y).toBytes(b)}function h(y){if(typeof y=="bigint")return!1;if(y instanceof e)return!0;let A=J("key",y).length,I=s.BYTES,v=I+1,L=2*I+1;if(!(r.allowedPrivateKeyLengths||i.BYTES===v))return A===v||A===L}function E(y,b,A=!0){if(h(y)===!0)throw new Error("first arg must be private key");if(h(b)===!1)throw new Error("second arg must be public key");return e.fromHex(b).multiply(p(y)).toBytes(A)}let B=t.bits2int||function(y){if(y.length>8192)throw new Error("input is too large");let b=$e(y),A=y.length*8-c;return A>0?b>>BigInt(A):b},_=t.bits2int_modN||function(y){return i.create(B(y))},K=Ie(c);function S(y){return Nt("num < 2^"+c,y,Rr,K),i.toBytes(y)}function k(y,b,A=C){if(["recovered","canonical"].some(Q=>Q in A))throw new Error("sign() legacy options not supported");let{hash:I}=t,{lowS:v,prehash:L,extraEntropy:P}=A;v==null&&(v=!0),y=J("msgHash",y),wc(A),L&&(y=J("prehashed msgHash",I(y)));let U=_(y),D=p(b),M=[S(D),S(U)];if(P!=null&&P!==!1){let Q=P===!0?n(s.BYTES):P;M.push(J("extraEntropy",Q))}let R=Ct(...M),H=U;function G(Q){let V=B(Q);if(!i.isValidNot0(V))return;let rt=i.inv(V),Lt=e.BASE.multiply(V).toAffine(),gt=i.create(Lt.x);if(gt===Rr)return;let pt=i.create(rt*i.create(H+gt*D));if(pt===Rr)return;let Ne=(Lt.x===gt?0:2)|Number(Lt.y&Nr),Zt=pt;return v&&u(pt)&&(Zt=f(pt),Ne^=1),new m(gt,Zt,Ne)}return{seed:R,k2sig:G}}let C={lowS:t.lowS,prehash:!1},T={lowS:t.lowS,prehash:!1};function d(y,b,A=C){let{seed:I,k2sig:v}=k(y,b,A);return Ta(t.hash.outputLen,i.BYTES,o)(I,v)}e.BASE.precompute(8);function x(y,b,A,I=T){let v=y;b=J("msgHash",b),A=J("publicKey",A),wc(I);let{lowS:L,prehash:P,format:U}=I;if("strict"in I)throw new Error("options.strict was renamed to lowS");if(U!==void 0&&!["compact","der","js"].includes(U))throw new Error('format must be "compact", "der" or "js"');let D=typeof v=="string"||Ge(v),M=!D&&!U&&typeof v=="object"&&v!==null&&typeof v.r=="bigint"&&typeof v.s=="bigint";if(!D&&!M)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let R,H;try{if(M)if(U===void 0||U==="js")R=new m(v.r,v.s);else throw new Error("invalid format");if(D){try{U!=="compact"&&(R=m.fromDER(v))}catch(Zt){if(!(Zt instanceof re.Err))throw Zt}!R&&U!=="der"&&(R=m.fromCompact(v))}H=e.fromHex(A)}catch{return!1}if(!R||L&&R.hasHighS())return!1;P&&(b=t.hash(b));let{r:G,s:Q}=R,V=_(b),rt=i.inv(Q),Lt=i.create(V*rt),gt=i.create(G*rt),pt=e.BASE.multiplyUnsafe(Lt).add(H.multiplyUnsafe(gt));return pt.is0()?!1:i.create(pt.x)===G}return Object.freeze({getPublicKey:w,getSharedSecret:E,sign:d,verify:x,utils:g,Point:e,Signature:m})}function gh(e){let t={a:e.a,b:e.b,p:e.Fp.ORDER,n:e.n,h:e.h,Gx:e.Gx,Gy:e.Gy},r=e.Fp,n=Mt(t.n,e.nBitLength),o={Fp:r,Fn:n,allowedPrivateKeyLengths:e.allowedPrivateKeyLengths,allowInfinityPoint:e.allowInfinityPoint,endo:e.endo,wrapPrivateKey:e.wrapPrivateKey,isTorsionFree:e.isTorsionFree,clearCofactor:e.clearCofactor,fromBytes:e.fromBytes,toBytes:e.toBytes};return{CURVE:t,curveOpts:o}}function wh(e){let{CURVE:t,curveOpts:r}=gh(e),n={hash:e.hash,hmac:e.hmac,randomBytes:e.randomBytes,lowS:e.lowS,bits2int:e.bits2int,bits2int_modN:e.bits2int_modN};return{CURVE:t,curveOpts:r,ecdsaOpts:n}}function xh(e,t){return Object.assign({},t,{ProjectivePoint:t.Point,CURVE:e})}function Ec(e){let{CURVE:t,curveOpts:r,ecdsaOpts:n}=wh(e),o=mh(t,r),s=yh(o,n,r);return xh(e,s)}function Sc(e,t){let r=n=>Ec({...e,hash:n});return{...r(t),create:r}}var Tn={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},Jy=BigInt(0),bh=BigInt(1),Ms=BigInt(2),Ac=(e,t)=>(e+t/Ms)/t;function Eh(e){let t=Tn.p,r=BigInt(3),n=BigInt(6),o=BigInt(11),s=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),u=e*e*e%t,f=u*u*e%t,l=et(f,r,t)*f%t,m=et(l,r,t)*f%t,p=et(m,Ms,t)*u%t,g=et(p,o,t)*p%t,w=et(g,s,t)*g%t,h=et(w,a,t)*w%t,E=et(h,c,t)*h%t,B=et(E,a,t)*w%t,_=et(B,r,t)*f%t,K=et(_,i,t)*g%t,S=et(K,n,t)*u%t,k=et(S,Ms,t);if(!Os.eql(Os.sqr(k),e))throw new Error("Cannot find square root");return k}var Os=Mt(Tn.p,void 0,void 0,{sqrt:Eh}),rr=Sc({...Tn,Fp:Os,lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:e=>{let t=Tn.n,r=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-bh*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),o=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=r,i=BigInt("0x100000000000000000000000000000000"),a=Ac(s*e,t),c=Ac(-n*e,t),u=tt(e-a*r-c*o,t),f=tt(-a*n-c*s,t),l=u>i,m=f>i;if(l&&(u=t-u),m&&(f=t-f),u>i||f>i)throw new Error("splitScalar: Endomorphism failed, k="+e);return{k1neg:l,k1:u,k2neg:m,k2:f}}}},dn);function vc(e,t,r,n){let o=gr.digest(r instanceof Uint8Array?r:r.subarray());if(Sn(o))return o.then(({digest:s})=>(n?.signal?.throwIfAborted(),rr.verify(t,s,e))).catch(s=>{throw s.name==="AbortError"?s:new Tr(String(s))});try{return n?.signal?.throwIfAborted(),rr.verify(t,o.digest,e)}catch(s){throw new Tr(String(s))}}var Cn=class{type="secp256k1";raw;_key;constructor(t){this._key=_c(t),this.raw=Ic(this._key)}toMultihash(){return Ut.digest(fe(this))}toCID(){return it.createV1(114,this.toMultihash())}toString(){return X.encode(this.toMultihash().bytes).substring(1)}equals(t){return t==null||!(t.raw instanceof Uint8Array)?!1:ft(this.raw,t.raw)}verify(t,r,n){return vc(this._key,r,t,n)}};function Hs(e){return new Cn(e)}function Ic(e){return rr.ProjectivePoint.fromHex(e).toRawBytes(!0)}function _c(e){try{return rr.ProjectivePoint.fromHex(e),e}catch(t){throw new Oe(String(t))}}function Mr(e,t){let{Type:r,Data:n}=$t.decode(e),o=n??new Uint8Array;switch(r){case at.RSA:return Us(o,t);case at.Ed25519:return as(o);case at.secp256k1:return Hs(o);case at.ECDSA:return Go(o);default:throw new ge}}function Bc(e){let{Type:t,Data:r}=$t.decode(e.digest),n=r??new Uint8Array;switch(t){case at.Ed25519:return as(n);case at.secp256k1:return Hs(n);case at.ECDSA:return Go(n);default:throw new ge}}function fe(e){return $t.encode({Type:at[e.type],Data:e.raw})}var Lc=Symbol.for("nodejs.util.inspect.custom"),Sh=114,Or=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()})`}[yo]=!0;toString(){return this.string==null&&(this.string=X.encode(this.multihash.bytes).slice(1)),this.string}toMultihash(){return this.multihash}toCID(){return it.createV1(Sh,this.multihash)}toJSON(){return this.toString()}equals(t){if(t==null)return!1;if(t instanceof Uint8Array)return ft(this.multihash.bytes,t);if(typeof t=="string")return this.toString()===t;if(t?.toMultihash()?.bytes!=null)return ft(this.multihash.bytes,t.toMultihash().bytes);throw new Error("not valid Id")}[Lc](){return`PeerId(${this.toString()})`}},Hr=class extends Or{type="RSA";publicKey;constructor(t){super({...t,type:"RSA"}),this.publicKey=t.publicKey}},qr=class extends Or{type="Ed25519";publicKey;constructor(t){super({...t,type:"Ed25519"}),this.publicKey=t.publicKey}},Vr=class extends Or{type="secp256k1";publicKey;constructor(t){super({...t,type:"secp256k1"}),this.publicKey=t.publicKey}},Ah=2336,zr=class{type="url";multihash;publicKey;url;constructor(t){this.url=t.toString(),this.multihash=Ut.digest(j(this.url))}[Lc](){return`PeerId(${this.url})`}[yo]=!0;toString(){return this.toCID().toString()}toMultihash(){return this.multihash}toCID(){return it.createV1(Ah,this.toMultihash())}toJSON(){return this.toString()}equals(t){return t==null?!1:(t instanceof Uint8Array&&(t=O(t)),t.toString()===this.toString())}};var vh=114,Tc=2336;function Cc(e,t){let r;if(e.charAt(0)==="1"||e.charAt(0)==="Q")r=ae(X.decode(`z${e}`));else{if(e.startsWith("k51qzi5uqu5")||e.startsWith("kzwfwjn5ji4")||e.startsWith("k2k4r8")||e.startsWith("bafz"))return Ih(it.parse(e));if(t==null)throw new ot('Please pass a multibase decoder for strings that do not start with "1" or "Q"');r=ae(t.decode(e))}return Pc(r)}function qs(e){if(e.type==="Ed25519")return new qr({multihash:e.toCID().multihash,publicKey:e});if(e.type==="secp256k1")return new Vr({multihash:e.toCID().multihash,publicKey:e});if(e.type==="RSA")return new Hr({multihash:e.toCID().multihash,publicKey:e});throw new ge}function Pc(e){if(Bh(e))return new Hr({multihash:e});if(_h(e))try{let t=Bc(e);if(t.type==="Ed25519")return new qr({multihash:e,publicKey:t});if(t.type==="secp256k1")return new Vr({multihash:e,publicKey:t})}catch{let r=O(e.digest);return new zr(new URL(r))}throw new nn("Supplied PeerID Multihash is invalid")}function Ih(e){if(e?.multihash==null||e.version==null||e.version===1&&e.code!==vh&&e.code!==Tc)throw new rn("Supplied PeerID CID is invalid");if(e.code===Tc){let t=O(e.multihash.digest);return new zr(new URL(t))}return Pc(e.multihash)}function _h(e){return e.code===Ut.code}function Bh(e){return e.code===gr.code}var Pn=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},nr=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},Dn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"},Fr=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function kn(e){return e[Symbol.asyncIterator]!=null}function Dc(e,t){if(e.byteLength>t)throw new nr("Message length too long")}var Kn=e=>{let t=ct(e),r=lt(t);return jt(e,r),Kn.bytes=t,r};Kn.bytes=0;function kc(e,t){t=t??{};let r=t.lengthEncoder??Kn,n=t?.maxDataLength??4194304;function*o(s){Dc(s,n);let i=r(s.byteLength);i instanceof Uint8Array?yield i:yield*i,s instanceof Uint8Array?yield s:yield*s}return kn(e)?async function*(){for await(let s of e)yield*o(s)}():function*(){for(let s of e)yield*o(s)}()}kc.single=(e,t)=>{t=t??{};let r=t.lengthEncoder??Kn,n=t?.maxDataLength??4194304;return Dc(e,n),new F(r(e.byteLength),e)};var ke;(function(e){e[e.LENGTH=0]="LENGTH",e[e.DATA=1]="DATA"})(ke||(ke={}));var Vs=e=>{let t=Ot(e);return Vs.bytes=ct(t),t};Vs.bytes=0;function Gr(e,t){let r=new F,n=ke.LENGTH,o=-1,s=t?.lengthDecoder??Vs,i=t?.maxLengthLength??8,a=t?.maxDataLength??4194304;function*c(){for(;r.byteLength>0;){if(n===ke.LENGTH)try{if(o=s(r),o<0)throw new Pn("Invalid message length");if(o>a)throw new nr("Message length too long");let u=s.bytes;r.consume(u),t?.onLength!=null&&t.onLength(o),n=ke.DATA}catch(u){if(u instanceof RangeError){if(r.byteLength>i)throw new Dn("Message length length too long");break}throw u}if(n===ke.DATA){if(r.byteLength<o)break;let u=r.sublist(0,o);r.consume(o),t?.onData!=null&&t.onData(u),yield u,n=ke.LENGTH}}}return kn(e)?async function*(){for await(let u of e)r.append(u),yield*c();if(r.byteLength>0)throw new Fr("Unexpected end of input")}():function*(){for(let u of e)r.append(u),yield*c();if(r.byteLength>0)throw new Fr("Unexpected end of input")}()}Gr.fromReader=(e,t)=>{let r=1,n=async function*(){for(;;)try{let{done:s,value:i}=await e.next(r);if(s===!0)return;i!=null&&(yield i)}catch(s){if(s.code==="ERR_UNDER_READ")return{done:!0,value:null};throw s}finally{r=1}}();return Gr(n,{...t??{},onLength:s=>{r=s}})};function Bt(){let e={};return e.promise=new Promise((t,r)=>{e.resolve=t,e.reject=r}),e}var Rn=class extends Error{type;code;constructor(t,r,n){super(t??"The operation was aborted"),this.type="aborted",this.name=n??"AbortError",this.code=r??"ABORT_ERR"}};async function dt(e,t,r){if(t==null)return e;if(t.aborted)return e.catch(()=>{}),Promise.reject(new Rn(r?.errorMessage,r?.errorCode,r?.errorName));let n,o=new Rn(r?.errorMessage,r?.errorCode,r?.errorName);try{return await Promise.race([e,new Promise((s,i)=>{n=()=>{i(o)},t.addEventListener("abort",n)})])}finally{n!=null&&t.removeEventListener("abort",n)}}var zs=class{readNext;haveNext;ended;nextResult;error;constructor(){this.ended=!1,this.readNext=Bt(),this.haveNext=Bt()}[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=Bt(),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,r){await this._push(t,r)}async end(t,r){t!=null?await this.throw(t):await this._push(void 0,r)}async _push(t,r){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=Bt(),await dt(this.readNext.promise,r?.signal,r)}};function Nn(){return new zs}var Mn=class extends Error{name="UnexpectedEOFError";code="ERR_UNEXPECTED_EOF"};function Uc(e,t){let r=Nn();e.sink(r).catch(async i=>{await r.end(i)}),e.sink=async i=>{for await(let a of i)await r.push(a);await r.end()};let n=e.source;e.source[Symbol.iterator]!=null?n=e.source[Symbol.iterator]():e.source[Symbol.asyncIterator]!=null&&(n=e.source[Symbol.asyncIterator]());let o=new F;return{read:async i=>{if(i?.signal?.throwIfAborted(),i?.bytes==null){let{done:c,value:u}=await dt(n.next(),i?.signal);return c===!0?null:u}for(;o.byteLength<i.bytes;){let{value:c,done:u}=await dt(n.next(),i?.signal);if(u===!0)throw new Mn("unexpected end of input");o.append(c)}let a=o.sublist(0,i.bytes);return o.consume(i.bytes),a},write:async(i,a)=>{a?.signal?.throwIfAborted(),i instanceof Uint8Array?await r.push(i,a):await r.push(i.subarray(),a)},unwrap:()=>{if(o.byteLength>0){let i=e.source;e.source=async function*(){t?.yieldBytes===!1?yield o:yield*o,yield*i}()}return e}}}var On=class extends Error{name="InvalidMessageLengthError";code="ERR_INVALID_MSG_LENGTH"},Hn=class extends Error{name="InvalidDataLengthError";code="ERR_MSG_DATA_TOO_LONG"},qn=class extends Error{name="InvalidDataLengthLengthError";code="ERR_MSG_LENGTH_TOO_LONG"};function Fs(e,t={}){let r=Uc(e,t);t.maxDataLength!=null&&t.maxLengthLength==null&&(t.maxLengthLength=ct(t.maxDataLength));let n=t?.lengthDecoder??Ot,o=t?.lengthEncoder??jt;return{read:async i=>{let a=-1,c=new F;for(;;){c.append(await r.read({...i,bytes:1}));try{a=n(c)}catch(u){if(u instanceof RangeError)continue;throw u}if(a<0)throw new On("Invalid message length");if(t?.maxLengthLength!=null&&c.byteLength>t.maxLengthLength)throw new qn("message length length too long");if(a>-1)break}if(t?.maxDataLength!=null&&a>t.maxDataLength)throw new Hn("message length too long");return r.read({...i,bytes:a})},write:async(i,a)=>{await r.write(new F(o(i.byteLength),i),a)},writeV:async(i,a)=>{let c=new F(...i.flatMap(u=>[o(u.byteLength),u]));await r.write(c,a)},unwrap:()=>r.unwrap()}}function Gs(){let e=Bt(),t=!1;return{sink:async r=>{if(t)throw new Error("already piped");t=!0,e.resolve(r)},source:async function*(){yield*await e.promise}()}}function Kc(){let e=Gs(),t=Gs();return[{source:e.source,sink:t.sink},{source:t.source,sink:e.sink}]}var Vn=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}},or=class{size;hwm;head;tail;constructor(t={}){this.hwm=t.splitLimit??16,this.head=new Vn(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 r=this.head;this.head=r.next=new Vn(2*this.head.buffer.length),this.head.push(t)}}shift(){let t=this.tail.shift();if(t===void 0&&this.tail.next!=null){let r=this.tail.next;this.tail.next=null,this.tail=r,t=this.tail.shift()}return t?.value!=null&&(this.size-=this.calculateSize(t.value)),t}isEmpty(){return this.head.isEmpty()}};var Ws=class extends Error{type;code;constructor(t,r){super(t??"The operation was aborted"),this.type="aborted",this.code=r??"ABORT_ERR"}};function zn(e={}){return Th(r=>{let n=r.shift();if(n==null)return{done:!0};if(n.error!=null)throw n.error;return{done:n.done===!0,value:n.value}},e)}function Th(e,t){t=t??{};let r=t.onEnd,n=new or,o,s,i,a=Bt(),c=async()=>{try{return n.isEmpty()?i?{done:!0}:await new Promise((h,E)=>{s=B=>{s=null,n.push(B);try{h(e(n))}catch(_){E(_)}return o}}):e(n)}finally{n.isEmpty()&&queueMicrotask(()=>{a.resolve(),a=Bt()})}},u=h=>s!=null?s(h):(n.push(h),o),f=h=>(n=new or,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 u({done:!1,value:h})},m=h=>i?o:(i=!0,h!=null?f(h):u({done:!0})),p=()=>(n=new or,m(),{done:!0}),g=h=>(m(h),{done:!0});if(o={[Symbol.asyncIterator](){return this},next:c,return:p,throw:g,push:l,end:m,get readableLength(){return n.size},onEmpty:async h=>{let E=h?.signal;if(E?.throwIfAborted(),n.isEmpty())return;let B,_;E!=null&&(B=new Promise((K,S)=>{_=()=>{S(new Ws)},E.addEventListener("abort",_)}));try{await Promise.race([a.promise,B])}finally{_!=null&&E!=null&&E?.removeEventListener("abort",_)}}},r==null)return o;let w=o;return o={[Symbol.asyncIterator](){return this},next(){return w.next()},throw(h){return w.throw(h),r!=null&&(r(h),r=void 0),{done:!0}},return(){return w.return(),r!=null&&(r(),r=void 0),{done:!0}},push:l,end(h){return w.end(h),r!=null&&(r(h),r=void 0),o},get readableLength(){return w.readableLength},onEmpty:h=>w.onEmpty(h)},o}function Ch(e){return e[Symbol.asyncIterator]!=null}async function Ph(e,t,r){try{await Promise.all(e.map(async n=>{for await(let o of n)await t.push(o,{signal:r}),r.throwIfAborted()})),await t.end(void 0,{signal:r})}catch(n){await t.end(n,{signal:r}).catch(()=>{})}}async function*Dh(e){let t=new AbortController,r=Nn();Ph(e,r,t.signal).catch(()=>{});try{yield*r}finally{t.abort()}}function*kh(e){for(let t of e)yield*t}function Uh(...e){let t=[];for(let r of e)Ch(r)||t.push(r);return t.length===e.length?kh(t):Dh(e)}var Rc=Uh;function Nc(e,...t){if(e==null)throw new Error("Empty pipeline");if(js(e)){let n=e;e=()=>n.source}else if(Oc(e)||Mc(e)){let n=e;e=()=>n}let r=[e,...t];if(r.length>1&&js(r[r.length-1])&&(r[r.length-1]=r[r.length-1].sink),r.length>2)for(let n=1;n<r.length-1;n++)js(r[n])&&(r[n]=Rh(r[n]));return Kh(...r)}var Kh=(...e)=>{let t;for(;e.length>0;)t=e.shift()(t);return t},Mc=e=>e?.[Symbol.asyncIterator]!=null,Oc=e=>e?.[Symbol.iterator]!=null,js=e=>e==null?!1:e.sink!=null&&e.source!=null,Rh=e=>t=>{let r=e.sink(t);if(r?.then!=null){let n=zn({objectMode:!0});r.then(()=>{n.end()},i=>{n.end(i)});let o,s=e.source;if(Mc(s))o=async function*(){yield*s,n.end()};else if(Oc(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 e.source};var sr=!!globalThis.process?.env?.DUMP_SESSION_KEYS;function qc(e){return e instanceof Uint8Array||ArrayBuffer.isView(e)&&e.constructor.name==="Uint8Array"}function Fn(e){if(typeof e!="boolean")throw new Error(`boolean expected, not ${e}`)}function Gn(e){if(!Number.isSafeInteger(e)||e<0)throw new Error("positive integer expected, got "+e)}function St(e,...t){if(!qc(e))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(e.length))throw new Error("Uint8Array expected of length "+t+", got length="+e.length)}function $s(e,t=!0){if(e.destroyed)throw new Error("Hash instance has been destroyed");if(t&&e.finished)throw new Error("Hash#digest() has already been called")}function Vc(e,t){St(e);let r=t.outputLen;if(e.length<r)throw new Error("digestInto() expects output buffer of length at least "+r)}function ne(e){return new Uint32Array(e.buffer,e.byteOffset,Math.floor(e.byteLength/4))}function oe(...e){for(let t=0;t<e.length;t++)e[t].fill(0)}function Nh(e){return new DataView(e.buffer,e.byteOffset,e.byteLength)}var Mh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Oh(e){if(typeof e!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(e))}function Wn(e){if(typeof e=="string")e=Oh(e);else if(qc(e))e=jn(e);else throw new Error("Uint8Array expected, got "+typeof e);return e}function zc(e,t){if(t==null||typeof t!="object")throw new Error("options must be defined");return Object.assign(e,t)}function Fc(e,t){if(e.length!==t.length)return!1;let r=0;for(let n=0;n<e.length;n++)r|=e[n]^t[n];return r===0}var Zs=(e,t)=>{function r(n,...o){if(St(n),!Mh)throw new Error("Non little-endian hardware is not yet supported");if(e.nonceLength!==void 0){let f=o[0];if(!f)throw new Error("nonce / iv required");e.varSizeNonce?St(f):St(f,e.nonceLength)}let s=e.tagLength;s&&o[1]!==void 0&&St(o[1]);let i=t(n,...o),a=(f,l)=>{if(l!==void 0){if(f!==2)throw new Error("cipher output not supported");St(l)}},c=!1;return{encrypt(f,l){if(c)throw new Error("cannot encrypt() twice with same key + nonce");return c=!0,St(f),a(i.encrypt.length,l),i.encrypt(f,l)},decrypt(f,l){if(St(f),s&&f.length<s)throw new Error("invalid ciphertext length: smaller than tagLength="+s);return a(i.decrypt.length,l),i.decrypt(f,l)}}}return Object.assign(r,e),r};function Ys(e,t,r=!0){if(t===void 0)return new Uint8Array(e);if(t.length!==e)throw new Error("invalid output length, expected "+e+", got: "+t.length);if(r&&!Hh(t))throw new Error("invalid output, must be aligned");return t}function Hc(e,t,r,n){if(typeof e.setBigUint64=="function")return e.setBigUint64(t,r,n);let o=BigInt(32),s=BigInt(4294967295),i=Number(r>>o&s),a=Number(r&s),c=n?4:0,u=n?0:4;e.setUint32(t+c,i,n),e.setUint32(t+u,a,n)}function Gc(e,t,r){Fn(r);let n=new Uint8Array(16),o=Nh(n);return Hc(o,0,BigInt(t),r),Hc(o,8,BigInt(e),r),n}function Hh(e){return e.byteOffset%4===0}function jn(e){return Uint8Array.from(e)}var jc=e=>Uint8Array.from(e.split("").map(t=>t.charCodeAt(0))),qh=jc("expand 16-byte k"),Vh=jc("expand 32-byte k"),zh=ne(qh),Fh=ne(Vh);function N(e,t){return e<<t|e>>>32-t}function Xs(e){return e.byteOffset%4===0}var $n=64,Gh=16,$c=2**32-1,Wc=new Uint32Array;function Wh(e,t,r,n,o,s,i,a){let c=o.length,u=new Uint8Array($n),f=ne(u),l=Xs(o)&&Xs(s),m=l?ne(o):Wc,p=l?ne(s):Wc;for(let g=0;g<c;i++){if(e(t,r,n,f,i,a),i>=$c)throw new Error("arx: counter overflow");let w=Math.min($n,c-g);if(l&&w===$n){let h=g/4;if(g%4!==0)throw new Error("arx: invalid block position");for(let E=0,B;E<Gh;E++)B=h+E,p[B]=m[B]^f[E];g+=$n;continue}for(let h=0,E;h<w;h++)E=g+h,s[E]=o[E]^u[h];g+=w}}function Js(e,t){let{allowShortKeys:r,extendNonceFn:n,counterLength:o,counterRight:s,rounds:i}=zc({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},t);if(typeof e!="function")throw new Error("core must be a function");return Gn(o),Gn(i),Fn(s),Fn(r),(a,c,u,f,l=0)=>{St(a),St(c),St(u);let m=u.length;if(f===void 0&&(f=new Uint8Array(m)),St(f),Gn(l),l<0||l>=$c)throw new Error("arx: counter overflow");if(f.length<m)throw new Error(`arx: output (${f.length}) is shorter than data (${m})`);let p=[],g=a.length,w,h;if(g===32)p.push(w=jn(a)),h=Fh;else if(g===16&&r)w=new Uint8Array(32),w.set(a),w.set(a,16),h=zh,p.push(w);else throw new Error(`arx: invalid 32-byte key, got length=${g}`);Xs(c)||p.push(c=jn(c));let E=ne(w);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(h,E,ne(c.subarray(0,16)),E),c=c.subarray(16)}let B=16-o;if(B!==c.length)throw new Error(`arx: nonce must be ${B} or 16 bytes`);if(B!==12){let K=new Uint8Array(12);K.set(c,s?0:12-c.length),c=K,p.push(c)}let _=ne(c);return Wh(e,h,E,_,u,f,l,i),oe(...p),f}}var yt=(e,t)=>e[t++]&255|(e[t++]&255)<<8,Qs=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=Wn(t),St(t,32);let r=yt(t,0),n=yt(t,2),o=yt(t,4),s=yt(t,6),i=yt(t,8),a=yt(t,10),c=yt(t,12),u=yt(t,14);this.r[0]=r&8191,this.r[1]=(r>>>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|u<<8)&8191,this.r[9]=u>>>5&127;for(let f=0;f<8;f++)this.pad[f]=yt(t,16+2*f)}process(t,r,n=!1){let o=n?0:2048,{h:s,r:i}=this,a=i[0],c=i[1],u=i[2],f=i[3],l=i[4],m=i[5],p=i[6],g=i[7],w=i[8],h=i[9],E=yt(t,r+0),B=yt(t,r+2),_=yt(t,r+4),K=yt(t,r+6),S=yt(t,r+8),k=yt(t,r+10),C=yt(t,r+12),T=yt(t,r+14),d=s[0]+(E&8191),x=s[1]+((E>>>13|B<<3)&8191),y=s[2]+((B>>>10|_<<6)&8191),b=s[3]+((_>>>7|K<<9)&8191),A=s[4]+((K>>>4|S<<12)&8191),I=s[5]+(S>>>1&8191),v=s[6]+((S>>>14|k<<2)&8191),L=s[7]+((k>>>11|C<<5)&8191),P=s[8]+((C>>>8|T<<8)&8191),U=s[9]+(T>>>5|o),D=0,M=D+d*a+x*(5*h)+y*(5*w)+b*(5*g)+A*(5*p);D=M>>>13,M&=8191,M+=I*(5*m)+v*(5*l)+L*(5*f)+P*(5*u)+U*(5*c),D+=M>>>13,M&=8191;let R=D+d*c+x*a+y*(5*h)+b*(5*w)+A*(5*g);D=R>>>13,R&=8191,R+=I*(5*p)+v*(5*m)+L*(5*l)+P*(5*f)+U*(5*u),D+=R>>>13,R&=8191;let H=D+d*u+x*c+y*a+b*(5*h)+A*(5*w);D=H>>>13,H&=8191,H+=I*(5*g)+v*(5*p)+L*(5*m)+P*(5*l)+U*(5*f),D+=H>>>13,H&=8191;let G=D+d*f+x*u+y*c+b*a+A*(5*h);D=G>>>13,G&=8191,G+=I*(5*w)+v*(5*g)+L*(5*p)+P*(5*m)+U*(5*l),D+=G>>>13,G&=8191;let Q=D+d*l+x*f+y*u+b*c+A*a;D=Q>>>13,Q&=8191,Q+=I*(5*h)+v*(5*w)+L*(5*g)+P*(5*p)+U*(5*m),D+=Q>>>13,Q&=8191;let V=D+d*m+x*l+y*f+b*u+A*c;D=V>>>13,V&=8191,V+=I*a+v*(5*h)+L*(5*w)+P*(5*g)+U*(5*p),D+=V>>>13,V&=8191;let rt=D+d*p+x*m+y*l+b*f+A*u;D=rt>>>13,rt&=8191,rt+=I*c+v*a+L*(5*h)+P*(5*w)+U*(5*g),D+=rt>>>13,rt&=8191;let Lt=D+d*g+x*p+y*m+b*l+A*f;D=Lt>>>13,Lt&=8191,Lt+=I*u+v*c+L*a+P*(5*h)+U*(5*w),D+=Lt>>>13,Lt&=8191;let gt=D+d*w+x*g+y*p+b*m+A*l;D=gt>>>13,gt&=8191,gt+=I*f+v*u+L*c+P*a+U*(5*h),D+=gt>>>13,gt&=8191;let pt=D+d*h+x*w+y*g+b*p+A*m;D=pt>>>13,pt&=8191,pt+=I*l+v*f+L*u+P*c+U*a,D+=pt>>>13,pt&=8191,D=(D<<2)+D|0,D=D+M|0,M=D&8191,D=D>>>13,R+=D,s[0]=M,s[1]=R,s[2]=H,s[3]=G,s[4]=Q,s[5]=V,s[6]=rt,s[7]=Lt,s[8]=gt,s[9]=pt}finalize(){let{h:t,pad:r}=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]+r[0];t[0]=i&65535;for(let a=1;a<8;a++)i=(t[a]+r[a]|0)+(i>>>16)|0,t[a]=i&65535;oe(n)}update(t){$s(this),t=Wn(t),St(t);let{buffer:r,blockLen:n}=this,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}r.set(t.subarray(s,s+i),this.pos),this.pos+=i,s+=i,this.pos===n&&(this.process(r,0,!1),this.pos=0)}return this}destroy(){oe(this.h,this.r,this.buffer,this.pad)}digestInto(t){$s(this),Vc(t,this),this.finished=!0;let{buffer:r,h:n}=this,{pos:o}=this;if(o){for(r[o++]=1;o<16;o++)r[o]=0;this.process(r,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:r}=this;this.digestInto(t);let n=t.slice(0,r);return this.destroy(),n}};function jh(e){let t=(n,o)=>e(o).update(Wn(n)).digest(),r=e(new Uint8Array(32));return t.outputLen=r.outputLen,t.blockLen=r.blockLen,t.create=n=>e(n),t}var Zc=jh(e=>new Qs(e));function Jc(e,t,r,n,o,s=20){let i=e[0],a=e[1],c=e[2],u=e[3],f=t[0],l=t[1],m=t[2],p=t[3],g=t[4],w=t[5],h=t[6],E=t[7],B=o,_=r[0],K=r[1],S=r[2],k=i,C=a,T=c,d=u,x=f,y=l,b=m,A=p,I=g,v=w,L=h,P=E,U=B,D=_,M=K,R=S;for(let G=0;G<s;G+=2)k=k+x|0,U=N(U^k,16),I=I+U|0,x=N(x^I,12),k=k+x|0,U=N(U^k,8),I=I+U|0,x=N(x^I,7),C=C+y|0,D=N(D^C,16),v=v+D|0,y=N(y^v,12),C=C+y|0,D=N(D^C,8),v=v+D|0,y=N(y^v,7),T=T+b|0,M=N(M^T,16),L=L+M|0,b=N(b^L,12),T=T+b|0,M=N(M^T,8),L=L+M|0,b=N(b^L,7),d=d+A|0,R=N(R^d,16),P=P+R|0,A=N(A^P,12),d=d+A|0,R=N(R^d,8),P=P+R|0,A=N(A^P,7),k=k+y|0,R=N(R^k,16),L=L+R|0,y=N(y^L,12),k=k+y|0,R=N(R^k,8),L=L+R|0,y=N(y^L,7),C=C+b|0,U=N(U^C,16),P=P+U|0,b=N(b^P,12),C=C+b|0,U=N(U^C,8),P=P+U|0,b=N(b^P,7),T=T+A|0,D=N(D^T,16),I=I+D|0,A=N(A^I,12),T=T+A|0,D=N(D^T,8),I=I+D|0,A=N(A^I,7),d=d+x|0,M=N(M^d,16),v=v+M|0,x=N(x^v,12),d=d+x|0,M=N(M^d,8),v=v+M|0,x=N(x^v,7);let H=0;n[H++]=i+k|0,n[H++]=a+C|0,n[H++]=c+T|0,n[H++]=u+d|0,n[H++]=f+x|0,n[H++]=l+y|0,n[H++]=m+b|0,n[H++]=p+A|0,n[H++]=g+I|0,n[H++]=w+v|0,n[H++]=h+L|0,n[H++]=E+P|0,n[H++]=B+U|0,n[H++]=_+D|0,n[H++]=K+M|0,n[H++]=S+R|0}function $h(e,t,r,n){let o=e[0],s=e[1],i=e[2],a=e[3],c=t[0],u=t[1],f=t[2],l=t[3],m=t[4],p=t[5],g=t[6],w=t[7],h=r[0],E=r[1],B=r[2],_=r[3];for(let S=0;S<20;S+=2)o=o+c|0,h=N(h^o,16),m=m+h|0,c=N(c^m,12),o=o+c|0,h=N(h^o,8),m=m+h|0,c=N(c^m,7),s=s+u|0,E=N(E^s,16),p=p+E|0,u=N(u^p,12),s=s+u|0,E=N(E^s,8),p=p+E|0,u=N(u^p,7),i=i+f|0,B=N(B^i,16),g=g+B|0,f=N(f^g,12),i=i+f|0,B=N(B^i,8),g=g+B|0,f=N(f^g,7),a=a+l|0,_=N(_^a,16),w=w+_|0,l=N(l^w,12),a=a+l|0,_=N(_^a,8),w=w+_|0,l=N(l^w,7),o=o+u|0,_=N(_^o,16),g=g+_|0,u=N(u^g,12),o=o+u|0,_=N(_^o,8),g=g+_|0,u=N(u^g,7),s=s+f|0,h=N(h^s,16),w=w+h|0,f=N(f^w,12),s=s+f|0,h=N(h^s,8),w=w+h|0,f=N(f^w,7),i=i+l|0,E=N(E^i,16),m=m+E|0,l=N(l^m,12),i=i+l|0,E=N(E^i,8),m=m+E|0,l=N(l^m,7),a=a+c|0,B=N(B^a,16),p=p+B|0,c=N(c^p,12),a=a+c|0,B=N(B^a,8),p=p+B|0,c=N(c^p,7);let K=0;n[K++]=o,n[K++]=s,n[K++]=i,n[K++]=a,n[K++]=h,n[K++]=E,n[K++]=B,n[K++]=_}var Zh=Js(Jc,{counterRight:!1,counterLength:4,allowShortKeys:!1}),Yh=Js(Jc,{counterRight:!1,counterLength:8,extendNonceFn:$h,allowShortKeys:!1});var Xh=new Uint8Array(16),Yc=(e,t)=>{e.update(t);let r=t.length%16;r&&e.update(Xh.subarray(r))},Jh=new Uint8Array(32);function Xc(e,t,r,n,o){let s=e(t,r,Jh),i=Zc.create(s);o&&Yc(i,o),Yc(i,n);let a=Gc(n.length,o?o.length:0,!0);i.update(a);let c=i.digest();return oe(s,a),c}var Qc=e=>(t,r,n)=>({encrypt(s,i){let a=s.length;i=Ys(a+16,i,!1),i.set(s);let c=i.subarray(0,-16);e(t,r,c,c,1);let u=Xc(e,t,r,c,n);return i.set(u,a),oe(u),i},decrypt(s,i){i=Ys(s.length-16,i,!1);let a=s.subarray(0,-16),c=s.subarray(-16),u=Xc(e,t,r,a,n);if(!Fc(c,u))throw new Error("invalid tag");return i.set(s.subarray(0,-16)),e(t,r,i,i,1),oe(u),i}}),ti=Zs({blockSize:64,nonceLength:12,tagLength:16},Qc(Zh)),rx=Zs({blockSize:64,nonceLength:24,tagLength:16},Qc(Yh));function ef(e,t,r){return br(e),r===void 0&&(r=new Uint8Array(e.outputLen)),er(e,ue(r),ue(t))}var ei=Uint8Array.from([0]),tf=Uint8Array.of();function rf(e,t,r,n=32){br(e),Ee(n);let o=e.outputLen;if(n>255*o)throw new Error("Length should be <= 255*HashLen");let s=Math.ceil(n/o);r===void 0&&(r=tf);let i=new Uint8Array(s*o),a=er.create(e,t),c=a._cloneInto(),u=new Uint8Array(a.outputLen);for(let f=0;f<s;f++)ei[0]=f+1,c.update(f===0?tf:u).update(r).update(ei).digestInto(u),i.set(u,o*f),a._cloneInto(c);return a.destroy(),c.destroy(),Kt(u,ei),i.slice(0,n)}var ri={hashSHA256(e){return ye(e.subarray())},getHKDF(e,t){let r=ef(ye,t,e),o=rf(ye,r,void 0,96),s=o.subarray(0,32),i=o.subarray(32,64),a=o.subarray(64,96);return[s,i,a]},generateX25519KeyPair(){let e=Lr.utils.randomPrivateKey();return{publicKey:Lr.getPublicKey(e),privateKey:e}},generateX25519KeyPairFromSeed(e){return{publicKey:Lr.getPublicKey(e),privateKey:e}},generateX25519SharedKey(e,t){return Lr.getSharedSecret(e.subarray(),t.subarray())},chaCha20Poly1305Encrypt(e,t,r,n){return ti(n,t,r).encrypt(e.subarray())},chaCha20Poly1305Decrypt(e,t,r,n,o){return ti(n,t,r).decrypt(e.subarray(),o)}};var nf=ri;function of(e){return{generateKeypair:e.generateX25519KeyPair,dh:(t,r)=>e.generateX25519SharedKey(t.privateKey,r).subarray(0,32),encrypt:e.chaCha20Poly1305Encrypt,decrypt:e.chaCha20Poly1305Decrypt,hash:e.hashSHA256,hkdf:e.getHKDF}}var ir=e=>{let t=lt(2);return t[0]=e>>8,t[1]=e,t};ir.bytes=2;var Wr=e=>{if(e.length<2)throw RangeError("Could not decode int16BE");if(e instanceof Uint8Array){let t=0;return t+=e[0]<<8,t+=e[1],t}return e.getUint16(0)};Wr.bytes=2;function sf(e){return{xxHandshakeSuccesses:e.registerCounter("libp2p_noise_xxhandshake_successes_total",{help:"Total count of noise xxHandshakes successes_"}),xxHandshakeErrors:e.registerCounter("libp2p_noise_xxhandshake_error_total",{help:"Total count of noise xxHandshakes errors"}),encryptedPackets:e.registerCounter("libp2p_noise_encrypted_packets_total",{help:"Total count of noise encrypted packets successfully"}),decryptedPackets:e.registerCounter("libp2p_noise_decrypted_packets_total",{help:"Total count of noise decrypted packets"}),decryptErrors:e.registerCounter("libp2p_noise_decrypt_errors_total",{help:"Total count of noise decrypt errors"})}}function ni(e,t){!t.enabled||!sr||(e?(t(`LOCAL_STATIC_PUBLIC_KEY ${O(e.publicKey,"hex")}`),t(`LOCAL_STATIC_PRIVATE_KEY ${O(e.privateKey,"hex")}`)):t("Missing local static keys."))}function oi(e,t){!t.enabled||!sr||(e?(t(`LOCAL_PUBLIC_EPHEMERAL_KEY ${O(e.publicKey,"hex")}`),t(`LOCAL_PRIVATE_EPHEMERAL_KEY ${O(e.privateKey,"hex")}`)):t("Missing local ephemeral keys."))}function af(e,t){!t.enabled||!sr||t(e?`REMOTE_STATIC_PUBLIC_KEY ${O(e.subarray(),"hex")}`:"Missing remote static public key.")}function si(e,t){!t.enabled||!sr||t(e?`REMOTE_EPHEMERAL_PUBLIC_KEY ${O(e.subarray(),"hex")}`:"Missing remote ephemeral keys.")}function ii(e,t,r){!r.enabled||!sr||(r(`CIPHER_STATE_1 ${e.n.getUint64()} ${e.k&&O(e.k,"hex")}`),r(`CIPHER_STATE_2 ${t.n.getUint64()} ${t.k&&O(t.k,"hex")}`))}var ar=class e extends Error{code;constructor(t="Invalid crypto exchange"){super(t),this.code=e.code}static code="ERR_INVALID_CRYPTO_EXCHANGE"};var Qh=0,td=4294967295,ed="Cipherstate has reached maximum n, a new handshake must be performed",Zn=class{n;bytes;view;constructor(t=Qh){this.n=t,this.bytes=ut(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 Ue=ut(0),cr=class{k;n;crypto;constructor(t,r=void 0,n=0){this.crypto=t,this.k=r,this.n=new Zn(n)}hasKey(){return!!this.k}encryptWithAd(t,r){if(!this.hasKey())return r;this.n.assertValue();let n=this.crypto.encrypt(r,this.n.getBytes(),t,this.k);return this.n.increment(),n}decryptWithAd(t,r,n){if(!this.hasKey())return r;this.n.assertValue();let o=this.crypto.decrypt(r,this.n.getBytes(),t,this.k,n);return this.n.increment(),o}},ai=class{cs;ck;h;crypto;constructor(t,r){this.crypto=t;let n=j(r,"utf-8");this.h=rd(t,n),this.ck=this.h,this.cs=new cr(t)}mixKey(t){let[r,n]=this.crypto.hkdf(this.ck,t);this.ck=r,this.cs=new cr(this.crypto,n)}mixHash(t){this.h=this.crypto.hash(new F(this.h,t))}encryptAndHash(t){let r=this.cs.encryptWithAd(this.h,t);return this.mixHash(r),r}decryptAndHash(t){let r=this.cs.decryptWithAd(this.h,t);return this.mixHash(t),r}split(){let[t,r]=this.crypto.hkdf(this.ck,Ue);return[new cr(this.crypto,t),new cr(this.crypto,r)]}},ci=class{ss;s;e;rs;re;initiator;crypto;constructor(t){let{crypto:r,protocolName:n,prologue:o,initiator:s,s:i,e:a,rs:c,re:u}=t;this.crypto=r,this.ss=new ai(r,n),this.ss.mixHash(o),this.initiator=s,this.s=i,this.e=a,this.rs=c,this.re=u}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,r=0){if(this.re)throw new Error("remote ephemeral public key is already set");if(t.byteLength<r+32)throw new Error("message is not long enough");this.re=t.sublist(r,r+32),this.ss.mixHash(this.re)}readS(t,r=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<r+n)throw new Error("message is not long enough");let o=t.sublist(r,r+n);return this.rs=this.ss.decryptAndHash(o),n}readEE(){this.writeEE()}readES(){this.writeES()}readSE(){this.writeSE()}},jr=class extends ci{writeMessageA(t){return new F(this.writeE(),this.ss.encryptAndHash(t))}writeMessageB(t){let r=this.writeE();this.writeEE();let n=this.writeS();return this.writeES(),new F(r,n,this.ss.encryptAndHash(t))}writeMessageC(t){let r=this.writeS();return this.writeSE(),new F(r,this.ss.encryptAndHash(t))}readMessageA(t){try{return this.readE(t),this.ss.decryptAndHash(t.sublist(32))}catch(r){throw new ar(`handshake stage 0 validation fail: ${r.message}`)}}readMessageB(t){try{this.readE(t),this.readEE();let r=this.readS(t,32);return this.readES(),this.ss.decryptAndHash(t.sublist(32+r))}catch(r){throw new ar(`handshake stage 1 validation fail: ${r.message}`)}}readMessageC(t){try{let r=this.readS(t);return this.readSE(),this.ss.decryptAndHash(t.sublist(r))}catch(r){throw new ar(`handshake stage 2 validation fail: ${r.message}`)}}};function rd(e,t){if(t.length<=32){let r=ut(32);return r.set(t),r}else return e.hash(t)}var Yn;(function(e){let t;e.codec=()=>(t==null&&(t=De((r,n,o={})=>{if(o.lengthDelimited!==!1&&n.fork(),r.webtransportCerthashes!=null)for(let s of r.webtransportCerthashes)n.uint32(10),n.bytes(s);if(r.streamMuxers!=null)for(let s of r.streamMuxers)n.uint32(18),n.string(s);o.lengthDelimited!==!1&&n.ldelim()},(r,n,o={})=>{let s={webtransportCerthashes:[],streamMuxers:[]},i=n==null?r.len:r.pos+n;for(;r.pos<i;){let a=r.uint32();switch(a>>>3){case 1:{if(o.limits?.webtransportCerthashes!=null&&s.webtransportCerthashes.length===o.limits.webtransportCerthashes)throw new kr('Decode error - map field "webtransportCerthashes" had too many elements');s.webtransportCerthashes.push(r.bytes());break}case 2:{if(o.limits?.streamMuxers!=null&&s.streamMuxers.length===o.limits.streamMuxers)throw new kr('Decode error - map field "streamMuxers" had too many elements');s.streamMuxers.push(r.string());break}default:{r.skipType(a&7);break}}}return s})),t),e.encode=r=>Pe(r,e.codec()),e.decode=(r,n)=>Te(r,e.codec(),n)})(Yn||(Yn={}));var $r;(function(e){let t;e.codec=()=>(t==null&&(t=De((r,n,o={})=>{o.lengthDelimited!==!1&&n.fork(),r.identityKey!=null&&r.identityKey.byteLength>0&&(n.uint32(10),n.bytes(r.identityKey)),r.identitySig!=null&&r.identitySig.byteLength>0&&(n.uint32(18),n.bytes(r.identitySig)),r.extensions!=null&&(n.uint32(34),Yn.codec().encode(r.extensions,n)),o.lengthDelimited!==!1&&n.ldelim()},(r,n,o={})=>{let s={identityKey:ut(0),identitySig:ut(0)},i=n==null?r.len:r.pos+n;for(;r.pos<i;){let a=r.uint32();switch(a>>>3){case 1:{s.identityKey=r.bytes();break}case 2:{s.identitySig=r.bytes();break}case 4:{s.extensions=Yn.codec().decode(r,r.uint32(),{limits:o.limits?.extensions});break}default:{r.skipType(a&7);break}}}return s})),t),e.encode=r=>Pe(r,e.codec()),e.decode=(r,n)=>Te(r,e.codec(),n)})($r||($r={}));async function fi(e,t,r){let n=await e.sign(cf(t));return $r.encode({identityKey:fe(e.publicKey),identitySig:n,extensions:r})}async function ui(e,t,r){try{let n=$r.decode(e),o=Mr(n.identityKey);if(r?.equals(o)===!1)throw new Error(`Payload identity key ${o} does not match expected remote identity key ${r}`);if(!t)throw new Error("Remote static does not exist");let s=cf(t);if(!await o.verify(s,n.identitySig))throw new Error("Invalid payload signature");return n}catch(n){throw new Jr(n.message)}}function cf(e){let t=j("noise-libp2p-static-key:");return e instanceof Uint8Array?wt([t,e],t.length+e.length):(e.prepend(t),e)}async function ff(e,t){let{log:r,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:u}=e,f=await fi(s,a.publicKey,u),l=new jr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!0,prologue:i,s:a});ni(l.s,r),r.trace("Stage 0 - Initiator starting to send first message."),await n.write(l.writeMessageA(Ue),t),r.trace("Stage 0 - Initiator finished sending first message."),oi(l.e,r),r.trace("Stage 1 - Initiator waiting to receive first message from responder...");let m=l.readMessageB(await n.read(t));r.trace("Stage 1 - Initiator received the message."),si(l.re,r),af(l.rs,r),r.trace("Initiator going to check remote's signature...");let p=await ui(m,l.rs,c);r.trace("All good with the signature!"),r.trace("Stage 2 - Initiator sending third handshake message."),await n.write(l.writeMessageC(f),t),r.trace("Stage 2 - Initiator sent message with signed payload.");let[g,w]=l.ss.split();return ii(g,w,r),{payload:p,encrypt:h=>g.encryptWithAd(Ue,h),decrypt:(h,E)=>w.decryptWithAd(Ue,h,E)}}async function uf(e,t){let{log:r,connection:n,crypto:o,privateKey:s,prologue:i,s:a,remoteIdentityKey:c,extensions:u}=e,f=await fi(s,a.publicKey,u),l=new jr({crypto:o,protocolName:"Noise_XX_25519_ChaChaPoly_SHA256",initiator:!1,prologue:i,s:a});ni(l.s,r),r.trace("Stage 0 - Responder waiting to receive first message."),l.readMessageA(await n.read(t)),r.trace("Stage 0 - Responder received first message."),si(l.re,r),r.trace("Stage 1 - Responder sending out first message with signed payload and static key."),await n.write(l.writeMessageB(f),t),r.trace("Stage 1 - Responder sent the second handshake message with signed payload."),oi(l.e,r),r.trace("Stage 2 - Responder waiting for third handshake message...");let m=l.readMessageC(await n.read(t));r.trace("Stage 2 - Responder received the message, finished handshake.");let p=await ui(m,l.rs,c),[g,w]=l.ss.split();return ii(g,w,r),{payload:p,encrypt:h=>w.encryptWithAd(Ue,h),decrypt:(h,E)=>g.decryptWithAd(Ue,h,E)}}var hf=16;function df(e,t){return async function*(r){for await(let n of r)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=e.encrypt(n.subarray(o,s)):i=e.encrypt(n.sublist(o,s)),t?.encryptedPackets.increment(),yield new F(ir(i.byteLength),i)}}}function pf(e,t){return async function*(r){for await(let n of r)for(let o=0;o<n.length;o+=65535){let s=o+65535;if(s>n.length&&(s=n.length),s-hf<o)throw new Error("Invalid chunk");let i=n.sublist(o,s),a=n.subarray(o,s-hf);try{let c=e.decrypt(i,a);t?.decryptedPackets.increment(),yield c}catch(c){throw t?.decryptErrors.increment(),c}}}}var Xn=class{protocol="/noise";crypto;prologue;staticKey;extensions;metrics;components;constructor(t,r={}){let{staticNoiseKey:n,extensions:o,crypto:s,prologueBytes:i}=r,{metrics:a}=t;this.components=t;let c=s??nf;this.crypto=of(c),this.extensions={webtransportCerthashes:[],...o},this.metrics=a?sf(a):void 0,n?this.staticKey=c.generateX25519KeyPairFromSeed(n):this.staticKey=c.generateX25519KeyPair(),this.prologue=i??ut(0)}[Symbol.toStringTag]="@chainsafe/libp2p-noise";[on]=["@libp2p/connection-encryption","@chainsafe/libp2p-noise"];async secureOutbound(t,r){let n=Fs(t,{lengthEncoder:ir,lengthDecoder:Wr,maxDataLength:65535}),o=await this.performHandshakeInitiator(n,this.components.privateKey,r?.remotePeer?.publicKey,r),s=await this.createSecureConnection(n,o);t.source=s.source,t.sink=s.sink;let i=Mr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:qs(i),streamMuxer:r?.skipStreamMuxerNegotiation===!0?void 0:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}getStreamMuxer(t){if(t==null||t.length===0)return;let r=this.components.upgrader.getStreamMuxers();if(r!=null)for(let n of t){let o=r.get(n);if(o!=null)return o}if(t.length)throw new Me("Early muxer negotiation was requested but the initiator and responder had no common muxers")}async secureInbound(t,r){let n=Fs(t,{lengthEncoder:ir,lengthDecoder:Wr,maxDataLength:65535}),o=await this.performHandshakeResponder(n,this.components.privateKey,r?.remotePeer?.publicKey,r),s=await this.createSecureConnection(n,o);t.source=s.source,t.sink=s.sink;let i=Mr(o.payload.identityKey);return{conn:t,remoteExtensions:o.payload.extensions,remotePeer:qs(i),streamMuxer:r?.skipStreamMuxerNegotiation===!0?void 0:this.getStreamMuxer(o.payload.extensions?.streamMuxers)}}async performHandshakeInitiator(t,r,n,o){let s,i=o?.skipStreamMuxerNegotiation===!0?[]:[...this.components.upgrader.getStreamMuxers().keys()];try{s=await ff({connection:t,privateKey:r,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:{streamMuxers:i,webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(a){throw this.metrics?.xxHandshakeErrors.increment(),a}return s}async performHandshakeResponder(t,r,n,o){let s,i=o?.skipStreamMuxerNegotiation===!0?[]:[...this.components.upgrader.getStreamMuxers().keys()];try{s=await uf({connection:t,privateKey:r,remoteIdentityKey:n,log:this.components.logger.forComponent("libp2p:noise:xxhandshake"),crypto:this.crypto,prologue:this.prologue,s:this.staticKey,extensions:{streamMuxers:i,webtransportCerthashes:[],...this.extensions}},o),this.metrics?.xxHandshakeSuccesses.increment()}catch(a){throw this.metrics?.xxHandshakeErrors.increment(),a}return s}async createSecureConnection(t,r){let[n,o]=Kc(),s=t.unwrap();return await Nc(n,df(r,this.metrics),s,i=>Gr(i,{lengthDecoder:Wr}),pf(r,this.metrics),n),o}};function mf(e={}){return t=>new Xn(t,e)}var Jn=class{index=0;input="";new(t){return this.index=0,this.input=t,this}readAtomically(t){let r=this.index,n=t();return n===void 0&&(this.index=r),n}parseWith(t){let r=t();if(this.index===this.input.length)return r}peekChar(){if(!(this.index>=this.input.length))return this.input[this.index]}readChar(){if(!(this.index>=this.input.length))return this.input[this.index++]}readGivenChar(t){return this.readAtomically(()=>{let r=this.readChar();if(r===t)return r})}readSeparator(t,r,n){return this.readAtomically(()=>{if(!(r>0&&this.readGivenChar(t)===void 0))return n()})}readNumber(t,r,n,o){return this.readAtomically(()=>{let s=0,i=0,a=this.peekChar();if(a===void 0)return;let c=a==="0",u=2**(8*o)-1;for(;;){let f=this.readAtomically(()=>{let l=this.readChar();if(l===void 0)return;let m=Number.parseInt(l,t);if(!Number.isNaN(m))return m});if(f===void 0)break;if(s*=t,s+=f,s>u||(i+=1,r!==void 0&&i>r))return}if(i!==0)return!n&&c&&i>1?void 0:s})}readIPv4Addr(){return this.readAtomically(()=>{let t=new Uint8Array(4);for(let r=0;r<t.length;r++){let n=this.readSeparator(".",r,()=>this.readNumber(10,3,!1,1));if(n===void 0)return;t[r]=n}return t})}readIPv6Addr(){let t=r=>{for(let n=0;n<r.length/2;n++){let o=n*2;if(n<r.length-3){let i=this.readSeparator(":",n,()=>this.readIPv4Addr());if(i!==void 0)return r[o]=i[0],r[o+1]=i[1],r[o+2]=i[2],r[o+3]=i[3],[o+4,!0]}let s=this.readSeparator(":",n,()=>this.readNumber(16,4,!0,2));if(s===void 0)return[o,!1];r[o]=s>>8,r[o+1]=s&255}return[r.length,!1]};return this.readAtomically(()=>{let r=new Uint8Array(16),[n,o]=t(r);if(n===16)return r;if(o||this.readGivenChar(":")===void 0||this.readGivenChar(":")===void 0)return;let s=new Uint8Array(14),i=16-(n+2),[a]=t(s.subarray(0,i));return r.set(s.subarray(0,a),16-a),r})}readIPAddr(){return this.readIPv4Addr()??this.readIPv6Addr()}};var yf=45,nd=15,fr=new Jn;function li(e){if(!(e.length>nd))return fr.new(e).parseWith(()=>fr.readIPv4Addr())}function hi(e){if(e.includes("%")&&(e=e.split("%")[0]),!(e.length>yf))return fr.new(e).parseWith(()=>fr.readIPv6Addr())}function Qn(e,t=!1){if(e.includes("%")&&(e=e.split("%")[0]),e.length>yf)return;let r=fr.new(e).parseWith(()=>fr.readIPAddr());if(r)return t&&r.length===4?Uint8Array.from([0,0,0,0,0,0,0,0,0,0,255,255,r[0],r[1],r[2],r[3]]):r}function to(e){return!!li(e)}function eo(e){return!!hi(e)}function ro(e){return!!Qn(e)}var od=e=>e.toString().split("/").slice(1),ur=e=>({match:t=>t.length<1?!1:e(t[0])?t.slice(1):!1,pattern:"fn"}),q=e=>({match:t=>ur(r=>r===e).match(t),pattern:e}),Ke=()=>({match:e=>ur(t=>typeof t=="string").match(e),pattern:"{string}"}),lr=()=>({match:e=>ur(t=>!isNaN(parseInt(t))).match(e),pattern:"{number}"}),Y=()=>({match:e=>{if(e.length<2||e[0]!=="p2p"&&e[0]!=="ipfs")return!1;if(e[1].startsWith("Q")||e[1].startsWith("1"))try{X.decode(`z${e[1]}`)}catch{return!1}else return!1;return e.slice(2)},pattern:"/p2p/{peerid}"}),Yr=()=>({match:e=>{if(e.length<2||e[0]!=="certhash")return!1;try{Do.decode(e[1])}catch{return!1}return e.slice(2)},pattern:"/certhash/{certhash}"}),W=e=>({match:t=>{let r=e.match(t);return r===!1?t:r},pattern:`optional(${e.pattern})`}),At=(...e)=>({match:t=>{let r;for(let n of e){let o=n.match(t);o!==!1&&(r==null||o.length<r.length)&&(r=o)}return r??!1},pattern:`or(${e.map(t=>t.pattern).join(", ")})`}),z=(...e)=>({match:t=>{for(let r of e){let n=r.match(t);if(n===!1)return!1;t=n}return t},pattern:`and(${e.map(t=>t.pattern).join(", ")})`});function nt(...e){function t(o){let s=od(o);for(let i of e){let a=i.match(s);if(a===!1)return!1;s=a}return s}function r(o){return t(o)!==!1}function n(o){let s=t(o);return s===!1?!1:s.length===0}return{matchers:e,matches:r,exactMatch:n}}var sd=Y(),Nb=nt(sd),oo=z(q("dns4"),Ke()),so=z(q("dns6"),Ke()),io=z(q("dnsaddr"),Ke()),pi=z(q("dns"),Ke()),Mb=nt(oo,W(Y())),Ob=nt(so,W(Y())),Hb=nt(io,W(Y())),qb=nt(At(pi,io,oo,so),W(Y())),gf=z(q("ip4"),ur(to)),wf=z(q("ip6"),ur(eo)),mi=At(gf,wf),se=At(mi,pi,oo,so,io),Vb=nt(At(mi,z(At(pi,io,oo,so),W(Y())))),zb=nt(gf),Fb=nt(wf),Gb=nt(mi),yi=z(se,q("tcp"),lr()),Xr=z(se,q("udp"),lr()),Wb=nt(z(yi,W(Y()))),jb=nt(Xr),gi=z(Xr,q("quic"),W(Y())),ao=z(Xr,q("quic-v1"),W(Y())),id=At(gi,ao),$b=nt(gi),Zb=nt(ao),di=At(se,yi,Xr,gi,ao),xf=At(z(di,q("ws"),W(Y()))),Yb=nt(xf),bf=At(z(di,q("wss"),W(Y())),z(di,q("tls"),W(z(q("sni"),Ke())),q("ws"),W(Y()))),Xb=nt(bf),Ef=z(Xr,q("webrtc-direct"),W(Yr()),W(Yr()),W(Y())),Jb=nt(Ef),Sf=z(ao,q("webtransport"),W(Yr()),W(Yr()),W(Y())),co=nt(Sf),no=At(xf,bf,z(yi,W(Y())),z(id,W(Y())),z(se,W(Y())),Ef,Sf,Y()),Qb=nt(no),ad=z(no,q("p2p-circuit"),Y()),t1=nt(ad),cd=At(z(no,q("p2p-circuit"),q("webrtc"),W(Y())),z(no,q("webrtc"),W(Y())),z(q("webrtc"),W(Y()))),e1=nt(cd),fd=At(z(se,q("tcp"),lr(),q("http"),W(Y())),z(se,q("http"),W(Y()))),r1=nt(fd),ud=At(z(se,q("tcp"),At(z(q("443"),q("http")),z(lr(),q("https")),z(lr(),q("tls"),q("http"))),W(Y())),z(se,q("tls"),q("http"),W(Y())),z(se,q("https"),W(Y()))),n1=nt(ud),ld=At(z(q("memory"),Ke(),W(Y()))),o1=nt(ld);var Re=class extends Event{type;detail;constructor(t,r){super(t),this.type=t,this.detail=r}};function wi(e){throw new Error("Not implemented")}function Af(e){if(e!=null){if(typeof e[Symbol.iterator]=="function")return e[Symbol.iterator]();if(typeof e[Symbol.asyncIterator]=="function")return e[Symbol.asyncIterator]();if(typeof e.next=="function")return e}throw new Error("argument is not an iterator or iterable")}function vf(e){return e==null?!1:typeof e.then=="function"&&typeof e.catch=="function"&&typeof e.finally=="function"}function If(e,t){let r=Af(e).return?.();vf(r)&&r.catch(n=>{t.error("could not cause iterator to return",n)})}var hd=5e3;function xi(e){return e==null?!1:typeof e.then=="function"&&typeof e.catch=="function"&&typeof e.finally=="function"}var fo=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=Bt(),this.closed=Bt(),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??hd,this.onEnd=t.onEnd,this.onCloseRead=t.onCloseRead,this.onCloseWrite=t.onCloseWrite,this.onReset=t.onReset,this.onAbort=t.onAbort,this.source=this.streamSource=zn({onEnd:r=>{r!=null?this.log.trace("source ended with error",r):this.log.trace("source ended"),this.onSourceEnd(r)}}),this.sink=this.sink.bind(this)}async sink(t){if(this.writeStatus!=="ready")throw new tn(`writable end state is "${this.writeStatus}" not "ready"`);try{this.writeStatus="writing";let r={signal:this.sinkController.signal};if(this.direction==="outbound"){let o=this.sendNewStream(r);xi(o)&&await o}let n=()=>{If(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 F(o):o;let s=this.sendData(o,r);xi(s)&&(this.sendingData=Bt(),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(r){throw this.log.trace("sink ended with error, calling abort with error",r),this.abort(r),r}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 dt(Promise.all([this.closeWrite(t),this.closeRead(t),this.closed.promise]),t?.signal),this.status="closed",this.log.trace("closed gracefully"))}async closeRead(t={}){if(this.readStatus==="closing"||this.readStatus==="closed")return;this.log.trace('closing readable end of stream with starting read status "%s"',this.readStatus);let r=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)),r==="ready"&&(this.log.trace("ending internal source queue with %d queued bytes",this.streamSource.readableLength),this.streamSource.end()),this.log.trace("closed readable end of stream")}async closeWrite(t={}){this.writeStatus==="closing"||this.writeStatus==="closed"||(this.log.trace('closing writable end of stream with starting write status "%s"',this.writeStatus),this.writeStatus==="ready"&&(this.log.trace("sink was never sunk, sink an empty array"),await dt(this.sink([]),t.signal)),this.writeStatus==="writing"&&(this.sendingData!=null&&await dt(this.sendingData.promise,t.signal),this.log.trace("aborting source passed to .sink"),this.sinkController.abort(),await dt(this.sinkEnd.promise,t.signal)),this.writeStatus="closed",this.log.trace("closed writable end of stream"))}abort(t){if(this.status==="closed"||this.status==="aborted"||this.status==="reset")return;this.log("abort with error",t),this.log("try to send reset to remote");let r=this.sendReset();xi(r)&&r.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 Qr("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 bi=class extends fo{writer;reader;constructor(t){super(t),this.writer=t.bidiStream.writable.getWriter(),this.reader=t.bidiStream.readable.getReader(),Promise.resolve().then(async()=>{for(;;){let r=await this.reader.read();if(r.done){t.log("remote closed write");return}r.value!=null&&this.sourcePush(new F(r.value))}}).catch(r=>{t.log.error("error reading from stream",r),this.abort(r)}).finally(()=>{this.remoteCloseWrite()}),this.writer.closed.then(()=>{t.log("writer closed")}).catch(r=>{t.log("writer close promise rejected",r)}).finally(()=>{this.remoteCloseRead()})}sendNewStream(t){}async sendData(t,r){for(let n of t)this.log("sendData waiting for writer to be ready"),await dt(this.writer.ready,r?.signal),this.writer.write(n).catch(o=>{this.log.error("error sending stream data",o)})}async sendReset(t){this.log("sendReset aborting writer"),await dt(this.writer.abort(),t?.signal),this.log("sendReset aborted writer")}async sendCloseWrite(t){this.log("sendCloseWrite closing writer"),await dt(this.writer.close(),t?.signal),this.log("sendCloseWrite closed writer")}async sendCloseRead(t){this.log("sendCloseRead cancelling reader"),await dt(this.reader.cancel(),t?.signal),this.log("sendCloseRead cancelled reader")}};async function Ei(e,t,r,n,o,s){let i=s.forComponent(`libp2p:webtransport:stream:${r}:${t}`),a=new bi({bidiStream:e,id:t,direction:r,log:i,onEnd:()=>{let c=n.findIndex(u=>u===a);c!==-1&&n.splice(c,1),o?.(a)}});return a}function uo(){return{source:{[Symbol.asyncIterator](){return{async next(){return new Promise(()=>{})}}}},sink:async e=>new Promise(()=>{})}}function _f(e,t,r,n){let o=0,s=r.forComponent("libp2p:webtransport:muxer");return{protocol:"webtransport",createStreamMuxer:i=>{typeof i=="function"&&(i={onIncomingStream:i});let a=[];Promise.resolve().then(async()=>{for(;;){let{done:u,value:f}=await t.read();if(u)break;if(a.length>=n.maxInboundStreams)s(`too many inbound streams open - ${a.length}/${n.maxInboundStreams}, closing new incoming stream`),f.writable.close().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)}),f.readable.cancel().catch(l=>{s.error(`failed to close inbound stream that crossed our maxInboundStream limit: ${l.message}`)});else{let l=await Ei(f,String(o++),"inbound",a,i?.onStreamEnd,r);a.push(l),i?.onIncomingStream?.(l)}}}).catch(u=>{s.error("could not create a new stream",u)});let c={protocol:"webtransport",streams:a,newStream:async u=>{s("new outgoing stream",u);let f=await e.createBidirectionalStream(),l=await Ei(f,String(o++),i?.direction??"outbound",a,i?.onStreamEnd,r);return a.push(l),l},close:async()=>{s("closing webtransport muxer gracefully");try{e.close()}catch(u){c.abort(u)}},abort:u=>{s("closing webtransport muxer with err:",u);try{e.close()}catch(f){s.error("webtransport session threw error during close",f)}},...uo()};return c}}}function Bf(e,t){return t.filter(n=>!!e.find(o=>ft(n,o))).length===t.length}var R1=parseInt("0xFFFF",16),N1=new Uint8Array([0,0,0,0,0,0,0,0,0,0,255,255]);var Cf=to,gd=eo,Si=function(e){let t=0;if(e=e.toString().trim(),Cf(e)){let r=new Uint8Array(t+4);return e.split(/\./g).forEach(n=>{r[t++]=parseInt(n,10)&255}),r}if(gd(e)){let r=e.split(":",8),n;for(n=0;n<r.length;n++){let s=Cf(r[n]),i;s&&(i=Si(r[n]),r[n]=O(i.slice(0,2),"base16")),i!=null&&++n<8&&r.splice(n,0,O(i.slice(2,4),"base16"))}if(r[0]==="")for(;r.length<8;)r.unshift("0");else if(r[r.length-1]==="")for(;r.length<8;)r.push("0");else if(r.length<8){for(n=0;n<r.length&&r[n]!=="";n++);let s=[n,1];for(n=9-r.length;n>0;n--)s.push("0");r.splice.apply(r,s)}let o=new Uint8Array(t+16);for(n=0;n<r.length;n++){let s=parseInt(r[n],16);o[t++]=s>>8&255,o[t++]=s&255}return o}throw new Error("invalid ip address")},Pf=function(e,t=0,r){t=~~t,r=r??e.length-t;let n=new DataView(e.buffer);if(r===4){let o=[];for(let s=0;s<r;s++)o.push(e[t+s]);return o.join(".")}if(r===16){let o=[];for(let s=0;s<r;s+=2)o.push(n.getUint16(t+s).toString(16));return o.join(":").replace(/(^|:)0(:0)*:0(:|$)/,"$1::$3").replace(/:{3,4}/,"::")}return""};var hr={},Ai={},xd=[[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"]];xd.forEach(e=>{let t=bd(...e);Ai[t.code]=t,hr[t.name]=t});function bd(e,t,r,n,o){return{code:e,size:t,name:r,resolvable:!!n,path:!!o}}function Z(e){if(typeof e=="number"){if(Ai[e]!=null)return Ai[e];throw new Error(`no protocol with code: ${e}`)}else if(typeof e=="string"){if(hr[e]!=null)return hr[e];throw new Error(`no protocol with name: ${e}`)}throw new Error(`invalid protocol id type: ${typeof e}`)}var w2=Z("ip4"),x2=Z("ip6"),b2=Z("ipcidr");function Bi(e,t){switch(Z(e).code){case 4:case 41:return Sd(t);case 42:return _i(t);case 43:return O(t,"base10");case 6:case 273:case 33:case 132:return Uf(t).toString();case 53:case 54:case 55:case 56:case 400:case 449:case 777:return _i(t);case 421:return _d(t);case 444:return kf(t);case 445:return kf(t);case 466:return Id(t);case 481:return globalThis.encodeURIComponent(_i(t));default:return O(t,"base16")}}function Li(e,t){switch(Z(e).code){case 4:return Df(t);case 41:return Df(t);case 42:return Ii(t);case 43:return j(t,"base10");case 6:case 273:case 33:case 132:return Ti(parseInt(t,10));case 53:case 54:case 55:case 56:case 400:case 449:case 777:return Ii(t);case 421:return Ad(t);case 444:return Bd(t);case 445:return Ld(t);case 466:return vd(t);case 481:return Ii(globalThis.decodeURIComponent(t));default:return j(t,"base16")}}var vi=Object.values(xe).map(e=>e.decoder),Ed=function(){let e=vi[0].or(vi[1]);return vi.slice(2).forEach(t=>e=e.or(t)),e}();function Df(e){if(!ro(e))throw new Error("invalid ip address");return Si(e)}function Sd(e){let t=Pf(e,0,e.length);if(t==null)throw new Error("ipBuff is required");if(!ro(t))throw new Error("invalid ip address");return t}function Ti(e){let t=new ArrayBuffer(2);return new DataView(t).setUint16(0,e),new Uint8Array(t)}function Uf(e){return new DataView(e.buffer).getUint16(e.byteOffset)}function Ii(e){let t=j(e),r=Uint8Array.from(jt(t.length));return wt([r,t],r.length+t.length)}function _i(e){let t=Ot(e);if(e=e.slice(ct(t)),e.length!==t)throw new Error("inconsistent lengths");return O(e)}function Ad(e){let t;e[0]==="Q"||e[0]==="1"?t=ae(X.decode(`z${e}`)).bytes:t=it.parse(e).multihash.bytes;let r=Uint8Array.from(jt(t.length));return wt([r,t],r.length+t.length)}function vd(e){let t=Ed.decode(e),r=Uint8Array.from(jt(t.length));return wt([r,t],r.length+t.length)}function Id(e){let t=Ot(e),r=e.slice(ct(t));if(r.length!==t)throw new Error("inconsistent lengths");return"u"+O(r,"base64url")}function _d(e){let t=Ot(e),r=e.slice(ct(t));if(r.length!==t)throw new Error("inconsistent lengths");return O(r,"base58btc")}function Bd(e){let t=e.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 r=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=Ti(n);return wt([r,o],r.length+o.length)}function Ld(e){let t=e.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 r=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=Ti(n);return wt([r,o],r.length+o.length)}function kf(e){let t=e.slice(0,e.length-2),r=e.slice(e.length-2),n=O(t,"base32"),o=Uf(r);return`${n}:${o}`}function Kf(e){e=Ci(e);let t=[],r=[],n=null,o=e.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=Z(i);if(a.size===0){t.push([a.code]),r.push([a.code]);continue}if(s++,s>=o.length)throw new lo("invalid address: "+e);if(a.path===!0){n=Ci(o.slice(s).join("/")),t.push([a.code,Li(a.code,n)]),r.push([a.code,n]);break}let c=Li(a.code,o[s]);t.push([a.code,c]),r.push([a.code,Bi(a.code,c)])}return{string:Rf(r),bytes:ho(t),tuples:t,stringTuples:r,path:n}}function Pi(e){let t=[],r=[],n=null,o=0;for(;o<e.length;){let s=Ot(e,o),i=ct(s),a=Z(s),c=Td(a,e.slice(o+i));if(c===0){t.push([s]),r.push([s]),o+=i;continue}let u=e.slice(o+i,o+i+c);if(o+=c+i,o>e.length)throw new lo("Invalid address Uint8Array: "+O(e,"base16"));t.push([s,u]);let f=Bi(s,u);if(r.push([s,f]),a.path===!0){n=f;break}}return{bytes:Uint8Array.from(e),string:Rf(r),tuples:t,stringTuples:r,path:n}}function Rf(e){let t=[];return e.map(r=>{let n=Z(r[0]);return t.push(n.name),r.length>1&&r[1]!=null&&t.push(r[1]),null}),Ci(t.join("/"))}function ho(e){return wt(e.map(t=>{let r=Z(t[0]),n=Uint8Array.from(jt(r.code));return t.length>1&&t[1]!=null&&(n=wt([n,t[1]])),n}))}function Td(e,t){if(e.size>0)return e.size/8;if(e.size===0)return 0;{let r=Ot(t instanceof Uint8Array?t:Uint8Array.from(t));return r+ct(r)}}function Ci(e){return"/"+e.trim().split("/").filter(t=>t).join("/")}var lo=class extends Error{static name="ParseError";name="ParseError";constructor(t){super(`Error parsing address: ${t}`)}};var Cd=Symbol.for("nodejs.util.inspect.custom"),ki=Symbol.for("@multiformats/js-multiaddr/multiaddr"),Pd=[Z("dns").code,Z("dns4").code,Z("dns6").code,Z("dnsaddr").code],Di=class extends Error{constructor(t="No available resolver"){super(t),this.name="NoAvailableResolverError"}},po=class e{bytes;#e;#t;#r;#n;[ki]=!0;constructor(t){t==null&&(t="");let r;if(t instanceof Uint8Array)r=Pi(t);else if(typeof t=="string"){if(t.length>0&&t.charAt(0)!=="/")throw new Error(`multiaddr "${t}" must start with a "/"`);r=Kf(t)}else if(Mf(t))r=Pi(t.bytes);else throw new Error("addr must be a string, Buffer, or another Multiaddr");this.bytes=r.bytes,this.#e=r.string,this.#t=r.tuples,this.#r=r.stringTuples,this.#n=r.path}toString(){return this.#e}toJSON(){return this.toString()}toOptions(){let t,r,n,o,s="",i=Z("tcp"),a=Z("udp"),c=Z("ip4"),u=Z("ip6"),f=Z("dns6"),l=Z("ip6zone");for(let[p,g]of this.stringTuples())p===l.code&&(s=`%${g??""}`),Pd.includes(p)&&(r=i.name==="tcp"?"tcp":"udp",o=443,n=`${g??""}${s}`,t=p===f.code?6:4),(p===i.code||p===a.code)&&(r=Z(p).name==="tcp"?"tcp":"udp",o=parseInt(g??"")),(p===c.code||p===u.code)&&(r=Z(p).name==="tcp"?"tcp":"udp",n=`${g??""}${s}`,t=p===u.code?6:4);if(t==null||r==null||n==null||o==null)throw new Error('multiaddr must have a valid format: "/{ip4, ip6, dns4, dns6, dnsaddr}/{address}/{tcp, udp}/{port}".');return{family:t,host:n,transport:r,port:o}}protos(){return this.#t.map(([t])=>Object.assign({},Z(t)))}protoCodes(){return this.#t.map(([t])=>t)}protoNames(){return this.#t.map(([t])=>Z(t).name)}tuples(){return this.#t.map(([t,r])=>r==null?[t]:[t,r])}stringTuples(){return this.#r.map(([t,r])=>r==null?[t]:[t,r])}encapsulate(t){return t=new e(t),new e(this.toString()+t.toString())}decapsulate(t){let r=t.toString(),n=this.toString(),o=n.lastIndexOf(r);if(o<0)throw new Error(`Address ${this.toString()} does not contain subaddress: ${t.toString()}`);return new e(n.slice(0,o))}decapsulateCode(t){let r=this.tuples();for(let n=r.length-1;n>=0;n--)if(r[n][0]===t)return new e(ho(r.slice(0,n)));return this}getPeerId(){try{let t=[];this.stringTuples().forEach(([n,o])=>{n===hr.p2p.code&&t.push([n,o]),n===hr["p2p-circuit"].code&&(t=[])});let r=t.pop();if(r?.[1]!=null){let n=r[1];return n[0]==="Q"||n[0]==="1"?O(X.decode(`z${n}`),"base58btc"):O(it.parse(n).multihash.bytes,"base58btc")}return null}catch{return null}}getPath(){return this.#n}equals(t){return ft(this.bytes,t.bytes)}async resolve(t){let r=this.protos().find(s=>s.resolvable);if(r==null)return[this];let n=Nf.get(r.name);if(n==null)throw new Di(`no available resolver for ${r.name}`);return(await n(this,t)).map(s=>Ui(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 r=(t??this).protos();return!(r.length!==2||r[0].code!==4&&r[0].code!==41||r[1].code!==6&&r[1].code!==273)}[Cd](){return`Multiaddr(${this.#e})`}};var Nf=new Map;function Mf(e){return!!e?.[ki]}function Ui(e){return new po(e)}var Dd=Object.values(xe).map(e=>e.decoder).reduce((e,t)=>e.or(t));function kd(e){return qt.decode(Dd.decode(e))}function Ki(e){if(!co.matches(e))throw new en("Invalid multiaddr, was not a WebTransport address");let t=e.stringTuples(),r=t.filter(([i,a])=>i===Z("certhash").code).map(([i,a])=>kd(a??"")),n=t.filter(([i,a])=>i===Z("p2p").code).map(([i,a])=>Cc(a??""))[0],o=e.toOptions(),s=o.host;return o.family===6&&s?.includes(":")&&(s=`[${s}]`),{url:`https://${s}:${o.port}`,certhashes:r,remotePeer:n}}var Of=globalThis.WebTransport;var Ri=class{log;components;config;metrics;constructor(t,r={}){this.log=t.logger.forComponent("libp2p:webtransport"),this.components=t,this.config={...r,maxInboundStreams:r.maxInboundStreams??1e3,certificates:r.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";[Mi]=!0;[on]=["@libp2p/transport"];async dial(t,r){r.signal.throwIfAborted(),this.log("dialing %s",t),r=r??{};let{url:n,certhashes:o,remotePeer:s}=Ki(t),i,a,c=()=>{},u=!1,f=!1,l=!1;try{this.metrics?.dialerEvents.increment({pending:!0});let m=new Of(`${n}/.well-known/libp2p-webtransport?type=noise`,{serverCertificateHashes:o.map(p=>({algorithm:"sha-256",value:p.digest}))});if(c=p=>{if(!u)try{this.metrics?.dialerEvents.increment({[p]:!0}),m.close()}catch(g){this.log.error("error closing wt session",g)}finally{a!=null&&(a.timeline.close=Date.now()),u=!0}},i=()=>{c(f?"noise_timeout":"ready_timeout")},r.signal.addEventListener("abort",i,{once:!0}),this.log("wait for session to be ready"),r.onProgress?.(new Re("webtransport:wait-for-session")),await Promise.race([m.closed,m.ready]),this.log("session became ready"),f=!0,this.metrics?.dialerEvents.increment({ready:!0}),m.closed.catch(p=>{this.log.error("error on remote wt session close",p)}).finally(()=>{c("remote_close")}),l=await dt(this.authenticateWebTransport({wt:m,remotePeer:s,certhashes:o,...r}),r.signal),!l)throw new Me("Failed to authenticate webtransport");return this.metrics?.dialerEvents.increment({open:!0}),a={close:async()=>{this.log("closing webtransport"),c("close")},abort:p=>{this.log("aborting webtransport due to passed err",p),c("abort")},remoteAddr:t,timeline:{open:Date.now()},log:this.components.logger.forComponent("libp2p:webtransport:maconn"),...uo()},await r.upgrader.upgradeOutbound(a,{...r,skipEncryption:!0,muxerFactory:_f(m,m.incomingBidirectionalStreams.getReader(),this.components.logger,this.config),skipProtection:!0})}catch(m){throw this.log.error("caught wt session err",m),c(l?"upgrade_error":f?"noise_error":"ready_error"),m}finally{i!=null&&r.signal?.removeEventListener("abort",i)}}async authenticateWebTransport({wt:t,remotePeer:r,certhashes:n,onProgress:o,signal:s}){s?.throwIfAborted(),o?.(new Re("webtransport:open-authentication-stream"));let i=await t.createBidirectionalStream(),a=i.writable.getWriter(),c=i.readable.getReader(),u={source:async function*(){for(;;){let m=await c.read();if(m.value!=null&&(yield m.value),m.done)break}}(),sink:async m=>{for await(let p of m){await dt(a.ready,s);let g=p instanceof Uint8Array?p:p.subarray();a.write(g).catch(w=>{this.log.error("could not write chunk during authentication of WebTransport stream",w)})}}},f=mf()(this.components);o?.(new Re("webtransport:secure-outbound-connection"));let{remoteExtensions:l}=await f.secureOutbound(u,{signal:s,remotePeer:r,skipStreamMuxerNegotiation:!0});if(o?.(new Re("webtransport:close-authentication-stream")),a.close().catch(m=>{this.log.error(`Failed to close authentication stream writer: ${m.message}`)}),c.cancel().catch(m=>{this.log.error(`Failed to close authentication stream reader: ${m.message}`)}),!Bf(l?.webtransportCerthashes??[],n.map(m=>m.bytes)))throw new ot("Our certhashes are not a subset of the remote's reported certhashes");return!0}createListener(t){return wi(this.components,{...t,certificates:this.config.certificates,maxInboundStreams:this.config.maxInboundStreams})}listenFilter(){return[]}dialFilter(t){return globalThis.WebTransport==null?[]:t.filter(r=>{if(!co.exactMatch(r))return!1;let{url:n,certhashes:o}=Ki(r);return n!=null&&o.length>0})}};function Ud(e={}){return t=>new Ri(t,e)}return Ff(Kd);})();
3
3
  //! TODO unclear how to add backpressure here?
4
4
  /*! Bundled license information:
5
5
 
6
6
  @noble/hashes/esm/utils.js:
7
7
  (*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
8
8
 
9
- @noble/curves/esm/abstract/utils.js:
9
+ @noble/curves/esm/utils.js:
10
10
  @noble/curves/esm/abstract/modular.js:
11
11
  @noble/curves/esm/abstract/curve.js:
12
12
  @noble/curves/esm/abstract/edwards.js: