genosdb 0.16.1 → 0.17.0

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.
@@ -1 +1 @@
1
- var u0=typeof globalThis==="object"&&"crypto"in globalThis?globalThis.crypto:void 0;/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */function F0($){return $ instanceof Uint8Array||ArrayBuffer.isView($)&&$.constructor.name==="Uint8Array"}function U$($){if(!Number.isSafeInteger($)||$<0)throw Error("positive integer expected, got "+$)}function O0($,...J){if(!F0($))throw Error("Uint8Array expected");if(J.length>0&&!J.includes($.length))throw Error("Uint8Array expected of length "+J+", got length="+$.length)}function L$($){if(typeof $!=="function"||typeof $.create!=="function")throw Error("Hash should be wrapped by utils.createHasher");U$($.outputLen),U$($.blockLen)}function t0($,J=!0){if($.destroyed)throw Error("Hash instance has been destroyed");if(J&&$.finished)throw Error("Hash#digest() has already been called")}function P8($,J){O0($);let q=J.outputLen;if($.length<q)throw Error("digestInto() expects output buffer of length at least "+q)}function m0(...$){for(let J=0;J<$.length;J++)$[J].fill(0)}function C$($){return new DataView($.buffer,$.byteOffset,$.byteLength)}function B0($,J){return $<<32-J|$>>>J}var I8=(()=>typeof Uint8Array.from([]).toHex==="function"&&typeof Uint8Array.fromHex==="function")(),sQ=Array.from({length:256},($,J)=>J.toString(16).padStart(2,"0"));function L0($){if(O0($),I8)return $.toHex();let J="";for(let q=0;q<$.length;q++)J+=sQ[$[q]];return J}var k0={_0:48,_9:57,A:65,F:70,a:97,f:102};function S8($){if($>=k0._0&&$<=k0._9)return $-k0._0;if($>=k0.A&&$<=k0.F)return $-(k0.A-10);if($>=k0.a&&$<=k0.f)return $-(k0.a-10);return}function h0($){if(typeof $!=="string")throw Error("hex string expected, got "+typeof $);if(I8)return Uint8Array.fromHex($);let J=$.length,q=J/2;if(J%2)throw Error("hex string expected, got unpadded hex of length "+J);let Q=new Uint8Array(q);for(let G=0,Y=0;G<q;G++,Y+=2){let X=S8($.charCodeAt(Y)),U=S8($.charCodeAt(Y+1));if(X===void 0||U===void 0){let z=$[Y]+$[Y+1];throw Error('hex string expected, got non-hex character "'+z+'" at index '+Y)}Q[G]=X*16+U}return Q}function S$($){if(typeof $!=="string")throw Error("string expected");return new Uint8Array(new TextEncoder().encode($))}function z$($){if(typeof $==="string")$=S$($);return O0($),$}function K0(...$){let J=0;for(let Q=0;Q<$.length;Q++){let G=$[Q];O0(G),J+=G.length}let q=new Uint8Array(J);for(let Q=0,G=0;Q<$.length;Q++){let Y=$[Q];q.set(Y,G),G+=Y.length}return q}class K${}function E8($){let J=(Q)=>$().update(z$(Q)).digest(),q=$();return J.outputLen=q.outputLen,J.blockLen=q.blockLen,J.create=()=>$(),J}function c0($=32){if(u0&&typeof u0.getRandomValues==="function")return u0.getRandomValues(new Uint8Array($));if(u0&&typeof u0.randomBytes==="function")return Uint8Array.from(u0.randomBytes($));throw Error("crypto.getRandomValues must be defined")}function tQ($,J,q,Q){if(typeof $.setBigUint64==="function")return $.setBigUint64(J,q,Q);let G=BigInt(32),Y=BigInt(4294967295),X=Number(q>>G&Y),U=Number(q&Y),z=Q?4:0,N=Q?0:4;$.setUint32(J+z,X,Q),$.setUint32(J+N,U,Q)}function v8($,J,q){return $&J^~$&q}function f8($,J,q){return $&J^$&q^J&q}class e$ extends K${constructor($,J,q,Q){super();this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=$,this.outputLen=J,this.padOffset=q,this.isLE=Q,this.buffer=new Uint8Array($),this.view=C$(this.buffer)}update($){t0(this),$=z$($),O0($);let{view:J,buffer:q,blockLen:Q}=this,G=$.length;for(let Y=0;Y<G;){let X=Math.min(Q-this.pos,G-Y);if(X===Q){let U=C$($);for(;Q<=G-Y;Y+=Q)this.process(U,Y);continue}if(q.set($.subarray(Y,Y+X),this.pos),this.pos+=X,Y+=X,this.pos===Q)this.process(J,0),this.pos=0}return this.length+=$.length,this.roundClean(),this}digestInto($){t0(this),P8($,this),this.finished=!0;let{buffer:J,view:q,blockLen:Q,isLE:G}=this,{pos:Y}=this;if(J[Y++]=128,m0(this.buffer.subarray(Y)),this.padOffset>Q-Y)this.process(q,0),Y=0;for(let K=Y;K<Q;K++)J[K]=0;tQ(q,Q-8,BigInt(this.length*8),G),this.process(q,0);let X=C$($),U=this.outputLen;if(U%4)throw Error("_sha2: outputLen should be aligned to 32bit");let z=U/4,N=this.get();if(z>N.length)throw Error("_sha2: outputLen bigger than state");for(let K=0;K<z;K++)X.setUint32(4*K,N[K],G)}digest(){let{buffer:$,outputLen:J}=this;this.digestInto($);let q=$.slice(0,J);return this.destroy(),q}_cloneInto($){$||($=new this.constructor),$.set(...this.get());let{blockLen:J,buffer:q,length:Q,finished:G,destroyed:Y,pos:X}=this;if($.destroyed=Y,$.finished=G,$.length=Q,$.pos=X,Q%J)$.buffer.set(q);return $}clone(){return this._cloneInto()}}var C0=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var eQ=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]),f0=new Uint32Array(64);class _8 extends e${constructor($=32){super(64,$,8,!1);this.A=C0[0]|0,this.B=C0[1]|0,this.C=C0[2]|0,this.D=C0[3]|0,this.E=C0[4]|0,this.F=C0[5]|0,this.G=C0[6]|0,this.H=C0[7]|0}get(){let{A:$,B:J,C:q,D:Q,E:G,F:Y,G:X,H:U}=this;return[$,J,q,Q,G,Y,X,U]}set($,J,q,Q,G,Y,X,U){this.A=$|0,this.B=J|0,this.C=q|0,this.D=Q|0,this.E=G|0,this.F=Y|0,this.G=X|0,this.H=U|0}process($,J){for(let K=0;K<16;K++,J+=4)f0[K]=$.getUint32(J,!1);for(let K=16;K<64;K++){let w=f0[K-15],Z=f0[K-2],j=B0(w,7)^B0(w,18)^w>>>3,R=B0(Z,17)^B0(Z,19)^Z>>>10;f0[K]=R+f0[K-7]+j+f0[K-16]|0}let{A:q,B:Q,C:G,D:Y,E:X,F:U,G:z,H:N}=this;for(let K=0;K<64;K++){let w=B0(X,6)^B0(X,11)^B0(X,25),Z=N+w+v8(X,U,z)+eQ[K]+f0[K]|0,R=(B0(q,2)^B0(q,13)^B0(q,22))+f8(q,Q,G)|0;N=z,z=U,U=X,X=Y+Z|0,Y=G,G=Q,Q=q,q=Z+R|0}q=q+this.A|0,Q=Q+this.B|0,G=G+this.C|0,Y=Y+this.D|0,X=X+this.E|0,U=U+this.F|0,z=z+this.G|0,N=N+this.H|0,this.set(q,Q,G,Y,X,U,z,N)}roundClean(){m0(f0)}destroy(){this.set(0,0,0,0,0,0,0,0),m0(this.buffer)}}var P$=E8(()=>new _8);class $8 extends K${constructor($,J){super();this.finished=!1,this.destroyed=!1,L$($);let q=z$(J);if(this.iHash=$.create(),typeof this.iHash.update!=="function")throw Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let Q=this.blockLen,G=new Uint8Array(Q);G.set(q.length>Q?$.create().update(q).digest():q);for(let Y=0;Y<G.length;Y++)G[Y]^=54;this.iHash.update(G),this.oHash=$.create();for(let Y=0;Y<G.length;Y++)G[Y]^=106;this.oHash.update(G),m0(G)}update($){return t0(this),this.iHash.update($),this}digestInto($){t0(this),O0($,this.outputLen),this.finished=!0,this.iHash.digestInto($),this.oHash.update($),this.oHash.digestInto($),this.destroy()}digest(){let $=new Uint8Array(this.oHash.outputLen);return this.digestInto($),$}_cloneInto($){$||($=Object.create(Object.getPrototypeOf(this),{}));let{oHash:J,iHash:q,finished:Q,destroyed:G,blockLen:Y,outputLen:X}=this;return $=$,$.finished=Q,$.destroyed=G,$.blockLen=Y,$.outputLen=X,$.oHash=J._cloneInto($.oHash),$.iHash=q._cloneInto($.iHash),$}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}}var Q8=($,J,q)=>new $8($,J).update(q).digest();Q8.create=($,J)=>new $8($,J);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var G8=BigInt(0),q8=BigInt(1);function j$($,J=""){if(typeof $!=="boolean"){let q=J&&`"${J}"`;throw Error(q+"expected boolean, got type="+typeof $)}return $}function _0($,J,q=""){let Q=F0($),G=$?.length,Y=J!==void 0;if(!Q||Y&&G!==J){let X=q&&`"${q}" `,U=Y?` of length ${J}`:"",z=Q?`length=${G}`:`type=${typeof $}`;throw Error(X+"expected Uint8Array"+U+", got "+z)}return $}function D$($){let J=$.toString(16);return J.length&1?"0"+J:J}function b8($){if(typeof $!=="string")throw Error("hex string expected, got "+typeof $);return $===""?G8:BigInt("0x"+$)}function S0($){return b8(L0($))}function Y8($){return O0($),b8(L0(Uint8Array.from($).reverse()))}function e0($,J){return h0($.toString(16).padStart(J*2,"0"))}function X8($,J){return e0($,J).reverse()}function p($,J,q){let Q;if(typeof J==="string")try{Q=h0(J)}catch(Y){throw Error($+" must be hex string or Uint8Array, cause: "+Y)}else if(F0(J))Q=Uint8Array.from(J);else throw Error($+" must be hex string or Uint8Array");let G=Q.length;if(typeof q==="number"&&G!==q)throw Error($+" of length "+q+" expected, got "+G);return Q}var J8=($)=>typeof $==="bigint"&&G8<=$;function W$($,J,q){return J8($)&&J8(J)&&J8(q)&&J<=$&&$<q}function y8($,J,q,Q){if(!W$(J,q,Q))throw Error("expected valid "+$+": "+q+" <= n < "+Q+", got "+J)}function I$($){let J;for(J=0;$>G8;$>>=q8,J+=1);return J}var b0=($)=>(q8<<BigInt($))-q8;function g8($,J,q){if(typeof $!=="number"||$<2)throw Error("hashLen must be a number");if(typeof J!=="number"||J<2)throw Error("qByteLen must be a number");if(typeof q!=="function")throw Error("hmacFn must be a function");let Q=(j)=>new Uint8Array(j),G=(j)=>Uint8Array.of(j),Y=Q($),X=Q($),U=0,z=()=>{Y.fill(1),X.fill(0),U=0},N=(...j)=>q(X,Y,...j),K=(j=Q(0))=>{if(X=N(G(0),j),Y=N(),j.length===0)return;X=N(G(1),j),Y=N()},w=()=>{if(U++>=1000)throw Error("drbg: tried 1000 values");let j=0,R=[];while(j<J){Y=N();let k=Y.slice();R.push(k),j+=Y.length}return K0(...R)};return(j,R)=>{z(),K(j);let k=void 0;while(!(k=R(w())))K();return z(),k}}function M$($,J,q={}){if(!$||typeof $!=="object")throw Error("expected valid options object");function Q(G,Y,X){let U=$[G];if(X&&U===void 0)return;let z=typeof U;if(z!==Y||U===null)throw Error(`param "${G}" is invalid: expected ${Y}, got ${z}`)}Object.entries(J).forEach(([G,Y])=>Q(G,Y,!1)),Object.entries(q).forEach(([G,Y])=>Q(G,Y,!0))}function Z8($){let J=new WeakMap;return(q,...Q)=>{let G=J.get(q);if(G!==void 0)return G;let Y=$(q,...Q);return J.set(q,Y),Y}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var Y0=BigInt(0),G0=BigInt(1),d0=BigInt(2),m8=BigInt(3),h8=BigInt(4),c8=BigInt(5),$J=BigInt(7),d8=BigInt(8),QJ=BigInt(9),l8=BigInt(16);function W0($,J){let q=$%J;return q>=Y0?q:J+q}function M0($,J,q){let Q=$;while(J-- >Y0)Q*=Q,Q%=q;return Q}function u8($,J){if($===Y0)throw Error("invert: expected non-zero number");if(J<=Y0)throw Error("invert: expected positive modulus, got "+J);let q=W0($,J),Q=J,G=Y0,Y=G0,X=G0,U=Y0;while(q!==Y0){let N=Q/q,K=Q%q,w=G-X*N,Z=Y-U*N;Q=q,q=K,G=X,Y=U,X=w,U=Z}if(Q!==G0)throw Error("invert: does not exist");return W0(G,J)}function U8($,J,q){if(!$.eql($.sqr(J),q))throw Error("Cannot find square root")}function o8($,J){let q=($.ORDER+G0)/h8,Q=$.pow(J,q);return U8($,Q,J),Q}function JJ($,J){let q=($.ORDER-c8)/d8,Q=$.mul(J,d0),G=$.pow(Q,q),Y=$.mul(J,G),X=$.mul($.mul(Y,d0),G),U=$.mul(Y,$.sub(X,$.ONE));return U8($,U,J),U}function qJ($){let J=y0($),q=p8($),Q=q(J,J.neg(J.ONE)),G=q(J,Q),Y=q(J,J.neg(Q)),X=($+$J)/l8;return(U,z)=>{let N=U.pow(z,X),K=U.mul(N,Q),w=U.mul(N,G),Z=U.mul(N,Y),j=U.eql(U.sqr(K),z),R=U.eql(U.sqr(w),z);N=U.cmov(N,K,j),K=U.cmov(Z,w,R);let k=U.eql(U.sqr(K),z),y=U.cmov(N,K,k);return U8(U,y,z),y}}function p8($){if($<m8)throw Error("sqrt is not defined for small field");let J=$-G0,q=0;while(J%d0===Y0)J/=d0,q++;let Q=d0,G=y0($);while(F8(G,Q)===1)if(Q++>1000)throw Error("Cannot find square root: probably non-prime P");if(q===1)return o8;let Y=G.pow(Q,J),X=(J+G0)/d0;return function(z,N){if(z.is0(N))return N;if(F8(z,N)!==1)throw Error("Cannot find square root");let K=q,w=z.mul(z.ONE,Y),Z=z.pow(N,J),j=z.pow(N,X);while(!z.eql(Z,z.ONE)){if(z.is0(Z))return z.ZERO;let R=1,k=z.sqr(Z);while(!z.eql(k,z.ONE))if(R++,k=z.sqr(k),R===K)throw Error("Cannot find square root");let y=G0<<BigInt(K-R-1),b=z.pow(w,y);K=R,w=z.sqr(b),Z=z.mul(Z,w),j=z.mul(j,b)}return j}}function GJ($){if($%h8===m8)return o8;if($%d8===c8)return JJ;if($%l8===QJ)return qJ($);return p8($)}var YJ=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function z8($){let J={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},q=YJ.reduce((Q,G)=>{return Q[G]="function",Q},J);return M$($,q),$}function XJ($,J,q){if(q<Y0)throw Error("invalid exponent, negatives unsupported");if(q===Y0)return $.ONE;if(q===G0)return J;let Q=$.ONE,G=J;while(q>Y0){if(q&G0)Q=$.mul(Q,G);G=$.sqr(G),q>>=G0}return Q}function E$($,J,q=!1){let Q=Array(J.length).fill(q?$.ZERO:void 0),G=J.reduce((X,U,z)=>{if($.is0(U))return X;return Q[z]=X,$.mul(X,U)},$.ONE),Y=$.inv(G);return J.reduceRight((X,U,z)=>{if($.is0(U))return X;return Q[z]=$.mul(X,Q[z]),$.mul(X,U)},Y),Q}function F8($,J){let q=($.ORDER-G0)/d0,Q=$.pow(J,q),G=$.eql(Q,$.ONE),Y=$.eql(Q,$.ZERO),X=$.eql(Q,$.neg($.ONE));if(!G&&!Y&&!X)throw Error("invalid Legendre symbol result");return G?1:Y?0:-1}function v$($,J){if(J!==void 0)U$(J);let q=J!==void 0?J:$.toString(2).length,Q=Math.ceil(q/8);return{nBitLength:q,nByteLength:Q}}function y0($,J,q=!1,Q={}){if($<=Y0)throw Error("invalid field: expected ORDER > 0, got "+$);let G=void 0,Y=void 0,X=!1,U=void 0;if(typeof J==="object"&&J!=null){if(Q.sqrt||q)throw Error("cannot specify opts in two arguments");let Z=J;if(Z.BITS)G=Z.BITS;if(Z.sqrt)Y=Z.sqrt;if(typeof Z.isLE==="boolean")q=Z.isLE;if(typeof Z.modFromBytes==="boolean")X=Z.modFromBytes;U=Z.allowedLengths}else{if(typeof J==="number")G=J;if(Q.sqrt)Y=Q.sqrt}let{nBitLength:z,nByteLength:N}=v$($,G);if(N>2048)throw Error("invalid field: expected ORDER of <= 2048 bytes");let K,w=Object.freeze({ORDER:$,isLE:q,BITS:z,BYTES:N,MASK:b0(z),ZERO:Y0,ONE:G0,allowedLengths:U,create:(Z)=>W0(Z,$),isValid:(Z)=>{if(typeof Z!=="bigint")throw Error("invalid field element: expected bigint, got "+typeof Z);return Y0<=Z&&Z<$},is0:(Z)=>Z===Y0,isValidNot0:(Z)=>!w.is0(Z)&&w.isValid(Z),isOdd:(Z)=>(Z&G0)===G0,neg:(Z)=>W0(-Z,$),eql:(Z,j)=>Z===j,sqr:(Z)=>W0(Z*Z,$),add:(Z,j)=>W0(Z+j,$),sub:(Z,j)=>W0(Z-j,$),mul:(Z,j)=>W0(Z*j,$),pow:(Z,j)=>XJ(w,Z,j),div:(Z,j)=>W0(Z*u8(j,$),$),sqrN:(Z)=>Z*Z,addN:(Z,j)=>Z+j,subN:(Z,j)=>Z-j,mulN:(Z,j)=>Z*j,inv:(Z)=>u8(Z,$),sqrt:Y||((Z)=>{if(!K)K=GJ($);return K(w,Z)}),toBytes:(Z)=>q?X8(Z,N):e0(Z,N),fromBytes:(Z,j=!0)=>{if(U){if(!U.includes(Z.length)||Z.length>N)throw Error("Field.fromBytes: expected "+U+" bytes, got "+Z.length);let k=new Uint8Array(N);k.set(Z,q?0:k.length-Z.length),Z=k}if(Z.length!==N)throw Error("Field.fromBytes: expected "+N+" bytes, got "+Z.length);let R=q?Y8(Z):S0(Z);if(X)R=W0(R,$);if(!j){if(!w.isValid(R))throw Error("invalid field element: outside of range 0..ORDER")}return R},invertBatch:(Z)=>E$(w,Z),cmov:(Z,j,R)=>R?j:Z});return Object.freeze(w)}function r8($){if(typeof $!=="bigint")throw Error("field order must be bigint");let J=$.toString(2).length;return Math.ceil(J/8)}function K8($){let J=r8($);return J+Math.ceil(J/2)}function f$($,J,q=!1){let Q=$.length,G=r8(J),Y=K8(J);if(Q<16||Q<Y||Q>1024)throw Error("expected "+Y+"-1024 bytes of input, got "+Q);let X=q?Y8($):S0($),U=W0(X,J-G0)+G0;return q?X8(U,G):e0(U,G)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var $$=BigInt(0),l0=BigInt(1);function V$($,J){let q=J.negate();return $?q:J}function _$($,J){let q=E$($.Fp,J.map((Q)=>Q.Z));return J.map((Q,G)=>$.fromAffine(Q.toAffine(q[G])))}function s8($,J){if(!Number.isSafeInteger($)||$<=0||$>J)throw Error("invalid window size, expected [1.."+J+"], got W="+$)}function j8($,J){s8($,J);let q=Math.ceil(J/$)+1,Q=2**($-1),G=2**$,Y=b0($),X=BigInt($);return{windows:q,windowSize:Q,mask:Y,maxNumber:G,shiftBy:X}}function i8($,J,q){let{windowSize:Q,mask:G,maxNumber:Y,shiftBy:X}=q,U=Number($&G),z=$>>X;if(U>Q)U-=Y,z+=l0;let N=J*Q,K=N+Math.abs(U)-1,w=U===0,Z=U<0,j=J%2!==0;return{nextN:z,offset:K,isZero:w,isNeg:Z,isNegF:j,offsetF:N}}function ZJ($,J){if(!Array.isArray($))throw Error("array expected");$.forEach((q,Q)=>{if(!(q instanceof J))throw Error("invalid point at index "+Q)})}function UJ($,J){if(!Array.isArray($))throw Error("array of scalars expected");$.forEach((q,Q)=>{if(!J.isValid(q))throw Error("invalid scalar at index "+Q)})}var D8=new WeakMap,t8=new WeakMap;function W8($){return t8.get($)||1}function a8($){if($!==$$)throw Error("invalid wNAF")}class M8{constructor($,J){this.BASE=$.BASE,this.ZERO=$.ZERO,this.Fn=$.Fn,this.bits=J}_unsafeLadder($,J,q=this.ZERO){let Q=$;while(J>$$){if(J&l0)q=q.add(Q);Q=Q.double(),J>>=l0}return q}precomputeWindow($,J){let{windows:q,windowSize:Q}=j8(J,this.bits),G=[],Y=$,X=Y;for(let U=0;U<q;U++){X=Y,G.push(X);for(let z=1;z<Q;z++)X=X.add(Y),G.push(X);Y=X.double()}return G}wNAF($,J,q){if(!this.Fn.isValid(q))throw Error("invalid scalar");let Q=this.ZERO,G=this.BASE,Y=j8($,this.bits);for(let X=0;X<Y.windows;X++){let{nextN:U,offset:z,isZero:N,isNeg:K,isNegF:w,offsetF:Z}=i8(q,X,Y);if(q=U,N)G=G.add(V$(w,J[Z]));else Q=Q.add(V$(K,J[z]))}return a8(q),{p:Q,f:G}}wNAFUnsafe($,J,q,Q=this.ZERO){let G=j8($,this.bits);for(let Y=0;Y<G.windows;Y++){if(q===$$)break;let{nextN:X,offset:U,isZero:z,isNeg:N}=i8(q,Y,G);if(q=X,z)continue;else{let K=J[U];Q=Q.add(N?K.negate():K)}}return a8(q),Q}getPrecomputes($,J,q){let Q=D8.get(J);if(!Q){if(Q=this.precomputeWindow(J,$),$!==1){if(typeof q==="function")Q=q(Q);D8.set(J,Q)}}return Q}cached($,J,q){let Q=W8($);return this.wNAF(Q,this.getPrecomputes(Q,$,q),J)}unsafe($,J,q,Q){let G=W8($);if(G===1)return this._unsafeLadder($,J,Q);return this.wNAFUnsafe(G,this.getPrecomputes(G,$,q),J,Q)}createCache($,J){s8(J,this.bits),t8.set($,J),D8.delete($)}hasCache($){return W8($)!==1}}function e8($,J,q,Q){let G=J,Y=$.ZERO,X=$.ZERO;while(q>$$||Q>$$){if(q&l0)Y=Y.add(G);if(Q&l0)X=X.add(G);G=G.double(),q>>=l0,Q>>=l0}return{p1:Y,p2:X}}function $Q($,J,q,Q){ZJ(q,$),UJ(Q,J);let G=q.length,Y=Q.length;if(G!==Y)throw Error("arrays of points and scalars must have equal length");let X=$.ZERO,U=I$(BigInt(G)),z=1;if(U>12)z=U-3;else if(U>4)z=U-2;else if(U>0)z=2;let N=b0(z),K=Array(Number(N)+1).fill(X),w=Math.floor((J.BITS-1)/z)*z,Z=X;for(let j=w;j>=0;j-=z){K.fill(X);for(let k=0;k<Y;k++){let y=Q[k],b=Number(y>>BigInt(j)&N);K[b]=K[b].add(q[k])}let R=X;for(let k=K.length-1,y=X;k>0;k--)y=y.add(K[k]),R=R.add(y);if(Z=Z.add(R),j!==0)for(let k=0;k<z;k++)Z=Z.double()}return Z}function n8($,J,q){if(J){if(J.ORDER!==$)throw Error("Field.ORDER must match order: Fp == p, Fn == n");return z8(J),J}else return y0($,{isLE:q})}function QQ($,J,q={},Q){if(Q===void 0)Q=$==="edwards";if(!J||typeof J!=="object")throw Error(`expected valid ${$} CURVE object`);for(let z of["p","n","h"]){let N=J[z];if(!(typeof N==="bigint"&&N>$$))throw Error(`CURVE.${z} must be positive bigint`)}let G=n8(J.p,q.Fp,Q),Y=n8(J.n,q.Fn,Q),U=["Gx","Gy","a",$==="weierstrass"?"b":"d"];for(let z of U)if(!G.isValid(J[z]))throw Error(`CURVE.${z} must be valid field element of CURVE.Fp`);return J=Object.freeze(Object.assign({},J)),{CURVE:J,Fp:G,Fn:Y}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var JQ=($,J)=>($+($>=0?J:-J)/GQ)/J;function zJ($,J,q){let[[Q,G],[Y,X]]=J,U=JQ(X*$,q),z=JQ(-G*$,q),N=$-U*Q-z*Y,K=-U*G-z*X,w=N<I0,Z=K<I0;if(w)N=-N;if(Z)K=-K;let j=b0(Math.ceil(I$(q)/2))+Q$;if(N<I0||N>=j||K<I0||K>=j)throw Error("splitScalar (endomorphism): failed, k="+$);return{k1neg:w,k1:N,k2neg:Z,k2:K}}function N8($){if(!["compact","recovered","der"].includes($))throw Error('Signature format must be "compact", "recovered", or "der"');return $}function V8($,J){let q={};for(let Q of Object.keys(J))q[Q]=$[Q]===void 0?J[Q]:$[Q];if(j$(q.lowS,"lowS"),j$(q.prehash,"prehash"),q.format!==void 0)N8(q.format);return q}class qQ extends Error{constructor($=""){super($)}}var P0={Err:qQ,_tlv:{encode:($,J)=>{let{Err:q}=P0;if($<0||$>256)throw new q("tlv.encode: wrong tag");if(J.length&1)throw new q("tlv.encode: unpadded data");let Q=J.length/2,G=D$(Q);if(G.length/2&128)throw new q("tlv.encode: long form length too big");let Y=Q>127?D$(G.length/2|128):"";return D$($)+Y+G+J},decode($,J){let{Err:q}=P0,Q=0;if($<0||$>256)throw new q("tlv.encode: wrong tag");if(J.length<2||J[Q++]!==$)throw new q("tlv.decode: wrong tlv");let G=J[Q++],Y=!!(G&128),X=0;if(!Y)X=G;else{let z=G&127;if(!z)throw new q("tlv.decode(long): indefinite length not supported");if(z>4)throw new q("tlv.decode(long): byte length is too big");let N=J.subarray(Q,Q+z);if(N.length!==z)throw new q("tlv.decode: length bytes not complete");if(N[0]===0)throw new q("tlv.decode(long): zero leftmost byte");for(let K of N)X=X<<8|K;if(Q+=z,X<128)throw new q("tlv.decode(long): not minimal encoding")}let U=J.subarray(Q,Q+X);if(U.length!==X)throw new q("tlv.decode: wrong value length");return{v:U,l:J.subarray(Q+X)}}},_int:{encode($){let{Err:J}=P0;if($<I0)throw new J("integer: negative integers are not allowed");let q=D$($);if(Number.parseInt(q[0],16)&8)q="00"+q;if(q.length&1)throw new J("unexpected DER parsing assertion: unpadded hex");return q},decode($){let{Err:J}=P0;if($[0]&128)throw new J("invalid signature integer: negative");if($[0]===0&&!($[1]&128))throw new J("invalid signature integer: unnecessary leading zero");return S0($)}},toSig($){let{Err:J,_int:q,_tlv:Q}=P0,G=p("signature",$),{v:Y,l:X}=Q.decode(48,G);if(X.length)throw new J("invalid signature: left bytes after parsing");let{v:U,l:z}=Q.decode(2,Y),{v:N,l:K}=Q.decode(2,z);if(K.length)throw new J("invalid signature: left bytes after parsing");return{r:q.decode(U),s:q.decode(N)}},hexFromSig($){let{_tlv:J,_int:q}=P0,Q=J.encode(2,q.encode($.r)),G=J.encode(2,q.encode($.s)),Y=Q+G;return J.encode(48,Y)}},I0=BigInt(0),Q$=BigInt(1),GQ=BigInt(2),b$=BigInt(3),KJ=BigInt(4);function g0($,J){let{BYTES:q}=$,Q;if(typeof J==="bigint")Q=J;else{let G=p("private key",J);try{Q=$.fromBytes(G)}catch(Y){throw Error(`invalid private key: expected ui8a of size ${q}, got ${typeof J}`)}}if(!$.isValidNot0(Q))throw Error("invalid private key: out of range [1..N-1]");return Q}function jJ($,J={}){let q=QQ("weierstrass",$,J),{Fp:Q,Fn:G}=q,Y=q.CURVE,{h:X,n:U}=Y;M$(J,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});let{endo:z}=J;if(z){if(!Q.is0(Y.a)||typeof z.beta!=="bigint"||!Array.isArray(z.basises))throw Error('invalid endo: expected "beta": bigint and "basises": array')}let N=XQ(Q,G);function K(){if(!Q.isOdd)throw Error("compression is not supported: Field does not have .isOdd()")}function w(V,L,W){let{x:A,y:D}=L.toAffine(),M=Q.toBytes(A);if(j$(W,"isCompressed"),W){K();let B=!Q.isOdd(D);return K0(YQ(B),M)}else return K0(Uint8Array.of(4),M,Q.toBytes(D))}function Z(V){_0(V,void 0,"Point");let{publicKey:L,publicKeyUncompressed:W}=N,A=V.length,D=V[0],M=V.subarray(1);if(A===L&&(D===2||D===3)){let B=Q.fromBytes(M);if(!Q.isValid(B))throw Error("bad point: is not on curve, wrong x");let H=k(B),T;try{T=Q.sqrt(H)}catch(E){let v=E instanceof Error?": "+E.message:"";throw Error("bad point: is not on curve, sqrt error"+v)}K();let C=Q.isOdd(T);if((D&1)===1!==C)T=Q.neg(T);return{x:B,y:T}}else if(A===W&&D===4){let B=Q.BYTES,H=Q.fromBytes(M.subarray(0,B)),T=Q.fromBytes(M.subarray(B,B*2));if(!y(H,T))throw Error("bad point: is not on curve");return{x:H,y:T}}else throw Error(`bad point: got length ${A}, expected compressed=${L} or uncompressed=${W}`)}let j=J.toBytes||w,R=J.fromBytes||Z;function k(V){let L=Q.sqr(V),W=Q.mul(L,V);return Q.add(Q.add(W,Q.mul(V,Y.a)),Y.b)}function y(V,L){let W=Q.sqr(L),A=k(V);return Q.eql(W,A)}if(!y(Y.Gx,Y.Gy))throw Error("bad curve params: generator point");let b=Q.mul(Q.pow(Y.a,b$),KJ),J0=Q.mul(Q.sqr(Y.b),BigInt(27));if(Q.is0(Q.add(b,J0)))throw Error("bad curve params: a or b");function u(V,L,W=!1){if(!Q.isValid(L)||W&&Q.is0(L))throw Error(`bad point coordinate ${V}`);return L}function X0(V){if(!(V instanceof I))throw Error("ProjectivePoint expected")}function n(V){if(!z||!z.basises)throw Error("no endo");return zJ(V,z.basises,G.ORDER)}let q0=Z8((V,L)=>{let{X:W,Y:A,Z:D}=V;if(Q.eql(D,Q.ONE))return{x:W,y:A};let M=V.is0();if(L==null)L=M?Q.ONE:Q.inv(D);let B=Q.mul(W,L),H=Q.mul(A,L),T=Q.mul(D,L);if(M)return{x:Q.ZERO,y:Q.ZERO};if(!Q.eql(T,Q.ONE))throw Error("invZ was invalid");return{x:B,y:H}}),j0=Z8((V)=>{if(V.is0()){if(J.allowInfinityPoint&&!Q.is0(V.Y))return;throw Error("bad point: ZERO")}let{x:L,y:W}=V.toAffine();if(!Q.isValid(L)||!Q.isValid(W))throw Error("bad point: x or y not field elements");if(!y(L,W))throw Error("bad point: equation left != right");if(!V.isTorsionFree())throw Error("bad point: not in prime-order subgroup");return!0});function e(V,L,W,A,D){return W=new I(Q.mul(W.X,V),W.Y,W.Z),L=V$(A,L),W=V$(D,W),L.add(W)}class I{constructor(V,L,W){this.X=u("x",V),this.Y=u("y",L,!0),this.Z=u("z",W),Object.freeze(this)}static CURVE(){return Y}static fromAffine(V){let{x:L,y:W}=V||{};if(!V||!Q.isValid(L)||!Q.isValid(W))throw Error("invalid affine point");if(V instanceof I)throw Error("projective point not allowed");if(Q.is0(L)&&Q.is0(W))return I.ZERO;return new I(L,W,Q.ONE)}static fromBytes(V){let L=I.fromAffine(R(_0(V,void 0,"point")));return L.assertValidity(),L}static fromHex(V){return I.fromBytes(p("pointHex",V))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(V=8,L=!0){if(_.createCache(this,V),!L)this.multiply(b$);return this}assertValidity(){j0(this)}hasEvenY(){let{y:V}=this.toAffine();if(!Q.isOdd)throw Error("Field doesn't support isOdd");return!Q.isOdd(V)}equals(V){X0(V);let{X:L,Y:W,Z:A}=this,{X:D,Y:M,Z:B}=V,H=Q.eql(Q.mul(L,B),Q.mul(D,A)),T=Q.eql(Q.mul(W,B),Q.mul(M,A));return H&&T}negate(){return new I(this.X,Q.neg(this.Y),this.Z)}double(){let{a:V,b:L}=Y,W=Q.mul(L,b$),{X:A,Y:D,Z:M}=this,B=Q.ZERO,H=Q.ZERO,T=Q.ZERO,C=Q.mul(A,A),c=Q.mul(D,D),E=Q.mul(M,M),v=Q.mul(A,D);return v=Q.add(v,v),T=Q.mul(A,M),T=Q.add(T,T),B=Q.mul(V,T),H=Q.mul(W,E),H=Q.add(B,H),B=Q.sub(c,H),H=Q.add(c,H),H=Q.mul(B,H),B=Q.mul(v,B),T=Q.mul(W,T),E=Q.mul(V,E),v=Q.sub(C,E),v=Q.mul(V,v),v=Q.add(v,T),T=Q.add(C,C),C=Q.add(T,C),C=Q.add(C,E),C=Q.mul(C,v),H=Q.add(H,C),E=Q.mul(D,M),E=Q.add(E,E),C=Q.mul(E,v),B=Q.sub(B,C),T=Q.mul(E,c),T=Q.add(T,T),T=Q.add(T,T),new I(B,H,T)}add(V){X0(V);let{X:L,Y:W,Z:A}=this,{X:D,Y:M,Z:B}=V,H=Q.ZERO,T=Q.ZERO,C=Q.ZERO,c=Y.a,E=Q.mul(Y.b,b$),v=Q.mul(L,D),g=Q.mul(W,M),f=Q.mul(A,B),h=Q.add(L,W),d=Q.add(D,M);h=Q.mul(h,d),d=Q.add(v,g),h=Q.sub(h,d),d=Q.add(L,A);let l=Q.add(D,B);return d=Q.mul(d,l),l=Q.add(v,f),d=Q.sub(d,l),l=Q.add(W,A),H=Q.add(M,B),l=Q.mul(l,H),H=Q.add(g,f),l=Q.sub(l,H),C=Q.mul(c,d),H=Q.mul(E,f),C=Q.add(H,C),H=Q.sub(g,C),C=Q.add(g,C),T=Q.mul(H,C),g=Q.add(v,v),g=Q.add(g,v),f=Q.mul(c,f),d=Q.mul(E,d),g=Q.add(g,f),f=Q.sub(v,f),f=Q.mul(c,f),d=Q.add(d,f),v=Q.mul(g,d),T=Q.add(T,v),v=Q.mul(l,d),H=Q.mul(h,H),H=Q.sub(H,v),v=Q.mul(h,g),C=Q.mul(l,C),C=Q.add(C,v),new I(H,T,C)}subtract(V){return this.add(V.negate())}is0(){return this.equals(I.ZERO)}multiply(V){let{endo:L}=J;if(!G.isValidNot0(V))throw Error("invalid scalar: out of range");let W,A,D=(M)=>_.cached(this,M,(B)=>_$(I,B));if(L){let{k1neg:M,k1:B,k2neg:H,k2:T}=n(V),{p:C,f:c}=D(B),{p:E,f:v}=D(T);A=c.add(v),W=e(L.beta,C,E,M,H)}else{let{p:M,f:B}=D(V);W=M,A=B}return _$(I,[W,A])[0]}multiplyUnsafe(V){let{endo:L}=J,W=this;if(!G.isValid(V))throw Error("invalid scalar: out of range");if(V===I0||W.is0())return I.ZERO;if(V===Q$)return W;if(_.hasCache(this))return this.multiply(V);if(L){let{k1neg:A,k1:D,k2neg:M,k2:B}=n(V),{p1:H,p2:T}=e8(I,W,D,B);return e(L.beta,H,T,A,M)}else return _.unsafe(W,V)}multiplyAndAddUnsafe(V,L,W){let A=this.multiplyUnsafe(L).add(V.multiplyUnsafe(W));return A.is0()?void 0:A}toAffine(V){return q0(this,V)}isTorsionFree(){let{isTorsionFree:V}=J;if(X===Q$)return!0;if(V)return V(I,this);return _.unsafe(this,U).is0()}clearCofactor(){let{clearCofactor:V}=J;if(X===Q$)return this;if(V)return V(I,this);return this.multiplyUnsafe(X)}isSmallOrder(){return this.multiplyUnsafe(X).is0()}toBytes(V=!0){return j$(V,"isCompressed"),this.assertValidity(),j(I,this,V)}toHex(V=!0){return L0(this.toBytes(V))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}get px(){return this.X}get py(){return this.X}get pz(){return this.Z}toRawBytes(V=!0){return this.toBytes(V)}_setWindowSize(V){this.precompute(V)}static normalizeZ(V){return _$(I,V)}static msm(V,L){return $Q(I,G,V,L)}static fromPrivateKey(V){return I.BASE.multiply(g0(G,V))}}I.BASE=new I(Y.Gx,Y.Gy,Q.ONE),I.ZERO=new I(Q.ZERO,Q.ONE,Q.ZERO),I.Fp=Q,I.Fn=G;let r=G.BITS,_=new M8(I,J.endo?Math.ceil(r/2):r);return I.BASE.precompute(8),I}function YQ($){return Uint8Array.of($?2:3)}function XQ($,J){return{secretKey:J.BYTES,publicKey:1+$.BYTES,publicKeyUncompressed:1+2*$.BYTES,publicKeyHasPrefix:!0,signature:2*J.BYTES}}function DJ($,J={}){let{Fn:q}=$,Q=J.randomBytes||c0,G=Object.assign(XQ($.Fp,q),{seed:K8(q.ORDER)});function Y(j){try{return!!g0(q,j)}catch(R){return!1}}function X(j,R){let{publicKey:k,publicKeyUncompressed:y}=G;try{let b=j.length;if(R===!0&&b!==k)return!1;if(R===!1&&b!==y)return!1;return!!$.fromBytes(j)}catch(b){return!1}}function U(j=Q(G.seed)){return f$(_0(j,G.seed,"seed"),q.ORDER)}function z(j,R=!0){return $.BASE.multiply(g0(q,j)).toBytes(R)}function N(j){let R=U(j);return{secretKey:R,publicKey:z(R)}}function K(j){if(typeof j==="bigint")return!1;if(j instanceof $)return!0;let{secretKey:R,publicKey:k,publicKeyUncompressed:y}=G;if(q.allowedLengths||R===k)return;let b=p("key",j).length;return b===k||b===y}function w(j,R,k=!0){if(K(j)===!0)throw Error("first arg must be private key");if(K(R)===!1)throw Error("second arg must be public key");let y=g0(q,j);return $.fromHex(R).multiply(y).toBytes(k)}return Object.freeze({getPublicKey:z,getSharedSecret:w,keygen:N,Point:$,utils:{isValidSecretKey:Y,isValidPublicKey:X,randomSecretKey:U,isValidPrivateKey:Y,randomPrivateKey:U,normPrivateKeyToScalar:(j)=>g0(q,j),precompute(j=8,R=$.BASE){return R.precompute(j,!1)}},lengths:G})}function WJ($,J,q={}){L$(J),M$(q,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});let Q=q.randomBytes||c0,G=q.hmac||((W,...A)=>Q8(J,W,K0(...A))),{Fp:Y,Fn:X}=$,{ORDER:U,BITS:z}=X,{keygen:N,getPublicKey:K,getSharedSecret:w,utils:Z,lengths:j}=DJ($,q),R={prehash:!1,lowS:typeof q.lowS==="boolean"?q.lowS:!1,format:void 0,extraEntropy:!1},k="compact";function y(W){let A=U>>Q$;return W>A}function b(W,A){if(!X.isValidNot0(A))throw Error(`invalid signature ${W}: out of range 1..Point.Fn.ORDER`);return A}function J0(W,A){N8(A);let D=j.signature,M=A==="compact"?D:A==="recovered"?D+1:void 0;return _0(W,M,`${A} signature`)}class u{constructor(W,A,D){if(this.r=b("r",W),this.s=b("s",A),D!=null)this.recovery=D;Object.freeze(this)}static fromBytes(W,A=k){J0(W,A);let D;if(A==="der"){let{r:T,s:C}=P0.toSig(_0(W));return new u(T,C)}if(A==="recovered")D=W[0],A="compact",W=W.subarray(1);let M=X.BYTES,B=W.subarray(0,M),H=W.subarray(M,M*2);return new u(X.fromBytes(B),X.fromBytes(H),D)}static fromHex(W,A){return this.fromBytes(h0(W),A)}addRecoveryBit(W){return new u(this.r,this.s,W)}recoverPublicKey(W){let A=Y.ORDER,{r:D,s:M,recovery:B}=this;if(B==null||![0,1,2,3].includes(B))throw Error("recovery id invalid");if(U*GQ<A&&B>1)throw Error("recovery id is ambiguous for h>1 curve");let T=B===2||B===3?D+U:D;if(!Y.isValid(T))throw Error("recovery id 2 or 3 invalid");let C=Y.toBytes(T),c=$.fromBytes(K0(YQ((B&1)===0),C)),E=X.inv(T),v=n(p("msgHash",W)),g=X.create(-v*E),f=X.create(M*E),h=$.BASE.multiplyUnsafe(g).add(c.multiplyUnsafe(f));if(h.is0())throw Error("point at infinify");return h.assertValidity(),h}hasHighS(){return y(this.s)}toBytes(W=k){if(N8(W),W==="der")return h0(P0.hexFromSig(this));let A=X.toBytes(this.r),D=X.toBytes(this.s);if(W==="recovered"){if(this.recovery==null)throw Error("recovery bit must be present");return K0(Uint8Array.of(this.recovery),A,D)}return K0(A,D)}toHex(W){return L0(this.toBytes(W))}assertValidity(){}static fromCompact(W){return u.fromBytes(p("sig",W),"compact")}static fromDER(W){return u.fromBytes(p("sig",W),"der")}normalizeS(){return this.hasHighS()?new u(this.r,X.neg(this.s),this.recovery):this}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return L0(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return L0(this.toBytes("compact"))}}let X0=q.bits2int||function(A){if(A.length>8192)throw Error("input is too large");let D=S0(A),M=A.length*8-z;return M>0?D>>BigInt(M):D},n=q.bits2int_modN||function(A){return X.create(X0(A))},q0=b0(z);function j0(W){return y8("num < 2^"+z,W,I0,q0),X.toBytes(W)}function e(W,A){return _0(W,void 0,"message"),A?_0(J(W),void 0,"prehashed message"):W}function I(W,A,D){if(["recovered","canonical"].some((f)=>(f in D)))throw Error("sign() legacy options not supported");let{lowS:M,prehash:B,extraEntropy:H}=V8(D,R);W=e(W,B);let T=n(W),C=g0(X,A),c=[j0(C),j0(T)];if(H!=null&&H!==!1){let f=H===!0?Q(j.secretKey):H;c.push(p("extraEntropy",f))}let E=K0(...c),v=T;function g(f){let h=X0(f);if(!X.isValidNot0(h))return;let d=X.inv(h),l=$.BASE.multiply(h).toAffine(),s=X.create(l.x);if(s===I0)return;let Z0=X.create(d*X.create(v+s*C));if(Z0===I0)return;let $0=(l.x===s?0:2)|Number(l.y&Q$),Q0=Z0;if(M&&y(Z0))Q0=X.neg(Z0),$0^=1;return new u(s,Q0,$0)}return{seed:E,k2sig:g}}function r(W,A,D={}){W=p("message",W);let{seed:M,k2sig:B}=I(W,A,D);return g8(J.outputLen,X.BYTES,G)(M,B)}function _(W){let A=void 0,D=typeof W==="string"||F0(W),M=!D&&W!==null&&typeof W==="object"&&typeof W.r==="bigint"&&typeof W.s==="bigint";if(!D&&!M)throw Error("invalid signature, expected Uint8Array, hex string or Signature instance");if(M)A=new u(W.r,W.s);else if(D){try{A=u.fromBytes(p("sig",W),"der")}catch(B){if(!(B instanceof P0.Err))throw B}if(!A)try{A=u.fromBytes(p("sig",W),"compact")}catch(B){return!1}}if(!A)return!1;return A}function V(W,A,D,M={}){let{lowS:B,prehash:H,format:T}=V8(M,R);if(D=p("publicKey",D),A=e(p("message",A),H),"strict"in M)throw Error("options.strict was renamed to lowS");let C=T===void 0?_(W):u.fromBytes(p("sig",W),T);if(C===!1)return!1;try{let c=$.fromBytes(D);if(B&&C.hasHighS())return!1;let{r:E,s:v}=C,g=n(A),f=X.inv(v),h=X.create(g*f),d=X.create(E*f),l=$.BASE.multiplyUnsafe(h).add(c.multiplyUnsafe(d));if(l.is0())return!1;return X.create(l.x)===E}catch(c){return!1}}function L(W,A,D={}){let{prehash:M}=V8(D,R);return A=e(A,M),u.fromBytes(W,"recovered").recoverPublicKey(A).toBytes()}return Object.freeze({keygen:N,getPublicKey:K,getSharedSecret:w,utils:Z,lengths:j,Point:$,sign:r,verify:V,recoverPublicKey:L,Signature:u,hash:J})}function MJ($){let J={a:$.a,b:$.b,p:$.Fp.ORDER,n:$.n,h:$.h,Gx:$.Gx,Gy:$.Gy},q=$.Fp,Q=$.allowedPrivateKeyLengths?Array.from(new Set($.allowedPrivateKeyLengths.map((X)=>Math.ceil(X/2)))):void 0,G=y0(J.n,{BITS:$.nBitLength,allowedLengths:Q,modFromBytes:$.wrapPrivateKey}),Y={Fp:q,Fn:G,allowInfinityPoint:$.allowInfinityPoint,endo:$.endo,isTorsionFree:$.isTorsionFree,clearCofactor:$.clearCofactor,fromBytes:$.fromBytes,toBytes:$.toBytes};return{CURVE:J,curveOpts:Y}}function VJ($){let{CURVE:J,curveOpts:q}=MJ($),Q={hmac:$.hmac,randomBytes:$.randomBytes,lowS:$.lowS,bits2int:$.bits2int,bits2int_modN:$.bits2int_modN};return{CURVE:J,curveOpts:q,hash:$.hash,ecdsaOpts:Q}}function NJ($,J){let q=J.Point;return Object.assign({},J,{ProjectivePoint:q,CURVE:Object.assign({},$,v$(q.Fn.ORDER,q.Fn.BITS))})}function ZQ($){let{CURVE:J,curveOpts:q,hash:Q,ecdsaOpts:G}=VJ($),Y=jJ(J,q),X=WJ(Y,Q,G);return NJ($,X)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */function UQ($,J){let q=(Q)=>ZQ({...$,hash:Q});return{...q(J),create:q}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var J$={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},OJ={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]},BJ=BigInt(0),zQ=BigInt(1),O8=BigInt(2);function TJ($){let J=J$.p,q=BigInt(3),Q=BigInt(6),G=BigInt(11),Y=BigInt(22),X=BigInt(23),U=BigInt(44),z=BigInt(88),N=$*$*$%J,K=N*N*$%J,w=M0(K,q,J)*K%J,Z=M0(w,q,J)*K%J,j=M0(Z,O8,J)*N%J,R=M0(j,G,J)*j%J,k=M0(R,Y,J)*R%J,y=M0(k,U,J)*k%J,b=M0(y,z,J)*y%J,J0=M0(b,U,J)*k%J,u=M0(J0,q,J)*K%J,X0=M0(u,X,J)*R%J,n=M0(X0,Q,J)*N%J,q0=M0(n,O8,J);if(!y$.eql(y$.sqr(q0),$))throw Error("Cannot find square root");return q0}var y$=y0(J$.p,{sqrt:TJ}),DQ=UQ({...J$,Fp:y$,lowS:!0,endo:OJ},P$),KQ={};function g$($,...J){let q=KQ[$];if(q===void 0){let Q=P$(S$($));q=K0(Q,Q),KQ[$]=q}return P$(K0(q,...J))}var T8=($)=>$.toBytes(!0).slice(1),q$=(()=>DQ.Point)(),A8=($)=>$%O8===BJ;function B8($){let{Fn:J,BASE:q}=q$,Q=g0(J,$),G=q.multiply(Q);return{scalar:A8(G.y)?Q:J.neg(Q),bytes:T8(G)}}function WQ($){let J=y$;if(!J.isValidNot0($))throw Error("invalid x: Fail if x ≥ p");let q=J.create($*$),Q=J.create(q*$+BigInt(7)),G=J.sqrt(Q);if(!A8(G))G=J.neg(G);let Y=q$.fromAffine({x:$,y:G});return Y.assertValidity(),Y}var N$=S0;function MQ(...$){return q$.Fn.create(N$(g$("BIP0340/challenge",...$)))}function jQ($){return B8($).bytes}function AJ($,J,q=c0(32)){let{Fn:Q}=q$,G=p("message",$),{bytes:Y,scalar:X}=B8(J),U=p("auxRand",q,32),z=Q.toBytes(X^N$(g$("BIP0340/aux",U))),N=g$("BIP0340/nonce",z,Y,G),{bytes:K,scalar:w}=B8(N),Z=MQ(K,Y,G),j=new Uint8Array(64);if(j.set(K,0),j.set(Q.toBytes(Q.create(w+Z*X)),32),!VQ(j,G,Y))throw Error("sign: Invalid signature produced");return j}function VQ($,J,q){let{Fn:Q,BASE:G}=q$,Y=p("signature",$,64),X=p("message",J),U=p("publicKey",q,32);try{let z=WQ(N$(U)),N=N$(Y.subarray(0,32));if(!W$(N,zQ,J$.p))return!1;let K=N$(Y.subarray(32,64));if(!W$(K,zQ,J$.n))return!1;let w=MQ(Q.toBytes(N),T8(z),X),Z=G.multiplyUnsafe(K).add(z.multiplyUnsafe(Q.neg(w))),{x:j,y:R}=Z.toAffine();if(Z.is0()||!A8(R)||j!==N)return!1;return!0}catch(z){return!1}}var u$=(()=>{let q=(G=c0(48))=>{return f$(G,J$.n)};DQ.utils.randomSecretKey;function Q(G){let Y=q(G);return{secretKey:Y,publicKey:jQ(Y)}}return{keygen:Q,getPublicKey:jQ,sign:AJ,verify:VQ,Point:q$,utils:{randomSecretKey:q,randomPrivateKey:q,taggedHash:g$,lift_x:WQ,pointToBytes:T8,numberToBytesBE:e0,bytesToNumberBE:S0,mod:W0},lengths:{secretKey:32,publicKey:32,publicKeyHasPrefix:!1,signature:64,seed:48}}})();var HJ=new TextEncoder,RJ=new TextDecoder,H0=($)=>HJ.encode($),o0=($)=>RJ.decode($),F$=($)=>Array.from($,(J)=>J.toString(16).padStart(2,"0")).join(""),V0=JSON.stringify,p0=JSON.parse,m$=($,J=Number.MAX_SAFE_INTEGER)=>$.split("").reduce((q,Q)=>q+Q.charCodeAt(0),0)%J;var H8="AES-GCM",xJ={},NQ="$",OQ=",",wJ=($)=>{let J=new Uint8Array($),q=32768,Q="";for(let G=0;G<J.length;G+=32768)Q+=String.fromCharCode(...J.subarray(G,G+32768));return btoa(Q)},kJ=($)=>Uint8Array.from(atob($),(J)=>J.charCodeAt(0)).buffer,O$=($)=>xJ[$]??=crypto.subtle.digest("SHA-1",H0($)).then((J)=>{let q=new Uint8Array(J),Q="";for(let G of q)Q+=G.toString(36);return Q}),BQ=async($,J,q)=>{let Q=await crypto.subtle.digest("SHA-256",H0(`${$}:${J}:${q}`));return crypto.subtle.importKey("raw",Q,{name:H8},!1,["encrypt","decrypt"])},TQ=async($,J)=>{let q=crypto.getRandomValues(new Uint8Array(12)),Q=await $,G=await crypto.subtle.encrypt({name:H8,iv:q},Q,H0(J));return`${q.join(OQ)}${NQ}${wJ(G)}`},AQ=async($,J)=>{let[q,Q]=J.split(NQ);if(!q||!Q)throw Error("Invalid encrypted payload format");let G=Uint8Array.from(q.split(OQ),Number),Y=await $,X=await crypto.subtle.decrypt({name:H8,iv:G},Y,kJ(Q));return o0(X)};var B$="GenosRTC",G$=($,J)=>Array.from({length:$},J);var T$=($)=>Array.from(crypto.getRandomValues(new Uint8Array($)),(J)=>"0123456789AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz"[J%62]).join(""),m=T$(20),E0=Promise.all.bind(Promise),HQ=typeof window<"u",{entries:RQ,fromEntries:h$,keys:g9}=Object,xQ=()=>{},T0=($)=>Error(`GenosRTC: ${$}`),A$=(...$)=>$.join("@"),wQ=($,J)=>{let q=[...$],Q=q.length,G=()=>{let Y=Math.sin(J++)*1e4;return Y-Math.floor(Y)};while(Q){let Y=Math.floor(G()*Q--);[q[Q],q[Y]]=[q[Y],q[Q]]}return q};var LJ=5000,kQ="icegatheringstatechange",LQ="offer",CJ="answer",SJ=[...G$(3,($,J)=>`stun:stun${J||""}.l.google.com:19302`),"stun:stun.cloudflare.com:3478"].map(($)=>({urls:$})),c$=($,{rtcConfig:J,rtcPolyfill:q,turnConfig:Q})=>{let G=new(q||RTCPeerConnection)({iceServers:[...SJ,...Q||[]],...J}),Y={},X=!1,U=!1,z,N=(Z)=>Object.assign(Z,{binaryType:"arraybuffer",bufferedAmountLowThreshold:65535,onmessage:(j)=>Y.data?.(j.data),onopen:()=>Y.connect?.(),onclose:()=>Y.close?.(),onerror:(j)=>!j?.error?.message?.includes("User-Initiated Abort")&&Y.error?.(j)}),K=()=>Promise.race([new Promise((Z)=>{let j=()=>{if(G.iceGatheringState==="complete")G.removeEventListener(kQ,j),Z()};G.addEventListener(kQ,j),j()}),new Promise((Z)=>setTimeout(Z,LJ))]).then(()=>({type:G.localDescription.type,sdp:G.localDescription.sdp.replace(/a=ice-options:trickle\s\n/g,"")}));if($?N(z=G.createDataChannel("data")):G.ondatachannel=({channel:Z})=>N(z=Z),G.onnegotiationneeded=async()=>{try{X=!0,await G.setLocalDescription(),Y.signal?.(await K())}catch(Z){Y.error?.(Z)}finally{X=!1}},G.onconnectionstatechange=()=>{if(["disconnected","failed","closed"].includes(G.connectionState))Y.close?.()},G.ontrack=(Z)=>{Y.track?.(Z.track,Z.streams[0]),Y.stream?.(Z.streams[0])},G.onremovestream=(Z)=>Y.stream?.(Z.stream),$&&!G.canTrickleIceCandidates)G.onnegotiationneeded();let w=()=>G.getSenders();return{created:Date.now(),connection:G,get channel(){return z},get isDead(){return G.connectionState==="closed"},async signal(Z){if(z?.readyState==="open"&&!Z.sdp?.includes("a=rtpmap"))return;try{if(Z.type===LQ){if(X||G.signalingState!=="stable"&&!U){if($)return;await E0([G.setLocalDescription({type:"rollback"}),G.setRemoteDescription(Z)])}else await G.setRemoteDescription(Z);await G.setLocalDescription();let j=await K();return Y.signal?.(j),j}if(Z.type===CJ){U=!0;try{await G.setRemoteDescription(Z)}finally{U=!1}}}catch(j){Y.error?.(j)}},sendData:(Z)=>z.send(Z),destroy:()=>{z?.close(),G.close(),X=U=!1},setHandlers:(Z)=>Object.assign(Y,Z),offerPromise:$?new Promise((Z)=>Y.signal=(j)=>j.type===LQ&&Z(j)):Promise.resolve(),addStream:(Z)=>Z.getTracks().forEach((j)=>G.addTrack(j,Z)),removeStream:(Z)=>w().filter((j)=>Z.getTracks().includes(j.track)).forEach((j)=>G.removeTrack(j)),addTrack:(Z,j)=>G.addTrack(Z,j),removeTrack:(Z)=>{let j=w().find((R)=>R.track===Z);if(j)G.removeTrack(j)},replaceTrack:(Z,j)=>w().find((R)=>R.track===Z)?.replaceTrack(j)}};var PJ=Object.getPrototypeOf(Uint8Array),l$=12,CQ=0,o$=CQ+l$,p$=o$+1,R$=p$+1,x$=R$+1,H$=16384-x$,d$=255,R8="bufferedamountlow",Y$=($)=>`@_${$}`,x8=100,IJ=3,EJ=200,SQ=($,J,q)=>{let Q=new Map,G=new Map,Y=new Map,X={},U={},z={},N={},K=new Map,w=(D,M)=>{if(!K.has(D))K.set(D,new Set);K.get(D).add(M)},Z=(D,M)=>K.get(D)?.delete(M),j=(D,...M)=>K.get(D)?.forEach((B)=>B(...M)),R=(D,M)=>{let B=D?Array.isArray(D)?D:[D]:Q.keys();return Array.from(B,(H)=>{let T=Q.get(H);if(!T)return null;return M(H,T)}).filter(Boolean)},k=(D)=>{if(!Q.has(D))return;Q.delete(D),delete X[D],delete U[D],delete z[D],delete N[D],j("peer:leave",D),J(D)},y=(D)=>new Promise((M,B)=>{let H=setTimeout(()=>{D.removeEventListener(R8,T),B(Error(`${B$}: bufferLow timeout`))},5000);function T(){clearTimeout(H),D.removeEventListener(R8,T),M()}D.addEventListener(R8,T)}),b=(D)=>{if(Y.has(D))return Y.get(D);if(!D)throw T0("action type is required");let M=H0(D);if(M.byteLength>l$)throw T0(`❌ "${D}" exceeds ${l$} bytes. Use a shorter name.`);let B=new Uint8Array(l$).map((g,f)=>M[f]||0),H=0,T=new Map([["message",new Set],["progress",new Set]]),C=(g,f)=>T.get(g)?.add(f),c=(g,f)=>T.get(g)?.delete(f),E=async(g,f,h,d)=>{if(h&&typeof h!=="object")throw T0("meta must be object");if(g===void 0)throw T0("data cannot be undefined");let l=g instanceof Blob,s=l||g instanceof ArrayBuffer||g instanceof PJ,Z0=typeof g!=="string";if(h&&!s)throw T0("meta only allowed with binary");let $0=s?new Uint8Array(l?await g.arrayBuffer():g):H0(Z0?V0(g):g),Q0=h?H0(V0(h)):null,t=Math.ceil($0.byteLength/H$)+(h?1:0)||1;if(t>x8)throw T0(`Message too large, exceeds max chunks ${x8}`);let r0=G$(t,(i0,U0)=>{let R0=U0===t-1,A0=h&&U0===0,a0=A0?Q0:$0.subarray(h?(U0-1)*H$:U0*H$,h?U0*H$:(U0+1)*H$),x0=new Uint8Array(x$+a0.byteLength);return x0.set(B),x0.set([H],o$),x0.set([R0|A0<<1|s<<2|Z0<<3],p$),x0.set([Math.round((U0+1)/t*d$)],R$),x0.set(a0,x$),x0});return H=H+1&d$,E0(R(f,async(i0,U0)=>{let{channel:R0}=U0;for(let A0=0;A0<t;A0++){let a0=0;while(R0.bufferedAmount>R0.bufferedAmountLowThreshold){if(a0++>IJ)throw T0(`${B$}: send buffer full, max retries reached for peer ${i0}`);try{await y(R0)}catch(x0){await new Promise((t$)=>setTimeout(t$,EJ))}}if(!Q.has(i0))break;U0.sendData(r0[A0]),d?.(r0[A0][R$]/d$,i0,h)}}))};G.set(D,{listeners:T,send:E});let v={send:E,on:C,off:c};return Y.set(D,v),v},J0=(D,M)=>{try{let B=new Uint8Array(M),H=o0(B.subarray(CQ,o$)).replace(//g,"");if(!G.has(H))return;let[T]=B.subarray(o$,p$),[C]=B.subarray(p$,R$),[c]=B.subarray(R$,x$),E=B.subarray(x$),v=Boolean(C&1),g=Boolean(C&2),f=Boolean(C&4),h=Boolean(C&8),d=G.get(H),l=(X[D]||={})[H]||={};if(l[T]?.chunks?.length>x8)return;let s=l[T]||={chunks:[]};if(g)try{s.meta=p0(o0(E))}catch{return}else s.chunks.push(E);if(d.listeners.get("progress").forEach((Q0)=>{try{Q0(c/d$,D,s.meta)}catch(t){}}),!v)return;let Z0=new Uint8Array(s.chunks.reduce((Q0,t)=>Q0+t.byteLength,0));s.chunks.reduce((Q0,t)=>(Z0.set(t,Q0),Q0+t.byteLength),0),delete l[T];let $0;if(f)$0=Z0;else if(h)try{$0=p0(o0(Z0))}catch{return}else $0=o0(Z0);d.listeners.get("message").forEach((Q0)=>{try{Q0($0,D,s.meta)}catch(t){}})}catch(B){}},u=async()=>{try{await W(""),await new Promise((D)=>setTimeout(D,99))}catch(D){}for(let[D,M]of Q){try{M.destroy()}catch{}Q.delete(D)}q()},{send:X0,on:n}=b(Y$("ping")),{send:q0,on:j0}=b(Y$("pong")),{send:e,on:I}=b(Y$("signal")),{send:r,on:_}=b(Y$("stream")),{send:V,on:L}=b(Y$("track")),{send:W,on:A}=b(Y$("leave"));if($((D,M)=>{if(Q.has(M))return;Q.set(M,D),D.setHandlers({data:(B)=>J0(M,B),stream:(B)=>{j("stream:add",B,M,z[M]),delete z[M]},track:(B,H)=>{j("track:add",B,H,M,N[M]),delete N[M]},signal:(B)=>e(B,M),close:()=>k(M),error:(B)=>{k(M)}}),j("peer:join",M)}),n("message",(D,M)=>q0("",M)),j0("message",(D,M)=>{U[M]?.(),delete U[M]}),I("message",(D,M)=>Q.get(M)?.signal(D)),_("message",(D,M)=>z[M]=D),L("message",(D,M)=>N[M]=D),A("message",(D,M)=>k(M)),HQ)addEventListener("beforeunload",u);return{on:w,off:Z,channel:b,leave:u,ping:async(D)=>{if(!D)throw T0("ping() requires target peer ID");let M=Date.now();return X0("",D),await new Promise((B)=>U[D]=B),Date.now()-M},getPeers:()=>h$(Array.from(Q,([D,M])=>[D,M.connection])),addStream:(D,M,B)=>R(M,async(H,T)=>{if(B)await r(B,H);T.addStream(D)}),removeStream:(D,M)=>R(M,(B,H)=>H.removeStream(D)),addTrack:(D,M,B,H)=>R(B,async(T,C)=>{if(H)await V(H,T);C.addTrack(D,M)}),removeTrack:(D,M)=>R(M,(B,H)=>H.removeTrack(D)),replaceTrack:(D,M,B,H)=>R(B,async(T,C)=>{if(H)await V(H,T);C.replaceTrack(D,M)})}};var vJ=20,fJ=5333,PQ=57333,IQ=({init:$,subscribe:J,announce:q})=>{let Q={},G=!1,Y,X;return(U,z,N)=>{let{appId:K}=U;if(Q[K]?.[z])return Q[K][z];if(!U||!z||!K&&!U.firebaseApp)throw T0(!U?"config required":!z?"roomId required":"appId missing");let w=xQ;if(!G){let _=$(U);X=G$(vJ,()=>c$(!0,U)),Y=Array.isArray(_)?_:[_];let V=setInterval(()=>{X=X.filter((L)=>{let W=Date.now()-L.created<PQ;if(!W)L.destroy();return W})},PQ);Q.offerCleanupTimer||=V,G=!0}let Z={},j={},R=A$(B$,K,z),k=O$(R),y=O$(A$(R,m)),b=BQ(U.password||"",K,z),J0=(_)=>async(V)=>({type:V.type,sdp:await _(b,V.sdp)}),u=J0(AQ),X0=J0(TQ),n=(_,V)=>{if(j[V]===_)return;j[V]?.destroy(),j[V]=_,w(_,V),Z[V]?.forEach((L)=>L!==_&&L.destroy()),delete Z[V]},q0=(_,V)=>{if(j[V]===_)delete j[V]},j0=(_)=>async(V,L,W)=>{let[A,D]=await E0([k,y]);if(V!==A&&V!==D)return;let{peerId:M,offer:B,answer:H}=typeof L==="string"?p0(L):L;if(M===m||j[M])return;if(B){if(Z[M]?.[_]&&m>M)return;let T=c$(!1,U);T.setHandlers({connect:()=>n(T,M),close:()=>q0(T,M)});try{let C=await u(B);if(T.isDead)return;let[c,E]=await E0([O$(A$(R,M)),T.signal(C).then(X0)]);W(c,V0({peerId:m,answer:E}))}catch{N?.({error:"decryption failed (offer)",appId:K,peerId:M,roomId:z})}}else if(H){let T=Z[M]?.[_];if(!T||T.isDead)return;T.setHandlers({connect:()=>n(T,M),close:()=>q0(T,M)});try{T.signal(await u(H))}catch{N?.({error:"decryption failed (answer)",appId:K,peerId:M,roomId:z})}}else{if(Z[M]?.[_])return;let T=X.pop()||c$(!0,U),[C,{offer:c}]=await E0([O$(A$(R,M)),T.offerPromise.then(X0).then((E)=>({offer:E}))]);Z[M]||=[],Z[M][_]=T,T.setHandlers({connect:()=>n(T,M),close:()=>q0(T,M)}),W(C,V0({peerId:m,offer:c,peer:T}))}},e=E0(Y.map(async(_,V)=>J(await _,await k,await y,j0(V)))),I=[];e.then((_)=>{Y.forEach((V,L)=>{let W=async()=>{let A=await q(await V,await k,await y);I[L]=setTimeout(W,typeof A==="number"?A:fJ)};W()}),Q[K][z].onCleanup=()=>{if(delete Q[K][z],I.forEach(clearTimeout),_.forEach((V)=>V()),Object.keys(Q).length===0)clearInterval(Q.offerCleanupTimer),delete Q.offerCleanupTimer}}),Q[K]||={};let r=SQ((_)=>w=_,(_)=>delete j[_],()=>r.onCleanup?.());return Q[K][z]=r}};var EQ=3333,r$={},vQ={},fQ=($,J)=>{let q={},Q=null,G=()=>{if(Q)clearTimeout(Q),Q=null;let Y=new WebSocket($);Y.onclose=()=>{r$[$]??=EQ,Q=setTimeout(G,r$[$]),r$[$]*=2},Y.onmessage=(X)=>J(X.data),q.socket=Y,q.url=Y.url,q.ready=new Promise((X)=>{Y.onopen=()=>{r$[$]=EQ,X(q)}}),q.send=(X)=>{if(Y.readyState===1)Y.send(X)}};return q.forceReconnect=G,G(),vQ[$]=q,q};if(typeof window<"u"){let $=()=>{Object.values(vQ).forEach((J)=>{if(J.socket&&J.socket.readyState!==WebSocket.OPEN&&J.socket.readyState!==WebSocket.CONNECTING)J.forceReconnect()})};window.addEventListener("online",()=>{$()}),window.addEventListener("offline",async()=>{}),document.addEventListener("visibilitychange",()=>{if(document.visibilityState==="visible")$()})}var _Q=($)=>()=>h$(RQ($).map(([J,q])=>[J,q.socket])),bQ=($,J,q,Q)=>($.relayUrls??(Q?wQ(J,m$($.appId)):J)).slice(0,$.relayUrls?.length??$.relayRedundancy??q);var X$={},_J=5,FQ="x",mQ="EVENT",bJ=/pow:\s*(\d+)\s*bits needed\.?/i,w8=new Set,hQ=u$.utils.randomSecretKey(),yJ=F$(u$.getPublicKey(hQ)),k8={},w$={},gJ={},cQ=()=>Math.floor(Date.now()/1000),dQ=($)=>gJ[$]??=m$($,1e4)+20000,i$=($)=>$.replace(/\/$/,""),uJ=["wss://black.nostrcity.club","wss://eu.purplerelay.com","wss://ftp.halifax.rwth-aachen.de/nostr","wss://nostr.data.haus","wss://nostr.mom","wss://nostr.oxtr.dev","wss://nostr.sathoarder.com","wss://nostr.vulpem.com","wss://relay.fountain.fm","wss://relay.mostro.network","wss://relay.nostrdice.com","wss://sendit.nosflare.com","wss://yabu.me/v2","wss://relay.damus.io"],FJ=($,J)=>{let[q,Q,G,Y]=p0(J);if(q===mQ)return w$[Q]?.(k8[Q],G.content);if(q==="NOTICE"||q==="OK"&&!G){if(+((q==="NOTICE"?Q:Y).match(bJ)?.[1]??0)>0){let U=i$($);w8.add(U),X$[U]?.close?.(),delete X$[U]}}},mJ=($)=>{let J=i$($);if(X$[J])return X$[J];let q=fQ(J,(Q)=>FJ(J,Q));return X$[J]=q},yQ=async($,J)=>{let q={kind:dQ($),content:J,pubkey:yJ,created_at:cQ(),tags:[[FQ,$]]},Q=H0(V0([0,q.pubkey,q.created_at,q.kind,q.tags,q.content])),G=new Uint8Array(await crypto.subtle.digest("SHA-256",Q)),Y=u$.sign(G,hQ);return V0([mQ,{...q,id:F$(G),sig:F$(Y)}])},gQ=($,J)=>{return k8[$]=J,V0(["REQ",$,{kinds:[dQ(J)],since:cQ(),["#"+FQ]:[J]}])},uQ=($)=>{return delete k8[$],V0(["CLOSE",$])},lQ=IQ({init:($)=>{let q=($?.relayUrls?.length?$.relayUrls:null)??uJ;return bQ($,q,_J,!0).map(mJ).map((G)=>G.ready.then(()=>G).catch(()=>null))},subscribe:($,J,q,Q)=>{let G=T$(64),Y=T$(64);return w$[G]=w$[Y]=(X,U)=>Q(X,U,async(z,N)=>{if(w8.has(i$($.url)))return;$.send(await yQ(z,N))}),$.send(gQ(G,J)),$.send(gQ(Y,q)),()=>{$.send(uQ(G)),$.send(uQ(Y)),delete w$[G],delete w$[Y]}},announce:async($,J)=>{if(w8.has(i$($.url)))return;$.send(await yQ(J,V0({peerId:m})))}}),hJ=_Q(X$);var cJ={cellSize:"auto",bridgesPerEdge:2,maxCellSize:50,targetCells:100,debug:!1},oQ=5000,dJ=3000,lJ=30000,oJ=2000,s$=($)=>{let J=String($||"").match(/cell-(\d+)/);return J?Number(J[1]):null},Z$=($)=>{let J=s$($);if(J==null)return[];let q=[];if(J>0)q.push(`cell-${J-1}`);return q.push(`cell-${J+1}`),q},a$=($)=>`c${(s$($)||0).toString(36)}`,pJ=($,J,q)=>{if($<=10)return Math.max(2,$);let G=10,Y=Math.ceil($/J);return Math.max(G,Math.min(q,Y))},pQ=($,J)=>{return Math.max(1,Math.ceil($/J))},rJ=($,J,q)=>{let Q=Math.max(1,Math.ceil(J.length/q)),G=Math.ceil(J.length/Q),Y=J.indexOf($);if(Y<0)return 0;return Math.floor(Y/G)};class n${constructor($){this.peerId=$,this.joinedAt=Date.now(),this.lastSeen=Date.now(),this.rttSamples=[],this.stability=1,this.reconnects=0,this.isResponsive=!0,this.connectedCells=new Set}get uptime(){return Date.now()-this.joinedAt}get avgRtt(){if(this.rttSamples.length===0)return 1/0;return Math.round(this.rttSamples.reduce(($,J)=>$+J,0)/this.rttSamples.length)}get healthScore(){let $=this.avgRtt===1/0?0.5:Math.max(0,100-this.avgRtt)/100,J=Math.min(1,this.uptime/60000),q=this.stability,Q=this.isResponsive?1:0.3;return $*0.25+J*0.25+q*0.3+Q*0.2}get isStale(){return Date.now()-this.lastSeen>lJ}addRttSample($){if(this.rttSamples.push($),this.rttSamples.length>10)this.rttSamples.shift();this.lastSeen=Date.now(),this.isResponsive=!0}markReconnect(){this.reconnects++,this.stability=Math.max(0,1-this.reconnects*0.1)}markUnresponsive(){this.isResponsive=!1}markSeen(){this.lastSeen=Date.now()}addConnectedCell($){if($)this.connectedCells.add($)}}function iJ($,J={}){let q={...cJ,...J},Q=!!q.debug,G=(...O)=>Q&&void 0,Y=Math.max(0,q.bridgesPerEdge|0),X=Math.max(5,q.maxCellSize|0),U=Math.max(10,q.targetCells|0),z=q.cellSize==="auto",N=z?2:Math.max(1,q.cellSize|0),K={cellId:null,bridges:[],isBridge:!1},w=null,Z=null,j=null,R=new Map,k=new Map,y=new Set,b=new Map,J0=new Set,u=new Set,X0=0,n=[],q0=new Map,j0=new Set,e=new Map,I=new Map,r=()=>{let O=Math.ceil(f().length/N);return Math.min(150,O+3)},_=$.on?.bind($),V=$.off?.bind($);if(_)$.on=(O,x)=>String(O).startsWith("mesh:")?A(O,x):_(O,x);if(V)$.off=(O,x)=>String(O).startsWith("mesh:")?b.get(O)?.delete(x):V(O,x);let L=(O)=>(y.add(O),()=>y.delete(O)),W=(O,x,S)=>{if(u.has(S))return;if(u.add(S),u.size>oQ){let P=u.values().next().value;u.delete(P)}for(let P of y)try{P(O,x)}catch(F){G("Error in deliver handler:",F)}},A=(O,x)=>{if(!b.has(O))b.set(O,new Set);return b.get(O).add(x),()=>b.get(O)?.delete(x)},D=(O,...x)=>{let S=b.get(O);if(S)for(let P of S)try{P(...x)}catch{}},M=(O)=>{try{return typeof O==="string"?JSON.parse(O):O}catch{return null}},B=()=>`${m}:${Date.now().toString(36)}:${(X0++&65535).toString(36)}`,H=()=>{if(J0.size>oQ)J0.delete(J0.values().next().value)},T=(O,x,S=[])=>{if(!O||!x)return;if(R.set(O,{cell:x,isBridge:S.length>0,bridges:[...S]}),!k.has(O))k.set(O,new n$(O));let P=k.get(O);if(P.markSeen(),P.addConnectedCell(x),I.set(x,{lastSeen:Date.now(),peerId:O}),S.length>0)for(let F of Z$(x))P.addConnectedCell(F)},C=(O)=>k.get(O),c=(O,x)=>{let S=k.get(O);if(S)S.addRttSample(x)},E=(O)=>{let x=$0(O);if(x.length===0)return null;let S=0,P=0;for(let i of x){let z0=k.get(i);if(z0&&!z0.isStale){if(S+=z0.healthScore,z0.isResponsive)P++}}let F=x.filter((i)=>{let z0=k.get(i);return z0&&!z0.isStale});return{cellId:O,memberCount:F.length,avgHealth:F.length>0?S/F.length:0,responsiveRatio:F.length>0?P/F.length:0}},v=()=>{let O=E(K.cellId);D("mesh:health",{...K,health:O})},g=()=>{let O=Object.keys($.getPeers?.()||{}),x=[...O,m].sort();return{peers:O,all:x}},f=()=>{let{all:O}=g();return O.filter((x)=>{if(x===m)return!0;let S=k.get(x);return S&&!S.isStale})},h=()=>{if(!z)return;let O=f().length,x=pJ(O,U,X);if(x!==N)G("cellSize changed:",N,"->",x),N=x},d=(O,x)=>{let S=pQ(x.length,N),P=Math.ceil(x.length/S),F=O*P,i=Math.min(F+P,x.length);return x.slice(F,i)},l=(O,x)=>{if(Y===0)return[];let S=s$(O),P=s$(x);if(S==null||P==null)return[];let F=f(),i=d(S,F),z0=d(P,F),a=[...new Set([...i,...z0])];if(!a.length)return[];let n0=new Set($0(O)),k$=new Set($0(x)),N0=a.filter((D0)=>{if(D0===m)return!0;let w0=k.get(D0);if(!w0||w0.isStale)return!1;let o=n0.has(D0)||w0.connectedCells.has(O),v0=k$.has(D0)||w0.connectedCells.has(x);return o||v0});if(!N0.length)N0.push(...a);let s0=N0.map((D0)=>({id:D0,score:k.get(D0)?.healthScore||0.5}));return s0.sort((D0,w0)=>{let o=w0.score-D0.score;return o!==0?o:D0.id.localeCompare(w0.id)}),s0.slice(0,Y).map((D0)=>D0.id)},s=(O,x)=>{if(Y===0)return[];let S=Z$(x),P=[];for(let F of S)if(l(x,F).includes(O))P.push(F);return P},Z0=()=>{h();let O=f(),x=rJ(m,O,N),S=pQ(O.length,N),P=`cell-${x}`,F=s(m,P),i=F.length>0;return G("computeState",{self:m,myCell:P,isBridge:i,bridgeEdges:F,cellSize:N,rosterSize:O.length,totalCells:S,dynamicTTL:r()}),{cellId:P,isBridge:i,bridges:F,cellSize:N,dynamicTTL:r(),totalCells:S}},$0=(O)=>{let x=[],S=new Set(Object.keys($.getPeers?.()||{}));for(let[P,F]of R)if(F.cell===O){let i=k.get(P);if(S.has(P)&&(!i||!i.isStale))x.push(P)}return x.sort(),x},Q0=()=>{if(!w)return;R0=A0();let O={t:"state",id:B(),ttl:r(),data:{id:m,cell:K.cellId,bridges:K.bridges,health:k.get(m)?.healthScore||0.5,timestamp:Date.now()},origin:m,originCell:K.cellId},x=JSON.stringify(O);w.send(x),t(Z,x)},t=(O,x)=>{let S=M(x);if(!S?.id||!S?.t)return;let P=J0.has(S.id);if(!P)J0.add(S.id),H();let{t:F,id:i,ttl:z0,data:a,origin:n0,originCell:k$}=S,N0=K.cellId;if(F==="state"&&a)T(a.id,a.cell,a.bridges),D("mesh:peer-state",a);if(F==="ping"&&a?.pingId&&n0!==m){let o={t:"pong",id:B(),ttl:r(),data:{pingId:a.pingId,receivedAt:Date.now()},origin:m,originCell:N0};w?.send(JSON.stringify(o))}if(F==="pong"&&a?.pingId){let o=e.get(a.pingId);if(o){clearTimeout(o.timeout);let v0=Date.now()-o.start;c(o.peerId,v0),o.resolve(v0),e.delete(a.pingId)}}if(F==="msg"&&n0!==m){if(k$===N0||Y>0)W(a,n0,i)}if(P)return;if(!K.isBridge)return;if((z0??0)<=0)return;let s0=(o,v0,rQ=null)=>{if(!o)return;let iQ={t:F,id:i,ttl:rQ??(z0??r())-1,data:a,origin:n0||m,originCell:k$||N0},L8=JSON.stringify(iQ);if(v0?.length){let aQ=new Set(Object.keys($.getPeers?.()||{})),C8=v0.filter((nQ)=>aQ.has(nQ));if(C8.length>0)o.send(L8,C8)}else o.send(L8)};if(O===Z){for(let o of Z$(N0))s0(r0(o),null);return}if(!Z$(N0).map(a$).includes(O))return;let w0=$0(N0);s0(w,w0);for(let o of Z$(N0))if(a$(o)!==O)s0(r0(o),null)},r0=(O)=>{let x=a$(O);if(q0.has(O))return q0.get(O);let S=$.channel(x);if(q0.set(O,S),!j0.has(x))j0.add(x),S.on("message",(P)=>t(x,P));return S},i0=()=>{if(!K.cellId)return;if(Z=a$(K.cellId),w=$.channel(Z),!j0.has(Z))j0.add(Z),w.on("message",(O)=>t(Z,O));if(K.isBridge)for(let O of Z$(K.cellId))r0(O);if(n.length){let O=$0(K.cellId);for(let x of n.splice(0)){let S={t:"msg",id:B(),ttl:r(),data:x,origin:m,originCell:K.cellId},P=JSON.stringify(S);O.length?w.send(P,O):w.send(P),t(Z,P)}}Q0()},U0=()=>{let O=Z0(),x=!K.cellId||K.cellId!==O.cellId||K.isBridge!==O.isBridge||JSON.stringify(K.bridges)!==JSON.stringify(O.bridges);if(K=O,T(m,O.cellId,O.bridges),x)i0();else Q0();D("mesh:state",O),v()},R0="",A0=()=>{return`${K.cellId}:${K.isBridge}:${K.bridges.join(",")}`},a0=()=>{if(j)return;j=setInterval(()=>{let O=A0();if(O!==R0)Q0(),R0=O;for(let[x,S]of k)if(x!==m&&S.isStale)R.delete(x),k.delete(x),G("Removed stale peer:",x)},oJ)},x0=()=>{if(j)clearInterval(j),j=null},t$=(O)=>{return new Promise((x,S)=>{let P=`${Date.now()}-${Math.random().toString(36).slice(2,8)}`,F=Date.now(),i=setTimeout(()=>{e.delete(P);let a=k.get(O);if(a)a.markUnresponsive();S(Error("Ping timeout"))},dJ);e.set(P,{start:F,resolve:x,reject:S,timeout:i,peerId:O});let z0={t:"ping",id:B(),ttl:r(),data:{pingId:P,target:O},origin:m,originCell:K.cellId};w?.send(JSON.stringify(z0))})};if($.on?.("peer:join",(O)=>{if(!k.has(O))k.set(O,new n$(O));else k.get(O).markReconnect();U0()}),$.on?.("peer:leave",(O)=>{R.delete(O),U0()}),!k.has(m))k.set(m,new n$(m));return k.get(m).addConnectedCell(K.cellId||"cell-0"),U0(),a0(),{send:(O)=>{if(!K.cellId||!w)return n.push(O);let x=$0(K.cellId),S={t:"msg",id:B(),ttl:r(),data:O,origin:m,originCell:K.cellId},P=JSON.stringify(S);x.length?w.send(P,x):w.send(P),t(Z,P)},on:(O,x)=>O==="message"?L(x):void 0,ping:t$,getState:()=>({...K,cellSize:N,health:E(K.cellId),dynamicTTL:r(),totalCells:Math.ceil(f().length/N),knownCells:I.size}),getMetrics:C,getCellHealth:E,getPeerInfo:()=>new Map(R),getStableRoster:()=>f(),getKnownCells:()=>new Map(I),getCellSize:()=>N,destroy:()=>{x0(),e.forEach((O)=>clearTimeout(O.timeout)),e.clear(),u.clear(),I.clear()}}}function Xq($,J,q){let Q=lQ($,J,q),G=$.overlay||{},Y=iJ(Q,G),X=new Map;return{on:(U,z)=>Q.on(U,z),off:(U,z)=>Q.off?.(U,z),channel:(U)=>{if(X.has(U))return X.get(U);let z=Q.channel(U),N={send:(K,w)=>{Y.send({_ch:U,_d:K,_t:w})},on:(K,w)=>{if(K==="message")Y.on("message",(Z,j)=>{if(Z?._ch===U)w(Z._d,j)}),z.on(K,w);else z.on(K,w)},off:(K,w)=>z.off?.(K,w),_original:z};return X.set(U,N),N},get id(){return Q.id},get peers(){return Q.peers},getPeers:()=>Q.getPeers?.()||{},mesh:Y,_room:Q,getState:()=>Y.getState(),getMetrics:(U)=>Y.getMetrics(U),getCellHealth:(U)=>Y.getCellHealth(U),getPeerInfo:()=>Y.getPeerInfo(),ping:(U)=>Y.ping(U),destroy:()=>{Y.destroy(),X.clear()}}}export{m as selfId,Xq as join,hJ as getRelaySockets,cJ as OVERLAY_DEFAULTS};
1
+ var u0=typeof globalThis==="object"&&"crypto"in globalThis?globalThis.crypto:void 0;/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */function F0($){return $ instanceof Uint8Array||ArrayBuffer.isView($)&&$.constructor.name==="Uint8Array"}function U$($){if(!Number.isSafeInteger($)||$<0)throw Error("positive integer expected, got "+$)}function O0($,...J){if(!F0($))throw Error("Uint8Array expected");if(J.length>0&&!J.includes($.length))throw Error("Uint8Array expected of length "+J+", got length="+$.length)}function L$($){if(typeof $!=="function"||typeof $.create!=="function")throw Error("Hash should be wrapped by utils.createHasher");U$($.outputLen),U$($.blockLen)}function t0($,J=!0){if($.destroyed)throw Error("Hash instance has been destroyed");if(J&&$.finished)throw Error("Hash#digest() has already been called")}function P8($,J){O0($);let q=J.outputLen;if($.length<q)throw Error("digestInto() expects output buffer of length at least "+q)}function m0(...$){for(let J=0;J<$.length;J++)$[J].fill(0)}function C$($){return new DataView($.buffer,$.byteOffset,$.byteLength)}function B0($,J){return $<<32-J|$>>>J}var I8=(()=>typeof Uint8Array.from([]).toHex==="function"&&typeof Uint8Array.fromHex==="function")(),sQ=Array.from({length:256},($,J)=>J.toString(16).padStart(2,"0"));function L0($){if(O0($),I8)return $.toHex();let J="";for(let q=0;q<$.length;q++)J+=sQ[$[q]];return J}var k0={_0:48,_9:57,A:65,F:70,a:97,f:102};function S8($){if($>=k0._0&&$<=k0._9)return $-k0._0;if($>=k0.A&&$<=k0.F)return $-(k0.A-10);if($>=k0.a&&$<=k0.f)return $-(k0.a-10);return}function h0($){if(typeof $!=="string")throw Error("hex string expected, got "+typeof $);if(I8)return Uint8Array.fromHex($);let J=$.length,q=J/2;if(J%2)throw Error("hex string expected, got unpadded hex of length "+J);let Q=new Uint8Array(q);for(let G=0,Y=0;G<q;G++,Y+=2){let X=S8($.charCodeAt(Y)),U=S8($.charCodeAt(Y+1));if(X===void 0||U===void 0){let z=$[Y]+$[Y+1];throw Error('hex string expected, got non-hex character "'+z+'" at index '+Y)}Q[G]=X*16+U}return Q}function S$($){if(typeof $!=="string")throw Error("string expected");return new Uint8Array(new TextEncoder().encode($))}function z$($){if(typeof $==="string")$=S$($);return O0($),$}function K0(...$){let J=0;for(let Q=0;Q<$.length;Q++){let G=$[Q];O0(G),J+=G.length}let q=new Uint8Array(J);for(let Q=0,G=0;Q<$.length;Q++){let Y=$[Q];q.set(Y,G),G+=Y.length}return q}class K${}function E8($){let J=(Q)=>$().update(z$(Q)).digest(),q=$();return J.outputLen=q.outputLen,J.blockLen=q.blockLen,J.create=()=>$(),J}function c0($=32){if(u0&&typeof u0.getRandomValues==="function")return u0.getRandomValues(new Uint8Array($));if(u0&&typeof u0.randomBytes==="function")return Uint8Array.from(u0.randomBytes($));throw Error("crypto.getRandomValues must be defined")}function tQ($,J,q,Q){if(typeof $.setBigUint64==="function")return $.setBigUint64(J,q,Q);let G=BigInt(32),Y=BigInt(4294967295),X=Number(q>>G&Y),U=Number(q&Y),z=Q?4:0,N=Q?0:4;$.setUint32(J+z,X,Q),$.setUint32(J+N,U,Q)}function v8($,J,q){return $&J^~$&q}function f8($,J,q){return $&J^$&q^J&q}class e$ extends K${constructor($,J,q,Q){super();this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=$,this.outputLen=J,this.padOffset=q,this.isLE=Q,this.buffer=new Uint8Array($),this.view=C$(this.buffer)}update($){t0(this),$=z$($),O0($);let{view:J,buffer:q,blockLen:Q}=this,G=$.length;for(let Y=0;Y<G;){let X=Math.min(Q-this.pos,G-Y);if(X===Q){let U=C$($);for(;Q<=G-Y;Y+=Q)this.process(U,Y);continue}if(q.set($.subarray(Y,Y+X),this.pos),this.pos+=X,Y+=X,this.pos===Q)this.process(J,0),this.pos=0}return this.length+=$.length,this.roundClean(),this}digestInto($){t0(this),P8($,this),this.finished=!0;let{buffer:J,view:q,blockLen:Q,isLE:G}=this,{pos:Y}=this;if(J[Y++]=128,m0(this.buffer.subarray(Y)),this.padOffset>Q-Y)this.process(q,0),Y=0;for(let K=Y;K<Q;K++)J[K]=0;tQ(q,Q-8,BigInt(this.length*8),G),this.process(q,0);let X=C$($),U=this.outputLen;if(U%4)throw Error("_sha2: outputLen should be aligned to 32bit");let z=U/4,N=this.get();if(z>N.length)throw Error("_sha2: outputLen bigger than state");for(let K=0;K<z;K++)X.setUint32(4*K,N[K],G)}digest(){let{buffer:$,outputLen:J}=this;this.digestInto($);let q=$.slice(0,J);return this.destroy(),q}_cloneInto($){$||($=new this.constructor),$.set(...this.get());let{blockLen:J,buffer:q,length:Q,finished:G,destroyed:Y,pos:X}=this;if($.destroyed=Y,$.finished=G,$.length=Q,$.pos=X,Q%J)$.buffer.set(q);return $}clone(){return this._cloneInto()}}var C0=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var eQ=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]),f0=new Uint32Array(64);class _8 extends e${constructor($=32){super(64,$,8,!1);this.A=C0[0]|0,this.B=C0[1]|0,this.C=C0[2]|0,this.D=C0[3]|0,this.E=C0[4]|0,this.F=C0[5]|0,this.G=C0[6]|0,this.H=C0[7]|0}get(){let{A:$,B:J,C:q,D:Q,E:G,F:Y,G:X,H:U}=this;return[$,J,q,Q,G,Y,X,U]}set($,J,q,Q,G,Y,X,U){this.A=$|0,this.B=J|0,this.C=q|0,this.D=Q|0,this.E=G|0,this.F=Y|0,this.G=X|0,this.H=U|0}process($,J){for(let K=0;K<16;K++,J+=4)f0[K]=$.getUint32(J,!1);for(let K=16;K<64;K++){let w=f0[K-15],Z=f0[K-2],j=B0(w,7)^B0(w,18)^w>>>3,T=B0(Z,17)^B0(Z,19)^Z>>>10;f0[K]=T+f0[K-7]+j+f0[K-16]|0}let{A:q,B:Q,C:G,D:Y,E:X,F:U,G:z,H:N}=this;for(let K=0;K<64;K++){let w=B0(X,6)^B0(X,11)^B0(X,25),Z=N+w+v8(X,U,z)+eQ[K]+f0[K]|0,T=(B0(q,2)^B0(q,13)^B0(q,22))+f8(q,Q,G)|0;N=z,z=U,U=X,X=Y+Z|0,Y=G,G=Q,Q=q,q=Z+T|0}q=q+this.A|0,Q=Q+this.B|0,G=G+this.C|0,Y=Y+this.D|0,X=X+this.E|0,U=U+this.F|0,z=z+this.G|0,N=N+this.H|0,this.set(q,Q,G,Y,X,U,z,N)}roundClean(){m0(f0)}destroy(){this.set(0,0,0,0,0,0,0,0),m0(this.buffer)}}var P$=E8(()=>new _8);class $8 extends K${constructor($,J){super();this.finished=!1,this.destroyed=!1,L$($);let q=z$(J);if(this.iHash=$.create(),typeof this.iHash.update!=="function")throw Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let Q=this.blockLen,G=new Uint8Array(Q);G.set(q.length>Q?$.create().update(q).digest():q);for(let Y=0;Y<G.length;Y++)G[Y]^=54;this.iHash.update(G),this.oHash=$.create();for(let Y=0;Y<G.length;Y++)G[Y]^=106;this.oHash.update(G),m0(G)}update($){return t0(this),this.iHash.update($),this}digestInto($){t0(this),O0($,this.outputLen),this.finished=!0,this.iHash.digestInto($),this.oHash.update($),this.oHash.digestInto($),this.destroy()}digest(){let $=new Uint8Array(this.oHash.outputLen);return this.digestInto($),$}_cloneInto($){$||($=Object.create(Object.getPrototypeOf(this),{}));let{oHash:J,iHash:q,finished:Q,destroyed:G,blockLen:Y,outputLen:X}=this;return $=$,$.finished=Q,$.destroyed=G,$.blockLen=Y,$.outputLen=X,$.oHash=J._cloneInto($.oHash),$.iHash=q._cloneInto($.iHash),$}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}}var Q8=($,J,q)=>new $8($,J).update(q).digest();Q8.create=($,J)=>new $8($,J);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var G8=BigInt(0),q8=BigInt(1);function j$($,J=""){if(typeof $!=="boolean"){let q=J&&`"${J}"`;throw Error(q+"expected boolean, got type="+typeof $)}return $}function _0($,J,q=""){let Q=F0($),G=$?.length,Y=J!==void 0;if(!Q||Y&&G!==J){let X=q&&`"${q}" `,U=Y?` of length ${J}`:"",z=Q?`length=${G}`:`type=${typeof $}`;throw Error(X+"expected Uint8Array"+U+", got "+z)}return $}function D$($){let J=$.toString(16);return J.length&1?"0"+J:J}function b8($){if(typeof $!=="string")throw Error("hex string expected, got "+typeof $);return $===""?G8:BigInt("0x"+$)}function S0($){return b8(L0($))}function Y8($){return O0($),b8(L0(Uint8Array.from($).reverse()))}function e0($,J){return h0($.toString(16).padStart(J*2,"0"))}function X8($,J){return e0($,J).reverse()}function p($,J,q){let Q;if(typeof J==="string")try{Q=h0(J)}catch(Y){throw Error($+" must be hex string or Uint8Array, cause: "+Y)}else if(F0(J))Q=Uint8Array.from(J);else throw Error($+" must be hex string or Uint8Array");let G=Q.length;if(typeof q==="number"&&G!==q)throw Error($+" of length "+q+" expected, got "+G);return Q}var J8=($)=>typeof $==="bigint"&&G8<=$;function W$($,J,q){return J8($)&&J8(J)&&J8(q)&&J<=$&&$<q}function y8($,J,q,Q){if(!W$(J,q,Q))throw Error("expected valid "+$+": "+q+" <= n < "+Q+", got "+J)}function I$($){let J;for(J=0;$>G8;$>>=q8,J+=1);return J}var b0=($)=>(q8<<BigInt($))-q8;function g8($,J,q){if(typeof $!=="number"||$<2)throw Error("hashLen must be a number");if(typeof J!=="number"||J<2)throw Error("qByteLen must be a number");if(typeof q!=="function")throw Error("hmacFn must be a function");let Q=(j)=>new Uint8Array(j),G=(j)=>Uint8Array.of(j),Y=Q($),X=Q($),U=0,z=()=>{Y.fill(1),X.fill(0),U=0},N=(...j)=>q(X,Y,...j),K=(j=Q(0))=>{if(X=N(G(0),j),Y=N(),j.length===0)return;X=N(G(1),j),Y=N()},w=()=>{if(U++>=1000)throw Error("drbg: tried 1000 values");let j=0,T=[];while(j<J){Y=N();let L=Y.slice();T.push(L),j+=Y.length}return K0(...T)};return(j,T)=>{z(),K(j);let L=void 0;while(!(L=T(w())))K();return z(),L}}function M$($,J,q={}){if(!$||typeof $!=="object")throw Error("expected valid options object");function Q(G,Y,X){let U=$[G];if(X&&U===void 0)return;let z=typeof U;if(z!==Y||U===null)throw Error(`param "${G}" is invalid: expected ${Y}, got ${z}`)}Object.entries(J).forEach(([G,Y])=>Q(G,Y,!1)),Object.entries(q).forEach(([G,Y])=>Q(G,Y,!0))}function Z8($){let J=new WeakMap;return(q,...Q)=>{let G=J.get(q);if(G!==void 0)return G;let Y=$(q,...Q);return J.set(q,Y),Y}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var Y0=BigInt(0),G0=BigInt(1),d0=BigInt(2),m8=BigInt(3),h8=BigInt(4),c8=BigInt(5),$J=BigInt(7),d8=BigInt(8),QJ=BigInt(9),l8=BigInt(16);function W0($,J){let q=$%J;return q>=Y0?q:J+q}function M0($,J,q){let Q=$;while(J-- >Y0)Q*=Q,Q%=q;return Q}function u8($,J){if($===Y0)throw Error("invert: expected non-zero number");if(J<=Y0)throw Error("invert: expected positive modulus, got "+J);let q=W0($,J),Q=J,G=Y0,Y=G0,X=G0,U=Y0;while(q!==Y0){let N=Q/q,K=Q%q,w=G-X*N,Z=Y-U*N;Q=q,q=K,G=X,Y=U,X=w,U=Z}if(Q!==G0)throw Error("invert: does not exist");return W0(G,J)}function U8($,J,q){if(!$.eql($.sqr(J),q))throw Error("Cannot find square root")}function o8($,J){let q=($.ORDER+G0)/h8,Q=$.pow(J,q);return U8($,Q,J),Q}function JJ($,J){let q=($.ORDER-c8)/d8,Q=$.mul(J,d0),G=$.pow(Q,q),Y=$.mul(J,G),X=$.mul($.mul(Y,d0),G),U=$.mul(Y,$.sub(X,$.ONE));return U8($,U,J),U}function qJ($){let J=y0($),q=p8($),Q=q(J,J.neg(J.ONE)),G=q(J,Q),Y=q(J,J.neg(Q)),X=($+$J)/l8;return(U,z)=>{let N=U.pow(z,X),K=U.mul(N,Q),w=U.mul(N,G),Z=U.mul(N,Y),j=U.eql(U.sqr(K),z),T=U.eql(U.sqr(w),z);N=U.cmov(N,K,j),K=U.cmov(Z,w,T);let L=U.eql(U.sqr(K),z),g=U.cmov(N,K,L);return U8(U,g,z),g}}function p8($){if($<m8)throw Error("sqrt is not defined for small field");let J=$-G0,q=0;while(J%d0===Y0)J/=d0,q++;let Q=d0,G=y0($);while(F8(G,Q)===1)if(Q++>1000)throw Error("Cannot find square root: probably non-prime P");if(q===1)return o8;let Y=G.pow(Q,J),X=(J+G0)/d0;return function(z,N){if(z.is0(N))return N;if(F8(z,N)!==1)throw Error("Cannot find square root");let K=q,w=z.mul(z.ONE,Y),Z=z.pow(N,J),j=z.pow(N,X);while(!z.eql(Z,z.ONE)){if(z.is0(Z))return z.ZERO;let T=1,L=z.sqr(Z);while(!z.eql(L,z.ONE))if(T++,L=z.sqr(L),T===K)throw Error("Cannot find square root");let g=G0<<BigInt(K-T-1),b=z.pow(w,g);K=T,w=z.sqr(b),Z=z.mul(Z,w),j=z.mul(j,b)}return j}}function GJ($){if($%h8===m8)return o8;if($%d8===c8)return JJ;if($%l8===QJ)return qJ($);return p8($)}var YJ=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function z8($){let J={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},q=YJ.reduce((Q,G)=>{return Q[G]="function",Q},J);return M$($,q),$}function XJ($,J,q){if(q<Y0)throw Error("invalid exponent, negatives unsupported");if(q===Y0)return $.ONE;if(q===G0)return J;let Q=$.ONE,G=J;while(q>Y0){if(q&G0)Q=$.mul(Q,G);G=$.sqr(G),q>>=G0}return Q}function E$($,J,q=!1){let Q=Array(J.length).fill(q?$.ZERO:void 0),G=J.reduce((X,U,z)=>{if($.is0(U))return X;return Q[z]=X,$.mul(X,U)},$.ONE),Y=$.inv(G);return J.reduceRight((X,U,z)=>{if($.is0(U))return X;return Q[z]=$.mul(X,Q[z]),$.mul(X,U)},Y),Q}function F8($,J){let q=($.ORDER-G0)/d0,Q=$.pow(J,q),G=$.eql(Q,$.ONE),Y=$.eql(Q,$.ZERO),X=$.eql(Q,$.neg($.ONE));if(!G&&!Y&&!X)throw Error("invalid Legendre symbol result");return G?1:Y?0:-1}function v$($,J){if(J!==void 0)U$(J);let q=J!==void 0?J:$.toString(2).length,Q=Math.ceil(q/8);return{nBitLength:q,nByteLength:Q}}function y0($,J,q=!1,Q={}){if($<=Y0)throw Error("invalid field: expected ORDER > 0, got "+$);let G=void 0,Y=void 0,X=!1,U=void 0;if(typeof J==="object"&&J!=null){if(Q.sqrt||q)throw Error("cannot specify opts in two arguments");let Z=J;if(Z.BITS)G=Z.BITS;if(Z.sqrt)Y=Z.sqrt;if(typeof Z.isLE==="boolean")q=Z.isLE;if(typeof Z.modFromBytes==="boolean")X=Z.modFromBytes;U=Z.allowedLengths}else{if(typeof J==="number")G=J;if(Q.sqrt)Y=Q.sqrt}let{nBitLength:z,nByteLength:N}=v$($,G);if(N>2048)throw Error("invalid field: expected ORDER of <= 2048 bytes");let K,w=Object.freeze({ORDER:$,isLE:q,BITS:z,BYTES:N,MASK:b0(z),ZERO:Y0,ONE:G0,allowedLengths:U,create:(Z)=>W0(Z,$),isValid:(Z)=>{if(typeof Z!=="bigint")throw Error("invalid field element: expected bigint, got "+typeof Z);return Y0<=Z&&Z<$},is0:(Z)=>Z===Y0,isValidNot0:(Z)=>!w.is0(Z)&&w.isValid(Z),isOdd:(Z)=>(Z&G0)===G0,neg:(Z)=>W0(-Z,$),eql:(Z,j)=>Z===j,sqr:(Z)=>W0(Z*Z,$),add:(Z,j)=>W0(Z+j,$),sub:(Z,j)=>W0(Z-j,$),mul:(Z,j)=>W0(Z*j,$),pow:(Z,j)=>XJ(w,Z,j),div:(Z,j)=>W0(Z*u8(j,$),$),sqrN:(Z)=>Z*Z,addN:(Z,j)=>Z+j,subN:(Z,j)=>Z-j,mulN:(Z,j)=>Z*j,inv:(Z)=>u8(Z,$),sqrt:Y||((Z)=>{if(!K)K=GJ($);return K(w,Z)}),toBytes:(Z)=>q?X8(Z,N):e0(Z,N),fromBytes:(Z,j=!0)=>{if(U){if(!U.includes(Z.length)||Z.length>N)throw Error("Field.fromBytes: expected "+U+" bytes, got "+Z.length);let L=new Uint8Array(N);L.set(Z,q?0:L.length-Z.length),Z=L}if(Z.length!==N)throw Error("Field.fromBytes: expected "+N+" bytes, got "+Z.length);let T=q?Y8(Z):S0(Z);if(X)T=W0(T,$);if(!j){if(!w.isValid(T))throw Error("invalid field element: outside of range 0..ORDER")}return T},invertBatch:(Z)=>E$(w,Z),cmov:(Z,j,T)=>T?j:Z});return Object.freeze(w)}function r8($){if(typeof $!=="bigint")throw Error("field order must be bigint");let J=$.toString(2).length;return Math.ceil(J/8)}function K8($){let J=r8($);return J+Math.ceil(J/2)}function f$($,J,q=!1){let Q=$.length,G=r8(J),Y=K8(J);if(Q<16||Q<Y||Q>1024)throw Error("expected "+Y+"-1024 bytes of input, got "+Q);let X=q?Y8($):S0($),U=W0(X,J-G0)+G0;return q?X8(U,G):e0(U,G)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var $$=BigInt(0),l0=BigInt(1);function V$($,J){let q=J.negate();return $?q:J}function _$($,J){let q=E$($.Fp,J.map((Q)=>Q.Z));return J.map((Q,G)=>$.fromAffine(Q.toAffine(q[G])))}function s8($,J){if(!Number.isSafeInteger($)||$<=0||$>J)throw Error("invalid window size, expected [1.."+J+"], got W="+$)}function j8($,J){s8($,J);let q=Math.ceil(J/$)+1,Q=2**($-1),G=2**$,Y=b0($),X=BigInt($);return{windows:q,windowSize:Q,mask:Y,maxNumber:G,shiftBy:X}}function i8($,J,q){let{windowSize:Q,mask:G,maxNumber:Y,shiftBy:X}=q,U=Number($&G),z=$>>X;if(U>Q)U-=Y,z+=l0;let N=J*Q,K=N+Math.abs(U)-1,w=U===0,Z=U<0,j=J%2!==0;return{nextN:z,offset:K,isZero:w,isNeg:Z,isNegF:j,offsetF:N}}function ZJ($,J){if(!Array.isArray($))throw Error("array expected");$.forEach((q,Q)=>{if(!(q instanceof J))throw Error("invalid point at index "+Q)})}function UJ($,J){if(!Array.isArray($))throw Error("array of scalars expected");$.forEach((q,Q)=>{if(!J.isValid(q))throw Error("invalid scalar at index "+Q)})}var D8=new WeakMap,t8=new WeakMap;function W8($){return t8.get($)||1}function a8($){if($!==$$)throw Error("invalid wNAF")}class M8{constructor($,J){this.BASE=$.BASE,this.ZERO=$.ZERO,this.Fn=$.Fn,this.bits=J}_unsafeLadder($,J,q=this.ZERO){let Q=$;while(J>$$){if(J&l0)q=q.add(Q);Q=Q.double(),J>>=l0}return q}precomputeWindow($,J){let{windows:q,windowSize:Q}=j8(J,this.bits),G=[],Y=$,X=Y;for(let U=0;U<q;U++){X=Y,G.push(X);for(let z=1;z<Q;z++)X=X.add(Y),G.push(X);Y=X.double()}return G}wNAF($,J,q){if(!this.Fn.isValid(q))throw Error("invalid scalar");let Q=this.ZERO,G=this.BASE,Y=j8($,this.bits);for(let X=0;X<Y.windows;X++){let{nextN:U,offset:z,isZero:N,isNeg:K,isNegF:w,offsetF:Z}=i8(q,X,Y);if(q=U,N)G=G.add(V$(w,J[Z]));else Q=Q.add(V$(K,J[z]))}return a8(q),{p:Q,f:G}}wNAFUnsafe($,J,q,Q=this.ZERO){let G=j8($,this.bits);for(let Y=0;Y<G.windows;Y++){if(q===$$)break;let{nextN:X,offset:U,isZero:z,isNeg:N}=i8(q,Y,G);if(q=X,z)continue;else{let K=J[U];Q=Q.add(N?K.negate():K)}}return a8(q),Q}getPrecomputes($,J,q){let Q=D8.get(J);if(!Q){if(Q=this.precomputeWindow(J,$),$!==1){if(typeof q==="function")Q=q(Q);D8.set(J,Q)}}return Q}cached($,J,q){let Q=W8($);return this.wNAF(Q,this.getPrecomputes(Q,$,q),J)}unsafe($,J,q,Q){let G=W8($);if(G===1)return this._unsafeLadder($,J,Q);return this.wNAFUnsafe(G,this.getPrecomputes(G,$,q),J,Q)}createCache($,J){s8(J,this.bits),t8.set($,J),D8.delete($)}hasCache($){return W8($)!==1}}function e8($,J,q,Q){let G=J,Y=$.ZERO,X=$.ZERO;while(q>$$||Q>$$){if(q&l0)Y=Y.add(G);if(Q&l0)X=X.add(G);G=G.double(),q>>=l0,Q>>=l0}return{p1:Y,p2:X}}function $Q($,J,q,Q){ZJ(q,$),UJ(Q,J);let G=q.length,Y=Q.length;if(G!==Y)throw Error("arrays of points and scalars must have equal length");let X=$.ZERO,U=I$(BigInt(G)),z=1;if(U>12)z=U-3;else if(U>4)z=U-2;else if(U>0)z=2;let N=b0(z),K=Array(Number(N)+1).fill(X),w=Math.floor((J.BITS-1)/z)*z,Z=X;for(let j=w;j>=0;j-=z){K.fill(X);for(let L=0;L<Y;L++){let g=Q[L],b=Number(g>>BigInt(j)&N);K[b]=K[b].add(q[L])}let T=X;for(let L=K.length-1,g=X;L>0;L--)g=g.add(K[L]),T=T.add(g);if(Z=Z.add(T),j!==0)for(let L=0;L<z;L++)Z=Z.double()}return Z}function n8($,J,q){if(J){if(J.ORDER!==$)throw Error("Field.ORDER must match order: Fp == p, Fn == n");return z8(J),J}else return y0($,{isLE:q})}function QQ($,J,q={},Q){if(Q===void 0)Q=$==="edwards";if(!J||typeof J!=="object")throw Error(`expected valid ${$} CURVE object`);for(let z of["p","n","h"]){let N=J[z];if(!(typeof N==="bigint"&&N>$$))throw Error(`CURVE.${z} must be positive bigint`)}let G=n8(J.p,q.Fp,Q),Y=n8(J.n,q.Fn,Q),U=["Gx","Gy","a",$==="weierstrass"?"b":"d"];for(let z of U)if(!G.isValid(J[z]))throw Error(`CURVE.${z} must be valid field element of CURVE.Fp`);return J=Object.freeze(Object.assign({},J)),{CURVE:J,Fp:G,Fn:Y}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var JQ=($,J)=>($+($>=0?J:-J)/GQ)/J;function zJ($,J,q){let[[Q,G],[Y,X]]=J,U=JQ(X*$,q),z=JQ(-G*$,q),N=$-U*Q-z*Y,K=-U*G-z*X,w=N<I0,Z=K<I0;if(w)N=-N;if(Z)K=-K;let j=b0(Math.ceil(I$(q)/2))+Q$;if(N<I0||N>=j||K<I0||K>=j)throw Error("splitScalar (endomorphism): failed, k="+$);return{k1neg:w,k1:N,k2neg:Z,k2:K}}function N8($){if(!["compact","recovered","der"].includes($))throw Error('Signature format must be "compact", "recovered", or "der"');return $}function V8($,J){let q={};for(let Q of Object.keys(J))q[Q]=$[Q]===void 0?J[Q]:$[Q];if(j$(q.lowS,"lowS"),j$(q.prehash,"prehash"),q.format!==void 0)N8(q.format);return q}class qQ extends Error{constructor($=""){super($)}}var P0={Err:qQ,_tlv:{encode:($,J)=>{let{Err:q}=P0;if($<0||$>256)throw new q("tlv.encode: wrong tag");if(J.length&1)throw new q("tlv.encode: unpadded data");let Q=J.length/2,G=D$(Q);if(G.length/2&128)throw new q("tlv.encode: long form length too big");let Y=Q>127?D$(G.length/2|128):"";return D$($)+Y+G+J},decode($,J){let{Err:q}=P0,Q=0;if($<0||$>256)throw new q("tlv.encode: wrong tag");if(J.length<2||J[Q++]!==$)throw new q("tlv.decode: wrong tlv");let G=J[Q++],Y=!!(G&128),X=0;if(!Y)X=G;else{let z=G&127;if(!z)throw new q("tlv.decode(long): indefinite length not supported");if(z>4)throw new q("tlv.decode(long): byte length is too big");let N=J.subarray(Q,Q+z);if(N.length!==z)throw new q("tlv.decode: length bytes not complete");if(N[0]===0)throw new q("tlv.decode(long): zero leftmost byte");for(let K of N)X=X<<8|K;if(Q+=z,X<128)throw new q("tlv.decode(long): not minimal encoding")}let U=J.subarray(Q,Q+X);if(U.length!==X)throw new q("tlv.decode: wrong value length");return{v:U,l:J.subarray(Q+X)}}},_int:{encode($){let{Err:J}=P0;if($<I0)throw new J("integer: negative integers are not allowed");let q=D$($);if(Number.parseInt(q[0],16)&8)q="00"+q;if(q.length&1)throw new J("unexpected DER parsing assertion: unpadded hex");return q},decode($){let{Err:J}=P0;if($[0]&128)throw new J("invalid signature integer: negative");if($[0]===0&&!($[1]&128))throw new J("invalid signature integer: unnecessary leading zero");return S0($)}},toSig($){let{Err:J,_int:q,_tlv:Q}=P0,G=p("signature",$),{v:Y,l:X}=Q.decode(48,G);if(X.length)throw new J("invalid signature: left bytes after parsing");let{v:U,l:z}=Q.decode(2,Y),{v:N,l:K}=Q.decode(2,z);if(K.length)throw new J("invalid signature: left bytes after parsing");return{r:q.decode(U),s:q.decode(N)}},hexFromSig($){let{_tlv:J,_int:q}=P0,Q=J.encode(2,q.encode($.r)),G=J.encode(2,q.encode($.s)),Y=Q+G;return J.encode(48,Y)}},I0=BigInt(0),Q$=BigInt(1),GQ=BigInt(2),b$=BigInt(3),KJ=BigInt(4);function g0($,J){let{BYTES:q}=$,Q;if(typeof J==="bigint")Q=J;else{let G=p("private key",J);try{Q=$.fromBytes(G)}catch(Y){throw Error(`invalid private key: expected ui8a of size ${q}, got ${typeof J}`)}}if(!$.isValidNot0(Q))throw Error("invalid private key: out of range [1..N-1]");return Q}function jJ($,J={}){let q=QQ("weierstrass",$,J),{Fp:Q,Fn:G}=q,Y=q.CURVE,{h:X,n:U}=Y;M$(J,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});let{endo:z}=J;if(z){if(!Q.is0(Y.a)||typeof z.beta!=="bigint"||!Array.isArray(z.basises))throw Error('invalid endo: expected "beta": bigint and "basises": array')}let N=XQ(Q,G);function K(){if(!Q.isOdd)throw Error("compression is not supported: Field does not have .isOdd()")}function w(V,k,M){let{x:A,y:D}=k.toAffine(),W=Q.toBytes(A);if(j$(M,"isCompressed"),M){K();let B=!Q.isOdd(D);return K0(YQ(B),W)}else return K0(Uint8Array.of(4),W,Q.toBytes(D))}function Z(V){_0(V,void 0,"Point");let{publicKey:k,publicKeyUncompressed:M}=N,A=V.length,D=V[0],W=V.subarray(1);if(A===k&&(D===2||D===3)){let B=Q.fromBytes(W);if(!Q.isValid(B))throw Error("bad point: is not on curve, wrong x");let H=L(B),R;try{R=Q.sqrt(H)}catch(E){let v=E instanceof Error?": "+E.message:"";throw Error("bad point: is not on curve, sqrt error"+v)}K();let C=Q.isOdd(R);if((D&1)===1!==C)R=Q.neg(R);return{x:B,y:R}}else if(A===M&&D===4){let B=Q.BYTES,H=Q.fromBytes(W.subarray(0,B)),R=Q.fromBytes(W.subarray(B,B*2));if(!g(H,R))throw Error("bad point: is not on curve");return{x:H,y:R}}else throw Error(`bad point: got length ${A}, expected compressed=${k} or uncompressed=${M}`)}let j=J.toBytes||w,T=J.fromBytes||Z;function L(V){let k=Q.sqr(V),M=Q.mul(k,V);return Q.add(Q.add(M,Q.mul(V,Y.a)),Y.b)}function g(V,k){let M=Q.sqr(k),A=L(V);return Q.eql(M,A)}if(!g(Y.Gx,Y.Gy))throw Error("bad curve params: generator point");let b=Q.mul(Q.pow(Y.a,b$),KJ),J0=Q.mul(Q.sqr(Y.b),BigInt(27));if(Q.is0(Q.add(b,J0)))throw Error("bad curve params: a or b");function u(V,k,M=!1){if(!Q.isValid(k)||M&&Q.is0(k))throw Error(`bad point coordinate ${V}`);return k}function X0(V){if(!(V instanceof I))throw Error("ProjectivePoint expected")}function n(V){if(!z||!z.basises)throw Error("no endo");return zJ(V,z.basises,G.ORDER)}let q0=Z8((V,k)=>{let{X:M,Y:A,Z:D}=V;if(Q.eql(D,Q.ONE))return{x:M,y:A};let W=V.is0();if(k==null)k=W?Q.ONE:Q.inv(D);let B=Q.mul(M,k),H=Q.mul(A,k),R=Q.mul(D,k);if(W)return{x:Q.ZERO,y:Q.ZERO};if(!Q.eql(R,Q.ONE))throw Error("invZ was invalid");return{x:B,y:H}}),j0=Z8((V)=>{if(V.is0()){if(J.allowInfinityPoint&&!Q.is0(V.Y))return;throw Error("bad point: ZERO")}let{x:k,y:M}=V.toAffine();if(!Q.isValid(k)||!Q.isValid(M))throw Error("bad point: x or y not field elements");if(!g(k,M))throw Error("bad point: equation left != right");if(!V.isTorsionFree())throw Error("bad point: not in prime-order subgroup");return!0});function s(V,k,M,A,D){return M=new I(Q.mul(M.X,V),M.Y,M.Z),k=V$(A,k),M=V$(D,M),k.add(M)}class I{constructor(V,k,M){this.X=u("x",V),this.Y=u("y",k,!0),this.Z=u("z",M),Object.freeze(this)}static CURVE(){return Y}static fromAffine(V){let{x:k,y:M}=V||{};if(!V||!Q.isValid(k)||!Q.isValid(M))throw Error("invalid affine point");if(V instanceof I)throw Error("projective point not allowed");if(Q.is0(k)&&Q.is0(M))return I.ZERO;return new I(k,M,Q.ONE)}static fromBytes(V){let k=I.fromAffine(T(_0(V,void 0,"point")));return k.assertValidity(),k}static fromHex(V){return I.fromBytes(p("pointHex",V))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(V=8,k=!0){if(_.createCache(this,V),!k)this.multiply(b$);return this}assertValidity(){j0(this)}hasEvenY(){let{y:V}=this.toAffine();if(!Q.isOdd)throw Error("Field doesn't support isOdd");return!Q.isOdd(V)}equals(V){X0(V);let{X:k,Y:M,Z:A}=this,{X:D,Y:W,Z:B}=V,H=Q.eql(Q.mul(k,B),Q.mul(D,A)),R=Q.eql(Q.mul(M,B),Q.mul(W,A));return H&&R}negate(){return new I(this.X,Q.neg(this.Y),this.Z)}double(){let{a:V,b:k}=Y,M=Q.mul(k,b$),{X:A,Y:D,Z:W}=this,B=Q.ZERO,H=Q.ZERO,R=Q.ZERO,C=Q.mul(A,A),c=Q.mul(D,D),E=Q.mul(W,W),v=Q.mul(A,D);return v=Q.add(v,v),R=Q.mul(A,W),R=Q.add(R,R),B=Q.mul(V,R),H=Q.mul(M,E),H=Q.add(B,H),B=Q.sub(c,H),H=Q.add(c,H),H=Q.mul(B,H),B=Q.mul(v,B),R=Q.mul(M,R),E=Q.mul(V,E),v=Q.sub(C,E),v=Q.mul(V,v),v=Q.add(v,R),R=Q.add(C,C),C=Q.add(R,C),C=Q.add(C,E),C=Q.mul(C,v),H=Q.add(H,C),E=Q.mul(D,W),E=Q.add(E,E),C=Q.mul(E,v),B=Q.sub(B,C),R=Q.mul(E,c),R=Q.add(R,R),R=Q.add(R,R),new I(B,H,R)}add(V){X0(V);let{X:k,Y:M,Z:A}=this,{X:D,Y:W,Z:B}=V,H=Q.ZERO,R=Q.ZERO,C=Q.ZERO,c=Y.a,E=Q.mul(Y.b,b$),v=Q.mul(k,D),y=Q.mul(M,W),f=Q.mul(A,B),h=Q.add(k,M),d=Q.add(D,W);h=Q.mul(h,d),d=Q.add(v,y),h=Q.sub(h,d),d=Q.add(k,A);let l=Q.add(D,B);return d=Q.mul(d,l),l=Q.add(v,f),d=Q.sub(d,l),l=Q.add(M,A),H=Q.add(W,B),l=Q.mul(l,H),H=Q.add(y,f),l=Q.sub(l,H),C=Q.mul(c,d),H=Q.mul(E,f),C=Q.add(H,C),H=Q.sub(y,C),C=Q.add(y,C),R=Q.mul(H,C),y=Q.add(v,v),y=Q.add(y,v),f=Q.mul(c,f),d=Q.mul(E,d),y=Q.add(y,f),f=Q.sub(v,f),f=Q.mul(c,f),d=Q.add(d,f),v=Q.mul(y,d),R=Q.add(R,v),v=Q.mul(l,d),H=Q.mul(h,H),H=Q.sub(H,v),v=Q.mul(h,y),C=Q.mul(l,C),C=Q.add(C,v),new I(H,R,C)}subtract(V){return this.add(V.negate())}is0(){return this.equals(I.ZERO)}multiply(V){let{endo:k}=J;if(!G.isValidNot0(V))throw Error("invalid scalar: out of range");let M,A,D=(W)=>_.cached(this,W,(B)=>_$(I,B));if(k){let{k1neg:W,k1:B,k2neg:H,k2:R}=n(V),{p:C,f:c}=D(B),{p:E,f:v}=D(R);A=c.add(v),M=s(k.beta,C,E,W,H)}else{let{p:W,f:B}=D(V);M=W,A=B}return _$(I,[M,A])[0]}multiplyUnsafe(V){let{endo:k}=J,M=this;if(!G.isValid(V))throw Error("invalid scalar: out of range");if(V===I0||M.is0())return I.ZERO;if(V===Q$)return M;if(_.hasCache(this))return this.multiply(V);if(k){let{k1neg:A,k1:D,k2neg:W,k2:B}=n(V),{p1:H,p2:R}=e8(I,M,D,B);return s(k.beta,H,R,A,W)}else return _.unsafe(M,V)}multiplyAndAddUnsafe(V,k,M){let A=this.multiplyUnsafe(k).add(V.multiplyUnsafe(M));return A.is0()?void 0:A}toAffine(V){return q0(this,V)}isTorsionFree(){let{isTorsionFree:V}=J;if(X===Q$)return!0;if(V)return V(I,this);return _.unsafe(this,U).is0()}clearCofactor(){let{clearCofactor:V}=J;if(X===Q$)return this;if(V)return V(I,this);return this.multiplyUnsafe(X)}isSmallOrder(){return this.multiplyUnsafe(X).is0()}toBytes(V=!0){return j$(V,"isCompressed"),this.assertValidity(),j(I,this,V)}toHex(V=!0){return L0(this.toBytes(V))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}get px(){return this.X}get py(){return this.X}get pz(){return this.Z}toRawBytes(V=!0){return this.toBytes(V)}_setWindowSize(V){this.precompute(V)}static normalizeZ(V){return _$(I,V)}static msm(V,k){return $Q(I,G,V,k)}static fromPrivateKey(V){return I.BASE.multiply(g0(G,V))}}I.BASE=new I(Y.Gx,Y.Gy,Q.ONE),I.ZERO=new I(Q.ZERO,Q.ONE,Q.ZERO),I.Fp=Q,I.Fn=G;let r=G.BITS,_=new M8(I,J.endo?Math.ceil(r/2):r);return I.BASE.precompute(8),I}function YQ($){return Uint8Array.of($?2:3)}function XQ($,J){return{secretKey:J.BYTES,publicKey:1+$.BYTES,publicKeyUncompressed:1+2*$.BYTES,publicKeyHasPrefix:!0,signature:2*J.BYTES}}function DJ($,J={}){let{Fn:q}=$,Q=J.randomBytes||c0,G=Object.assign(XQ($.Fp,q),{seed:K8(q.ORDER)});function Y(j){try{return!!g0(q,j)}catch(T){return!1}}function X(j,T){let{publicKey:L,publicKeyUncompressed:g}=G;try{let b=j.length;if(T===!0&&b!==L)return!1;if(T===!1&&b!==g)return!1;return!!$.fromBytes(j)}catch(b){return!1}}function U(j=Q(G.seed)){return f$(_0(j,G.seed,"seed"),q.ORDER)}function z(j,T=!0){return $.BASE.multiply(g0(q,j)).toBytes(T)}function N(j){let T=U(j);return{secretKey:T,publicKey:z(T)}}function K(j){if(typeof j==="bigint")return!1;if(j instanceof $)return!0;let{secretKey:T,publicKey:L,publicKeyUncompressed:g}=G;if(q.allowedLengths||T===L)return;let b=p("key",j).length;return b===L||b===g}function w(j,T,L=!0){if(K(j)===!0)throw Error("first arg must be private key");if(K(T)===!1)throw Error("second arg must be public key");let g=g0(q,j);return $.fromHex(T).multiply(g).toBytes(L)}return Object.freeze({getPublicKey:z,getSharedSecret:w,keygen:N,Point:$,utils:{isValidSecretKey:Y,isValidPublicKey:X,randomSecretKey:U,isValidPrivateKey:Y,randomPrivateKey:U,normPrivateKeyToScalar:(j)=>g0(q,j),precompute(j=8,T=$.BASE){return T.precompute(j,!1)}},lengths:G})}function WJ($,J,q={}){L$(J),M$(q,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});let Q=q.randomBytes||c0,G=q.hmac||((M,...A)=>Q8(J,M,K0(...A))),{Fp:Y,Fn:X}=$,{ORDER:U,BITS:z}=X,{keygen:N,getPublicKey:K,getSharedSecret:w,utils:Z,lengths:j}=DJ($,q),T={prehash:!1,lowS:typeof q.lowS==="boolean"?q.lowS:!1,format:void 0,extraEntropy:!1},L="compact";function g(M){let A=U>>Q$;return M>A}function b(M,A){if(!X.isValidNot0(A))throw Error(`invalid signature ${M}: out of range 1..Point.Fn.ORDER`);return A}function J0(M,A){N8(A);let D=j.signature,W=A==="compact"?D:A==="recovered"?D+1:void 0;return _0(M,W,`${A} signature`)}class u{constructor(M,A,D){if(this.r=b("r",M),this.s=b("s",A),D!=null)this.recovery=D;Object.freeze(this)}static fromBytes(M,A=L){J0(M,A);let D;if(A==="der"){let{r:R,s:C}=P0.toSig(_0(M));return new u(R,C)}if(A==="recovered")D=M[0],A="compact",M=M.subarray(1);let W=X.BYTES,B=M.subarray(0,W),H=M.subarray(W,W*2);return new u(X.fromBytes(B),X.fromBytes(H),D)}static fromHex(M,A){return this.fromBytes(h0(M),A)}addRecoveryBit(M){return new u(this.r,this.s,M)}recoverPublicKey(M){let A=Y.ORDER,{r:D,s:W,recovery:B}=this;if(B==null||![0,1,2,3].includes(B))throw Error("recovery id invalid");if(U*GQ<A&&B>1)throw Error("recovery id is ambiguous for h>1 curve");let R=B===2||B===3?D+U:D;if(!Y.isValid(R))throw Error("recovery id 2 or 3 invalid");let C=Y.toBytes(R),c=$.fromBytes(K0(YQ((B&1)===0),C)),E=X.inv(R),v=n(p("msgHash",M)),y=X.create(-v*E),f=X.create(W*E),h=$.BASE.multiplyUnsafe(y).add(c.multiplyUnsafe(f));if(h.is0())throw Error("point at infinify");return h.assertValidity(),h}hasHighS(){return g(this.s)}toBytes(M=L){if(N8(M),M==="der")return h0(P0.hexFromSig(this));let A=X.toBytes(this.r),D=X.toBytes(this.s);if(M==="recovered"){if(this.recovery==null)throw Error("recovery bit must be present");return K0(Uint8Array.of(this.recovery),A,D)}return K0(A,D)}toHex(M){return L0(this.toBytes(M))}assertValidity(){}static fromCompact(M){return u.fromBytes(p("sig",M),"compact")}static fromDER(M){return u.fromBytes(p("sig",M),"der")}normalizeS(){return this.hasHighS()?new u(this.r,X.neg(this.s),this.recovery):this}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return L0(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return L0(this.toBytes("compact"))}}let X0=q.bits2int||function(A){if(A.length>8192)throw Error("input is too large");let D=S0(A),W=A.length*8-z;return W>0?D>>BigInt(W):D},n=q.bits2int_modN||function(A){return X.create(X0(A))},q0=b0(z);function j0(M){return y8("num < 2^"+z,M,I0,q0),X.toBytes(M)}function s(M,A){return _0(M,void 0,"message"),A?_0(J(M),void 0,"prehashed message"):M}function I(M,A,D){if(["recovered","canonical"].some((f)=>(f in D)))throw Error("sign() legacy options not supported");let{lowS:W,prehash:B,extraEntropy:H}=V8(D,T);M=s(M,B);let R=n(M),C=g0(X,A),c=[j0(C),j0(R)];if(H!=null&&H!==!1){let f=H===!0?Q(j.secretKey):H;c.push(p("extraEntropy",f))}let E=K0(...c),v=R;function y(f){let h=X0(f);if(!X.isValidNot0(h))return;let d=X.inv(h),l=$.BASE.multiply(h).toAffine(),t=X.create(l.x);if(t===I0)return;let Z0=X.create(d*X.create(v+t*C));if(Z0===I0)return;let $0=(l.x===t?0:2)|Number(l.y&Q$),Q0=Z0;if(W&&g(Z0))Q0=X.neg(Z0),$0^=1;return new u(t,Q0,$0)}return{seed:E,k2sig:y}}function r(M,A,D={}){M=p("message",M);let{seed:W,k2sig:B}=I(M,A,D);return g8(J.outputLen,X.BYTES,G)(W,B)}function _(M){let A=void 0,D=typeof M==="string"||F0(M),W=!D&&M!==null&&typeof M==="object"&&typeof M.r==="bigint"&&typeof M.s==="bigint";if(!D&&!W)throw Error("invalid signature, expected Uint8Array, hex string or Signature instance");if(W)A=new u(M.r,M.s);else if(D){try{A=u.fromBytes(p("sig",M),"der")}catch(B){if(!(B instanceof P0.Err))throw B}if(!A)try{A=u.fromBytes(p("sig",M),"compact")}catch(B){return!1}}if(!A)return!1;return A}function V(M,A,D,W={}){let{lowS:B,prehash:H,format:R}=V8(W,T);if(D=p("publicKey",D),A=s(p("message",A),H),"strict"in W)throw Error("options.strict was renamed to lowS");let C=R===void 0?_(M):u.fromBytes(p("sig",M),R);if(C===!1)return!1;try{let c=$.fromBytes(D);if(B&&C.hasHighS())return!1;let{r:E,s:v}=C,y=n(A),f=X.inv(v),h=X.create(y*f),d=X.create(E*f),l=$.BASE.multiplyUnsafe(h).add(c.multiplyUnsafe(d));if(l.is0())return!1;return X.create(l.x)===E}catch(c){return!1}}function k(M,A,D={}){let{prehash:W}=V8(D,T);return A=s(A,W),u.fromBytes(M,"recovered").recoverPublicKey(A).toBytes()}return Object.freeze({keygen:N,getPublicKey:K,getSharedSecret:w,utils:Z,lengths:j,Point:$,sign:r,verify:V,recoverPublicKey:k,Signature:u,hash:J})}function MJ($){let J={a:$.a,b:$.b,p:$.Fp.ORDER,n:$.n,h:$.h,Gx:$.Gx,Gy:$.Gy},q=$.Fp,Q=$.allowedPrivateKeyLengths?Array.from(new Set($.allowedPrivateKeyLengths.map((X)=>Math.ceil(X/2)))):void 0,G=y0(J.n,{BITS:$.nBitLength,allowedLengths:Q,modFromBytes:$.wrapPrivateKey}),Y={Fp:q,Fn:G,allowInfinityPoint:$.allowInfinityPoint,endo:$.endo,isTorsionFree:$.isTorsionFree,clearCofactor:$.clearCofactor,fromBytes:$.fromBytes,toBytes:$.toBytes};return{CURVE:J,curveOpts:Y}}function VJ($){let{CURVE:J,curveOpts:q}=MJ($),Q={hmac:$.hmac,randomBytes:$.randomBytes,lowS:$.lowS,bits2int:$.bits2int,bits2int_modN:$.bits2int_modN};return{CURVE:J,curveOpts:q,hash:$.hash,ecdsaOpts:Q}}function NJ($,J){let q=J.Point;return Object.assign({},J,{ProjectivePoint:q,CURVE:Object.assign({},$,v$(q.Fn.ORDER,q.Fn.BITS))})}function ZQ($){let{CURVE:J,curveOpts:q,hash:Q,ecdsaOpts:G}=VJ($),Y=jJ(J,q),X=WJ(Y,Q,G);return NJ($,X)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */function UQ($,J){let q=(Q)=>ZQ({...$,hash:Q});return{...q(J),create:q}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var J$={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},OJ={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]},BJ=BigInt(0),zQ=BigInt(1),O8=BigInt(2);function RJ($){let J=J$.p,q=BigInt(3),Q=BigInt(6),G=BigInt(11),Y=BigInt(22),X=BigInt(23),U=BigInt(44),z=BigInt(88),N=$*$*$%J,K=N*N*$%J,w=M0(K,q,J)*K%J,Z=M0(w,q,J)*K%J,j=M0(Z,O8,J)*N%J,T=M0(j,G,J)*j%J,L=M0(T,Y,J)*T%J,g=M0(L,U,J)*L%J,b=M0(g,z,J)*g%J,J0=M0(b,U,J)*L%J,u=M0(J0,q,J)*K%J,X0=M0(u,X,J)*T%J,n=M0(X0,Q,J)*N%J,q0=M0(n,O8,J);if(!y$.eql(y$.sqr(q0),$))throw Error("Cannot find square root");return q0}var y$=y0(J$.p,{sqrt:RJ}),DQ=UQ({...J$,Fp:y$,lowS:!0,endo:OJ},P$),KQ={};function g$($,...J){let q=KQ[$];if(q===void 0){let Q=P$(S$($));q=K0(Q,Q),KQ[$]=q}return P$(K0(q,...J))}var R8=($)=>$.toBytes(!0).slice(1),q$=(()=>DQ.Point)(),A8=($)=>$%O8===BJ;function B8($){let{Fn:J,BASE:q}=q$,Q=g0(J,$),G=q.multiply(Q);return{scalar:A8(G.y)?Q:J.neg(Q),bytes:R8(G)}}function WQ($){let J=y$;if(!J.isValidNot0($))throw Error("invalid x: Fail if x ≥ p");let q=J.create($*$),Q=J.create(q*$+BigInt(7)),G=J.sqrt(Q);if(!A8(G))G=J.neg(G);let Y=q$.fromAffine({x:$,y:G});return Y.assertValidity(),Y}var N$=S0;function MQ(...$){return q$.Fn.create(N$(g$("BIP0340/challenge",...$)))}function jQ($){return B8($).bytes}function AJ($,J,q=c0(32)){let{Fn:Q}=q$,G=p("message",$),{bytes:Y,scalar:X}=B8(J),U=p("auxRand",q,32),z=Q.toBytes(X^N$(g$("BIP0340/aux",U))),N=g$("BIP0340/nonce",z,Y,G),{bytes:K,scalar:w}=B8(N),Z=MQ(K,Y,G),j=new Uint8Array(64);if(j.set(K,0),j.set(Q.toBytes(Q.create(w+Z*X)),32),!VQ(j,G,Y))throw Error("sign: Invalid signature produced");return j}function VQ($,J,q){let{Fn:Q,BASE:G}=q$,Y=p("signature",$,64),X=p("message",J),U=p("publicKey",q,32);try{let z=WQ(N$(U)),N=N$(Y.subarray(0,32));if(!W$(N,zQ,J$.p))return!1;let K=N$(Y.subarray(32,64));if(!W$(K,zQ,J$.n))return!1;let w=MQ(Q.toBytes(N),R8(z),X),Z=G.multiplyUnsafe(K).add(z.multiplyUnsafe(Q.neg(w))),{x:j,y:T}=Z.toAffine();if(Z.is0()||!A8(T)||j!==N)return!1;return!0}catch(z){return!1}}var u$=(()=>{let q=(G=c0(48))=>{return f$(G,J$.n)};DQ.utils.randomSecretKey;function Q(G){let Y=q(G);return{secretKey:Y,publicKey:jQ(Y)}}return{keygen:Q,getPublicKey:jQ,sign:AJ,verify:VQ,Point:q$,utils:{randomSecretKey:q,randomPrivateKey:q,taggedHash:g$,lift_x:WQ,pointToBytes:R8,numberToBytesBE:e0,bytesToNumberBE:S0,mod:W0},lengths:{secretKey:32,publicKey:32,publicKeyHasPrefix:!1,signature:64,seed:48}}})();var HJ=new TextEncoder,TJ=new TextDecoder,H0=($)=>HJ.encode($),o0=($)=>TJ.decode($),F$=($)=>Array.from($,(J)=>J.toString(16).padStart(2,"0")).join(""),V0=JSON.stringify,p0=JSON.parse,m$=($,J=Number.MAX_SAFE_INTEGER)=>$.split("").reduce((q,Q)=>q+Q.charCodeAt(0),0)%J;var H8="AES-GCM",xJ={},NQ="$",OQ=",",wJ=($)=>{let J=new Uint8Array($),q=32768,Q="";for(let G=0;G<J.length;G+=32768)Q+=String.fromCharCode(...J.subarray(G,G+32768));return btoa(Q)},kJ=($)=>Uint8Array.from(atob($),(J)=>J.charCodeAt(0)).buffer,O$=($)=>xJ[$]??=crypto.subtle.digest("SHA-1",H0($)).then((J)=>{let q=new Uint8Array(J),Q="";for(let G of q)Q+=G.toString(36);return Q}),BQ=async($,J,q)=>{let Q=await crypto.subtle.digest("SHA-256",H0(`${$}:${J}:${q}`));return crypto.subtle.importKey("raw",Q,{name:H8},!1,["encrypt","decrypt"])},RQ=async($,J)=>{let q=crypto.getRandomValues(new Uint8Array(12)),Q=await $,G=await crypto.subtle.encrypt({name:H8,iv:q},Q,H0(J));return`${q.join(OQ)}${NQ}${wJ(G)}`},AQ=async($,J)=>{let[q,Q]=J.split(NQ);if(!q||!Q)throw Error("Invalid encrypted payload format");let G=Uint8Array.from(q.split(OQ),Number),Y=await $,X=await crypto.subtle.decrypt({name:H8,iv:G},Y,kJ(Q));return o0(X)};var B$="GenosRTC",G$=($,J)=>Array.from({length:$},J);var R$=($)=>Array.from(crypto.getRandomValues(new Uint8Array($)),(J)=>"0123456789AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz"[J%62]).join(""),m=R$(20),E0=Promise.all.bind(Promise),HQ=typeof window<"u",{entries:TQ,fromEntries:h$,keys:g9}=Object,xQ=()=>{},R0=($)=>Error(`GenosRTC: ${$}`),A$=(...$)=>$.join("@"),wQ=($,J)=>{let q=[...$],Q=q.length,G=()=>{let Y=Math.sin(J++)*1e4;return Y-Math.floor(Y)};while(Q){let Y=Math.floor(G()*Q--);[q[Q],q[Y]]=[q[Y],q[Q]]}return q};var LJ=5000,kQ="icegatheringstatechange",LQ="offer",CJ="answer",SJ=[...G$(3,($,J)=>`stun:stun${J||""}.l.google.com:19302`),"stun:stun.cloudflare.com:3478"].map(($)=>({urls:$})),c$=($,{rtcConfig:J,rtcPolyfill:q,turnConfig:Q})=>{let G=new(q||RTCPeerConnection)({iceServers:[...SJ,...Q||[]],...J}),Y={},X=!1,U=!1,z,N=(Z)=>Object.assign(Z,{binaryType:"arraybuffer",bufferedAmountLowThreshold:65535,onmessage:(j)=>Y.data?.(j.data),onopen:()=>Y.connect?.(),onclose:()=>Y.close?.(),onerror:(j)=>!j?.error?.message?.includes("User-Initiated Abort")&&Y.error?.(j)}),K=()=>Promise.race([new Promise((Z)=>{let j=()=>{if(G.iceGatheringState==="complete")G.removeEventListener(kQ,j),Z()};G.addEventListener(kQ,j),j()}),new Promise((Z)=>setTimeout(Z,LJ))]).then(()=>({type:G.localDescription.type,sdp:G.localDescription.sdp.replace(/a=ice-options:trickle\s\n/g,"")}));if($?N(z=G.createDataChannel("data")):G.ondatachannel=({channel:Z})=>N(z=Z),G.onnegotiationneeded=async()=>{try{X=!0,await G.setLocalDescription(),Y.signal?.(await K())}catch(Z){Y.error?.(Z)}finally{X=!1}},G.onconnectionstatechange=()=>{if(["disconnected","failed","closed"].includes(G.connectionState))Y.close?.()},G.ontrack=(Z)=>{Y.track?.(Z.track,Z.streams[0]),Y.stream?.(Z.streams[0])},G.onremovestream=(Z)=>Y.stream?.(Z.stream),$&&!G.canTrickleIceCandidates)G.onnegotiationneeded();let w=()=>G.getSenders();return{created:Date.now(),connection:G,get channel(){return z},get isDead(){return G.connectionState==="closed"},async signal(Z){if(z?.readyState==="open"&&!Z.sdp?.includes("a=rtpmap"))return;try{if(Z.type===LQ){if(X||G.signalingState!=="stable"&&!U){if($)return;await E0([G.setLocalDescription({type:"rollback"}),G.setRemoteDescription(Z)])}else await G.setRemoteDescription(Z);await G.setLocalDescription();let j=await K();return Y.signal?.(j),j}if(Z.type===CJ){U=!0;try{await G.setRemoteDescription(Z)}finally{U=!1}}}catch(j){Y.error?.(j)}},sendData:(Z)=>z.send(Z),destroy:()=>{z?.close(),G.close(),X=U=!1},setHandlers:(Z)=>Object.assign(Y,Z),offerPromise:$?new Promise((Z)=>Y.signal=(j)=>j.type===LQ&&Z(j)):Promise.resolve(),addStream:(Z)=>Z.getTracks().forEach((j)=>G.addTrack(j,Z)),removeStream:(Z)=>w().filter((j)=>Z.getTracks().includes(j.track)).forEach((j)=>G.removeTrack(j)),addTrack:(Z,j)=>G.addTrack(Z,j),removeTrack:(Z)=>{let j=w().find((T)=>T.track===Z);if(j)G.removeTrack(j)},replaceTrack:(Z,j)=>w().find((T)=>T.track===Z)?.replaceTrack(j)}};var PJ=Object.getPrototypeOf(Uint8Array),l$=12,CQ=0,o$=CQ+l$,p$=o$+1,T$=p$+1,x$=T$+1,H$=16384-x$,d$=255,T8="bufferedamountlow",Y$=($)=>`@_${$}`,x8=100,IJ=3,EJ=200,SQ=($,J,q)=>{let Q=new Map,G=new Map,Y=new Map,X={},U={},z={},N={},K=new Map,w=(D,W)=>{if(!K.has(D))K.set(D,new Set);K.get(D).add(W)},Z=(D,W)=>K.get(D)?.delete(W),j=(D,...W)=>K.get(D)?.forEach((B)=>B(...W)),T=(D,W)=>{let B=D?Array.isArray(D)?D:[D]:Q.keys();return Array.from(B,(H)=>{let R=Q.get(H);if(!R)return null;return W(H,R)}).filter(Boolean)},L=(D)=>{if(!Q.has(D))return;Q.delete(D),delete X[D],delete U[D],delete z[D],delete N[D],j("peer:leave",D),J(D)},g=(D)=>new Promise((W,B)=>{let H=setTimeout(()=>{D.removeEventListener(T8,R),B(Error(`${B$}: bufferLow timeout`))},5000);function R(){clearTimeout(H),D.removeEventListener(T8,R),W()}D.addEventListener(T8,R)}),b=(D)=>{if(Y.has(D))return Y.get(D);if(!D)throw R0("action type is required");let W=H0(D);if(W.byteLength>l$)throw R0(`❌ "${D}" exceeds ${l$} bytes. Use a shorter name.`);let B=new Uint8Array(l$).map((y,f)=>W[f]||0),H=0,R=new Map([["message",new Set],["progress",new Set]]),C=(y,f)=>R.get(y)?.add(f),c=(y,f)=>R.get(y)?.delete(f),E=async(y,f,h,d)=>{if(h&&typeof h!=="object")throw R0("meta must be object");if(y===void 0)throw R0("data cannot be undefined");let l=y instanceof Blob,t=l||y instanceof ArrayBuffer||y instanceof PJ,Z0=typeof y!=="string";if(h&&!t)throw R0("meta only allowed with binary");let $0=t?new Uint8Array(l?await y.arrayBuffer():y):H0(Z0?V0(y):y),Q0=h?H0(V0(h)):null,e=Math.ceil($0.byteLength/H$)+(h?1:0)||1;if(e>x8)throw R0(`Message too large, exceeds max chunks ${x8}`);let r0=G$(e,(i0,U0)=>{let T0=U0===e-1,A0=h&&U0===0,a0=A0?Q0:$0.subarray(h?(U0-1)*H$:U0*H$,h?U0*H$:(U0+1)*H$),x0=new Uint8Array(x$+a0.byteLength);return x0.set(B),x0.set([H],o$),x0.set([T0|A0<<1|t<<2|Z0<<3],p$),x0.set([Math.round((U0+1)/e*d$)],T$),x0.set(a0,x$),x0});return H=H+1&d$,E0(T(f,async(i0,U0)=>{let{channel:T0}=U0;for(let A0=0;A0<e;A0++){let a0=0;while(T0.bufferedAmount>T0.bufferedAmountLowThreshold){if(a0++>IJ)throw R0(`${B$}: send buffer full, max retries reached for peer ${i0}`);try{await g(T0)}catch(x0){await new Promise((t$)=>setTimeout(t$,EJ))}}if(!Q.has(i0))break;U0.sendData(r0[A0]),d?.(r0[A0][T$]/d$,i0,h)}}))};G.set(D,{listeners:R,send:E});let v={send:E,on:C,off:c};return Y.set(D,v),v},J0=(D,W)=>{try{let B=new Uint8Array(W),H=o0(B.subarray(CQ,o$)).replace(//g,"");if(!G.has(H))return;let[R]=B.subarray(o$,p$),[C]=B.subarray(p$,T$),[c]=B.subarray(T$,x$),E=B.subarray(x$),v=Boolean(C&1),y=Boolean(C&2),f=Boolean(C&4),h=Boolean(C&8),d=G.get(H),l=(X[D]||={})[H]||={};if(l[R]?.chunks?.length>x8)return;let t=l[R]||={chunks:[]};if(y)try{t.meta=p0(o0(E))}catch{return}else t.chunks.push(E);if(d.listeners.get("progress").forEach((Q0)=>{try{Q0(c/d$,D,t.meta)}catch(e){}}),!v)return;let Z0=new Uint8Array(t.chunks.reduce((Q0,e)=>Q0+e.byteLength,0));t.chunks.reduce((Q0,e)=>(Z0.set(e,Q0),Q0+e.byteLength),0),delete l[R];let $0;if(f)$0=Z0;else if(h)try{$0=p0(o0(Z0))}catch{return}else $0=o0(Z0);d.listeners.get("message").forEach((Q0)=>{try{Q0($0,D,t.meta)}catch(e){}})}catch(B){}},u=async()=>{try{await M(""),await new Promise((D)=>setTimeout(D,99))}catch(D){}for(let[D,W]of Q){try{W.destroy()}catch{}Q.delete(D)}q()},{send:X0,on:n}=b(Y$("ping")),{send:q0,on:j0}=b(Y$("pong")),{send:s,on:I}=b(Y$("signal")),{send:r,on:_}=b(Y$("stream")),{send:V,on:k}=b(Y$("track")),{send:M,on:A}=b(Y$("leave"));if($((D,W)=>{if(Q.has(W))return;Q.set(W,D),D.setHandlers({data:(B)=>J0(W,B),stream:(B)=>{j("stream:add",B,W,z[W]),delete z[W]},track:(B,H)=>{j("track:add",B,H,W,N[W]),delete N[W]},signal:(B)=>s(B,W),close:()=>L(W),error:(B)=>{L(W)}}),j("peer:join",W)}),n("message",(D,W)=>q0("",W)),j0("message",(D,W)=>{U[W]?.(),delete U[W]}),I("message",(D,W)=>Q.get(W)?.signal(D)),_("message",(D,W)=>z[W]=D),k("message",(D,W)=>N[W]=D),A("message",(D,W)=>L(W)),HQ)addEventListener("beforeunload",u);return{on:w,off:Z,channel:b,leave:u,ping:async(D)=>{if(!D)throw R0("ping() requires target peer ID");let W=Date.now();return X0("",D),await new Promise((B)=>U[D]=B),Date.now()-W},getPeers:()=>h$(Array.from(Q,([D,W])=>[D,W.connection])),addStream:(D,W,B)=>T(W,async(H,R)=>{if(B)await r(B,H);R.addStream(D)}),removeStream:(D,W)=>T(W,(B,H)=>H.removeStream(D)),addTrack:(D,W,B,H)=>T(B,async(R,C)=>{if(H)await V(H,R);C.addTrack(D,W)}),removeTrack:(D,W)=>T(W,(B,H)=>H.removeTrack(D)),replaceTrack:(D,W,B,H)=>T(B,async(R,C)=>{if(H)await V(H,R);C.replaceTrack(D,W)})}};var vJ=20,fJ=2500,PQ=57333,IQ=({init:$,subscribe:J,announce:q})=>{let Q={},G=!1,Y,X;return(U,z,N)=>{let{appId:K}=U;if(Q[K]?.[z])return Q[K][z];if(!U||!z||!K&&!U.firebaseApp)throw R0(!U?"config required":!z?"roomId required":"appId missing");let w=xQ;if(!G){let _=$(U);X=G$(vJ,()=>c$(!0,U)),Y=Array.isArray(_)?_:[_];let V=setInterval(()=>{X=X.filter((k)=>{let M=Date.now()-k.created<PQ;if(!M)k.destroy();return M})},PQ);Q.offerCleanupTimer||=V,G=!0}let Z={},j={},T=A$(B$,K,z),L=O$(T),g=O$(A$(T,m)),b=BQ(U.password||"",K,z),J0=(_)=>async(V)=>({type:V.type,sdp:await _(b,V.sdp)}),u=J0(AQ),X0=J0(RQ),n=(_,V)=>{if(j[V]===_)return;j[V]?.destroy(),j[V]=_,w(_,V),Z[V]?.forEach((k)=>k!==_&&k.destroy()),delete Z[V]},q0=(_,V)=>{if(j[V]===_)delete j[V]},j0=(_)=>async(V,k,M)=>{let[A,D]=await E0([L,g]);if(V!==A&&V!==D)return;let{peerId:W,offer:B,answer:H}=typeof k==="string"?p0(k):k;if(W===m||j[W])return;if(B){if(Z[W]?.[_]&&m>W)return;let R=c$(!1,U);R.setHandlers({connect:()=>n(R,W),close:()=>q0(R,W)});try{let C=await u(B);if(R.isDead)return;let[c,E]=await E0([O$(A$(T,W)),R.signal(C).then(X0)]);M(c,V0({peerId:m,answer:E}))}catch{N?.({error:"decryption failed (offer)",appId:K,peerId:W,roomId:z})}}else if(H){let R=Z[W]?.[_];if(!R||R.isDead)return;R.setHandlers({connect:()=>n(R,W),close:()=>q0(R,W)});try{R.signal(await u(H))}catch{N?.({error:"decryption failed (answer)",appId:K,peerId:W,roomId:z})}}else{if(Z[W]?.[_])return;let R=X.pop()||c$(!0,U),[C,{offer:c}]=await E0([O$(A$(T,W)),R.offerPromise.then(X0).then((E)=>({offer:E}))]);Z[W]||=[],Z[W][_]=R,R.setHandlers({connect:()=>n(R,W),close:()=>q0(R,W)}),M(C,V0({peerId:m,offer:c,peer:R}))}},s=[],I=[];Y.forEach(async(_,V)=>{let k=await _;if(!k)return;let[M,A]=await E0([L,g]);I[V]=J(k,M,A,j0(V));let D=async()=>{let W=await q(k,M,A);s[V]=setTimeout(D,typeof W==="number"?W:fJ)};D()}),Q[K]||={};let r=SQ((_)=>w=_,(_)=>delete j[_],()=>r.onCleanup?.());return r.onCleanup=()=>{if(delete Q[K][z],s.forEach(clearTimeout),I.forEach((_)=>_?.()),Object.keys(Q).length===0)clearInterval(Q.offerCleanupTimer),delete Q.offerCleanupTimer},Q[K][z]=r}};var EQ=3333,r$={},vQ={},fQ=($,J)=>{let q={},Q=null,G=()=>{if(Q)clearTimeout(Q),Q=null;let Y=new WebSocket($);Y.onclose=()=>{r$[$]??=EQ,Q=setTimeout(G,r$[$]),r$[$]*=2},Y.onmessage=(X)=>J(X.data),q.socket=Y,q.url=Y.url,q.ready=new Promise((X)=>{Y.onopen=()=>{r$[$]=EQ,X(q)}}),q.send=(X)=>{if(Y.readyState===1)Y.send(X)}};return q.forceReconnect=G,G(),vQ[$]=q,q};if(typeof window<"u"){let $=()=>{Object.values(vQ).forEach((J)=>{if(J.socket&&J.socket.readyState!==WebSocket.OPEN&&J.socket.readyState!==WebSocket.CONNECTING)J.forceReconnect()})};window.addEventListener("online",()=>{$()}),window.addEventListener("offline",async()=>{}),document.addEventListener("visibilitychange",()=>{if(document.visibilityState==="visible")$()})}var _Q=($)=>()=>h$(TQ($).map(([J,q])=>[J,q.socket])),bQ=($,J,q,Q)=>($.relayUrls??(Q?wQ(J,m$($.appId)):J)).slice(0,$.relayUrls?.length??$.relayRedundancy??q);var X$={},_J=10,FQ="x",mQ="EVENT",bJ=/pow:\s*(\d+)\s*bits needed\.?/i,w8=new Set,hQ=u$.utils.randomSecretKey(),yJ=F$(u$.getPublicKey(hQ)),k8={},w$={},gJ={},cQ=()=>Math.floor(Date.now()/1000),dQ=($)=>gJ[$]??=m$($,1e4)+20000,i$=($)=>$.replace(/\/$/,""),uJ=["wss://relay.primal.net","wss://ftp.halifax.rwth-aachen.de/nostr","wss://nostr.oxtr.dev","wss://nostr.sathoarder.com","wss://nostr.mom","wss://nos.lol","wss://nostr.vulpem.com","wss://nostr.data.haus","wss://relay.mostro.network","wss://relay.nostrdice.com"],FJ=($,J)=>{let[q,Q,G,Y]=p0(J);if(q===mQ)return w$[Q]?.(k8[Q],G.content);if(q==="NOTICE"||q==="OK"&&!G){if(+((q==="NOTICE"?Q:Y).match(bJ)?.[1]??0)>0){let U=i$($);w8.add(U),X$[U]?.close?.(),delete X$[U]}}},mJ=($)=>{let J=i$($);if(X$[J])return X$[J];let q=fQ(J,(Q)=>FJ(J,Q));return X$[J]=q},yQ=async($,J)=>{let q={kind:dQ($),content:J,pubkey:yJ,created_at:cQ(),tags:[[FQ,$]]},Q=H0(V0([0,q.pubkey,q.created_at,q.kind,q.tags,q.content])),G=new Uint8Array(await crypto.subtle.digest("SHA-256",Q)),Y=u$.sign(G,hQ);return V0([mQ,{...q,id:F$(G),sig:F$(Y)}])},gQ=($,J)=>{return k8[$]=J,V0(["REQ",$,{kinds:[dQ(J)],since:cQ(),["#"+FQ]:[J]}])},uQ=($)=>{return delete k8[$],V0(["CLOSE",$])},lQ=IQ({init:($)=>{let q=($?.relayUrls?.length?$.relayUrls:null)??uJ;return bQ($,q,_J,!1).map(mJ).map((G)=>G.ready.then(()=>G).catch(()=>null))},subscribe:($,J,q,Q)=>{let G=R$(64),Y=R$(64);return w$[G]=w$[Y]=(X,U)=>Q(X,U,async(z,N)=>{if(w8.has(i$($.url)))return;$.send(await yQ(z,N))}),$.send(gQ(G,J)),$.send(gQ(Y,q)),()=>{$.send(uQ(G)),$.send(uQ(Y)),delete w$[G],delete w$[Y]}},announce:async($,J)=>{if(w8.has(i$($.url)))return;$.send(await yQ(J,V0({peerId:m})))}}),hJ=_Q(X$);var cJ={cellSize:"auto",bridgesPerEdge:2,maxCellSize:50,targetCells:100,debug:!1},oQ=5000,dJ=3000,lJ=30000,oJ=2000,s$=($)=>{let J=String($||"").match(/cell-(\d+)/);return J?Number(J[1]):null},Z$=($)=>{let J=s$($);if(J==null)return[];let q=[];if(J>0)q.push(`cell-${J-1}`);return q.push(`cell-${J+1}`),q},a$=($)=>`c${(s$($)||0).toString(36)}`,pJ=($,J,q)=>{if($<=10)return Math.max(2,$);let G=10,Y=Math.ceil($/J);return Math.max(G,Math.min(q,Y))},pQ=($,J)=>{return Math.max(1,Math.ceil($/J))},rJ=($,J,q)=>{let Q=Math.max(1,Math.ceil(J.length/q)),G=Math.ceil(J.length/Q),Y=J.indexOf($);if(Y<0)return 0;return Math.floor(Y/G)};class n${constructor($){this.peerId=$,this.joinedAt=Date.now(),this.lastSeen=Date.now(),this.rttSamples=[],this.stability=1,this.reconnects=0,this.isResponsive=!0,this.connectedCells=new Set}get uptime(){return Date.now()-this.joinedAt}get avgRtt(){if(this.rttSamples.length===0)return 1/0;return Math.round(this.rttSamples.reduce(($,J)=>$+J,0)/this.rttSamples.length)}get healthScore(){let $=this.avgRtt===1/0?0.5:Math.max(0,100-this.avgRtt)/100,J=Math.min(1,this.uptime/60000),q=this.stability,Q=this.isResponsive?1:0.3;return $*0.25+J*0.25+q*0.3+Q*0.2}get isStale(){return Date.now()-this.lastSeen>lJ}addRttSample($){if(this.rttSamples.push($),this.rttSamples.length>10)this.rttSamples.shift();this.lastSeen=Date.now(),this.isResponsive=!0}markReconnect(){this.reconnects++,this.stability=Math.max(0,1-this.reconnects*0.1)}markUnresponsive(){this.isResponsive=!1}markSeen(){this.lastSeen=Date.now()}addConnectedCell($){if($)this.connectedCells.add($)}}function iJ($,J={}){let q={...cJ,...J},Q=!!q.debug,G=(...O)=>Q&&void 0,Y=Math.max(0,q.bridgesPerEdge|0),X=Math.max(5,q.maxCellSize|0),U=Math.max(10,q.targetCells|0),z=q.cellSize==="auto",N=z?2:Math.max(1,q.cellSize|0),K={cellId:null,bridges:[],isBridge:!1},w=null,Z=null,j=null,T=new Map,L=new Map,g=new Set,b=new Map,J0=new Set,u=new Set,X0=0,n=[],q0=new Map,j0=new Set,s=new Map,I=new Map,r=()=>{let O=Math.ceil(f().length/N);return Math.min(150,O+3)},_=$.on?.bind($),V=$.off?.bind($);if(_)$.on=(O,x)=>String(O).startsWith("mesh:")?A(O,x):_(O,x);if(V)$.off=(O,x)=>String(O).startsWith("mesh:")?b.get(O)?.delete(x):V(O,x);let k=(O)=>(g.add(O),()=>g.delete(O)),M=(O,x,S)=>{if(u.has(S))return;if(u.add(S),u.size>oQ){let P=u.values().next().value;u.delete(P)}for(let P of g)try{P(O,x)}catch(F){G("Error in deliver handler:",F)}},A=(O,x)=>{if(!b.has(O))b.set(O,new Set);return b.get(O).add(x),()=>b.get(O)?.delete(x)},D=(O,...x)=>{let S=b.get(O);if(S)for(let P of S)try{P(...x)}catch{}},W=(O)=>{try{return typeof O==="string"?JSON.parse(O):O}catch{return null}},B=()=>`${m}:${Date.now().toString(36)}:${(X0++&65535).toString(36)}`,H=()=>{if(J0.size>oQ)J0.delete(J0.values().next().value)},R=(O,x,S=[])=>{if(!O||!x)return;if(T.set(O,{cell:x,isBridge:S.length>0,bridges:[...S]}),!L.has(O))L.set(O,new n$(O));let P=L.get(O);if(P.markSeen(),P.addConnectedCell(x),I.set(x,{lastSeen:Date.now(),peerId:O}),S.length>0)for(let F of Z$(x))P.addConnectedCell(F)},C=(O)=>L.get(O),c=(O,x)=>{let S=L.get(O);if(S)S.addRttSample(x)},E=(O)=>{let x=$0(O);if(x.length===0)return null;let S=0,P=0;for(let i of x){let z0=L.get(i);if(z0&&!z0.isStale){if(S+=z0.healthScore,z0.isResponsive)P++}}let F=x.filter((i)=>{let z0=L.get(i);return z0&&!z0.isStale});return{cellId:O,memberCount:F.length,avgHealth:F.length>0?S/F.length:0,responsiveRatio:F.length>0?P/F.length:0}},v=()=>{let O=E(K.cellId);D("mesh:health",{...K,health:O})},y=()=>{let O=Object.keys($.getPeers?.()||{}),x=[...O,m].sort();return{peers:O,all:x}},f=()=>{let{all:O}=y();return O.filter((x)=>{if(x===m)return!0;let S=L.get(x);return S&&!S.isStale})},h=()=>{if(!z)return;let O=f().length,x=pJ(O,U,X);if(x!==N)G("cellSize changed:",N,"->",x),N=x},d=(O,x)=>{let S=pQ(x.length,N),P=Math.ceil(x.length/S),F=O*P,i=Math.min(F+P,x.length);return x.slice(F,i)},l=(O,x)=>{if(Y===0)return[];let S=s$(O),P=s$(x);if(S==null||P==null)return[];let F=f(),i=d(S,F),z0=d(P,F),a=[...new Set([...i,...z0])];if(!a.length)return[];let n0=new Set($0(O)),k$=new Set($0(x)),N0=a.filter((D0)=>{if(D0===m)return!0;let w0=L.get(D0);if(!w0||w0.isStale)return!1;let o=n0.has(D0)||w0.connectedCells.has(O),v0=k$.has(D0)||w0.connectedCells.has(x);return o||v0});if(!N0.length)N0.push(...a);let s0=N0.map((D0)=>({id:D0,score:L.get(D0)?.healthScore||0.5}));return s0.sort((D0,w0)=>{let o=w0.score-D0.score;return o!==0?o:D0.id.localeCompare(w0.id)}),s0.slice(0,Y).map((D0)=>D0.id)},t=(O,x)=>{if(Y===0)return[];let S=Z$(x),P=[];for(let F of S)if(l(x,F).includes(O))P.push(F);return P},Z0=()=>{h();let O=f(),x=rJ(m,O,N),S=pQ(O.length,N),P=`cell-${x}`,F=t(m,P),i=F.length>0;return G("computeState",{self:m,myCell:P,isBridge:i,bridgeEdges:F,cellSize:N,rosterSize:O.length,totalCells:S,dynamicTTL:r()}),{cellId:P,isBridge:i,bridges:F,cellSize:N,dynamicTTL:r(),totalCells:S}},$0=(O)=>{let x=[],S=new Set(Object.keys($.getPeers?.()||{}));for(let[P,F]of T)if(F.cell===O){let i=L.get(P);if(S.has(P)&&(!i||!i.isStale))x.push(P)}return x.sort(),x},Q0=()=>{if(!w)return;T0=A0();let O={t:"state",id:B(),ttl:r(),data:{id:m,cell:K.cellId,bridges:K.bridges,health:L.get(m)?.healthScore||0.5,timestamp:Date.now()},origin:m,originCell:K.cellId},x=JSON.stringify(O);w.send(x),e(Z,x)},e=(O,x)=>{let S=W(x);if(!S?.id||!S?.t)return;let P=J0.has(S.id);if(!P)J0.add(S.id),H();let{t:F,id:i,ttl:z0,data:a,origin:n0,originCell:k$}=S,N0=K.cellId;if(F==="state"&&a)R(a.id,a.cell,a.bridges),D("mesh:peer-state",a);if(F==="ping"&&a?.pingId&&n0!==m){let o={t:"pong",id:B(),ttl:r(),data:{pingId:a.pingId,receivedAt:Date.now()},origin:m,originCell:N0};w?.send(JSON.stringify(o))}if(F==="pong"&&a?.pingId){let o=s.get(a.pingId);if(o){clearTimeout(o.timeout);let v0=Date.now()-o.start;c(o.peerId,v0),o.resolve(v0),s.delete(a.pingId)}}if(F==="msg"&&n0!==m){if(k$===N0||Y>0)M(a,n0,i)}if(P)return;if(!K.isBridge)return;if((z0??0)<=0)return;let s0=(o,v0,rQ=null)=>{if(!o)return;let iQ={t:F,id:i,ttl:rQ??(z0??r())-1,data:a,origin:n0||m,originCell:k$||N0},L8=JSON.stringify(iQ);if(v0?.length){let aQ=new Set(Object.keys($.getPeers?.()||{})),C8=v0.filter((nQ)=>aQ.has(nQ));if(C8.length>0)o.send(L8,C8)}else o.send(L8)};if(O===Z){for(let o of Z$(N0))s0(r0(o),null);return}if(!Z$(N0).map(a$).includes(O))return;let w0=$0(N0);s0(w,w0);for(let o of Z$(N0))if(a$(o)!==O)s0(r0(o),null)},r0=(O)=>{let x=a$(O);if(q0.has(O))return q0.get(O);let S=$.channel(x);if(q0.set(O,S),!j0.has(x))j0.add(x),S.on("message",(P)=>e(x,P));return S},i0=()=>{if(!K.cellId)return;if(Z=a$(K.cellId),w=$.channel(Z),!j0.has(Z))j0.add(Z),w.on("message",(O)=>e(Z,O));if(K.isBridge)for(let O of Z$(K.cellId))r0(O);if(n.length){let O=$0(K.cellId);for(let x of n.splice(0)){let S={t:"msg",id:B(),ttl:r(),data:x,origin:m,originCell:K.cellId},P=JSON.stringify(S);O.length?w.send(P,O):w.send(P),e(Z,P)}}Q0()},U0=()=>{let O=Z0(),x=!K.cellId||K.cellId!==O.cellId||K.isBridge!==O.isBridge||JSON.stringify(K.bridges)!==JSON.stringify(O.bridges);if(K=O,R(m,O.cellId,O.bridges),x)i0();else Q0();D("mesh:state",O),v()},T0="",A0=()=>{return`${K.cellId}:${K.isBridge}:${K.bridges.join(",")}`},a0=()=>{if(j)return;j=setInterval(()=>{let O=A0();if(O!==T0)Q0(),T0=O;for(let[x,S]of L)if(x!==m&&S.isStale)T.delete(x),L.delete(x),G("Removed stale peer:",x)},oJ)},x0=()=>{if(j)clearInterval(j),j=null},t$=(O)=>{return new Promise((x,S)=>{let P=`${Date.now()}-${Math.random().toString(36).slice(2,8)}`,F=Date.now(),i=setTimeout(()=>{s.delete(P);let a=L.get(O);if(a)a.markUnresponsive();S(Error("Ping timeout"))},dJ);s.set(P,{start:F,resolve:x,reject:S,timeout:i,peerId:O});let z0={t:"ping",id:B(),ttl:r(),data:{pingId:P,target:O},origin:m,originCell:K.cellId};w?.send(JSON.stringify(z0))})};if($.on?.("peer:join",(O)=>{if(!L.has(O))L.set(O,new n$(O));else L.get(O).markReconnect();U0()}),$.on?.("peer:leave",(O)=>{T.delete(O),U0()}),!L.has(m))L.set(m,new n$(m));return L.get(m).addConnectedCell(K.cellId||"cell-0"),U0(),a0(),{send:(O)=>{if(!K.cellId||!w)return n.push(O);let x=$0(K.cellId),S={t:"msg",id:B(),ttl:r(),data:O,origin:m,originCell:K.cellId},P=JSON.stringify(S);x.length?w.send(P,x):w.send(P),e(Z,P)},on:(O,x)=>O==="message"?k(x):void 0,ping:t$,getState:()=>({...K,cellSize:N,health:E(K.cellId),dynamicTTL:r(),totalCells:Math.ceil(f().length/N),knownCells:I.size}),getMetrics:C,getCellHealth:E,getPeerInfo:()=>new Map(T),getStableRoster:()=>f(),getKnownCells:()=>new Map(I),getCellSize:()=>N,destroy:()=>{x0(),s.forEach((O)=>clearTimeout(O.timeout)),s.clear(),u.clear(),I.clear()}}}function Xq($,J,q){let Q=lQ($,J,q),G=$.overlay||{},Y=iJ(Q,G),X=new Map;return{on:(U,z)=>Q.on(U,z),off:(U,z)=>Q.off?.(U,z),channel:(U)=>{if(X.has(U))return X.get(U);let z=Q.channel(U),N={send:(K,w)=>{Y.send({_ch:U,_d:K,_t:w})},on:(K,w)=>{if(K==="message")Y.on("message",(Z,j)=>{if(Z?._ch===U)w(Z._d,j)}),z.on(K,w);else z.on(K,w)},off:(K,w)=>z.off?.(K,w),_original:z};return X.set(U,N),N},get id(){return Q.id},get peers(){return Q.peers},getPeers:()=>Q.getPeers?.()||{},mesh:Y,_room:Q,getState:()=>Y.getState(),getMetrics:(U)=>Y.getMetrics(U),getCellHealth:(U)=>Y.getCellHealth(U),getPeerInfo:()=>Y.getPeerInfo(),ping:(U)=>Y.ping(U),destroy:()=>{Y.destroy(),X.clear()}}}export{m as selfId,Xq as join,hJ as getRelaySockets,cJ as OVERLAY_DEFAULTS};
Binary file
@@ -1 +1 @@
1
- var x0=typeof globalThis==="object"&&"crypto"in globalThis?globalThis.crypto:void 0;/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */function w0($){return $ instanceof Uint8Array||ArrayBuffer.isView($)&&$.constructor.name==="Uint8Array"}function l0($){if(!Number.isSafeInteger($)||$<0)throw Error("positive integer expected, got "+$)}function e($,...J){if(!w0($))throw Error("Uint8Array expected");if(J.length>0&&!J.includes($.length))throw Error("Uint8Array expected of length "+J+", got length="+$.length)}function Z$($){if(typeof $!=="function"||typeof $.create!=="function")throw Error("Hash should be wrapped by utils.createHasher");l0($.outputLen),l0($.blockLen)}function v0($,J=!0){if($.destroyed)throw Error("Hash instance has been destroyed");if(J&&$.finished)throw Error("Hash#digest() has already been called")}function Y8($,J){e($);let G=J.outputLen;if($.length<G)throw Error("digestInto() expects output buffer of length at least "+G)}function L0(...$){for(let J=0;J<$.length;J++)$[J].fill(0)}function U$($){return new DataView($.buffer,$.byteOffset,$.byteLength)}function $0($,J){return $<<32-J|$>>>J}var X8=(()=>typeof Uint8Array.from([]).toHex==="function"&&typeof Uint8Array.fromHex==="function")(),BQ=Array.from({length:256},($,J)=>J.toString(16).padStart(2,"0"));function U0($){if(e($),X8)return $.toHex();let J="";for(let G=0;G<$.length;G++)J+=BQ[$[G]];return J}var Z0={_0:48,_9:57,A:65,F:70,a:97,f:102};function z8($){if($>=Z0._0&&$<=Z0._9)return $-Z0._0;if($>=Z0.A&&$<=Z0.F)return $-(Z0.A-10);if($>=Z0.a&&$<=Z0.f)return $-(Z0.a-10);return}function k0($){if(typeof $!=="string")throw Error("hex string expected, got "+typeof $);if(X8)return Uint8Array.fromHex($);let J=$.length,G=J/2;if(J%2)throw Error("hex string expected, got unpadded hex of length "+J);let Q=new Uint8Array(G);for(let q=0,z=0;q<G;q++,z+=2){let Y=z8($.charCodeAt(z)),Z=z8($.charCodeAt(z+1));if(Y===void 0||Z===void 0){let U=$[z]+$[z+1];throw Error('hex string expected, got non-hex character "'+U+'" at index '+z)}Q[q]=Y*16+Z}return Q}function j$($){if(typeof $!=="string")throw Error("string expected");return new Uint8Array(new TextEncoder().encode($))}function d0($){if(typeof $==="string")$=j$($);return e($),$}function d(...$){let J=0;for(let Q=0;Q<$.length;Q++){let q=$[Q];e(q),J+=q.length}let G=new Uint8Array(J);for(let Q=0,q=0;Q<$.length;Q++){let z=$[Q];G.set(z,q),q+=z.length}return G}class r0{}function Z8($){let J=(Q)=>$().update(d0(Q)).digest(),G=$();return J.outputLen=G.outputLen,J.blockLen=G.blockLen,J.create=()=>$(),J}function I0($=32){if(x0&&typeof x0.getRandomValues==="function")return x0.getRandomValues(new Uint8Array($));if(x0&&typeof x0.randomBytes==="function")return Uint8Array.from(x0.randomBytes($));throw Error("crypto.getRandomValues must be defined")}function RQ($,J,G,Q){if(typeof $.setBigUint64==="function")return $.setBigUint64(J,G,Q);let q=BigInt(32),z=BigInt(4294967295),Y=Number(G>>q&z),Z=Number(G&z),U=Q?4:0,V=Q?0:4;$.setUint32(J+U,Y,Q),$.setUint32(J+V,Z,Q)}function U8($,J,G){return $&J^~$&G}function j8($,J,G){return $&J^$&G^J&G}class E$ extends r0{constructor($,J,G,Q){super();this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=$,this.outputLen=J,this.padOffset=G,this.isLE=Q,this.buffer=new Uint8Array($),this.view=U$(this.buffer)}update($){v0(this),$=d0($),e($);let{view:J,buffer:G,blockLen:Q}=this,q=$.length;for(let z=0;z<q;){let Y=Math.min(Q-this.pos,q-z);if(Y===Q){let Z=U$($);for(;Q<=q-z;z+=Q)this.process(Z,z);continue}if(G.set($.subarray(z,z+Y),this.pos),this.pos+=Y,z+=Y,this.pos===Q)this.process(J,0),this.pos=0}return this.length+=$.length,this.roundClean(),this}digestInto($){v0(this),Y8($,this),this.finished=!0;let{buffer:J,view:G,blockLen:Q,isLE:q}=this,{pos:z}=this;if(J[z++]=128,L0(this.buffer.subarray(z)),this.padOffset>Q-z)this.process(G,0),z=0;for(let N=z;N<Q;N++)J[N]=0;RQ(G,Q-8,BigInt(this.length*8),q),this.process(G,0);let Y=U$($),Z=this.outputLen;if(Z%4)throw Error("_sha2: outputLen should be aligned to 32bit");let U=Z/4,V=this.get();if(U>V.length)throw Error("_sha2: outputLen bigger than state");for(let N=0;N<U;N++)Y.setUint32(4*N,V[N],q)}digest(){let{buffer:$,outputLen:J}=this;this.digestInto($);let G=$.slice(0,J);return this.destroy(),G}_cloneInto($){$||($=new this.constructor),$.set(...this.get());let{blockLen:J,buffer:G,length:Q,finished:q,destroyed:z,pos:Y}=this;if($.destroyed=z,$.finished=q,$.length=Q,$.pos=Y,Q%J)$.buffer.set(G);return $}clone(){return this._cloneInto()}}var j0=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var xQ=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]),C0=new Uint32Array(64);class K8 extends E${constructor($=32){super(64,$,8,!1);this.A=j0[0]|0,this.B=j0[1]|0,this.C=j0[2]|0,this.D=j0[3]|0,this.E=j0[4]|0,this.F=j0[5]|0,this.G=j0[6]|0,this.H=j0[7]|0}get(){let{A:$,B:J,C:G,D:Q,E:q,F:z,G:Y,H:Z}=this;return[$,J,G,Q,q,z,Y,Z]}set($,J,G,Q,q,z,Y,Z){this.A=$|0,this.B=J|0,this.C=G|0,this.D=Q|0,this.E=q|0,this.F=z|0,this.G=Y|0,this.H=Z|0}process($,J){for(let N=0;N<16;N++,J+=4)C0[N]=$.getUint32(J,!1);for(let N=16;N<64;N++){let x=C0[N-15],X=C0[N-2],j=$0(x,7)^$0(x,18)^x>>>3,A=$0(X,17)^$0(X,19)^X>>>10;C0[N]=A+C0[N-7]+j+C0[N-16]|0}let{A:G,B:Q,C:q,D:z,E:Y,F:Z,G:U,H:V}=this;for(let N=0;N<64;N++){let x=$0(Y,6)^$0(Y,11)^$0(Y,25),X=V+x+U8(Y,Z,U)+xQ[N]+C0[N]|0,A=($0(G,2)^$0(G,13)^$0(G,22))+j8(G,Q,q)|0;V=U,U=Z,Z=Y,Y=z+X|0,z=q,q=Q,Q=G,G=X+A|0}G=G+this.A|0,Q=Q+this.B|0,q=q+this.C|0,z=z+this.D|0,Y=Y+this.E|0,Z=Z+this.F|0,U=U+this.G|0,V=V+this.H|0,this.set(G,Q,q,z,Y,Z,U,V)}roundClean(){L0(C0)}destroy(){this.set(0,0,0,0,0,0,0,0),L0(this.buffer)}}var K$=Z8(()=>new K8);class f$ extends r0{constructor($,J){super();this.finished=!1,this.destroyed=!1,Z$($);let G=d0(J);if(this.iHash=$.create(),typeof this.iHash.update!=="function")throw Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let Q=this.blockLen,q=new Uint8Array(Q);q.set(G.length>Q?$.create().update(G).digest():G);for(let z=0;z<q.length;z++)q[z]^=54;this.iHash.update(q),this.oHash=$.create();for(let z=0;z<q.length;z++)q[z]^=106;this.oHash.update(q),L0(q)}update($){return v0(this),this.iHash.update($),this}digestInto($){v0(this),e($,this.outputLen),this.finished=!0,this.iHash.digestInto($),this.oHash.update($),this.oHash.digestInto($),this.destroy()}digest(){let $=new Uint8Array(this.oHash.outputLen);return this.digestInto($),$}_cloneInto($){$||($=Object.create(Object.getPrototypeOf(this),{}));let{oHash:J,iHash:G,finished:Q,destroyed:q,blockLen:z,outputLen:Y}=this;return $=$,$.finished=Q,$.destroyed=q,$.blockLen=z,$.outputLen=Y,$.oHash=J._cloneInto($.oHash),$.iHash=G._cloneInto($.iHash),$}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}}var v$=($,J,G)=>new f$($,J).update(G).digest();v$.create=($,J)=>new f$($,J);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var g$=BigInt(0),_$=BigInt(1);function o0($,J=""){if(typeof $!=="boolean"){let G=J&&`"${J}"`;throw Error(G+"expected boolean, got type="+typeof $)}return $}function T0($,J,G=""){let Q=w0($),q=$?.length,z=J!==void 0;if(!Q||z&&q!==J){let Y=G&&`"${G}" `,Z=z?` of length ${J}`:"",U=Q?`length=${q}`:`type=${typeof $}`;throw Error(Y+"expected Uint8Array"+Z+", got "+U)}return $}function p0($){let J=$.toString(16);return J.length&1?"0"+J:J}function D8($){if(typeof $!=="string")throw Error("hex string expected, got "+typeof $);return $===""?g$:BigInt("0x"+$)}function K0($){return D8(U0($))}function y$($){return e($),D8(U0(Uint8Array.from($).reverse()))}function b0($,J){return k0($.toString(16).padStart(J*2,"0"))}function u$($,J){return b0($,J).reverse()}function m($,J,G){let Q;if(typeof J==="string")try{Q=k0(J)}catch(z){throw Error($+" must be hex string or Uint8Array, cause: "+z)}else if(w0(J))Q=Uint8Array.from(J);else throw Error($+" must be hex string or Uint8Array");let q=Q.length;if(typeof G==="number"&&q!==G)throw Error($+" of length "+G+" expected, got "+q);return Q}var b$=($)=>typeof $==="bigint"&&g$<=$;function i0($,J,G){return b$($)&&b$(J)&&b$(G)&&J<=$&&$<G}function M8($,J,G,Q){if(!i0(J,G,Q))throw Error("expected valid "+$+": "+G+" <= n < "+Q+", got "+J)}function D$($){let J;for(J=0;$>g$;$>>=_$,J+=1);return J}var H0=($)=>(_$<<BigInt($))-_$;function W8($,J,G){if(typeof $!=="number"||$<2)throw Error("hashLen must be a number");if(typeof J!=="number"||J<2)throw Error("qByteLen must be a number");if(typeof G!=="function")throw Error("hmacFn must be a function");let Q=(j)=>new Uint8Array(j),q=(j)=>Uint8Array.of(j),z=Q($),Y=Q($),Z=0,U=()=>{z.fill(1),Y.fill(0),Z=0},V=(...j)=>G(Y,z,...j),N=(j=Q(0))=>{if(Y=V(q(0),j),z=V(),j.length===0)return;Y=V(q(1),j),z=V()},x=()=>{if(Z++>=1000)throw Error("drbg: tried 1000 values");let j=0,A=[];while(j<J){z=V();let w=z.slice();A.push(w),j+=z.length}return d(...A)};return(j,A)=>{U(),N(j);let w=void 0;while(!(w=A(x())))N();return U(),w}}function a0($,J,G={}){if(!$||typeof $!=="object")throw Error("expected valid options object");function Q(q,z,Y){let Z=$[q];if(Y&&Z===void 0)return;let U=typeof Z;if(U!==z||Z===null)throw Error(`param "${q}" is invalid: expected ${z}, got ${U}`)}Object.entries(J).forEach(([q,z])=>Q(q,z,!1)),Object.entries(G).forEach(([q,z])=>Q(q,z,!0))}function m$($){let J=new WeakMap;return(G,...Q)=>{let q=J.get(G);if(q!==void 0)return q;let z=$(G,...Q);return J.set(G,z),z}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var c=BigInt(0),h=BigInt(1),S0=BigInt(2),C8=BigInt(3),T8=BigInt(4),H8=BigInt(5),wQ=BigInt(7),O8=BigInt(8),LQ=BigInt(9),A8=BigInt(16);function o($,J){let G=$%J;return G>=c?G:J+G}function p($,J,G){let Q=$;while(J-- >c)Q*=Q,Q%=G;return Q}function N8($,J){if($===c)throw Error("invert: expected non-zero number");if(J<=c)throw Error("invert: expected positive modulus, got "+J);let G=o($,J),Q=J,q=c,z=h,Y=h,Z=c;while(G!==c){let V=Q/G,N=Q%G,x=q-Y*V,X=z-Z*V;Q=G,G=N,q=Y,z=Z,Y=x,Z=X}if(Q!==h)throw Error("invert: does not exist");return o(q,J)}function F$($,J,G){if(!$.eql($.sqr(J),G))throw Error("Cannot find square root")}function B8($,J){let G=($.ORDER+h)/T8,Q=$.pow(J,G);return F$($,Q,J),Q}function kQ($,J){let G=($.ORDER-H8)/O8,Q=$.mul(J,S0),q=$.pow(Q,G),z=$.mul(J,q),Y=$.mul($.mul(z,S0),q),Z=$.mul(z,$.sub(Y,$.ONE));return F$($,Z,J),Z}function IQ($){let J=O0($),G=R8($),Q=G(J,J.neg(J.ONE)),q=G(J,Q),z=G(J,J.neg(Q)),Y=($+wQ)/A8;return(Z,U)=>{let V=Z.pow(U,Y),N=Z.mul(V,Q),x=Z.mul(V,q),X=Z.mul(V,z),j=Z.eql(Z.sqr(N),U),A=Z.eql(Z.sqr(x),U);V=Z.cmov(V,N,j),N=Z.cmov(X,x,A);let w=Z.eql(Z.sqr(N),U),E=Z.cmov(V,N,w);return F$(Z,E,U),E}}function R8($){if($<C8)throw Error("sqrt is not defined for small field");let J=$-h,G=0;while(J%S0===c)J/=S0,G++;let Q=S0,q=O0($);while(V8(q,Q)===1)if(Q++>1000)throw Error("Cannot find square root: probably non-prime P");if(G===1)return B8;let z=q.pow(Q,J),Y=(J+h)/S0;return function(U,V){if(U.is0(V))return V;if(V8(U,V)!==1)throw Error("Cannot find square root");let N=G,x=U.mul(U.ONE,z),X=U.pow(V,J),j=U.pow(V,Y);while(!U.eql(X,U.ONE)){if(U.is0(X))return U.ZERO;let A=1,w=U.sqr(X);while(!U.eql(w,U.ONE))if(A++,w=U.sqr(w),A===N)throw Error("Cannot find square root");let E=h<<BigInt(N-A-1),v=U.pow(x,E);N=A,x=U.sqr(v),X=U.mul(X,x),j=U.mul(j,v)}return j}}function SQ($){if($%T8===C8)return B8;if($%O8===H8)return kQ;if($%A8===LQ)return IQ($);return R8($)}var PQ=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function h$($){let J={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},G=PQ.reduce((Q,q)=>{return Q[q]="function",Q},J);return a0($,G),$}function EQ($,J,G){if(G<c)throw Error("invalid exponent, negatives unsupported");if(G===c)return $.ONE;if(G===h)return J;let Q=$.ONE,q=J;while(G>c){if(G&h)Q=$.mul(Q,q);q=$.sqr(q),G>>=h}return Q}function M$($,J,G=!1){let Q=Array(J.length).fill(G?$.ZERO:void 0),q=J.reduce((Y,Z,U)=>{if($.is0(Z))return Y;return Q[U]=Y,$.mul(Y,Z)},$.ONE),z=$.inv(q);return J.reduceRight((Y,Z,U)=>{if($.is0(Z))return Y;return Q[U]=$.mul(Y,Q[U]),$.mul(Y,Z)},z),Q}function V8($,J){let G=($.ORDER-h)/S0,Q=$.pow(J,G),q=$.eql(Q,$.ONE),z=$.eql(Q,$.ZERO),Y=$.eql(Q,$.neg($.ONE));if(!q&&!z&&!Y)throw Error("invalid Legendre symbol result");return q?1:z?0:-1}function W$($,J){if(J!==void 0)l0(J);let G=J!==void 0?J:$.toString(2).length,Q=Math.ceil(G/8);return{nBitLength:G,nByteLength:Q}}function O0($,J,G=!1,Q={}){if($<=c)throw Error("invalid field: expected ORDER > 0, got "+$);let q=void 0,z=void 0,Y=!1,Z=void 0;if(typeof J==="object"&&J!=null){if(Q.sqrt||G)throw Error("cannot specify opts in two arguments");let X=J;if(X.BITS)q=X.BITS;if(X.sqrt)z=X.sqrt;if(typeof X.isLE==="boolean")G=X.isLE;if(typeof X.modFromBytes==="boolean")Y=X.modFromBytes;Z=X.allowedLengths}else{if(typeof J==="number")q=J;if(Q.sqrt)z=Q.sqrt}let{nBitLength:U,nByteLength:V}=W$($,q);if(V>2048)throw Error("invalid field: expected ORDER of <= 2048 bytes");let N,x=Object.freeze({ORDER:$,isLE:G,BITS:U,BYTES:V,MASK:H0(U),ZERO:c,ONE:h,allowedLengths:Z,create:(X)=>o(X,$),isValid:(X)=>{if(typeof X!=="bigint")throw Error("invalid field element: expected bigint, got "+typeof X);return c<=X&&X<$},is0:(X)=>X===c,isValidNot0:(X)=>!x.is0(X)&&x.isValid(X),isOdd:(X)=>(X&h)===h,neg:(X)=>o(-X,$),eql:(X,j)=>X===j,sqr:(X)=>o(X*X,$),add:(X,j)=>o(X+j,$),sub:(X,j)=>o(X-j,$),mul:(X,j)=>o(X*j,$),pow:(X,j)=>EQ(x,X,j),div:(X,j)=>o(X*N8(j,$),$),sqrN:(X)=>X*X,addN:(X,j)=>X+j,subN:(X,j)=>X-j,mulN:(X,j)=>X*j,inv:(X)=>N8(X,$),sqrt:z||((X)=>{if(!N)N=SQ($);return N(x,X)}),toBytes:(X)=>G?u$(X,V):b0(X,V),fromBytes:(X,j=!0)=>{if(Z){if(!Z.includes(X.length)||X.length>V)throw Error("Field.fromBytes: expected "+Z+" bytes, got "+X.length);let w=new Uint8Array(V);w.set(X,G?0:w.length-X.length),X=w}if(X.length!==V)throw Error("Field.fromBytes: expected "+V+" bytes, got "+X.length);let A=G?y$(X):K0(X);if(Y)A=o(A,$);if(!j){if(!x.isValid(A))throw Error("invalid field element: outside of range 0..ORDER")}return A},invertBatch:(X)=>M$(x,X),cmov:(X,j,A)=>A?j:X});return Object.freeze(x)}function x8($){if(typeof $!=="bigint")throw Error("field order must be bigint");let J=$.toString(2).length;return Math.ceil(J/8)}function c$($){let J=x8($);return J+Math.ceil(J/2)}function N$($,J,G=!1){let Q=$.length,q=x8(J),z=c$(J);if(Q<16||Q<z||Q>1024)throw Error("expected "+z+"-1024 bytes of input, got "+Q);let Y=G?y$($):K0($),Z=o(Y,J-h)+h;return G?u$(Z,q):b0(Z,q)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var _0=BigInt(0),P0=BigInt(1);function n0($,J){let G=J.negate();return $?G:J}function V$($,J){let G=M$($.Fp,J.map((Q)=>Q.Z));return J.map((Q,q)=>$.fromAffine(Q.toAffine(G[q])))}function I8($,J){if(!Number.isSafeInteger($)||$<=0||$>J)throw Error("invalid window size, expected [1.."+J+"], got W="+$)}function l$($,J){I8($,J);let G=Math.ceil(J/$)+1,Q=2**($-1),q=2**$,z=H0($),Y=BigInt($);return{windows:G,windowSize:Q,mask:z,maxNumber:q,shiftBy:Y}}function w8($,J,G){let{windowSize:Q,mask:q,maxNumber:z,shiftBy:Y}=G,Z=Number($&q),U=$>>Y;if(Z>Q)Z-=z,U+=P0;let V=J*Q,N=V+Math.abs(Z)-1,x=Z===0,X=Z<0,j=J%2!==0;return{nextN:U,offset:N,isZero:x,isNeg:X,isNegF:j,offsetF:V}}function fQ($,J){if(!Array.isArray($))throw Error("array expected");$.forEach((G,Q)=>{if(!(G instanceof J))throw Error("invalid point at index "+Q)})}function vQ($,J){if(!Array.isArray($))throw Error("array of scalars expected");$.forEach((G,Q)=>{if(!J.isValid(G))throw Error("invalid scalar at index "+Q)})}var d$=new WeakMap,S8=new WeakMap;function r$($){return S8.get($)||1}function L8($){if($!==_0)throw Error("invalid wNAF")}class o${constructor($,J){this.BASE=$.BASE,this.ZERO=$.ZERO,this.Fn=$.Fn,this.bits=J}_unsafeLadder($,J,G=this.ZERO){let Q=$;while(J>_0){if(J&P0)G=G.add(Q);Q=Q.double(),J>>=P0}return G}precomputeWindow($,J){let{windows:G,windowSize:Q}=l$(J,this.bits),q=[],z=$,Y=z;for(let Z=0;Z<G;Z++){Y=z,q.push(Y);for(let U=1;U<Q;U++)Y=Y.add(z),q.push(Y);z=Y.double()}return q}wNAF($,J,G){if(!this.Fn.isValid(G))throw Error("invalid scalar");let Q=this.ZERO,q=this.BASE,z=l$($,this.bits);for(let Y=0;Y<z.windows;Y++){let{nextN:Z,offset:U,isZero:V,isNeg:N,isNegF:x,offsetF:X}=w8(G,Y,z);if(G=Z,V)q=q.add(n0(x,J[X]));else Q=Q.add(n0(N,J[U]))}return L8(G),{p:Q,f:q}}wNAFUnsafe($,J,G,Q=this.ZERO){let q=l$($,this.bits);for(let z=0;z<q.windows;z++){if(G===_0)break;let{nextN:Y,offset:Z,isZero:U,isNeg:V}=w8(G,z,q);if(G=Y,U)continue;else{let N=J[Z];Q=Q.add(V?N.negate():N)}}return L8(G),Q}getPrecomputes($,J,G){let Q=d$.get(J);if(!Q){if(Q=this.precomputeWindow(J,$),$!==1){if(typeof G==="function")Q=G(Q);d$.set(J,Q)}}return Q}cached($,J,G){let Q=r$($);return this.wNAF(Q,this.getPrecomputes(Q,$,G),J)}unsafe($,J,G,Q){let q=r$($);if(q===1)return this._unsafeLadder($,J,Q);return this.wNAFUnsafe(q,this.getPrecomputes(q,$,G),J,Q)}createCache($,J){I8(J,this.bits),S8.set($,J),d$.delete($)}hasCache($){return r$($)!==1}}function P8($,J,G,Q){let q=J,z=$.ZERO,Y=$.ZERO;while(G>_0||Q>_0){if(G&P0)z=z.add(q);if(Q&P0)Y=Y.add(q);q=q.double(),G>>=P0,Q>>=P0}return{p1:z,p2:Y}}function E8($,J,G,Q){fQ(G,$),vQ(Q,J);let q=G.length,z=Q.length;if(q!==z)throw Error("arrays of points and scalars must have equal length");let Y=$.ZERO,Z=D$(BigInt(q)),U=1;if(Z>12)U=Z-3;else if(Z>4)U=Z-2;else if(Z>0)U=2;let V=H0(U),N=Array(Number(V)+1).fill(Y),x=Math.floor((J.BITS-1)/U)*U,X=Y;for(let j=x;j>=0;j-=U){N.fill(Y);for(let w=0;w<z;w++){let E=Q[w],v=Number(E>>BigInt(j)&V);N[v]=N[v].add(G[w])}let A=Y;for(let w=N.length-1,E=Y;w>0;w--)E=E.add(N[w]),A=A.add(E);if(X=X.add(A),j!==0)for(let w=0;w<U;w++)X=X.double()}return X}function k8($,J,G){if(J){if(J.ORDER!==$)throw Error("Field.ORDER must match order: Fp == p, Fn == n");return h$(J),J}else return O0($,{isLE:G})}function f8($,J,G={},Q){if(Q===void 0)Q=$==="edwards";if(!J||typeof J!=="object")throw Error(`expected valid ${$} CURVE object`);for(let U of["p","n","h"]){let V=J[U];if(!(typeof V==="bigint"&&V>_0))throw Error(`CURVE.${U} must be positive bigint`)}let q=k8(J.p,G.Fp,Q),z=k8(J.n,G.Fn,Q),Z=["Gx","Gy","a",$==="weierstrass"?"b":"d"];for(let U of Z)if(!q.isValid(J[U]))throw Error(`CURVE.${U} must be valid field element of CURVE.Fp`);return J=Object.freeze(Object.assign({},J)),{CURVE:J,Fp:q,Fn:z}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var v8=($,J)=>($+($>=0?J:-J)/_8)/J;function bQ($,J,G){let[[Q,q],[z,Y]]=J,Z=v8(Y*$,G),U=v8(-q*$,G),V=$-Z*Q-U*z,N=-Z*q-U*Y,x=V<M0,X=N<M0;if(x)V=-V;if(X)N=-N;let j=H0(Math.ceil(D$(G)/2))+g0;if(V<M0||V>=j||N<M0||N>=j)throw Error("splitScalar (endomorphism): failed, k="+$);return{k1neg:x,k1:V,k2neg:X,k2:N}}function i$($){if(!["compact","recovered","der"].includes($))throw Error('Signature format must be "compact", "recovered", or "der"');return $}function p$($,J){let G={};for(let Q of Object.keys(J))G[Q]=$[Q]===void 0?J[Q]:$[Q];if(o0(G.lowS,"lowS"),o0(G.prehash,"prehash"),G.format!==void 0)i$(G.format);return G}class b8 extends Error{constructor($=""){super($)}}var D0={Err:b8,_tlv:{encode:($,J)=>{let{Err:G}=D0;if($<0||$>256)throw new G("tlv.encode: wrong tag");if(J.length&1)throw new G("tlv.encode: unpadded data");let Q=J.length/2,q=p0(Q);if(q.length/2&128)throw new G("tlv.encode: long form length too big");let z=Q>127?p0(q.length/2|128):"";return p0($)+z+q+J},decode($,J){let{Err:G}=D0,Q=0;if($<0||$>256)throw new G("tlv.encode: wrong tag");if(J.length<2||J[Q++]!==$)throw new G("tlv.decode: wrong tlv");let q=J[Q++],z=!!(q&128),Y=0;if(!z)Y=q;else{let U=q&127;if(!U)throw new G("tlv.decode(long): indefinite length not supported");if(U>4)throw new G("tlv.decode(long): byte length is too big");let V=J.subarray(Q,Q+U);if(V.length!==U)throw new G("tlv.decode: length bytes not complete");if(V[0]===0)throw new G("tlv.decode(long): zero leftmost byte");for(let N of V)Y=Y<<8|N;if(Q+=U,Y<128)throw new G("tlv.decode(long): not minimal encoding")}let Z=J.subarray(Q,Q+Y);if(Z.length!==Y)throw new G("tlv.decode: wrong value length");return{v:Z,l:J.subarray(Q+Y)}}},_int:{encode($){let{Err:J}=D0;if($<M0)throw new J("integer: negative integers are not allowed");let G=p0($);if(Number.parseInt(G[0],16)&8)G="00"+G;if(G.length&1)throw new J("unexpected DER parsing assertion: unpadded hex");return G},decode($){let{Err:J}=D0;if($[0]&128)throw new J("invalid signature integer: negative");if($[0]===0&&!($[1]&128))throw new J("invalid signature integer: unnecessary leading zero");return K0($)}},toSig($){let{Err:J,_int:G,_tlv:Q}=D0,q=m("signature",$),{v:z,l:Y}=Q.decode(48,q);if(Y.length)throw new J("invalid signature: left bytes after parsing");let{v:Z,l:U}=Q.decode(2,z),{v:V,l:N}=Q.decode(2,U);if(N.length)throw new J("invalid signature: left bytes after parsing");return{r:G.decode(Z),s:G.decode(V)}},hexFromSig($){let{_tlv:J,_int:G}=D0,Q=J.encode(2,G.encode($.r)),q=J.encode(2,G.encode($.s)),z=Q+q;return J.encode(48,z)}},M0=BigInt(0),g0=BigInt(1),_8=BigInt(2),C$=BigInt(3),_Q=BigInt(4);function A0($,J){let{BYTES:G}=$,Q;if(typeof J==="bigint")Q=J;else{let q=m("private key",J);try{Q=$.fromBytes(q)}catch(z){throw Error(`invalid private key: expected ui8a of size ${G}, got ${typeof J}`)}}if(!$.isValidNot0(Q))throw Error("invalid private key: out of range [1..N-1]");return Q}function gQ($,J={}){let G=f8("weierstrass",$,J),{Fp:Q,Fn:q}=G,z=G.CURVE,{h:Y,n:Z}=z;a0(J,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});let{endo:U}=J;if(U){if(!Q.is0(z.a)||typeof U.beta!=="bigint"||!Array.isArray(U.basises))throw Error('invalid endo: expected "beta": bigint and "basises": array')}let V=y8(Q,q);function N(){if(!Q.isOdd)throw Error("compression is not supported: Field does not have .isOdd()")}function x(W,B,D){let{x:T,y:K}=B.toAffine(),M=Q.toBytes(T);if(o0(D,"isCompressed"),D){N();let H=!Q.isOdd(K);return d(g8(H),M)}else return d(Uint8Array.of(4),M,Q.toBytes(K))}function X(W){T0(W,void 0,"Point");let{publicKey:B,publicKeyUncompressed:D}=V,T=W.length,K=W[0],M=W.subarray(1);if(T===B&&(K===2||K===3)){let H=Q.fromBytes(M);if(!Q.isValid(H))throw Error("bad point: is not on curve, wrong x");let O=w(H),C;try{C=Q.sqrt(O)}catch(I){let L=I instanceof Error?": "+I.message:"";throw Error("bad point: is not on curve, sqrt error"+L)}N();let R=Q.isOdd(C);if((K&1)===1!==R)C=Q.neg(C);return{x:H,y:C}}else if(T===D&&K===4){let H=Q.BYTES,O=Q.fromBytes(M.subarray(0,H)),C=Q.fromBytes(M.subarray(H,H*2));if(!E(O,C))throw Error("bad point: is not on curve");return{x:O,y:C}}else throw Error(`bad point: got length ${T}, expected compressed=${B} or uncompressed=${D}`)}let j=J.toBytes||x,A=J.fromBytes||X;function w(W){let B=Q.sqr(W),D=Q.mul(B,W);return Q.add(Q.add(D,Q.mul(W,z.a)),z.b)}function E(W,B){let D=Q.sqr(B),T=w(W);return Q.eql(D,T)}if(!E(z.Gx,z.Gy))throw Error("bad curve params: generator point");let v=Q.mul(Q.pow(z.a,C$),_Q),J0=Q.mul(Q.sqr(z.b),BigInt(27));if(Q.is0(Q.add(v,J0)))throw Error("bad curve params: a or b");function _(W,B,D=!1){if(!Q.isValid(B)||D&&Q.is0(B))throw Error(`bad point coordinate ${W}`);return B}function i(W){if(!(W instanceof k))throw Error("ProjectivePoint expected")}function l(W){if(!U||!U.basises)throw Error("no endo");return bQ(W,U.basises,q.ORDER)}let a=m$((W,B)=>{let{X:D,Y:T,Z:K}=W;if(Q.eql(K,Q.ONE))return{x:D,y:T};let M=W.is0();if(B==null)B=M?Q.ONE:Q.inv(K);let H=Q.mul(D,B),O=Q.mul(T,B),C=Q.mul(K,B);if(M)return{x:Q.ZERO,y:Q.ZERO};if(!Q.eql(C,Q.ONE))throw Error("invZ was invalid");return{x:H,y:O}}),V0=m$((W)=>{if(W.is0()){if(J.allowInfinityPoint&&!Q.is0(W.Y))return;throw Error("bad point: ZERO")}let{x:B,y:D}=W.toAffine();if(!Q.isValid(B)||!Q.isValid(D))throw Error("bad point: x or y not field elements");if(!E(B,D))throw Error("bad point: equation left != right");if(!W.isTorsionFree())throw Error("bad point: not in prime-order subgroup");return!0});function G0(W,B,D,T,K){return D=new k(Q.mul(D.X,W),D.Y,D.Z),B=n0(T,B),D=n0(K,D),B.add(D)}class k{constructor(W,B,D){this.X=_("x",W),this.Y=_("y",B,!0),this.Z=_("z",D),Object.freeze(this)}static CURVE(){return z}static fromAffine(W){let{x:B,y:D}=W||{};if(!W||!Q.isValid(B)||!Q.isValid(D))throw Error("invalid affine point");if(W instanceof k)throw Error("projective point not allowed");if(Q.is0(B)&&Q.is0(D))return k.ZERO;return new k(B,D,Q.ONE)}static fromBytes(W){let B=k.fromAffine(A(T0(W,void 0,"point")));return B.assertValidity(),B}static fromHex(W){return k.fromBytes(m("pointHex",W))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(W=8,B=!0){if(S.createCache(this,W),!B)this.multiply(C$);return this}assertValidity(){V0(this)}hasEvenY(){let{y:W}=this.toAffine();if(!Q.isOdd)throw Error("Field doesn't support isOdd");return!Q.isOdd(W)}equals(W){i(W);let{X:B,Y:D,Z:T}=this,{X:K,Y:M,Z:H}=W,O=Q.eql(Q.mul(B,H),Q.mul(K,T)),C=Q.eql(Q.mul(D,H),Q.mul(M,T));return O&&C}negate(){return new k(this.X,Q.neg(this.Y),this.Z)}double(){let{a:W,b:B}=z,D=Q.mul(B,C$),{X:T,Y:K,Z:M}=this,H=Q.ZERO,O=Q.ZERO,C=Q.ZERO,R=Q.mul(T,T),g=Q.mul(K,K),I=Q.mul(M,M),L=Q.mul(T,K);return L=Q.add(L,L),C=Q.mul(T,M),C=Q.add(C,C),H=Q.mul(W,C),O=Q.mul(D,I),O=Q.add(H,O),H=Q.sub(g,O),O=Q.add(g,O),O=Q.mul(H,O),H=Q.mul(L,H),C=Q.mul(D,C),I=Q.mul(W,I),L=Q.sub(R,I),L=Q.mul(W,L),L=Q.add(L,C),C=Q.add(R,R),R=Q.add(C,R),R=Q.add(R,I),R=Q.mul(R,L),O=Q.add(O,R),I=Q.mul(K,M),I=Q.add(I,I),R=Q.mul(I,L),H=Q.sub(H,R),C=Q.mul(I,g),C=Q.add(C,C),C=Q.add(C,C),new k(H,O,C)}add(W){i(W);let{X:B,Y:D,Z:T}=this,{X:K,Y:M,Z:H}=W,O=Q.ZERO,C=Q.ZERO,R=Q.ZERO,g=z.a,I=Q.mul(z.b,C$),L=Q.mul(B,K),P=Q.mul(D,M),f=Q.mul(T,H),b=Q.add(B,D),y=Q.add(K,M);b=Q.mul(b,y),y=Q.add(L,P),b=Q.sub(b,y),y=Q.add(B,T);let u=Q.add(K,H);return y=Q.mul(y,u),u=Q.add(L,f),y=Q.sub(y,u),u=Q.add(D,T),O=Q.add(M,H),u=Q.mul(u,O),O=Q.add(P,f),u=Q.sub(u,O),R=Q.mul(g,y),O=Q.mul(I,f),R=Q.add(O,R),O=Q.sub(P,R),R=Q.add(P,R),C=Q.mul(O,R),P=Q.add(L,L),P=Q.add(P,L),f=Q.mul(g,f),y=Q.mul(I,y),P=Q.add(P,f),f=Q.sub(L,f),f=Q.mul(g,f),y=Q.add(y,f),L=Q.mul(P,y),C=Q.add(C,L),L=Q.mul(u,y),O=Q.mul(b,O),O=Q.sub(O,L),L=Q.mul(b,P),R=Q.mul(u,R),R=Q.add(R,L),new k(O,C,R)}subtract(W){return this.add(W.negate())}is0(){return this.equals(k.ZERO)}multiply(W){let{endo:B}=J;if(!q.isValidNot0(W))throw Error("invalid scalar: out of range");let D,T,K=(M)=>S.cached(this,M,(H)=>V$(k,H));if(B){let{k1neg:M,k1:H,k2neg:O,k2:C}=l(W),{p:R,f:g}=K(H),{p:I,f:L}=K(C);T=g.add(L),D=G0(B.beta,R,I,M,O)}else{let{p:M,f:H}=K(W);D=M,T=H}return V$(k,[D,T])[0]}multiplyUnsafe(W){let{endo:B}=J,D=this;if(!q.isValid(W))throw Error("invalid scalar: out of range");if(W===M0||D.is0())return k.ZERO;if(W===g0)return D;if(S.hasCache(this))return this.multiply(W);if(B){let{k1neg:T,k1:K,k2neg:M,k2:H}=l(W),{p1:O,p2:C}=P8(k,D,K,H);return G0(B.beta,O,C,T,M)}else return S.unsafe(D,W)}multiplyAndAddUnsafe(W,B,D){let T=this.multiplyUnsafe(B).add(W.multiplyUnsafe(D));return T.is0()?void 0:T}toAffine(W){return a(this,W)}isTorsionFree(){let{isTorsionFree:W}=J;if(Y===g0)return!0;if(W)return W(k,this);return S.unsafe(this,Z).is0()}clearCofactor(){let{clearCofactor:W}=J;if(Y===g0)return this;if(W)return W(k,this);return this.multiplyUnsafe(Y)}isSmallOrder(){return this.multiplyUnsafe(Y).is0()}toBytes(W=!0){return o0(W,"isCompressed"),this.assertValidity(),j(k,this,W)}toHex(W=!0){return U0(this.toBytes(W))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}get px(){return this.X}get py(){return this.X}get pz(){return this.Z}toRawBytes(W=!0){return this.toBytes(W)}_setWindowSize(W){this.precompute(W)}static normalizeZ(W){return V$(k,W)}static msm(W,B){return E8(k,q,W,B)}static fromPrivateKey(W){return k.BASE.multiply(A0(q,W))}}k.BASE=new k(z.Gx,z.Gy,Q.ONE),k.ZERO=new k(Q.ZERO,Q.ONE,Q.ZERO),k.Fp=Q,k.Fn=q;let X0=q.BITS,S=new o$(k,J.endo?Math.ceil(X0/2):X0);return k.BASE.precompute(8),k}function g8($){return Uint8Array.of($?2:3)}function y8($,J){return{secretKey:J.BYTES,publicKey:1+$.BYTES,publicKeyUncompressed:1+2*$.BYTES,publicKeyHasPrefix:!0,signature:2*J.BYTES}}function yQ($,J={}){let{Fn:G}=$,Q=J.randomBytes||I0,q=Object.assign(y8($.Fp,G),{seed:c$(G.ORDER)});function z(j){try{return!!A0(G,j)}catch(A){return!1}}function Y(j,A){let{publicKey:w,publicKeyUncompressed:E}=q;try{let v=j.length;if(A===!0&&v!==w)return!1;if(A===!1&&v!==E)return!1;return!!$.fromBytes(j)}catch(v){return!1}}function Z(j=Q(q.seed)){return N$(T0(j,q.seed,"seed"),G.ORDER)}function U(j,A=!0){return $.BASE.multiply(A0(G,j)).toBytes(A)}function V(j){let A=Z(j);return{secretKey:A,publicKey:U(A)}}function N(j){if(typeof j==="bigint")return!1;if(j instanceof $)return!0;let{secretKey:A,publicKey:w,publicKeyUncompressed:E}=q;if(G.allowedLengths||A===w)return;let v=m("key",j).length;return v===w||v===E}function x(j,A,w=!0){if(N(j)===!0)throw Error("first arg must be private key");if(N(A)===!1)throw Error("second arg must be public key");let E=A0(G,j);return $.fromHex(A).multiply(E).toBytes(w)}return Object.freeze({getPublicKey:U,getSharedSecret:x,keygen:V,Point:$,utils:{isValidSecretKey:z,isValidPublicKey:Y,randomSecretKey:Z,isValidPrivateKey:z,randomPrivateKey:Z,normPrivateKeyToScalar:(j)=>A0(G,j),precompute(j=8,A=$.BASE){return A.precompute(j,!1)}},lengths:q})}function uQ($,J,G={}){Z$(J),a0(G,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});let Q=G.randomBytes||I0,q=G.hmac||((D,...T)=>v$(J,D,d(...T))),{Fp:z,Fn:Y}=$,{ORDER:Z,BITS:U}=Y,{keygen:V,getPublicKey:N,getSharedSecret:x,utils:X,lengths:j}=yQ($,G),A={prehash:!1,lowS:typeof G.lowS==="boolean"?G.lowS:!1,format:void 0,extraEntropy:!1},w="compact";function E(D){let T=Z>>g0;return D>T}function v(D,T){if(!Y.isValidNot0(T))throw Error(`invalid signature ${D}: out of range 1..Point.Fn.ORDER`);return T}function J0(D,T){i$(T);let K=j.signature,M=T==="compact"?K:T==="recovered"?K+1:void 0;return T0(D,M,`${T} signature`)}class _{constructor(D,T,K){if(this.r=v("r",D),this.s=v("s",T),K!=null)this.recovery=K;Object.freeze(this)}static fromBytes(D,T=w){J0(D,T);let K;if(T==="der"){let{r:C,s:R}=D0.toSig(T0(D));return new _(C,R)}if(T==="recovered")K=D[0],T="compact",D=D.subarray(1);let M=Y.BYTES,H=D.subarray(0,M),O=D.subarray(M,M*2);return new _(Y.fromBytes(H),Y.fromBytes(O),K)}static fromHex(D,T){return this.fromBytes(k0(D),T)}addRecoveryBit(D){return new _(this.r,this.s,D)}recoverPublicKey(D){let T=z.ORDER,{r:K,s:M,recovery:H}=this;if(H==null||![0,1,2,3].includes(H))throw Error("recovery id invalid");if(Z*_8<T&&H>1)throw Error("recovery id is ambiguous for h>1 curve");let C=H===2||H===3?K+Z:K;if(!z.isValid(C))throw Error("recovery id 2 or 3 invalid");let R=z.toBytes(C),g=$.fromBytes(d(g8((H&1)===0),R)),I=Y.inv(C),L=l(m("msgHash",D)),P=Y.create(-L*I),f=Y.create(M*I),b=$.BASE.multiplyUnsafe(P).add(g.multiplyUnsafe(f));if(b.is0())throw Error("point at infinify");return b.assertValidity(),b}hasHighS(){return E(this.s)}toBytes(D=w){if(i$(D),D==="der")return k0(D0.hexFromSig(this));let T=Y.toBytes(this.r),K=Y.toBytes(this.s);if(D==="recovered"){if(this.recovery==null)throw Error("recovery bit must be present");return d(Uint8Array.of(this.recovery),T,K)}return d(T,K)}toHex(D){return U0(this.toBytes(D))}assertValidity(){}static fromCompact(D){return _.fromBytes(m("sig",D),"compact")}static fromDER(D){return _.fromBytes(m("sig",D),"der")}normalizeS(){return this.hasHighS()?new _(this.r,Y.neg(this.s),this.recovery):this}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return U0(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return U0(this.toBytes("compact"))}}let i=G.bits2int||function(T){if(T.length>8192)throw Error("input is too large");let K=K0(T),M=T.length*8-U;return M>0?K>>BigInt(M):K},l=G.bits2int_modN||function(T){return Y.create(i(T))},a=H0(U);function V0(D){return M8("num < 2^"+U,D,M0,a),Y.toBytes(D)}function G0(D,T){return T0(D,void 0,"message"),T?T0(J(D),void 0,"prehashed message"):D}function k(D,T,K){if(["recovered","canonical"].some((f)=>(f in K)))throw Error("sign() legacy options not supported");let{lowS:M,prehash:H,extraEntropy:O}=p$(K,A);D=G0(D,H);let C=l(D),R=A0(Y,T),g=[V0(R),V0(C)];if(O!=null&&O!==!1){let f=O===!0?Q(j.secretKey):O;g.push(m("extraEntropy",f))}let I=d(...g),L=C;function P(f){let b=i(f);if(!Y.isValidNot0(b))return;let y=Y.inv(b),u=$.BASE.multiply(b).toAffine(),F=Y.create(u.x);if(F===M0)return;let n=Y.create(y*Y.create(L+F*R));if(n===M0)return;let q0=(u.x===F?0:2)|Number(u.y&g0),r=n;if(M&&E(n))r=Y.neg(n),q0^=1;return new _(F,r,q0)}return{seed:I,k2sig:P}}function X0(D,T,K={}){D=m("message",D);let{seed:M,k2sig:H}=k(D,T,K);return W8(J.outputLen,Y.BYTES,q)(M,H)}function S(D){let T=void 0,K=typeof D==="string"||w0(D),M=!K&&D!==null&&typeof D==="object"&&typeof D.r==="bigint"&&typeof D.s==="bigint";if(!K&&!M)throw Error("invalid signature, expected Uint8Array, hex string or Signature instance");if(M)T=new _(D.r,D.s);else if(K){try{T=_.fromBytes(m("sig",D),"der")}catch(H){if(!(H instanceof D0.Err))throw H}if(!T)try{T=_.fromBytes(m("sig",D),"compact")}catch(H){return!1}}if(!T)return!1;return T}function W(D,T,K,M={}){let{lowS:H,prehash:O,format:C}=p$(M,A);if(K=m("publicKey",K),T=G0(m("message",T),O),"strict"in M)throw Error("options.strict was renamed to lowS");let R=C===void 0?S(D):_.fromBytes(m("sig",D),C);if(R===!1)return!1;try{let g=$.fromBytes(K);if(H&&R.hasHighS())return!1;let{r:I,s:L}=R,P=l(T),f=Y.inv(L),b=Y.create(P*f),y=Y.create(I*f),u=$.BASE.multiplyUnsafe(b).add(g.multiplyUnsafe(y));if(u.is0())return!1;return Y.create(u.x)===I}catch(g){return!1}}function B(D,T,K={}){let{prehash:M}=p$(K,A);return T=G0(T,M),_.fromBytes(D,"recovered").recoverPublicKey(T).toBytes()}return Object.freeze({keygen:V,getPublicKey:N,getSharedSecret:x,utils:X,lengths:j,Point:$,sign:X0,verify:W,recoverPublicKey:B,Signature:_,hash:J})}function mQ($){let J={a:$.a,b:$.b,p:$.Fp.ORDER,n:$.n,h:$.h,Gx:$.Gx,Gy:$.Gy},G=$.Fp,Q=$.allowedPrivateKeyLengths?Array.from(new Set($.allowedPrivateKeyLengths.map((Y)=>Math.ceil(Y/2)))):void 0,q=O0(J.n,{BITS:$.nBitLength,allowedLengths:Q,modFromBytes:$.wrapPrivateKey}),z={Fp:G,Fn:q,allowInfinityPoint:$.allowInfinityPoint,endo:$.endo,isTorsionFree:$.isTorsionFree,clearCofactor:$.clearCofactor,fromBytes:$.fromBytes,toBytes:$.toBytes};return{CURVE:J,curveOpts:z}}function FQ($){let{CURVE:J,curveOpts:G}=mQ($),Q={hmac:$.hmac,randomBytes:$.randomBytes,lowS:$.lowS,bits2int:$.bits2int,bits2int_modN:$.bits2int_modN};return{CURVE:J,curveOpts:G,hash:$.hash,ecdsaOpts:Q}}function hQ($,J){let G=J.Point;return Object.assign({},J,{ProjectivePoint:G,CURVE:Object.assign({},$,W$(G.Fn.ORDER,G.Fn.BITS))})}function u8($){let{CURVE:J,curveOpts:G,hash:Q,ecdsaOpts:q}=FQ($),z=gQ(J,G),Y=uQ(z,Q,q);return hQ($,Y)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */function m8($,J){let G=(Q)=>u8({...$,hash:Q});return{...G(J),create:G}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var y0={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},cQ={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]},lQ=BigInt(0),F8=BigInt(1),a$=BigInt(2);function dQ($){let J=y0.p,G=BigInt(3),Q=BigInt(6),q=BigInt(11),z=BigInt(22),Y=BigInt(23),Z=BigInt(44),U=BigInt(88),V=$*$*$%J,N=V*V*$%J,x=p(N,G,J)*N%J,X=p(x,G,J)*N%J,j=p(X,a$,J)*V%J,A=p(j,q,J)*j%J,w=p(A,z,J)*A%J,E=p(w,Z,J)*w%J,v=p(E,U,J)*E%J,J0=p(v,Z,J)*w%J,_=p(J0,G,J)*N%J,i=p(_,Y,J)*A%J,l=p(i,Q,J)*V%J,a=p(l,a$,J);if(!T$.eql(T$.sqr(a),$))throw Error("Cannot find square root");return a}var T$=O0(y0.p,{sqrt:dQ}),l8=m8({...y0,Fp:T$,lowS:!0,endo:cQ},K$),h8={};function H$($,...J){let G=h8[$];if(G===void 0){let Q=K$(j$($));G=d(Q,Q),h8[$]=G}return K$(d(G,...J))}var s$=($)=>$.toBytes(!0).slice(1),u0=(()=>l8.Point)(),t$=($)=>$%a$===lQ;function n$($){let{Fn:J,BASE:G}=u0,Q=A0(J,$),q=G.multiply(Q);return{scalar:t$(q.y)?Q:J.neg(Q),bytes:s$(q)}}function d8($){let J=T$;if(!J.isValidNot0($))throw Error("invalid x: Fail if x ≥ p");let G=J.create($*$),Q=J.create(G*$+BigInt(7)),q=J.sqrt(Q);if(!t$(q))q=J.neg(q);let z=u0.fromAffine({x:$,y:q});return z.assertValidity(),z}var s0=K0;function r8(...$){return u0.Fn.create(s0(H$("BIP0340/challenge",...$)))}function c8($){return n$($).bytes}function rQ($,J,G=I0(32)){let{Fn:Q}=u0,q=m("message",$),{bytes:z,scalar:Y}=n$(J),Z=m("auxRand",G,32),U=Q.toBytes(Y^s0(H$("BIP0340/aux",Z))),V=H$("BIP0340/nonce",U,z,q),{bytes:N,scalar:x}=n$(V),X=r8(N,z,q),j=new Uint8Array(64);if(j.set(N,0),j.set(Q.toBytes(Q.create(x+X*Y)),32),!o8(j,q,z))throw Error("sign: Invalid signature produced");return j}function o8($,J,G){let{Fn:Q,BASE:q}=u0,z=m("signature",$,64),Y=m("message",J),Z=m("publicKey",G,32);try{let U=d8(s0(Z)),V=s0(z.subarray(0,32));if(!i0(V,F8,y0.p))return!1;let N=s0(z.subarray(32,64));if(!i0(N,F8,y0.n))return!1;let x=r8(Q.toBytes(V),s$(U),Y),X=q.multiplyUnsafe(N).add(U.multiplyUnsafe(Q.neg(x))),{x:j,y:A}=X.toAffine();if(X.is0()||!t$(A)||j!==V)return!1;return!0}catch(U){return!1}}var O$=(()=>{let G=(q=I0(48))=>{return N$(q,y0.n)};l8.utils.randomSecretKey;function Q(q){let z=G(q);return{secretKey:z,publicKey:c8(z)}}return{keygen:Q,getPublicKey:c8,sign:rQ,verify:o8,Point:u0,utils:{randomSecretKey:G,randomPrivateKey:G,taggedHash:H$,lift_x:d8,pointToBytes:s$,numberToBytesBE:b0,bytesToNumberBE:K0,mod:o},lengths:{secretKey:32,publicKey:32,publicKeyHasPrefix:!1,signature:64,seed:48}}})();var oQ=new TextEncoder,pQ=new TextDecoder,Y0=($)=>oQ.encode($),E0=($)=>pQ.decode($),A$=($)=>Array.from($,(J)=>J.toString(16).padStart(2,"0")).join(""),t=JSON.stringify,f0=JSON.parse,B$=($,J=Number.MAX_SAFE_INTEGER)=>$.split("").reduce((G,Q)=>G+Q.charCodeAt(0),0)%J;var e$="AES-GCM",iQ={},p8="$",i8=",",aQ=($)=>{let J=new Uint8Array($),G=32768,Q="";for(let q=0;q<J.length;q+=32768)Q+=String.fromCharCode(...J.subarray(q,q+32768));return btoa(Q)},nQ=($)=>Uint8Array.from(atob($),(J)=>J.charCodeAt(0)).buffer,t0=($)=>iQ[$]??=crypto.subtle.digest("SHA-1",Y0($)).then((J)=>{let G=new Uint8Array(J),Q="";for(let q of G)Q+=q.toString(36);return Q}),a8=async($,J,G)=>{let Q=await crypto.subtle.digest("SHA-256",Y0(`${$}:${J}:${G}`));return crypto.subtle.importKey("raw",Q,{name:e$},!1,["encrypt","decrypt"])},n8=async($,J)=>{let G=crypto.getRandomValues(new Uint8Array(12)),Q=await $,q=await crypto.subtle.encrypt({name:e$,iv:G},Q,Y0(J));return`${G.join(i8)}${p8}${aQ(q)}`},s8=async($,J)=>{let[G,Q]=J.split(p8);if(!G||!Q)throw Error("Invalid encrypted payload format");let q=Uint8Array.from(G.split(i8),Number),z=await $,Y=await crypto.subtle.decrypt({name:e$,iv:q},z,nQ(Q));return E0(Y)};var e0="GenosRTC",m0=($,J)=>Array.from({length:$},J);var $$=($)=>Array.from(crypto.getRandomValues(new Uint8Array($)),(J)=>"0123456789AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz"[J%62]).join(""),W0=$$(20),N0=Promise.all.bind(Promise),t8=typeof window<"u",{entries:e8,fromEntries:R$,keys:J9}=Object,$Q=()=>{},Q0=($)=>Error(`GenosRTC: ${$}`),Q$=(...$)=>$.join("@"),QQ=($,J)=>{let G=[...$],Q=G.length,q=()=>{let z=Math.sin(J++)*1e4;return z-Math.floor(z)};while(Q){let z=Math.floor(q()*Q--);[G[Q],G[z]]=[G[z],G[Q]]}return G};var sQ=5000,JQ="icegatheringstatechange",GQ="offer",tQ="answer",eQ=[...m0(3,($,J)=>`stun:stun${J||""}.l.google.com:19302`),"stun:stun.cloudflare.com:3478"].map(($)=>({urls:$})),x$=($,{rtcConfig:J,rtcPolyfill:G,turnConfig:Q})=>{let q=new(G||RTCPeerConnection)({iceServers:[...eQ,...Q||[]],...J}),z={},Y=!1,Z=!1,U,V=(X)=>Object.assign(X,{binaryType:"arraybuffer",bufferedAmountLowThreshold:65535,onmessage:(j)=>z.data?.(j.data),onopen:()=>z.connect?.(),onclose:()=>z.close?.(),onerror:(j)=>!j?.error?.message?.includes("User-Initiated Abort")&&z.error?.(j)}),N=()=>Promise.race([new Promise((X)=>{let j=()=>{if(q.iceGatheringState==="complete")q.removeEventListener(JQ,j),X()};q.addEventListener(JQ,j),j()}),new Promise((X)=>setTimeout(X,sQ))]).then(()=>({type:q.localDescription.type,sdp:q.localDescription.sdp.replace(/a=ice-options:trickle\s\n/g,"")}));if($?V(U=q.createDataChannel("data")):q.ondatachannel=({channel:X})=>V(U=X),q.onnegotiationneeded=async()=>{try{Y=!0,await q.setLocalDescription(),z.signal?.(await N())}catch(X){z.error?.(X)}finally{Y=!1}},q.onconnectionstatechange=()=>{if(["disconnected","failed","closed"].includes(q.connectionState))z.close?.()},q.ontrack=(X)=>{z.track?.(X.track,X.streams[0]),z.stream?.(X.streams[0])},q.onremovestream=(X)=>z.stream?.(X.stream),$&&!q.canTrickleIceCandidates)q.onnegotiationneeded();let x=()=>q.getSenders();return{created:Date.now(),connection:q,get channel(){return U},get isDead(){return q.connectionState==="closed"},async signal(X){if(U?.readyState==="open"&&!X.sdp?.includes("a=rtpmap"))return;try{if(X.type===GQ){if(Y||q.signalingState!=="stable"&&!Z){if($)return;await N0([q.setLocalDescription({type:"rollback"}),q.setRemoteDescription(X)])}else await q.setRemoteDescription(X);await q.setLocalDescription();let j=await N();return z.signal?.(j),j}if(X.type===tQ){Z=!0;try{await q.setRemoteDescription(X)}finally{Z=!1}}}catch(j){z.error?.(j)}},sendData:(X)=>U.send(X),destroy:()=>{U?.close(),q.close(),Y=Z=!1},setHandlers:(X)=>Object.assign(z,X),offerPromise:$?new Promise((X)=>z.signal=(j)=>j.type===GQ&&X(j)):Promise.resolve(),addStream:(X)=>X.getTracks().forEach((j)=>q.addTrack(j,X)),removeStream:(X)=>x().filter((j)=>X.getTracks().includes(j.track)).forEach((j)=>q.removeTrack(j)),addTrack:(X,j)=>q.addTrack(X,j),removeTrack:(X)=>{let j=x().find((A)=>A.track===X);if(j)q.removeTrack(j)},replaceTrack:(X,j)=>x().find((A)=>A.track===X)?.replaceTrack(j)}};var $J=Object.getPrototypeOf(Uint8Array),L$=12,qQ=0,k$=qQ+L$,I$=k$+1,G$=I$+1,q$=G$+1,J$=16384-q$,w$=255,$8="bufferedamountlow",F0=($)=>`@_${$}`,Q8=100,QJ=3,JJ=200,zQ=($,J,G)=>{let Q=new Map,q=new Map,z=new Map,Y={},Z={},U={},V={},N=new Map,x=(K,M)=>{if(!N.has(K))N.set(K,new Set);N.get(K).add(M)},X=(K,M)=>N.get(K)?.delete(M),j=(K,...M)=>N.get(K)?.forEach((H)=>H(...M)),A=(K,M)=>{let H=K?Array.isArray(K)?K:[K]:Q.keys();return Array.from(H,(O)=>{let C=Q.get(O);if(!C)return null;return M(O,C)}).filter(Boolean)},w=(K)=>{if(!Q.has(K))return;Q.delete(K),delete Y[K],delete Z[K],delete U[K],delete V[K],j("peer:leave",K),J(K)},E=(K)=>new Promise((M,H)=>{let O=setTimeout(()=>{K.removeEventListener($8,C),H(Error(`${e0}: bufferLow timeout`))},5000);function C(){clearTimeout(O),K.removeEventListener($8,C),M()}K.addEventListener($8,C)}),v=(K)=>{if(z.has(K))return z.get(K);if(!K)throw Q0("action type is required");let M=Y0(K);if(M.byteLength>L$)throw Q0(`❌ "${K}" exceeds ${L$} bytes. Use a shorter name.`);let H=new Uint8Array(L$).map((P,f)=>M[f]||0),O=0,C=new Map([["message",new Set],["progress",new Set]]),R=(P,f)=>C.get(P)?.add(f),g=(P,f)=>C.get(P)?.delete(f),I=async(P,f,b,y)=>{if(b&&typeof b!=="object")throw Q0("meta must be object");if(P===void 0)throw Q0("data cannot be undefined");let u=P instanceof Blob,F=u||P instanceof ArrayBuffer||P instanceof $J,n=typeof P!=="string";if(b&&!F)throw Q0("meta only allowed with binary");let q0=F?new Uint8Array(u?await P.arrayBuffer():P):Y0(n?t(P):P),r=b?Y0(t(b)):null,s=Math.ceil(q0.byteLength/J$)+(b?1:0)||1;if(s>Q8)throw Q0(`Message too large, exceeds max chunks ${Q8}`);let q8=m0(s,(Y$,z0)=>{let c0=z0===s-1,B0=b&&z0===0,X$=B0?r:q0.subarray(b?(z0-1)*J$:z0*J$,b?z0*J$:(z0+1)*J$),R0=new Uint8Array(q$+X$.byteLength);return R0.set(H),R0.set([O],k$),R0.set([c0|B0<<1|F<<2|n<<3],I$),R0.set([Math.round((z0+1)/s*w$)],G$),R0.set(X$,q$),R0});return O=O+1&w$,N0(A(f,async(Y$,z0)=>{let{channel:c0}=z0;for(let B0=0;B0<s;B0++){let X$=0;while(c0.bufferedAmount>c0.bufferedAmountLowThreshold){if(X$++>QJ)throw Q0(`${e0}: send buffer full, max retries reached for peer ${Y$}`);try{await E(c0)}catch(R0){await new Promise((AQ)=>setTimeout(AQ,JJ))}}if(!Q.has(Y$))break;z0.sendData(q8[B0]),y?.(q8[B0][G$]/w$,Y$,b)}}))};q.set(K,{listeners:C,send:I});let L={send:I,on:R,off:g};return z.set(K,L),L},J0=(K,M)=>{try{let H=new Uint8Array(M),O=E0(H.subarray(qQ,k$)).replace(//g,"");if(!q.has(O))return;let[C]=H.subarray(k$,I$),[R]=H.subarray(I$,G$),[g]=H.subarray(G$,q$),I=H.subarray(q$),L=Boolean(R&1),P=Boolean(R&2),f=Boolean(R&4),b=Boolean(R&8),y=q.get(O),u=(Y[K]||={})[O]||={};if(u[C]?.chunks?.length>Q8)return;let F=u[C]||={chunks:[]};if(P)try{F.meta=f0(E0(I))}catch{return}else F.chunks.push(I);if(y.listeners.get("progress").forEach((r)=>{try{r(g/w$,K,F.meta)}catch(s){}}),!L)return;let n=new Uint8Array(F.chunks.reduce((r,s)=>r+s.byteLength,0));F.chunks.reduce((r,s)=>(n.set(s,r),r+s.byteLength),0),delete u[C];let q0;if(f)q0=n;else if(b)try{q0=f0(E0(n))}catch{return}else q0=E0(n);y.listeners.get("message").forEach((r)=>{try{r(q0,K,F.meta)}catch(s){}})}catch(H){}},_=async()=>{try{await D(""),await new Promise((K)=>setTimeout(K,99))}catch(K){}for(let[K,M]of Q){try{M.destroy()}catch{}Q.delete(K)}G()},{send:i,on:l}=v(F0("ping")),{send:a,on:V0}=v(F0("pong")),{send:G0,on:k}=v(F0("signal")),{send:X0,on:S}=v(F0("stream")),{send:W,on:B}=v(F0("track")),{send:D,on:T}=v(F0("leave"));if($((K,M)=>{if(Q.has(M))return;Q.set(M,K),K.setHandlers({data:(H)=>J0(M,H),stream:(H)=>{j("stream:add",H,M,U[M]),delete U[M]},track:(H,O)=>{j("track:add",H,O,M,V[M]),delete V[M]},signal:(H)=>G0(H,M),close:()=>w(M),error:(H)=>{w(M)}}),j("peer:join",M)}),l("message",(K,M)=>a("",M)),V0("message",(K,M)=>{Z[M]?.(),delete Z[M]}),k("message",(K,M)=>Q.get(M)?.signal(K)),S("message",(K,M)=>U[M]=K),B("message",(K,M)=>V[M]=K),T("message",(K,M)=>w(M)),t8)addEventListener("beforeunload",_);return{on:x,off:X,channel:v,leave:_,ping:async(K)=>{if(!K)throw Q0("ping() requires target peer ID");let M=Date.now();return i("",K),await new Promise((H)=>Z[K]=H),Date.now()-M},getPeers:()=>R$(Array.from(Q,([K,M])=>[K,M.connection])),addStream:(K,M,H)=>A(M,async(O,C)=>{if(H)await X0(H,O);C.addStream(K)}),removeStream:(K,M)=>A(M,(H,O)=>O.removeStream(K)),addTrack:(K,M,H,O)=>A(H,async(C,R)=>{if(O)await W(O,C);R.addTrack(K,M)}),removeTrack:(K,M)=>A(M,(H,O)=>O.removeTrack(K)),replaceTrack:(K,M,H,O)=>A(H,async(C,R)=>{if(O)await W(O,C);R.replaceTrack(K,M)})}};var GJ=20,qJ=5333,YQ=57333,XQ=({init:$,subscribe:J,announce:G})=>{let Q={},q=!1,z,Y;return(Z,U,V)=>{let{appId:N}=Z;if(Q[N]?.[U])return Q[N][U];if(!Z||!U||!N&&!Z.firebaseApp)throw Q0(!Z?"config required":!U?"roomId required":"appId missing");let x=$Q;if(!q){let S=$(Z);Y=m0(GJ,()=>x$(!0,Z)),z=Array.isArray(S)?S:[S];let W=setInterval(()=>{Y=Y.filter((B)=>{let D=Date.now()-B.created<YQ;if(!D)B.destroy();return D})},YQ);Q.offerCleanupTimer||=W,q=!0}let X={},j={},A=Q$(e0,N,U),w=t0(A),E=t0(Q$(A,W0)),v=a8(Z.password||"",N,U),J0=(S)=>async(W)=>({type:W.type,sdp:await S(v,W.sdp)}),_=J0(s8),i=J0(n8),l=(S,W)=>{if(j[W]===S)return;j[W]?.destroy(),j[W]=S,x(S,W),X[W]?.forEach((B)=>B!==S&&B.destroy()),delete X[W]},a=(S,W)=>{if(j[W]===S)delete j[W]},V0=(S)=>async(W,B,D)=>{let[T,K]=await N0([w,E]);if(W!==T&&W!==K)return;let{peerId:M,offer:H,answer:O}=typeof B==="string"?f0(B):B;if(M===W0||j[M])return;if(H){if(X[M]?.[S]&&W0>M)return;let C=x$(!1,Z);C.setHandlers({connect:()=>l(C,M),close:()=>a(C,M)});try{let R=await _(H);if(C.isDead)return;let[g,I]=await N0([t0(Q$(A,M)),C.signal(R).then(i)]);D(g,t({peerId:W0,answer:I}))}catch{V?.({error:"decryption failed (offer)",appId:N,peerId:M,roomId:U})}}else if(O){let C=X[M]?.[S];if(!C||C.isDead)return;C.setHandlers({connect:()=>l(C,M),close:()=>a(C,M)});try{C.signal(await _(O))}catch{V?.({error:"decryption failed (answer)",appId:N,peerId:M,roomId:U})}}else{if(X[M]?.[S])return;let C=Y.pop()||x$(!0,Z),[R,{offer:g}]=await N0([t0(Q$(A,M)),C.offerPromise.then(i).then((I)=>({offer:I}))]);X[M]||=[],X[M][S]=C,C.setHandlers({connect:()=>l(C,M),close:()=>a(C,M)}),D(R,t({peerId:W0,offer:g,peer:C}))}},G0=N0(z.map(async(S,W)=>J(await S,await w,await E,V0(W)))),k=[];G0.then((S)=>{z.forEach((W,B)=>{let D=async()=>{let T=await G(await W,await w,await E);k[B]=setTimeout(D,typeof T==="number"?T:qJ)};D()}),Q[N][U].onCleanup=()=>{if(delete Q[N][U],k.forEach(clearTimeout),S.forEach((W)=>W()),Object.keys(Q).length===0)clearInterval(Q.offerCleanupTimer),delete Q.offerCleanupTimer}}),Q[N]||={};let X0=zQ((S)=>x=S,(S)=>delete j[S],()=>X0.onCleanup?.());return Q[N][U]=X0}};var ZQ=3333,S$={},UQ={},jQ=($,J)=>{let G={},Q=null,q=()=>{if(Q)clearTimeout(Q),Q=null;let z=new WebSocket($);z.onclose=()=>{S$[$]??=ZQ,Q=setTimeout(q,S$[$]),S$[$]*=2},z.onmessage=(Y)=>J(Y.data),G.socket=z,G.url=z.url,G.ready=new Promise((Y)=>{z.onopen=()=>{S$[$]=ZQ,Y(G)}}),G.send=(Y)=>{if(z.readyState===1)z.send(Y)}};return G.forceReconnect=q,q(),UQ[$]=G,G};if(typeof window<"u"){let $=()=>{Object.values(UQ).forEach((J)=>{if(J.socket&&J.socket.readyState!==WebSocket.OPEN&&J.socket.readyState!==WebSocket.CONNECTING)J.forceReconnect()})};window.addEventListener("online",()=>{$()}),window.addEventListener("offline",async()=>{}),document.addEventListener("visibilitychange",()=>{if(document.visibilityState==="visible")$()})}var KQ=($)=>()=>R$(e8($).map(([J,G])=>[J,G.socket])),DQ=($,J,G,Q)=>($.relayUrls??(Q?QQ(J,B$($.appId)):J)).slice(0,$.relayUrls?.length??$.relayRedundancy??G);var h0={},zJ=5,VQ="x",CQ="EVENT",YJ=/pow:\s*(\d+)\s*bits needed\.?/i,J8=new Set,TQ=O$.utils.randomSecretKey(),XJ=A$(O$.getPublicKey(TQ)),G8={},z$={},ZJ={},HQ=()=>Math.floor(Date.now()/1000),OQ=($)=>ZJ[$]??=B$($,1e4)+20000,P$=($)=>$.replace(/\/$/,""),UJ=["wss://black.nostrcity.club","wss://eu.purplerelay.com","wss://ftp.halifax.rwth-aachen.de/nostr","wss://nostr.data.haus","wss://nostr.mom","wss://nostr.oxtr.dev","wss://nostr.sathoarder.com","wss://nostr.vulpem.com","wss://relay.fountain.fm","wss://relay.mostro.network","wss://relay.nostrdice.com","wss://sendit.nosflare.com","wss://yabu.me/v2","wss://relay.damus.io"],jJ=($,J)=>{let[G,Q,q,z]=f0(J);if(G===CQ)return z$[Q]?.(G8[Q],q.content);if(G==="NOTICE"||G==="OK"&&!q){if(+((G==="NOTICE"?Q:z).match(YJ)?.[1]??0)>0){let Z=P$($);J8.add(Z),h0[Z]?.close?.(),delete h0[Z]}}},KJ=($)=>{let J=P$($);if(h0[J])return h0[J];let G=jQ(J,(Q)=>jJ(J,Q));return h0[J]=G},MQ=async($,J)=>{let G={kind:OQ($),content:J,pubkey:XJ,created_at:HQ(),tags:[[VQ,$]]},Q=Y0(t([0,G.pubkey,G.created_at,G.kind,G.tags,G.content])),q=new Uint8Array(await crypto.subtle.digest("SHA-256",Q)),z=O$.sign(q,TQ);return t([CQ,{...G,id:A$(q),sig:A$(z)}])},WQ=($,J)=>{return G8[$]=J,t(["REQ",$,{kinds:[OQ(J)],since:HQ(),["#"+VQ]:[J]}])},NQ=($)=>{return delete G8[$],t(["CLOSE",$])},DJ=XQ({init:($)=>{let G=($?.relayUrls?.length?$.relayUrls:null)??UJ;return DQ($,G,zJ,!0).map(KJ).map((q)=>q.ready.then(()=>q).catch(()=>null))},subscribe:($,J,G,Q)=>{let q=$$(64),z=$$(64);return z$[q]=z$[z]=(Y,Z)=>Q(Y,Z,async(U,V)=>{if(J8.has(P$($.url)))return;$.send(await MQ(U,V))}),$.send(WQ(q,J)),$.send(WQ(z,G)),()=>{$.send(NQ(q)),$.send(NQ(z)),delete z$[q],delete z$[z]}},announce:async($,J)=>{if(J8.has(P$($.url)))return;$.send(await MQ(J,t({peerId:W0})))}}),MJ=KQ(h0);export{W0 as selfId,DJ as join,MJ as getRelaySockets};
1
+ var x0=typeof globalThis==="object"&&"crypto"in globalThis?globalThis.crypto:void 0;/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */function w0($){return $ instanceof Uint8Array||ArrayBuffer.isView($)&&$.constructor.name==="Uint8Array"}function l0($){if(!Number.isSafeInteger($)||$<0)throw Error("positive integer expected, got "+$)}function $0($,...J){if(!w0($))throw Error("Uint8Array expected");if(J.length>0&&!J.includes($.length))throw Error("Uint8Array expected of length "+J+", got length="+$.length)}function Z$($){if(typeof $!=="function"||typeof $.create!=="function")throw Error("Hash should be wrapped by utils.createHasher");l0($.outputLen),l0($.blockLen)}function v0($,J=!0){if($.destroyed)throw Error("Hash instance has been destroyed");if(J&&$.finished)throw Error("Hash#digest() has already been called")}function Y8($,J){$0($);let q=J.outputLen;if($.length<q)throw Error("digestInto() expects output buffer of length at least "+q)}function L0(...$){for(let J=0;J<$.length;J++)$[J].fill(0)}function U$($){return new DataView($.buffer,$.byteOffset,$.byteLength)}function Q0($,J){return $<<32-J|$>>>J}var X8=(()=>typeof Uint8Array.from([]).toHex==="function"&&typeof Uint8Array.fromHex==="function")(),BQ=Array.from({length:256},($,J)=>J.toString(16).padStart(2,"0"));function U0($){if($0($),X8)return $.toHex();let J="";for(let q=0;q<$.length;q++)J+=BQ[$[q]];return J}var Z0={_0:48,_9:57,A:65,F:70,a:97,f:102};function z8($){if($>=Z0._0&&$<=Z0._9)return $-Z0._0;if($>=Z0.A&&$<=Z0.F)return $-(Z0.A-10);if($>=Z0.a&&$<=Z0.f)return $-(Z0.a-10);return}function k0($){if(typeof $!=="string")throw Error("hex string expected, got "+typeof $);if(X8)return Uint8Array.fromHex($);let J=$.length,q=J/2;if(J%2)throw Error("hex string expected, got unpadded hex of length "+J);let Q=new Uint8Array(q);for(let G=0,z=0;G<q;G++,z+=2){let Y=z8($.charCodeAt(z)),Z=z8($.charCodeAt(z+1));if(Y===void 0||Z===void 0){let j=$[z]+$[z+1];throw Error('hex string expected, got non-hex character "'+j+'" at index '+z)}Q[G]=Y*16+Z}return Q}function j$($){if(typeof $!=="string")throw Error("string expected");return new Uint8Array(new TextEncoder().encode($))}function d0($){if(typeof $==="string")$=j$($);return $0($),$}function d(...$){let J=0;for(let Q=0;Q<$.length;Q++){let G=$[Q];$0(G),J+=G.length}let q=new Uint8Array(J);for(let Q=0,G=0;Q<$.length;Q++){let z=$[Q];q.set(z,G),G+=z.length}return q}class r0{}function Z8($){let J=(Q)=>$().update(d0(Q)).digest(),q=$();return J.outputLen=q.outputLen,J.blockLen=q.blockLen,J.create=()=>$(),J}function I0($=32){if(x0&&typeof x0.getRandomValues==="function")return x0.getRandomValues(new Uint8Array($));if(x0&&typeof x0.randomBytes==="function")return Uint8Array.from(x0.randomBytes($));throw Error("crypto.getRandomValues must be defined")}function RQ($,J,q,Q){if(typeof $.setBigUint64==="function")return $.setBigUint64(J,q,Q);let G=BigInt(32),z=BigInt(4294967295),Y=Number(q>>G&z),Z=Number(q&z),j=Q?4:0,V=Q?0:4;$.setUint32(J+j,Y,Q),$.setUint32(J+V,Z,Q)}function U8($,J,q){return $&J^~$&q}function j8($,J,q){return $&J^$&q^J&q}class E$ extends r0{constructor($,J,q,Q){super();this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=$,this.outputLen=J,this.padOffset=q,this.isLE=Q,this.buffer=new Uint8Array($),this.view=U$(this.buffer)}update($){v0(this),$=d0($),$0($);let{view:J,buffer:q,blockLen:Q}=this,G=$.length;for(let z=0;z<G;){let Y=Math.min(Q-this.pos,G-z);if(Y===Q){let Z=U$($);for(;Q<=G-z;z+=Q)this.process(Z,z);continue}if(q.set($.subarray(z,z+Y),this.pos),this.pos+=Y,z+=Y,this.pos===Q)this.process(J,0),this.pos=0}return this.length+=$.length,this.roundClean(),this}digestInto($){v0(this),Y8($,this),this.finished=!0;let{buffer:J,view:q,blockLen:Q,isLE:G}=this,{pos:z}=this;if(J[z++]=128,L0(this.buffer.subarray(z)),this.padOffset>Q-z)this.process(q,0),z=0;for(let N=z;N<Q;N++)J[N]=0;RQ(q,Q-8,BigInt(this.length*8),G),this.process(q,0);let Y=U$($),Z=this.outputLen;if(Z%4)throw Error("_sha2: outputLen should be aligned to 32bit");let j=Z/4,V=this.get();if(j>V.length)throw Error("_sha2: outputLen bigger than state");for(let N=0;N<j;N++)Y.setUint32(4*N,V[N],G)}digest(){let{buffer:$,outputLen:J}=this;this.digestInto($);let q=$.slice(0,J);return this.destroy(),q}_cloneInto($){$||($=new this.constructor),$.set(...this.get());let{blockLen:J,buffer:q,length:Q,finished:G,destroyed:z,pos:Y}=this;if($.destroyed=z,$.finished=G,$.length=Q,$.pos=Y,Q%J)$.buffer.set(q);return $}clone(){return this._cloneInto()}}var j0=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]);var xQ=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]),C0=new Uint32Array(64);class K8 extends E${constructor($=32){super(64,$,8,!1);this.A=j0[0]|0,this.B=j0[1]|0,this.C=j0[2]|0,this.D=j0[3]|0,this.E=j0[4]|0,this.F=j0[5]|0,this.G=j0[6]|0,this.H=j0[7]|0}get(){let{A:$,B:J,C:q,D:Q,E:G,F:z,G:Y,H:Z}=this;return[$,J,q,Q,G,z,Y,Z]}set($,J,q,Q,G,z,Y,Z){this.A=$|0,this.B=J|0,this.C=q|0,this.D=Q|0,this.E=G|0,this.F=z|0,this.G=Y|0,this.H=Z|0}process($,J){for(let N=0;N<16;N++,J+=4)C0[N]=$.getUint32(J,!1);for(let N=16;N<64;N++){let x=C0[N-15],X=C0[N-2],K=Q0(x,7)^Q0(x,18)^x>>>3,B=Q0(X,17)^Q0(X,19)^X>>>10;C0[N]=B+C0[N-7]+K+C0[N-16]|0}let{A:q,B:Q,C:G,D:z,E:Y,F:Z,G:j,H:V}=this;for(let N=0;N<64;N++){let x=Q0(Y,6)^Q0(Y,11)^Q0(Y,25),X=V+x+U8(Y,Z,j)+xQ[N]+C0[N]|0,B=(Q0(q,2)^Q0(q,13)^Q0(q,22))+j8(q,Q,G)|0;V=j,j=Z,Z=Y,Y=z+X|0,z=G,G=Q,Q=q,q=X+B|0}q=q+this.A|0,Q=Q+this.B|0,G=G+this.C|0,z=z+this.D|0,Y=Y+this.E|0,Z=Z+this.F|0,j=j+this.G|0,V=V+this.H|0,this.set(q,Q,G,z,Y,Z,j,V)}roundClean(){L0(C0)}destroy(){this.set(0,0,0,0,0,0,0,0),L0(this.buffer)}}var K$=Z8(()=>new K8);class f$ extends r0{constructor($,J){super();this.finished=!1,this.destroyed=!1,Z$($);let q=d0(J);if(this.iHash=$.create(),typeof this.iHash.update!=="function")throw Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;let Q=this.blockLen,G=new Uint8Array(Q);G.set(q.length>Q?$.create().update(q).digest():q);for(let z=0;z<G.length;z++)G[z]^=54;this.iHash.update(G),this.oHash=$.create();for(let z=0;z<G.length;z++)G[z]^=106;this.oHash.update(G),L0(G)}update($){return v0(this),this.iHash.update($),this}digestInto($){v0(this),$0($,this.outputLen),this.finished=!0,this.iHash.digestInto($),this.oHash.update($),this.oHash.digestInto($),this.destroy()}digest(){let $=new Uint8Array(this.oHash.outputLen);return this.digestInto($),$}_cloneInto($){$||($=Object.create(Object.getPrototypeOf(this),{}));let{oHash:J,iHash:q,finished:Q,destroyed:G,blockLen:z,outputLen:Y}=this;return $=$,$.finished=Q,$.destroyed=G,$.blockLen=z,$.outputLen=Y,$.oHash=J._cloneInto($.oHash),$.iHash=q._cloneInto($.iHash),$}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}}var v$=($,J,q)=>new f$($,J).update(q).digest();v$.create=($,J)=>new f$($,J);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var g$=BigInt(0),_$=BigInt(1);function o0($,J=""){if(typeof $!=="boolean"){let q=J&&`"${J}"`;throw Error(q+"expected boolean, got type="+typeof $)}return $}function T0($,J,q=""){let Q=w0($),G=$?.length,z=J!==void 0;if(!Q||z&&G!==J){let Y=q&&`"${q}" `,Z=z?` of length ${J}`:"",j=Q?`length=${G}`:`type=${typeof $}`;throw Error(Y+"expected Uint8Array"+Z+", got "+j)}return $}function p0($){let J=$.toString(16);return J.length&1?"0"+J:J}function D8($){if(typeof $!=="string")throw Error("hex string expected, got "+typeof $);return $===""?g$:BigInt("0x"+$)}function K0($){return D8(U0($))}function y$($){return $0($),D8(U0(Uint8Array.from($).reverse()))}function b0($,J){return k0($.toString(16).padStart(J*2,"0"))}function u$($,J){return b0($,J).reverse()}function m($,J,q){let Q;if(typeof J==="string")try{Q=k0(J)}catch(z){throw Error($+" must be hex string or Uint8Array, cause: "+z)}else if(w0(J))Q=Uint8Array.from(J);else throw Error($+" must be hex string or Uint8Array");let G=Q.length;if(typeof q==="number"&&G!==q)throw Error($+" of length "+q+" expected, got "+G);return Q}var b$=($)=>typeof $==="bigint"&&g$<=$;function i0($,J,q){return b$($)&&b$(J)&&b$(q)&&J<=$&&$<q}function M8($,J,q,Q){if(!i0(J,q,Q))throw Error("expected valid "+$+": "+q+" <= n < "+Q+", got "+J)}function D$($){let J;for(J=0;$>g$;$>>=_$,J+=1);return J}var H0=($)=>(_$<<BigInt($))-_$;function W8($,J,q){if(typeof $!=="number"||$<2)throw Error("hashLen must be a number");if(typeof J!=="number"||J<2)throw Error("qByteLen must be a number");if(typeof q!=="function")throw Error("hmacFn must be a function");let Q=(K)=>new Uint8Array(K),G=(K)=>Uint8Array.of(K),z=Q($),Y=Q($),Z=0,j=()=>{z.fill(1),Y.fill(0),Z=0},V=(...K)=>q(Y,z,...K),N=(K=Q(0))=>{if(Y=V(G(0),K),z=V(),K.length===0)return;Y=V(G(1),K),z=V()},x=()=>{if(Z++>=1000)throw Error("drbg: tried 1000 values");let K=0,B=[];while(K<J){z=V();let w=z.slice();B.push(w),K+=z.length}return d(...B)};return(K,B)=>{j(),N(K);let w=void 0;while(!(w=B(x())))N();return j(),w}}function a0($,J,q={}){if(!$||typeof $!=="object")throw Error("expected valid options object");function Q(G,z,Y){let Z=$[G];if(Y&&Z===void 0)return;let j=typeof Z;if(j!==z||Z===null)throw Error(`param "${G}" is invalid: expected ${z}, got ${j}`)}Object.entries(J).forEach(([G,z])=>Q(G,z,!1)),Object.entries(q).forEach(([G,z])=>Q(G,z,!0))}function m$($){let J=new WeakMap;return(q,...Q)=>{let G=J.get(q);if(G!==void 0)return G;let z=$(q,...Q);return J.set(q,z),z}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var c=BigInt(0),h=BigInt(1),S0=BigInt(2),C8=BigInt(3),T8=BigInt(4),H8=BigInt(5),wQ=BigInt(7),O8=BigInt(8),LQ=BigInt(9),A8=BigInt(16);function o($,J){let q=$%J;return q>=c?q:J+q}function p($,J,q){let Q=$;while(J-- >c)Q*=Q,Q%=q;return Q}function N8($,J){if($===c)throw Error("invert: expected non-zero number");if(J<=c)throw Error("invert: expected positive modulus, got "+J);let q=o($,J),Q=J,G=c,z=h,Y=h,Z=c;while(q!==c){let V=Q/q,N=Q%q,x=G-Y*V,X=z-Z*V;Q=q,q=N,G=Y,z=Z,Y=x,Z=X}if(Q!==h)throw Error("invert: does not exist");return o(G,J)}function F$($,J,q){if(!$.eql($.sqr(J),q))throw Error("Cannot find square root")}function B8($,J){let q=($.ORDER+h)/T8,Q=$.pow(J,q);return F$($,Q,J),Q}function kQ($,J){let q=($.ORDER-H8)/O8,Q=$.mul(J,S0),G=$.pow(Q,q),z=$.mul(J,G),Y=$.mul($.mul(z,S0),G),Z=$.mul(z,$.sub(Y,$.ONE));return F$($,Z,J),Z}function IQ($){let J=O0($),q=R8($),Q=q(J,J.neg(J.ONE)),G=q(J,Q),z=q(J,J.neg(Q)),Y=($+wQ)/A8;return(Z,j)=>{let V=Z.pow(j,Y),N=Z.mul(V,Q),x=Z.mul(V,G),X=Z.mul(V,z),K=Z.eql(Z.sqr(N),j),B=Z.eql(Z.sqr(x),j);V=Z.cmov(V,N,K),N=Z.cmov(X,x,B);let w=Z.eql(Z.sqr(N),j),f=Z.cmov(V,N,w);return F$(Z,f,j),f}}function R8($){if($<C8)throw Error("sqrt is not defined for small field");let J=$-h,q=0;while(J%S0===c)J/=S0,q++;let Q=S0,G=O0($);while(V8(G,Q)===1)if(Q++>1000)throw Error("Cannot find square root: probably non-prime P");if(q===1)return B8;let z=G.pow(Q,J),Y=(J+h)/S0;return function(j,V){if(j.is0(V))return V;if(V8(j,V)!==1)throw Error("Cannot find square root");let N=q,x=j.mul(j.ONE,z),X=j.pow(V,J),K=j.pow(V,Y);while(!j.eql(X,j.ONE)){if(j.is0(X))return j.ZERO;let B=1,w=j.sqr(X);while(!j.eql(w,j.ONE))if(B++,w=j.sqr(w),B===N)throw Error("Cannot find square root");let f=h<<BigInt(N-B-1),v=j.pow(x,f);N=B,x=j.sqr(v),X=j.mul(X,x),K=j.mul(K,v)}return K}}function SQ($){if($%T8===C8)return B8;if($%O8===H8)return kQ;if($%A8===LQ)return IQ($);return R8($)}var PQ=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function h$($){let J={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},q=PQ.reduce((Q,G)=>{return Q[G]="function",Q},J);return a0($,q),$}function EQ($,J,q){if(q<c)throw Error("invalid exponent, negatives unsupported");if(q===c)return $.ONE;if(q===h)return J;let Q=$.ONE,G=J;while(q>c){if(q&h)Q=$.mul(Q,G);G=$.sqr(G),q>>=h}return Q}function M$($,J,q=!1){let Q=Array(J.length).fill(q?$.ZERO:void 0),G=J.reduce((Y,Z,j)=>{if($.is0(Z))return Y;return Q[j]=Y,$.mul(Y,Z)},$.ONE),z=$.inv(G);return J.reduceRight((Y,Z,j)=>{if($.is0(Z))return Y;return Q[j]=$.mul(Y,Q[j]),$.mul(Y,Z)},z),Q}function V8($,J){let q=($.ORDER-h)/S0,Q=$.pow(J,q),G=$.eql(Q,$.ONE),z=$.eql(Q,$.ZERO),Y=$.eql(Q,$.neg($.ONE));if(!G&&!z&&!Y)throw Error("invalid Legendre symbol result");return G?1:z?0:-1}function W$($,J){if(J!==void 0)l0(J);let q=J!==void 0?J:$.toString(2).length,Q=Math.ceil(q/8);return{nBitLength:q,nByteLength:Q}}function O0($,J,q=!1,Q={}){if($<=c)throw Error("invalid field: expected ORDER > 0, got "+$);let G=void 0,z=void 0,Y=!1,Z=void 0;if(typeof J==="object"&&J!=null){if(Q.sqrt||q)throw Error("cannot specify opts in two arguments");let X=J;if(X.BITS)G=X.BITS;if(X.sqrt)z=X.sqrt;if(typeof X.isLE==="boolean")q=X.isLE;if(typeof X.modFromBytes==="boolean")Y=X.modFromBytes;Z=X.allowedLengths}else{if(typeof J==="number")G=J;if(Q.sqrt)z=Q.sqrt}let{nBitLength:j,nByteLength:V}=W$($,G);if(V>2048)throw Error("invalid field: expected ORDER of <= 2048 bytes");let N,x=Object.freeze({ORDER:$,isLE:q,BITS:j,BYTES:V,MASK:H0(j),ZERO:c,ONE:h,allowedLengths:Z,create:(X)=>o(X,$),isValid:(X)=>{if(typeof X!=="bigint")throw Error("invalid field element: expected bigint, got "+typeof X);return c<=X&&X<$},is0:(X)=>X===c,isValidNot0:(X)=>!x.is0(X)&&x.isValid(X),isOdd:(X)=>(X&h)===h,neg:(X)=>o(-X,$),eql:(X,K)=>X===K,sqr:(X)=>o(X*X,$),add:(X,K)=>o(X+K,$),sub:(X,K)=>o(X-K,$),mul:(X,K)=>o(X*K,$),pow:(X,K)=>EQ(x,X,K),div:(X,K)=>o(X*N8(K,$),$),sqrN:(X)=>X*X,addN:(X,K)=>X+K,subN:(X,K)=>X-K,mulN:(X,K)=>X*K,inv:(X)=>N8(X,$),sqrt:z||((X)=>{if(!N)N=SQ($);return N(x,X)}),toBytes:(X)=>q?u$(X,V):b0(X,V),fromBytes:(X,K=!0)=>{if(Z){if(!Z.includes(X.length)||X.length>V)throw Error("Field.fromBytes: expected "+Z+" bytes, got "+X.length);let w=new Uint8Array(V);w.set(X,q?0:w.length-X.length),X=w}if(X.length!==V)throw Error("Field.fromBytes: expected "+V+" bytes, got "+X.length);let B=q?y$(X):K0(X);if(Y)B=o(B,$);if(!K){if(!x.isValid(B))throw Error("invalid field element: outside of range 0..ORDER")}return B},invertBatch:(X)=>M$(x,X),cmov:(X,K,B)=>B?K:X});return Object.freeze(x)}function x8($){if(typeof $!=="bigint")throw Error("field order must be bigint");let J=$.toString(2).length;return Math.ceil(J/8)}function c$($){let J=x8($);return J+Math.ceil(J/2)}function N$($,J,q=!1){let Q=$.length,G=x8(J),z=c$(J);if(Q<16||Q<z||Q>1024)throw Error("expected "+z+"-1024 bytes of input, got "+Q);let Y=q?y$($):K0($),Z=o(Y,J-h)+h;return q?u$(Z,G):b0(Z,G)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var _0=BigInt(0),P0=BigInt(1);function n0($,J){let q=J.negate();return $?q:J}function V$($,J){let q=M$($.Fp,J.map((Q)=>Q.Z));return J.map((Q,G)=>$.fromAffine(Q.toAffine(q[G])))}function I8($,J){if(!Number.isSafeInteger($)||$<=0||$>J)throw Error("invalid window size, expected [1.."+J+"], got W="+$)}function l$($,J){I8($,J);let q=Math.ceil(J/$)+1,Q=2**($-1),G=2**$,z=H0($),Y=BigInt($);return{windows:q,windowSize:Q,mask:z,maxNumber:G,shiftBy:Y}}function w8($,J,q){let{windowSize:Q,mask:G,maxNumber:z,shiftBy:Y}=q,Z=Number($&G),j=$>>Y;if(Z>Q)Z-=z,j+=P0;let V=J*Q,N=V+Math.abs(Z)-1,x=Z===0,X=Z<0,K=J%2!==0;return{nextN:j,offset:N,isZero:x,isNeg:X,isNegF:K,offsetF:V}}function fQ($,J){if(!Array.isArray($))throw Error("array expected");$.forEach((q,Q)=>{if(!(q instanceof J))throw Error("invalid point at index "+Q)})}function vQ($,J){if(!Array.isArray($))throw Error("array of scalars expected");$.forEach((q,Q)=>{if(!J.isValid(q))throw Error("invalid scalar at index "+Q)})}var d$=new WeakMap,S8=new WeakMap;function r$($){return S8.get($)||1}function L8($){if($!==_0)throw Error("invalid wNAF")}class o${constructor($,J){this.BASE=$.BASE,this.ZERO=$.ZERO,this.Fn=$.Fn,this.bits=J}_unsafeLadder($,J,q=this.ZERO){let Q=$;while(J>_0){if(J&P0)q=q.add(Q);Q=Q.double(),J>>=P0}return q}precomputeWindow($,J){let{windows:q,windowSize:Q}=l$(J,this.bits),G=[],z=$,Y=z;for(let Z=0;Z<q;Z++){Y=z,G.push(Y);for(let j=1;j<Q;j++)Y=Y.add(z),G.push(Y);z=Y.double()}return G}wNAF($,J,q){if(!this.Fn.isValid(q))throw Error("invalid scalar");let Q=this.ZERO,G=this.BASE,z=l$($,this.bits);for(let Y=0;Y<z.windows;Y++){let{nextN:Z,offset:j,isZero:V,isNeg:N,isNegF:x,offsetF:X}=w8(q,Y,z);if(q=Z,V)G=G.add(n0(x,J[X]));else Q=Q.add(n0(N,J[j]))}return L8(q),{p:Q,f:G}}wNAFUnsafe($,J,q,Q=this.ZERO){let G=l$($,this.bits);for(let z=0;z<G.windows;z++){if(q===_0)break;let{nextN:Y,offset:Z,isZero:j,isNeg:V}=w8(q,z,G);if(q=Y,j)continue;else{let N=J[Z];Q=Q.add(V?N.negate():N)}}return L8(q),Q}getPrecomputes($,J,q){let Q=d$.get(J);if(!Q){if(Q=this.precomputeWindow(J,$),$!==1){if(typeof q==="function")Q=q(Q);d$.set(J,Q)}}return Q}cached($,J,q){let Q=r$($);return this.wNAF(Q,this.getPrecomputes(Q,$,q),J)}unsafe($,J,q,Q){let G=r$($);if(G===1)return this._unsafeLadder($,J,Q);return this.wNAFUnsafe(G,this.getPrecomputes(G,$,q),J,Q)}createCache($,J){I8(J,this.bits),S8.set($,J),d$.delete($)}hasCache($){return r$($)!==1}}function P8($,J,q,Q){let G=J,z=$.ZERO,Y=$.ZERO;while(q>_0||Q>_0){if(q&P0)z=z.add(G);if(Q&P0)Y=Y.add(G);G=G.double(),q>>=P0,Q>>=P0}return{p1:z,p2:Y}}function E8($,J,q,Q){fQ(q,$),vQ(Q,J);let G=q.length,z=Q.length;if(G!==z)throw Error("arrays of points and scalars must have equal length");let Y=$.ZERO,Z=D$(BigInt(G)),j=1;if(Z>12)j=Z-3;else if(Z>4)j=Z-2;else if(Z>0)j=2;let V=H0(j),N=Array(Number(V)+1).fill(Y),x=Math.floor((J.BITS-1)/j)*j,X=Y;for(let K=x;K>=0;K-=j){N.fill(Y);for(let w=0;w<z;w++){let f=Q[w],v=Number(f>>BigInt(K)&V);N[v]=N[v].add(q[w])}let B=Y;for(let w=N.length-1,f=Y;w>0;w--)f=f.add(N[w]),B=B.add(f);if(X=X.add(B),K!==0)for(let w=0;w<j;w++)X=X.double()}return X}function k8($,J,q){if(J){if(J.ORDER!==$)throw Error("Field.ORDER must match order: Fp == p, Fn == n");return h$(J),J}else return O0($,{isLE:q})}function f8($,J,q={},Q){if(Q===void 0)Q=$==="edwards";if(!J||typeof J!=="object")throw Error(`expected valid ${$} CURVE object`);for(let j of["p","n","h"]){let V=J[j];if(!(typeof V==="bigint"&&V>_0))throw Error(`CURVE.${j} must be positive bigint`)}let G=k8(J.p,q.Fp,Q),z=k8(J.n,q.Fn,Q),Z=["Gx","Gy","a",$==="weierstrass"?"b":"d"];for(let j of Z)if(!G.isValid(J[j]))throw Error(`CURVE.${j} must be valid field element of CURVE.Fp`);return J=Object.freeze(Object.assign({},J)),{CURVE:J,Fp:G,Fn:z}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var v8=($,J)=>($+($>=0?J:-J)/_8)/J;function bQ($,J,q){let[[Q,G],[z,Y]]=J,Z=v8(Y*$,q),j=v8(-G*$,q),V=$-Z*Q-j*z,N=-Z*G-j*Y,x=V<M0,X=N<M0;if(x)V=-V;if(X)N=-N;let K=H0(Math.ceil(D$(q)/2))+g0;if(V<M0||V>=K||N<M0||N>=K)throw Error("splitScalar (endomorphism): failed, k="+$);return{k1neg:x,k1:V,k2neg:X,k2:N}}function i$($){if(!["compact","recovered","der"].includes($))throw Error('Signature format must be "compact", "recovered", or "der"');return $}function p$($,J){let q={};for(let Q of Object.keys(J))q[Q]=$[Q]===void 0?J[Q]:$[Q];if(o0(q.lowS,"lowS"),o0(q.prehash,"prehash"),q.format!==void 0)i$(q.format);return q}class b8 extends Error{constructor($=""){super($)}}var D0={Err:b8,_tlv:{encode:($,J)=>{let{Err:q}=D0;if($<0||$>256)throw new q("tlv.encode: wrong tag");if(J.length&1)throw new q("tlv.encode: unpadded data");let Q=J.length/2,G=p0(Q);if(G.length/2&128)throw new q("tlv.encode: long form length too big");let z=Q>127?p0(G.length/2|128):"";return p0($)+z+G+J},decode($,J){let{Err:q}=D0,Q=0;if($<0||$>256)throw new q("tlv.encode: wrong tag");if(J.length<2||J[Q++]!==$)throw new q("tlv.decode: wrong tlv");let G=J[Q++],z=!!(G&128),Y=0;if(!z)Y=G;else{let j=G&127;if(!j)throw new q("tlv.decode(long): indefinite length not supported");if(j>4)throw new q("tlv.decode(long): byte length is too big");let V=J.subarray(Q,Q+j);if(V.length!==j)throw new q("tlv.decode: length bytes not complete");if(V[0]===0)throw new q("tlv.decode(long): zero leftmost byte");for(let N of V)Y=Y<<8|N;if(Q+=j,Y<128)throw new q("tlv.decode(long): not minimal encoding")}let Z=J.subarray(Q,Q+Y);if(Z.length!==Y)throw new q("tlv.decode: wrong value length");return{v:Z,l:J.subarray(Q+Y)}}},_int:{encode($){let{Err:J}=D0;if($<M0)throw new J("integer: negative integers are not allowed");let q=p0($);if(Number.parseInt(q[0],16)&8)q="00"+q;if(q.length&1)throw new J("unexpected DER parsing assertion: unpadded hex");return q},decode($){let{Err:J}=D0;if($[0]&128)throw new J("invalid signature integer: negative");if($[0]===0&&!($[1]&128))throw new J("invalid signature integer: unnecessary leading zero");return K0($)}},toSig($){let{Err:J,_int:q,_tlv:Q}=D0,G=m("signature",$),{v:z,l:Y}=Q.decode(48,G);if(Y.length)throw new J("invalid signature: left bytes after parsing");let{v:Z,l:j}=Q.decode(2,z),{v:V,l:N}=Q.decode(2,j);if(N.length)throw new J("invalid signature: left bytes after parsing");return{r:q.decode(Z),s:q.decode(V)}},hexFromSig($){let{_tlv:J,_int:q}=D0,Q=J.encode(2,q.encode($.r)),G=J.encode(2,q.encode($.s)),z=Q+G;return J.encode(48,z)}},M0=BigInt(0),g0=BigInt(1),_8=BigInt(2),C$=BigInt(3),_Q=BigInt(4);function A0($,J){let{BYTES:q}=$,Q;if(typeof J==="bigint")Q=J;else{let G=m("private key",J);try{Q=$.fromBytes(G)}catch(z){throw Error(`invalid private key: expected ui8a of size ${q}, got ${typeof J}`)}}if(!$.isValidNot0(Q))throw Error("invalid private key: out of range [1..N-1]");return Q}function gQ($,J={}){let q=f8("weierstrass",$,J),{Fp:Q,Fn:G}=q,z=q.CURVE,{h:Y,n:Z}=z;a0(J,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});let{endo:j}=J;if(j){if(!Q.is0(z.a)||typeof j.beta!=="bigint"||!Array.isArray(j.basises))throw Error('invalid endo: expected "beta": bigint and "basises": array')}let V=y8(Q,G);function N(){if(!Q.isOdd)throw Error("compression is not supported: Field does not have .isOdd()")}function x(W,A,M){let{x:T,y:U}=A.toAffine(),D=Q.toBytes(T);if(o0(M,"isCompressed"),M){N();let H=!Q.isOdd(U);return d(g8(H),D)}else return d(Uint8Array.of(4),D,Q.toBytes(U))}function X(W){T0(W,void 0,"Point");let{publicKey:A,publicKeyUncompressed:M}=V,T=W.length,U=W[0],D=W.subarray(1);if(T===A&&(U===2||U===3)){let H=Q.fromBytes(D);if(!Q.isValid(H))throw Error("bad point: is not on curve, wrong x");let O=w(H),C;try{C=Q.sqrt(O)}catch(I){let L=I instanceof Error?": "+I.message:"";throw Error("bad point: is not on curve, sqrt error"+L)}N();let R=Q.isOdd(C);if((U&1)===1!==R)C=Q.neg(C);return{x:H,y:C}}else if(T===M&&U===4){let H=Q.BYTES,O=Q.fromBytes(D.subarray(0,H)),C=Q.fromBytes(D.subarray(H,H*2));if(!f(O,C))throw Error("bad point: is not on curve");return{x:O,y:C}}else throw Error(`bad point: got length ${T}, expected compressed=${A} or uncompressed=${M}`)}let K=J.toBytes||x,B=J.fromBytes||X;function w(W){let A=Q.sqr(W),M=Q.mul(A,W);return Q.add(Q.add(M,Q.mul(W,z.a)),z.b)}function f(W,A){let M=Q.sqr(A),T=w(W);return Q.eql(M,T)}if(!f(z.Gx,z.Gy))throw Error("bad curve params: generator point");let v=Q.mul(Q.pow(z.a,C$),_Q),q0=Q.mul(Q.sqr(z.b),BigInt(27));if(Q.is0(Q.add(v,q0)))throw Error("bad curve params: a or b");function _(W,A,M=!1){if(!Q.isValid(A)||M&&Q.is0(A))throw Error(`bad point coordinate ${W}`);return A}function i(W){if(!(W instanceof k))throw Error("ProjectivePoint expected")}function l(W){if(!j||!j.basises)throw Error("no endo");return bQ(W,j.basises,G.ORDER)}let a=m$((W,A)=>{let{X:M,Y:T,Z:U}=W;if(Q.eql(U,Q.ONE))return{x:M,y:T};let D=W.is0();if(A==null)A=D?Q.ONE:Q.inv(U);let H=Q.mul(M,A),O=Q.mul(T,A),C=Q.mul(U,A);if(D)return{x:Q.ZERO,y:Q.ZERO};if(!Q.eql(C,Q.ONE))throw Error("invZ was invalid");return{x:H,y:O}}),V0=m$((W)=>{if(W.is0()){if(J.allowInfinityPoint&&!Q.is0(W.Y))return;throw Error("bad point: ZERO")}let{x:A,y:M}=W.toAffine();if(!Q.isValid(A)||!Q.isValid(M))throw Error("bad point: x or y not field elements");if(!f(A,M))throw Error("bad point: equation left != right");if(!W.isTorsionFree())throw Error("bad point: not in prime-order subgroup");return!0});function e(W,A,M,T,U){return M=new k(Q.mul(M.X,W),M.Y,M.Z),A=n0(T,A),M=n0(U,M),A.add(M)}class k{constructor(W,A,M){this.X=_("x",W),this.Y=_("y",A,!0),this.Z=_("z",M),Object.freeze(this)}static CURVE(){return z}static fromAffine(W){let{x:A,y:M}=W||{};if(!W||!Q.isValid(A)||!Q.isValid(M))throw Error("invalid affine point");if(W instanceof k)throw Error("projective point not allowed");if(Q.is0(A)&&Q.is0(M))return k.ZERO;return new k(A,M,Q.ONE)}static fromBytes(W){let A=k.fromAffine(B(T0(W,void 0,"point")));return A.assertValidity(),A}static fromHex(W){return k.fromBytes(m("pointHex",W))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(W=8,A=!0){if(S.createCache(this,W),!A)this.multiply(C$);return this}assertValidity(){V0(this)}hasEvenY(){let{y:W}=this.toAffine();if(!Q.isOdd)throw Error("Field doesn't support isOdd");return!Q.isOdd(W)}equals(W){i(W);let{X:A,Y:M,Z:T}=this,{X:U,Y:D,Z:H}=W,O=Q.eql(Q.mul(A,H),Q.mul(U,T)),C=Q.eql(Q.mul(M,H),Q.mul(D,T));return O&&C}negate(){return new k(this.X,Q.neg(this.Y),this.Z)}double(){let{a:W,b:A}=z,M=Q.mul(A,C$),{X:T,Y:U,Z:D}=this,H=Q.ZERO,O=Q.ZERO,C=Q.ZERO,R=Q.mul(T,T),g=Q.mul(U,U),I=Q.mul(D,D),L=Q.mul(T,U);return L=Q.add(L,L),C=Q.mul(T,D),C=Q.add(C,C),H=Q.mul(W,C),O=Q.mul(M,I),O=Q.add(H,O),H=Q.sub(g,O),O=Q.add(g,O),O=Q.mul(H,O),H=Q.mul(L,H),C=Q.mul(M,C),I=Q.mul(W,I),L=Q.sub(R,I),L=Q.mul(W,L),L=Q.add(L,C),C=Q.add(R,R),R=Q.add(C,R),R=Q.add(R,I),R=Q.mul(R,L),O=Q.add(O,R),I=Q.mul(U,D),I=Q.add(I,I),R=Q.mul(I,L),H=Q.sub(H,R),C=Q.mul(I,g),C=Q.add(C,C),C=Q.add(C,C),new k(H,O,C)}add(W){i(W);let{X:A,Y:M,Z:T}=this,{X:U,Y:D,Z:H}=W,O=Q.ZERO,C=Q.ZERO,R=Q.ZERO,g=z.a,I=Q.mul(z.b,C$),L=Q.mul(A,U),P=Q.mul(M,D),E=Q.mul(T,H),b=Q.add(A,M),y=Q.add(U,D);b=Q.mul(b,y),y=Q.add(L,P),b=Q.sub(b,y),y=Q.add(A,T);let u=Q.add(U,H);return y=Q.mul(y,u),u=Q.add(L,E),y=Q.sub(y,u),u=Q.add(M,T),O=Q.add(D,H),u=Q.mul(u,O),O=Q.add(P,E),u=Q.sub(u,O),R=Q.mul(g,y),O=Q.mul(I,E),R=Q.add(O,R),O=Q.sub(P,R),R=Q.add(P,R),C=Q.mul(O,R),P=Q.add(L,L),P=Q.add(P,L),E=Q.mul(g,E),y=Q.mul(I,y),P=Q.add(P,E),E=Q.sub(L,E),E=Q.mul(g,E),y=Q.add(y,E),L=Q.mul(P,y),C=Q.add(C,L),L=Q.mul(u,y),O=Q.mul(b,O),O=Q.sub(O,L),L=Q.mul(b,P),R=Q.mul(u,R),R=Q.add(R,L),new k(O,C,R)}subtract(W){return this.add(W.negate())}is0(){return this.equals(k.ZERO)}multiply(W){let{endo:A}=J;if(!G.isValidNot0(W))throw Error("invalid scalar: out of range");let M,T,U=(D)=>S.cached(this,D,(H)=>V$(k,H));if(A){let{k1neg:D,k1:H,k2neg:O,k2:C}=l(W),{p:R,f:g}=U(H),{p:I,f:L}=U(C);T=g.add(L),M=e(A.beta,R,I,D,O)}else{let{p:D,f:H}=U(W);M=D,T=H}return V$(k,[M,T])[0]}multiplyUnsafe(W){let{endo:A}=J,M=this;if(!G.isValid(W))throw Error("invalid scalar: out of range");if(W===M0||M.is0())return k.ZERO;if(W===g0)return M;if(S.hasCache(this))return this.multiply(W);if(A){let{k1neg:T,k1:U,k2neg:D,k2:H}=l(W),{p1:O,p2:C}=P8(k,M,U,H);return e(A.beta,O,C,T,D)}else return S.unsafe(M,W)}multiplyAndAddUnsafe(W,A,M){let T=this.multiplyUnsafe(A).add(W.multiplyUnsafe(M));return T.is0()?void 0:T}toAffine(W){return a(this,W)}isTorsionFree(){let{isTorsionFree:W}=J;if(Y===g0)return!0;if(W)return W(k,this);return S.unsafe(this,Z).is0()}clearCofactor(){let{clearCofactor:W}=J;if(Y===g0)return this;if(W)return W(k,this);return this.multiplyUnsafe(Y)}isSmallOrder(){return this.multiplyUnsafe(Y).is0()}toBytes(W=!0){return o0(W,"isCompressed"),this.assertValidity(),K(k,this,W)}toHex(W=!0){return U0(this.toBytes(W))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}get px(){return this.X}get py(){return this.X}get pz(){return this.Z}toRawBytes(W=!0){return this.toBytes(W)}_setWindowSize(W){this.precompute(W)}static normalizeZ(W){return V$(k,W)}static msm(W,A){return E8(k,G,W,A)}static fromPrivateKey(W){return k.BASE.multiply(A0(G,W))}}k.BASE=new k(z.Gx,z.Gy,Q.ONE),k.ZERO=new k(Q.ZERO,Q.ONE,Q.ZERO),k.Fp=Q,k.Fn=G;let G0=G.BITS,S=new o$(k,J.endo?Math.ceil(G0/2):G0);return k.BASE.precompute(8),k}function g8($){return Uint8Array.of($?2:3)}function y8($,J){return{secretKey:J.BYTES,publicKey:1+$.BYTES,publicKeyUncompressed:1+2*$.BYTES,publicKeyHasPrefix:!0,signature:2*J.BYTES}}function yQ($,J={}){let{Fn:q}=$,Q=J.randomBytes||I0,G=Object.assign(y8($.Fp,q),{seed:c$(q.ORDER)});function z(K){try{return!!A0(q,K)}catch(B){return!1}}function Y(K,B){let{publicKey:w,publicKeyUncompressed:f}=G;try{let v=K.length;if(B===!0&&v!==w)return!1;if(B===!1&&v!==f)return!1;return!!$.fromBytes(K)}catch(v){return!1}}function Z(K=Q(G.seed)){return N$(T0(K,G.seed,"seed"),q.ORDER)}function j(K,B=!0){return $.BASE.multiply(A0(q,K)).toBytes(B)}function V(K){let B=Z(K);return{secretKey:B,publicKey:j(B)}}function N(K){if(typeof K==="bigint")return!1;if(K instanceof $)return!0;let{secretKey:B,publicKey:w,publicKeyUncompressed:f}=G;if(q.allowedLengths||B===w)return;let v=m("key",K).length;return v===w||v===f}function x(K,B,w=!0){if(N(K)===!0)throw Error("first arg must be private key");if(N(B)===!1)throw Error("second arg must be public key");let f=A0(q,K);return $.fromHex(B).multiply(f).toBytes(w)}return Object.freeze({getPublicKey:j,getSharedSecret:x,keygen:V,Point:$,utils:{isValidSecretKey:z,isValidPublicKey:Y,randomSecretKey:Z,isValidPrivateKey:z,randomPrivateKey:Z,normPrivateKeyToScalar:(K)=>A0(q,K),precompute(K=8,B=$.BASE){return B.precompute(K,!1)}},lengths:G})}function uQ($,J,q={}){Z$(J),a0(q,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});let Q=q.randomBytes||I0,G=q.hmac||((M,...T)=>v$(J,M,d(...T))),{Fp:z,Fn:Y}=$,{ORDER:Z,BITS:j}=Y,{keygen:V,getPublicKey:N,getSharedSecret:x,utils:X,lengths:K}=yQ($,q),B={prehash:!1,lowS:typeof q.lowS==="boolean"?q.lowS:!1,format:void 0,extraEntropy:!1},w="compact";function f(M){let T=Z>>g0;return M>T}function v(M,T){if(!Y.isValidNot0(T))throw Error(`invalid signature ${M}: out of range 1..Point.Fn.ORDER`);return T}function q0(M,T){i$(T);let U=K.signature,D=T==="compact"?U:T==="recovered"?U+1:void 0;return T0(M,D,`${T} signature`)}class _{constructor(M,T,U){if(this.r=v("r",M),this.s=v("s",T),U!=null)this.recovery=U;Object.freeze(this)}static fromBytes(M,T=w){q0(M,T);let U;if(T==="der"){let{r:C,s:R}=D0.toSig(T0(M));return new _(C,R)}if(T==="recovered")U=M[0],T="compact",M=M.subarray(1);let D=Y.BYTES,H=M.subarray(0,D),O=M.subarray(D,D*2);return new _(Y.fromBytes(H),Y.fromBytes(O),U)}static fromHex(M,T){return this.fromBytes(k0(M),T)}addRecoveryBit(M){return new _(this.r,this.s,M)}recoverPublicKey(M){let T=z.ORDER,{r:U,s:D,recovery:H}=this;if(H==null||![0,1,2,3].includes(H))throw Error("recovery id invalid");if(Z*_8<T&&H>1)throw Error("recovery id is ambiguous for h>1 curve");let C=H===2||H===3?U+Z:U;if(!z.isValid(C))throw Error("recovery id 2 or 3 invalid");let R=z.toBytes(C),g=$.fromBytes(d(g8((H&1)===0),R)),I=Y.inv(C),L=l(m("msgHash",M)),P=Y.create(-L*I),E=Y.create(D*I),b=$.BASE.multiplyUnsafe(P).add(g.multiplyUnsafe(E));if(b.is0())throw Error("point at infinify");return b.assertValidity(),b}hasHighS(){return f(this.s)}toBytes(M=w){if(i$(M),M==="der")return k0(D0.hexFromSig(this));let T=Y.toBytes(this.r),U=Y.toBytes(this.s);if(M==="recovered"){if(this.recovery==null)throw Error("recovery bit must be present");return d(Uint8Array.of(this.recovery),T,U)}return d(T,U)}toHex(M){return U0(this.toBytes(M))}assertValidity(){}static fromCompact(M){return _.fromBytes(m("sig",M),"compact")}static fromDER(M){return _.fromBytes(m("sig",M),"der")}normalizeS(){return this.hasHighS()?new _(this.r,Y.neg(this.s),this.recovery):this}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return U0(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return U0(this.toBytes("compact"))}}let i=q.bits2int||function(T){if(T.length>8192)throw Error("input is too large");let U=K0(T),D=T.length*8-j;return D>0?U>>BigInt(D):U},l=q.bits2int_modN||function(T){return Y.create(i(T))},a=H0(j);function V0(M){return M8("num < 2^"+j,M,M0,a),Y.toBytes(M)}function e(M,T){return T0(M,void 0,"message"),T?T0(J(M),void 0,"prehashed message"):M}function k(M,T,U){if(["recovered","canonical"].some((E)=>(E in U)))throw Error("sign() legacy options not supported");let{lowS:D,prehash:H,extraEntropy:O}=p$(U,B);M=e(M,H);let C=l(M),R=A0(Y,T),g=[V0(R),V0(C)];if(O!=null&&O!==!1){let E=O===!0?Q(K.secretKey):O;g.push(m("extraEntropy",E))}let I=d(...g),L=C;function P(E){let b=i(E);if(!Y.isValidNot0(b))return;let y=Y.inv(b),u=$.BASE.multiply(b).toAffine(),F=Y.create(u.x);if(F===M0)return;let n=Y.create(y*Y.create(L+F*R));if(n===M0)return;let z0=(u.x===F?0:2)|Number(u.y&g0),r=n;if(D&&f(n))r=Y.neg(n),z0^=1;return new _(F,r,z0)}return{seed:I,k2sig:P}}function G0(M,T,U={}){M=m("message",M);let{seed:D,k2sig:H}=k(M,T,U);return W8(J.outputLen,Y.BYTES,G)(D,H)}function S(M){let T=void 0,U=typeof M==="string"||w0(M),D=!U&&M!==null&&typeof M==="object"&&typeof M.r==="bigint"&&typeof M.s==="bigint";if(!U&&!D)throw Error("invalid signature, expected Uint8Array, hex string or Signature instance");if(D)T=new _(M.r,M.s);else if(U){try{T=_.fromBytes(m("sig",M),"der")}catch(H){if(!(H instanceof D0.Err))throw H}if(!T)try{T=_.fromBytes(m("sig",M),"compact")}catch(H){return!1}}if(!T)return!1;return T}function W(M,T,U,D={}){let{lowS:H,prehash:O,format:C}=p$(D,B);if(U=m("publicKey",U),T=e(m("message",T),O),"strict"in D)throw Error("options.strict was renamed to lowS");let R=C===void 0?S(M):_.fromBytes(m("sig",M),C);if(R===!1)return!1;try{let g=$.fromBytes(U);if(H&&R.hasHighS())return!1;let{r:I,s:L}=R,P=l(T),E=Y.inv(L),b=Y.create(P*E),y=Y.create(I*E),u=$.BASE.multiplyUnsafe(b).add(g.multiplyUnsafe(y));if(u.is0())return!1;return Y.create(u.x)===I}catch(g){return!1}}function A(M,T,U={}){let{prehash:D}=p$(U,B);return T=e(T,D),_.fromBytes(M,"recovered").recoverPublicKey(T).toBytes()}return Object.freeze({keygen:V,getPublicKey:N,getSharedSecret:x,utils:X,lengths:K,Point:$,sign:G0,verify:W,recoverPublicKey:A,Signature:_,hash:J})}function mQ($){let J={a:$.a,b:$.b,p:$.Fp.ORDER,n:$.n,h:$.h,Gx:$.Gx,Gy:$.Gy},q=$.Fp,Q=$.allowedPrivateKeyLengths?Array.from(new Set($.allowedPrivateKeyLengths.map((Y)=>Math.ceil(Y/2)))):void 0,G=O0(J.n,{BITS:$.nBitLength,allowedLengths:Q,modFromBytes:$.wrapPrivateKey}),z={Fp:q,Fn:G,allowInfinityPoint:$.allowInfinityPoint,endo:$.endo,isTorsionFree:$.isTorsionFree,clearCofactor:$.clearCofactor,fromBytes:$.fromBytes,toBytes:$.toBytes};return{CURVE:J,curveOpts:z}}function FQ($){let{CURVE:J,curveOpts:q}=mQ($),Q={hmac:$.hmac,randomBytes:$.randomBytes,lowS:$.lowS,bits2int:$.bits2int,bits2int_modN:$.bits2int_modN};return{CURVE:J,curveOpts:q,hash:$.hash,ecdsaOpts:Q}}function hQ($,J){let q=J.Point;return Object.assign({},J,{ProjectivePoint:q,CURVE:Object.assign({},$,W$(q.Fn.ORDER,q.Fn.BITS))})}function u8($){let{CURVE:J,curveOpts:q,hash:Q,ecdsaOpts:G}=FQ($),z=gQ(J,q),Y=uQ(z,Q,G);return hQ($,Y)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */function m8($,J){let q=(Q)=>u8({...$,hash:Q});return{...q(J),create:q}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */var y0={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},cQ={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]},lQ=BigInt(0),F8=BigInt(1),a$=BigInt(2);function dQ($){let J=y0.p,q=BigInt(3),Q=BigInt(6),G=BigInt(11),z=BigInt(22),Y=BigInt(23),Z=BigInt(44),j=BigInt(88),V=$*$*$%J,N=V*V*$%J,x=p(N,q,J)*N%J,X=p(x,q,J)*N%J,K=p(X,a$,J)*V%J,B=p(K,G,J)*K%J,w=p(B,z,J)*B%J,f=p(w,Z,J)*w%J,v=p(f,j,J)*f%J,q0=p(v,Z,J)*w%J,_=p(q0,q,J)*N%J,i=p(_,Y,J)*B%J,l=p(i,Q,J)*V%J,a=p(l,a$,J);if(!T$.eql(T$.sqr(a),$))throw Error("Cannot find square root");return a}var T$=O0(y0.p,{sqrt:dQ}),l8=m8({...y0,Fp:T$,lowS:!0,endo:cQ},K$),h8={};function H$($,...J){let q=h8[$];if(q===void 0){let Q=K$(j$($));q=d(Q,Q),h8[$]=q}return K$(d(q,...J))}var s$=($)=>$.toBytes(!0).slice(1),u0=(()=>l8.Point)(),t$=($)=>$%a$===lQ;function n$($){let{Fn:J,BASE:q}=u0,Q=A0(J,$),G=q.multiply(Q);return{scalar:t$(G.y)?Q:J.neg(Q),bytes:s$(G)}}function d8($){let J=T$;if(!J.isValidNot0($))throw Error("invalid x: Fail if x ≥ p");let q=J.create($*$),Q=J.create(q*$+BigInt(7)),G=J.sqrt(Q);if(!t$(G))G=J.neg(G);let z=u0.fromAffine({x:$,y:G});return z.assertValidity(),z}var s0=K0;function r8(...$){return u0.Fn.create(s0(H$("BIP0340/challenge",...$)))}function c8($){return n$($).bytes}function rQ($,J,q=I0(32)){let{Fn:Q}=u0,G=m("message",$),{bytes:z,scalar:Y}=n$(J),Z=m("auxRand",q,32),j=Q.toBytes(Y^s0(H$("BIP0340/aux",Z))),V=H$("BIP0340/nonce",j,z,G),{bytes:N,scalar:x}=n$(V),X=r8(N,z,G),K=new Uint8Array(64);if(K.set(N,0),K.set(Q.toBytes(Q.create(x+X*Y)),32),!o8(K,G,z))throw Error("sign: Invalid signature produced");return K}function o8($,J,q){let{Fn:Q,BASE:G}=u0,z=m("signature",$,64),Y=m("message",J),Z=m("publicKey",q,32);try{let j=d8(s0(Z)),V=s0(z.subarray(0,32));if(!i0(V,F8,y0.p))return!1;let N=s0(z.subarray(32,64));if(!i0(N,F8,y0.n))return!1;let x=r8(Q.toBytes(V),s$(j),Y),X=G.multiplyUnsafe(N).add(j.multiplyUnsafe(Q.neg(x))),{x:K,y:B}=X.toAffine();if(X.is0()||!t$(B)||K!==V)return!1;return!0}catch(j){return!1}}var O$=(()=>{let q=(G=I0(48))=>{return N$(G,y0.n)};l8.utils.randomSecretKey;function Q(G){let z=q(G);return{secretKey:z,publicKey:c8(z)}}return{keygen:Q,getPublicKey:c8,sign:rQ,verify:o8,Point:u0,utils:{randomSecretKey:q,randomPrivateKey:q,taggedHash:H$,lift_x:d8,pointToBytes:s$,numberToBytesBE:b0,bytesToNumberBE:K0,mod:o},lengths:{secretKey:32,publicKey:32,publicKeyHasPrefix:!1,signature:64,seed:48}}})();var oQ=new TextEncoder,pQ=new TextDecoder,X0=($)=>oQ.encode($),E0=($)=>pQ.decode($),A$=($)=>Array.from($,(J)=>J.toString(16).padStart(2,"0")).join(""),t=JSON.stringify,f0=JSON.parse,B$=($,J=Number.MAX_SAFE_INTEGER)=>$.split("").reduce((q,Q)=>q+Q.charCodeAt(0),0)%J;var e$="AES-GCM",iQ={},p8="$",i8=",",aQ=($)=>{let J=new Uint8Array($),q=32768,Q="";for(let G=0;G<J.length;G+=32768)Q+=String.fromCharCode(...J.subarray(G,G+32768));return btoa(Q)},nQ=($)=>Uint8Array.from(atob($),(J)=>J.charCodeAt(0)).buffer,t0=($)=>iQ[$]??=crypto.subtle.digest("SHA-1",X0($)).then((J)=>{let q=new Uint8Array(J),Q="";for(let G of q)Q+=G.toString(36);return Q}),a8=async($,J,q)=>{let Q=await crypto.subtle.digest("SHA-256",X0(`${$}:${J}:${q}`));return crypto.subtle.importKey("raw",Q,{name:e$},!1,["encrypt","decrypt"])},n8=async($,J)=>{let q=crypto.getRandomValues(new Uint8Array(12)),Q=await $,G=await crypto.subtle.encrypt({name:e$,iv:q},Q,X0(J));return`${q.join(i8)}${p8}${aQ(G)}`},s8=async($,J)=>{let[q,Q]=J.split(p8);if(!q||!Q)throw Error("Invalid encrypted payload format");let G=Uint8Array.from(q.split(i8),Number),z=await $,Y=await crypto.subtle.decrypt({name:e$,iv:G},z,nQ(Q));return E0(Y)};var e0="GenosRTC",m0=($,J)=>Array.from({length:$},J);var $$=($)=>Array.from(crypto.getRandomValues(new Uint8Array($)),(J)=>"0123456789AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPpQqRrSsTtUuVvWwXxYyZz"[J%62]).join(""),W0=$$(20),N0=Promise.all.bind(Promise),t8=typeof window<"u",{entries:e8,fromEntries:R$,keys:J9}=Object,$Q=()=>{},J0=($)=>Error(`GenosRTC: ${$}`),Q$=(...$)=>$.join("@"),QQ=($,J)=>{let q=[...$],Q=q.length,G=()=>{let z=Math.sin(J++)*1e4;return z-Math.floor(z)};while(Q){let z=Math.floor(G()*Q--);[q[Q],q[z]]=[q[z],q[Q]]}return q};var sQ=5000,JQ="icegatheringstatechange",qQ="offer",tQ="answer",eQ=[...m0(3,($,J)=>`stun:stun${J||""}.l.google.com:19302`),"stun:stun.cloudflare.com:3478"].map(($)=>({urls:$})),x$=($,{rtcConfig:J,rtcPolyfill:q,turnConfig:Q})=>{let G=new(q||RTCPeerConnection)({iceServers:[...eQ,...Q||[]],...J}),z={},Y=!1,Z=!1,j,V=(X)=>Object.assign(X,{binaryType:"arraybuffer",bufferedAmountLowThreshold:65535,onmessage:(K)=>z.data?.(K.data),onopen:()=>z.connect?.(),onclose:()=>z.close?.(),onerror:(K)=>!K?.error?.message?.includes("User-Initiated Abort")&&z.error?.(K)}),N=()=>Promise.race([new Promise((X)=>{let K=()=>{if(G.iceGatheringState==="complete")G.removeEventListener(JQ,K),X()};G.addEventListener(JQ,K),K()}),new Promise((X)=>setTimeout(X,sQ))]).then(()=>({type:G.localDescription.type,sdp:G.localDescription.sdp.replace(/a=ice-options:trickle\s\n/g,"")}));if($?V(j=G.createDataChannel("data")):G.ondatachannel=({channel:X})=>V(j=X),G.onnegotiationneeded=async()=>{try{Y=!0,await G.setLocalDescription(),z.signal?.(await N())}catch(X){z.error?.(X)}finally{Y=!1}},G.onconnectionstatechange=()=>{if(["disconnected","failed","closed"].includes(G.connectionState))z.close?.()},G.ontrack=(X)=>{z.track?.(X.track,X.streams[0]),z.stream?.(X.streams[0])},G.onremovestream=(X)=>z.stream?.(X.stream),$&&!G.canTrickleIceCandidates)G.onnegotiationneeded();let x=()=>G.getSenders();return{created:Date.now(),connection:G,get channel(){return j},get isDead(){return G.connectionState==="closed"},async signal(X){if(j?.readyState==="open"&&!X.sdp?.includes("a=rtpmap"))return;try{if(X.type===qQ){if(Y||G.signalingState!=="stable"&&!Z){if($)return;await N0([G.setLocalDescription({type:"rollback"}),G.setRemoteDescription(X)])}else await G.setRemoteDescription(X);await G.setLocalDescription();let K=await N();return z.signal?.(K),K}if(X.type===tQ){Z=!0;try{await G.setRemoteDescription(X)}finally{Z=!1}}}catch(K){z.error?.(K)}},sendData:(X)=>j.send(X),destroy:()=>{j?.close(),G.close(),Y=Z=!1},setHandlers:(X)=>Object.assign(z,X),offerPromise:$?new Promise((X)=>z.signal=(K)=>K.type===qQ&&X(K)):Promise.resolve(),addStream:(X)=>X.getTracks().forEach((K)=>G.addTrack(K,X)),removeStream:(X)=>x().filter((K)=>X.getTracks().includes(K.track)).forEach((K)=>G.removeTrack(K)),addTrack:(X,K)=>G.addTrack(X,K),removeTrack:(X)=>{let K=x().find((B)=>B.track===X);if(K)G.removeTrack(K)},replaceTrack:(X,K)=>x().find((B)=>B.track===X)?.replaceTrack(K)}};var $J=Object.getPrototypeOf(Uint8Array),L$=12,GQ=0,k$=GQ+L$,I$=k$+1,q$=I$+1,G$=q$+1,J$=16384-G$,w$=255,$8="bufferedamountlow",F0=($)=>`@_${$}`,Q8=100,QJ=3,JJ=200,zQ=($,J,q)=>{let Q=new Map,G=new Map,z=new Map,Y={},Z={},j={},V={},N=new Map,x=(U,D)=>{if(!N.has(U))N.set(U,new Set);N.get(U).add(D)},X=(U,D)=>N.get(U)?.delete(D),K=(U,...D)=>N.get(U)?.forEach((H)=>H(...D)),B=(U,D)=>{let H=U?Array.isArray(U)?U:[U]:Q.keys();return Array.from(H,(O)=>{let C=Q.get(O);if(!C)return null;return D(O,C)}).filter(Boolean)},w=(U)=>{if(!Q.has(U))return;Q.delete(U),delete Y[U],delete Z[U],delete j[U],delete V[U],K("peer:leave",U),J(U)},f=(U)=>new Promise((D,H)=>{let O=setTimeout(()=>{U.removeEventListener($8,C),H(Error(`${e0}: bufferLow timeout`))},5000);function C(){clearTimeout(O),U.removeEventListener($8,C),D()}U.addEventListener($8,C)}),v=(U)=>{if(z.has(U))return z.get(U);if(!U)throw J0("action type is required");let D=X0(U);if(D.byteLength>L$)throw J0(`❌ "${U}" exceeds ${L$} bytes. Use a shorter name.`);let H=new Uint8Array(L$).map((P,E)=>D[E]||0),O=0,C=new Map([["message",new Set],["progress",new Set]]),R=(P,E)=>C.get(P)?.add(E),g=(P,E)=>C.get(P)?.delete(E),I=async(P,E,b,y)=>{if(b&&typeof b!=="object")throw J0("meta must be object");if(P===void 0)throw J0("data cannot be undefined");let u=P instanceof Blob,F=u||P instanceof ArrayBuffer||P instanceof $J,n=typeof P!=="string";if(b&&!F)throw J0("meta only allowed with binary");let z0=F?new Uint8Array(u?await P.arrayBuffer():P):X0(n?t(P):P),r=b?X0(t(b)):null,s=Math.ceil(z0.byteLength/J$)+(b?1:0)||1;if(s>Q8)throw J0(`Message too large, exceeds max chunks ${Q8}`);let G8=m0(s,(Y$,Y0)=>{let c0=Y0===s-1,B0=b&&Y0===0,X$=B0?r:z0.subarray(b?(Y0-1)*J$:Y0*J$,b?Y0*J$:(Y0+1)*J$),R0=new Uint8Array(G$+X$.byteLength);return R0.set(H),R0.set([O],k$),R0.set([c0|B0<<1|F<<2|n<<3],I$),R0.set([Math.round((Y0+1)/s*w$)],q$),R0.set(X$,G$),R0});return O=O+1&w$,N0(B(E,async(Y$,Y0)=>{let{channel:c0}=Y0;for(let B0=0;B0<s;B0++){let X$=0;while(c0.bufferedAmount>c0.bufferedAmountLowThreshold){if(X$++>QJ)throw J0(`${e0}: send buffer full, max retries reached for peer ${Y$}`);try{await f(c0)}catch(R0){await new Promise((AQ)=>setTimeout(AQ,JJ))}}if(!Q.has(Y$))break;Y0.sendData(G8[B0]),y?.(G8[B0][q$]/w$,Y$,b)}}))};G.set(U,{listeners:C,send:I});let L={send:I,on:R,off:g};return z.set(U,L),L},q0=(U,D)=>{try{let H=new Uint8Array(D),O=E0(H.subarray(GQ,k$)).replace(//g,"");if(!G.has(O))return;let[C]=H.subarray(k$,I$),[R]=H.subarray(I$,q$),[g]=H.subarray(q$,G$),I=H.subarray(G$),L=Boolean(R&1),P=Boolean(R&2),E=Boolean(R&4),b=Boolean(R&8),y=G.get(O),u=(Y[U]||={})[O]||={};if(u[C]?.chunks?.length>Q8)return;let F=u[C]||={chunks:[]};if(P)try{F.meta=f0(E0(I))}catch{return}else F.chunks.push(I);if(y.listeners.get("progress").forEach((r)=>{try{r(g/w$,U,F.meta)}catch(s){}}),!L)return;let n=new Uint8Array(F.chunks.reduce((r,s)=>r+s.byteLength,0));F.chunks.reduce((r,s)=>(n.set(s,r),r+s.byteLength),0),delete u[C];let z0;if(E)z0=n;else if(b)try{z0=f0(E0(n))}catch{return}else z0=E0(n);y.listeners.get("message").forEach((r)=>{try{r(z0,U,F.meta)}catch(s){}})}catch(H){}},_=async()=>{try{await M(""),await new Promise((U)=>setTimeout(U,99))}catch(U){}for(let[U,D]of Q){try{D.destroy()}catch{}Q.delete(U)}q()},{send:i,on:l}=v(F0("ping")),{send:a,on:V0}=v(F0("pong")),{send:e,on:k}=v(F0("signal")),{send:G0,on:S}=v(F0("stream")),{send:W,on:A}=v(F0("track")),{send:M,on:T}=v(F0("leave"));if($((U,D)=>{if(Q.has(D))return;Q.set(D,U),U.setHandlers({data:(H)=>q0(D,H),stream:(H)=>{K("stream:add",H,D,j[D]),delete j[D]},track:(H,O)=>{K("track:add",H,O,D,V[D]),delete V[D]},signal:(H)=>e(H,D),close:()=>w(D),error:(H)=>{w(D)}}),K("peer:join",D)}),l("message",(U,D)=>a("",D)),V0("message",(U,D)=>{Z[D]?.(),delete Z[D]}),k("message",(U,D)=>Q.get(D)?.signal(U)),S("message",(U,D)=>j[D]=U),A("message",(U,D)=>V[D]=U),T("message",(U,D)=>w(D)),t8)addEventListener("beforeunload",_);return{on:x,off:X,channel:v,leave:_,ping:async(U)=>{if(!U)throw J0("ping() requires target peer ID");let D=Date.now();return i("",U),await new Promise((H)=>Z[U]=H),Date.now()-D},getPeers:()=>R$(Array.from(Q,([U,D])=>[U,D.connection])),addStream:(U,D,H)=>B(D,async(O,C)=>{if(H)await G0(H,O);C.addStream(U)}),removeStream:(U,D)=>B(D,(H,O)=>O.removeStream(U)),addTrack:(U,D,H,O)=>B(H,async(C,R)=>{if(O)await W(O,C);R.addTrack(U,D)}),removeTrack:(U,D)=>B(D,(H,O)=>O.removeTrack(U)),replaceTrack:(U,D,H,O)=>B(H,async(C,R)=>{if(O)await W(O,C);R.replaceTrack(U,D)})}};var qJ=20,GJ=2500,YQ=57333,XQ=({init:$,subscribe:J,announce:q})=>{let Q={},G=!1,z,Y;return(Z,j,V)=>{let{appId:N}=Z;if(Q[N]?.[j])return Q[N][j];if(!Z||!j||!N&&!Z.firebaseApp)throw J0(!Z?"config required":!j?"roomId required":"appId missing");let x=$Q;if(!G){let S=$(Z);Y=m0(qJ,()=>x$(!0,Z)),z=Array.isArray(S)?S:[S];let W=setInterval(()=>{Y=Y.filter((A)=>{let M=Date.now()-A.created<YQ;if(!M)A.destroy();return M})},YQ);Q.offerCleanupTimer||=W,G=!0}let X={},K={},B=Q$(e0,N,j),w=t0(B),f=t0(Q$(B,W0)),v=a8(Z.password||"",N,j),q0=(S)=>async(W)=>({type:W.type,sdp:await S(v,W.sdp)}),_=q0(s8),i=q0(n8),l=(S,W)=>{if(K[W]===S)return;K[W]?.destroy(),K[W]=S,x(S,W),X[W]?.forEach((A)=>A!==S&&A.destroy()),delete X[W]},a=(S,W)=>{if(K[W]===S)delete K[W]},V0=(S)=>async(W,A,M)=>{let[T,U]=await N0([w,f]);if(W!==T&&W!==U)return;let{peerId:D,offer:H,answer:O}=typeof A==="string"?f0(A):A;if(D===W0||K[D])return;if(H){if(X[D]?.[S]&&W0>D)return;let C=x$(!1,Z);C.setHandlers({connect:()=>l(C,D),close:()=>a(C,D)});try{let R=await _(H);if(C.isDead)return;let[g,I]=await N0([t0(Q$(B,D)),C.signal(R).then(i)]);M(g,t({peerId:W0,answer:I}))}catch{V?.({error:"decryption failed (offer)",appId:N,peerId:D,roomId:j})}}else if(O){let C=X[D]?.[S];if(!C||C.isDead)return;C.setHandlers({connect:()=>l(C,D),close:()=>a(C,D)});try{C.signal(await _(O))}catch{V?.({error:"decryption failed (answer)",appId:N,peerId:D,roomId:j})}}else{if(X[D]?.[S])return;let C=Y.pop()||x$(!0,Z),[R,{offer:g}]=await N0([t0(Q$(B,D)),C.offerPromise.then(i).then((I)=>({offer:I}))]);X[D]||=[],X[D][S]=C,C.setHandlers({connect:()=>l(C,D),close:()=>a(C,D)}),M(R,t({peerId:W0,offer:g,peer:C}))}},e=[],k=[];z.forEach(async(S,W)=>{let A=await S;if(!A)return;let[M,T]=await N0([w,f]);k[W]=J(A,M,T,V0(W));let U=async()=>{let D=await q(A,M,T);e[W]=setTimeout(U,typeof D==="number"?D:GJ)};U()}),Q[N]||={};let G0=zQ((S)=>x=S,(S)=>delete K[S],()=>G0.onCleanup?.());return G0.onCleanup=()=>{if(delete Q[N][j],e.forEach(clearTimeout),k.forEach((S)=>S?.()),Object.keys(Q).length===0)clearInterval(Q.offerCleanupTimer),delete Q.offerCleanupTimer},Q[N][j]=G0}};var ZQ=3333,S$={},UQ={},jQ=($,J)=>{let q={},Q=null,G=()=>{if(Q)clearTimeout(Q),Q=null;let z=new WebSocket($);z.onclose=()=>{S$[$]??=ZQ,Q=setTimeout(G,S$[$]),S$[$]*=2},z.onmessage=(Y)=>J(Y.data),q.socket=z,q.url=z.url,q.ready=new Promise((Y)=>{z.onopen=()=>{S$[$]=ZQ,Y(q)}}),q.send=(Y)=>{if(z.readyState===1)z.send(Y)}};return q.forceReconnect=G,G(),UQ[$]=q,q};if(typeof window<"u"){let $=()=>{Object.values(UQ).forEach((J)=>{if(J.socket&&J.socket.readyState!==WebSocket.OPEN&&J.socket.readyState!==WebSocket.CONNECTING)J.forceReconnect()})};window.addEventListener("online",()=>{$()}),window.addEventListener("offline",async()=>{}),document.addEventListener("visibilitychange",()=>{if(document.visibilityState==="visible")$()})}var KQ=($)=>()=>R$(e8($).map(([J,q])=>[J,q.socket])),DQ=($,J,q,Q)=>($.relayUrls??(Q?QQ(J,B$($.appId)):J)).slice(0,$.relayUrls?.length??$.relayRedundancy??q);var h0={},zJ=10,VQ="x",CQ="EVENT",YJ=/pow:\s*(\d+)\s*bits needed\.?/i,J8=new Set,TQ=O$.utils.randomSecretKey(),XJ=A$(O$.getPublicKey(TQ)),q8={},z$={},ZJ={},HQ=()=>Math.floor(Date.now()/1000),OQ=($)=>ZJ[$]??=B$($,1e4)+20000,P$=($)=>$.replace(/\/$/,""),UJ=["wss://relay.primal.net","wss://ftp.halifax.rwth-aachen.de/nostr","wss://nostr.oxtr.dev","wss://nostr.sathoarder.com","wss://nostr.mom","wss://nos.lol","wss://nostr.vulpem.com","wss://nostr.data.haus","wss://relay.mostro.network","wss://relay.nostrdice.com"],jJ=($,J)=>{let[q,Q,G,z]=f0(J);if(q===CQ)return z$[Q]?.(q8[Q],G.content);if(q==="NOTICE"||q==="OK"&&!G){if(+((q==="NOTICE"?Q:z).match(YJ)?.[1]??0)>0){let Z=P$($);J8.add(Z),h0[Z]?.close?.(),delete h0[Z]}}},KJ=($)=>{let J=P$($);if(h0[J])return h0[J];let q=jQ(J,(Q)=>jJ(J,Q));return h0[J]=q},MQ=async($,J)=>{let q={kind:OQ($),content:J,pubkey:XJ,created_at:HQ(),tags:[[VQ,$]]},Q=X0(t([0,q.pubkey,q.created_at,q.kind,q.tags,q.content])),G=new Uint8Array(await crypto.subtle.digest("SHA-256",Q)),z=O$.sign(G,TQ);return t([CQ,{...q,id:A$(G),sig:A$(z)}])},WQ=($,J)=>{return q8[$]=J,t(["REQ",$,{kinds:[OQ(J)],since:HQ(),["#"+VQ]:[J]}])},NQ=($)=>{return delete q8[$],t(["CLOSE",$])},DJ=XQ({init:($)=>{let q=($?.relayUrls?.length?$.relayUrls:null)??UJ;return DQ($,q,zJ,!1).map(KJ).map((G)=>G.ready.then(()=>G).catch(()=>null))},subscribe:($,J,q,Q)=>{let G=$$(64),z=$$(64);return z$[G]=z$[z]=(Y,Z)=>Q(Y,Z,async(j,V)=>{if(J8.has(P$($.url)))return;$.send(await MQ(j,V))}),$.send(WQ(G,J)),$.send(WQ(z,q)),()=>{$.send(NQ(G)),$.send(NQ(z)),delete z$[G],delete z$[z]}},announce:async($,J)=>{if(J8.has(P$($.url)))return;$.send(await MQ(J,t({peerId:W0})))}}),MJ=KQ(h0);export{W0 as selfId,DJ as join,MJ as getRelaySockets};
Binary file
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "genosdb",
3
- "version": "0.16.1",
3
+ "version": "0.17.0",
4
4
  "description": "GenosDB (GDB): distributed graph database in real-time, peer-to-peer, scalable storage - efficient querying of complex relationships.",
5
5
  "main": "dist/index.js",
6
6
  "type": "module",