@konemono/nostr-login 1.7.40 → 1.7.42
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.esm.js +1 -1
- package/dist/unpkg.js +1 -1
- package/package.json +1 -1
- package/src/modules/AuthNostrService.ts +34 -6
package/dist/index.esm.js
CHANGED
|
@@ -43,5 +43,5 @@ function getHash(e){return{hash:e,hmac:(t,...n)=>hmac(e,t,concatBytes$1(...n)),r
|
|
|
43
43
|
/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */hmac.create=(e,t)=>new HMAC(e,t);const secp256k1P=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),secp256k1N=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),_1n=BigInt(1),_2n=BigInt(2),divNearest=(e,t)=>(e+t/_2n)/t;function sqrtMod(e){const t=secp256k1P,n=BigInt(3),r=BigInt(6),i=BigInt(11),s=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),l=e*e*e%t,h=l*l*e%t,d=pow2(h,n,t)*h%t,u=pow2(d,n,t)*h%t,f=pow2(u,_2n,t)*l%t,p=pow2(f,i,t)*f%t,g=pow2(p,s,t)*p%t,y=pow2(g,a,t)*g%t,m=pow2(y,c,t)*y%t,b=pow2(m,a,t)*g%t,w=pow2(b,n,t)*h%t,v=pow2(w,o,t)*p%t,$=pow2(v,r,t)*l%t,E=pow2($,_2n,t);if(!Fp.eql(Fp.sqr(E),e))throw new Error("Cannot find square root");return E}const Fp=Field(secp256k1P,void 0,void 0,{sqrt:sqrtMod}),secp256k1=createCurve({a:BigInt(0),b:BigInt(7),Fp:Fp,n:secp256k1N,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:e=>{const t=secp256k1N,n=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),r=-_1n*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),i=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=n,o=BigInt("0x100000000000000000000000000000000"),a=divNearest(s*e,t),c=divNearest(-r*e,t);let l=mod(e-a*n-c*i,t),h=mod(-a*r-c*s,t);const d=l>o,u=h>o;if(d&&(l=t-l),u&&(h=t-h),l>o||h>o)throw new Error("splitScalar: Endomorphism failed, k="+e);return{k1neg:d,k1:l,k2neg:u,k2:h}}}},sha256);
|
|
44
44
|
/*! scure-base - MIT License (c) 2022 Paul Miller (paulmillr.com) */
|
|
45
45
|
function isBytes(e){return e instanceof Uint8Array||null!=e&&"object"==typeof e&&"Uint8Array"===e.constructor.name}function chain(...e){const t=e=>e,n=(e,t)=>n=>e(t(n));return{encode:e.map(e=>e.encode).reduceRight(n,t),decode:e.map(e=>e.decode).reduce(n,t)}}function alphabet(e){return{encode:t=>{if(!Array.isArray(t)||t.length&&"number"!=typeof t[0])throw new Error("alphabet.encode input should be an array of numbers");return t.map(t=>{if(t<0||t>=e.length)throw new Error(`Digit index outside alphabet: ${t} (alphabet: ${e.length})`);return e[t]})},decode:t=>{if(!Array.isArray(t)||t.length&&"string"!=typeof t[0])throw new Error("alphabet.decode input should be array of strings");return t.map(t=>{if("string"!=typeof t)throw new Error(`alphabet.decode: not string element=${t}`);const n=e.indexOf(t);if(-1===n)throw new Error(`Unknown letter: "${t}". Allowed: ${e}`);return n})}}}function join(e=""){if("string"!=typeof e)throw new Error("join separator should be string");return{encode:t=>{if(!Array.isArray(t)||t.length&&"string"!=typeof t[0])throw new Error("join.encode input should be array of strings");for(let e of t)if("string"!=typeof e)throw new Error(`join.encode: non-string input=${e}`);return t.join(e)},decode:t=>{if("string"!=typeof t)throw new Error("join.decode input should be string");return t.split(e)}}}function convertRadix(e,t,n){if(t<2)throw new Error(`convertRadix: wrong from=${t}, base cannot be less than 2`);if(n<2)throw new Error(`convertRadix: wrong to=${n}, base cannot be less than 2`);if(!Array.isArray(e))throw new Error("convertRadix: data should be array");if(!e.length)return[];let r=0;const i=[],s=Array.from(e);for(s.forEach(e=>{if(e<0||e>=t)throw new Error(`Wrong integer: ${e}`)});;){let e=0,o=!0;for(let i=r;i<s.length;i++){const a=s[i],c=t*e+a;if(!Number.isSafeInteger(c)||t*e/t!==e||c-a!==t*e)throw new Error("convertRadix: carry overflow");e=c%n;const l=Math.floor(c/n);if(s[i]=l,!Number.isSafeInteger(l)||l*n+e!==c)throw new Error("convertRadix: carry overflow");o&&(l?o=!1:r=i)}if(i.push(e),o)break}for(let t=0;t<e.length-1&&0===e[t];t++)i.push(0);return i.reverse()}function radix(e){return{encode:t=>{if(!isBytes(t))throw new Error("radix.encode input should be Uint8Array");return convertRadix(Array.from(t),256,e)},decode:t=>{if(!Array.isArray(t)||t.length&&"number"!=typeof t[0])throw new Error("radix.decode input should be array of numbers");return Uint8Array.from(convertRadix(t,e,256))}}}function checksum(e,t){if("function"!=typeof t)throw new Error("checksum fn should be function");return{encode(n){if(!isBytes(n))throw new Error("checksum.encode: input should be Uint8Array");const r=t(n).slice(0,e),i=new Uint8Array(n.length+e);return i.set(n),i.set(r,n.length),i},decode(n){if(!isBytes(n))throw new Error("checksum.decode: input should be Uint8Array");const r=n.slice(0,-e),i=t(r).slice(0,e),s=n.slice(-e);for(let t=0;t<e;t++)if(i[t]!==s[t])throw new Error("Invalid checksum");return r}}}BigInt(0),secp256k1.ProjectivePoint;const genBase58=e=>chain(radix(58),alphabet(e),join("")),base58=genBase58("123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"),createBase58check=e=>chain(checksum(4,t=>e(e(t))),base58),base58check$1=createBase58check,Point=secp256k1.ProjectivePoint,base58check=base58check$1(sha256$1);function bytesToNumber(e){return BigInt(`0x${bytesToHex$1(e)}`)}function numberToBytes(e){return hexToBytes$1(e.toString(16).padStart(64,"0"))}const MASTER_SECRET=utf8ToBytes$3("Bitcoin seed"),BITCOIN_VERSIONS={private:76066276,public:76067358},HARDENED_OFFSET=2147483648,hash160=e=>ripemd160(sha256$1(e)),fromU32=e=>createView$1(e).getUint32(0,!1),toU32=e=>{if(!Number.isSafeInteger(e)||e<0||e>2**32-1)throw new Error(`Invalid number=${e}. Should be from 0 to 2 ** 32 - 1`);const t=new Uint8Array(4);return createView$1(t).setUint32(0,e,!1),t};class HDKey{get fingerprint(){if(!this.pubHash)throw new Error("No publicKey set!");return fromU32(this.pubHash)}get identifier(){return this.pubHash}get pubKeyHash(){return this.pubHash}get privateKey(){return this.privKeyBytes||null}get publicKey(){return this.pubKey||null}get privateExtendedKey(){const e=this.privateKey;if(!e)throw new Error("No private key");return base58check.encode(this.serialize(this.versions.private,concatBytes$2(new Uint8Array([0]),e)))}get publicExtendedKey(){if(!this.pubKey)throw new Error("No public key");return base58check.encode(this.serialize(this.versions.public,this.pubKey))}static fromMasterSeed(e,t=BITCOIN_VERSIONS){if(bytes$2(e),8*e.length<128||8*e.length>512)throw new Error(`HDKey: wrong seed length=${e.length}. Should be between 128 and 512 bits; 256 bits is advised)`);const n=hmac$1(sha512,MASTER_SECRET,e);return new HDKey({versions:t,chainCode:n.slice(32),privateKey:n.slice(0,32)})}static fromExtendedKey(e,t=BITCOIN_VERSIONS){const n=base58check.decode(e),r=createView$1(n),i=r.getUint32(0,!1),s={versions:t,depth:n[4],parentFingerprint:r.getUint32(5,!1),index:r.getUint32(9,!1),chainCode:n.slice(13,45)},o=n.slice(45),a=0===o[0];if(i!==t[a?"private":"public"])throw new Error("Version mismatch");return new HDKey(a?{...s,privateKey:o.slice(1)}:{...s,publicKey:o})}static fromJSON(e){return HDKey.fromExtendedKey(e.xpriv)}constructor(e){if(this.depth=0,this.index=0,this.chainCode=null,this.parentFingerprint=0,!e||"object"!=typeof e)throw new Error("HDKey.constructor must not be called directly");if(this.versions=e.versions||BITCOIN_VERSIONS,this.depth=e.depth||0,this.chainCode=e.chainCode,this.index=e.index||0,this.parentFingerprint=e.parentFingerprint||0,!this.depth&&(this.parentFingerprint||this.index))throw new Error("HDKey: zero depth with non-zero index/parent fingerprint");if(e.publicKey&&e.privateKey)throw new Error("HDKey: publicKey and privateKey at same time.");if(e.privateKey){if(!secp256k1.utils.isValidPrivateKey(e.privateKey))throw new Error("Invalid private key");this.privKey="bigint"==typeof e.privateKey?e.privateKey:bytesToNumber(e.privateKey),this.privKeyBytes=numberToBytes(this.privKey),this.pubKey=secp256k1.getPublicKey(e.privateKey,!0)}else{if(!e.publicKey)throw new Error("HDKey: no public or private key provided");this.pubKey=Point.fromHex(e.publicKey).toRawBytes(!0)}this.pubHash=hash160(this.pubKey)}derive(e){if(!/^[mM]'?/.test(e))throw new Error('Path must start with "m" or "M"');if(/^[mM]'?$/.test(e))return this;const t=e.replace(/^[mM]'?\//,"").split("/");let n=this;for(const e of t){const t=/^(\d+)('?)$/.exec(e);if(!t||3!==t.length)throw new Error(`Invalid child index: ${e}`);let r=+t[1];if(!Number.isSafeInteger(r)||r>=HARDENED_OFFSET)throw new Error("Invalid index");"'"===t[2]&&(r+=HARDENED_OFFSET),n=n.deriveChild(r)}return n}deriveChild(e){if(!this.pubKey||!this.chainCode)throw new Error("No publicKey or chainCode set");let t=toU32(e);if(e>=HARDENED_OFFSET){const e=this.privateKey;if(!e)throw new Error("Could not derive hardened child key");t=concatBytes$2(new Uint8Array([0]),e,t)}else t=concatBytes$2(this.pubKey,t);const n=hmac$1(sha512,this.chainCode,t),r=bytesToNumber(n.slice(0,32)),i=n.slice(32);if(!secp256k1.utils.isValidPrivateKey(r))throw new Error("Tweak bigger than curve order");const s={versions:this.versions,chainCode:i,depth:this.depth+1,parentFingerprint:this.fingerprint,index:e};try{if(this.privateKey){const e=mod(this.privKey+r,secp256k1.CURVE.n);if(!secp256k1.utils.isValidPrivateKey(e))throw new Error("The tweak was out of range or the resulted private key is invalid");s.privateKey=e}else{const e=Point.fromHex(this.pubKey).add(Point.fromPrivateKey(r));if(e.equals(Point.ZERO))throw new Error("The tweak was equal to negative P, which made the result key invalid");s.publicKey=e.toRawBytes(!0)}return new HDKey(s)}catch(t){return this.deriveChild(e+1)}}sign(e){if(!this.privateKey)throw new Error("No privateKey set!");return bytes$2(e,32),secp256k1.sign(e,this.privKey).toCompactRawBytes()}verify(e,t){if(bytes$2(e,32),bytes$2(t,64),!this.publicKey)throw new Error("No publicKey set!");let n;try{n=secp256k1.Signature.fromCompact(t)}catch(e){return!1}return secp256k1.verify(n,e,this.publicKey)}wipePrivateData(){return this.privKey=void 0,this.privKeyBytes&&(this.privKeyBytes.fill(0),this.privKeyBytes=void 0),this}toJSON(){return{xpriv:this.privateExtendedKey,xpub:this.publicExtendedKey}}serialize(e,t){if(!this.chainCode)throw new Error("No chainCode set");return bytes$2(t,33),concatBytes$2(toU32(e),new Uint8Array([this.depth]),toU32(this.parentFingerprint),toU32(this.index),this.chainCode,t)}}
|
|
46
|
-
/*! noble-ciphers - MIT License (c) 2023 Paul Miller (paulmillr.com) */const u8a=e=>e instanceof Uint8Array,u32=e=>new Uint32Array(e.buffer,e.byteOffset,Math.floor(e.byteLength/4)),isLE=68===new Uint8Array(new Uint32Array([287454020]).buffer)[0];if(!isLE)throw new Error("Non little-endian hardware is not supported");function utf8ToBytes(e){if("string"!=typeof e)throw new Error("utf8ToBytes expected string, got "+typeof e);return new Uint8Array((new TextEncoder).encode(e))}function toBytes(e){if("string"==typeof e&&(e=utf8ToBytes(e)),!u8a(e))throw new Error("expected Uint8Array, got "+typeof e);return e}const isPlainObject=e=>"[object Object]"===Object.prototype.toString.call(e)&&e.constructor===Object;function checkOpts(e,t){if(void 0!==t&&("object"!=typeof t||!isPlainObject(t)))throw new Error("options must be object or undefined");return Object.assign(e,t)}function ensureBytes(e,t){if(!(e instanceof Uint8Array))throw new Error("Uint8Array expected");if(e.length!==t)throw new Error(`Uint8Array length ${t} expected`)}function equalBytes(e,t){if(e.length!==t.length)throw new Error("equalBytes: Different size of Uint8Arrays");let n=!0;for(let r=0;r<e.length;r++)n&&(n=e[r]===t[r]);return n}function number(e){if(!Number.isSafeInteger(e)||e<0)throw new Error(`Wrong positive integer: ${e}`)}function bool(e){if("boolean"!=typeof e)throw new Error(`Expected boolean, not ${e}`)}function bytes(e,...t){if(!(e instanceof Uint8Array))throw new Error("Expected Uint8Array");if(t.length>0&&!t.includes(e.length))throw new Error(`Expected Uint8Array of length ${t}, not of length=${e.length}`)}function hash(e){if("function"!=typeof e||"function"!=typeof e.create)throw new Error("hash must be wrapped by utils.wrapConstructor");number(e.outputLen),number(e.blockLen)}function exists(e,t=!0){if(e.destroyed)throw new Error("Hash instance has been destroyed");if(t&&e.finished)throw new Error("Hash#digest() has already been called")}function output(e,t){bytes(e);const n=t.outputLen;if(e.length<n)throw new Error(`digestInto() expects output buffer of length at least ${n}`)}const assert={number:number,bool:bool,bytes:bytes,hash:hash,exists:exists,output:output},u8to16=(e,t)=>255&e[t++]|(255&e[t++])<<8;class Poly1305{constructor(e){this.blockLen=16,this.outputLen=16,this.buffer=new Uint8Array(16),this.r=new Uint16Array(10),this.h=new Uint16Array(10),this.pad=new Uint16Array(8),this.pos=0,this.finished=!1,ensureBytes(e=toBytes(e),32);const t=u8to16(e,0),n=u8to16(e,2),r=u8to16(e,4),i=u8to16(e,6),s=u8to16(e,8),o=u8to16(e,10),a=u8to16(e,12),c=u8to16(e,14);this.r[0]=8191&t,this.r[1]=8191&(t>>>13|n<<3),this.r[2]=7939&(n>>>10|r<<6),this.r[3]=8191&(r>>>7|i<<9),this.r[4]=255&(i>>>4|s<<12),this.r[5]=s>>>1&8190,this.r[6]=8191&(s>>>14|o<<2),this.r[7]=8065&(o>>>11|a<<5),this.r[8]=8191&(a>>>8|c<<8),this.r[9]=c>>>5&127;for(let t=0;t<8;t++)this.pad[t]=u8to16(e,16+2*t)}process(e,t,n=!1){const r=n?0:2048,{h:i,r:s}=this,o=s[0],a=s[1],c=s[2],l=s[3],h=s[4],d=s[5],u=s[6],f=s[7],p=s[8],g=s[9],y=u8to16(e,t+0),m=u8to16(e,t+2),b=u8to16(e,t+4),w=u8to16(e,t+6),v=u8to16(e,t+8),$=u8to16(e,t+10),E=u8to16(e,t+12),k=u8to16(e,t+14);let x=i[0]+(8191&y),_=i[1]+(8191&(y>>>13|m<<3)),S=i[2]+(8191&(m>>>10|b<<6)),C=i[3]+(8191&(b>>>7|w<<9)),A=i[4]+(8191&(w>>>4|v<<12)),N=i[5]+(v>>>1&8191),R=i[6]+(8191&(v>>>14|$<<2)),T=i[7]+(8191&($>>>11|E<<5)),B=i[8]+(8191&(E>>>8|k<<8)),L=i[9]+(k>>>5|r),I=0,U=I+x*o+_*(5*g)+S*(5*p)+C*(5*f)+A*(5*u);I=U>>>13,U&=8191,U+=N*(5*d)+R*(5*h)+T*(5*l)+B*(5*c)+L*(5*a),I+=U>>>13,U&=8191;let O=I+x*a+_*o+S*(5*g)+C*(5*p)+A*(5*f);I=O>>>13,O&=8191,O+=N*(5*u)+R*(5*d)+T*(5*h)+B*(5*l)+L*(5*c),I+=O>>>13,O&=8191;let P=I+x*c+_*a+S*o+C*(5*g)+A*(5*p);I=P>>>13,P&=8191,P+=N*(5*f)+R*(5*u)+T*(5*d)+B*(5*h)+L*(5*l),I+=P>>>13,P&=8191;let M=I+x*l+_*c+S*a+C*o+A*(5*g);I=M>>>13,M&=8191,M+=N*(5*p)+R*(5*f)+T*(5*u)+B*(5*d)+L*(5*h),I+=M>>>13,M&=8191;let D=I+x*h+_*l+S*c+C*a+A*o;I=D>>>13,D&=8191,D+=N*(5*g)+R*(5*p)+T*(5*f)+B*(5*u)+L*(5*d),I+=D>>>13,D&=8191;let H=I+x*d+_*h+S*l+C*c+A*a;I=H>>>13,H&=8191,H+=N*o+R*(5*g)+T*(5*p)+B*(5*f)+L*(5*u),I+=H>>>13,H&=8191;let F=I+x*u+_*d+S*h+C*l+A*c;I=F>>>13,F&=8191,F+=N*a+R*o+T*(5*g)+B*(5*p)+L*(5*f),I+=F>>>13,F&=8191;let K=I+x*f+_*u+S*d+C*h+A*l;I=K>>>13,K&=8191,K+=N*c+R*a+T*o+B*(5*g)+L*(5*p),I+=K>>>13,K&=8191;let V=I+x*p+_*f+S*u+C*d+A*h;I=V>>>13,V&=8191,V+=N*l+R*c+T*a+B*o+L*(5*g),I+=V>>>13,V&=8191;let j=I+x*g+_*p+S*f+C*u+A*d;I=j>>>13,j&=8191,j+=N*h+R*l+T*c+B*a+L*o,I+=j>>>13,j&=8191,I=(I<<2)+I|0,I=I+U|0,U=8191&I,I>>>=13,O+=I,i[0]=U,i[1]=O,i[2]=P,i[3]=M,i[4]=D,i[5]=H,i[6]=F,i[7]=K,i[8]=V,i[9]=j}finalize(){const{h:e,pad:t}=this,n=new Uint16Array(10);let r=e[1]>>>13;e[1]&=8191;for(let t=2;t<10;t++)e[t]+=r,r=e[t]>>>13,e[t]&=8191;e[0]+=5*r,r=e[0]>>>13,e[0]&=8191,e[1]+=r,r=e[1]>>>13,e[1]&=8191,e[2]+=r,n[0]=e[0]+5,r=n[0]>>>13,n[0]&=8191;for(let t=1;t<10;t++)n[t]=e[t]+r,r=n[t]>>>13,n[t]&=8191;n[9]-=8192;let i=(1^r)-1;for(let e=0;e<10;e++)n[e]&=i;i=~i;for(let t=0;t<10;t++)e[t]=e[t]&i|n[t];e[0]=65535&(e[0]|e[1]<<13),e[1]=65535&(e[1]>>>3|e[2]<<10),e[2]=65535&(e[2]>>>6|e[3]<<7),e[3]=65535&(e[3]>>>9|e[4]<<4),e[4]=65535&(e[4]>>>12|e[5]<<1|e[6]<<14),e[5]=65535&(e[6]>>>2|e[7]<<11),e[6]=65535&(e[7]>>>5|e[8]<<8),e[7]=65535&(e[8]>>>8|e[9]<<5);let s=e[0]+t[0];e[0]=65535&s;for(let n=1;n<8;n++)s=(e[n]+t[n]|0)+(s>>>16)|0,e[n]=65535&s}update(e){assert.exists(this);const{buffer:t,blockLen:n}=this,r=(e=toBytes(e)).length;for(let i=0;i<r;){const s=Math.min(n-this.pos,r-i);if(s!==n)t.set(e.subarray(i,i+s),this.pos),this.pos+=s,i+=s,this.pos===n&&(this.process(t,0,!1),this.pos=0);else for(;n<=r-i;i+=n)this.process(e,i)}return this}destroy(){this.h.fill(0),this.r.fill(0),this.buffer.fill(0),this.pad.fill(0)}digestInto(e){assert.exists(this),assert.output(e,this),this.finished=!0;const{buffer:t,h:n}=this;let{pos:r}=this;if(r){for(t[r++]=1;r<16;r++)t[r]=0;this.process(t,0,!0)}this.finalize();let i=0;for(let t=0;t<8;t++)e[i++]=n[t]>>>0,e[i++]=n[t]>>>8;return e}digest(){const{buffer:e,outputLen:t}=this;this.digestInto(e);const n=e.slice(0,t);return this.destroy(),n}}function wrapConstructorWithKey(e){const t=(t,n)=>e(n).update(toBytes(t)).digest(),n=e(new Uint8Array(32));return t.outputLen=n.outputLen,t.blockLen=n.blockLen,t.create=t=>e(t),t}wrapConstructorWithKey(e=>new Poly1305(e));const sigma16=utf8ToBytes("expand 16-byte k"),sigma32=utf8ToBytes("expand 32-byte k"),sigma16_32=u32(sigma16),sigma32_32=u32(sigma32),isAligned32=e=>!(e.byteOffset%4),salsaBasic=e=>{const{core:t,rounds:n,counterRight:r,counterLen:i,allow128bitKeys:s,extendNonceFn:o,blockLen:a}=checkOpts({rounds:20,counterRight:!1,counterLen:8,allow128bitKeys:!0,blockLen:64},e);assert.number(i),assert.number(n),assert.number(a),assert.bool(r),assert.bool(s);const c=a/4;if(a%4!=0)throw new Error("Salsa/ChaCha: blockLen must be aligned to 4 bytes");return(e,l,h,d,u=0)=>{if(assert.bytes(e),assert.bytes(l),assert.bytes(h),d||(d=new Uint8Array(h.length)),assert.bytes(d),assert.number(u),u<0||u>=2**32-1)throw new Error("Salsa/ChaCha: counter overflow");if(d.length<h.length)throw new Error(`Salsa/ChaCha: output (${d.length}) is shorter than data (${h.length})`);const f=[];let p,g;if(32===e.length)p=e,g=sigma32_32;else{if(16!==e.length||!s)throw new Error(`Salsa/ChaCha: invalid 32-byte key, got length=${e.length}`);p=new Uint8Array(32),p.set(e),p.set(e,16),g=sigma16_32,f.push(p)}if(o){if(l.length<=16)throw new Error("Salsa/ChaCha: extended nonce must be bigger than 16 bytes");p=o(g,p,l.subarray(0,16),new Uint8Array(32)),f.push(p),l=l.subarray(16)}const y=16-i;if(l.length!==y)throw new Error(`Salsa/ChaCha: nonce must be ${y} or 16 bytes`);if(12!==y){const e=new Uint8Array(12);e.set(l,r?0:12-l.length),f.push(l=e)}const m=new Uint8Array(a),b=u32(m),w=u32(p),v=u32(l),$=isAligned32(h)&&u32(h),E=isAligned32(d)&&u32(d);f.push(b);const k=h.length;for(let e=0,r=u;e<k;r++){if(t(g,w,v,b,r,n),r>=2**32-1)throw new Error("Salsa/ChaCha: counter overflow");const i=Math.min(a,k-e);if(i===a&&E&&$){const t=e/4;if(e%4!=0)throw new Error("Salsa/ChaCha: invalid block position");for(let e=0;e<c;e++)E[t+e]=$[t+e]^b[e];e+=a;continue}for(let t=0;t<i;t++)d[e+t]=h[e+t]^m[t];e+=i}for(let e=0;e<f.length;e++)f[e].fill(0);return d}},rotl=(e,t)=>e<<t|e>>>32-t;function chachaCore(e,t,n,r,i,s=20){let o=e[0],a=e[1],c=e[2],l=e[3],h=t[0],d=t[1],u=t[2],f=t[3],p=t[4],g=t[5],y=t[6],m=t[7],b=i,w=n[0],v=n[1],$=n[2],E=o,k=a,x=c,_=l,S=h,C=d,A=u,N=f,R=p,T=g,B=y,L=m,I=b,U=w,O=v,P=$;for(let e=0;e<s;e+=2)E=E+S|0,I=rotl(I^E,16),R=R+I|0,S=rotl(S^R,12),E=E+S|0,I=rotl(I^E,8),R=R+I|0,S=rotl(S^R,7),k=k+C|0,U=rotl(U^k,16),T=T+U|0,C=rotl(C^T,12),k=k+C|0,U=rotl(U^k,8),T=T+U|0,C=rotl(C^T,7),x=x+A|0,O=rotl(O^x,16),B=B+O|0,A=rotl(A^B,12),x=x+A|0,O=rotl(O^x,8),B=B+O|0,A=rotl(A^B,7),_=_+N|0,P=rotl(P^_,16),L=L+P|0,N=rotl(N^L,12),_=_+N|0,P=rotl(P^_,8),L=L+P|0,N=rotl(N^L,7),E=E+C|0,P=rotl(P^E,16),B=B+P|0,C=rotl(C^B,12),E=E+C|0,P=rotl(P^E,8),B=B+P|0,C=rotl(C^B,7),k=k+A|0,I=rotl(I^k,16),L=L+I|0,A=rotl(A^L,12),k=k+A|0,I=rotl(I^k,8),L=L+I|0,A=rotl(A^L,7),x=x+N|0,U=rotl(U^x,16),R=R+U|0,N=rotl(N^R,12),x=x+N|0,U=rotl(U^x,8),R=R+U|0,N=rotl(N^R,7),_=_+S|0,O=rotl(O^_,16),T=T+O|0,S=rotl(S^T,12),_=_+S|0,O=rotl(O^_,8),T=T+O|0,S=rotl(S^T,7);let M=0;r[M++]=o+E|0,r[M++]=a+k|0,r[M++]=c+x|0,r[M++]=l+_|0,r[M++]=h+S|0,r[M++]=d+C|0,r[M++]=u+A|0,r[M++]=f+N|0,r[M++]=p+R|0,r[M++]=g+T|0,r[M++]=y+B|0,r[M++]=m+L|0,r[M++]=b+I|0,r[M++]=w+U|0,r[M++]=v+O|0,r[M++]=$+P|0}const chacha20=salsaBasic({core:chachaCore,counterRight:!1,counterLen:4,allow128bitKeys:!1});function extract(e,t,n){return assert$3.hash(e),void 0===n&&(n=new Uint8Array(e.outputLen)),hmac$3(e,toBytes$4(n),toBytes$4(t))}const HKDF_COUNTER=new Uint8Array([0]),EMPTY_BUFFER=new Uint8Array;function expand(e,t,n,r=32){if(assert$3.hash(e),assert$3.number(r),r>255*e.outputLen)throw new Error("Length should be <= 255*HashLen");const i=Math.ceil(r/e.outputLen);void 0===n&&(n=EMPTY_BUFFER);const s=new Uint8Array(i*e.outputLen),o=hmac$3.create(e,t),a=o._cloneInto(),c=new Uint8Array(o.outputLen);for(let t=0;t<i;t++)HKDF_COUNTER[0]=t+1,a.update(0===t?EMPTY_BUFFER:c).update(n).update(HKDF_COUNTER).digestInto(c),s.set(c,e.outputLen*t),o._cloneInto(a);return o.destroy(),a.destroy(),c.fill(0),HKDF_COUNTER.fill(0),s.slice(0,r)}const hkdf=(e,t,n,r,i)=>expand(e,extract(e,t,n),r,i);var __defProp=Object.defineProperty,__export=(e,t)=>{for(var n in t)__defProp(e,n,{get:t[n],enumerable:!0})};function generatePrivateKey(){return bytesToHex$3(schnorr.utils.randomPrivateKey())}function getPublicKey(e){return bytesToHex$3(schnorr.getPublicKey(e))}var utils_exports={};__export(utils_exports,{MessageNode:()=>MessageNode,MessageQueue:()=>MessageQueue,insertEventIntoAscendingList:()=>insertEventIntoAscendingList,insertEventIntoDescendingList:()=>insertEventIntoDescendingList,normalizeURL:()=>normalizeURL,utf8Decoder:()=>utf8Decoder,utf8Encoder:()=>utf8Encoder});var utf8Decoder=new TextDecoder("utf-8"),utf8Encoder=new TextEncoder;function normalizeURL(e){let t=new URL(e);return t.pathname=t.pathname.replace(/\/+/g,"/"),t.pathname.endsWith("/")&&(t.pathname=t.pathname.slice(0,-1)),("80"===t.port&&"ws:"===t.protocol||"443"===t.port&&"wss:"===t.protocol)&&(t.port=""),t.searchParams.sort(),t.hash="",t.toString()}function insertEventIntoDescendingList(e,t){let n,r=0,i=e.length-1,s=r;if(i<0)s=0;else if(t.created_at<e[i].created_at)s=i+1;else if(t.created_at>=e[r].created_at)s=r;else for(;;){if(i<=r+1){s=i;break}if(n=Math.floor(r+(i-r)/2),e[n].created_at>t.created_at)r=n;else{if(!(e[n].created_at<t.created_at)){s=n;break}i=n}}return e[s]?.id!==t.id?[...e.slice(0,s),t,...e.slice(s)]:e}function insertEventIntoAscendingList(e,t){let n,r=0,i=e.length-1,s=r;if(i<0)s=0;else if(t.created_at>e[i].created_at)s=i+1;else if(t.created_at<=e[r].created_at)s=r;else for(;;){if(i<=r+1){s=i;break}if(n=Math.floor(r+(i-r)/2),e[n].created_at<t.created_at)r=n;else{if(!(e[n].created_at>t.created_at)){s=n;break}i=n}}return e[s]?.id!==t.id?[...e.slice(0,s),t,...e.slice(s)]:e}var MessageNode=class{_value;_next;get value(){return this._value}set value(e){this._value=e}get next(){return this._next}set next(e){this._next=e}constructor(e){this._value=e,this._next=null}},MessageQueue=class{_first;_last;get first(){return this._first}set first(e){this._first=e}get last(){return this._last}set last(e){this._last=e}_size;get size(){return this._size}set size(e){this._size=e}constructor(){this._first=null,this._last=null,this._size=0}enqueue(e){const t=new MessageNode(e);return 0!==this._size&&this._last?(this._last.next=t,this._last=t):(this._first=t,this._last=t),this._size++,!0}dequeue(){if(0===this._size||!this._first)return null;let e=this._first;return this._first=e.next,e.next=null,this._size--,e.value}},verifiedSymbol=Symbol("verified");function getBlankEvent(e=255){return{kind:e,content:"",tags:[],created_at:0}}function finishEvent(e,t){const n=e;return n.pubkey=getPublicKey(t),n.id=getEventHash(n),n.sig=getSignature(n,t),n[verifiedSymbol]=!0,n}function serializeEvent(e){if(!validateEvent(e))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,e.pubkey,e.created_at,e.kind,e.tags,e.content])}function getEventHash(e){return bytesToHex$3(sha256$3(utf8Encoder.encode(serializeEvent(e))))}var isRecord=e=>e instanceof Object;function validateEvent(e){if(!isRecord(e))return!1;if("number"!=typeof e.kind)return!1;if("string"!=typeof e.content)return!1;if("number"!=typeof e.created_at)return!1;if("string"!=typeof e.pubkey)return!1;if(!e.pubkey.match(/^[a-f0-9]{64}$/))return!1;if(!Array.isArray(e.tags))return!1;for(let t=0;t<e.tags.length;t++){let n=e.tags[t];if(!Array.isArray(n))return!1;for(let e=0;e<n.length;e++)if("object"==typeof n[e])return!1}return!0}function verifySignature(e){if("boolean"==typeof e[verifiedSymbol])return e[verifiedSymbol];const t=getEventHash(e);if(t!==e.id)return e[verifiedSymbol]=!1;try{return e[verifiedSymbol]=schnorr.verify(e.sig,t,e.pubkey)}catch(t){return e[verifiedSymbol]=!1}}function getSignature(e,t){return bytesToHex$3(schnorr.sign(getEventHash(e),t))}var fakejson_exports={};function getHex64(e,t){let n=t.length+3,r=e.indexOf(`"${t}":`)+n,i=e.slice(r).indexOf('"')+r+1;return e.slice(i,i+64)}function getInt(e,t){let n=t.length,r=e.indexOf(`"${t}":`)+n+3,i=e.slice(r),s=Math.min(i.indexOf(","),i.indexOf("}"));return parseInt(i.slice(0,s),10)}function getSubscriptionId(e){let t=e.slice(0,22).indexOf('"EVENT"');if(-1===t)return null;let n=e.slice(t+7+1).indexOf('"');if(-1===n)return null;let r=t+7+1+n,i=e.slice(r+1,80).indexOf('"');if(-1===i)return null;let s=r+1+i;return e.slice(r+1,s)}function matchEventId(e,t){return t===getHex64(e,"id")}function matchEventPubkey(e,t){return t===getHex64(e,"pubkey")}function matchEventKind(e,t){return t===getInt(e,"kind")}__export(fakejson_exports,{getHex64:()=>getHex64,getInt:()=>getInt,getSubscriptionId:()=>getSubscriptionId,matchEventId:()=>matchEventId,matchEventKind:()=>matchEventKind,matchEventPubkey:()=>matchEventPubkey});var nip19_exports={};__export(nip19_exports,{BECH32_REGEX:()=>BECH32_REGEX,decode:()=>decode,naddrEncode:()=>naddrEncode,neventEncode:()=>neventEncode,noteEncode:()=>noteEncode,nprofileEncode:()=>nprofileEncode,npubEncode:()=>npubEncode,nrelayEncode:()=>nrelayEncode,nsecEncode:()=>nsecEncode});var Bech32MaxSize=5e3,BECH32_REGEX=/[\x21-\x7E]{1,83}1[023456789acdefghjklmnpqrstuvwxyz]{6,}/;function integerToUint8Array(e){const t=new Uint8Array(4);return t[0]=e>>24&255,t[1]=e>>16&255,t[2]=e>>8&255,t[3]=255&e,t}function decode(e){let{prefix:t,words:n}=bech32.decode(e,Bech32MaxSize),r=new Uint8Array(bech32.fromWords(n));switch(t){case"nprofile":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for nprofile");if(32!==e[0][0].length)throw new Error("TLV 0 should be 32 bytes");return{type:"nprofile",data:{pubkey:bytesToHex$3(e[0][0]),relays:e[1]?e[1].map(e=>utf8Decoder.decode(e)):[]}}}case"nevent":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for nevent");if(32!==e[0][0].length)throw new Error("TLV 0 should be 32 bytes");if(e[2]&&32!==e[2][0].length)throw new Error("TLV 2 should be 32 bytes");if(e[3]&&4!==e[3][0].length)throw new Error("TLV 3 should be 4 bytes");return{type:"nevent",data:{id:bytesToHex$3(e[0][0]),relays:e[1]?e[1].map(e=>utf8Decoder.decode(e)):[],author:e[2]?.[0]?bytesToHex$3(e[2][0]):void 0,kind:e[3]?.[0]?parseInt(bytesToHex$3(e[3][0]),16):void 0}}}case"naddr":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for naddr");if(!e[2]?.[0])throw new Error("missing TLV 2 for naddr");if(32!==e[2][0].length)throw new Error("TLV 2 should be 32 bytes");if(!e[3]?.[0])throw new Error("missing TLV 3 for naddr");if(4!==e[3][0].length)throw new Error("TLV 3 should be 4 bytes");return{type:"naddr",data:{identifier:utf8Decoder.decode(e[0][0]),pubkey:bytesToHex$3(e[2][0]),kind:parseInt(bytesToHex$3(e[3][0]),16),relays:e[1]?e[1].map(e=>utf8Decoder.decode(e)):[]}}}case"nrelay":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for nrelay");return{type:"nrelay",data:utf8Decoder.decode(e[0][0])}}case"nsec":case"npub":case"note":return{type:t,data:bytesToHex$3(r)};default:throw new Error(`unknown prefix ${t}`)}}function parseTLV(e){let t={},n=e;for(;n.length>0;){let e=n[0],r=n[1];if(!r)throw new Error(`malformed TLV ${e}`);let i=n.slice(2,2+r);if(n=n.slice(2+r),i.length<r)throw new Error(`not enough data to read on TLV ${e}`);t[e]=t[e]||[],t[e].push(i)}return t}function nsecEncode(e){return encodeBytes("nsec",e)}function npubEncode(e){return encodeBytes("npub",e)}function noteEncode(e){return encodeBytes("note",e)}function encodeBech32(e,t){let n=bech32.toWords(t);return bech32.encode(e,n,Bech32MaxSize)}function encodeBytes(e,t){return encodeBech32(e,hexToBytes$3(t))}function nprofileEncode(e){return encodeBech32("nprofile",encodeTLV({0:[hexToBytes$3(e.pubkey)],1:(e.relays||[]).map(e=>utf8Encoder.encode(e))}))}function neventEncode(e){let t;return null!=e.kind&&(t=integerToUint8Array(e.kind)),encodeBech32("nevent",encodeTLV({0:[hexToBytes$3(e.id)],1:(e.relays||[]).map(e=>utf8Encoder.encode(e)),2:e.author?[hexToBytes$3(e.author)]:[],3:t?[new Uint8Array(t)]:[]}))}function naddrEncode(e){let t=new ArrayBuffer(4);return new DataView(t).setUint32(0,e.kind,!1),encodeBech32("naddr",encodeTLV({0:[utf8Encoder.encode(e.identifier)],1:(e.relays||[]).map(e=>utf8Encoder.encode(e)),2:[hexToBytes$3(e.pubkey)],3:[new Uint8Array(t)]}))}function nrelayEncode(e){return encodeBech32("nrelay",encodeTLV({0:[utf8Encoder.encode(e)]}))}function encodeTLV(e){let t=[];return Object.entries(e).forEach(([e,n])=>{n.forEach(n=>{let r=new Uint8Array(n.length+2);r.set([parseInt(e)],0),r.set([n.length],1),r.set(n,2),t.push(r)})}),concatBytes$4(...t)}var nip04_exports={};async function encrypt(e,t,n){const r=getNormalizedX(secp256k1$1.getSharedSecret(e,"02"+t));let i=Uint8Array.from(randomBytes$2(16)),s=utf8Encoder.encode(n),o=await crypto.subtle.importKey("raw",r,{name:"AES-CBC"},!1,["encrypt"]),a=await crypto.subtle.encrypt({name:"AES-CBC",iv:i},o,s);return`${base64.encode(new Uint8Array(a))}?iv=${base64.encode(new Uint8Array(i.buffer))}`}async function decrypt(e,t,n){let[r,i]=n.split("?iv="),s=getNormalizedX(secp256k1$1.getSharedSecret(e,"02"+t)),o=await crypto.subtle.importKey("raw",s,{name:"AES-CBC"},!1,["decrypt"]),a=base64.decode(r),c=base64.decode(i),l=await crypto.subtle.decrypt({name:"AES-CBC",iv:c},o,a);return utf8Decoder.decode(l)}function getNormalizedX(e){return e.slice(1,33)}__export(nip04_exports,{decrypt:()=>decrypt,encrypt:()=>encrypt}),"undefined"!=typeof crypto&&!crypto.subtle&&crypto.webcrypto&&(crypto.subtle=crypto.webcrypto.subtle);var nip05_exports={};__export(nip05_exports,{NIP05_REGEX:()=>NIP05_REGEX,queryProfile:()=>queryProfile,searchDomain:()=>searchDomain,useFetchImplementation:()=>useFetchImplementation});var NIP05_REGEX=/^(?:([\w.+-]+)@)?([\w.-]+)$/,_fetch;try{_fetch=fetch}catch{}function useFetchImplementation(e){_fetch=e}async function searchDomain(e,t=""){try{return(await(await _fetch(`https://${e}/.well-known/nostr.json?name=${t}`)).json()).names}catch(e){return{}}}async function queryProfile(e){const t=e.match(NIP05_REGEX);if(!t)return null;const[n,r="_",i]=t;try{const e=await _fetch(`https://${i}/.well-known/nostr.json?name=${r}`),{names:t,relays:n}=parseNIP05Result(await e.json()),s=t[r];return s?{pubkey:s,relays:n?.[s]}:null}catch(e){return null}}function parseNIP05Result(e){const t={names:{}};for(const[n,r]of Object.entries(e.names))"string"==typeof n&&"string"==typeof r&&(t.names[n]=r);if(e.relays){t.relays={};for(const[n,r]of Object.entries(e.relays))"string"==typeof n&&Array.isArray(r)&&(t.relays[n]=r.filter(e=>"string"==typeof e))}return t}var nip06_exports={};function privateKeyFromSeedWords(e,t){let n=HDKey.fromMasterSeed(mnemonicToSeedSync(e,t)).derive("m/44'/1237'/0'/0/0").privateKey;if(!n)throw new Error("could not derive private key");return bytesToHex$3(n)}function generateSeedWords(){return generateMnemonic(wordlist)}function validateWords(e){return validateMnemonic(e,wordlist)}__export(nip06_exports,{generateSeedWords:()=>generateSeedWords,privateKeyFromSeedWords:()=>privateKeyFromSeedWords,validateWords:()=>validateWords});var nip10_exports={};function parse(e){const t={reply:void 0,root:void 0,mentions:[],profiles:[]},n=[];for(const r of e.tags)"e"===r[0]&&r[1]&&n.push(r),"p"===r[0]&&r[1]&&t.profiles.push({pubkey:r[1],relays:r[2]?[r[2]]:[]});for(let e=0;e<n.length;e++){const r=n[e],[i,s,o,a]=r,c={id:s,relays:o?[o]:[]},l=0===e,h=e===n.length-1;"root"!==a?"reply"!==a?"mention"!==a?l?t.root=c:h?t.reply=c:t.mentions.push(c):t.mentions.push(c):t.reply=c:t.root=c}return t}__export(nip10_exports,{parse:()=>parse});var nip13_exports={};function getPow(e){let t=0;for(let n=0;n<e.length;n++){const r=parseInt(e[n],16);if(0!==r){t+=Math.clz32(r)-28;break}t+=4}return t}function minePow(e,t){let n=0;const r=e,i=["nonce",n.toString(),t.toString()];for(r.tags.push(i);;){const e=Math.floor((new Date).getTime()/1e3);if(e!==r.created_at&&(n=0,r.created_at=e),i[1]=(++n).toString(),r.id=getEventHash(r),getPow(r.id)>=t)break}return r}__export(nip13_exports,{getPow:()=>getPow,minePow:()=>minePow});var nip18_exports={};function finishRepostEvent(e,t,n,r){return finishEvent({kind:6,tags:[...e.tags??[],["e",t.id,n],["p",t.pubkey]],content:""===e.content?"":JSON.stringify(t),created_at:e.created_at},r)}function getRepostedEventPointer(e){if(6!==e.kind)return;let t,n;for(let r=e.tags.length-1;r>=0&&(void 0===t||void 0===n);r--){const i=e.tags[r];i.length>=2&&("e"===i[0]&&void 0===t?t=i:"p"===i[0]&&void 0===n&&(n=i))}return void 0!==t?{id:t[1],relays:[t[2],n?.[2]].filter(e=>"string"==typeof e),author:n?.[1]}:void 0}function getRepostedEvent(e,{skipVerification:t}={}){const n=getRepostedEventPointer(e);if(void 0===n||""===e.content)return;let r;try{r=JSON.parse(e.content)}catch(e){return}return r.id===n.id&&(t||verifySignature(r))?r:void 0}__export(nip18_exports,{finishRepostEvent:()=>finishRepostEvent,getRepostedEvent:()=>getRepostedEvent,getRepostedEventPointer:()=>getRepostedEventPointer});var nip21_exports={};__export(nip21_exports,{NOSTR_URI_REGEX:()=>NOSTR_URI_REGEX,parse:()=>parse2,test:()=>test});var NOSTR_URI_REGEX=new RegExp(`nostr:(${BECH32_REGEX.source})`);function test(e){return"string"==typeof e&&new RegExp(`^${NOSTR_URI_REGEX.source}$`).test(e)}function parse2(e){const t=e.match(new RegExp(`^${NOSTR_URI_REGEX.source}$`));if(!t)throw new Error(`Invalid Nostr URI: ${e}`);return{uri:t[0],value:t[1],decoded:decode(t[1])}}var nip25_exports={};function finishReactionEvent(e,t,n){const r=t.tags.filter(e=>e.length>=2&&("e"===e[0]||"p"===e[0]));return finishEvent({...e,kind:7,tags:[...e.tags??[],...r,["e",t.id],["p",t.pubkey]],content:e.content??"+"},n)}function getReactedEventPointer(e){if(7!==e.kind)return;let t,n;for(let r=e.tags.length-1;r>=0&&(void 0===t||void 0===n);r--){const i=e.tags[r];i.length>=2&&("e"===i[0]&&void 0===t?t=i:"p"===i[0]&&void 0===n&&(n=i))}return void 0!==t&&void 0!==n?{id:t[1],relays:[t[2],n[2]].filter(e=>void 0!==e),author:n[1]}:void 0}__export(nip25_exports,{finishReactionEvent:()=>finishReactionEvent,getReactedEventPointer:()=>getReactedEventPointer});var nip26_exports={};function createDelegation(e,t){let n=[];(t.kind||-1)>=0&&n.push(`kind=${t.kind}`),t.until&&n.push(`created_at<${t.until}`),t.since&&n.push(`created_at>${t.since}`);let r=n.join("&");if(""===r)throw new Error("refusing to create a delegation without any conditions");let i=sha256$3(utf8Encoder.encode(`nostr:delegation:${t.pubkey}:${r}`)),s=bytesToHex$3(schnorr.sign(i,e));return{from:getPublicKey(e),to:t.pubkey,cond:r,sig:s}}function getDelegator(e){let t=e.tags.find(e=>"delegation"===e[0]&&e.length>=4);if(!t)return null;let n=t[1],r=t[2],i=t[3],s=r.split("&");for(let t=0;t<s.length;t++){let[n,r,i]=s[t].split(/\b/);if(("kind"!==n||"="!==r||e.kind!==parseInt(i))&&!("created_at"===n&&"<"===r&&e.created_at<parseInt(i)||"created_at"===n&&">"===r&&e.created_at>parseInt(i)))return null}let o=sha256$3(utf8Encoder.encode(`nostr:delegation:${e.pubkey}:${r}`));return schnorr.verify(i,o,n)?n:null}__export(nip26_exports,{createDelegation:()=>createDelegation,getDelegator:()=>getDelegator});var nip27_exports={};__export(nip27_exports,{matchAll:()=>matchAll,regex:()=>regex,replaceAll:()=>replaceAll});var regex=()=>new RegExp(`\\b${NOSTR_URI_REGEX.source}\\b`,"g");function*matchAll(e){const t=e.matchAll(regex());for(const e of t)try{const[t,n]=e;yield{uri:t,value:n,decoded:decode(n),start:e.index,end:e.index+t.length}}catch(e){}}function replaceAll(e,t){return e.replaceAll(regex(),(e,n)=>t({uri:e,value:n,decoded:decode(n)}))}var nip28_exports={};__export(nip28_exports,{channelCreateEvent:()=>channelCreateEvent,channelHideMessageEvent:()=>channelHideMessageEvent,channelMessageEvent:()=>channelMessageEvent,channelMetadataEvent:()=>channelMetadataEvent,channelMuteUserEvent:()=>channelMuteUserEvent});var channelCreateEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:40,tags:[...e.tags??[]],content:n,created_at:e.created_at},t)},channelMetadataEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:41,tags:[["e",e.channel_create_event_id],...e.tags??[]],content:n,created_at:e.created_at},t)},channelMessageEvent=(e,t)=>{const n=[["e",e.channel_create_event_id,e.relay_url,"root"]];return e.reply_to_channel_message_event_id&&n.push(["e",e.reply_to_channel_message_event_id,e.relay_url,"reply"]),finishEvent({kind:42,tags:[...n,...e.tags??[]],content:e.content,created_at:e.created_at},t)},channelHideMessageEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:43,tags:[["e",e.channel_message_event_id],...e.tags??[]],content:n,created_at:e.created_at},t)},channelMuteUserEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:44,tags:[["p",e.pubkey_to_mute],...e.tags??[]],content:n,created_at:e.created_at},t)},nip39_exports={},_fetch2;__export(nip39_exports,{useFetchImplementation:()=>useFetchImplementation2,validateGithub:()=>validateGithub});try{_fetch2=fetch}catch{}function useFetchImplementation2(e){_fetch2=e}async function validateGithub(e,t,n){try{return await(await _fetch2(`https://gist.github.com/${t}/${n}/raw`)).text()===`Verifying that I control the following Nostr public key: ${e}`}catch(e){return!1}}var nip42_exports={};__export(nip42_exports,{authenticate:()=>authenticate});var authenticate=async({challenge:e,relay:t,sign:n})=>{const r={kind:22242,created_at:Math.floor(Date.now()/1e3),tags:[["relay",t.url],["challenge",e]],content:""};return t.auth(await n(r))},nip44_exports={};__export(nip44_exports,{decrypt:()=>decrypt2,encrypt:()=>encrypt2,utils:()=>utils});var utils={v2:{maxPlaintextSize:65408,minCiphertextSize:100,maxCiphertextSize:102400,getConversationKey:(e,t)=>secp256k1$1.getSharedSecret(e,"02"+t).subarray(1,33),getMessageKeys(e,t){const n=hkdf(sha256$3,e,t,"nip44-v2",76);return{encryption:n.subarray(0,32),nonce:n.subarray(32,44),auth:n.subarray(44,76)}},calcPadding(e){if(!Number.isSafeInteger(e)||e<0)throw new Error("expected positive integer");if(e<=32)return 32;const t=1<<Math.floor(Math.log2(e-1))+1,n=t<=256?32:t/8;return n*(Math.floor((e-1)/n)+1)},pad(e){const t=utf8Encoder.encode(e),n=t.length;if(n<1||n>=utils.v2.maxPlaintextSize)throw new Error("invalid plaintext length: must be between 1b and 64KB");const r=utils.v2.calcPadding(n),i=new Uint8Array(r-n),s=new Uint8Array(2);return new DataView(s.buffer).setUint16(0,n),concatBytes$4(s,t,i)},unpad(e){const t=new DataView(e.buffer).getUint16(0),n=e.subarray(2,2+t);if(0===t||n.length!==t||e.length!==2+utils.v2.calcPadding(t))throw new Error("invalid padding");return utf8Decoder.decode(n)}}};function encrypt2(e,t,n={}){const r=n.version??2;if(2!==r)throw new Error("unknown encryption version "+r);const i=n.salt??randomBytes$2(32);ensureBytes(i,32);const s=utils.v2.getMessageKeys(e,i),o=utils.v2.pad(t),a=chacha20(s.encryption,s.nonce,o),c=hmac$3(sha256$3,s.auth,a);return base64.encode(concatBytes$4(new Uint8Array([r]),i,a,c))}function decrypt2(e,t){const n=utils.v2;ensureBytes(e,32);const r=t.length;if(r<n.minCiphertextSize||r>=n.maxCiphertextSize)throw new Error("invalid ciphertext length: "+r);if("#"===t[0])throw new Error("unknown encryption version");let i;try{i=base64.decode(t)}catch(e){throw new Error("invalid base64: "+e.message)}const s=i.subarray(0,1)[0];if(2!==s)throw new Error("unknown encryption version "+s);const o=i.subarray(1,33),a=i.subarray(33,-32),c=i.subarray(-32),l=n.getMessageKeys(e,o);if(!equalBytes(hmac$3(sha256$3,l.auth,a),c))throw new Error("invalid MAC");const h=chacha20(l.encryption,l.nonce,a);return n.unpad(h)}var nip47_exports={};function parseConnectionString(e){const{pathname:t,searchParams:n}=new URL(e),r=t,i=n.get("relay"),s=n.get("secret");if(!r||!i||!s)throw new Error("invalid connection string");return{pubkey:r,relay:i,secret:s}}async function makeNwcRequestEvent({pubkey:e,secret:t,invoice:n}){const r={method:"pay_invoice",params:{invoice:n}},i=await encrypt(t,e,JSON.stringify(r));return finishEvent({kind:23194,created_at:Math.round(Date.now()/1e3),content:i,tags:[["p",e]]},t)}__export(nip47_exports,{makeNwcRequestEvent:()=>makeNwcRequestEvent,parseConnectionString:()=>parseConnectionString});var nip57_exports={},_fetch3;__export(nip57_exports,{getZapEndpoint:()=>getZapEndpoint,makeZapReceipt:()=>makeZapReceipt,makeZapRequest:()=>makeZapRequest,useFetchImplementation:()=>useFetchImplementation3,validateZapRequest:()=>validateZapRequest});try{_fetch3=fetch}catch{}function useFetchImplementation3(e){_fetch3=e}async function getZapEndpoint(e){try{let t="",{lud06:n,lud16:r}=JSON.parse(e.content);if(n){let{words:e}=bech32.decode(n,1e3),r=bech32.fromWords(e);t=utf8Decoder.decode(r)}else{if(!r)return null;{let[e,n]=r.split("@");t=`https://${n}/.well-known/lnurlp/${e}`}}let i=await _fetch3(t),s=await i.json();if(s.allowsNostr&&s.nostrPubkey)return s.callback}catch(e){}return null}function makeZapRequest({profile:e,event:t,amount:n,relays:r,comment:i=""}){if(!n)throw new Error("amount not given");if(!e)throw new Error("profile not given");let s={kind:9734,created_at:Math.round(Date.now()/1e3),content:i,tags:[["p",e],["amount",n.toString()],["relays",...r]]};return t&&s.tags.push(["e",t]),s}function validateZapRequest(e){let t;try{t=JSON.parse(e)}catch(e){return"Invalid zap request JSON."}if(!validateEvent(t))return"Zap request is not a valid Nostr event.";if(!verifySignature(t))return"Invalid signature on zap request.";let n=t.tags.find(([e,t])=>"p"===e&&t);if(!n)return"Zap request doesn't have a 'p' tag.";if(!n[1].match(/^[a-f0-9]{64}$/))return"Zap request 'p' tag is not valid hex.";let r=t.tags.find(([e,t])=>"e"===e&&t);return r&&!r[1].match(/^[a-f0-9]{64}$/)?"Zap request 'e' tag is not valid hex.":t.tags.find(([e,t])=>"relays"===e&&t)?null:"Zap request doesn't have a 'relays' tag."}function makeZapReceipt({zapRequest:e,preimage:t,bolt11:n,paidAt:r}){let i=JSON.parse(e).tags.filter(([e])=>"e"===e||"p"===e||"a"===e),s={kind:9735,created_at:Math.round(r.getTime()/1e3),content:"",tags:[...i,["bolt11",n],["description",e]]};return t&&s.tags.push(["preimage",t]),s}var nip98_exports={};__export(nip98_exports,{getToken:()=>getToken,unpackEventFromToken:()=>unpackEventFromToken,validateEvent:()=>validateEvent2,validateToken:()=>validateToken});var _authorizationScheme="Nostr ";async function getToken(e,t,n,r=!1){if(!e||!t)throw new Error("Missing loginUrl or httpMethod");const i=getBlankEvent(27235);i.tags=[["u",e],["method",t]],i.created_at=Math.round((new Date).getTime()/1e3);const s=await n(i);return(r?_authorizationScheme:"")+base64.encode(utf8Encoder.encode(JSON.stringify(s)))}async function validateToken(e,t,n){const r=await unpackEventFromToken(e).catch(e=>{throw e});return await validateEvent2(r,t,n).catch(e=>{throw e})}async function unpackEventFromToken(e){if(!e)throw new Error("Missing token");e=e.replace(_authorizationScheme,"");const t=utf8Decoder.decode(base64.decode(e));if(!t||0===t.length||!t.startsWith("{"))throw new Error("Invalid token");return JSON.parse(t)}async function validateEvent2(e,t,n){if(!e)throw new Error("Invalid nostr event");if(!verifySignature(e))throw new Error("Invalid nostr event, signature invalid");if(27235!==e.kind)throw new Error("Invalid nostr event, kind invalid");if(!e.created_at)throw new Error("Invalid nostr event, created_at invalid");if(Math.round((new Date).getTime()/1e3)-e.created_at>60)throw new Error("Invalid nostr event, expired");const r=e.tags.find(e=>"u"===e[0]);if(1!==r?.length&&r?.[1]!==t)throw new Error("Invalid nostr event, url tag invalid");const i=e.tags.find(e=>"method"===e[0]);if(1!==i?.length&&i?.[1].toLowerCase()!==n.toLowerCase())throw new Error("Invalid nostr event, method tag invalid");return!0}const LOCAL_STORE_KEY="__nostrlogin_nip46",LOGGED_IN_ACCOUNTS="__nostrlogin_accounts",RECENT_ACCOUNTS="__nostrlogin_recent",OUTBOX_RELAYS$1=["wss://purplepag.es","wss://relay.nos.social","wss://user.kindpag.es","wss://relay.damus.io","wss://nos.lol"],DEFAULT_SIGNUP_RELAYS=["wss://relay.damus.io/","wss://nos.lol/","wss://relay.primal.net/"],localStorageSetItem=(e,t)=>{localStorage.setItem(e,t)},localStorageGetItem=e=>{const t=window.localStorage.getItem(e);if(t)try{return JSON.parse(t)}catch{}return null},localStorageRemoveItem=e=>{localStorage.removeItem(e)},fetchProfile=async(e,t)=>{const n=new NDKUser({pubkey:e.pubkey});return n.ndk=t,await n.fetchProfile()},prepareSignupRelays=e=>{const t=(e||"").split(",").map(e=>e.trim()).filter(e=>e.startsWith("ws"));return t.length||t.push(...DEFAULT_SIGNUP_RELAYS),t},createProfile=async(e,t,n,r,i)=>{const s={name:e.name},o=new NDKEvent(t,{kind:0,created_at:Math.floor(Date.now()/1e3),pubkey:e.pubkey,content:JSON.stringify(s),tags:[]});window.location.hostname&&o.tags.push(["client",window.location.hostname]);const a=new NDKEvent(t,{kind:10002,created_at:Math.floor(Date.now()/1e3),pubkey:e.pubkey,content:"",tags:[]}),c=prepareSignupRelays(r);for(const e of c)a.tags.push(["r",e]);await o.sign(n),console.log("signed profile",o),await a.sign(n),console.log("signed relays",a);const l=i&&i.length?i:OUTBOX_RELAYS$1;await o.publish(NDKRelaySet.fromRelayUrls(l,t)),console.log("published profile",o),await a.publish(NDKRelaySet.fromRelayUrls(l,t)),console.log("published relays",a)},bunkerUrlToInfo=(e,t="")=>{const n=new URL(e);return{pubkey:"",signerPubkey:n.hostname||n.pathname.split("//")[1],sk:t||generatePrivateKey(),relays:n.searchParams.getAll("relay"),token:n.searchParams.get("secret")||"",authMethod:"connect"}},isBunkerUrl=e=>e.startsWith("bunker://"),getBunkerUrl=async(e,t)=>{if(!e)return"";if(isBunkerUrl(e))return e;if(e.includes("@")){const[n,r]=e.toLocaleLowerCase().split("@"),i=t.devOverrideBunkerOrigin||`https://${r}`,s=`${i}/.well-known/nostr.json?name=_`,o=`${i}/.well-known/nostr.json?name=${n}`,a=await fetch(s),c=await a.json(),l=c.names._,h=c.nip46[l],d=await fetch(o),u=(await d.json()).names[n];if(!h.length)throw new Error("Bunker relay not provided");return`bunker://${u}?relay=${h[0]}`}throw new Error("Invalid user name or bunker url")},checkNip05=async e=>{let t=!1,n="",r="";return await(async()=>{if(!e||!e.includes("@"))return;const[i,s]=e.toLocaleLowerCase().split("@");if(!i)return;if(!new RegExp(/^[\w-.]+@([\w-]+\.)+[\w-]{2,8}$/g).test(e))return void(n="Invalid name");if(!s)return void(n="Select service");const o=`https://${s}/.well-known/nostr.json?name=${i.toLowerCase()}`;try{const e=await fetch(o),t=await e.json();if(t.names[i])return void(r=t.names[i])}catch{}t=!0})(),{available:t,taken:""!=r,error:n,pubkey:r}},upgradeInfo=e=>{"typeAuthMethod"in e&&delete e.typeAuthMethod,e.authMethod||("extension"in e&&e.extension?e.authMethod="extension":"readOnly"in e&&e.readOnly?e.authMethod="readOnly":e.authMethod="connect"),e.nip05&&isBunkerUrl(e.nip05)&&(e.bunkerUrl=e.nip05,e.nip05=""),"connect"!==e.authMethod||e.signerPubkey||(e.signerPubkey=e.pubkey)},localStorageAddAccount=e=>{localStorageSetItem(LOCAL_STORE_KEY,JSON.stringify(e));const t=localStorageGetItem(LOGGED_IN_ACCOUNTS)||[],n=localStorageGetItem(RECENT_ACCOUNTS)||[];t.forEach(e=>upgradeInfo(e)),n.forEach(e=>upgradeInfo(e));const r=t,i=t.findIndex(t=>t.pubkey===e.pubkey&&t.authMethod===e.authMethod);-1!==i?r[i]=e:r.push(e);const s=n.filter(t=>t.pubkey!==e.pubkey||t.authMethod!==e.authMethod);localStorageSetItem(RECENT_ACCOUNTS,JSON.stringify(s)),localStorageSetItem(LOGGED_IN_ACCOUNTS,JSON.stringify(r))},localStorageRemoveCurrentAccount=()=>{const e=localStorageGetItem(LOCAL_STORE_KEY);if(!e)return;upgradeInfo(e);const t={...e};delete t.sk,delete t.otpData;const n=localStorageGetItem(LOGGED_IN_ACCOUNTS)||[],r=localStorageGetItem(RECENT_ACCOUNTS)||[];n.forEach(e=>upgradeInfo(e)),r.forEach(e=>upgradeInfo(e));const i=r;if("connect"===t.authMethod&&t.bunkerUrl&&t.bunkerUrl.includes("secret="))console.log("nostr login bunker conn with a secret not saved to recent");else if("local"===t.authMethod)console.log("nostr login temporary local keys not save to recent");else{const e=r.findIndex(e=>e.pubkey===t.pubkey&&e.authMethod===t.authMethod);-1!==e?i[e]=t:i.push(t)}const s=n.filter(t=>t.pubkey!==e.pubkey||t.authMethod!==e.authMethod);localStorageSetItem(RECENT_ACCOUNTS,JSON.stringify(i)),localStorageSetItem(LOGGED_IN_ACCOUNTS,JSON.stringify(s)),localStorageRemoveItem(LOCAL_STORE_KEY)},localStorageRemoveRecent=e=>{const t=localStorageGetItem(RECENT_ACCOUNTS)||[];t.forEach(e=>upgradeInfo(e));const n=t.filter(t=>t.pubkey!==e.pubkey||t.authMethod!==e.authMethod);localStorageSetItem(RECENT_ACCOUNTS,JSON.stringify(n))},localStorageGetRecents=()=>{const e=localStorageGetItem(RECENT_ACCOUNTS)||[];return e.forEach(e=>upgradeInfo(e)),e},localStorageGetAccounts=()=>{const e=localStorageGetItem(LOGGED_IN_ACCOUNTS)||[];return e.forEach(e=>upgradeInfo(e)),e},localStorageGetCurrent=()=>{const e=localStorageGetItem(LOCAL_STORE_KEY);return e&&upgradeInfo(e),e},getDarkMode=e=>{const t=localStorage.getItem("nl-dark-mode");return t?Boolean(JSON.parse(t)):void 0!==e.darkMode?e.darkMode:!(!window.matchMedia||!window.matchMedia("(prefers-color-scheme: dark)").matches)},getIcon=async()=>document.location.origin+"/favicon.ico";class NostrRpc extends NDKNostrRpc{_ndk;_signer;requests=new Set;sub;_useNip44=!1;constructor(e,t){super(e,t,e.debug.extend("nip46:signer:rpc")),this._ndk=e,this._signer=t}async subscribe(e){return e.kinds=e.kinds?.filter(e=>24133===e),this.sub=await super.subscribe(e),this.sub}stop(){this.sub&&(this.sub.stop(),this.sub=void 0)}setUseNip44(e){this._useNip44=e}isNip04(e){const t=e.length;return!(t<28)&&("?"===e[t-28]&&"i"===e[t-27]&&"v"===e[t-26]&&"="===e[t-25])}async parseEvent(e){const t=this._ndk.getUser({pubkey:e.pubkey});t.ndk=this._ndk;const n=this.isNip04(e.content)?await this._signer.decrypt(t,e.content,"nip04"):await this._signer.decrypt(t,e.content,"nip44"),r=JSON.parse(n),{id:i,method:s,params:o,result:a,error:c}=r;return s?{id:i,pubkey:e.pubkey,method:s,params:o,event:e}:{id:i,result:a,error:c,event:e}}async parseNostrConnectReply(e,t){const n=new NDKEvent(this._ndk,e),r=await this.parseEvent(n);if(console.log("nostr connect parsedEvent",r),r.method)throw new Error("Bad nostr connect reply");{const e=r;if(e.result!==t)throw new Error(e.error);return n.pubkey}}async listen(e){const t=this._signer.pubkey;console.log("nostr-login listening for conn to",t);const n=await this.subscribe({kinds:[24133],"#p":[t]});return new Promise((t,r)=>{n.on("event",async n=>{try{const i=await this.parseEvent(n);if(!i.method){const s=i;if("auth_url"===s.result)return;"ack"===s.result||s.result===e?t(n.pubkey):r(s.error)}}catch(e){console.log("error parsing event",e,n.rawEvent())}this.stop()})})}async connect(e,t,n){return new Promise((r,i)=>{const s=[e,t||"",n||""];this.sendRequest(e,"connect",s,24133,e=>{"ack"===e.result?r():i(e.error)})})}getId(){return Math.random().toString(36).substring(7)}async sendRequest(e,t,n=[],r=24133,i){const s=this.getId();this.setResponseHandler(s,i);const o=await this.createRequestEvent(s,e,t,n,r);console.log("sendRequest",{event:o,method:t,remotePubkey:e,params:n}),await o.publish()}setResponseHandler(e,t){let n=!1;const r=Date.now();return new Promise(()=>{const i=s=>{"auth_url"===s.result?(this.once(`response-${e}`,i),n||(n=!0,this.emit("authUrl",s.error))):t&&this.requests.has(e)&&(this.requests.delete(e),console.log("nostr-login processed nip46 request in",Date.now()-r,"ms"),t(s))};this.once(`response-${e}`,i)})}async createRequestEvent(e,t,n,r=[],i=24133){this.requests.add(e);const s=await this._signer.user(),o=this._ndk.getUser({pubkey:t}),a={id:e,method:n,params:r},c=new NDKEvent(this._ndk,{kind:i,content:JSON.stringify(a),tags:[["p",t]],pubkey:s.pubkey}),l=this._useNip44&&"create_account"!==n;return c.content=l?await this._signer.encrypt(o,c.content,"nip44"):await this._signer.encrypt(o,c.content,"nip04"),await c.sign(this._signer),c}}class IframeNostrRpc extends NostrRpc{peerOrigin;iframePort;iframeRequests=new Map;constructor(e,t,n){super(e,t),this._ndk=e,this.peerOrigin=n}async subscribe(e){return this.peerOrigin?new NDKSubscription(this._ndk,{},{closeOnEose:!0,cacheUsage:NDKSubscriptionCacheUsage.ONLY_CACHE}):super.subscribe(e)}setWorkerIframePort(e){if(!this.peerOrigin)throw new Error("Unexpected iframe port");this.iframePort=e,setInterval(()=>{console.log("iframe-nip46 ping"),this.iframePort.postMessage("ping")},5e3),e.onmessage=async e=>{if(console.log("iframe-nip46 got response",e.data),"string"==typeof e.data&&e.data.startsWith("errorNoKey")){const t=e.data.split(":")[1],{id:n="",pubkey:r=""}=this.iframeRequests.get(t)||{};return void(n&&r&&this.requests.has(n)&&this.emit(`iframeRestart-${r}`))}try{const t=e.data;if(!validateEvent(t))throw new Error("Invalid event from iframe");if(!verifySignature(t))throw new Error("Invalid event signature from iframe");const n=new NDKEvent(this._ndk,t),r=await this.parseEvent(n);r.method||(console.log("parsed response",r),this.emit(`response-${r.id}`,r))}catch(t){console.log("error parsing event",t,e.data)}}}async sendRequest(e,t,n=[],r=24133,i){const s=this.getId(),o=await this.createRequestEvent(s,e,t,n,r);this.setResponseHandler(s,i),this.iframePort?(this.iframeRequests.set(o.id,{id:s,pubkey:e}),console.log("iframe-nip46 sending request to",this.peerOrigin,o.rawEvent()),this.iframePort.postMessage(o.rawEvent())):await o.publish()}}class ReadyListener{origin;messages;promise;constructor(e,t){this.origin=t,this.messages=e,this.promise=new Promise(e=>{console.log(new Date,"started listener for",this.messages);const n=async r=>{const i=new URL(t).hostname,s=new URL(r.origin).hostname;(s===i||s.endsWith("."+i))&&Array.isArray(r.data)&&r.data.length&&this.messages.includes(r.data[0])&&(console.log(new Date,"got ready message from",r.origin,r.data),window.removeEventListener("message",n),e(r.data))};window.addEventListener("message",n)})}async wait(){console.log(new Date,"waiting for",this.messages);const e=await this.promise;return console.log(new Date,"finished waiting for",this.messages,e),e}}class Nip46Signer extends NDKNip46Signer{_rpc;_remotePubkey="";constructor(e,t,n,r){super(e,n,t),this._remotePubkey=n,this._rpc=new IframeNostrRpc(e,t,r),this._rpc.setUseNip44(!0),this._rpc.on("authUrl",e=>{this.emit("authUrl",e)}),this.rpc=this._rpc}get remotePubkey(){return this._remotePubkey}set remotePubkey(e){this._remotePubkey=e}async setSignerPubkey(e,t=!1){console.log("setSignerPubkey",e),this.remotePubkey=e,this._rpc.on(`iframeRestart-${e}`,()=>{this.emit("iframeRestart")}),await this.initUserPubkey(t?e:"")}async initUserPubkey(e){if(this.userPubkey)throw new Error("Already called initUserPubkey");this.userPubkey=e||await new Promise((e,t)=>{if(!this.remotePubkey)throw new Error("Signer pubkey not set");console.log("get_public_key",this.remotePubkey),this._rpc.sendRequest(this.remotePubkey,"get_public_key",[],24133,t=>{e(t.result)})})}async listen(e){const t=await this.rpc.listen(e);await this.setSignerPubkey(t)}async connect(e,t){if(!this.remotePubkey)throw new Error("No signer pubkey");await this._rpc.connect(this.remotePubkey,e,t),await this.setSignerPubkey(this.remotePubkey)}async setListenReply(e,t){const n=await this._rpc.parseNostrConnectReply(e,t);await this.setSignerPubkey(n,!0)}async createAccount2({bunkerPubkey:e,name:t,domain:n,perms:r=""}){const i=[t,n,"",r],s=await new Promise(t=>{this.rpc.sendRequest(e,"create_account",i,void 0,t)});if(console.log("create_account pubkey",s),"error"===s.result)throw new Error(s.error);return s.result}}class BannerManager extends lib$1.EventEmitter{banner=null;iframeReady;params;constructor(e){super(),this.params=e}onAuthUrl(e,t){this.banner&&(this.banner.notify=e?{mode:t?"iframeAuthUrl":"authUrl",url:e}:{mode:""})}onIframeRestart(e){this.banner&&(this.iframeReady=new ReadyListener(["rebinderDone","rebinderError"],new URL(e).origin),this.banner.notify={mode:"rebind",url:e})}onUserInfo(e){this.banner&&(this.banner.userInfo=e)}onCallTimeout(){this.banner&&(this.banner.notify={mode:"timeout"})}onCallStart(){this.banner&&(this.banner.isLoading=!0)}async onCallEnd(){this.banner&&(this.iframeReady&&(await this.iframeReady.wait(),this.iframeReady=void 0),this.banner.isLoading=!1,this.banner.notify={mode:""})}onUpdateAccounts(e){this.banner&&(this.banner.accounts=e)}onDarkMode(e){this.banner&&(this.banner.darkMode=e)}launchAuthBanner(e){this.banner=document.createElement("nl-banner"),this.banner.setAttribute("dark-mode",String(getDarkMode(e))),e.theme&&this.banner.setAttribute("theme",e.theme),e.noBanner&&this.banner.setAttribute("hidden-mode","true"),this.banner.addEventListener("handleLoginBanner",e=>{this.emit("launch",e.detail)}),this.banner.addEventListener("handleConfirmLogout",()=>{this.emit("onConfirmLogout")}),this.banner.addEventListener("handleLogoutBanner",async()=>{this.emit("logout")}),this.banner.addEventListener("handleImportModal",e=>{this.emit("import")}),this.banner.addEventListener("handleNotifyConfirmBanner",e=>{this.emit("onAuthUrlClick",e.detail)}),this.banner.addEventListener("handleNotifyConfirmBannerIframe",e=>{this.emit("onIframeAuthUrlClick",e.detail)}),this.banner.addEventListener("handleSwitchAccount",e=>{this.emit("onSwitchAccount",e.detail)}),this.banner.addEventListener("handleOpenWelcomeModal",()=>{this.emit("launch"),this.banner&&(this.banner.isOpen=!1)}),document.body.appendChild(this.banner)}}const decoder=new TextDecoder,u={minPlaintextSize:1,maxPlaintextSize:65535,utf8Encode:utf8ToBytes$6,utf8Decode:e=>decoder.decode(e),getConversationKey(e,t){const n=secp256k1$1.getSharedSecret(e,"02"+t).subarray(1,33);return extract(sha256$3,n,"nip44-v2")},getMessageKeys(e,t){const n=expand(sha256$3,e,t,76);return{chacha_key:n.subarray(0,32),chacha_nonce:n.subarray(32,44),hmac_key:n.subarray(44,76)}},calcPaddedLen(e){if(!Number.isSafeInteger(e)||e<1)throw new Error("expected positive integer");if(e<=32)return 32;const t=1<<Math.floor(Math.log2(e-1))+1,n=t<=256?32:t/8;return n*(Math.floor((e-1)/n)+1)},writeU16BE(e){if(!Number.isSafeInteger(e)||e<u.minPlaintextSize||e>u.maxPlaintextSize)throw new Error("invalid plaintext size: must be between 1 and 65535 bytes");const t=new Uint8Array(2);return new DataView(t.buffer).setUint16(0,e,!1),t},pad(e){const t=u.utf8Encode(e),n=t.length;return concatBytes$4(u.writeU16BE(n),t,new Uint8Array(u.calcPaddedLen(n)-n))},unpad(e){const t=new DataView(e.buffer).getUint16(0),n=e.subarray(2,2+t);if(t<u.minPlaintextSize||t>u.maxPlaintextSize||n.length!==t||e.length!==2+u.calcPaddedLen(t))throw new Error("invalid padding");return u.utf8Decode(n)},hmacAad(e,t,n){if(32!==n.length)throw new Error("AAD associated data must be 32 bytes");const r=concatBytes$4(n,t);return hmac$3(sha256$3,e,r)},decodePayload(e){if("string"!=typeof e)throw new Error("payload must be a valid string");const t=e.length;if(t<132||t>87472)throw new Error("invalid payload length: "+t);if("#"===e[0])throw new Error("unknown encryption version");let n;try{n=base64.decode(e)}catch(e){throw new Error("invalid base64: "+e.message)}const r=n.length;if(r<99||r>65603)throw new Error("invalid data length: "+r);const i=n[0];if(2!==i)throw new Error("unknown encryption version "+i);return{nonce:n.subarray(1,33),ciphertext:n.subarray(33,-32),mac:n.subarray(-32)}}};function encryptNip44(e,t,n=randomBytes$2(32)){const{chacha_key:r,chacha_nonce:i,hmac_key:s}=u.getMessageKeys(t,n),o=u.pad(e),a=chacha20(r,i,o),c=u.hmacAad(s,a,n);return base64.encode(concatBytes$4(new Uint8Array([2]),n,a,c))}function decryptNip44(e,t){const{nonce:n,ciphertext:r,mac:i}=u.decodePayload(e),{chacha_key:s,chacha_nonce:o,hmac_key:a}=u.getMessageKeys(t,n);if(!equalBytes(u.hmacAad(a,r,n),i))throw new Error("invalid MAC");const c=chacha20(s,o,r);return u.unpad(c)}class Nip44{cache=new Map;createKey(e,t){return u.getConversationKey(e,t)}getKey(e,t,n){const r=getPublicKey(e)+t;let i=this.cache.get(r);if(i)return i;const s=this.createKey(e,t);return this.cache.set(r,s),s}encrypt(e,t,n){return encryptNip44(n,this.getKey(e,t))}decrypt(e,t,n){return decryptNip44(n,this.getKey(e,t))}}const OUTBOX_RELAYS=["wss://user.kindpag.es","wss://purplepag.es","wss://relay.nos.social"],DEFAULT_NOSTRCONNECT_RELAYS=["wss://relay.nsec.app/","wss://ephemeral.snowflare.cc/"],CONNECT_TIMEOUT=5e3,NOSTRCONNECT_APPS=[{name:"Nsec.app",domain:"nsec.app",canImport:!0,img:"https://nsec.app/assets/favicon.ico",link:"https://use.nsec.app/<nostrconnect>",relays:DEFAULT_NOSTRCONNECT_RELAYS},{name:"Amber",img:"https://raw.githubusercontent.com/greenart7c3/Amber/refs/heads/master/assets/android-icon.svg",link:"<nostrconnect>",relays:DEFAULT_NOSTRCONNECT_RELAYS},{name:"Other key stores",img:"",link:"<nostrconnect>",relays:DEFAULT_NOSTRCONNECT_RELAYS}];class AuthNostrService extends lib$1.EventEmitter{ndk;profileNdk;signer=null;localSigner=null;params;signerPromise;signerErrCallback;readyPromise;readyCallback;nip44Codec=new Nip44;nostrConnectKey="";nostrConnectSecret="";iframe;starterReady;nip04;nip44;constructor(e){super(),this.params=e,this.ndk=new NDK({enableOutboxModel:!1}),this.profileNdk=new NDK({enableOutboxModel:!0,explicitRelayUrls:OUTBOX_RELAYS}),this.profileNdk.connect(CONNECT_TIMEOUT),this.nip04={encrypt:this.encrypt04.bind(this),decrypt:this.decrypt04.bind(this)},this.nip44={encrypt:this.encrypt44.bind(this),decrypt:this.decrypt44.bind(this)}}isIframe(){return!!this.iframe}async waitReady(){if(this.signerPromise)try{await this.signerPromise}catch{}if(this.readyPromise)try{await this.readyPromise}catch{}}cancelNostrConnect(){this.releaseSigner(),this.resetAuth()}async nostrConnect(e,{domain:t="",link:n="",iframeUrl:r="",importConnect:i=!1}={}){e=e&&e.length>0?e:DEFAULT_NOSTRCONNECT_RELAYS;const s={authMethod:"connect",pubkey:"",signerPubkey:"",sk:this.nostrConnectKey,domain:t,relays:e,iframeUrl:r};if(console.log("nostrconnect info",s,n),n&&!r&&window.open(n,"_blank","width=400,height=700"),await this.initSigner(s,{listen:!0}),!s.pubkey||!s.signerPubkey)throw new Error("Bad remote pubkey");return s.bunkerUrl=`bunker://${s.signerPubkey}?${e.map((e,t)=>`${0!==t?"&":""}relay=${e}`)}`,i||this.onAuth("login",s),s}async createNostrConnect(e){this.nostrConnectKey=generatePrivateKey(),this.nostrConnectSecret=Math.random().toString(36).substring(7);const t=getPublicKey(this.nostrConnectKey),n=encodeURIComponent(document.location.host),r=encodeURIComponent(document.location.origin);return`nostrconnect://${t}?image=${encodeURIComponent(await getIcon())}&url=${r}&name=${n}&perms=${encodeURIComponent(this.params.optionsModal.perms||"")}&secret=${this.nostrConnectSecret}${(e||[]).length>0?(e||[]).map((e,t)=>`&relay=${e}`):""}`}async getNostrConnectServices(){const e=await this.createNostrConnect(DEFAULT_NOSTRCONNECT_RELAYS),t=NOSTRCONNECT_APPS.map(e=>({...e}));for(const n of t){let t=[...DEFAULT_NOSTRCONNECT_RELAYS];if(n.link.startsWith("https://")){const e=n.domain||new URL(n.link).hostname;try{const r=await(await fetch(`https://${e}/.well-known/nostr.json`)).json(),i=r.names._,s=r.nip46?.[i];Array.isArray(s)&&s.length>0&&(t=s),n.iframeUrl=r.nip46?.iframe_url||""}catch(e){console.log("Bad app info",e,n)}}const r=e.split("&relay=")[0]+t.map(e=>`&relay=${encodeURIComponent(e)}`).join("");n.link=n.iframeUrl?r:n.link.replace("<nostrconnect>",r)}return[e,t]}async localSignup(e,t){const n=!t,r={pubkey:getPublicKey(t=t||generatePrivateKey()),sk:t,name:e,authMethod:"local"};console.log(`localSignup name: ${e}`),await this.setLocal(r,n)}async setLocal(e,t){this.releaseSigner(),this.localSigner=new NDKPrivateKeySigner(e.sk),t&&await createProfile(e,this.profileNdk,this.localSigner,this.params.optionsModal.signupRelays,this.params.optionsModal.outboxRelays),this.onAuth(t?"signup":"login",e)}prepareImportUrl(e){if("otp"===this.params.userInfo?.authMethod)return e+"&import=true";if(!this.localSigner||"local"!==this.params.userInfo?.authMethod)throw new Error("Most be local keys");return e+"#import="+nip19_exports.nsecEncode(this.localSigner.privateKey)}async importAndConnect(e){const{relays:t,domain:n,link:r,iframeUrl:i}=e;if(!n)throw new Error("Domain required");const s=await this.nostrConnect(t,{domain:n,link:r,importConnect:!0,iframeUrl:i});await this.logout(!0),this.localSigner=null,this.onAuth("login",s)}setReadOnly(e){const t={pubkey:e,authMethod:"readOnly"};this.onAuth("login",t)}setExtension(e){const t={pubkey:e,authMethod:"extension"};this.onAuth("login",t)}setOTP(e,t){const n={pubkey:e,authMethod:"otp",otpData:t};this.onAuth("login",n)}async setConnect(e){this.releaseSigner(),await this.startAuth(),await this.initSigner(e),this.onAuth("login",e),await this.endAuth()}async createAccount(e){const[t,n]=e.split("@"),r=await getBunkerUrl(`_@${n}`,this.params.optionsModal);console.log("create account bunker's url",r);const i=bunkerUrlToInfo(r);if(!i.signerPubkey)throw new Error("Bad bunker url");const s=Boolean(this.params.userInfo);await this.initSigner(i,{eventToAddAccount:s});return{bunkerUrl:`bunker://${await this.signer.createAccount2({bunkerPubkey:i.signerPubkey,name:t,domain:n,perms:this.params.optionsModal.perms})}?`+(i.relays??[]).map(e=>`relay=${encodeURIComponent(e)}`).join("&"),sk:i.sk}}releaseSigner(){this.signer=null,this.signerErrCallback?.("cancelled"),this.localSigner=null;for(const e of this.ndk.pool.relays.keys())this.ndk.pool.removeRelay(e)}async logout(e=!1){e||this.releaseSigner(),localStorageRemoveCurrentAccount(),this.onAuth("logout"),this.emit("updateAccounts")}setUserInfo(e){this.params.userInfo=e,this.emit("onUserInfo",e),e&&(localStorageAddAccount(e),this.emit("updateAccounts"))}exportKeys(){return this.params.userInfo?"local"!==this.params.userInfo.authMethod?"":nip19_exports.nsecEncode(this.params.userInfo.sk):""}onAuth(e,t=null){if("logout"!==e&&!t)throw new Error("No user info in onAuth");if(t&&this.params.userInfo&&(t.pubkey!==this.params.userInfo.pubkey||t.authMethod!==this.params.userInfo.authMethod)){const e=new CustomEvent("nlAuth",{detail:{type:"logout"}});console.log("nostr-login auth",e.detail),document.dispatchEvent(e)}this.setUserInfo(t),t&&fetchProfile(t,this.profileNdk).then(e=>{if(this.params.userInfo!==t)return;const n={...this.params.userInfo,picture:e?.image||e?.picture,name:e?.name||e?.displayName||e?.nip05||nip19_exports.npubEncode(t.pubkey)};this.setUserInfo(n)});try{const n=t?nip19_exports.npubEncode(t.pubkey):"",r={type:e};"logout"===e?(this.iframe&&this.iframe.remove(),this.iframe=void 0):(r.pubkey=t.pubkey,r.name=t.name,t.sk&&(r.localNsec=nip19_exports.nsecEncode(t.sk)),t.relays&&(r.relays=t.relays),t.otpData&&(r.otpData=t.otpData),r.method=t.authMethod||"connect");const i=new CustomEvent("nlAuth",{detail:r});console.log("nostr-login auth",r),document.dispatchEvent(i),this.params.optionsModal.onAuth&&this.params.optionsModal.onAuth(n,r)}catch(e){console.log("onAuth error",e)}}async createIframe(e){if(!e)return;const t=new URL(e);let n;const r="__nostr-login-worker-iframe-"+t.hostname.replaceAll(".","-");n=document.querySelector(`#${r}`),console.log("iframe",r,n),n||(n=document.createElement("iframe"),n.setAttribute("width","0"),n.setAttribute("height","0"),n.setAttribute("border","0"),n.style.display="none",n.id=r,document.body.append(n)),n.setAttribute("src",e);const i=new ReadyListener(["workerReady","workerError"],t.origin);await new Promise(e=>{n.addEventListener("load",e)});const s=await i.wait();return console.log("nostr-login iframe ready",e,s),{iframe:n,port:s[1]}}async sendNeedAuth(){const[e]=await this.getNostrConnectServices(),t=new CustomEvent("nlNeedAuth",{detail:{nostrconnect:e}});console.log("nostr-login need auth",e),document.dispatchEvent(t)}isAuthing(){return!!this.readyCallback}async startAuth(){if(console.log("startAuth"),this.readyCallback)throw new Error("Already started");this.readyPromise=new Promise(e=>this.readyCallback=e)}async endAuth(){if(console.log("endAuth",this.params.userInfo),this.params.userInfo&&this.params.userInfo.iframeUrl){const{iframe:e,port:t}=await this.createIframe(this.params.userInfo.iframeUrl)||{};if(this.iframe=e,!this.iframe||!t)return;this.signer.rpc.setWorkerIframePort(t)}this.readyCallback(),this.readyCallback=void 0}resetAuth(){this.readyCallback&&this.readyCallback(),this.readyCallback=void 0}async listen(e){if(!e.iframeUrl)return this.signer.listen(this.nostrConnectSecret);const t=await this.starterReady.wait();if("starterError"===t[0])throw new Error(t[1]);return this.signer.setListenReply(t[1],this.nostrConnectSecret)}async connect(e,t){return this.signer.connect(e.token,t)}async initSigner(e,{listen:t=!1,connect:n=!1,eventToAddAccount:r=!1}={}){if(this.signerPromise)try{await this.signerPromise}catch{}console.log("initSigner info",e);const i=e.iframeUrl?new URL(e.iframeUrl).origin:void 0;return i&&(this.starterReady=new ReadyListener(["starterDone","starterError"],i)),this.emit("onIframeUrl",e.iframeUrl),this.signerPromise=new Promise(async(s,o)=>{this.signerErrCallback=o;try{if(console.log("NDK relays before connect:",Array.from(this.ndk.pool.relays.keys())),e.relays&&!e.iframeUrl)for(const t of e.relays)this.ndk.addExplicitRelay(t,void 0),console.log("Added relay:",t);console.log("NDK relays after add:",Array.from(this.ndk.pool.relays.keys())),await this.ndk.connect(CONNECT_TIMEOUT),console.log("NDK connected relays:",Array.from(this.ndk.pool.relays.entries()).map(([e,t])=>({url:e,status:t.status,connectionStats:t.connectionStats})));const o=new NDKPrivateKeySigner(e.sk);this.signer=new Nip46Signer(this.ndk,o,e.signerPubkey,i),this.signer.on("iframeRestart",async()=>{const t=e.iframeUrl+(e.iframeUrl.includes("?")?"&":"?")+"pubkey="+e.pubkey+"&rebind="+o.pubkey;this.emit("iframeRestart",{pubkey:e.pubkey,iframeUrl:t})}),this.signer.on("authUrl",t=>{console.log("nostr login auth url",t),this.emit("onAuthUrl",{url:t,iframeUrl:e.iframeUrl,eventToAddAccount:r})}),t?await this.listen(e):n?await this.connect(e,this.params.optionsModal.perms):await this.signer.initUserPubkey(e.pubkey),e.pubkey=this.signer.userPubkey,e.signerPubkey=this.signer.remotePubkey,s()}catch(e){console.log("initSigner failure",e),this.signer=null,o(e)}}),this.signerPromise}async authNip46(e,{name:t,bunkerUrl:n,sk:r="",domain:i="",iframeUrl:s=""}){try{const o=bunkerUrlToInfo(n,r);if(isBunkerUrl(t)?o.bunkerUrl=t:(o.nip05=t,o.domain=t.split("@")[1]),i&&(o.domain=i),s&&(o.iframeUrl=s),!o.signerPubkey||!o.sk||!o.relays||0===o.relays.length)throw new Error(`Bad bunker url ${n}`);const a=Boolean(this.params.userInfo);console.log("authNip46",e,o),await this.initSigner(o,{connect:!0,eventToAddAccount:a}),this.onAuth(e,o)}catch(e){throw console.log("nostr login auth failed",e),e}}async signEvent(e){const t=(async()=>(this.localSigner?(e.pubkey=getPublicKey(this.localSigner.privateKey),e.id=getEventHash(e),e.sig=await this.localSigner.sign(e)):(e.pubkey=this.signer?.remotePubkey,e.id=getEventHash(e),e.sig=await(this.signer?.sign(e))),e))(),n=new Promise((e,t)=>{setTimeout(()=>t(new Error("Sign timeout")),2e4)}),r=await Promise.race([t,n]);return console.log("signed",{event:r}),r}async codec_call(e,t,n){return new Promise((r,i)=>{this.signer.rpc.sendRequest(this.signer.remotePubkey,e,[t,n],24133,e=>{e.error?i(e.error):r(e.result)})})}async encrypt04(e,t){return this.localSigner?this.localSigner.encrypt(new NDKUser({pubkey:e}),t):this.signer.encrypt(new NDKUser({pubkey:e}),t)}async decrypt04(e,t){return this.localSigner?this.localSigner.decrypt(new NDKUser({pubkey:e}),t):this.codec_call("nip04_decrypt",e,t)}async encrypt44(e,t){return this.localSigner?this.nip44Codec.encrypt(this.localSigner.privateKey,e,t):this.codec_call("nip44_encrypt",e,t)}async decrypt44(e,t){return this.localSigner?this.nip44Codec.decrypt(this.localSigner.privateKey,e,t):this.codec_call("nip44_decrypt",e,t)}}class ModalManager extends lib$1.EventEmitter{modal=null;params;extensionService;authNostrService;launcherPromise;accounts=[];recents=[];opt;constructor(e,t,n){super(),this.params=e,this.extensionService=n,this.authNostrService=t}async waitReady(){if(this.launcherPromise){try{await this.launcherPromise}catch{}this.launcherPromise=void 0}}async launch(e){console.log("nostr-login launch",e),this.launcherPromise&&await this.waitReady(),this.authNostrService.isAuthing()&&this.authNostrService.resetAuth(),this.opt=e;const t=document.createElement("dialog");if(this.modal=document.createElement("nl-auth"),this.modal.accounts=this.accounts,this.modal.recents=this.recents,this.modal.setAttribute("dark-mode",String(getDarkMode(e))),e.theme&&this.modal.setAttribute("theme",e.theme),e.startScreen&&this.modal.setAttribute("start-screen",e.startScreen),e.bunkers)this.modal.setAttribute("bunkers",e.bunkers);else{let e="nsec.app,highlighter.com";this.modal.setAttribute("bunkers",e)}void 0!==e.methods&&(this.modal.authMethods=e.methods),void 0!==e.localSignup&&(this.modal.localSignup=e.localSignup),void 0!==e.signupNstart&&(this.modal.signupNjump=e.signupNstart),e.title&&(this.modal.welcomeTitle=e.title),e.description&&(this.modal.welcomeDescription=e.description),this.modal.hasExtension=this.extensionService.hasExtension(),this.modal.hasOTP=!!e.otpRequestUrl&&!!e.otpReplyUrl,this.modal.isLoadingExtension=!1,this.modal.isLoading=!1,[this.modal.connectionString,this.modal.connectionStringServices]=await this.authNostrService.getNostrConnectServices(),t.appendChild(this.modal),document.body.appendChild(t);let n="";return this.launcherPromise=new Promise((e,r)=>{t.addEventListener("close",()=>{r(new Error("Closed")),this.authNostrService.resetAuth(),this.modal&&(document.body.removeChild(this.modal.parentNode),this.modal=null)});const i=async e=>{this.modal&&(this.modal.isLoading=!1),await this.authNostrService.endAuth(),t.close(),this.modal=null,e()},s=async(t,n)=>{this.modal&&(this.modal.isLoading=!0);try{n&&!n.start||await this.authNostrService.startAuth(),await t(),n&&!n.end||await i(e)}catch(e){console.log("error",e),this.modal&&(this.modal.isLoading=!1,this.modal.authUrl="",this.modal.iframeUrl="","cancelled"!==e&&(this.modal.error=e.toString()))}},o=async(e,t)=>{await s(async()=>{const n=await getBunkerUrl(e,this.params.optionsModal);await this.authNostrService.authNip46("login",{name:e,bunkerUrl:n,domain:t})})},a=async e=>{await s(async()=>{const{bunkerUrl:t,sk:n}=await this.authNostrService.createAccount(e);await this.authNostrService.authNip46("signup",{name:e,bunkerUrl:t,sk:n})})},c=async()=>{try{await navigator.clipboard.writeText(this.authNostrService.exportKeys()),localStorageSetItem("backupKey","true")}catch(e){console.error("Failed to copy to clipboard: ",e)}},l=async e=>{await s(async()=>{const{iframeUrl:t}=e;e.link=this.authNostrService.prepareImportUrl(e.link),this.modal&&t&&(this.modal.authUrl=e.link,this.modal.iframeUrl=t,this.modal.isLoading=!1,console.log("nostrconnect authUrl",this.modal.authUrl,this.modal.iframeUrl)),await this.authNostrService.importAndConnect(e)})},h=async e=>{await s(async()=>{const{relays:t,domain:n,link:r,iframeUrl:i}=e||{};console.log("nostrConnect",e,t,n,r,i),this.modal&&(i&&(this.modal.authUrl=r,this.modal.iframeUrl=i,this.modal.isLoading=!1,console.log("nostrconnect authUrl",this.modal.authUrl,this.modal.iframeUrl)),e||(this.modal.isLoading=!1)),await this.authNostrService.nostrConnect(t,{domain:n,link:r,iframeUrl:i})})},d=async e=>{await s(async()=>{if(!e)throw new Error("Please enter some nickname");await this.authNostrService.localSignup(e)})},u=async()=>{await s(async()=>{const e=new URL(window.location.href),t=e.hostname.toLocaleLowerCase().replace(/^www\./i,"").charAt(0).toUpperCase()+e.hostname.slice(1),n=prepareSignupRelays(this.params.optionsModal.signupRelays);return this.modal.njumpIframe=`\n <html><body>\n <script src='https://start.njump.me/modal.js'><\/script>\n <script>\n new NstartModal({\n baseUrl: 'https://start.njump.me',\n // Required parameters\n an: '${t}',\n // Optional parameters\n s: [${this.opt.followNpubs?`'${this.opt.followNpubs}'`:""}],\n afb: false, // forceBunker\n asb: false, // skipBunker\n aan: false, // avoidNsec\n aac: true, // avoidNcryptsec\n ahc: true, // hide close button\n arr: ${JSON.stringify(n)}, //readRelays\n awr: ${JSON.stringify(n)}, //writeRelays\n // Callbacks\n onComplete: (result) => {\n console.log('Login token:', result.nostrLogin);\n window.parent.location.href='${window.location.href}#nostr-login='+result.nostrLogin;\n },\n onCancel: () => {\n window.parent.location.href='${window.location.href}#nostr-login=null';\n },\n }).open();\n <\/script>\n </body></html>\n `.replaceAll("&","&"),new Promise((e,t)=>{const n=async n=>{if(console.log("nsecOrBunker",n),n.startsWith("nsec1")){let t;try{t=nip19_exports.decode(n)}catch(e){throw new Error("Bad nsec value")}if("nsec"!==t.type)throw new Error("Bad bech32 type");await this.authNostrService.localSignup("",t.data),e()}else n.startsWith("bunker:")?(await this.authNostrService.authNip46("login",{name:"",bunkerUrl:n}),e()):t("null"===n?"Cancelled":"Unknown return value")};window.addEventListener("hashchange",async()=>{if(window.location.hash.startsWith("#nostr-login=")){const e=window.location.hash.split("#nostr-login=")[1],t=new URL(window.location.toString());t.hash="",window.history.replaceState({},"",t.toString()),n(e)}})})})};if(!this.modal)throw new Error("WTH?");this.modal.addEventListener("handleContinue",()=>{this.modal&&(this.modal.isLoading=!0,this.emit("onAuthUrlClick",this.modal.authUrl))}),this.modal.addEventListener("nlLogin",e=>{o(e.detail)}),this.modal.addEventListener("nlSignup",e=>{a(e.detail)}),this.modal.addEventListener("nlLocalSignup",e=>{d(e.detail)}),this.modal.addEventListener("nlSignupNjump",e=>{u()}),this.modal.addEventListener("nlImportAccount",e=>{l(e.detail)}),this.modal.addEventListener("nlExportKeys",e=>{c()}),this.modal.addEventListener("handleLogoutBanner",()=>{this.emit("onLogoutBanner")}),this.modal.addEventListener("nlNostrConnect",e=>{h(e.detail)}),this.modal.addEventListener("nlNostrConnectDefault",()=>{this.authNostrService.isAuthing()||h()}),this.modal.addEventListener("nlNostrConnectDefaultCancel",()=>{console.log("nlNostrConnectDefaultCancel"),this.authNostrService.cancelNostrConnect()}),this.modal.addEventListener("nlSwitchAccount",e=>{const n=e.detail;this.emit("onSwitchAccount",n),setTimeout(()=>t.close(),300)}),this.modal.addEventListener("nlLoginRecentAccount",async e=>{const n=e.detail;if("readOnly"===n.authMethod)this.authNostrService.setReadOnly(n.pubkey),t.close();else if("otp"===n.authMethod)try{this.modal.dispatchEvent(new CustomEvent("nlLoginOTPUser",{detail:n.nip05||n.pubkey}))}catch(e){console.error(e)}else if("extension"===n.authMethod)await this.extensionService.trySetExtensionForPubkey(n.pubkey),t.close();else{const e=n.bunkerUrl||n.nip05;if(!e)throw new Error("Bad connect info");o(e,n.domain)}}),this.modal.addEventListener("nlRemoveRecent",e=>{localStorageRemoveRecent(e.detail),this.emit("updateAccounts")});const f=async e=>{let t="";if(e.includes("@")){const{error:n,pubkey:r}=await checkNip05(e);if(!r)throw new Error(n);t=r}else if(e.startsWith("npub")){const{type:n,data:r}=nip19_exports.decode(e);if("npub"!==n)throw new Error("Bad npub");t=r}else 64===e.trim().length&&(t=e.trim(),nip19_exports.npubEncode(t));return t};this.modal.addEventListener("nlLoginReadOnly",async e=>{await s(async()=>{const t=e.detail,n=await f(t);this.authNostrService.setReadOnly(n)})}),this.modal.addEventListener("nlLoginExtension",async()=>{if(!this.extensionService.hasExtension())throw new Error("No extension");await s(async()=>{this.modal&&(this.modal.isLoadingExtension=!0,await this.extensionService.setExtension(),this.modal.isLoadingExtension=!1)})}),this.modal.addEventListener("nlLoginOTPUser",async e=>{await s(async()=>{if(!this.modal)return;const t=e.detail,r=await f(t),i=this.opt.otpRequestUrl+(this.opt.otpRequestUrl.includes("?")?"&":"?")+"pubkey="+r,s=await fetch(i);if(200!==s.status)throw console.warn("nostr-login: bad otp reply",s),new Error("Failed to send DM");this.modal.isOTP=!0,n=r,this.modal.isLoading=!1},{start:!0})}),this.modal.addEventListener("nlLoginOTPCode",async e=>{await s(async()=>{if(!this.modal)return;const t=e.detail,r=this.opt.otpReplyUrl+(this.opt.otpRequestUrl.includes("?")?"&":"?")+"pubkey="+n+"&code="+t,i=await fetch(r);if(200!==i.status)throw console.warn("nostr-login: bad otp reply",i),new Error("Invalid code");const s=await i.text();this.authNostrService.setOTP(n,s),this.modal.isOTP=!1},{end:!0})}),this.modal.addEventListener("nlCheckSignup",async e=>{const{available:t,taken:n,error:r}=await checkNip05(e.detail);this.modal&&(this.modal.error=String(r),!r&&n&&(this.modal.error="Already taken"),this.modal.signupNameIsAvailable=t)}),this.modal.addEventListener("nlCheckLogin",async e=>{const{available:t,taken:n,error:r}=await checkNip05(e.detail);this.modal&&(this.modal.error=String(r),t&&(this.modal.error="Name not found"),this.modal.loginIsGood=n)});const p=()=>{this.modal&&(this.modal.isLoading=!1),t.close(),r(new Error("Cancelled"))};this.modal.addEventListener("stopFetchHandler",p),this.modal.addEventListener("nlCloseModal",p),this.modal.addEventListener("nlChangeDarkMode",e=>{setDarkMode(e.detail),document.dispatchEvent(new CustomEvent("nlDarkMode",{detail:e.detail}))}),this.on("onIframeAuthUrlCallEnd",()=>{t.close(),this.modal=null,e()}),t.showModal()}),this.launcherPromise}async showIframeUrl(e){await this.waitReady(),this.launch({startScreen:"iframe"}).catch(()=>console.log("closed auth iframe")),this.modal.authUrl=e}connectModals(e){const t=async e=>{await this.launch(e)},n=document.getElementsByTagName("nl-button");for(let r=0;r<n.length;r++){const i=n[r].getAttribute("nl-theme"),s=n[r].getAttribute("start-screen"),o={...e};switch(i&&(o.theme=i),s){case"login":case"login-bunker-url":case"login-read-only":case"signup":case"switch-account":case"welcome":o.startScreen=s}n[r].addEventListener("click",function(){t(o)})}}onAuthUrl(e){this.modal&&(this.modal.authUrl=e,this.modal.isLoading=!1)}onIframeUrl(e){this.modal&&(console.log("modal iframe url",e),this.modal.iframeUrl=e)}onCallEnd(){this.modal&&this.modal.authUrl&&this.params.userInfo?.iframeUrl&&this.emit("onIframeAuthUrlCallEnd")}onUpdateAccounts(e,t){this.accounts=e,this.recents=t,this.modal&&(this.modal.accounts=e,this.modal.recents=t)}onDarkMode(e){this.modal&&(this.modal.darkMode=e)}}class Nostr{#e;nip04;nip44;constructor(e){this.#e=e,this.getPublicKey=this.getPublicKey.bind(this),this.signEvent=this.signEvent.bind(this),this.getRelays=this.getRelays.bind(this),this.nip04={encrypt:this.encrypt04.bind(this),decrypt:this.decrypt04.bind(this)},this.nip44={encrypt:this.encrypt44.bind(this),decrypt:this.decrypt44.bind(this)}}async ensureAuth(){if(await this.#e.waitReady(),!this.#e.getUserInfo()&&(await this.#e.launch(),!this.#e.getUserInfo()))throw new Error("Rejected by user")}async getPublicKey(){await this.ensureAuth();const e=this.#e.getUserInfo();if(e)return e.pubkey;throw new Error("No user")}async signEvent(e){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().signEvent(e))}async getRelays(){return{}}async encrypt04(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip04.encrypt(e,t))}async decrypt04(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip04.decrypt(e,t))}async encrypt44(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip44.encrypt(e,t))}async decrypt44(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip44.decrypt(e,t))}}class NostrExtensionService extends lib$1.EventEmitter{params;nostrExtension;constructor(e){super(),this.params=e}startCheckingExtension(e){if(this.checkExtension(e))return;const t=setInterval(()=>{this.checkExtension(e)&&clearTimeout(t)},100)}checkExtension(e){return!(this.nostrExtension||!window.nostr||window.nostr===e)&&(this.initExtension(e),!0)}async initExtension(e,t){this.nostrExtension=window.nostr,window.nostr=e,"extension"===this.params.userInfo?.authMethod&&await this.trySetExtensionForPubkey(this.params.userInfo.pubkey),t||setTimeout(()=>{window.nostr!==e&&this.nostrExtension!==window.nostr&&this.initExtension(e,!0)},300)}async setExtensionReadPubkey(e){window.nostr=this.nostrExtension;const t=await window.nostr.getPublicKey();e&&e!==t?this.emit("extensionLogout"):this.emit("extensionLogin",t)}async trySetExtensionForPubkey(e){if(this.nostrExtension)return this.setExtensionReadPubkey(e)}async setExtension(){return this.setExtensionReadPubkey()}unsetExtension(e){window.nostr===this.nostrExtension&&(window.nostr=e)}getExtension(){return this.nostrExtension}hasExtension(){return!!this.nostrExtension}}class NostrParams{userInfo;optionsModal;constructor(){this.userInfo=null,this.optionsModal={theme:"default",startScreen:"welcome",devOverrideBunkerOrigin:""}}}class Popup{popup=null;constructor(){}openPopup(e){if((!this.popup||this.popup.closed)&&(this.popup=window.open(e,"_blank","width=400,height=700"),console.log("popup",this.popup),!this.popup))throw new Error("Popup blocked. Try again, please!")}closePopup(){try{this.popup?.close(),this.popup=null}catch{}}}const CALL_TIMEOUT=5e3;class ProcessManager extends lib$1.EventEmitter{callCount=0;callTimer;constructor(){super()}onAuthUrl(){Boolean(this.callTimer)&&clearTimeout(this.callTimer)}onIframeUrl(){Boolean(this.callTimer)&&clearTimeout(this.callTimer)}async wait(e){let t,n;this.callTimer||(this.callTimer=setTimeout(()=>this.emit("onCallTimeout"),CALL_TIMEOUT)),this.callCount||this.emit("onCallStart"),this.callCount++;try{n=await e()}catch(e){t=e}if(this.callCount--,this.emit("onCallEnd"),this.callTimer&&clearTimeout(this.callTimer),this.callTimer=void 0,t)throw t;return n}}class NostrLoginInitializer{extensionService;params;authNostrService;nostr;processManager;popupManager;bannerManager;modalManager;customLaunchCallback;constructor(){this.params=new NostrParams,this.processManager=new ProcessManager,this.popupManager=new Popup,this.bannerManager=new BannerManager(this.params),this.authNostrService=new AuthNostrService(this.params),this.extensionService=new NostrExtensionService(this.params),this.modalManager=new ModalManager(this.params,this.authNostrService,this.extensionService);const e={waitReady:async()=>{await this.authNostrService.waitReady(),await this.modalManager.waitReady()},getUserInfo:()=>this.params.userInfo,getSigner:()=>{if("readOnly"===this.params.userInfo.authMethod)throw new Error("Read only");return"extension"===this.params.userInfo.authMethod?this.extensionService.getExtension():this.authNostrService},launch:()=>this.launch(),wait:e=>this.processManager.wait(e)};this.nostr=new Nostr(e),this.processManager.on("onCallTimeout",()=>{this.bannerManager.onCallTimeout()}),this.processManager.on("onCallEnd",()=>{this.bannerManager.onCallEnd(),this.modalManager.onCallEnd()}),this.processManager.on("onCallStart",()=>{this.bannerManager.onCallStart()}),this.authNostrService.on("onIframeUrl",e=>{this.modalManager.onIframeUrl(e)}),this.authNostrService.on("iframeRestart",({iframeUrl:e})=>{this.processManager.onIframeUrl(),this.bannerManager.onIframeRestart(e)}),this.authNostrService.on("onAuthUrl",({url:e,iframeUrl:t,eventToAddAccount:n})=>{this.processManager.onAuthUrl(),n?this.modalManager.onAuthUrl(e):this.params.userInfo?this.bannerManager.onAuthUrl(e,t):this.modalManager.onAuthUrl(e)}),this.authNostrService.on("updateAccounts",()=>{this.updateAccounts()}),this.authNostrService.on("onUserInfo",e=>{this.bannerManager.onUserInfo(e)}),this.modalManager.on("onAuthUrlClick",e=>{this.openPopup(e)}),this.bannerManager.on("onIframeAuthUrlClick",e=>{this.modalManager.showIframeUrl(e)}),this.modalManager.on("onSwitchAccount",async e=>{this.switchAccount(e)}),this.modalManager.on("onLogoutBanner",async e=>{logout()}),this.bannerManager.on("onConfirmLogout",async()=>{this.launch("confirm-logout")}),this.modalManager.on("updateAccounts",()=>{this.updateAccounts()}),this.bannerManager.on("logout",()=>{logout()}),this.bannerManager.on("onAuthUrlClick",e=>{this.openPopup(e)}),this.bannerManager.on("onSwitchAccount",async e=>{this.switchAccount(e)}),this.bannerManager.on("import",()=>{this.launch("import")}),this.extensionService.on("extensionLogin",e=>{this.authNostrService.setExtension(e)}),this.extensionService.on("extensionLogout",()=>{logout()}),this.bannerManager.on("launch",e=>{this.launch(e)})}openPopup(e){this.popupManager.openPopup(e)}async switchAccount(e,t=!1){if(console.log("nostr login switch to info",e),this.extensionService.unsetExtension(this.nostr),"readOnly"===e.authMethod)this.authNostrService.setReadOnly(e.pubkey);else if("otp"===e.authMethod)this.authNostrService.setOTP(e.pubkey,e.otpData||"");else if("local"===e.authMethod&&e.sk)this.authNostrService.setLocal(e,t);else if("extension"===e.authMethod)await this.extensionService.trySetExtensionForPubkey(e.pubkey);else{if(!("connect"===e.authMethod&&e.sk&&e.relays&&e.relays[0]))throw new Error("Bad auth info");this.authNostrService.setConnect(e)}}updateAccounts(){const e=localStorageGetAccounts(),t=localStorageGetRecents();this.bannerManager.onUpdateAccounts(e),this.modalManager.onUpdateAccounts(e,t)}async launchCustomNostrConnect(){try{this.authNostrService.isAuthing()&&this.authNostrService.cancelNostrConnect();const e=new Promise(e=>this.customLaunchCallback=e);await this.authNostrService.startAuth(),await this.authNostrService.sendNeedAuth();try{await this.authNostrService.nostrConnect(),await this.authNostrService.endAuth()}catch(t){"cancelled"===t&&await e}}catch(e){console.error("launchCustomNostrConnect",e)}}fulfillCustomLaunchPromise(){if(this.customLaunchCallback){const e=this.customLaunchCallback;this.customLaunchCallback=void 0,e()}}launch=async e=>{if(!e&&this.params.optionsModal.customNostrConnect)return this.launchCustomNostrConnect();const t=localStorageGetRecents(),n=localStorageGetAccounts(),r={...this.params.optionsModal};e&&"default"!==e?r.startScreen=e:(Boolean(t?.length)||Boolean(n?.length))&&(r.startScreen="switch-account"),this.customLaunchCallback&&this.authNostrService.cancelNostrConnect();try{await this.modalManager.launch(r),this.fulfillCustomLaunchPromise()}catch(e){console.log("nostr-login failed",e)}};init=async e=>{this.extensionService.startCheckingExtension(this.nostr),window.nostr=this.nostr,this.modalManager.connectModals(e),this.bannerManager.launchAuthBanner(e),e&&(this.params.optionsModal={...e});try{const e=localStorageGetCurrent();if(e){if(!e.pubkey)throw new Error("Bad stored info");await this.switchAccount(e)}}catch(e){console.log("nostr login init error",e),await logout()}this.updateAccounts()};logout=async()=>{this.extensionService.unsetExtension(this.nostr),await this.authNostrService.logout()};setDarkMode=e=>{localStorageSetItem("nl-dark-mode",`${e}`),this.bannerManager.onDarkMode(e),this.modalManager.onDarkMode(e)};setAuth=async e=>{if(!e.type)throw new Error("Invalid auth event");if("login"!==e.type&&"logout"!==e.type&&"signup"!==e.type)throw new Error("Invalid auth event");if(e.method&&"connect"!==e.method&&"extension"!==e.method&&"local"!==e.method&&"otp"!==e.method&&"readOnly"!==e.method)throw new Error("Invalid auth event");if("logout"===e.type)return this.logout();if(!e.method||!e.pubkey)throw new Error("Invalid pubkey");const t={authMethod:e.method,pubkey:e.pubkey,relays:e.relays,sk:e.localNsec,otpData:e.otpData,name:e.name};await this.switchAccount(t,"signup"===e.type)};cancelNeedAuth=()=>{console.log("cancelNeedAuth"),this.fulfillCustomLaunchPromise(),this.authNostrService.cancelNostrConnect()}}const initializer=new NostrLoginInitializer,{init:init,launch:launch,logout:logout,setDarkMode:setDarkMode,setAuth:setAuth,cancelNeedAuth:cancelNeedAuth}=initializer;document.addEventListener("nlLogout",logout),document.addEventListener("nlLaunch",e=>{launch(e.detail||"")}),document.addEventListener("nlNeedAuthCancel",()=>{cancelNeedAuth()}),document.addEventListener("nlDarkMode",e=>{setDarkMode(!!e.detail)}),document.addEventListener("nlSetAuth",e=>{setAuth(e.detail)});export{NostrLoginInitializer,cancelNeedAuth,init,launch,logout,setAuth,setDarkMode};
|
|
46
|
+
/*! noble-ciphers - MIT License (c) 2023 Paul Miller (paulmillr.com) */const u8a=e=>e instanceof Uint8Array,u32=e=>new Uint32Array(e.buffer,e.byteOffset,Math.floor(e.byteLength/4)),isLE=68===new Uint8Array(new Uint32Array([287454020]).buffer)[0];if(!isLE)throw new Error("Non little-endian hardware is not supported");function utf8ToBytes(e){if("string"!=typeof e)throw new Error("utf8ToBytes expected string, got "+typeof e);return new Uint8Array((new TextEncoder).encode(e))}function toBytes(e){if("string"==typeof e&&(e=utf8ToBytes(e)),!u8a(e))throw new Error("expected Uint8Array, got "+typeof e);return e}const isPlainObject=e=>"[object Object]"===Object.prototype.toString.call(e)&&e.constructor===Object;function checkOpts(e,t){if(void 0!==t&&("object"!=typeof t||!isPlainObject(t)))throw new Error("options must be object or undefined");return Object.assign(e,t)}function ensureBytes(e,t){if(!(e instanceof Uint8Array))throw new Error("Uint8Array expected");if(e.length!==t)throw new Error(`Uint8Array length ${t} expected`)}function equalBytes(e,t){if(e.length!==t.length)throw new Error("equalBytes: Different size of Uint8Arrays");let n=!0;for(let r=0;r<e.length;r++)n&&(n=e[r]===t[r]);return n}function number(e){if(!Number.isSafeInteger(e)||e<0)throw new Error(`Wrong positive integer: ${e}`)}function bool(e){if("boolean"!=typeof e)throw new Error(`Expected boolean, not ${e}`)}function bytes(e,...t){if(!(e instanceof Uint8Array))throw new Error("Expected Uint8Array");if(t.length>0&&!t.includes(e.length))throw new Error(`Expected Uint8Array of length ${t}, not of length=${e.length}`)}function hash(e){if("function"!=typeof e||"function"!=typeof e.create)throw new Error("hash must be wrapped by utils.wrapConstructor");number(e.outputLen),number(e.blockLen)}function exists(e,t=!0){if(e.destroyed)throw new Error("Hash instance has been destroyed");if(t&&e.finished)throw new Error("Hash#digest() has already been called")}function output(e,t){bytes(e);const n=t.outputLen;if(e.length<n)throw new Error(`digestInto() expects output buffer of length at least ${n}`)}const assert={number:number,bool:bool,bytes:bytes,hash:hash,exists:exists,output:output},u8to16=(e,t)=>255&e[t++]|(255&e[t++])<<8;class Poly1305{constructor(e){this.blockLen=16,this.outputLen=16,this.buffer=new Uint8Array(16),this.r=new Uint16Array(10),this.h=new Uint16Array(10),this.pad=new Uint16Array(8),this.pos=0,this.finished=!1,ensureBytes(e=toBytes(e),32);const t=u8to16(e,0),n=u8to16(e,2),r=u8to16(e,4),i=u8to16(e,6),s=u8to16(e,8),o=u8to16(e,10),a=u8to16(e,12),c=u8to16(e,14);this.r[0]=8191&t,this.r[1]=8191&(t>>>13|n<<3),this.r[2]=7939&(n>>>10|r<<6),this.r[3]=8191&(r>>>7|i<<9),this.r[4]=255&(i>>>4|s<<12),this.r[5]=s>>>1&8190,this.r[6]=8191&(s>>>14|o<<2),this.r[7]=8065&(o>>>11|a<<5),this.r[8]=8191&(a>>>8|c<<8),this.r[9]=c>>>5&127;for(let t=0;t<8;t++)this.pad[t]=u8to16(e,16+2*t)}process(e,t,n=!1){const r=n?0:2048,{h:i,r:s}=this,o=s[0],a=s[1],c=s[2],l=s[3],h=s[4],d=s[5],u=s[6],f=s[7],p=s[8],g=s[9],y=u8to16(e,t+0),m=u8to16(e,t+2),b=u8to16(e,t+4),w=u8to16(e,t+6),v=u8to16(e,t+8),$=u8to16(e,t+10),E=u8to16(e,t+12),k=u8to16(e,t+14);let x=i[0]+(8191&y),_=i[1]+(8191&(y>>>13|m<<3)),S=i[2]+(8191&(m>>>10|b<<6)),C=i[3]+(8191&(b>>>7|w<<9)),A=i[4]+(8191&(w>>>4|v<<12)),N=i[5]+(v>>>1&8191),R=i[6]+(8191&(v>>>14|$<<2)),T=i[7]+(8191&($>>>11|E<<5)),B=i[8]+(8191&(E>>>8|k<<8)),L=i[9]+(k>>>5|r),I=0,U=I+x*o+_*(5*g)+S*(5*p)+C*(5*f)+A*(5*u);I=U>>>13,U&=8191,U+=N*(5*d)+R*(5*h)+T*(5*l)+B*(5*c)+L*(5*a),I+=U>>>13,U&=8191;let O=I+x*a+_*o+S*(5*g)+C*(5*p)+A*(5*f);I=O>>>13,O&=8191,O+=N*(5*u)+R*(5*d)+T*(5*h)+B*(5*l)+L*(5*c),I+=O>>>13,O&=8191;let P=I+x*c+_*a+S*o+C*(5*g)+A*(5*p);I=P>>>13,P&=8191,P+=N*(5*f)+R*(5*u)+T*(5*d)+B*(5*h)+L*(5*l),I+=P>>>13,P&=8191;let M=I+x*l+_*c+S*a+C*o+A*(5*g);I=M>>>13,M&=8191,M+=N*(5*p)+R*(5*f)+T*(5*u)+B*(5*d)+L*(5*h),I+=M>>>13,M&=8191;let D=I+x*h+_*l+S*c+C*a+A*o;I=D>>>13,D&=8191,D+=N*(5*g)+R*(5*p)+T*(5*f)+B*(5*u)+L*(5*d),I+=D>>>13,D&=8191;let H=I+x*d+_*h+S*l+C*c+A*a;I=H>>>13,H&=8191,H+=N*o+R*(5*g)+T*(5*p)+B*(5*f)+L*(5*u),I+=H>>>13,H&=8191;let F=I+x*u+_*d+S*h+C*l+A*c;I=F>>>13,F&=8191,F+=N*a+R*o+T*(5*g)+B*(5*p)+L*(5*f),I+=F>>>13,F&=8191;let K=I+x*f+_*u+S*d+C*h+A*l;I=K>>>13,K&=8191,K+=N*c+R*a+T*o+B*(5*g)+L*(5*p),I+=K>>>13,K&=8191;let V=I+x*p+_*f+S*u+C*d+A*h;I=V>>>13,V&=8191,V+=N*l+R*c+T*a+B*o+L*(5*g),I+=V>>>13,V&=8191;let j=I+x*g+_*p+S*f+C*u+A*d;I=j>>>13,j&=8191,j+=N*h+R*l+T*c+B*a+L*o,I+=j>>>13,j&=8191,I=(I<<2)+I|0,I=I+U|0,U=8191&I,I>>>=13,O+=I,i[0]=U,i[1]=O,i[2]=P,i[3]=M,i[4]=D,i[5]=H,i[6]=F,i[7]=K,i[8]=V,i[9]=j}finalize(){const{h:e,pad:t}=this,n=new Uint16Array(10);let r=e[1]>>>13;e[1]&=8191;for(let t=2;t<10;t++)e[t]+=r,r=e[t]>>>13,e[t]&=8191;e[0]+=5*r,r=e[0]>>>13,e[0]&=8191,e[1]+=r,r=e[1]>>>13,e[1]&=8191,e[2]+=r,n[0]=e[0]+5,r=n[0]>>>13,n[0]&=8191;for(let t=1;t<10;t++)n[t]=e[t]+r,r=n[t]>>>13,n[t]&=8191;n[9]-=8192;let i=(1^r)-1;for(let e=0;e<10;e++)n[e]&=i;i=~i;for(let t=0;t<10;t++)e[t]=e[t]&i|n[t];e[0]=65535&(e[0]|e[1]<<13),e[1]=65535&(e[1]>>>3|e[2]<<10),e[2]=65535&(e[2]>>>6|e[3]<<7),e[3]=65535&(e[3]>>>9|e[4]<<4),e[4]=65535&(e[4]>>>12|e[5]<<1|e[6]<<14),e[5]=65535&(e[6]>>>2|e[7]<<11),e[6]=65535&(e[7]>>>5|e[8]<<8),e[7]=65535&(e[8]>>>8|e[9]<<5);let s=e[0]+t[0];e[0]=65535&s;for(let n=1;n<8;n++)s=(e[n]+t[n]|0)+(s>>>16)|0,e[n]=65535&s}update(e){assert.exists(this);const{buffer:t,blockLen:n}=this,r=(e=toBytes(e)).length;for(let i=0;i<r;){const s=Math.min(n-this.pos,r-i);if(s!==n)t.set(e.subarray(i,i+s),this.pos),this.pos+=s,i+=s,this.pos===n&&(this.process(t,0,!1),this.pos=0);else for(;n<=r-i;i+=n)this.process(e,i)}return this}destroy(){this.h.fill(0),this.r.fill(0),this.buffer.fill(0),this.pad.fill(0)}digestInto(e){assert.exists(this),assert.output(e,this),this.finished=!0;const{buffer:t,h:n}=this;let{pos:r}=this;if(r){for(t[r++]=1;r<16;r++)t[r]=0;this.process(t,0,!0)}this.finalize();let i=0;for(let t=0;t<8;t++)e[i++]=n[t]>>>0,e[i++]=n[t]>>>8;return e}digest(){const{buffer:e,outputLen:t}=this;this.digestInto(e);const n=e.slice(0,t);return this.destroy(),n}}function wrapConstructorWithKey(e){const t=(t,n)=>e(n).update(toBytes(t)).digest(),n=e(new Uint8Array(32));return t.outputLen=n.outputLen,t.blockLen=n.blockLen,t.create=t=>e(t),t}wrapConstructorWithKey(e=>new Poly1305(e));const sigma16=utf8ToBytes("expand 16-byte k"),sigma32=utf8ToBytes("expand 32-byte k"),sigma16_32=u32(sigma16),sigma32_32=u32(sigma32),isAligned32=e=>!(e.byteOffset%4),salsaBasic=e=>{const{core:t,rounds:n,counterRight:r,counterLen:i,allow128bitKeys:s,extendNonceFn:o,blockLen:a}=checkOpts({rounds:20,counterRight:!1,counterLen:8,allow128bitKeys:!0,blockLen:64},e);assert.number(i),assert.number(n),assert.number(a),assert.bool(r),assert.bool(s);const c=a/4;if(a%4!=0)throw new Error("Salsa/ChaCha: blockLen must be aligned to 4 bytes");return(e,l,h,d,u=0)=>{if(assert.bytes(e),assert.bytes(l),assert.bytes(h),d||(d=new Uint8Array(h.length)),assert.bytes(d),assert.number(u),u<0||u>=2**32-1)throw new Error("Salsa/ChaCha: counter overflow");if(d.length<h.length)throw new Error(`Salsa/ChaCha: output (${d.length}) is shorter than data (${h.length})`);const f=[];let p,g;if(32===e.length)p=e,g=sigma32_32;else{if(16!==e.length||!s)throw new Error(`Salsa/ChaCha: invalid 32-byte key, got length=${e.length}`);p=new Uint8Array(32),p.set(e),p.set(e,16),g=sigma16_32,f.push(p)}if(o){if(l.length<=16)throw new Error("Salsa/ChaCha: extended nonce must be bigger than 16 bytes");p=o(g,p,l.subarray(0,16),new Uint8Array(32)),f.push(p),l=l.subarray(16)}const y=16-i;if(l.length!==y)throw new Error(`Salsa/ChaCha: nonce must be ${y} or 16 bytes`);if(12!==y){const e=new Uint8Array(12);e.set(l,r?0:12-l.length),f.push(l=e)}const m=new Uint8Array(a),b=u32(m),w=u32(p),v=u32(l),$=isAligned32(h)&&u32(h),E=isAligned32(d)&&u32(d);f.push(b);const k=h.length;for(let e=0,r=u;e<k;r++){if(t(g,w,v,b,r,n),r>=2**32-1)throw new Error("Salsa/ChaCha: counter overflow");const i=Math.min(a,k-e);if(i===a&&E&&$){const t=e/4;if(e%4!=0)throw new Error("Salsa/ChaCha: invalid block position");for(let e=0;e<c;e++)E[t+e]=$[t+e]^b[e];e+=a;continue}for(let t=0;t<i;t++)d[e+t]=h[e+t]^m[t];e+=i}for(let e=0;e<f.length;e++)f[e].fill(0);return d}},rotl=(e,t)=>e<<t|e>>>32-t;function chachaCore(e,t,n,r,i,s=20){let o=e[0],a=e[1],c=e[2],l=e[3],h=t[0],d=t[1],u=t[2],f=t[3],p=t[4],g=t[5],y=t[6],m=t[7],b=i,w=n[0],v=n[1],$=n[2],E=o,k=a,x=c,_=l,S=h,C=d,A=u,N=f,R=p,T=g,B=y,L=m,I=b,U=w,O=v,P=$;for(let e=0;e<s;e+=2)E=E+S|0,I=rotl(I^E,16),R=R+I|0,S=rotl(S^R,12),E=E+S|0,I=rotl(I^E,8),R=R+I|0,S=rotl(S^R,7),k=k+C|0,U=rotl(U^k,16),T=T+U|0,C=rotl(C^T,12),k=k+C|0,U=rotl(U^k,8),T=T+U|0,C=rotl(C^T,7),x=x+A|0,O=rotl(O^x,16),B=B+O|0,A=rotl(A^B,12),x=x+A|0,O=rotl(O^x,8),B=B+O|0,A=rotl(A^B,7),_=_+N|0,P=rotl(P^_,16),L=L+P|0,N=rotl(N^L,12),_=_+N|0,P=rotl(P^_,8),L=L+P|0,N=rotl(N^L,7),E=E+C|0,P=rotl(P^E,16),B=B+P|0,C=rotl(C^B,12),E=E+C|0,P=rotl(P^E,8),B=B+P|0,C=rotl(C^B,7),k=k+A|0,I=rotl(I^k,16),L=L+I|0,A=rotl(A^L,12),k=k+A|0,I=rotl(I^k,8),L=L+I|0,A=rotl(A^L,7),x=x+N|0,U=rotl(U^x,16),R=R+U|0,N=rotl(N^R,12),x=x+N|0,U=rotl(U^x,8),R=R+U|0,N=rotl(N^R,7),_=_+S|0,O=rotl(O^_,16),T=T+O|0,S=rotl(S^T,12),_=_+S|0,O=rotl(O^_,8),T=T+O|0,S=rotl(S^T,7);let M=0;r[M++]=o+E|0,r[M++]=a+k|0,r[M++]=c+x|0,r[M++]=l+_|0,r[M++]=h+S|0,r[M++]=d+C|0,r[M++]=u+A|0,r[M++]=f+N|0,r[M++]=p+R|0,r[M++]=g+T|0,r[M++]=y+B|0,r[M++]=m+L|0,r[M++]=b+I|0,r[M++]=w+U|0,r[M++]=v+O|0,r[M++]=$+P|0}const chacha20=salsaBasic({core:chachaCore,counterRight:!1,counterLen:4,allow128bitKeys:!1});function extract(e,t,n){return assert$3.hash(e),void 0===n&&(n=new Uint8Array(e.outputLen)),hmac$3(e,toBytes$4(n),toBytes$4(t))}const HKDF_COUNTER=new Uint8Array([0]),EMPTY_BUFFER=new Uint8Array;function expand(e,t,n,r=32){if(assert$3.hash(e),assert$3.number(r),r>255*e.outputLen)throw new Error("Length should be <= 255*HashLen");const i=Math.ceil(r/e.outputLen);void 0===n&&(n=EMPTY_BUFFER);const s=new Uint8Array(i*e.outputLen),o=hmac$3.create(e,t),a=o._cloneInto(),c=new Uint8Array(o.outputLen);for(let t=0;t<i;t++)HKDF_COUNTER[0]=t+1,a.update(0===t?EMPTY_BUFFER:c).update(n).update(HKDF_COUNTER).digestInto(c),s.set(c,e.outputLen*t),o._cloneInto(a);return o.destroy(),a.destroy(),c.fill(0),HKDF_COUNTER.fill(0),s.slice(0,r)}const hkdf=(e,t,n,r,i)=>expand(e,extract(e,t,n),r,i);var __defProp=Object.defineProperty,__export=(e,t)=>{for(var n in t)__defProp(e,n,{get:t[n],enumerable:!0})};function generatePrivateKey(){return bytesToHex$3(schnorr.utils.randomPrivateKey())}function getPublicKey(e){return bytesToHex$3(schnorr.getPublicKey(e))}var utils_exports={};__export(utils_exports,{MessageNode:()=>MessageNode,MessageQueue:()=>MessageQueue,insertEventIntoAscendingList:()=>insertEventIntoAscendingList,insertEventIntoDescendingList:()=>insertEventIntoDescendingList,normalizeURL:()=>normalizeURL,utf8Decoder:()=>utf8Decoder,utf8Encoder:()=>utf8Encoder});var utf8Decoder=new TextDecoder("utf-8"),utf8Encoder=new TextEncoder;function normalizeURL(e){let t=new URL(e);return t.pathname=t.pathname.replace(/\/+/g,"/"),t.pathname.endsWith("/")&&(t.pathname=t.pathname.slice(0,-1)),("80"===t.port&&"ws:"===t.protocol||"443"===t.port&&"wss:"===t.protocol)&&(t.port=""),t.searchParams.sort(),t.hash="",t.toString()}function insertEventIntoDescendingList(e,t){let n,r=0,i=e.length-1,s=r;if(i<0)s=0;else if(t.created_at<e[i].created_at)s=i+1;else if(t.created_at>=e[r].created_at)s=r;else for(;;){if(i<=r+1){s=i;break}if(n=Math.floor(r+(i-r)/2),e[n].created_at>t.created_at)r=n;else{if(!(e[n].created_at<t.created_at)){s=n;break}i=n}}return e[s]?.id!==t.id?[...e.slice(0,s),t,...e.slice(s)]:e}function insertEventIntoAscendingList(e,t){let n,r=0,i=e.length-1,s=r;if(i<0)s=0;else if(t.created_at>e[i].created_at)s=i+1;else if(t.created_at<=e[r].created_at)s=r;else for(;;){if(i<=r+1){s=i;break}if(n=Math.floor(r+(i-r)/2),e[n].created_at<t.created_at)r=n;else{if(!(e[n].created_at>t.created_at)){s=n;break}i=n}}return e[s]?.id!==t.id?[...e.slice(0,s),t,...e.slice(s)]:e}var MessageNode=class{_value;_next;get value(){return this._value}set value(e){this._value=e}get next(){return this._next}set next(e){this._next=e}constructor(e){this._value=e,this._next=null}},MessageQueue=class{_first;_last;get first(){return this._first}set first(e){this._first=e}get last(){return this._last}set last(e){this._last=e}_size;get size(){return this._size}set size(e){this._size=e}constructor(){this._first=null,this._last=null,this._size=0}enqueue(e){const t=new MessageNode(e);return 0!==this._size&&this._last?(this._last.next=t,this._last=t):(this._first=t,this._last=t),this._size++,!0}dequeue(){if(0===this._size||!this._first)return null;let e=this._first;return this._first=e.next,e.next=null,this._size--,e.value}},verifiedSymbol=Symbol("verified");function getBlankEvent(e=255){return{kind:e,content:"",tags:[],created_at:0}}function finishEvent(e,t){const n=e;return n.pubkey=getPublicKey(t),n.id=getEventHash(n),n.sig=getSignature(n,t),n[verifiedSymbol]=!0,n}function serializeEvent(e){if(!validateEvent(e))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,e.pubkey,e.created_at,e.kind,e.tags,e.content])}function getEventHash(e){return bytesToHex$3(sha256$3(utf8Encoder.encode(serializeEvent(e))))}var isRecord=e=>e instanceof Object;function validateEvent(e){if(!isRecord(e))return!1;if("number"!=typeof e.kind)return!1;if("string"!=typeof e.content)return!1;if("number"!=typeof e.created_at)return!1;if("string"!=typeof e.pubkey)return!1;if(!e.pubkey.match(/^[a-f0-9]{64}$/))return!1;if(!Array.isArray(e.tags))return!1;for(let t=0;t<e.tags.length;t++){let n=e.tags[t];if(!Array.isArray(n))return!1;for(let e=0;e<n.length;e++)if("object"==typeof n[e])return!1}return!0}function verifySignature(e){if("boolean"==typeof e[verifiedSymbol])return e[verifiedSymbol];const t=getEventHash(e);if(t!==e.id)return e[verifiedSymbol]=!1;try{return e[verifiedSymbol]=schnorr.verify(e.sig,t,e.pubkey)}catch(t){return e[verifiedSymbol]=!1}}function getSignature(e,t){return bytesToHex$3(schnorr.sign(getEventHash(e),t))}var fakejson_exports={};function getHex64(e,t){let n=t.length+3,r=e.indexOf(`"${t}":`)+n,i=e.slice(r).indexOf('"')+r+1;return e.slice(i,i+64)}function getInt(e,t){let n=t.length,r=e.indexOf(`"${t}":`)+n+3,i=e.slice(r),s=Math.min(i.indexOf(","),i.indexOf("}"));return parseInt(i.slice(0,s),10)}function getSubscriptionId(e){let t=e.slice(0,22).indexOf('"EVENT"');if(-1===t)return null;let n=e.slice(t+7+1).indexOf('"');if(-1===n)return null;let r=t+7+1+n,i=e.slice(r+1,80).indexOf('"');if(-1===i)return null;let s=r+1+i;return e.slice(r+1,s)}function matchEventId(e,t){return t===getHex64(e,"id")}function matchEventPubkey(e,t){return t===getHex64(e,"pubkey")}function matchEventKind(e,t){return t===getInt(e,"kind")}__export(fakejson_exports,{getHex64:()=>getHex64,getInt:()=>getInt,getSubscriptionId:()=>getSubscriptionId,matchEventId:()=>matchEventId,matchEventKind:()=>matchEventKind,matchEventPubkey:()=>matchEventPubkey});var nip19_exports={};__export(nip19_exports,{BECH32_REGEX:()=>BECH32_REGEX,decode:()=>decode,naddrEncode:()=>naddrEncode,neventEncode:()=>neventEncode,noteEncode:()=>noteEncode,nprofileEncode:()=>nprofileEncode,npubEncode:()=>npubEncode,nrelayEncode:()=>nrelayEncode,nsecEncode:()=>nsecEncode});var Bech32MaxSize=5e3,BECH32_REGEX=/[\x21-\x7E]{1,83}1[023456789acdefghjklmnpqrstuvwxyz]{6,}/;function integerToUint8Array(e){const t=new Uint8Array(4);return t[0]=e>>24&255,t[1]=e>>16&255,t[2]=e>>8&255,t[3]=255&e,t}function decode(e){let{prefix:t,words:n}=bech32.decode(e,Bech32MaxSize),r=new Uint8Array(bech32.fromWords(n));switch(t){case"nprofile":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for nprofile");if(32!==e[0][0].length)throw new Error("TLV 0 should be 32 bytes");return{type:"nprofile",data:{pubkey:bytesToHex$3(e[0][0]),relays:e[1]?e[1].map(e=>utf8Decoder.decode(e)):[]}}}case"nevent":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for nevent");if(32!==e[0][0].length)throw new Error("TLV 0 should be 32 bytes");if(e[2]&&32!==e[2][0].length)throw new Error("TLV 2 should be 32 bytes");if(e[3]&&4!==e[3][0].length)throw new Error("TLV 3 should be 4 bytes");return{type:"nevent",data:{id:bytesToHex$3(e[0][0]),relays:e[1]?e[1].map(e=>utf8Decoder.decode(e)):[],author:e[2]?.[0]?bytesToHex$3(e[2][0]):void 0,kind:e[3]?.[0]?parseInt(bytesToHex$3(e[3][0]),16):void 0}}}case"naddr":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for naddr");if(!e[2]?.[0])throw new Error("missing TLV 2 for naddr");if(32!==e[2][0].length)throw new Error("TLV 2 should be 32 bytes");if(!e[3]?.[0])throw new Error("missing TLV 3 for naddr");if(4!==e[3][0].length)throw new Error("TLV 3 should be 4 bytes");return{type:"naddr",data:{identifier:utf8Decoder.decode(e[0][0]),pubkey:bytesToHex$3(e[2][0]),kind:parseInt(bytesToHex$3(e[3][0]),16),relays:e[1]?e[1].map(e=>utf8Decoder.decode(e)):[]}}}case"nrelay":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for nrelay");return{type:"nrelay",data:utf8Decoder.decode(e[0][0])}}case"nsec":case"npub":case"note":return{type:t,data:bytesToHex$3(r)};default:throw new Error(`unknown prefix ${t}`)}}function parseTLV(e){let t={},n=e;for(;n.length>0;){let e=n[0],r=n[1];if(!r)throw new Error(`malformed TLV ${e}`);let i=n.slice(2,2+r);if(n=n.slice(2+r),i.length<r)throw new Error(`not enough data to read on TLV ${e}`);t[e]=t[e]||[],t[e].push(i)}return t}function nsecEncode(e){return encodeBytes("nsec",e)}function npubEncode(e){return encodeBytes("npub",e)}function noteEncode(e){return encodeBytes("note",e)}function encodeBech32(e,t){let n=bech32.toWords(t);return bech32.encode(e,n,Bech32MaxSize)}function encodeBytes(e,t){return encodeBech32(e,hexToBytes$3(t))}function nprofileEncode(e){return encodeBech32("nprofile",encodeTLV({0:[hexToBytes$3(e.pubkey)],1:(e.relays||[]).map(e=>utf8Encoder.encode(e))}))}function neventEncode(e){let t;return null!=e.kind&&(t=integerToUint8Array(e.kind)),encodeBech32("nevent",encodeTLV({0:[hexToBytes$3(e.id)],1:(e.relays||[]).map(e=>utf8Encoder.encode(e)),2:e.author?[hexToBytes$3(e.author)]:[],3:t?[new Uint8Array(t)]:[]}))}function naddrEncode(e){let t=new ArrayBuffer(4);return new DataView(t).setUint32(0,e.kind,!1),encodeBech32("naddr",encodeTLV({0:[utf8Encoder.encode(e.identifier)],1:(e.relays||[]).map(e=>utf8Encoder.encode(e)),2:[hexToBytes$3(e.pubkey)],3:[new Uint8Array(t)]}))}function nrelayEncode(e){return encodeBech32("nrelay",encodeTLV({0:[utf8Encoder.encode(e)]}))}function encodeTLV(e){let t=[];return Object.entries(e).forEach(([e,n])=>{n.forEach(n=>{let r=new Uint8Array(n.length+2);r.set([parseInt(e)],0),r.set([n.length],1),r.set(n,2),t.push(r)})}),concatBytes$4(...t)}var nip04_exports={};async function encrypt(e,t,n){const r=getNormalizedX(secp256k1$1.getSharedSecret(e,"02"+t));let i=Uint8Array.from(randomBytes$2(16)),s=utf8Encoder.encode(n),o=await crypto.subtle.importKey("raw",r,{name:"AES-CBC"},!1,["encrypt"]),a=await crypto.subtle.encrypt({name:"AES-CBC",iv:i},o,s);return`${base64.encode(new Uint8Array(a))}?iv=${base64.encode(new Uint8Array(i.buffer))}`}async function decrypt(e,t,n){let[r,i]=n.split("?iv="),s=getNormalizedX(secp256k1$1.getSharedSecret(e,"02"+t)),o=await crypto.subtle.importKey("raw",s,{name:"AES-CBC"},!1,["decrypt"]),a=base64.decode(r),c=base64.decode(i),l=await crypto.subtle.decrypt({name:"AES-CBC",iv:c},o,a);return utf8Decoder.decode(l)}function getNormalizedX(e){return e.slice(1,33)}__export(nip04_exports,{decrypt:()=>decrypt,encrypt:()=>encrypt}),"undefined"!=typeof crypto&&!crypto.subtle&&crypto.webcrypto&&(crypto.subtle=crypto.webcrypto.subtle);var nip05_exports={};__export(nip05_exports,{NIP05_REGEX:()=>NIP05_REGEX,queryProfile:()=>queryProfile,searchDomain:()=>searchDomain,useFetchImplementation:()=>useFetchImplementation});var NIP05_REGEX=/^(?:([\w.+-]+)@)?([\w.-]+)$/,_fetch;try{_fetch=fetch}catch{}function useFetchImplementation(e){_fetch=e}async function searchDomain(e,t=""){try{return(await(await _fetch(`https://${e}/.well-known/nostr.json?name=${t}`)).json()).names}catch(e){return{}}}async function queryProfile(e){const t=e.match(NIP05_REGEX);if(!t)return null;const[n,r="_",i]=t;try{const e=await _fetch(`https://${i}/.well-known/nostr.json?name=${r}`),{names:t,relays:n}=parseNIP05Result(await e.json()),s=t[r];return s?{pubkey:s,relays:n?.[s]}:null}catch(e){return null}}function parseNIP05Result(e){const t={names:{}};for(const[n,r]of Object.entries(e.names))"string"==typeof n&&"string"==typeof r&&(t.names[n]=r);if(e.relays){t.relays={};for(const[n,r]of Object.entries(e.relays))"string"==typeof n&&Array.isArray(r)&&(t.relays[n]=r.filter(e=>"string"==typeof e))}return t}var nip06_exports={};function privateKeyFromSeedWords(e,t){let n=HDKey.fromMasterSeed(mnemonicToSeedSync(e,t)).derive("m/44'/1237'/0'/0/0").privateKey;if(!n)throw new Error("could not derive private key");return bytesToHex$3(n)}function generateSeedWords(){return generateMnemonic(wordlist)}function validateWords(e){return validateMnemonic(e,wordlist)}__export(nip06_exports,{generateSeedWords:()=>generateSeedWords,privateKeyFromSeedWords:()=>privateKeyFromSeedWords,validateWords:()=>validateWords});var nip10_exports={};function parse(e){const t={reply:void 0,root:void 0,mentions:[],profiles:[]},n=[];for(const r of e.tags)"e"===r[0]&&r[1]&&n.push(r),"p"===r[0]&&r[1]&&t.profiles.push({pubkey:r[1],relays:r[2]?[r[2]]:[]});for(let e=0;e<n.length;e++){const r=n[e],[i,s,o,a]=r,c={id:s,relays:o?[o]:[]},l=0===e,h=e===n.length-1;"root"!==a?"reply"!==a?"mention"!==a?l?t.root=c:h?t.reply=c:t.mentions.push(c):t.mentions.push(c):t.reply=c:t.root=c}return t}__export(nip10_exports,{parse:()=>parse});var nip13_exports={};function getPow(e){let t=0;for(let n=0;n<e.length;n++){const r=parseInt(e[n],16);if(0!==r){t+=Math.clz32(r)-28;break}t+=4}return t}function minePow(e,t){let n=0;const r=e,i=["nonce",n.toString(),t.toString()];for(r.tags.push(i);;){const e=Math.floor((new Date).getTime()/1e3);if(e!==r.created_at&&(n=0,r.created_at=e),i[1]=(++n).toString(),r.id=getEventHash(r),getPow(r.id)>=t)break}return r}__export(nip13_exports,{getPow:()=>getPow,minePow:()=>minePow});var nip18_exports={};function finishRepostEvent(e,t,n,r){return finishEvent({kind:6,tags:[...e.tags??[],["e",t.id,n],["p",t.pubkey]],content:""===e.content?"":JSON.stringify(t),created_at:e.created_at},r)}function getRepostedEventPointer(e){if(6!==e.kind)return;let t,n;for(let r=e.tags.length-1;r>=0&&(void 0===t||void 0===n);r--){const i=e.tags[r];i.length>=2&&("e"===i[0]&&void 0===t?t=i:"p"===i[0]&&void 0===n&&(n=i))}return void 0!==t?{id:t[1],relays:[t[2],n?.[2]].filter(e=>"string"==typeof e),author:n?.[1]}:void 0}function getRepostedEvent(e,{skipVerification:t}={}){const n=getRepostedEventPointer(e);if(void 0===n||""===e.content)return;let r;try{r=JSON.parse(e.content)}catch(e){return}return r.id===n.id&&(t||verifySignature(r))?r:void 0}__export(nip18_exports,{finishRepostEvent:()=>finishRepostEvent,getRepostedEvent:()=>getRepostedEvent,getRepostedEventPointer:()=>getRepostedEventPointer});var nip21_exports={};__export(nip21_exports,{NOSTR_URI_REGEX:()=>NOSTR_URI_REGEX,parse:()=>parse2,test:()=>test});var NOSTR_URI_REGEX=new RegExp(`nostr:(${BECH32_REGEX.source})`);function test(e){return"string"==typeof e&&new RegExp(`^${NOSTR_URI_REGEX.source}$`).test(e)}function parse2(e){const t=e.match(new RegExp(`^${NOSTR_URI_REGEX.source}$`));if(!t)throw new Error(`Invalid Nostr URI: ${e}`);return{uri:t[0],value:t[1],decoded:decode(t[1])}}var nip25_exports={};function finishReactionEvent(e,t,n){const r=t.tags.filter(e=>e.length>=2&&("e"===e[0]||"p"===e[0]));return finishEvent({...e,kind:7,tags:[...e.tags??[],...r,["e",t.id],["p",t.pubkey]],content:e.content??"+"},n)}function getReactedEventPointer(e){if(7!==e.kind)return;let t,n;for(let r=e.tags.length-1;r>=0&&(void 0===t||void 0===n);r--){const i=e.tags[r];i.length>=2&&("e"===i[0]&&void 0===t?t=i:"p"===i[0]&&void 0===n&&(n=i))}return void 0!==t&&void 0!==n?{id:t[1],relays:[t[2],n[2]].filter(e=>void 0!==e),author:n[1]}:void 0}__export(nip25_exports,{finishReactionEvent:()=>finishReactionEvent,getReactedEventPointer:()=>getReactedEventPointer});var nip26_exports={};function createDelegation(e,t){let n=[];(t.kind||-1)>=0&&n.push(`kind=${t.kind}`),t.until&&n.push(`created_at<${t.until}`),t.since&&n.push(`created_at>${t.since}`);let r=n.join("&");if(""===r)throw new Error("refusing to create a delegation without any conditions");let i=sha256$3(utf8Encoder.encode(`nostr:delegation:${t.pubkey}:${r}`)),s=bytesToHex$3(schnorr.sign(i,e));return{from:getPublicKey(e),to:t.pubkey,cond:r,sig:s}}function getDelegator(e){let t=e.tags.find(e=>"delegation"===e[0]&&e.length>=4);if(!t)return null;let n=t[1],r=t[2],i=t[3],s=r.split("&");for(let t=0;t<s.length;t++){let[n,r,i]=s[t].split(/\b/);if(("kind"!==n||"="!==r||e.kind!==parseInt(i))&&!("created_at"===n&&"<"===r&&e.created_at<parseInt(i)||"created_at"===n&&">"===r&&e.created_at>parseInt(i)))return null}let o=sha256$3(utf8Encoder.encode(`nostr:delegation:${e.pubkey}:${r}`));return schnorr.verify(i,o,n)?n:null}__export(nip26_exports,{createDelegation:()=>createDelegation,getDelegator:()=>getDelegator});var nip27_exports={};__export(nip27_exports,{matchAll:()=>matchAll,regex:()=>regex,replaceAll:()=>replaceAll});var regex=()=>new RegExp(`\\b${NOSTR_URI_REGEX.source}\\b`,"g");function*matchAll(e){const t=e.matchAll(regex());for(const e of t)try{const[t,n]=e;yield{uri:t,value:n,decoded:decode(n),start:e.index,end:e.index+t.length}}catch(e){}}function replaceAll(e,t){return e.replaceAll(regex(),(e,n)=>t({uri:e,value:n,decoded:decode(n)}))}var nip28_exports={};__export(nip28_exports,{channelCreateEvent:()=>channelCreateEvent,channelHideMessageEvent:()=>channelHideMessageEvent,channelMessageEvent:()=>channelMessageEvent,channelMetadataEvent:()=>channelMetadataEvent,channelMuteUserEvent:()=>channelMuteUserEvent});var channelCreateEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:40,tags:[...e.tags??[]],content:n,created_at:e.created_at},t)},channelMetadataEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:41,tags:[["e",e.channel_create_event_id],...e.tags??[]],content:n,created_at:e.created_at},t)},channelMessageEvent=(e,t)=>{const n=[["e",e.channel_create_event_id,e.relay_url,"root"]];return e.reply_to_channel_message_event_id&&n.push(["e",e.reply_to_channel_message_event_id,e.relay_url,"reply"]),finishEvent({kind:42,tags:[...n,...e.tags??[]],content:e.content,created_at:e.created_at},t)},channelHideMessageEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:43,tags:[["e",e.channel_message_event_id],...e.tags??[]],content:n,created_at:e.created_at},t)},channelMuteUserEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:44,tags:[["p",e.pubkey_to_mute],...e.tags??[]],content:n,created_at:e.created_at},t)},nip39_exports={},_fetch2;__export(nip39_exports,{useFetchImplementation:()=>useFetchImplementation2,validateGithub:()=>validateGithub});try{_fetch2=fetch}catch{}function useFetchImplementation2(e){_fetch2=e}async function validateGithub(e,t,n){try{return await(await _fetch2(`https://gist.github.com/${t}/${n}/raw`)).text()===`Verifying that I control the following Nostr public key: ${e}`}catch(e){return!1}}var nip42_exports={};__export(nip42_exports,{authenticate:()=>authenticate});var authenticate=async({challenge:e,relay:t,sign:n})=>{const r={kind:22242,created_at:Math.floor(Date.now()/1e3),tags:[["relay",t.url],["challenge",e]],content:""};return t.auth(await n(r))},nip44_exports={};__export(nip44_exports,{decrypt:()=>decrypt2,encrypt:()=>encrypt2,utils:()=>utils});var utils={v2:{maxPlaintextSize:65408,minCiphertextSize:100,maxCiphertextSize:102400,getConversationKey:(e,t)=>secp256k1$1.getSharedSecret(e,"02"+t).subarray(1,33),getMessageKeys(e,t){const n=hkdf(sha256$3,e,t,"nip44-v2",76);return{encryption:n.subarray(0,32),nonce:n.subarray(32,44),auth:n.subarray(44,76)}},calcPadding(e){if(!Number.isSafeInteger(e)||e<0)throw new Error("expected positive integer");if(e<=32)return 32;const t=1<<Math.floor(Math.log2(e-1))+1,n=t<=256?32:t/8;return n*(Math.floor((e-1)/n)+1)},pad(e){const t=utf8Encoder.encode(e),n=t.length;if(n<1||n>=utils.v2.maxPlaintextSize)throw new Error("invalid plaintext length: must be between 1b and 64KB");const r=utils.v2.calcPadding(n),i=new Uint8Array(r-n),s=new Uint8Array(2);return new DataView(s.buffer).setUint16(0,n),concatBytes$4(s,t,i)},unpad(e){const t=new DataView(e.buffer).getUint16(0),n=e.subarray(2,2+t);if(0===t||n.length!==t||e.length!==2+utils.v2.calcPadding(t))throw new Error("invalid padding");return utf8Decoder.decode(n)}}};function encrypt2(e,t,n={}){const r=n.version??2;if(2!==r)throw new Error("unknown encryption version "+r);const i=n.salt??randomBytes$2(32);ensureBytes(i,32);const s=utils.v2.getMessageKeys(e,i),o=utils.v2.pad(t),a=chacha20(s.encryption,s.nonce,o),c=hmac$3(sha256$3,s.auth,a);return base64.encode(concatBytes$4(new Uint8Array([r]),i,a,c))}function decrypt2(e,t){const n=utils.v2;ensureBytes(e,32);const r=t.length;if(r<n.minCiphertextSize||r>=n.maxCiphertextSize)throw new Error("invalid ciphertext length: "+r);if("#"===t[0])throw new Error("unknown encryption version");let i;try{i=base64.decode(t)}catch(e){throw new Error("invalid base64: "+e.message)}const s=i.subarray(0,1)[0];if(2!==s)throw new Error("unknown encryption version "+s);const o=i.subarray(1,33),a=i.subarray(33,-32),c=i.subarray(-32),l=n.getMessageKeys(e,o);if(!equalBytes(hmac$3(sha256$3,l.auth,a),c))throw new Error("invalid MAC");const h=chacha20(l.encryption,l.nonce,a);return n.unpad(h)}var nip47_exports={};function parseConnectionString(e){const{pathname:t,searchParams:n}=new URL(e),r=t,i=n.get("relay"),s=n.get("secret");if(!r||!i||!s)throw new Error("invalid connection string");return{pubkey:r,relay:i,secret:s}}async function makeNwcRequestEvent({pubkey:e,secret:t,invoice:n}){const r={method:"pay_invoice",params:{invoice:n}},i=await encrypt(t,e,JSON.stringify(r));return finishEvent({kind:23194,created_at:Math.round(Date.now()/1e3),content:i,tags:[["p",e]]},t)}__export(nip47_exports,{makeNwcRequestEvent:()=>makeNwcRequestEvent,parseConnectionString:()=>parseConnectionString});var nip57_exports={},_fetch3;__export(nip57_exports,{getZapEndpoint:()=>getZapEndpoint,makeZapReceipt:()=>makeZapReceipt,makeZapRequest:()=>makeZapRequest,useFetchImplementation:()=>useFetchImplementation3,validateZapRequest:()=>validateZapRequest});try{_fetch3=fetch}catch{}function useFetchImplementation3(e){_fetch3=e}async function getZapEndpoint(e){try{let t="",{lud06:n,lud16:r}=JSON.parse(e.content);if(n){let{words:e}=bech32.decode(n,1e3),r=bech32.fromWords(e);t=utf8Decoder.decode(r)}else{if(!r)return null;{let[e,n]=r.split("@");t=`https://${n}/.well-known/lnurlp/${e}`}}let i=await _fetch3(t),s=await i.json();if(s.allowsNostr&&s.nostrPubkey)return s.callback}catch(e){}return null}function makeZapRequest({profile:e,event:t,amount:n,relays:r,comment:i=""}){if(!n)throw new Error("amount not given");if(!e)throw new Error("profile not given");let s={kind:9734,created_at:Math.round(Date.now()/1e3),content:i,tags:[["p",e],["amount",n.toString()],["relays",...r]]};return t&&s.tags.push(["e",t]),s}function validateZapRequest(e){let t;try{t=JSON.parse(e)}catch(e){return"Invalid zap request JSON."}if(!validateEvent(t))return"Zap request is not a valid Nostr event.";if(!verifySignature(t))return"Invalid signature on zap request.";let n=t.tags.find(([e,t])=>"p"===e&&t);if(!n)return"Zap request doesn't have a 'p' tag.";if(!n[1].match(/^[a-f0-9]{64}$/))return"Zap request 'p' tag is not valid hex.";let r=t.tags.find(([e,t])=>"e"===e&&t);return r&&!r[1].match(/^[a-f0-9]{64}$/)?"Zap request 'e' tag is not valid hex.":t.tags.find(([e,t])=>"relays"===e&&t)?null:"Zap request doesn't have a 'relays' tag."}function makeZapReceipt({zapRequest:e,preimage:t,bolt11:n,paidAt:r}){let i=JSON.parse(e).tags.filter(([e])=>"e"===e||"p"===e||"a"===e),s={kind:9735,created_at:Math.round(r.getTime()/1e3),content:"",tags:[...i,["bolt11",n],["description",e]]};return t&&s.tags.push(["preimage",t]),s}var nip98_exports={};__export(nip98_exports,{getToken:()=>getToken,unpackEventFromToken:()=>unpackEventFromToken,validateEvent:()=>validateEvent2,validateToken:()=>validateToken});var _authorizationScheme="Nostr ";async function getToken(e,t,n,r=!1){if(!e||!t)throw new Error("Missing loginUrl or httpMethod");const i=getBlankEvent(27235);i.tags=[["u",e],["method",t]],i.created_at=Math.round((new Date).getTime()/1e3);const s=await n(i);return(r?_authorizationScheme:"")+base64.encode(utf8Encoder.encode(JSON.stringify(s)))}async function validateToken(e,t,n){const r=await unpackEventFromToken(e).catch(e=>{throw e});return await validateEvent2(r,t,n).catch(e=>{throw e})}async function unpackEventFromToken(e){if(!e)throw new Error("Missing token");e=e.replace(_authorizationScheme,"");const t=utf8Decoder.decode(base64.decode(e));if(!t||0===t.length||!t.startsWith("{"))throw new Error("Invalid token");return JSON.parse(t)}async function validateEvent2(e,t,n){if(!e)throw new Error("Invalid nostr event");if(!verifySignature(e))throw new Error("Invalid nostr event, signature invalid");if(27235!==e.kind)throw new Error("Invalid nostr event, kind invalid");if(!e.created_at)throw new Error("Invalid nostr event, created_at invalid");if(Math.round((new Date).getTime()/1e3)-e.created_at>60)throw new Error("Invalid nostr event, expired");const r=e.tags.find(e=>"u"===e[0]);if(1!==r?.length&&r?.[1]!==t)throw new Error("Invalid nostr event, url tag invalid");const i=e.tags.find(e=>"method"===e[0]);if(1!==i?.length&&i?.[1].toLowerCase()!==n.toLowerCase())throw new Error("Invalid nostr event, method tag invalid");return!0}const LOCAL_STORE_KEY="__nostrlogin_nip46",LOGGED_IN_ACCOUNTS="__nostrlogin_accounts",RECENT_ACCOUNTS="__nostrlogin_recent",OUTBOX_RELAYS$1=["wss://purplepag.es","wss://relay.nos.social","wss://user.kindpag.es","wss://relay.damus.io","wss://nos.lol"],DEFAULT_SIGNUP_RELAYS=["wss://relay.damus.io/","wss://nos.lol/","wss://relay.primal.net/"],localStorageSetItem=(e,t)=>{localStorage.setItem(e,t)},localStorageGetItem=e=>{const t=window.localStorage.getItem(e);if(t)try{return JSON.parse(t)}catch{}return null},localStorageRemoveItem=e=>{localStorage.removeItem(e)},fetchProfile=async(e,t)=>{const n=new NDKUser({pubkey:e.pubkey});return n.ndk=t,await n.fetchProfile()},prepareSignupRelays=e=>{const t=(e||"").split(",").map(e=>e.trim()).filter(e=>e.startsWith("ws"));return t.length||t.push(...DEFAULT_SIGNUP_RELAYS),t},createProfile=async(e,t,n,r,i)=>{const s={name:e.name},o=new NDKEvent(t,{kind:0,created_at:Math.floor(Date.now()/1e3),pubkey:e.pubkey,content:JSON.stringify(s),tags:[]});window.location.hostname&&o.tags.push(["client",window.location.hostname]);const a=new NDKEvent(t,{kind:10002,created_at:Math.floor(Date.now()/1e3),pubkey:e.pubkey,content:"",tags:[]}),c=prepareSignupRelays(r);for(const e of c)a.tags.push(["r",e]);await o.sign(n),console.log("signed profile",o),await a.sign(n),console.log("signed relays",a);const l=i&&i.length?i:OUTBOX_RELAYS$1;await o.publish(NDKRelaySet.fromRelayUrls(l,t)),console.log("published profile",o),await a.publish(NDKRelaySet.fromRelayUrls(l,t)),console.log("published relays",a)},bunkerUrlToInfo=(e,t="")=>{const n=new URL(e);return{pubkey:"",signerPubkey:n.hostname||n.pathname.split("//")[1],sk:t||generatePrivateKey(),relays:n.searchParams.getAll("relay"),token:n.searchParams.get("secret")||"",authMethod:"connect"}},isBunkerUrl=e=>e.startsWith("bunker://"),getBunkerUrl=async(e,t)=>{if(!e)return"";if(isBunkerUrl(e))return e;if(e.includes("@")){const[n,r]=e.toLocaleLowerCase().split("@"),i=t.devOverrideBunkerOrigin||`https://${r}`,s=`${i}/.well-known/nostr.json?name=_`,o=`${i}/.well-known/nostr.json?name=${n}`,a=await fetch(s),c=await a.json(),l=c.names._,h=c.nip46[l],d=await fetch(o),u=(await d.json()).names[n];if(!h.length)throw new Error("Bunker relay not provided");return`bunker://${u}?relay=${h[0]}`}throw new Error("Invalid user name or bunker url")},checkNip05=async e=>{let t=!1,n="",r="";return await(async()=>{if(!e||!e.includes("@"))return;const[i,s]=e.toLocaleLowerCase().split("@");if(!i)return;if(!new RegExp(/^[\w-.]+@([\w-]+\.)+[\w-]{2,8}$/g).test(e))return void(n="Invalid name");if(!s)return void(n="Select service");const o=`https://${s}/.well-known/nostr.json?name=${i.toLowerCase()}`;try{const e=await fetch(o),t=await e.json();if(t.names[i])return void(r=t.names[i])}catch{}t=!0})(),{available:t,taken:""!=r,error:n,pubkey:r}},upgradeInfo=e=>{"typeAuthMethod"in e&&delete e.typeAuthMethod,e.authMethod||("extension"in e&&e.extension?e.authMethod="extension":"readOnly"in e&&e.readOnly?e.authMethod="readOnly":e.authMethod="connect"),e.nip05&&isBunkerUrl(e.nip05)&&(e.bunkerUrl=e.nip05,e.nip05=""),"connect"!==e.authMethod||e.signerPubkey||(e.signerPubkey=e.pubkey)},localStorageAddAccount=e=>{localStorageSetItem(LOCAL_STORE_KEY,JSON.stringify(e));const t=localStorageGetItem(LOGGED_IN_ACCOUNTS)||[],n=localStorageGetItem(RECENT_ACCOUNTS)||[];t.forEach(e=>upgradeInfo(e)),n.forEach(e=>upgradeInfo(e));const r=t,i=t.findIndex(t=>t.pubkey===e.pubkey&&t.authMethod===e.authMethod);-1!==i?r[i]=e:r.push(e);const s=n.filter(t=>t.pubkey!==e.pubkey||t.authMethod!==e.authMethod);localStorageSetItem(RECENT_ACCOUNTS,JSON.stringify(s)),localStorageSetItem(LOGGED_IN_ACCOUNTS,JSON.stringify(r))},localStorageRemoveCurrentAccount=()=>{const e=localStorageGetItem(LOCAL_STORE_KEY);if(!e)return;upgradeInfo(e);const t={...e};delete t.sk,delete t.otpData;const n=localStorageGetItem(LOGGED_IN_ACCOUNTS)||[],r=localStorageGetItem(RECENT_ACCOUNTS)||[];n.forEach(e=>upgradeInfo(e)),r.forEach(e=>upgradeInfo(e));const i=r;if("connect"===t.authMethod&&t.bunkerUrl&&t.bunkerUrl.includes("secret="))console.log("nostr login bunker conn with a secret not saved to recent");else if("local"===t.authMethod)console.log("nostr login temporary local keys not save to recent");else{const e=r.findIndex(e=>e.pubkey===t.pubkey&&e.authMethod===t.authMethod);-1!==e?i[e]=t:i.push(t)}const s=n.filter(t=>t.pubkey!==e.pubkey||t.authMethod!==e.authMethod);localStorageSetItem(RECENT_ACCOUNTS,JSON.stringify(i)),localStorageSetItem(LOGGED_IN_ACCOUNTS,JSON.stringify(s)),localStorageRemoveItem(LOCAL_STORE_KEY)},localStorageRemoveRecent=e=>{const t=localStorageGetItem(RECENT_ACCOUNTS)||[];t.forEach(e=>upgradeInfo(e));const n=t.filter(t=>t.pubkey!==e.pubkey||t.authMethod!==e.authMethod);localStorageSetItem(RECENT_ACCOUNTS,JSON.stringify(n))},localStorageGetRecents=()=>{const e=localStorageGetItem(RECENT_ACCOUNTS)||[];return e.forEach(e=>upgradeInfo(e)),e},localStorageGetAccounts=()=>{const e=localStorageGetItem(LOGGED_IN_ACCOUNTS)||[];return e.forEach(e=>upgradeInfo(e)),e},localStorageGetCurrent=()=>{const e=localStorageGetItem(LOCAL_STORE_KEY);return e&&upgradeInfo(e),e},getDarkMode=e=>{const t=localStorage.getItem("nl-dark-mode");return t?Boolean(JSON.parse(t)):void 0!==e.darkMode?e.darkMode:!(!window.matchMedia||!window.matchMedia("(prefers-color-scheme: dark)").matches)},getIcon=async()=>document.location.origin+"/favicon.ico";class NostrRpc extends NDKNostrRpc{_ndk;_signer;requests=new Set;sub;_useNip44=!1;constructor(e,t){super(e,t,e.debug.extend("nip46:signer:rpc")),this._ndk=e,this._signer=t}async subscribe(e){return e.kinds=e.kinds?.filter(e=>24133===e),this.sub=await super.subscribe(e),this.sub}stop(){this.sub&&(this.sub.stop(),this.sub=void 0)}setUseNip44(e){this._useNip44=e}isNip04(e){const t=e.length;return!(t<28)&&("?"===e[t-28]&&"i"===e[t-27]&&"v"===e[t-26]&&"="===e[t-25])}async parseEvent(e){const t=this._ndk.getUser({pubkey:e.pubkey});t.ndk=this._ndk;const n=this.isNip04(e.content)?await this._signer.decrypt(t,e.content,"nip04"):await this._signer.decrypt(t,e.content,"nip44"),r=JSON.parse(n),{id:i,method:s,params:o,result:a,error:c}=r;return s?{id:i,pubkey:e.pubkey,method:s,params:o,event:e}:{id:i,result:a,error:c,event:e}}async parseNostrConnectReply(e,t){const n=new NDKEvent(this._ndk,e),r=await this.parseEvent(n);if(console.log("nostr connect parsedEvent",r),r.method)throw new Error("Bad nostr connect reply");{const e=r;if(e.result!==t)throw new Error(e.error);return n.pubkey}}async listen(e){const t=this._signer.pubkey;console.log("nostr-login listening for conn to",t);const n=await this.subscribe({kinds:[24133],"#p":[t]});return new Promise((t,r)=>{n.on("event",async n=>{try{const i=await this.parseEvent(n);if(!i.method){const s=i;if("auth_url"===s.result)return;"ack"===s.result||s.result===e?t(n.pubkey):r(s.error)}}catch(e){console.log("error parsing event",e,n.rawEvent())}this.stop()})})}async connect(e,t,n){return new Promise((r,i)=>{const s=[e,t||"",n||""];this.sendRequest(e,"connect",s,24133,e=>{"ack"===e.result?r():i(e.error)})})}getId(){return Math.random().toString(36).substring(7)}async sendRequest(e,t,n=[],r=24133,i){const s=this.getId();this.setResponseHandler(s,i);const o=await this.createRequestEvent(s,e,t,n,r);console.log("sendRequest",{event:o,method:t,remotePubkey:e,params:n}),await o.publish()}setResponseHandler(e,t){let n=!1;const r=Date.now();return new Promise(()=>{const i=s=>{"auth_url"===s.result?(this.once(`response-${e}`,i),n||(n=!0,this.emit("authUrl",s.error))):t&&this.requests.has(e)&&(this.requests.delete(e),console.log("nostr-login processed nip46 request in",Date.now()-r,"ms"),t(s))};this.once(`response-${e}`,i)})}async createRequestEvent(e,t,n,r=[],i=24133){this.requests.add(e);const s=await this._signer.user(),o=this._ndk.getUser({pubkey:t}),a={id:e,method:n,params:r},c=new NDKEvent(this._ndk,{kind:i,content:JSON.stringify(a),tags:[["p",t]],pubkey:s.pubkey}),l=this._useNip44&&"create_account"!==n;return c.content=l?await this._signer.encrypt(o,c.content,"nip44"):await this._signer.encrypt(o,c.content,"nip04"),await c.sign(this._signer),c}}class IframeNostrRpc extends NostrRpc{peerOrigin;iframePort;iframeRequests=new Map;constructor(e,t,n){super(e,t),this._ndk=e,this.peerOrigin=n}async subscribe(e){return this.peerOrigin?new NDKSubscription(this._ndk,{},{closeOnEose:!0,cacheUsage:NDKSubscriptionCacheUsage.ONLY_CACHE}):super.subscribe(e)}setWorkerIframePort(e){if(!this.peerOrigin)throw new Error("Unexpected iframe port");this.iframePort=e,setInterval(()=>{console.log("iframe-nip46 ping"),this.iframePort.postMessage("ping")},5e3),e.onmessage=async e=>{if(console.log("iframe-nip46 got response",e.data),"string"==typeof e.data&&e.data.startsWith("errorNoKey")){const t=e.data.split(":")[1],{id:n="",pubkey:r=""}=this.iframeRequests.get(t)||{};return void(n&&r&&this.requests.has(n)&&this.emit(`iframeRestart-${r}`))}try{const t=e.data;if(!validateEvent(t))throw new Error("Invalid event from iframe");if(!verifySignature(t))throw new Error("Invalid event signature from iframe");const n=new NDKEvent(this._ndk,t),r=await this.parseEvent(n);r.method||(console.log("parsed response",r),this.emit(`response-${r.id}`,r))}catch(t){console.log("error parsing event",t,e.data)}}}async sendRequest(e,t,n=[],r=24133,i){const s=this.getId(),o=await this.createRequestEvent(s,e,t,n,r);this.setResponseHandler(s,i),this.iframePort?(this.iframeRequests.set(o.id,{id:s,pubkey:e}),console.log("iframe-nip46 sending request to",this.peerOrigin,o.rawEvent()),this.iframePort.postMessage(o.rawEvent())):await o.publish()}}class ReadyListener{origin;messages;promise;constructor(e,t){this.origin=t,this.messages=e,this.promise=new Promise(e=>{console.log(new Date,"started listener for",this.messages);const n=async r=>{const i=new URL(t).hostname,s=new URL(r.origin).hostname;(s===i||s.endsWith("."+i))&&Array.isArray(r.data)&&r.data.length&&this.messages.includes(r.data[0])&&(console.log(new Date,"got ready message from",r.origin,r.data),window.removeEventListener("message",n),e(r.data))};window.addEventListener("message",n)})}async wait(){console.log(new Date,"waiting for",this.messages);const e=await this.promise;return console.log(new Date,"finished waiting for",this.messages,e),e}}class Nip46Signer extends NDKNip46Signer{_rpc;_remotePubkey="";constructor(e,t,n,r){super(e,n,t),this._remotePubkey=n,this._rpc=new IframeNostrRpc(e,t,r),this._rpc.setUseNip44(!0),this._rpc.on("authUrl",e=>{this.emit("authUrl",e)}),this.rpc=this._rpc}get remotePubkey(){return this._remotePubkey}set remotePubkey(e){this._remotePubkey=e}async setSignerPubkey(e,t=!1){console.log("setSignerPubkey",e),this.remotePubkey=e,this._rpc.on(`iframeRestart-${e}`,()=>{this.emit("iframeRestart")}),await this.initUserPubkey(t?e:"")}async initUserPubkey(e){if(this.userPubkey)throw new Error("Already called initUserPubkey");this.userPubkey=e||await new Promise((e,t)=>{if(!this.remotePubkey)throw new Error("Signer pubkey not set");console.log("get_public_key",this.remotePubkey),this._rpc.sendRequest(this.remotePubkey,"get_public_key",[],24133,t=>{e(t.result)})})}async listen(e){const t=await this.rpc.listen(e);await this.setSignerPubkey(t)}async connect(e,t){if(!this.remotePubkey)throw new Error("No signer pubkey");await this._rpc.connect(this.remotePubkey,e,t),await this.setSignerPubkey(this.remotePubkey)}async setListenReply(e,t){const n=await this._rpc.parseNostrConnectReply(e,t);await this.setSignerPubkey(n,!0)}async createAccount2({bunkerPubkey:e,name:t,domain:n,perms:r=""}){const i=[t,n,"",r],s=await new Promise(t=>{this.rpc.sendRequest(e,"create_account",i,void 0,t)});if(console.log("create_account pubkey",s),"error"===s.result)throw new Error(s.error);return s.result}}class BannerManager extends lib$1.EventEmitter{banner=null;iframeReady;params;constructor(e){super(),this.params=e}onAuthUrl(e,t){this.banner&&(this.banner.notify=e?{mode:t?"iframeAuthUrl":"authUrl",url:e}:{mode:""})}onIframeRestart(e){this.banner&&(this.iframeReady=new ReadyListener(["rebinderDone","rebinderError"],new URL(e).origin),this.banner.notify={mode:"rebind",url:e})}onUserInfo(e){this.banner&&(this.banner.userInfo=e)}onCallTimeout(){this.banner&&(this.banner.notify={mode:"timeout"})}onCallStart(){this.banner&&(this.banner.isLoading=!0)}async onCallEnd(){this.banner&&(this.iframeReady&&(await this.iframeReady.wait(),this.iframeReady=void 0),this.banner.isLoading=!1,this.banner.notify={mode:""})}onUpdateAccounts(e){this.banner&&(this.banner.accounts=e)}onDarkMode(e){this.banner&&(this.banner.darkMode=e)}launchAuthBanner(e){this.banner=document.createElement("nl-banner"),this.banner.setAttribute("dark-mode",String(getDarkMode(e))),e.theme&&this.banner.setAttribute("theme",e.theme),e.noBanner&&this.banner.setAttribute("hidden-mode","true"),this.banner.addEventListener("handleLoginBanner",e=>{this.emit("launch",e.detail)}),this.banner.addEventListener("handleConfirmLogout",()=>{this.emit("onConfirmLogout")}),this.banner.addEventListener("handleLogoutBanner",async()=>{this.emit("logout")}),this.banner.addEventListener("handleImportModal",e=>{this.emit("import")}),this.banner.addEventListener("handleNotifyConfirmBanner",e=>{this.emit("onAuthUrlClick",e.detail)}),this.banner.addEventListener("handleNotifyConfirmBannerIframe",e=>{this.emit("onIframeAuthUrlClick",e.detail)}),this.banner.addEventListener("handleSwitchAccount",e=>{this.emit("onSwitchAccount",e.detail)}),this.banner.addEventListener("handleOpenWelcomeModal",()=>{this.emit("launch"),this.banner&&(this.banner.isOpen=!1)}),document.body.appendChild(this.banner)}}const decoder=new TextDecoder,u={minPlaintextSize:1,maxPlaintextSize:65535,utf8Encode:utf8ToBytes$6,utf8Decode:e=>decoder.decode(e),getConversationKey(e,t){const n=secp256k1$1.getSharedSecret(e,"02"+t).subarray(1,33);return extract(sha256$3,n,"nip44-v2")},getMessageKeys(e,t){const n=expand(sha256$3,e,t,76);return{chacha_key:n.subarray(0,32),chacha_nonce:n.subarray(32,44),hmac_key:n.subarray(44,76)}},calcPaddedLen(e){if(!Number.isSafeInteger(e)||e<1)throw new Error("expected positive integer");if(e<=32)return 32;const t=1<<Math.floor(Math.log2(e-1))+1,n=t<=256?32:t/8;return n*(Math.floor((e-1)/n)+1)},writeU16BE(e){if(!Number.isSafeInteger(e)||e<u.minPlaintextSize||e>u.maxPlaintextSize)throw new Error("invalid plaintext size: must be between 1 and 65535 bytes");const t=new Uint8Array(2);return new DataView(t.buffer).setUint16(0,e,!1),t},pad(e){const t=u.utf8Encode(e),n=t.length;return concatBytes$4(u.writeU16BE(n),t,new Uint8Array(u.calcPaddedLen(n)-n))},unpad(e){const t=new DataView(e.buffer).getUint16(0),n=e.subarray(2,2+t);if(t<u.minPlaintextSize||t>u.maxPlaintextSize||n.length!==t||e.length!==2+u.calcPaddedLen(t))throw new Error("invalid padding");return u.utf8Decode(n)},hmacAad(e,t,n){if(32!==n.length)throw new Error("AAD associated data must be 32 bytes");const r=concatBytes$4(n,t);return hmac$3(sha256$3,e,r)},decodePayload(e){if("string"!=typeof e)throw new Error("payload must be a valid string");const t=e.length;if(t<132||t>87472)throw new Error("invalid payload length: "+t);if("#"===e[0])throw new Error("unknown encryption version");let n;try{n=base64.decode(e)}catch(e){throw new Error("invalid base64: "+e.message)}const r=n.length;if(r<99||r>65603)throw new Error("invalid data length: "+r);const i=n[0];if(2!==i)throw new Error("unknown encryption version "+i);return{nonce:n.subarray(1,33),ciphertext:n.subarray(33,-32),mac:n.subarray(-32)}}};function encryptNip44(e,t,n=randomBytes$2(32)){const{chacha_key:r,chacha_nonce:i,hmac_key:s}=u.getMessageKeys(t,n),o=u.pad(e),a=chacha20(r,i,o),c=u.hmacAad(s,a,n);return base64.encode(concatBytes$4(new Uint8Array([2]),n,a,c))}function decryptNip44(e,t){const{nonce:n,ciphertext:r,mac:i}=u.decodePayload(e),{chacha_key:s,chacha_nonce:o,hmac_key:a}=u.getMessageKeys(t,n);if(!equalBytes(u.hmacAad(a,r,n),i))throw new Error("invalid MAC");const c=chacha20(s,o,r);return u.unpad(c)}class Nip44{cache=new Map;createKey(e,t){return u.getConversationKey(e,t)}getKey(e,t,n){const r=getPublicKey(e)+t;let i=this.cache.get(r);if(i)return i;const s=this.createKey(e,t);return this.cache.set(r,s),s}encrypt(e,t,n){return encryptNip44(n,this.getKey(e,t))}decrypt(e,t,n){return decryptNip44(n,this.getKey(e,t))}}const OUTBOX_RELAYS=["wss://user.kindpag.es","wss://purplepag.es","wss://relay.nos.social"],DEFAULT_NOSTRCONNECT_RELAYS=["wss://relay.nsec.app/","wss://ephemeral.snowflare.cc/"],CONNECT_TIMEOUT=1e4,NOSTRCONNECT_APPS=[{name:"Nsec.app",domain:"nsec.app",canImport:!0,img:"https://nsec.app/assets/favicon.ico",link:"https://use.nsec.app/<nostrconnect>",relays:DEFAULT_NOSTRCONNECT_RELAYS},{name:"Amber",img:"https://raw.githubusercontent.com/greenart7c3/Amber/refs/heads/master/assets/android-icon.svg",link:"<nostrconnect>",relays:DEFAULT_NOSTRCONNECT_RELAYS},{name:"Other key stores",img:"",link:"<nostrconnect>",relays:DEFAULT_NOSTRCONNECT_RELAYS}];class AuthNostrService extends lib$1.EventEmitter{ndk;profileNdk;signer=null;localSigner=null;params;signerPromise;signerErrCallback;readyPromise;readyCallback;nip44Codec=new Nip44;nostrConnectKey="";nostrConnectSecret="";iframe;starterReady;nip04;nip44;constructor(e){super(),this.params=e,this.ndk=new NDK({enableOutboxModel:!1}),this.profileNdk=new NDK({enableOutboxModel:!0,explicitRelayUrls:OUTBOX_RELAYS}),this.profileNdk.connect(CONNECT_TIMEOUT),this.nip04={encrypt:this.encrypt04.bind(this),decrypt:this.decrypt04.bind(this)},this.nip44={encrypt:this.encrypt44.bind(this),decrypt:this.decrypt44.bind(this)}}isIframe(){return!!this.iframe}async waitReady(){if(this.signerPromise)try{await this.signerPromise}catch{}if(this.readyPromise)try{await this.readyPromise}catch{}}cancelNostrConnect(){this.releaseSigner(),this.resetAuth()}async nostrConnect(e,{domain:t="",link:n="",iframeUrl:r="",importConnect:i=!1}={}){e=e&&e.length>0?e:DEFAULT_NOSTRCONNECT_RELAYS;const s={authMethod:"connect",pubkey:"",signerPubkey:"",sk:this.nostrConnectKey,domain:t,relays:e,iframeUrl:r};if(console.log("nostrconnect info",s,n),n&&!r&&window.open(n,"_blank","width=400,height=700"),await this.initSigner(s,{listen:!0}),!s.pubkey||!s.signerPubkey)throw new Error("Bad remote pubkey");return s.bunkerUrl=`bunker://${s.signerPubkey}?${e.map((e,t)=>`${0!==t?"&":""}relay=${e}`)}`,i||this.onAuth("login",s),s}async createNostrConnect(e){this.nostrConnectKey=generatePrivateKey(),this.nostrConnectSecret=Math.random().toString(36).substring(7);const t=getPublicKey(this.nostrConnectKey),n=encodeURIComponent(document.location.host),r=encodeURIComponent(document.location.origin),i=encodeURIComponent(await getIcon()),s=encodeURIComponent(this.params.optionsModal.perms||""),o=(e||[]).length>0?(e||[]).map(e=>`&relay=${encodeURIComponent(e)}`).join(""):"";return`nostrconnect://${t}?image=${i}&url=${r}&name=${n}&perms=${s}&secret=${this.nostrConnectSecret}${o}`}async getNostrConnectServices(){const e=await this.createNostrConnect(DEFAULT_NOSTRCONNECT_RELAYS),t=NOSTRCONNECT_APPS.map(e=>({...e}));for(const n of t){let t=[...DEFAULT_NOSTRCONNECT_RELAYS];if(n.link.startsWith("https://")){const e=n.domain||new URL(n.link).hostname;try{const r=await(await fetch(`https://${e}/.well-known/nostr.json`)).json(),i=r.names._,s=r.nip46?.[i];Array.isArray(s)&&s.length>0&&(t=s),n.iframeUrl=r.nip46?.iframe_url||""}catch(e){console.log("Bad app info",e,n)}}const r=e.split("&relay=")[0]+t.map(e=>`&relay=${encodeURIComponent(e)}`).join("");n.link=n.iframeUrl?r:n.link.replace("<nostrconnect>",r)}return[e,t]}async localSignup(e,t){const n=!t,r={pubkey:getPublicKey(t=t||generatePrivateKey()),sk:t,name:e,authMethod:"local"};console.log(`localSignup name: ${e}`),await this.setLocal(r,n)}async setLocal(e,t){this.releaseSigner(),this.localSigner=new NDKPrivateKeySigner(e.sk),t&&await createProfile(e,this.profileNdk,this.localSigner,this.params.optionsModal.signupRelays,this.params.optionsModal.outboxRelays),this.onAuth(t?"signup":"login",e)}prepareImportUrl(e){if("otp"===this.params.userInfo?.authMethod)return e+"&import=true";if(!this.localSigner||"local"!==this.params.userInfo?.authMethod)throw new Error("Most be local keys");return e+"#import="+nip19_exports.nsecEncode(this.localSigner.privateKey)}async importAndConnect(e){const{relays:t,domain:n,link:r,iframeUrl:i}=e;if(!n)throw new Error("Domain required");const s=await this.nostrConnect(t,{domain:n,link:r,importConnect:!0,iframeUrl:i});await this.logout(!0),this.localSigner=null,this.onAuth("login",s)}setReadOnly(e){const t={pubkey:e,authMethod:"readOnly"};this.onAuth("login",t)}setExtension(e){const t={pubkey:e,authMethod:"extension"};this.onAuth("login",t)}setOTP(e,t){const n={pubkey:e,authMethod:"otp",otpData:t};this.onAuth("login",n)}async setConnect(e){this.releaseSigner(),await this.startAuth(),await this.initSigner(e),this.onAuth("login",e),await this.endAuth()}async createAccount(e){const[t,n]=e.split("@"),r=await getBunkerUrl(`_@${n}`,this.params.optionsModal);console.log("create account bunker's url",r);const i=bunkerUrlToInfo(r);if(!i.signerPubkey)throw new Error("Bad bunker url");const s=Boolean(this.params.userInfo);await this.initSigner(i,{eventToAddAccount:s});return{bunkerUrl:`bunker://${await this.signer.createAccount2({bunkerPubkey:i.signerPubkey,name:t,domain:n,perms:this.params.optionsModal.perms})}?`+(i.relays??[]).map(e=>`relay=${encodeURIComponent(e)}`).join("&"),sk:i.sk}}releaseSigner(){this.signer=null,this.signerErrCallback?.("cancelled"),this.localSigner=null;for(const e of this.ndk.pool.relays.keys())this.ndk.pool.removeRelay(e)}async logout(e=!1){e||this.releaseSigner(),localStorageRemoveCurrentAccount(),this.onAuth("logout"),this.emit("updateAccounts")}setUserInfo(e){this.params.userInfo=e,this.emit("onUserInfo",e),e&&(localStorageAddAccount(e),this.emit("updateAccounts"))}exportKeys(){return this.params.userInfo?"local"!==this.params.userInfo.authMethod?"":nip19_exports.nsecEncode(this.params.userInfo.sk):""}onAuth(e,t=null){if("logout"!==e&&!t)throw new Error("No user info in onAuth");if(t&&this.params.userInfo&&(t.pubkey!==this.params.userInfo.pubkey||t.authMethod!==this.params.userInfo.authMethod)){const e=new CustomEvent("nlAuth",{detail:{type:"logout"}});console.log("nostr-login auth",e.detail),document.dispatchEvent(e)}this.setUserInfo(t),t&&fetchProfile(t,this.profileNdk).then(e=>{if(this.params.userInfo!==t)return;const n={...this.params.userInfo,picture:e?.image||e?.picture,name:e?.name||e?.displayName||e?.nip05||nip19_exports.npubEncode(t.pubkey)};this.setUserInfo(n)});try{const n=t?nip19_exports.npubEncode(t.pubkey):"",r={type:e};"logout"===e?(this.iframe&&this.iframe.remove(),this.iframe=void 0):(r.pubkey=t.pubkey,r.name=t.name,t.sk&&(r.localNsec=nip19_exports.nsecEncode(t.sk)),t.relays&&(r.relays=t.relays),t.otpData&&(r.otpData=t.otpData),r.method=t.authMethod||"connect");const i=new CustomEvent("nlAuth",{detail:r});console.log("nostr-login auth",r),document.dispatchEvent(i),this.params.optionsModal.onAuth&&this.params.optionsModal.onAuth(n,r)}catch(e){console.log("onAuth error",e)}}async createIframe(e){if(!e)return;const t=new URL(e);let n;const r="__nostr-login-worker-iframe-"+t.hostname.replaceAll(".","-");n=document.querySelector(`#${r}`),console.log("iframe",r,n),n||(n=document.createElement("iframe"),n.setAttribute("width","0"),n.setAttribute("height","0"),n.setAttribute("border","0"),n.style.display="none",n.id=r,document.body.append(n)),n.setAttribute("src",e);const i=new ReadyListener(["workerReady","workerError"],t.origin);await new Promise(e=>{n.addEventListener("load",e)});const s=await i.wait();return console.log("nostr-login iframe ready",e,s),{iframe:n,port:s[1]}}async sendNeedAuth(){const[e]=await this.getNostrConnectServices(),t=new CustomEvent("nlNeedAuth",{detail:{nostrconnect:e}});console.log("nostr-login need auth",e),document.dispatchEvent(t)}isAuthing(){return!!this.readyCallback}async startAuth(){if(console.log("startAuth"),this.readyCallback)throw new Error("Already started");this.readyPromise=new Promise(e=>this.readyCallback=e)}async endAuth(){if(console.log("endAuth",this.params.userInfo),this.params.userInfo&&this.params.userInfo.iframeUrl){const{iframe:e,port:t}=await this.createIframe(this.params.userInfo.iframeUrl)||{};if(this.iframe=e,!this.iframe||!t)return;this.signer.rpc.setWorkerIframePort(t)}this.readyCallback(),this.readyCallback=void 0}resetAuth(){this.readyCallback&&this.readyCallback(),this.readyCallback=void 0}async listen(e){if(!e.iframeUrl)return this.signer.listen(this.nostrConnectSecret);const t=await this.starterReady.wait();if("starterError"===t[0])throw new Error(t[1]);return this.signer.setListenReply(t[1],this.nostrConnectSecret)}async connect(e,t){return this.signer.connect(e.token,t)}async initSigner(e,{listen:t=!1,connect:n=!1,eventToAddAccount:r=!1}={}){if(this.signerPromise)try{await this.signerPromise}catch{}console.log("initSigner info",e);const i=e.iframeUrl?new URL(e.iframeUrl).origin:void 0;return i&&(this.starterReady=new ReadyListener(["starterDone","starterError"],i)),this.emit("onIframeUrl",e.iframeUrl),this.signerPromise=new Promise(async(s,o)=>{this.signerErrCallback=o;try{if(console.log("NDK relays before connect:",Array.from(this.ndk.pool.relays.keys())),e.relays&&!e.iframeUrl)for(const t of e.relays)this.ndk.addExplicitRelay(t,void 0),console.log("Added relay:",t);console.log("NDK relays after add:",Array.from(this.ndk.pool.relays.keys())),this.ndk.connect(CONNECT_TIMEOUT).catch(e=>{console.log("Some relays failed to connect, continuing anyway:",e)}),await new Promise((e,t)=>{const n=()=>{Array.from(this.ndk.pool.relays.values()).filter(e=>3===e.status).length>0?e():setTimeout(n,100)};setTimeout(()=>{Array.from(this.ndk.pool.relays.values()).filter(e=>3===e.status).length>0?e():t(new Error("No relays connected"))},CONNECT_TIMEOUT);n()}),console.log("NDK connected relays:",Array.from(this.ndk.pool.relays.entries()).map(([e,t])=>({url:e,status:t.status})));const o=new NDKPrivateKeySigner(e.sk);this.signer=new Nip46Signer(this.ndk,o,e.signerPubkey,i),this.signer.on("iframeRestart",async()=>{const t=e.iframeUrl+(e.iframeUrl.includes("?")?"&":"?")+"pubkey="+e.pubkey+"&rebind="+o.pubkey;this.emit("iframeRestart",{pubkey:e.pubkey,iframeUrl:t})}),this.signer.on("authUrl",t=>{console.log("nostr login auth url",t),this.emit("onAuthUrl",{url:t,iframeUrl:e.iframeUrl,eventToAddAccount:r})}),t?await this.listen(e):n?await this.connect(e,this.params.optionsModal.perms):await this.signer.initUserPubkey(e.pubkey),e.pubkey=this.signer.userPubkey,e.signerPubkey=this.signer.remotePubkey,s()}catch(e){console.log("initSigner failure",e),this.signer=null,o(e)}}),this.signerPromise}async authNip46(e,{name:t,bunkerUrl:n,sk:r="",domain:i="",iframeUrl:s=""}){try{const o=bunkerUrlToInfo(n,r);if(isBunkerUrl(t)?o.bunkerUrl=t:(o.nip05=t,o.domain=t.split("@")[1]),i&&(o.domain=i),s&&(o.iframeUrl=s),!o.signerPubkey||!o.sk||!o.relays||0===o.relays.length)throw new Error(`Bad bunker url ${n}`);const a=Boolean(this.params.userInfo);console.log("authNip46",e,o),await this.initSigner(o,{connect:!0,eventToAddAccount:a}),this.onAuth(e,o)}catch(e){throw console.log("nostr login auth failed",e),e}}async signEvent(e){const t=(async()=>(this.localSigner?(e.pubkey=getPublicKey(this.localSigner.privateKey),e.id=getEventHash(e),e.sig=await this.localSigner.sign(e)):(e.pubkey=this.signer?.remotePubkey,e.id=getEventHash(e),e.sig=await(this.signer?.sign(e))),e))(),n=new Promise((e,t)=>{setTimeout(()=>t(new Error("Sign timeout")),2e4)}),r=await Promise.race([t,n]);return console.log("signed",{event:r}),r}async codec_call(e,t,n){return new Promise((r,i)=>{this.signer.rpc.sendRequest(this.signer.remotePubkey,e,[t,n],24133,e=>{e.error?i(e.error):r(e.result)})})}async encrypt04(e,t){return this.localSigner?this.localSigner.encrypt(new NDKUser({pubkey:e}),t):this.signer.encrypt(new NDKUser({pubkey:e}),t)}async decrypt04(e,t){return this.localSigner?this.localSigner.decrypt(new NDKUser({pubkey:e}),t):this.codec_call("nip04_decrypt",e,t)}async encrypt44(e,t){return this.localSigner?this.nip44Codec.encrypt(this.localSigner.privateKey,e,t):this.codec_call("nip44_encrypt",e,t)}async decrypt44(e,t){return this.localSigner?this.nip44Codec.decrypt(this.localSigner.privateKey,e,t):this.codec_call("nip44_decrypt",e,t)}}class ModalManager extends lib$1.EventEmitter{modal=null;params;extensionService;authNostrService;launcherPromise;accounts=[];recents=[];opt;constructor(e,t,n){super(),this.params=e,this.extensionService=n,this.authNostrService=t}async waitReady(){if(this.launcherPromise){try{await this.launcherPromise}catch{}this.launcherPromise=void 0}}async launch(e){console.log("nostr-login launch",e),this.launcherPromise&&await this.waitReady(),this.authNostrService.isAuthing()&&this.authNostrService.resetAuth(),this.opt=e;const t=document.createElement("dialog");if(this.modal=document.createElement("nl-auth"),this.modal.accounts=this.accounts,this.modal.recents=this.recents,this.modal.setAttribute("dark-mode",String(getDarkMode(e))),e.theme&&this.modal.setAttribute("theme",e.theme),e.startScreen&&this.modal.setAttribute("start-screen",e.startScreen),e.bunkers)this.modal.setAttribute("bunkers",e.bunkers);else{let e="nsec.app,highlighter.com";this.modal.setAttribute("bunkers",e)}void 0!==e.methods&&(this.modal.authMethods=e.methods),void 0!==e.localSignup&&(this.modal.localSignup=e.localSignup),void 0!==e.signupNstart&&(this.modal.signupNjump=e.signupNstart),e.title&&(this.modal.welcomeTitle=e.title),e.description&&(this.modal.welcomeDescription=e.description),this.modal.hasExtension=this.extensionService.hasExtension(),this.modal.hasOTP=!!e.otpRequestUrl&&!!e.otpReplyUrl,this.modal.isLoadingExtension=!1,this.modal.isLoading=!1,[this.modal.connectionString,this.modal.connectionStringServices]=await this.authNostrService.getNostrConnectServices(),t.appendChild(this.modal),document.body.appendChild(t);let n="";return this.launcherPromise=new Promise((e,r)=>{t.addEventListener("close",()=>{r(new Error("Closed")),this.authNostrService.resetAuth(),this.modal&&(document.body.removeChild(this.modal.parentNode),this.modal=null)});const i=async e=>{this.modal&&(this.modal.isLoading=!1),await this.authNostrService.endAuth(),t.close(),this.modal=null,e()},s=async(t,n)=>{this.modal&&(this.modal.isLoading=!0);try{n&&!n.start||await this.authNostrService.startAuth(),await t(),n&&!n.end||await i(e)}catch(e){console.log("error",e),this.modal&&(this.modal.isLoading=!1,this.modal.authUrl="",this.modal.iframeUrl="","cancelled"!==e&&(this.modal.error=e.toString()))}},o=async(e,t)=>{await s(async()=>{const n=await getBunkerUrl(e,this.params.optionsModal);await this.authNostrService.authNip46("login",{name:e,bunkerUrl:n,domain:t})})},a=async e=>{await s(async()=>{const{bunkerUrl:t,sk:n}=await this.authNostrService.createAccount(e);await this.authNostrService.authNip46("signup",{name:e,bunkerUrl:t,sk:n})})},c=async()=>{try{await navigator.clipboard.writeText(this.authNostrService.exportKeys()),localStorageSetItem("backupKey","true")}catch(e){console.error("Failed to copy to clipboard: ",e)}},l=async e=>{await s(async()=>{const{iframeUrl:t}=e;e.link=this.authNostrService.prepareImportUrl(e.link),this.modal&&t&&(this.modal.authUrl=e.link,this.modal.iframeUrl=t,this.modal.isLoading=!1,console.log("nostrconnect authUrl",this.modal.authUrl,this.modal.iframeUrl)),await this.authNostrService.importAndConnect(e)})},h=async e=>{await s(async()=>{const{relays:t,domain:n,link:r,iframeUrl:i}=e||{};console.log("nostrConnect",e,t,n,r,i),this.modal&&(i&&(this.modal.authUrl=r,this.modal.iframeUrl=i,this.modal.isLoading=!1,console.log("nostrconnect authUrl",this.modal.authUrl,this.modal.iframeUrl)),e||(this.modal.isLoading=!1)),await this.authNostrService.nostrConnect(t,{domain:n,link:r,iframeUrl:i})})},d=async e=>{await s(async()=>{if(!e)throw new Error("Please enter some nickname");await this.authNostrService.localSignup(e)})},u=async()=>{await s(async()=>{const e=new URL(window.location.href),t=e.hostname.toLocaleLowerCase().replace(/^www\./i,"").charAt(0).toUpperCase()+e.hostname.slice(1),n=prepareSignupRelays(this.params.optionsModal.signupRelays);return this.modal.njumpIframe=`\n <html><body>\n <script src='https://start.njump.me/modal.js'><\/script>\n <script>\n new NstartModal({\n baseUrl: 'https://start.njump.me',\n // Required parameters\n an: '${t}',\n // Optional parameters\n s: [${this.opt.followNpubs?`'${this.opt.followNpubs}'`:""}],\n afb: false, // forceBunker\n asb: false, // skipBunker\n aan: false, // avoidNsec\n aac: true, // avoidNcryptsec\n ahc: true, // hide close button\n arr: ${JSON.stringify(n)}, //readRelays\n awr: ${JSON.stringify(n)}, //writeRelays\n // Callbacks\n onComplete: (result) => {\n console.log('Login token:', result.nostrLogin);\n window.parent.location.href='${window.location.href}#nostr-login='+result.nostrLogin;\n },\n onCancel: () => {\n window.parent.location.href='${window.location.href}#nostr-login=null';\n },\n }).open();\n <\/script>\n </body></html>\n `.replaceAll("&","&"),new Promise((e,t)=>{const n=async n=>{if(console.log("nsecOrBunker",n),n.startsWith("nsec1")){let t;try{t=nip19_exports.decode(n)}catch(e){throw new Error("Bad nsec value")}if("nsec"!==t.type)throw new Error("Bad bech32 type");await this.authNostrService.localSignup("",t.data),e()}else n.startsWith("bunker:")?(await this.authNostrService.authNip46("login",{name:"",bunkerUrl:n}),e()):t("null"===n?"Cancelled":"Unknown return value")};window.addEventListener("hashchange",async()=>{if(window.location.hash.startsWith("#nostr-login=")){const e=window.location.hash.split("#nostr-login=")[1],t=new URL(window.location.toString());t.hash="",window.history.replaceState({},"",t.toString()),n(e)}})})})};if(!this.modal)throw new Error("WTH?");this.modal.addEventListener("handleContinue",()=>{this.modal&&(this.modal.isLoading=!0,this.emit("onAuthUrlClick",this.modal.authUrl))}),this.modal.addEventListener("nlLogin",e=>{o(e.detail)}),this.modal.addEventListener("nlSignup",e=>{a(e.detail)}),this.modal.addEventListener("nlLocalSignup",e=>{d(e.detail)}),this.modal.addEventListener("nlSignupNjump",e=>{u()}),this.modal.addEventListener("nlImportAccount",e=>{l(e.detail)}),this.modal.addEventListener("nlExportKeys",e=>{c()}),this.modal.addEventListener("handleLogoutBanner",()=>{this.emit("onLogoutBanner")}),this.modal.addEventListener("nlNostrConnect",e=>{h(e.detail)}),this.modal.addEventListener("nlNostrConnectDefault",()=>{this.authNostrService.isAuthing()||h()}),this.modal.addEventListener("nlNostrConnectDefaultCancel",()=>{console.log("nlNostrConnectDefaultCancel"),this.authNostrService.cancelNostrConnect()}),this.modal.addEventListener("nlSwitchAccount",e=>{const n=e.detail;this.emit("onSwitchAccount",n),setTimeout(()=>t.close(),300)}),this.modal.addEventListener("nlLoginRecentAccount",async e=>{const n=e.detail;if("readOnly"===n.authMethod)this.authNostrService.setReadOnly(n.pubkey),t.close();else if("otp"===n.authMethod)try{this.modal.dispatchEvent(new CustomEvent("nlLoginOTPUser",{detail:n.nip05||n.pubkey}))}catch(e){console.error(e)}else if("extension"===n.authMethod)await this.extensionService.trySetExtensionForPubkey(n.pubkey),t.close();else{const e=n.bunkerUrl||n.nip05;if(!e)throw new Error("Bad connect info");o(e,n.domain)}}),this.modal.addEventListener("nlRemoveRecent",e=>{localStorageRemoveRecent(e.detail),this.emit("updateAccounts")});const f=async e=>{let t="";if(e.includes("@")){const{error:n,pubkey:r}=await checkNip05(e);if(!r)throw new Error(n);t=r}else if(e.startsWith("npub")){const{type:n,data:r}=nip19_exports.decode(e);if("npub"!==n)throw new Error("Bad npub");t=r}else 64===e.trim().length&&(t=e.trim(),nip19_exports.npubEncode(t));return t};this.modal.addEventListener("nlLoginReadOnly",async e=>{await s(async()=>{const t=e.detail,n=await f(t);this.authNostrService.setReadOnly(n)})}),this.modal.addEventListener("nlLoginExtension",async()=>{if(!this.extensionService.hasExtension())throw new Error("No extension");await s(async()=>{this.modal&&(this.modal.isLoadingExtension=!0,await this.extensionService.setExtension(),this.modal.isLoadingExtension=!1)})}),this.modal.addEventListener("nlLoginOTPUser",async e=>{await s(async()=>{if(!this.modal)return;const t=e.detail,r=await f(t),i=this.opt.otpRequestUrl+(this.opt.otpRequestUrl.includes("?")?"&":"?")+"pubkey="+r,s=await fetch(i);if(200!==s.status)throw console.warn("nostr-login: bad otp reply",s),new Error("Failed to send DM");this.modal.isOTP=!0,n=r,this.modal.isLoading=!1},{start:!0})}),this.modal.addEventListener("nlLoginOTPCode",async e=>{await s(async()=>{if(!this.modal)return;const t=e.detail,r=this.opt.otpReplyUrl+(this.opt.otpRequestUrl.includes("?")?"&":"?")+"pubkey="+n+"&code="+t,i=await fetch(r);if(200!==i.status)throw console.warn("nostr-login: bad otp reply",i),new Error("Invalid code");const s=await i.text();this.authNostrService.setOTP(n,s),this.modal.isOTP=!1},{end:!0})}),this.modal.addEventListener("nlCheckSignup",async e=>{const{available:t,taken:n,error:r}=await checkNip05(e.detail);this.modal&&(this.modal.error=String(r),!r&&n&&(this.modal.error="Already taken"),this.modal.signupNameIsAvailable=t)}),this.modal.addEventListener("nlCheckLogin",async e=>{const{available:t,taken:n,error:r}=await checkNip05(e.detail);this.modal&&(this.modal.error=String(r),t&&(this.modal.error="Name not found"),this.modal.loginIsGood=n)});const p=()=>{this.modal&&(this.modal.isLoading=!1),t.close(),r(new Error("Cancelled"))};this.modal.addEventListener("stopFetchHandler",p),this.modal.addEventListener("nlCloseModal",p),this.modal.addEventListener("nlChangeDarkMode",e=>{setDarkMode(e.detail),document.dispatchEvent(new CustomEvent("nlDarkMode",{detail:e.detail}))}),this.on("onIframeAuthUrlCallEnd",()=>{t.close(),this.modal=null,e()}),t.showModal()}),this.launcherPromise}async showIframeUrl(e){await this.waitReady(),this.launch({startScreen:"iframe"}).catch(()=>console.log("closed auth iframe")),this.modal.authUrl=e}connectModals(e){const t=async e=>{await this.launch(e)},n=document.getElementsByTagName("nl-button");for(let r=0;r<n.length;r++){const i=n[r].getAttribute("nl-theme"),s=n[r].getAttribute("start-screen"),o={...e};switch(i&&(o.theme=i),s){case"login":case"login-bunker-url":case"login-read-only":case"signup":case"switch-account":case"welcome":o.startScreen=s}n[r].addEventListener("click",function(){t(o)})}}onAuthUrl(e){this.modal&&(this.modal.authUrl=e,this.modal.isLoading=!1)}onIframeUrl(e){this.modal&&(console.log("modal iframe url",e),this.modal.iframeUrl=e)}onCallEnd(){this.modal&&this.modal.authUrl&&this.params.userInfo?.iframeUrl&&this.emit("onIframeAuthUrlCallEnd")}onUpdateAccounts(e,t){this.accounts=e,this.recents=t,this.modal&&(this.modal.accounts=e,this.modal.recents=t)}onDarkMode(e){this.modal&&(this.modal.darkMode=e)}}class Nostr{#e;nip04;nip44;constructor(e){this.#e=e,this.getPublicKey=this.getPublicKey.bind(this),this.signEvent=this.signEvent.bind(this),this.getRelays=this.getRelays.bind(this),this.nip04={encrypt:this.encrypt04.bind(this),decrypt:this.decrypt04.bind(this)},this.nip44={encrypt:this.encrypt44.bind(this),decrypt:this.decrypt44.bind(this)}}async ensureAuth(){if(await this.#e.waitReady(),!this.#e.getUserInfo()&&(await this.#e.launch(),!this.#e.getUserInfo()))throw new Error("Rejected by user")}async getPublicKey(){await this.ensureAuth();const e=this.#e.getUserInfo();if(e)return e.pubkey;throw new Error("No user")}async signEvent(e){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().signEvent(e))}async getRelays(){return{}}async encrypt04(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip04.encrypt(e,t))}async decrypt04(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip04.decrypt(e,t))}async encrypt44(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip44.encrypt(e,t))}async decrypt44(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip44.decrypt(e,t))}}class NostrExtensionService extends lib$1.EventEmitter{params;nostrExtension;constructor(e){super(),this.params=e}startCheckingExtension(e){if(this.checkExtension(e))return;const t=setInterval(()=>{this.checkExtension(e)&&clearTimeout(t)},100)}checkExtension(e){return!(this.nostrExtension||!window.nostr||window.nostr===e)&&(this.initExtension(e),!0)}async initExtension(e,t){this.nostrExtension=window.nostr,window.nostr=e,"extension"===this.params.userInfo?.authMethod&&await this.trySetExtensionForPubkey(this.params.userInfo.pubkey),t||setTimeout(()=>{window.nostr!==e&&this.nostrExtension!==window.nostr&&this.initExtension(e,!0)},300)}async setExtensionReadPubkey(e){window.nostr=this.nostrExtension;const t=await window.nostr.getPublicKey();e&&e!==t?this.emit("extensionLogout"):this.emit("extensionLogin",t)}async trySetExtensionForPubkey(e){if(this.nostrExtension)return this.setExtensionReadPubkey(e)}async setExtension(){return this.setExtensionReadPubkey()}unsetExtension(e){window.nostr===this.nostrExtension&&(window.nostr=e)}getExtension(){return this.nostrExtension}hasExtension(){return!!this.nostrExtension}}class NostrParams{userInfo;optionsModal;constructor(){this.userInfo=null,this.optionsModal={theme:"default",startScreen:"welcome",devOverrideBunkerOrigin:""}}}class Popup{popup=null;constructor(){}openPopup(e){if((!this.popup||this.popup.closed)&&(this.popup=window.open(e,"_blank","width=400,height=700"),console.log("popup",this.popup),!this.popup))throw new Error("Popup blocked. Try again, please!")}closePopup(){try{this.popup?.close(),this.popup=null}catch{}}}const CALL_TIMEOUT=5e3;class ProcessManager extends lib$1.EventEmitter{callCount=0;callTimer;constructor(){super()}onAuthUrl(){Boolean(this.callTimer)&&clearTimeout(this.callTimer)}onIframeUrl(){Boolean(this.callTimer)&&clearTimeout(this.callTimer)}async wait(e){let t,n;this.callTimer||(this.callTimer=setTimeout(()=>this.emit("onCallTimeout"),CALL_TIMEOUT)),this.callCount||this.emit("onCallStart"),this.callCount++;try{n=await e()}catch(e){t=e}if(this.callCount--,this.emit("onCallEnd"),this.callTimer&&clearTimeout(this.callTimer),this.callTimer=void 0,t)throw t;return n}}class NostrLoginInitializer{extensionService;params;authNostrService;nostr;processManager;popupManager;bannerManager;modalManager;customLaunchCallback;constructor(){this.params=new NostrParams,this.processManager=new ProcessManager,this.popupManager=new Popup,this.bannerManager=new BannerManager(this.params),this.authNostrService=new AuthNostrService(this.params),this.extensionService=new NostrExtensionService(this.params),this.modalManager=new ModalManager(this.params,this.authNostrService,this.extensionService);const e={waitReady:async()=>{await this.authNostrService.waitReady(),await this.modalManager.waitReady()},getUserInfo:()=>this.params.userInfo,getSigner:()=>{if("readOnly"===this.params.userInfo.authMethod)throw new Error("Read only");return"extension"===this.params.userInfo.authMethod?this.extensionService.getExtension():this.authNostrService},launch:()=>this.launch(),wait:e=>this.processManager.wait(e)};this.nostr=new Nostr(e),this.processManager.on("onCallTimeout",()=>{this.bannerManager.onCallTimeout()}),this.processManager.on("onCallEnd",()=>{this.bannerManager.onCallEnd(),this.modalManager.onCallEnd()}),this.processManager.on("onCallStart",()=>{this.bannerManager.onCallStart()}),this.authNostrService.on("onIframeUrl",e=>{this.modalManager.onIframeUrl(e)}),this.authNostrService.on("iframeRestart",({iframeUrl:e})=>{this.processManager.onIframeUrl(),this.bannerManager.onIframeRestart(e)}),this.authNostrService.on("onAuthUrl",({url:e,iframeUrl:t,eventToAddAccount:n})=>{this.processManager.onAuthUrl(),n?this.modalManager.onAuthUrl(e):this.params.userInfo?this.bannerManager.onAuthUrl(e,t):this.modalManager.onAuthUrl(e)}),this.authNostrService.on("updateAccounts",()=>{this.updateAccounts()}),this.authNostrService.on("onUserInfo",e=>{this.bannerManager.onUserInfo(e)}),this.modalManager.on("onAuthUrlClick",e=>{this.openPopup(e)}),this.bannerManager.on("onIframeAuthUrlClick",e=>{this.modalManager.showIframeUrl(e)}),this.modalManager.on("onSwitchAccount",async e=>{this.switchAccount(e)}),this.modalManager.on("onLogoutBanner",async e=>{logout()}),this.bannerManager.on("onConfirmLogout",async()=>{this.launch("confirm-logout")}),this.modalManager.on("updateAccounts",()=>{this.updateAccounts()}),this.bannerManager.on("logout",()=>{logout()}),this.bannerManager.on("onAuthUrlClick",e=>{this.openPopup(e)}),this.bannerManager.on("onSwitchAccount",async e=>{this.switchAccount(e)}),this.bannerManager.on("import",()=>{this.launch("import")}),this.extensionService.on("extensionLogin",e=>{this.authNostrService.setExtension(e)}),this.extensionService.on("extensionLogout",()=>{logout()}),this.bannerManager.on("launch",e=>{this.launch(e)})}openPopup(e){this.popupManager.openPopup(e)}async switchAccount(e,t=!1){if(console.log("nostr login switch to info",e),this.extensionService.unsetExtension(this.nostr),"readOnly"===e.authMethod)this.authNostrService.setReadOnly(e.pubkey);else if("otp"===e.authMethod)this.authNostrService.setOTP(e.pubkey,e.otpData||"");else if("local"===e.authMethod&&e.sk)this.authNostrService.setLocal(e,t);else if("extension"===e.authMethod)await this.extensionService.trySetExtensionForPubkey(e.pubkey);else{if(!("connect"===e.authMethod&&e.sk&&e.relays&&e.relays[0]))throw new Error("Bad auth info");this.authNostrService.setConnect(e)}}updateAccounts(){const e=localStorageGetAccounts(),t=localStorageGetRecents();this.bannerManager.onUpdateAccounts(e),this.modalManager.onUpdateAccounts(e,t)}async launchCustomNostrConnect(){try{this.authNostrService.isAuthing()&&this.authNostrService.cancelNostrConnect();const e=new Promise(e=>this.customLaunchCallback=e);await this.authNostrService.startAuth(),await this.authNostrService.sendNeedAuth();try{await this.authNostrService.nostrConnect(),await this.authNostrService.endAuth()}catch(t){"cancelled"===t&&await e}}catch(e){console.error("launchCustomNostrConnect",e)}}fulfillCustomLaunchPromise(){if(this.customLaunchCallback){const e=this.customLaunchCallback;this.customLaunchCallback=void 0,e()}}launch=async e=>{if(!e&&this.params.optionsModal.customNostrConnect)return this.launchCustomNostrConnect();const t=localStorageGetRecents(),n=localStorageGetAccounts(),r={...this.params.optionsModal};e&&"default"!==e?r.startScreen=e:(Boolean(t?.length)||Boolean(n?.length))&&(r.startScreen="switch-account"),this.customLaunchCallback&&this.authNostrService.cancelNostrConnect();try{await this.modalManager.launch(r),this.fulfillCustomLaunchPromise()}catch(e){console.log("nostr-login failed",e)}};init=async e=>{this.extensionService.startCheckingExtension(this.nostr),window.nostr=this.nostr,this.modalManager.connectModals(e),this.bannerManager.launchAuthBanner(e),e&&(this.params.optionsModal={...e});try{const e=localStorageGetCurrent();if(e){if(!e.pubkey)throw new Error("Bad stored info");await this.switchAccount(e)}}catch(e){console.log("nostr login init error",e),await logout()}this.updateAccounts()};logout=async()=>{this.extensionService.unsetExtension(this.nostr),await this.authNostrService.logout()};setDarkMode=e=>{localStorageSetItem("nl-dark-mode",`${e}`),this.bannerManager.onDarkMode(e),this.modalManager.onDarkMode(e)};setAuth=async e=>{if(!e.type)throw new Error("Invalid auth event");if("login"!==e.type&&"logout"!==e.type&&"signup"!==e.type)throw new Error("Invalid auth event");if(e.method&&"connect"!==e.method&&"extension"!==e.method&&"local"!==e.method&&"otp"!==e.method&&"readOnly"!==e.method)throw new Error("Invalid auth event");if("logout"===e.type)return this.logout();if(!e.method||!e.pubkey)throw new Error("Invalid pubkey");const t={authMethod:e.method,pubkey:e.pubkey,relays:e.relays,sk:e.localNsec,otpData:e.otpData,name:e.name};await this.switchAccount(t,"signup"===e.type)};cancelNeedAuth=()=>{console.log("cancelNeedAuth"),this.fulfillCustomLaunchPromise(),this.authNostrService.cancelNostrConnect()}}const initializer=new NostrLoginInitializer,{init:init,launch:launch,logout:logout,setDarkMode:setDarkMode,setAuth:setAuth,cancelNeedAuth:cancelNeedAuth}=initializer;document.addEventListener("nlLogout",logout),document.addEventListener("nlLaunch",e=>{launch(e.detail||"")}),document.addEventListener("nlNeedAuthCancel",()=>{cancelNeedAuth()}),document.addEventListener("nlDarkMode",e=>{setDarkMode(!!e.detail)}),document.addEventListener("nlSetAuth",e=>{setAuth(e.detail)});export{NostrLoginInitializer,cancelNeedAuth,init,launch,logout,setAuth,setDarkMode};
|
|
47
47
|
//# sourceMappingURL=index.esm.js.map
|
package/dist/unpkg.js
CHANGED
|
@@ -43,4 +43,4 @@ function getHash(e){return{hash:e,hmac:(t,...n)=>hmac(e,t,concatBytes$1(...n)),r
|
|
|
43
43
|
/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */hmac.create=(e,t)=>new HMAC(e,t);const secp256k1P=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),secp256k1N=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),_1n=BigInt(1),_2n=BigInt(2),divNearest=(e,t)=>(e+t/_2n)/t;function sqrtMod(e){const t=secp256k1P,n=BigInt(3),r=BigInt(6),i=BigInt(11),s=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),l=e*e*e%t,h=l*l*e%t,d=pow2(h,n,t)*h%t,u=pow2(d,n,t)*h%t,p=pow2(u,_2n,t)*l%t,f=pow2(p,i,t)*p%t,g=pow2(f,s,t)*f%t,y=pow2(g,a,t)*g%t,m=pow2(y,c,t)*y%t,b=pow2(m,a,t)*g%t,w=pow2(b,n,t)*h%t,v=pow2(w,o,t)*f%t,$=pow2(v,r,t)*l%t,E=pow2($,_2n,t);if(!Fp.eql(Fp.sqr(E),e))throw new Error("Cannot find square root");return E}const Fp=Field(secp256k1P,void 0,void 0,{sqrt:sqrtMod}),secp256k1=createCurve({a:BigInt(0),b:BigInt(7),Fp:Fp,n:secp256k1N,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:e=>{const t=secp256k1N,n=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),r=-_1n*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),i=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),s=n,o=BigInt("0x100000000000000000000000000000000"),a=divNearest(s*e,t),c=divNearest(-r*e,t);let l=mod(e-a*n-c*i,t),h=mod(-a*r-c*s,t);const d=l>o,u=h>o;if(d&&(l=t-l),u&&(h=t-h),l>o||h>o)throw new Error("splitScalar: Endomorphism failed, k="+e);return{k1neg:d,k1:l,k2neg:u,k2:h}}}},sha256);
|
|
44
44
|
/*! scure-base - MIT License (c) 2022 Paul Miller (paulmillr.com) */
|
|
45
45
|
function isBytes(e){return e instanceof Uint8Array||null!=e&&"object"==typeof e&&"Uint8Array"===e.constructor.name}function chain(...e){const t=e=>e,n=(e,t)=>n=>e(t(n));return{encode:e.map(e=>e.encode).reduceRight(n,t),decode:e.map(e=>e.decode).reduce(n,t)}}function alphabet(e){return{encode:t=>{if(!Array.isArray(t)||t.length&&"number"!=typeof t[0])throw new Error("alphabet.encode input should be an array of numbers");return t.map(t=>{if(t<0||t>=e.length)throw new Error(`Digit index outside alphabet: ${t} (alphabet: ${e.length})`);return e[t]})},decode:t=>{if(!Array.isArray(t)||t.length&&"string"!=typeof t[0])throw new Error("alphabet.decode input should be array of strings");return t.map(t=>{if("string"!=typeof t)throw new Error(`alphabet.decode: not string element=${t}`);const n=e.indexOf(t);if(-1===n)throw new Error(`Unknown letter: "${t}". Allowed: ${e}`);return n})}}}function join(e=""){if("string"!=typeof e)throw new Error("join separator should be string");return{encode:t=>{if(!Array.isArray(t)||t.length&&"string"!=typeof t[0])throw new Error("join.encode input should be array of strings");for(let e of t)if("string"!=typeof e)throw new Error(`join.encode: non-string input=${e}`);return t.join(e)},decode:t=>{if("string"!=typeof t)throw new Error("join.decode input should be string");return t.split(e)}}}function convertRadix(e,t,n){if(t<2)throw new Error(`convertRadix: wrong from=${t}, base cannot be less than 2`);if(n<2)throw new Error(`convertRadix: wrong to=${n}, base cannot be less than 2`);if(!Array.isArray(e))throw new Error("convertRadix: data should be array");if(!e.length)return[];let r=0;const i=[],s=Array.from(e);for(s.forEach(e=>{if(e<0||e>=t)throw new Error(`Wrong integer: ${e}`)});;){let e=0,o=!0;for(let i=r;i<s.length;i++){const a=s[i],c=t*e+a;if(!Number.isSafeInteger(c)||t*e/t!==e||c-a!==t*e)throw new Error("convertRadix: carry overflow");e=c%n;const l=Math.floor(c/n);if(s[i]=l,!Number.isSafeInteger(l)||l*n+e!==c)throw new Error("convertRadix: carry overflow");o&&(l?o=!1:r=i)}if(i.push(e),o)break}for(let t=0;t<e.length-1&&0===e[t];t++)i.push(0);return i.reverse()}function radix(e){return{encode:t=>{if(!isBytes(t))throw new Error("radix.encode input should be Uint8Array");return convertRadix(Array.from(t),256,e)},decode:t=>{if(!Array.isArray(t)||t.length&&"number"!=typeof t[0])throw new Error("radix.decode input should be array of numbers");return Uint8Array.from(convertRadix(t,e,256))}}}function checksum(e,t){if("function"!=typeof t)throw new Error("checksum fn should be function");return{encode(n){if(!isBytes(n))throw new Error("checksum.encode: input should be Uint8Array");const r=t(n).slice(0,e),i=new Uint8Array(n.length+e);return i.set(n),i.set(r,n.length),i},decode(n){if(!isBytes(n))throw new Error("checksum.decode: input should be Uint8Array");const r=n.slice(0,-e),i=t(r).slice(0,e),s=n.slice(-e);for(let t=0;t<e;t++)if(i[t]!==s[t])throw new Error("Invalid checksum");return r}}}BigInt(0),secp256k1.ProjectivePoint;const genBase58=e=>chain(radix(58),alphabet(e),join("")),base58=genBase58("123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"),createBase58check=e=>chain(checksum(4,t=>e(e(t))),base58),base58check$1=createBase58check,Point=secp256k1.ProjectivePoint,base58check=base58check$1(sha256$1);function bytesToNumber(e){return BigInt(`0x${bytesToHex$1(e)}`)}function numberToBytes(e){return hexToBytes$1(e.toString(16).padStart(64,"0"))}const MASTER_SECRET=utf8ToBytes$3("Bitcoin seed"),BITCOIN_VERSIONS={private:76066276,public:76067358},HARDENED_OFFSET=2147483648,hash160=e=>ripemd160(sha256$1(e)),fromU32=e=>createView$1(e).getUint32(0,!1),toU32=e=>{if(!Number.isSafeInteger(e)||e<0||e>2**32-1)throw new Error(`Invalid number=${e}. Should be from 0 to 2 ** 32 - 1`);const t=new Uint8Array(4);return createView$1(t).setUint32(0,e,!1),t};class HDKey{get fingerprint(){if(!this.pubHash)throw new Error("No publicKey set!");return fromU32(this.pubHash)}get identifier(){return this.pubHash}get pubKeyHash(){return this.pubHash}get privateKey(){return this.privKeyBytes||null}get publicKey(){return this.pubKey||null}get privateExtendedKey(){const e=this.privateKey;if(!e)throw new Error("No private key");return base58check.encode(this.serialize(this.versions.private,concatBytes$2(new Uint8Array([0]),e)))}get publicExtendedKey(){if(!this.pubKey)throw new Error("No public key");return base58check.encode(this.serialize(this.versions.public,this.pubKey))}static fromMasterSeed(e,t=BITCOIN_VERSIONS){if(bytes$2(e),8*e.length<128||8*e.length>512)throw new Error(`HDKey: wrong seed length=${e.length}. Should be between 128 and 512 bits; 256 bits is advised)`);const n=hmac$1(sha512,MASTER_SECRET,e);return new HDKey({versions:t,chainCode:n.slice(32),privateKey:n.slice(0,32)})}static fromExtendedKey(e,t=BITCOIN_VERSIONS){const n=base58check.decode(e),r=createView$1(n),i=r.getUint32(0,!1),s={versions:t,depth:n[4],parentFingerprint:r.getUint32(5,!1),index:r.getUint32(9,!1),chainCode:n.slice(13,45)},o=n.slice(45),a=0===o[0];if(i!==t[a?"private":"public"])throw new Error("Version mismatch");return new HDKey(a?{...s,privateKey:o.slice(1)}:{...s,publicKey:o})}static fromJSON(e){return HDKey.fromExtendedKey(e.xpriv)}constructor(e){if(this.depth=0,this.index=0,this.chainCode=null,this.parentFingerprint=0,!e||"object"!=typeof e)throw new Error("HDKey.constructor must not be called directly");if(this.versions=e.versions||BITCOIN_VERSIONS,this.depth=e.depth||0,this.chainCode=e.chainCode,this.index=e.index||0,this.parentFingerprint=e.parentFingerprint||0,!this.depth&&(this.parentFingerprint||this.index))throw new Error("HDKey: zero depth with non-zero index/parent fingerprint");if(e.publicKey&&e.privateKey)throw new Error("HDKey: publicKey and privateKey at same time.");if(e.privateKey){if(!secp256k1.utils.isValidPrivateKey(e.privateKey))throw new Error("Invalid private key");this.privKey="bigint"==typeof e.privateKey?e.privateKey:bytesToNumber(e.privateKey),this.privKeyBytes=numberToBytes(this.privKey),this.pubKey=secp256k1.getPublicKey(e.privateKey,!0)}else{if(!e.publicKey)throw new Error("HDKey: no public or private key provided");this.pubKey=Point.fromHex(e.publicKey).toRawBytes(!0)}this.pubHash=hash160(this.pubKey)}derive(e){if(!/^[mM]'?/.test(e))throw new Error('Path must start with "m" or "M"');if(/^[mM]'?$/.test(e))return this;const t=e.replace(/^[mM]'?\//,"").split("/");let n=this;for(const e of t){const t=/^(\d+)('?)$/.exec(e);if(!t||3!==t.length)throw new Error(`Invalid child index: ${e}`);let r=+t[1];if(!Number.isSafeInteger(r)||r>=HARDENED_OFFSET)throw new Error("Invalid index");"'"===t[2]&&(r+=HARDENED_OFFSET),n=n.deriveChild(r)}return n}deriveChild(e){if(!this.pubKey||!this.chainCode)throw new Error("No publicKey or chainCode set");let t=toU32(e);if(e>=HARDENED_OFFSET){const e=this.privateKey;if(!e)throw new Error("Could not derive hardened child key");t=concatBytes$2(new Uint8Array([0]),e,t)}else t=concatBytes$2(this.pubKey,t);const n=hmac$1(sha512,this.chainCode,t),r=bytesToNumber(n.slice(0,32)),i=n.slice(32);if(!secp256k1.utils.isValidPrivateKey(r))throw new Error("Tweak bigger than curve order");const s={versions:this.versions,chainCode:i,depth:this.depth+1,parentFingerprint:this.fingerprint,index:e};try{if(this.privateKey){const e=mod(this.privKey+r,secp256k1.CURVE.n);if(!secp256k1.utils.isValidPrivateKey(e))throw new Error("The tweak was out of range or the resulted private key is invalid");s.privateKey=e}else{const e=Point.fromHex(this.pubKey).add(Point.fromPrivateKey(r));if(e.equals(Point.ZERO))throw new Error("The tweak was equal to negative P, which made the result key invalid");s.publicKey=e.toRawBytes(!0)}return new HDKey(s)}catch(t){return this.deriveChild(e+1)}}sign(e){if(!this.privateKey)throw new Error("No privateKey set!");return bytes$2(e,32),secp256k1.sign(e,this.privKey).toCompactRawBytes()}verify(e,t){if(bytes$2(e,32),bytes$2(t,64),!this.publicKey)throw new Error("No publicKey set!");let n;try{n=secp256k1.Signature.fromCompact(t)}catch(e){return!1}return secp256k1.verify(n,e,this.publicKey)}wipePrivateData(){return this.privKey=void 0,this.privKeyBytes&&(this.privKeyBytes.fill(0),this.privKeyBytes=void 0),this}toJSON(){return{xpriv:this.privateExtendedKey,xpub:this.publicExtendedKey}}serialize(e,t){if(!this.chainCode)throw new Error("No chainCode set");return bytes$2(t,33),concatBytes$2(toU32(e),new Uint8Array([this.depth]),toU32(this.parentFingerprint),toU32(this.index),this.chainCode,t)}}
|
|
46
|
-
/*! noble-ciphers - MIT License (c) 2023 Paul Miller (paulmillr.com) */const u8a=e=>e instanceof Uint8Array,u32=e=>new Uint32Array(e.buffer,e.byteOffset,Math.floor(e.byteLength/4)),isLE=68===new Uint8Array(new Uint32Array([287454020]).buffer)[0];if(!isLE)throw new Error("Non little-endian hardware is not supported");function utf8ToBytes(e){if("string"!=typeof e)throw new Error("utf8ToBytes expected string, got "+typeof e);return new Uint8Array((new TextEncoder).encode(e))}function toBytes(e){if("string"==typeof e&&(e=utf8ToBytes(e)),!u8a(e))throw new Error("expected Uint8Array, got "+typeof e);return e}const isPlainObject=e=>"[object Object]"===Object.prototype.toString.call(e)&&e.constructor===Object;function checkOpts(e,t){if(void 0!==t&&("object"!=typeof t||!isPlainObject(t)))throw new Error("options must be object or undefined");return Object.assign(e,t)}function ensureBytes(e,t){if(!(e instanceof Uint8Array))throw new Error("Uint8Array expected");if(e.length!==t)throw new Error(`Uint8Array length ${t} expected`)}function equalBytes(e,t){if(e.length!==t.length)throw new Error("equalBytes: Different size of Uint8Arrays");let n=!0;for(let r=0;r<e.length;r++)n&&(n=e[r]===t[r]);return n}function number(e){if(!Number.isSafeInteger(e)||e<0)throw new Error(`Wrong positive integer: ${e}`)}function bool(e){if("boolean"!=typeof e)throw new Error(`Expected boolean, not ${e}`)}function bytes(e,...t){if(!(e instanceof Uint8Array))throw new Error("Expected Uint8Array");if(t.length>0&&!t.includes(e.length))throw new Error(`Expected Uint8Array of length ${t}, not of length=${e.length}`)}function hash(e){if("function"!=typeof e||"function"!=typeof e.create)throw new Error("hash must be wrapped by utils.wrapConstructor");number(e.outputLen),number(e.blockLen)}function exists(e,t=!0){if(e.destroyed)throw new Error("Hash instance has been destroyed");if(t&&e.finished)throw new Error("Hash#digest() has already been called")}function output(e,t){bytes(e);const n=t.outputLen;if(e.length<n)throw new Error(`digestInto() expects output buffer of length at least ${n}`)}const assert={number:number,bool:bool,bytes:bytes,hash:hash,exists:exists,output:output},u8to16=(e,t)=>255&e[t++]|(255&e[t++])<<8;class Poly1305{constructor(e){this.blockLen=16,this.outputLen=16,this.buffer=new Uint8Array(16),this.r=new Uint16Array(10),this.h=new Uint16Array(10),this.pad=new Uint16Array(8),this.pos=0,this.finished=!1,ensureBytes(e=toBytes(e),32);const t=u8to16(e,0),n=u8to16(e,2),r=u8to16(e,4),i=u8to16(e,6),s=u8to16(e,8),o=u8to16(e,10),a=u8to16(e,12),c=u8to16(e,14);this.r[0]=8191&t,this.r[1]=8191&(t>>>13|n<<3),this.r[2]=7939&(n>>>10|r<<6),this.r[3]=8191&(r>>>7|i<<9),this.r[4]=255&(i>>>4|s<<12),this.r[5]=s>>>1&8190,this.r[6]=8191&(s>>>14|o<<2),this.r[7]=8065&(o>>>11|a<<5),this.r[8]=8191&(a>>>8|c<<8),this.r[9]=c>>>5&127;for(let t=0;t<8;t++)this.pad[t]=u8to16(e,16+2*t)}process(e,t,n=!1){const r=n?0:2048,{h:i,r:s}=this,o=s[0],a=s[1],c=s[2],l=s[3],h=s[4],d=s[5],u=s[6],p=s[7],f=s[8],g=s[9],y=u8to16(e,t+0),m=u8to16(e,t+2),b=u8to16(e,t+4),w=u8to16(e,t+6),v=u8to16(e,t+8),$=u8to16(e,t+10),E=u8to16(e,t+12),k=u8to16(e,t+14);let x=i[0]+(8191&y),_=i[1]+(8191&(y>>>13|m<<3)),S=i[2]+(8191&(m>>>10|b<<6)),C=i[3]+(8191&(b>>>7|w<<9)),A=i[4]+(8191&(w>>>4|v<<12)),N=i[5]+(v>>>1&8191),R=i[6]+(8191&(v>>>14|$<<2)),T=i[7]+(8191&($>>>11|E<<5)),B=i[8]+(8191&(E>>>8|k<<8)),L=i[9]+(k>>>5|r),I=0,U=I+x*o+_*(5*g)+S*(5*f)+C*(5*p)+A*(5*u);I=U>>>13,U&=8191,U+=N*(5*d)+R*(5*h)+T*(5*l)+B*(5*c)+L*(5*a),I+=U>>>13,U&=8191;let O=I+x*a+_*o+S*(5*g)+C*(5*f)+A*(5*p);I=O>>>13,O&=8191,O+=N*(5*u)+R*(5*d)+T*(5*h)+B*(5*l)+L*(5*c),I+=O>>>13,O&=8191;let P=I+x*c+_*a+S*o+C*(5*g)+A*(5*f);I=P>>>13,P&=8191,P+=N*(5*p)+R*(5*u)+T*(5*d)+B*(5*h)+L*(5*l),I+=P>>>13,P&=8191;let M=I+x*l+_*c+S*a+C*o+A*(5*g);I=M>>>13,M&=8191,M+=N*(5*f)+R*(5*p)+T*(5*u)+B*(5*d)+L*(5*h),I+=M>>>13,M&=8191;let D=I+x*h+_*l+S*c+C*a+A*o;I=D>>>13,D&=8191,D+=N*(5*g)+R*(5*f)+T*(5*p)+B*(5*u)+L*(5*d),I+=D>>>13,D&=8191;let H=I+x*d+_*h+S*l+C*c+A*a;I=H>>>13,H&=8191,H+=N*o+R*(5*g)+T*(5*f)+B*(5*p)+L*(5*u),I+=H>>>13,H&=8191;let F=I+x*u+_*d+S*h+C*l+A*c;I=F>>>13,F&=8191,F+=N*a+R*o+T*(5*g)+B*(5*f)+L*(5*p),I+=F>>>13,F&=8191;let K=I+x*p+_*u+S*d+C*h+A*l;I=K>>>13,K&=8191,K+=N*c+R*a+T*o+B*(5*g)+L*(5*f),I+=K>>>13,K&=8191;let V=I+x*f+_*p+S*u+C*d+A*h;I=V>>>13,V&=8191,V+=N*l+R*c+T*a+B*o+L*(5*g),I+=V>>>13,V&=8191;let j=I+x*g+_*f+S*p+C*u+A*d;I=j>>>13,j&=8191,j+=N*h+R*l+T*c+B*a+L*o,I+=j>>>13,j&=8191,I=(I<<2)+I|0,I=I+U|0,U=8191&I,I>>>=13,O+=I,i[0]=U,i[1]=O,i[2]=P,i[3]=M,i[4]=D,i[5]=H,i[6]=F,i[7]=K,i[8]=V,i[9]=j}finalize(){const{h:e,pad:t}=this,n=new Uint16Array(10);let r=e[1]>>>13;e[1]&=8191;for(let t=2;t<10;t++)e[t]+=r,r=e[t]>>>13,e[t]&=8191;e[0]+=5*r,r=e[0]>>>13,e[0]&=8191,e[1]+=r,r=e[1]>>>13,e[1]&=8191,e[2]+=r,n[0]=e[0]+5,r=n[0]>>>13,n[0]&=8191;for(let t=1;t<10;t++)n[t]=e[t]+r,r=n[t]>>>13,n[t]&=8191;n[9]-=8192;let i=(1^r)-1;for(let e=0;e<10;e++)n[e]&=i;i=~i;for(let t=0;t<10;t++)e[t]=e[t]&i|n[t];e[0]=65535&(e[0]|e[1]<<13),e[1]=65535&(e[1]>>>3|e[2]<<10),e[2]=65535&(e[2]>>>6|e[3]<<7),e[3]=65535&(e[3]>>>9|e[4]<<4),e[4]=65535&(e[4]>>>12|e[5]<<1|e[6]<<14),e[5]=65535&(e[6]>>>2|e[7]<<11),e[6]=65535&(e[7]>>>5|e[8]<<8),e[7]=65535&(e[8]>>>8|e[9]<<5);let s=e[0]+t[0];e[0]=65535&s;for(let n=1;n<8;n++)s=(e[n]+t[n]|0)+(s>>>16)|0,e[n]=65535&s}update(e){assert.exists(this);const{buffer:t,blockLen:n}=this,r=(e=toBytes(e)).length;for(let i=0;i<r;){const s=Math.min(n-this.pos,r-i);if(s!==n)t.set(e.subarray(i,i+s),this.pos),this.pos+=s,i+=s,this.pos===n&&(this.process(t,0,!1),this.pos=0);else for(;n<=r-i;i+=n)this.process(e,i)}return this}destroy(){this.h.fill(0),this.r.fill(0),this.buffer.fill(0),this.pad.fill(0)}digestInto(e){assert.exists(this),assert.output(e,this),this.finished=!0;const{buffer:t,h:n}=this;let{pos:r}=this;if(r){for(t[r++]=1;r<16;r++)t[r]=0;this.process(t,0,!0)}this.finalize();let i=0;for(let t=0;t<8;t++)e[i++]=n[t]>>>0,e[i++]=n[t]>>>8;return e}digest(){const{buffer:e,outputLen:t}=this;this.digestInto(e);const n=e.slice(0,t);return this.destroy(),n}}function wrapConstructorWithKey(e){const t=(t,n)=>e(n).update(toBytes(t)).digest(),n=e(new Uint8Array(32));return t.outputLen=n.outputLen,t.blockLen=n.blockLen,t.create=t=>e(t),t}wrapConstructorWithKey(e=>new Poly1305(e));const sigma16=utf8ToBytes("expand 16-byte k"),sigma32=utf8ToBytes("expand 32-byte k"),sigma16_32=u32(sigma16),sigma32_32=u32(sigma32),isAligned32=e=>!(e.byteOffset%4),salsaBasic=e=>{const{core:t,rounds:n,counterRight:r,counterLen:i,allow128bitKeys:s,extendNonceFn:o,blockLen:a}=checkOpts({rounds:20,counterRight:!1,counterLen:8,allow128bitKeys:!0,blockLen:64},e);assert.number(i),assert.number(n),assert.number(a),assert.bool(r),assert.bool(s);const c=a/4;if(a%4!=0)throw new Error("Salsa/ChaCha: blockLen must be aligned to 4 bytes");return(e,l,h,d,u=0)=>{if(assert.bytes(e),assert.bytes(l),assert.bytes(h),d||(d=new Uint8Array(h.length)),assert.bytes(d),assert.number(u),u<0||u>=2**32-1)throw new Error("Salsa/ChaCha: counter overflow");if(d.length<h.length)throw new Error(`Salsa/ChaCha: output (${d.length}) is shorter than data (${h.length})`);const p=[];let f,g;if(32===e.length)f=e,g=sigma32_32;else{if(16!==e.length||!s)throw new Error(`Salsa/ChaCha: invalid 32-byte key, got length=${e.length}`);f=new Uint8Array(32),f.set(e),f.set(e,16),g=sigma16_32,p.push(f)}if(o){if(l.length<=16)throw new Error("Salsa/ChaCha: extended nonce must be bigger than 16 bytes");f=o(g,f,l.subarray(0,16),new Uint8Array(32)),p.push(f),l=l.subarray(16)}const y=16-i;if(l.length!==y)throw new Error(`Salsa/ChaCha: nonce must be ${y} or 16 bytes`);if(12!==y){const e=new Uint8Array(12);e.set(l,r?0:12-l.length),p.push(l=e)}const m=new Uint8Array(a),b=u32(m),w=u32(f),v=u32(l),$=isAligned32(h)&&u32(h),E=isAligned32(d)&&u32(d);p.push(b);const k=h.length;for(let e=0,r=u;e<k;r++){if(t(g,w,v,b,r,n),r>=2**32-1)throw new Error("Salsa/ChaCha: counter overflow");const i=Math.min(a,k-e);if(i===a&&E&&$){const t=e/4;if(e%4!=0)throw new Error("Salsa/ChaCha: invalid block position");for(let e=0;e<c;e++)E[t+e]=$[t+e]^b[e];e+=a;continue}for(let t=0;t<i;t++)d[e+t]=h[e+t]^m[t];e+=i}for(let e=0;e<p.length;e++)p[e].fill(0);return d}},rotl=(e,t)=>e<<t|e>>>32-t;function chachaCore(e,t,n,r,i,s=20){let o=e[0],a=e[1],c=e[2],l=e[3],h=t[0],d=t[1],u=t[2],p=t[3],f=t[4],g=t[5],y=t[6],m=t[7],b=i,w=n[0],v=n[1],$=n[2],E=o,k=a,x=c,_=l,S=h,C=d,A=u,N=p,R=f,T=g,B=y,L=m,I=b,U=w,O=v,P=$;for(let e=0;e<s;e+=2)E=E+S|0,I=rotl(I^E,16),R=R+I|0,S=rotl(S^R,12),E=E+S|0,I=rotl(I^E,8),R=R+I|0,S=rotl(S^R,7),k=k+C|0,U=rotl(U^k,16),T=T+U|0,C=rotl(C^T,12),k=k+C|0,U=rotl(U^k,8),T=T+U|0,C=rotl(C^T,7),x=x+A|0,O=rotl(O^x,16),B=B+O|0,A=rotl(A^B,12),x=x+A|0,O=rotl(O^x,8),B=B+O|0,A=rotl(A^B,7),_=_+N|0,P=rotl(P^_,16),L=L+P|0,N=rotl(N^L,12),_=_+N|0,P=rotl(P^_,8),L=L+P|0,N=rotl(N^L,7),E=E+C|0,P=rotl(P^E,16),B=B+P|0,C=rotl(C^B,12),E=E+C|0,P=rotl(P^E,8),B=B+P|0,C=rotl(C^B,7),k=k+A|0,I=rotl(I^k,16),L=L+I|0,A=rotl(A^L,12),k=k+A|0,I=rotl(I^k,8),L=L+I|0,A=rotl(A^L,7),x=x+N|0,U=rotl(U^x,16),R=R+U|0,N=rotl(N^R,12),x=x+N|0,U=rotl(U^x,8),R=R+U|0,N=rotl(N^R,7),_=_+S|0,O=rotl(O^_,16),T=T+O|0,S=rotl(S^T,12),_=_+S|0,O=rotl(O^_,8),T=T+O|0,S=rotl(S^T,7);let M=0;r[M++]=o+E|0,r[M++]=a+k|0,r[M++]=c+x|0,r[M++]=l+_|0,r[M++]=h+S|0,r[M++]=d+C|0,r[M++]=u+A|0,r[M++]=p+N|0,r[M++]=f+R|0,r[M++]=g+T|0,r[M++]=y+B|0,r[M++]=m+L|0,r[M++]=b+I|0,r[M++]=w+U|0,r[M++]=v+O|0,r[M++]=$+P|0}const chacha20=salsaBasic({core:chachaCore,counterRight:!1,counterLen:4,allow128bitKeys:!1});function extract(e,t,n){return assert$3.hash(e),void 0===n&&(n=new Uint8Array(e.outputLen)),hmac$3(e,toBytes$4(n),toBytes$4(t))}const HKDF_COUNTER=new Uint8Array([0]),EMPTY_BUFFER=new Uint8Array;function expand(e,t,n,r=32){if(assert$3.hash(e),assert$3.number(r),r>255*e.outputLen)throw new Error("Length should be <= 255*HashLen");const i=Math.ceil(r/e.outputLen);void 0===n&&(n=EMPTY_BUFFER);const s=new Uint8Array(i*e.outputLen),o=hmac$3.create(e,t),a=o._cloneInto(),c=new Uint8Array(o.outputLen);for(let t=0;t<i;t++)HKDF_COUNTER[0]=t+1,a.update(0===t?EMPTY_BUFFER:c).update(n).update(HKDF_COUNTER).digestInto(c),s.set(c,e.outputLen*t),o._cloneInto(a);return o.destroy(),a.destroy(),c.fill(0),HKDF_COUNTER.fill(0),s.slice(0,r)}const hkdf=(e,t,n,r,i)=>expand(e,extract(e,t,n),r,i);var __defProp=Object.defineProperty,__export=(e,t)=>{for(var n in t)__defProp(e,n,{get:t[n],enumerable:!0})};function generatePrivateKey(){return bytesToHex$3(schnorr.utils.randomPrivateKey())}function getPublicKey(e){return bytesToHex$3(schnorr.getPublicKey(e))}var utils_exports={};__export(utils_exports,{MessageNode:()=>MessageNode,MessageQueue:()=>MessageQueue,insertEventIntoAscendingList:()=>insertEventIntoAscendingList,insertEventIntoDescendingList:()=>insertEventIntoDescendingList,normalizeURL:()=>normalizeURL,utf8Decoder:()=>utf8Decoder,utf8Encoder:()=>utf8Encoder});var utf8Decoder=new TextDecoder("utf-8"),utf8Encoder=new TextEncoder;function normalizeURL(e){let t=new URL(e);return t.pathname=t.pathname.replace(/\/+/g,"/"),t.pathname.endsWith("/")&&(t.pathname=t.pathname.slice(0,-1)),("80"===t.port&&"ws:"===t.protocol||"443"===t.port&&"wss:"===t.protocol)&&(t.port=""),t.searchParams.sort(),t.hash="",t.toString()}function insertEventIntoDescendingList(e,t){let n,r=0,i=e.length-1,s=r;if(i<0)s=0;else if(t.created_at<e[i].created_at)s=i+1;else if(t.created_at>=e[r].created_at)s=r;else for(;;){if(i<=r+1){s=i;break}if(n=Math.floor(r+(i-r)/2),e[n].created_at>t.created_at)r=n;else{if(!(e[n].created_at<t.created_at)){s=n;break}i=n}}return e[s]?.id!==t.id?[...e.slice(0,s),t,...e.slice(s)]:e}function insertEventIntoAscendingList(e,t){let n,r=0,i=e.length-1,s=r;if(i<0)s=0;else if(t.created_at>e[i].created_at)s=i+1;else if(t.created_at<=e[r].created_at)s=r;else for(;;){if(i<=r+1){s=i;break}if(n=Math.floor(r+(i-r)/2),e[n].created_at<t.created_at)r=n;else{if(!(e[n].created_at>t.created_at)){s=n;break}i=n}}return e[s]?.id!==t.id?[...e.slice(0,s),t,...e.slice(s)]:e}var MessageNode=class{_value;_next;get value(){return this._value}set value(e){this._value=e}get next(){return this._next}set next(e){this._next=e}constructor(e){this._value=e,this._next=null}},MessageQueue=class{_first;_last;get first(){return this._first}set first(e){this._first=e}get last(){return this._last}set last(e){this._last=e}_size;get size(){return this._size}set size(e){this._size=e}constructor(){this._first=null,this._last=null,this._size=0}enqueue(e){const t=new MessageNode(e);return 0!==this._size&&this._last?(this._last.next=t,this._last=t):(this._first=t,this._last=t),this._size++,!0}dequeue(){if(0===this._size||!this._first)return null;let e=this._first;return this._first=e.next,e.next=null,this._size--,e.value}},verifiedSymbol=Symbol("verified");function getBlankEvent(e=255){return{kind:e,content:"",tags:[],created_at:0}}function finishEvent(e,t){const n=e;return n.pubkey=getPublicKey(t),n.id=getEventHash(n),n.sig=getSignature(n,t),n[verifiedSymbol]=!0,n}function serializeEvent(e){if(!validateEvent(e))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,e.pubkey,e.created_at,e.kind,e.tags,e.content])}function getEventHash(e){return bytesToHex$3(sha256$3(utf8Encoder.encode(serializeEvent(e))))}var isRecord=e=>e instanceof Object;function validateEvent(e){if(!isRecord(e))return!1;if("number"!=typeof e.kind)return!1;if("string"!=typeof e.content)return!1;if("number"!=typeof e.created_at)return!1;if("string"!=typeof e.pubkey)return!1;if(!e.pubkey.match(/^[a-f0-9]{64}$/))return!1;if(!Array.isArray(e.tags))return!1;for(let t=0;t<e.tags.length;t++){let n=e.tags[t];if(!Array.isArray(n))return!1;for(let e=0;e<n.length;e++)if("object"==typeof n[e])return!1}return!0}function verifySignature(e){if("boolean"==typeof e[verifiedSymbol])return e[verifiedSymbol];const t=getEventHash(e);if(t!==e.id)return e[verifiedSymbol]=!1;try{return e[verifiedSymbol]=schnorr.verify(e.sig,t,e.pubkey)}catch(t){return e[verifiedSymbol]=!1}}function getSignature(e,t){return bytesToHex$3(schnorr.sign(getEventHash(e),t))}var fakejson_exports={};function getHex64(e,t){let n=t.length+3,r=e.indexOf(`"${t}":`)+n,i=e.slice(r).indexOf('"')+r+1;return e.slice(i,i+64)}function getInt(e,t){let n=t.length,r=e.indexOf(`"${t}":`)+n+3,i=e.slice(r),s=Math.min(i.indexOf(","),i.indexOf("}"));return parseInt(i.slice(0,s),10)}function getSubscriptionId(e){let t=e.slice(0,22).indexOf('"EVENT"');if(-1===t)return null;let n=e.slice(t+7+1).indexOf('"');if(-1===n)return null;let r=t+7+1+n,i=e.slice(r+1,80).indexOf('"');if(-1===i)return null;let s=r+1+i;return e.slice(r+1,s)}function matchEventId(e,t){return t===getHex64(e,"id")}function matchEventPubkey(e,t){return t===getHex64(e,"pubkey")}function matchEventKind(e,t){return t===getInt(e,"kind")}__export(fakejson_exports,{getHex64:()=>getHex64,getInt:()=>getInt,getSubscriptionId:()=>getSubscriptionId,matchEventId:()=>matchEventId,matchEventKind:()=>matchEventKind,matchEventPubkey:()=>matchEventPubkey});var nip19_exports={};__export(nip19_exports,{BECH32_REGEX:()=>BECH32_REGEX,decode:()=>decode,naddrEncode:()=>naddrEncode,neventEncode:()=>neventEncode,noteEncode:()=>noteEncode,nprofileEncode:()=>nprofileEncode,npubEncode:()=>npubEncode,nrelayEncode:()=>nrelayEncode,nsecEncode:()=>nsecEncode});var Bech32MaxSize=5e3,BECH32_REGEX=/[\x21-\x7E]{1,83}1[023456789acdefghjklmnpqrstuvwxyz]{6,}/;function integerToUint8Array(e){const t=new Uint8Array(4);return t[0]=e>>24&255,t[1]=e>>16&255,t[2]=e>>8&255,t[3]=255&e,t}function decode(e){let{prefix:t,words:n}=bech32.decode(e,Bech32MaxSize),r=new Uint8Array(bech32.fromWords(n));switch(t){case"nprofile":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for nprofile");if(32!==e[0][0].length)throw new Error("TLV 0 should be 32 bytes");return{type:"nprofile",data:{pubkey:bytesToHex$3(e[0][0]),relays:e[1]?e[1].map(e=>utf8Decoder.decode(e)):[]}}}case"nevent":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for nevent");if(32!==e[0][0].length)throw new Error("TLV 0 should be 32 bytes");if(e[2]&&32!==e[2][0].length)throw new Error("TLV 2 should be 32 bytes");if(e[3]&&4!==e[3][0].length)throw new Error("TLV 3 should be 4 bytes");return{type:"nevent",data:{id:bytesToHex$3(e[0][0]),relays:e[1]?e[1].map(e=>utf8Decoder.decode(e)):[],author:e[2]?.[0]?bytesToHex$3(e[2][0]):void 0,kind:e[3]?.[0]?parseInt(bytesToHex$3(e[3][0]),16):void 0}}}case"naddr":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for naddr");if(!e[2]?.[0])throw new Error("missing TLV 2 for naddr");if(32!==e[2][0].length)throw new Error("TLV 2 should be 32 bytes");if(!e[3]?.[0])throw new Error("missing TLV 3 for naddr");if(4!==e[3][0].length)throw new Error("TLV 3 should be 4 bytes");return{type:"naddr",data:{identifier:utf8Decoder.decode(e[0][0]),pubkey:bytesToHex$3(e[2][0]),kind:parseInt(bytesToHex$3(e[3][0]),16),relays:e[1]?e[1].map(e=>utf8Decoder.decode(e)):[]}}}case"nrelay":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for nrelay");return{type:"nrelay",data:utf8Decoder.decode(e[0][0])}}case"nsec":case"npub":case"note":return{type:t,data:bytesToHex$3(r)};default:throw new Error(`unknown prefix ${t}`)}}function parseTLV(e){let t={},n=e;for(;n.length>0;){let e=n[0],r=n[1];if(!r)throw new Error(`malformed TLV ${e}`);let i=n.slice(2,2+r);if(n=n.slice(2+r),i.length<r)throw new Error(`not enough data to read on TLV ${e}`);t[e]=t[e]||[],t[e].push(i)}return t}function nsecEncode(e){return encodeBytes("nsec",e)}function npubEncode(e){return encodeBytes("npub",e)}function noteEncode(e){return encodeBytes("note",e)}function encodeBech32(e,t){let n=bech32.toWords(t);return bech32.encode(e,n,Bech32MaxSize)}function encodeBytes(e,t){return encodeBech32(e,hexToBytes$3(t))}function nprofileEncode(e){return encodeBech32("nprofile",encodeTLV({0:[hexToBytes$3(e.pubkey)],1:(e.relays||[]).map(e=>utf8Encoder.encode(e))}))}function neventEncode(e){let t;return null!=e.kind&&(t=integerToUint8Array(e.kind)),encodeBech32("nevent",encodeTLV({0:[hexToBytes$3(e.id)],1:(e.relays||[]).map(e=>utf8Encoder.encode(e)),2:e.author?[hexToBytes$3(e.author)]:[],3:t?[new Uint8Array(t)]:[]}))}function naddrEncode(e){let t=new ArrayBuffer(4);return new DataView(t).setUint32(0,e.kind,!1),encodeBech32("naddr",encodeTLV({0:[utf8Encoder.encode(e.identifier)],1:(e.relays||[]).map(e=>utf8Encoder.encode(e)),2:[hexToBytes$3(e.pubkey)],3:[new Uint8Array(t)]}))}function nrelayEncode(e){return encodeBech32("nrelay",encodeTLV({0:[utf8Encoder.encode(e)]}))}function encodeTLV(e){let t=[];return Object.entries(e).forEach(([e,n])=>{n.forEach(n=>{let r=new Uint8Array(n.length+2);r.set([parseInt(e)],0),r.set([n.length],1),r.set(n,2),t.push(r)})}),concatBytes$4(...t)}var nip04_exports={};async function encrypt(e,t,n){const r=getNormalizedX(secp256k1$1.getSharedSecret(e,"02"+t));let i=Uint8Array.from(randomBytes$2(16)),s=utf8Encoder.encode(n),o=await crypto.subtle.importKey("raw",r,{name:"AES-CBC"},!1,["encrypt"]),a=await crypto.subtle.encrypt({name:"AES-CBC",iv:i},o,s);return`${base64.encode(new Uint8Array(a))}?iv=${base64.encode(new Uint8Array(i.buffer))}`}async function decrypt(e,t,n){let[r,i]=n.split("?iv="),s=getNormalizedX(secp256k1$1.getSharedSecret(e,"02"+t)),o=await crypto.subtle.importKey("raw",s,{name:"AES-CBC"},!1,["decrypt"]),a=base64.decode(r),c=base64.decode(i),l=await crypto.subtle.decrypt({name:"AES-CBC",iv:c},o,a);return utf8Decoder.decode(l)}function getNormalizedX(e){return e.slice(1,33)}__export(nip04_exports,{decrypt:()=>decrypt,encrypt:()=>encrypt}),"undefined"!=typeof crypto&&!crypto.subtle&&crypto.webcrypto&&(crypto.subtle=crypto.webcrypto.subtle);var nip05_exports={};__export(nip05_exports,{NIP05_REGEX:()=>NIP05_REGEX,queryProfile:()=>queryProfile,searchDomain:()=>searchDomain,useFetchImplementation:()=>useFetchImplementation});var NIP05_REGEX=/^(?:([\w.+-]+)@)?([\w.-]+)$/,_fetch;try{_fetch=fetch}catch{}function useFetchImplementation(e){_fetch=e}async function searchDomain(e,t=""){try{return(await(await _fetch(`https://${e}/.well-known/nostr.json?name=${t}`)).json()).names}catch(e){return{}}}async function queryProfile(e){const t=e.match(NIP05_REGEX);if(!t)return null;const[n,r="_",i]=t;try{const e=await _fetch(`https://${i}/.well-known/nostr.json?name=${r}`),{names:t,relays:n}=parseNIP05Result(await e.json()),s=t[r];return s?{pubkey:s,relays:n?.[s]}:null}catch(e){return null}}function parseNIP05Result(e){const t={names:{}};for(const[n,r]of Object.entries(e.names))"string"==typeof n&&"string"==typeof r&&(t.names[n]=r);if(e.relays){t.relays={};for(const[n,r]of Object.entries(e.relays))"string"==typeof n&&Array.isArray(r)&&(t.relays[n]=r.filter(e=>"string"==typeof e))}return t}var nip06_exports={};function privateKeyFromSeedWords(e,t){let n=HDKey.fromMasterSeed(mnemonicToSeedSync(e,t)).derive("m/44'/1237'/0'/0/0").privateKey;if(!n)throw new Error("could not derive private key");return bytesToHex$3(n)}function generateSeedWords(){return generateMnemonic(wordlist)}function validateWords(e){return validateMnemonic(e,wordlist)}__export(nip06_exports,{generateSeedWords:()=>generateSeedWords,privateKeyFromSeedWords:()=>privateKeyFromSeedWords,validateWords:()=>validateWords});var nip10_exports={};function parse(e){const t={reply:void 0,root:void 0,mentions:[],profiles:[]},n=[];for(const r of e.tags)"e"===r[0]&&r[1]&&n.push(r),"p"===r[0]&&r[1]&&t.profiles.push({pubkey:r[1],relays:r[2]?[r[2]]:[]});for(let e=0;e<n.length;e++){const r=n[e],[i,s,o,a]=r,c={id:s,relays:o?[o]:[]},l=0===e,h=e===n.length-1;"root"!==a?"reply"!==a?"mention"!==a?l?t.root=c:h?t.reply=c:t.mentions.push(c):t.mentions.push(c):t.reply=c:t.root=c}return t}__export(nip10_exports,{parse:()=>parse});var nip13_exports={};function getPow(e){let t=0;for(let n=0;n<e.length;n++){const r=parseInt(e[n],16);if(0!==r){t+=Math.clz32(r)-28;break}t+=4}return t}function minePow(e,t){let n=0;const r=e,i=["nonce",n.toString(),t.toString()];for(r.tags.push(i);;){const e=Math.floor((new Date).getTime()/1e3);if(e!==r.created_at&&(n=0,r.created_at=e),i[1]=(++n).toString(),r.id=getEventHash(r),getPow(r.id)>=t)break}return r}__export(nip13_exports,{getPow:()=>getPow,minePow:()=>minePow});var nip18_exports={};function finishRepostEvent(e,t,n,r){return finishEvent({kind:6,tags:[...e.tags??[],["e",t.id,n],["p",t.pubkey]],content:""===e.content?"":JSON.stringify(t),created_at:e.created_at},r)}function getRepostedEventPointer(e){if(6!==e.kind)return;let t,n;for(let r=e.tags.length-1;r>=0&&(void 0===t||void 0===n);r--){const i=e.tags[r];i.length>=2&&("e"===i[0]&&void 0===t?t=i:"p"===i[0]&&void 0===n&&(n=i))}return void 0!==t?{id:t[1],relays:[t[2],n?.[2]].filter(e=>"string"==typeof e),author:n?.[1]}:void 0}function getRepostedEvent(e,{skipVerification:t}={}){const n=getRepostedEventPointer(e);if(void 0===n||""===e.content)return;let r;try{r=JSON.parse(e.content)}catch(e){return}return r.id===n.id&&(t||verifySignature(r))?r:void 0}__export(nip18_exports,{finishRepostEvent:()=>finishRepostEvent,getRepostedEvent:()=>getRepostedEvent,getRepostedEventPointer:()=>getRepostedEventPointer});var nip21_exports={};__export(nip21_exports,{NOSTR_URI_REGEX:()=>NOSTR_URI_REGEX,parse:()=>parse2,test:()=>test});var NOSTR_URI_REGEX=new RegExp(`nostr:(${BECH32_REGEX.source})`);function test(e){return"string"==typeof e&&new RegExp(`^${NOSTR_URI_REGEX.source}$`).test(e)}function parse2(e){const t=e.match(new RegExp(`^${NOSTR_URI_REGEX.source}$`));if(!t)throw new Error(`Invalid Nostr URI: ${e}`);return{uri:t[0],value:t[1],decoded:decode(t[1])}}var nip25_exports={};function finishReactionEvent(e,t,n){const r=t.tags.filter(e=>e.length>=2&&("e"===e[0]||"p"===e[0]));return finishEvent({...e,kind:7,tags:[...e.tags??[],...r,["e",t.id],["p",t.pubkey]],content:e.content??"+"},n)}function getReactedEventPointer(e){if(7!==e.kind)return;let t,n;for(let r=e.tags.length-1;r>=0&&(void 0===t||void 0===n);r--){const i=e.tags[r];i.length>=2&&("e"===i[0]&&void 0===t?t=i:"p"===i[0]&&void 0===n&&(n=i))}return void 0!==t&&void 0!==n?{id:t[1],relays:[t[2],n[2]].filter(e=>void 0!==e),author:n[1]}:void 0}__export(nip25_exports,{finishReactionEvent:()=>finishReactionEvent,getReactedEventPointer:()=>getReactedEventPointer});var nip26_exports={};function createDelegation(e,t){let n=[];(t.kind||-1)>=0&&n.push(`kind=${t.kind}`),t.until&&n.push(`created_at<${t.until}`),t.since&&n.push(`created_at>${t.since}`);let r=n.join("&");if(""===r)throw new Error("refusing to create a delegation without any conditions");let i=sha256$3(utf8Encoder.encode(`nostr:delegation:${t.pubkey}:${r}`)),s=bytesToHex$3(schnorr.sign(i,e));return{from:getPublicKey(e),to:t.pubkey,cond:r,sig:s}}function getDelegator(e){let t=e.tags.find(e=>"delegation"===e[0]&&e.length>=4);if(!t)return null;let n=t[1],r=t[2],i=t[3],s=r.split("&");for(let t=0;t<s.length;t++){let[n,r,i]=s[t].split(/\b/);if(("kind"!==n||"="!==r||e.kind!==parseInt(i))&&!("created_at"===n&&"<"===r&&e.created_at<parseInt(i)||"created_at"===n&&">"===r&&e.created_at>parseInt(i)))return null}let o=sha256$3(utf8Encoder.encode(`nostr:delegation:${e.pubkey}:${r}`));return schnorr.verify(i,o,n)?n:null}__export(nip26_exports,{createDelegation:()=>createDelegation,getDelegator:()=>getDelegator});var nip27_exports={};__export(nip27_exports,{matchAll:()=>matchAll,regex:()=>regex,replaceAll:()=>replaceAll});var regex=()=>new RegExp(`\\b${NOSTR_URI_REGEX.source}\\b`,"g");function*matchAll(e){const t=e.matchAll(regex());for(const e of t)try{const[t,n]=e;yield{uri:t,value:n,decoded:decode(n),start:e.index,end:e.index+t.length}}catch(e){}}function replaceAll(e,t){return e.replaceAll(regex(),(e,n)=>t({uri:e,value:n,decoded:decode(n)}))}var nip28_exports={};__export(nip28_exports,{channelCreateEvent:()=>channelCreateEvent,channelHideMessageEvent:()=>channelHideMessageEvent,channelMessageEvent:()=>channelMessageEvent,channelMetadataEvent:()=>channelMetadataEvent,channelMuteUserEvent:()=>channelMuteUserEvent});var channelCreateEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:40,tags:[...e.tags??[]],content:n,created_at:e.created_at},t)},channelMetadataEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:41,tags:[["e",e.channel_create_event_id],...e.tags??[]],content:n,created_at:e.created_at},t)},channelMessageEvent=(e,t)=>{const n=[["e",e.channel_create_event_id,e.relay_url,"root"]];return e.reply_to_channel_message_event_id&&n.push(["e",e.reply_to_channel_message_event_id,e.relay_url,"reply"]),finishEvent({kind:42,tags:[...n,...e.tags??[]],content:e.content,created_at:e.created_at},t)},channelHideMessageEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:43,tags:[["e",e.channel_message_event_id],...e.tags??[]],content:n,created_at:e.created_at},t)},channelMuteUserEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:44,tags:[["p",e.pubkey_to_mute],...e.tags??[]],content:n,created_at:e.created_at},t)},nip39_exports={},_fetch2;__export(nip39_exports,{useFetchImplementation:()=>useFetchImplementation2,validateGithub:()=>validateGithub});try{_fetch2=fetch}catch{}function useFetchImplementation2(e){_fetch2=e}async function validateGithub(e,t,n){try{return await(await _fetch2(`https://gist.github.com/${t}/${n}/raw`)).text()===`Verifying that I control the following Nostr public key: ${e}`}catch(e){return!1}}var nip42_exports={};__export(nip42_exports,{authenticate:()=>authenticate});var authenticate=async({challenge:e,relay:t,sign:n})=>{const r={kind:22242,created_at:Math.floor(Date.now()/1e3),tags:[["relay",t.url],["challenge",e]],content:""};return t.auth(await n(r))},nip44_exports={};__export(nip44_exports,{decrypt:()=>decrypt2,encrypt:()=>encrypt2,utils:()=>utils});var utils={v2:{maxPlaintextSize:65408,minCiphertextSize:100,maxCiphertextSize:102400,getConversationKey:(e,t)=>secp256k1$1.getSharedSecret(e,"02"+t).subarray(1,33),getMessageKeys(e,t){const n=hkdf(sha256$3,e,t,"nip44-v2",76);return{encryption:n.subarray(0,32),nonce:n.subarray(32,44),auth:n.subarray(44,76)}},calcPadding(e){if(!Number.isSafeInteger(e)||e<0)throw new Error("expected positive integer");if(e<=32)return 32;const t=1<<Math.floor(Math.log2(e-1))+1,n=t<=256?32:t/8;return n*(Math.floor((e-1)/n)+1)},pad(e){const t=utf8Encoder.encode(e),n=t.length;if(n<1||n>=utils.v2.maxPlaintextSize)throw new Error("invalid plaintext length: must be between 1b and 64KB");const r=utils.v2.calcPadding(n),i=new Uint8Array(r-n),s=new Uint8Array(2);return new DataView(s.buffer).setUint16(0,n),concatBytes$4(s,t,i)},unpad(e){const t=new DataView(e.buffer).getUint16(0),n=e.subarray(2,2+t);if(0===t||n.length!==t||e.length!==2+utils.v2.calcPadding(t))throw new Error("invalid padding");return utf8Decoder.decode(n)}}};function encrypt2(e,t,n={}){const r=n.version??2;if(2!==r)throw new Error("unknown encryption version "+r);const i=n.salt??randomBytes$2(32);ensureBytes(i,32);const s=utils.v2.getMessageKeys(e,i),o=utils.v2.pad(t),a=chacha20(s.encryption,s.nonce,o),c=hmac$3(sha256$3,s.auth,a);return base64.encode(concatBytes$4(new Uint8Array([r]),i,a,c))}function decrypt2(e,t){const n=utils.v2;ensureBytes(e,32);const r=t.length;if(r<n.minCiphertextSize||r>=n.maxCiphertextSize)throw new Error("invalid ciphertext length: "+r);if("#"===t[0])throw new Error("unknown encryption version");let i;try{i=base64.decode(t)}catch(e){throw new Error("invalid base64: "+e.message)}const s=i.subarray(0,1)[0];if(2!==s)throw new Error("unknown encryption version "+s);const o=i.subarray(1,33),a=i.subarray(33,-32),c=i.subarray(-32),l=n.getMessageKeys(e,o);if(!equalBytes(hmac$3(sha256$3,l.auth,a),c))throw new Error("invalid MAC");const h=chacha20(l.encryption,l.nonce,a);return n.unpad(h)}var nip47_exports={};function parseConnectionString(e){const{pathname:t,searchParams:n}=new URL(e),r=t,i=n.get("relay"),s=n.get("secret");if(!r||!i||!s)throw new Error("invalid connection string");return{pubkey:r,relay:i,secret:s}}async function makeNwcRequestEvent({pubkey:e,secret:t,invoice:n}){const r={method:"pay_invoice",params:{invoice:n}},i=await encrypt(t,e,JSON.stringify(r));return finishEvent({kind:23194,created_at:Math.round(Date.now()/1e3),content:i,tags:[["p",e]]},t)}__export(nip47_exports,{makeNwcRequestEvent:()=>makeNwcRequestEvent,parseConnectionString:()=>parseConnectionString});var nip57_exports={},_fetch3;__export(nip57_exports,{getZapEndpoint:()=>getZapEndpoint,makeZapReceipt:()=>makeZapReceipt,makeZapRequest:()=>makeZapRequest,useFetchImplementation:()=>useFetchImplementation3,validateZapRequest:()=>validateZapRequest});try{_fetch3=fetch}catch{}function useFetchImplementation3(e){_fetch3=e}async function getZapEndpoint(e){try{let t="",{lud06:n,lud16:r}=JSON.parse(e.content);if(n){let{words:e}=bech32.decode(n,1e3),r=bech32.fromWords(e);t=utf8Decoder.decode(r)}else{if(!r)return null;{let[e,n]=r.split("@");t=`https://${n}/.well-known/lnurlp/${e}`}}let i=await _fetch3(t),s=await i.json();if(s.allowsNostr&&s.nostrPubkey)return s.callback}catch(e){}return null}function makeZapRequest({profile:e,event:t,amount:n,relays:r,comment:i=""}){if(!n)throw new Error("amount not given");if(!e)throw new Error("profile not given");let s={kind:9734,created_at:Math.round(Date.now()/1e3),content:i,tags:[["p",e],["amount",n.toString()],["relays",...r]]};return t&&s.tags.push(["e",t]),s}function validateZapRequest(e){let t;try{t=JSON.parse(e)}catch(e){return"Invalid zap request JSON."}if(!validateEvent(t))return"Zap request is not a valid Nostr event.";if(!verifySignature(t))return"Invalid signature on zap request.";let n=t.tags.find(([e,t])=>"p"===e&&t);if(!n)return"Zap request doesn't have a 'p' tag.";if(!n[1].match(/^[a-f0-9]{64}$/))return"Zap request 'p' tag is not valid hex.";let r=t.tags.find(([e,t])=>"e"===e&&t);return r&&!r[1].match(/^[a-f0-9]{64}$/)?"Zap request 'e' tag is not valid hex.":t.tags.find(([e,t])=>"relays"===e&&t)?null:"Zap request doesn't have a 'relays' tag."}function makeZapReceipt({zapRequest:e,preimage:t,bolt11:n,paidAt:r}){let i=JSON.parse(e).tags.filter(([e])=>"e"===e||"p"===e||"a"===e),s={kind:9735,created_at:Math.round(r.getTime()/1e3),content:"",tags:[...i,["bolt11",n],["description",e]]};return t&&s.tags.push(["preimage",t]),s}var nip98_exports={};__export(nip98_exports,{getToken:()=>getToken,unpackEventFromToken:()=>unpackEventFromToken,validateEvent:()=>validateEvent2,validateToken:()=>validateToken});var _authorizationScheme="Nostr ";async function getToken(e,t,n,r=!1){if(!e||!t)throw new Error("Missing loginUrl or httpMethod");const i=getBlankEvent(27235);i.tags=[["u",e],["method",t]],i.created_at=Math.round((new Date).getTime()/1e3);const s=await n(i);return(r?_authorizationScheme:"")+base64.encode(utf8Encoder.encode(JSON.stringify(s)))}async function validateToken(e,t,n){const r=await unpackEventFromToken(e).catch(e=>{throw e});return await validateEvent2(r,t,n).catch(e=>{throw e})}async function unpackEventFromToken(e){if(!e)throw new Error("Missing token");e=e.replace(_authorizationScheme,"");const t=utf8Decoder.decode(base64.decode(e));if(!t||0===t.length||!t.startsWith("{"))throw new Error("Invalid token");return JSON.parse(t)}async function validateEvent2(e,t,n){if(!e)throw new Error("Invalid nostr event");if(!verifySignature(e))throw new Error("Invalid nostr event, signature invalid");if(27235!==e.kind)throw new Error("Invalid nostr event, kind invalid");if(!e.created_at)throw new Error("Invalid nostr event, created_at invalid");if(Math.round((new Date).getTime()/1e3)-e.created_at>60)throw new Error("Invalid nostr event, expired");const r=e.tags.find(e=>"u"===e[0]);if(1!==r?.length&&r?.[1]!==t)throw new Error("Invalid nostr event, url tag invalid");const i=e.tags.find(e=>"method"===e[0]);if(1!==i?.length&&i?.[1].toLowerCase()!==n.toLowerCase())throw new Error("Invalid nostr event, method tag invalid");return!0}const LOCAL_STORE_KEY="__nostrlogin_nip46",LOGGED_IN_ACCOUNTS="__nostrlogin_accounts",RECENT_ACCOUNTS="__nostrlogin_recent",OUTBOX_RELAYS$1=["wss://purplepag.es","wss://relay.nos.social","wss://user.kindpag.es","wss://relay.damus.io","wss://nos.lol"],DEFAULT_SIGNUP_RELAYS=["wss://relay.damus.io/","wss://nos.lol/","wss://relay.primal.net/"],localStorageSetItem=(e,t)=>{localStorage.setItem(e,t)},localStorageGetItem=e=>{const t=window.localStorage.getItem(e);if(t)try{return JSON.parse(t)}catch{}return null},localStorageRemoveItem=e=>{localStorage.removeItem(e)},fetchProfile=async(e,t)=>{const n=new NDKUser({pubkey:e.pubkey});return n.ndk=t,await n.fetchProfile()},prepareSignupRelays=e=>{const t=(e||"").split(",").map(e=>e.trim()).filter(e=>e.startsWith("ws"));return t.length||t.push(...DEFAULT_SIGNUP_RELAYS),t},createProfile=async(e,t,n,r,i)=>{const s={name:e.name},o=new NDKEvent(t,{kind:0,created_at:Math.floor(Date.now()/1e3),pubkey:e.pubkey,content:JSON.stringify(s),tags:[]});window.location.hostname&&o.tags.push(["client",window.location.hostname]);const a=new NDKEvent(t,{kind:10002,created_at:Math.floor(Date.now()/1e3),pubkey:e.pubkey,content:"",tags:[]}),c=prepareSignupRelays(r);for(const e of c)a.tags.push(["r",e]);await o.sign(n),console.log("signed profile",o),await a.sign(n),console.log("signed relays",a);const l=i&&i.length?i:OUTBOX_RELAYS$1;await o.publish(NDKRelaySet.fromRelayUrls(l,t)),console.log("published profile",o),await a.publish(NDKRelaySet.fromRelayUrls(l,t)),console.log("published relays",a)},bunkerUrlToInfo=(e,t="")=>{const n=new URL(e);return{pubkey:"",signerPubkey:n.hostname||n.pathname.split("//")[1],sk:t||generatePrivateKey(),relays:n.searchParams.getAll("relay"),token:n.searchParams.get("secret")||"",authMethod:"connect"}},isBunkerUrl=e=>e.startsWith("bunker://"),getBunkerUrl=async(e,t)=>{if(!e)return"";if(isBunkerUrl(e))return e;if(e.includes("@")){const[n,r]=e.toLocaleLowerCase().split("@"),i=t.devOverrideBunkerOrigin||`https://${r}`,s=`${i}/.well-known/nostr.json?name=_`,o=`${i}/.well-known/nostr.json?name=${n}`,a=await fetch(s),c=await a.json(),l=c.names._,h=c.nip46[l],d=await fetch(o),u=(await d.json()).names[n];if(!h.length)throw new Error("Bunker relay not provided");return`bunker://${u}?relay=${h[0]}`}throw new Error("Invalid user name or bunker url")},checkNip05=async e=>{let t=!1,n="",r="";return await(async()=>{if(!e||!e.includes("@"))return;const[i,s]=e.toLocaleLowerCase().split("@");if(!i)return;if(!new RegExp(/^[\w-.]+@([\w-]+\.)+[\w-]{2,8}$/g).test(e))return void(n="Invalid name");if(!s)return void(n="Select service");const o=`https://${s}/.well-known/nostr.json?name=${i.toLowerCase()}`;try{const e=await fetch(o),t=await e.json();if(t.names[i])return void(r=t.names[i])}catch{}t=!0})(),{available:t,taken:""!=r,error:n,pubkey:r}},upgradeInfo=e=>{"typeAuthMethod"in e&&delete e.typeAuthMethod,e.authMethod||("extension"in e&&e.extension?e.authMethod="extension":"readOnly"in e&&e.readOnly?e.authMethod="readOnly":e.authMethod="connect"),e.nip05&&isBunkerUrl(e.nip05)&&(e.bunkerUrl=e.nip05,e.nip05=""),"connect"!==e.authMethod||e.signerPubkey||(e.signerPubkey=e.pubkey)},localStorageAddAccount=e=>{localStorageSetItem(LOCAL_STORE_KEY,JSON.stringify(e));const t=localStorageGetItem(LOGGED_IN_ACCOUNTS)||[],n=localStorageGetItem(RECENT_ACCOUNTS)||[];t.forEach(e=>upgradeInfo(e)),n.forEach(e=>upgradeInfo(e));const r=t,i=t.findIndex(t=>t.pubkey===e.pubkey&&t.authMethod===e.authMethod);-1!==i?r[i]=e:r.push(e);const s=n.filter(t=>t.pubkey!==e.pubkey||t.authMethod!==e.authMethod);localStorageSetItem(RECENT_ACCOUNTS,JSON.stringify(s)),localStorageSetItem(LOGGED_IN_ACCOUNTS,JSON.stringify(r))},localStorageRemoveCurrentAccount=()=>{const e=localStorageGetItem(LOCAL_STORE_KEY);if(!e)return;upgradeInfo(e);const t={...e};delete t.sk,delete t.otpData;const n=localStorageGetItem(LOGGED_IN_ACCOUNTS)||[],r=localStorageGetItem(RECENT_ACCOUNTS)||[];n.forEach(e=>upgradeInfo(e)),r.forEach(e=>upgradeInfo(e));const i=r;if("connect"===t.authMethod&&t.bunkerUrl&&t.bunkerUrl.includes("secret="))console.log("nostr login bunker conn with a secret not saved to recent");else if("local"===t.authMethod)console.log("nostr login temporary local keys not save to recent");else{const e=r.findIndex(e=>e.pubkey===t.pubkey&&e.authMethod===t.authMethod);-1!==e?i[e]=t:i.push(t)}const s=n.filter(t=>t.pubkey!==e.pubkey||t.authMethod!==e.authMethod);localStorageSetItem(RECENT_ACCOUNTS,JSON.stringify(i)),localStorageSetItem(LOGGED_IN_ACCOUNTS,JSON.stringify(s)),localStorageRemoveItem(LOCAL_STORE_KEY)},localStorageRemoveRecent=e=>{const t=localStorageGetItem(RECENT_ACCOUNTS)||[];t.forEach(e=>upgradeInfo(e));const n=t.filter(t=>t.pubkey!==e.pubkey||t.authMethod!==e.authMethod);localStorageSetItem(RECENT_ACCOUNTS,JSON.stringify(n))},localStorageGetRecents=()=>{const e=localStorageGetItem(RECENT_ACCOUNTS)||[];return e.forEach(e=>upgradeInfo(e)),e},localStorageGetAccounts=()=>{const e=localStorageGetItem(LOGGED_IN_ACCOUNTS)||[];return e.forEach(e=>upgradeInfo(e)),e},localStorageGetCurrent=()=>{const e=localStorageGetItem(LOCAL_STORE_KEY);return e&&upgradeInfo(e),e},getDarkMode=e=>{const t=localStorage.getItem("nl-dark-mode");return t?Boolean(JSON.parse(t)):void 0!==e.darkMode?e.darkMode:!(!window.matchMedia||!window.matchMedia("(prefers-color-scheme: dark)").matches)},getIcon=async()=>document.location.origin+"/favicon.ico";class NostrRpc extends NDKNostrRpc{_ndk;_signer;requests=new Set;sub;_useNip44=!1;constructor(e,t){super(e,t,e.debug.extend("nip46:signer:rpc")),this._ndk=e,this._signer=t}async subscribe(e){return e.kinds=e.kinds?.filter(e=>24133===e),this.sub=await super.subscribe(e),this.sub}stop(){this.sub&&(this.sub.stop(),this.sub=void 0)}setUseNip44(e){this._useNip44=e}isNip04(e){const t=e.length;return!(t<28)&&("?"===e[t-28]&&"i"===e[t-27]&&"v"===e[t-26]&&"="===e[t-25])}async parseEvent(e){const t=this._ndk.getUser({pubkey:e.pubkey});t.ndk=this._ndk;const n=this.isNip04(e.content)?await this._signer.decrypt(t,e.content,"nip04"):await this._signer.decrypt(t,e.content,"nip44"),r=JSON.parse(n),{id:i,method:s,params:o,result:a,error:c}=r;return s?{id:i,pubkey:e.pubkey,method:s,params:o,event:e}:{id:i,result:a,error:c,event:e}}async parseNostrConnectReply(e,t){const n=new NDKEvent(this._ndk,e),r=await this.parseEvent(n);if(console.log("nostr connect parsedEvent",r),r.method)throw new Error("Bad nostr connect reply");{const e=r;if(e.result!==t)throw new Error(e.error);return n.pubkey}}async listen(e){const t=this._signer.pubkey;console.log("nostr-login listening for conn to",t);const n=await this.subscribe({kinds:[24133],"#p":[t]});return new Promise((t,r)=>{n.on("event",async n=>{try{const i=await this.parseEvent(n);if(!i.method){const s=i;if("auth_url"===s.result)return;"ack"===s.result||s.result===e?t(n.pubkey):r(s.error)}}catch(e){console.log("error parsing event",e,n.rawEvent())}this.stop()})})}async connect(e,t,n){return new Promise((r,i)=>{const s=[e,t||"",n||""];this.sendRequest(e,"connect",s,24133,e=>{"ack"===e.result?r():i(e.error)})})}getId(){return Math.random().toString(36).substring(7)}async sendRequest(e,t,n=[],r=24133,i){const s=this.getId();this.setResponseHandler(s,i);const o=await this.createRequestEvent(s,e,t,n,r);console.log("sendRequest",{event:o,method:t,remotePubkey:e,params:n}),await o.publish()}setResponseHandler(e,t){let n=!1;const r=Date.now();return new Promise(()=>{const i=s=>{"auth_url"===s.result?(this.once(`response-${e}`,i),n||(n=!0,this.emit("authUrl",s.error))):t&&this.requests.has(e)&&(this.requests.delete(e),console.log("nostr-login processed nip46 request in",Date.now()-r,"ms"),t(s))};this.once(`response-${e}`,i)})}async createRequestEvent(e,t,n,r=[],i=24133){this.requests.add(e);const s=await this._signer.user(),o=this._ndk.getUser({pubkey:t}),a={id:e,method:n,params:r},c=new NDKEvent(this._ndk,{kind:i,content:JSON.stringify(a),tags:[["p",t]],pubkey:s.pubkey}),l=this._useNip44&&"create_account"!==n;return c.content=l?await this._signer.encrypt(o,c.content,"nip44"):await this._signer.encrypt(o,c.content,"nip04"),await c.sign(this._signer),c}}class IframeNostrRpc extends NostrRpc{peerOrigin;iframePort;iframeRequests=new Map;constructor(e,t,n){super(e,t),this._ndk=e,this.peerOrigin=n}async subscribe(e){return this.peerOrigin?new NDKSubscription(this._ndk,{},{closeOnEose:!0,cacheUsage:NDKSubscriptionCacheUsage.ONLY_CACHE}):super.subscribe(e)}setWorkerIframePort(e){if(!this.peerOrigin)throw new Error("Unexpected iframe port");this.iframePort=e,setInterval(()=>{console.log("iframe-nip46 ping"),this.iframePort.postMessage("ping")},5e3),e.onmessage=async e=>{if(console.log("iframe-nip46 got response",e.data),"string"==typeof e.data&&e.data.startsWith("errorNoKey")){const t=e.data.split(":")[1],{id:n="",pubkey:r=""}=this.iframeRequests.get(t)||{};return void(n&&r&&this.requests.has(n)&&this.emit(`iframeRestart-${r}`))}try{const t=e.data;if(!validateEvent(t))throw new Error("Invalid event from iframe");if(!verifySignature(t))throw new Error("Invalid event signature from iframe");const n=new NDKEvent(this._ndk,t),r=await this.parseEvent(n);r.method||(console.log("parsed response",r),this.emit(`response-${r.id}`,r))}catch(t){console.log("error parsing event",t,e.data)}}}async sendRequest(e,t,n=[],r=24133,i){const s=this.getId(),o=await this.createRequestEvent(s,e,t,n,r);this.setResponseHandler(s,i),this.iframePort?(this.iframeRequests.set(o.id,{id:s,pubkey:e}),console.log("iframe-nip46 sending request to",this.peerOrigin,o.rawEvent()),this.iframePort.postMessage(o.rawEvent())):await o.publish()}}class ReadyListener{origin;messages;promise;constructor(e,t){this.origin=t,this.messages=e,this.promise=new Promise(e=>{console.log(new Date,"started listener for",this.messages);const n=async r=>{const i=new URL(t).hostname,s=new URL(r.origin).hostname;(s===i||s.endsWith("."+i))&&Array.isArray(r.data)&&r.data.length&&this.messages.includes(r.data[0])&&(console.log(new Date,"got ready message from",r.origin,r.data),window.removeEventListener("message",n),e(r.data))};window.addEventListener("message",n)})}async wait(){console.log(new Date,"waiting for",this.messages);const e=await this.promise;return console.log(new Date,"finished waiting for",this.messages,e),e}}class Nip46Signer extends NDKNip46Signer{_rpc;_remotePubkey="";constructor(e,t,n,r){super(e,n,t),this._remotePubkey=n,this._rpc=new IframeNostrRpc(e,t,r),this._rpc.setUseNip44(!0),this._rpc.on("authUrl",e=>{this.emit("authUrl",e)}),this.rpc=this._rpc}get remotePubkey(){return this._remotePubkey}set remotePubkey(e){this._remotePubkey=e}async setSignerPubkey(e,t=!1){console.log("setSignerPubkey",e),this.remotePubkey=e,this._rpc.on(`iframeRestart-${e}`,()=>{this.emit("iframeRestart")}),await this.initUserPubkey(t?e:"")}async initUserPubkey(e){if(this.userPubkey)throw new Error("Already called initUserPubkey");this.userPubkey=e||await new Promise((e,t)=>{if(!this.remotePubkey)throw new Error("Signer pubkey not set");console.log("get_public_key",this.remotePubkey),this._rpc.sendRequest(this.remotePubkey,"get_public_key",[],24133,t=>{e(t.result)})})}async listen(e){const t=await this.rpc.listen(e);await this.setSignerPubkey(t)}async connect(e,t){if(!this.remotePubkey)throw new Error("No signer pubkey");await this._rpc.connect(this.remotePubkey,e,t),await this.setSignerPubkey(this.remotePubkey)}async setListenReply(e,t){const n=await this._rpc.parseNostrConnectReply(e,t);await this.setSignerPubkey(n,!0)}async createAccount2({bunkerPubkey:e,name:t,domain:n,perms:r=""}){const i=[t,n,"",r],s=await new Promise(t=>{this.rpc.sendRequest(e,"create_account",i,void 0,t)});if(console.log("create_account pubkey",s),"error"===s.result)throw new Error(s.error);return s.result}}class BannerManager extends lib$1.EventEmitter{banner=null;iframeReady;params;constructor(e){super(),this.params=e}onAuthUrl(e,t){this.banner&&(this.banner.notify=e?{mode:t?"iframeAuthUrl":"authUrl",url:e}:{mode:""})}onIframeRestart(e){this.banner&&(this.iframeReady=new ReadyListener(["rebinderDone","rebinderError"],new URL(e).origin),this.banner.notify={mode:"rebind",url:e})}onUserInfo(e){this.banner&&(this.banner.userInfo=e)}onCallTimeout(){this.banner&&(this.banner.notify={mode:"timeout"})}onCallStart(){this.banner&&(this.banner.isLoading=!0)}async onCallEnd(){this.banner&&(this.iframeReady&&(await this.iframeReady.wait(),this.iframeReady=void 0),this.banner.isLoading=!1,this.banner.notify={mode:""})}onUpdateAccounts(e){this.banner&&(this.banner.accounts=e)}onDarkMode(e){this.banner&&(this.banner.darkMode=e)}launchAuthBanner(e){this.banner=document.createElement("nl-banner"),this.banner.setAttribute("dark-mode",String(getDarkMode(e))),e.theme&&this.banner.setAttribute("theme",e.theme),e.noBanner&&this.banner.setAttribute("hidden-mode","true"),this.banner.addEventListener("handleLoginBanner",e=>{this.emit("launch",e.detail)}),this.banner.addEventListener("handleConfirmLogout",()=>{this.emit("onConfirmLogout")}),this.banner.addEventListener("handleLogoutBanner",async()=>{this.emit("logout")}),this.banner.addEventListener("handleImportModal",e=>{this.emit("import")}),this.banner.addEventListener("handleNotifyConfirmBanner",e=>{this.emit("onAuthUrlClick",e.detail)}),this.banner.addEventListener("handleNotifyConfirmBannerIframe",e=>{this.emit("onIframeAuthUrlClick",e.detail)}),this.banner.addEventListener("handleSwitchAccount",e=>{this.emit("onSwitchAccount",e.detail)}),this.banner.addEventListener("handleOpenWelcomeModal",()=>{this.emit("launch"),this.banner&&(this.banner.isOpen=!1)}),document.body.appendChild(this.banner)}}const decoder=new TextDecoder,u={minPlaintextSize:1,maxPlaintextSize:65535,utf8Encode:utf8ToBytes$6,utf8Decode:e=>decoder.decode(e),getConversationKey(e,t){const n=secp256k1$1.getSharedSecret(e,"02"+t).subarray(1,33);return extract(sha256$3,n,"nip44-v2")},getMessageKeys(e,t){const n=expand(sha256$3,e,t,76);return{chacha_key:n.subarray(0,32),chacha_nonce:n.subarray(32,44),hmac_key:n.subarray(44,76)}},calcPaddedLen(e){if(!Number.isSafeInteger(e)||e<1)throw new Error("expected positive integer");if(e<=32)return 32;const t=1<<Math.floor(Math.log2(e-1))+1,n=t<=256?32:t/8;return n*(Math.floor((e-1)/n)+1)},writeU16BE(e){if(!Number.isSafeInteger(e)||e<u.minPlaintextSize||e>u.maxPlaintextSize)throw new Error("invalid plaintext size: must be between 1 and 65535 bytes");const t=new Uint8Array(2);return new DataView(t.buffer).setUint16(0,e,!1),t},pad(e){const t=u.utf8Encode(e),n=t.length;return concatBytes$4(u.writeU16BE(n),t,new Uint8Array(u.calcPaddedLen(n)-n))},unpad(e){const t=new DataView(e.buffer).getUint16(0),n=e.subarray(2,2+t);if(t<u.minPlaintextSize||t>u.maxPlaintextSize||n.length!==t||e.length!==2+u.calcPaddedLen(t))throw new Error("invalid padding");return u.utf8Decode(n)},hmacAad(e,t,n){if(32!==n.length)throw new Error("AAD associated data must be 32 bytes");const r=concatBytes$4(n,t);return hmac$3(sha256$3,e,r)},decodePayload(e){if("string"!=typeof e)throw new Error("payload must be a valid string");const t=e.length;if(t<132||t>87472)throw new Error("invalid payload length: "+t);if("#"===e[0])throw new Error("unknown encryption version");let n;try{n=base64.decode(e)}catch(e){throw new Error("invalid base64: "+e.message)}const r=n.length;if(r<99||r>65603)throw new Error("invalid data length: "+r);const i=n[0];if(2!==i)throw new Error("unknown encryption version "+i);return{nonce:n.subarray(1,33),ciphertext:n.subarray(33,-32),mac:n.subarray(-32)}}};function encryptNip44(e,t,n=randomBytes$2(32)){const{chacha_key:r,chacha_nonce:i,hmac_key:s}=u.getMessageKeys(t,n),o=u.pad(e),a=chacha20(r,i,o),c=u.hmacAad(s,a,n);return base64.encode(concatBytes$4(new Uint8Array([2]),n,a,c))}function decryptNip44(e,t){const{nonce:n,ciphertext:r,mac:i}=u.decodePayload(e),{chacha_key:s,chacha_nonce:o,hmac_key:a}=u.getMessageKeys(t,n);if(!equalBytes(u.hmacAad(a,r,n),i))throw new Error("invalid MAC");const c=chacha20(s,o,r);return u.unpad(c)}class Nip44{cache=new Map;createKey(e,t){return u.getConversationKey(e,t)}getKey(e,t,n){const r=getPublicKey(e)+t;let i=this.cache.get(r);if(i)return i;const s=this.createKey(e,t);return this.cache.set(r,s),s}encrypt(e,t,n){return encryptNip44(n,this.getKey(e,t))}decrypt(e,t,n){return decryptNip44(n,this.getKey(e,t))}}const OUTBOX_RELAYS=["wss://user.kindpag.es","wss://purplepag.es","wss://relay.nos.social"],DEFAULT_NOSTRCONNECT_RELAYS=["wss://relay.nsec.app/","wss://ephemeral.snowflare.cc/"],CONNECT_TIMEOUT=5e3,NOSTRCONNECT_APPS=[{name:"Nsec.app",domain:"nsec.app",canImport:!0,img:"https://nsec.app/assets/favicon.ico",link:"https://use.nsec.app/<nostrconnect>",relays:DEFAULT_NOSTRCONNECT_RELAYS},{name:"Amber",img:"https://raw.githubusercontent.com/greenart7c3/Amber/refs/heads/master/assets/android-icon.svg",link:"<nostrconnect>",relays:DEFAULT_NOSTRCONNECT_RELAYS},{name:"Other key stores",img:"",link:"<nostrconnect>",relays:DEFAULT_NOSTRCONNECT_RELAYS}];class AuthNostrService extends lib$1.EventEmitter{ndk;profileNdk;signer=null;localSigner=null;params;signerPromise;signerErrCallback;readyPromise;readyCallback;nip44Codec=new Nip44;nostrConnectKey="";nostrConnectSecret="";iframe;starterReady;nip04;nip44;constructor(e){super(),this.params=e,this.ndk=new NDK({enableOutboxModel:!1}),this.profileNdk=new NDK({enableOutboxModel:!0,explicitRelayUrls:OUTBOX_RELAYS}),this.profileNdk.connect(CONNECT_TIMEOUT),this.nip04={encrypt:this.encrypt04.bind(this),decrypt:this.decrypt04.bind(this)},this.nip44={encrypt:this.encrypt44.bind(this),decrypt:this.decrypt44.bind(this)}}isIframe(){return!!this.iframe}async waitReady(){if(this.signerPromise)try{await this.signerPromise}catch{}if(this.readyPromise)try{await this.readyPromise}catch{}}cancelNostrConnect(){this.releaseSigner(),this.resetAuth()}async nostrConnect(e,{domain:t="",link:n="",iframeUrl:r="",importConnect:i=!1}={}){e=e&&e.length>0?e:DEFAULT_NOSTRCONNECT_RELAYS;const s={authMethod:"connect",pubkey:"",signerPubkey:"",sk:this.nostrConnectKey,domain:t,relays:e,iframeUrl:r};if(console.log("nostrconnect info",s,n),n&&!r&&window.open(n,"_blank","width=400,height=700"),await this.initSigner(s,{listen:!0}),!s.pubkey||!s.signerPubkey)throw new Error("Bad remote pubkey");return s.bunkerUrl=`bunker://${s.signerPubkey}?${e.map((e,t)=>`${0!==t?"&":""}relay=${e}`)}`,i||this.onAuth("login",s),s}async createNostrConnect(e){this.nostrConnectKey=generatePrivateKey(),this.nostrConnectSecret=Math.random().toString(36).substring(7);const t=getPublicKey(this.nostrConnectKey),n=encodeURIComponent(document.location.host),r=encodeURIComponent(document.location.origin);return`nostrconnect://${t}?image=${encodeURIComponent(await getIcon())}&url=${r}&name=${n}&perms=${encodeURIComponent(this.params.optionsModal.perms||"")}&secret=${this.nostrConnectSecret}${(e||[]).length>0?(e||[]).map((e,t)=>`&relay=${e}`):""}`}async getNostrConnectServices(){const e=await this.createNostrConnect(DEFAULT_NOSTRCONNECT_RELAYS),t=NOSTRCONNECT_APPS.map(e=>({...e}));for(const n of t){let t=[...DEFAULT_NOSTRCONNECT_RELAYS];if(n.link.startsWith("https://")){const e=n.domain||new URL(n.link).hostname;try{const r=await(await fetch(`https://${e}/.well-known/nostr.json`)).json(),i=r.names._,s=r.nip46?.[i];Array.isArray(s)&&s.length>0&&(t=s),n.iframeUrl=r.nip46?.iframe_url||""}catch(e){console.log("Bad app info",e,n)}}const r=e.split("&relay=")[0]+t.map(e=>`&relay=${encodeURIComponent(e)}`).join("");n.link=n.iframeUrl?r:n.link.replace("<nostrconnect>",r)}return[e,t]}async localSignup(e,t){const n=!t,r={pubkey:getPublicKey(t=t||generatePrivateKey()),sk:t,name:e,authMethod:"local"};console.log(`localSignup name: ${e}`),await this.setLocal(r,n)}async setLocal(e,t){this.releaseSigner(),this.localSigner=new NDKPrivateKeySigner(e.sk),t&&await createProfile(e,this.profileNdk,this.localSigner,this.params.optionsModal.signupRelays,this.params.optionsModal.outboxRelays),this.onAuth(t?"signup":"login",e)}prepareImportUrl(e){if("otp"===this.params.userInfo?.authMethod)return e+"&import=true";if(!this.localSigner||"local"!==this.params.userInfo?.authMethod)throw new Error("Most be local keys");return e+"#import="+nip19_exports.nsecEncode(this.localSigner.privateKey)}async importAndConnect(e){const{relays:t,domain:n,link:r,iframeUrl:i}=e;if(!n)throw new Error("Domain required");const s=await this.nostrConnect(t,{domain:n,link:r,importConnect:!0,iframeUrl:i});await this.logout(!0),this.localSigner=null,this.onAuth("login",s)}setReadOnly(e){const t={pubkey:e,authMethod:"readOnly"};this.onAuth("login",t)}setExtension(e){const t={pubkey:e,authMethod:"extension"};this.onAuth("login",t)}setOTP(e,t){const n={pubkey:e,authMethod:"otp",otpData:t};this.onAuth("login",n)}async setConnect(e){this.releaseSigner(),await this.startAuth(),await this.initSigner(e),this.onAuth("login",e),await this.endAuth()}async createAccount(e){const[t,n]=e.split("@"),r=await getBunkerUrl(`_@${n}`,this.params.optionsModal);console.log("create account bunker's url",r);const i=bunkerUrlToInfo(r);if(!i.signerPubkey)throw new Error("Bad bunker url");const s=Boolean(this.params.userInfo);await this.initSigner(i,{eventToAddAccount:s});return{bunkerUrl:`bunker://${await this.signer.createAccount2({bunkerPubkey:i.signerPubkey,name:t,domain:n,perms:this.params.optionsModal.perms})}?`+(i.relays??[]).map(e=>`relay=${encodeURIComponent(e)}`).join("&"),sk:i.sk}}releaseSigner(){this.signer=null,this.signerErrCallback?.("cancelled"),this.localSigner=null;for(const e of this.ndk.pool.relays.keys())this.ndk.pool.removeRelay(e)}async logout(e=!1){e||this.releaseSigner(),localStorageRemoveCurrentAccount(),this.onAuth("logout"),this.emit("updateAccounts")}setUserInfo(e){this.params.userInfo=e,this.emit("onUserInfo",e),e&&(localStorageAddAccount(e),this.emit("updateAccounts"))}exportKeys(){return this.params.userInfo?"local"!==this.params.userInfo.authMethod?"":nip19_exports.nsecEncode(this.params.userInfo.sk):""}onAuth(e,t=null){if("logout"!==e&&!t)throw new Error("No user info in onAuth");if(t&&this.params.userInfo&&(t.pubkey!==this.params.userInfo.pubkey||t.authMethod!==this.params.userInfo.authMethod)){const e=new CustomEvent("nlAuth",{detail:{type:"logout"}});console.log("nostr-login auth",e.detail),document.dispatchEvent(e)}this.setUserInfo(t),t&&fetchProfile(t,this.profileNdk).then(e=>{if(this.params.userInfo!==t)return;const n={...this.params.userInfo,picture:e?.image||e?.picture,name:e?.name||e?.displayName||e?.nip05||nip19_exports.npubEncode(t.pubkey)};this.setUserInfo(n)});try{const n=t?nip19_exports.npubEncode(t.pubkey):"",r={type:e};"logout"===e?(this.iframe&&this.iframe.remove(),this.iframe=void 0):(r.pubkey=t.pubkey,r.name=t.name,t.sk&&(r.localNsec=nip19_exports.nsecEncode(t.sk)),t.relays&&(r.relays=t.relays),t.otpData&&(r.otpData=t.otpData),r.method=t.authMethod||"connect");const i=new CustomEvent("nlAuth",{detail:r});console.log("nostr-login auth",r),document.dispatchEvent(i),this.params.optionsModal.onAuth&&this.params.optionsModal.onAuth(n,r)}catch(e){console.log("onAuth error",e)}}async createIframe(e){if(!e)return;const t=new URL(e);let n;const r="__nostr-login-worker-iframe-"+t.hostname.replaceAll(".","-");n=document.querySelector(`#${r}`),console.log("iframe",r,n),n||(n=document.createElement("iframe"),n.setAttribute("width","0"),n.setAttribute("height","0"),n.setAttribute("border","0"),n.style.display="none",n.id=r,document.body.append(n)),n.setAttribute("src",e);const i=new ReadyListener(["workerReady","workerError"],t.origin);await new Promise(e=>{n.addEventListener("load",e)});const s=await i.wait();return console.log("nostr-login iframe ready",e,s),{iframe:n,port:s[1]}}async sendNeedAuth(){const[e]=await this.getNostrConnectServices(),t=new CustomEvent("nlNeedAuth",{detail:{nostrconnect:e}});console.log("nostr-login need auth",e),document.dispatchEvent(t)}isAuthing(){return!!this.readyCallback}async startAuth(){if(console.log("startAuth"),this.readyCallback)throw new Error("Already started");this.readyPromise=new Promise(e=>this.readyCallback=e)}async endAuth(){if(console.log("endAuth",this.params.userInfo),this.params.userInfo&&this.params.userInfo.iframeUrl){const{iframe:e,port:t}=await this.createIframe(this.params.userInfo.iframeUrl)||{};if(this.iframe=e,!this.iframe||!t)return;this.signer.rpc.setWorkerIframePort(t)}this.readyCallback(),this.readyCallback=void 0}resetAuth(){this.readyCallback&&this.readyCallback(),this.readyCallback=void 0}async listen(e){if(!e.iframeUrl)return this.signer.listen(this.nostrConnectSecret);const t=await this.starterReady.wait();if("starterError"===t[0])throw new Error(t[1]);return this.signer.setListenReply(t[1],this.nostrConnectSecret)}async connect(e,t){return this.signer.connect(e.token,t)}async initSigner(e,{listen:t=!1,connect:n=!1,eventToAddAccount:r=!1}={}){if(this.signerPromise)try{await this.signerPromise}catch{}console.log("initSigner info",e);const i=e.iframeUrl?new URL(e.iframeUrl).origin:void 0;return i&&(this.starterReady=new ReadyListener(["starterDone","starterError"],i)),this.emit("onIframeUrl",e.iframeUrl),this.signerPromise=new Promise(async(s,o)=>{this.signerErrCallback=o;try{if(console.log("NDK relays before connect:",Array.from(this.ndk.pool.relays.keys())),e.relays&&!e.iframeUrl)for(const t of e.relays)this.ndk.addExplicitRelay(t,void 0),console.log("Added relay:",t);console.log("NDK relays after add:",Array.from(this.ndk.pool.relays.keys())),await this.ndk.connect(CONNECT_TIMEOUT),console.log("NDK connected relays:",Array.from(this.ndk.pool.relays.entries()).map(([e,t])=>({url:e,status:t.status,connectionStats:t.connectionStats})));const o=new NDKPrivateKeySigner(e.sk);this.signer=new Nip46Signer(this.ndk,o,e.signerPubkey,i),this.signer.on("iframeRestart",async()=>{const t=e.iframeUrl+(e.iframeUrl.includes("?")?"&":"?")+"pubkey="+e.pubkey+"&rebind="+o.pubkey;this.emit("iframeRestart",{pubkey:e.pubkey,iframeUrl:t})}),this.signer.on("authUrl",t=>{console.log("nostr login auth url",t),this.emit("onAuthUrl",{url:t,iframeUrl:e.iframeUrl,eventToAddAccount:r})}),t?await this.listen(e):n?await this.connect(e,this.params.optionsModal.perms):await this.signer.initUserPubkey(e.pubkey),e.pubkey=this.signer.userPubkey,e.signerPubkey=this.signer.remotePubkey,s()}catch(e){console.log("initSigner failure",e),this.signer=null,o(e)}}),this.signerPromise}async authNip46(e,{name:t,bunkerUrl:n,sk:r="",domain:i="",iframeUrl:s=""}){try{const o=bunkerUrlToInfo(n,r);if(isBunkerUrl(t)?o.bunkerUrl=t:(o.nip05=t,o.domain=t.split("@")[1]),i&&(o.domain=i),s&&(o.iframeUrl=s),!o.signerPubkey||!o.sk||!o.relays||0===o.relays.length)throw new Error(`Bad bunker url ${n}`);const a=Boolean(this.params.userInfo);console.log("authNip46",e,o),await this.initSigner(o,{connect:!0,eventToAddAccount:a}),this.onAuth(e,o)}catch(e){throw console.log("nostr login auth failed",e),e}}async signEvent(e){const t=(async()=>(this.localSigner?(e.pubkey=getPublicKey(this.localSigner.privateKey),e.id=getEventHash(e),e.sig=await this.localSigner.sign(e)):(e.pubkey=this.signer?.remotePubkey,e.id=getEventHash(e),e.sig=await(this.signer?.sign(e))),e))(),n=new Promise((e,t)=>{setTimeout(()=>t(new Error("Sign timeout")),2e4)}),r=await Promise.race([t,n]);return console.log("signed",{event:r}),r}async codec_call(e,t,n){return new Promise((r,i)=>{this.signer.rpc.sendRequest(this.signer.remotePubkey,e,[t,n],24133,e=>{e.error?i(e.error):r(e.result)})})}async encrypt04(e,t){return this.localSigner?this.localSigner.encrypt(new NDKUser({pubkey:e}),t):this.signer.encrypt(new NDKUser({pubkey:e}),t)}async decrypt04(e,t){return this.localSigner?this.localSigner.decrypt(new NDKUser({pubkey:e}),t):this.codec_call("nip04_decrypt",e,t)}async encrypt44(e,t){return this.localSigner?this.nip44Codec.encrypt(this.localSigner.privateKey,e,t):this.codec_call("nip44_encrypt",e,t)}async decrypt44(e,t){return this.localSigner?this.nip44Codec.decrypt(this.localSigner.privateKey,e,t):this.codec_call("nip44_decrypt",e,t)}}class ModalManager extends lib$1.EventEmitter{modal=null;params;extensionService;authNostrService;launcherPromise;accounts=[];recents=[];opt;constructor(e,t,n){super(),this.params=e,this.extensionService=n,this.authNostrService=t}async waitReady(){if(this.launcherPromise){try{await this.launcherPromise}catch{}this.launcherPromise=void 0}}async launch(e){console.log("nostr-login launch",e),this.launcherPromise&&await this.waitReady(),this.authNostrService.isAuthing()&&this.authNostrService.resetAuth(),this.opt=e;const t=document.createElement("dialog");if(this.modal=document.createElement("nl-auth"),this.modal.accounts=this.accounts,this.modal.recents=this.recents,this.modal.setAttribute("dark-mode",String(getDarkMode(e))),e.theme&&this.modal.setAttribute("theme",e.theme),e.startScreen&&this.modal.setAttribute("start-screen",e.startScreen),e.bunkers)this.modal.setAttribute("bunkers",e.bunkers);else{let e="nsec.app,highlighter.com";this.modal.setAttribute("bunkers",e)}void 0!==e.methods&&(this.modal.authMethods=e.methods),void 0!==e.localSignup&&(this.modal.localSignup=e.localSignup),void 0!==e.signupNstart&&(this.modal.signupNjump=e.signupNstart),e.title&&(this.modal.welcomeTitle=e.title),e.description&&(this.modal.welcomeDescription=e.description),this.modal.hasExtension=this.extensionService.hasExtension(),this.modal.hasOTP=!!e.otpRequestUrl&&!!e.otpReplyUrl,this.modal.isLoadingExtension=!1,this.modal.isLoading=!1,[this.modal.connectionString,this.modal.connectionStringServices]=await this.authNostrService.getNostrConnectServices(),t.appendChild(this.modal),document.body.appendChild(t);let n="";return this.launcherPromise=new Promise((e,r)=>{t.addEventListener("close",()=>{r(new Error("Closed")),this.authNostrService.resetAuth(),this.modal&&(document.body.removeChild(this.modal.parentNode),this.modal=null)});const i=async e=>{this.modal&&(this.modal.isLoading=!1),await this.authNostrService.endAuth(),t.close(),this.modal=null,e()},s=async(t,n)=>{this.modal&&(this.modal.isLoading=!0);try{n&&!n.start||await this.authNostrService.startAuth(),await t(),n&&!n.end||await i(e)}catch(e){console.log("error",e),this.modal&&(this.modal.isLoading=!1,this.modal.authUrl="",this.modal.iframeUrl="","cancelled"!==e&&(this.modal.error=e.toString()))}},o=async(e,t)=>{await s(async()=>{const n=await getBunkerUrl(e,this.params.optionsModal);await this.authNostrService.authNip46("login",{name:e,bunkerUrl:n,domain:t})})},a=async e=>{await s(async()=>{const{bunkerUrl:t,sk:n}=await this.authNostrService.createAccount(e);await this.authNostrService.authNip46("signup",{name:e,bunkerUrl:t,sk:n})})},c=async()=>{try{await navigator.clipboard.writeText(this.authNostrService.exportKeys()),localStorageSetItem("backupKey","true")}catch(e){console.error("Failed to copy to clipboard: ",e)}},l=async e=>{await s(async()=>{const{iframeUrl:t}=e;e.link=this.authNostrService.prepareImportUrl(e.link),this.modal&&t&&(this.modal.authUrl=e.link,this.modal.iframeUrl=t,this.modal.isLoading=!1,console.log("nostrconnect authUrl",this.modal.authUrl,this.modal.iframeUrl)),await this.authNostrService.importAndConnect(e)})},h=async e=>{await s(async()=>{const{relays:t,domain:n,link:r,iframeUrl:i}=e||{};console.log("nostrConnect",e,t,n,r,i),this.modal&&(i&&(this.modal.authUrl=r,this.modal.iframeUrl=i,this.modal.isLoading=!1,console.log("nostrconnect authUrl",this.modal.authUrl,this.modal.iframeUrl)),e||(this.modal.isLoading=!1)),await this.authNostrService.nostrConnect(t,{domain:n,link:r,iframeUrl:i})})},d=async e=>{await s(async()=>{if(!e)throw new Error("Please enter some nickname");await this.authNostrService.localSignup(e)})},u=async()=>{await s(async()=>{const e=new URL(window.location.href),t=e.hostname.toLocaleLowerCase().replace(/^www\./i,"").charAt(0).toUpperCase()+e.hostname.slice(1),n=prepareSignupRelays(this.params.optionsModal.signupRelays);return this.modal.njumpIframe=`\n <html><body>\n <script src='https://start.njump.me/modal.js'><\/script>\n <script>\n new NstartModal({\n baseUrl: 'https://start.njump.me',\n // Required parameters\n an: '${t}',\n // Optional parameters\n s: [${this.opt.followNpubs?`'${this.opt.followNpubs}'`:""}],\n afb: false, // forceBunker\n asb: false, // skipBunker\n aan: false, // avoidNsec\n aac: true, // avoidNcryptsec\n ahc: true, // hide close button\n arr: ${JSON.stringify(n)}, //readRelays\n awr: ${JSON.stringify(n)}, //writeRelays\n // Callbacks\n onComplete: (result) => {\n console.log('Login token:', result.nostrLogin);\n window.parent.location.href='${window.location.href}#nostr-login='+result.nostrLogin;\n },\n onCancel: () => {\n window.parent.location.href='${window.location.href}#nostr-login=null';\n },\n }).open();\n <\/script>\n </body></html>\n `.replaceAll("&","&"),new Promise((e,t)=>{const n=async n=>{if(console.log("nsecOrBunker",n),n.startsWith("nsec1")){let t;try{t=nip19_exports.decode(n)}catch(e){throw new Error("Bad nsec value")}if("nsec"!==t.type)throw new Error("Bad bech32 type");await this.authNostrService.localSignup("",t.data),e()}else n.startsWith("bunker:")?(await this.authNostrService.authNip46("login",{name:"",bunkerUrl:n}),e()):t("null"===n?"Cancelled":"Unknown return value")};window.addEventListener("hashchange",async()=>{if(window.location.hash.startsWith("#nostr-login=")){const e=window.location.hash.split("#nostr-login=")[1],t=new URL(window.location.toString());t.hash="",window.history.replaceState({},"",t.toString()),n(e)}})})})};if(!this.modal)throw new Error("WTH?");this.modal.addEventListener("handleContinue",()=>{this.modal&&(this.modal.isLoading=!0,this.emit("onAuthUrlClick",this.modal.authUrl))}),this.modal.addEventListener("nlLogin",e=>{o(e.detail)}),this.modal.addEventListener("nlSignup",e=>{a(e.detail)}),this.modal.addEventListener("nlLocalSignup",e=>{d(e.detail)}),this.modal.addEventListener("nlSignupNjump",e=>{u()}),this.modal.addEventListener("nlImportAccount",e=>{l(e.detail)}),this.modal.addEventListener("nlExportKeys",e=>{c()}),this.modal.addEventListener("handleLogoutBanner",()=>{this.emit("onLogoutBanner")}),this.modal.addEventListener("nlNostrConnect",e=>{h(e.detail)}),this.modal.addEventListener("nlNostrConnectDefault",()=>{this.authNostrService.isAuthing()||h()}),this.modal.addEventListener("nlNostrConnectDefaultCancel",()=>{console.log("nlNostrConnectDefaultCancel"),this.authNostrService.cancelNostrConnect()}),this.modal.addEventListener("nlSwitchAccount",e=>{const n=e.detail;this.emit("onSwitchAccount",n),setTimeout(()=>t.close(),300)}),this.modal.addEventListener("nlLoginRecentAccount",async e=>{const n=e.detail;if("readOnly"===n.authMethod)this.authNostrService.setReadOnly(n.pubkey),t.close();else if("otp"===n.authMethod)try{this.modal.dispatchEvent(new CustomEvent("nlLoginOTPUser",{detail:n.nip05||n.pubkey}))}catch(e){console.error(e)}else if("extension"===n.authMethod)await this.extensionService.trySetExtensionForPubkey(n.pubkey),t.close();else{const e=n.bunkerUrl||n.nip05;if(!e)throw new Error("Bad connect info");o(e,n.domain)}}),this.modal.addEventListener("nlRemoveRecent",e=>{localStorageRemoveRecent(e.detail),this.emit("updateAccounts")});const p=async e=>{let t="";if(e.includes("@")){const{error:n,pubkey:r}=await checkNip05(e);if(!r)throw new Error(n);t=r}else if(e.startsWith("npub")){const{type:n,data:r}=nip19_exports.decode(e);if("npub"!==n)throw new Error("Bad npub");t=r}else 64===e.trim().length&&(t=e.trim(),nip19_exports.npubEncode(t));return t};this.modal.addEventListener("nlLoginReadOnly",async e=>{await s(async()=>{const t=e.detail,n=await p(t);this.authNostrService.setReadOnly(n)})}),this.modal.addEventListener("nlLoginExtension",async()=>{if(!this.extensionService.hasExtension())throw new Error("No extension");await s(async()=>{this.modal&&(this.modal.isLoadingExtension=!0,await this.extensionService.setExtension(),this.modal.isLoadingExtension=!1)})}),this.modal.addEventListener("nlLoginOTPUser",async e=>{await s(async()=>{if(!this.modal)return;const t=e.detail,r=await p(t),i=this.opt.otpRequestUrl+(this.opt.otpRequestUrl.includes("?")?"&":"?")+"pubkey="+r,s=await fetch(i);if(200!==s.status)throw console.warn("nostr-login: bad otp reply",s),new Error("Failed to send DM");this.modal.isOTP=!0,n=r,this.modal.isLoading=!1},{start:!0})}),this.modal.addEventListener("nlLoginOTPCode",async e=>{await s(async()=>{if(!this.modal)return;const t=e.detail,r=this.opt.otpReplyUrl+(this.opt.otpRequestUrl.includes("?")?"&":"?")+"pubkey="+n+"&code="+t,i=await fetch(r);if(200!==i.status)throw console.warn("nostr-login: bad otp reply",i),new Error("Invalid code");const s=await i.text();this.authNostrService.setOTP(n,s),this.modal.isOTP=!1},{end:!0})}),this.modal.addEventListener("nlCheckSignup",async e=>{const{available:t,taken:n,error:r}=await checkNip05(e.detail);this.modal&&(this.modal.error=String(r),!r&&n&&(this.modal.error="Already taken"),this.modal.signupNameIsAvailable=t)}),this.modal.addEventListener("nlCheckLogin",async e=>{const{available:t,taken:n,error:r}=await checkNip05(e.detail);this.modal&&(this.modal.error=String(r),t&&(this.modal.error="Name not found"),this.modal.loginIsGood=n)});const f=()=>{this.modal&&(this.modal.isLoading=!1),t.close(),r(new Error("Cancelled"))};this.modal.addEventListener("stopFetchHandler",f),this.modal.addEventListener("nlCloseModal",f),this.modal.addEventListener("nlChangeDarkMode",e=>{setDarkMode(e.detail),document.dispatchEvent(new CustomEvent("nlDarkMode",{detail:e.detail}))}),this.on("onIframeAuthUrlCallEnd",()=>{t.close(),this.modal=null,e()}),t.showModal()}),this.launcherPromise}async showIframeUrl(e){await this.waitReady(),this.launch({startScreen:"iframe"}).catch(()=>console.log("closed auth iframe")),this.modal.authUrl=e}connectModals(e){const t=async e=>{await this.launch(e)},n=document.getElementsByTagName("nl-button");for(let r=0;r<n.length;r++){const i=n[r].getAttribute("nl-theme"),s=n[r].getAttribute("start-screen"),o={...e};switch(i&&(o.theme=i),s){case"login":case"login-bunker-url":case"login-read-only":case"signup":case"switch-account":case"welcome":o.startScreen=s}n[r].addEventListener("click",function(){t(o)})}}onAuthUrl(e){this.modal&&(this.modal.authUrl=e,this.modal.isLoading=!1)}onIframeUrl(e){this.modal&&(console.log("modal iframe url",e),this.modal.iframeUrl=e)}onCallEnd(){this.modal&&this.modal.authUrl&&this.params.userInfo?.iframeUrl&&this.emit("onIframeAuthUrlCallEnd")}onUpdateAccounts(e,t){this.accounts=e,this.recents=t,this.modal&&(this.modal.accounts=e,this.modal.recents=t)}onDarkMode(e){this.modal&&(this.modal.darkMode=e)}}class Nostr{#e;nip04;nip44;constructor(e){this.#e=e,this.getPublicKey=this.getPublicKey.bind(this),this.signEvent=this.signEvent.bind(this),this.getRelays=this.getRelays.bind(this),this.nip04={encrypt:this.encrypt04.bind(this),decrypt:this.decrypt04.bind(this)},this.nip44={encrypt:this.encrypt44.bind(this),decrypt:this.decrypt44.bind(this)}}async ensureAuth(){if(await this.#e.waitReady(),!this.#e.getUserInfo()&&(await this.#e.launch(),!this.#e.getUserInfo()))throw new Error("Rejected by user")}async getPublicKey(){await this.ensureAuth();const e=this.#e.getUserInfo();if(e)return e.pubkey;throw new Error("No user")}async signEvent(e){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().signEvent(e))}async getRelays(){return{}}async encrypt04(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip04.encrypt(e,t))}async decrypt04(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip04.decrypt(e,t))}async encrypt44(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip44.encrypt(e,t))}async decrypt44(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip44.decrypt(e,t))}}class NostrExtensionService extends lib$1.EventEmitter{params;nostrExtension;constructor(e){super(),this.params=e}startCheckingExtension(e){if(this.checkExtension(e))return;const t=setInterval(()=>{this.checkExtension(e)&&clearTimeout(t)},100)}checkExtension(e){return!(this.nostrExtension||!window.nostr||window.nostr===e)&&(this.initExtension(e),!0)}async initExtension(e,t){this.nostrExtension=window.nostr,window.nostr=e,"extension"===this.params.userInfo?.authMethod&&await this.trySetExtensionForPubkey(this.params.userInfo.pubkey),t||setTimeout(()=>{window.nostr!==e&&this.nostrExtension!==window.nostr&&this.initExtension(e,!0)},300)}async setExtensionReadPubkey(e){window.nostr=this.nostrExtension;const t=await window.nostr.getPublicKey();e&&e!==t?this.emit("extensionLogout"):this.emit("extensionLogin",t)}async trySetExtensionForPubkey(e){if(this.nostrExtension)return this.setExtensionReadPubkey(e)}async setExtension(){return this.setExtensionReadPubkey()}unsetExtension(e){window.nostr===this.nostrExtension&&(window.nostr=e)}getExtension(){return this.nostrExtension}hasExtension(){return!!this.nostrExtension}}class NostrParams{userInfo;optionsModal;constructor(){this.userInfo=null,this.optionsModal={theme:"default",startScreen:"welcome",devOverrideBunkerOrigin:""}}}class Popup{popup=null;constructor(){}openPopup(e){if((!this.popup||this.popup.closed)&&(this.popup=window.open(e,"_blank","width=400,height=700"),console.log("popup",this.popup),!this.popup))throw new Error("Popup blocked. Try again, please!")}closePopup(){try{this.popup?.close(),this.popup=null}catch{}}}const CALL_TIMEOUT=5e3;class ProcessManager extends lib$1.EventEmitter{callCount=0;callTimer;constructor(){super()}onAuthUrl(){Boolean(this.callTimer)&&clearTimeout(this.callTimer)}onIframeUrl(){Boolean(this.callTimer)&&clearTimeout(this.callTimer)}async wait(e){let t,n;this.callTimer||(this.callTimer=setTimeout(()=>this.emit("onCallTimeout"),CALL_TIMEOUT)),this.callCount||this.emit("onCallStart"),this.callCount++;try{n=await e()}catch(e){t=e}if(this.callCount--,this.emit("onCallEnd"),this.callTimer&&clearTimeout(this.callTimer),this.callTimer=void 0,t)throw t;return n}}class NostrLoginInitializer{extensionService;params;authNostrService;nostr;processManager;popupManager;bannerManager;modalManager;customLaunchCallback;constructor(){this.params=new NostrParams,this.processManager=new ProcessManager,this.popupManager=new Popup,this.bannerManager=new BannerManager(this.params),this.authNostrService=new AuthNostrService(this.params),this.extensionService=new NostrExtensionService(this.params),this.modalManager=new ModalManager(this.params,this.authNostrService,this.extensionService);const e={waitReady:async()=>{await this.authNostrService.waitReady(),await this.modalManager.waitReady()},getUserInfo:()=>this.params.userInfo,getSigner:()=>{if("readOnly"===this.params.userInfo.authMethod)throw new Error("Read only");return"extension"===this.params.userInfo.authMethod?this.extensionService.getExtension():this.authNostrService},launch:()=>this.launch(),wait:e=>this.processManager.wait(e)};this.nostr=new Nostr(e),this.processManager.on("onCallTimeout",()=>{this.bannerManager.onCallTimeout()}),this.processManager.on("onCallEnd",()=>{this.bannerManager.onCallEnd(),this.modalManager.onCallEnd()}),this.processManager.on("onCallStart",()=>{this.bannerManager.onCallStart()}),this.authNostrService.on("onIframeUrl",e=>{this.modalManager.onIframeUrl(e)}),this.authNostrService.on("iframeRestart",({iframeUrl:e})=>{this.processManager.onIframeUrl(),this.bannerManager.onIframeRestart(e)}),this.authNostrService.on("onAuthUrl",({url:e,iframeUrl:t,eventToAddAccount:n})=>{this.processManager.onAuthUrl(),n?this.modalManager.onAuthUrl(e):this.params.userInfo?this.bannerManager.onAuthUrl(e,t):this.modalManager.onAuthUrl(e)}),this.authNostrService.on("updateAccounts",()=>{this.updateAccounts()}),this.authNostrService.on("onUserInfo",e=>{this.bannerManager.onUserInfo(e)}),this.modalManager.on("onAuthUrlClick",e=>{this.openPopup(e)}),this.bannerManager.on("onIframeAuthUrlClick",e=>{this.modalManager.showIframeUrl(e)}),this.modalManager.on("onSwitchAccount",async e=>{this.switchAccount(e)}),this.modalManager.on("onLogoutBanner",async e=>{logout()}),this.bannerManager.on("onConfirmLogout",async()=>{this.launch("confirm-logout")}),this.modalManager.on("updateAccounts",()=>{this.updateAccounts()}),this.bannerManager.on("logout",()=>{logout()}),this.bannerManager.on("onAuthUrlClick",e=>{this.openPopup(e)}),this.bannerManager.on("onSwitchAccount",async e=>{this.switchAccount(e)}),this.bannerManager.on("import",()=>{this.launch("import")}),this.extensionService.on("extensionLogin",e=>{this.authNostrService.setExtension(e)}),this.extensionService.on("extensionLogout",()=>{logout()}),this.bannerManager.on("launch",e=>{this.launch(e)})}openPopup(e){this.popupManager.openPopup(e)}async switchAccount(e,t=!1){if(console.log("nostr login switch to info",e),this.extensionService.unsetExtension(this.nostr),"readOnly"===e.authMethod)this.authNostrService.setReadOnly(e.pubkey);else if("otp"===e.authMethod)this.authNostrService.setOTP(e.pubkey,e.otpData||"");else if("local"===e.authMethod&&e.sk)this.authNostrService.setLocal(e,t);else if("extension"===e.authMethod)await this.extensionService.trySetExtensionForPubkey(e.pubkey);else{if(!("connect"===e.authMethod&&e.sk&&e.relays&&e.relays[0]))throw new Error("Bad auth info");this.authNostrService.setConnect(e)}}updateAccounts(){const e=localStorageGetAccounts(),t=localStorageGetRecents();this.bannerManager.onUpdateAccounts(e),this.modalManager.onUpdateAccounts(e,t)}async launchCustomNostrConnect(){try{this.authNostrService.isAuthing()&&this.authNostrService.cancelNostrConnect();const e=new Promise(e=>this.customLaunchCallback=e);await this.authNostrService.startAuth(),await this.authNostrService.sendNeedAuth();try{await this.authNostrService.nostrConnect(),await this.authNostrService.endAuth()}catch(t){"cancelled"===t&&await e}}catch(e){console.error("launchCustomNostrConnect",e)}}fulfillCustomLaunchPromise(){if(this.customLaunchCallback){const e=this.customLaunchCallback;this.customLaunchCallback=void 0,e()}}launch=async e=>{if(!e&&this.params.optionsModal.customNostrConnect)return this.launchCustomNostrConnect();const t=localStorageGetRecents(),n=localStorageGetAccounts(),r={...this.params.optionsModal};e&&"default"!==e?r.startScreen=e:(Boolean(t?.length)||Boolean(n?.length))&&(r.startScreen="switch-account"),this.customLaunchCallback&&this.authNostrService.cancelNostrConnect();try{await this.modalManager.launch(r),this.fulfillCustomLaunchPromise()}catch(e){console.log("nostr-login failed",e)}};init=async e=>{this.extensionService.startCheckingExtension(this.nostr),window.nostr=this.nostr,this.modalManager.connectModals(e),this.bannerManager.launchAuthBanner(e),e&&(this.params.optionsModal={...e});try{const e=localStorageGetCurrent();if(e){if(!e.pubkey)throw new Error("Bad stored info");await this.switchAccount(e)}}catch(e){console.log("nostr login init error",e),await logout()}this.updateAccounts()};logout=async()=>{this.extensionService.unsetExtension(this.nostr),await this.authNostrService.logout()};setDarkMode=e=>{localStorageSetItem("nl-dark-mode",`${e}`),this.bannerManager.onDarkMode(e),this.modalManager.onDarkMode(e)};setAuth=async e=>{if(!e.type)throw new Error("Invalid auth event");if("login"!==e.type&&"logout"!==e.type&&"signup"!==e.type)throw new Error("Invalid auth event");if(e.method&&"connect"!==e.method&&"extension"!==e.method&&"local"!==e.method&&"otp"!==e.method&&"readOnly"!==e.method)throw new Error("Invalid auth event");if("logout"===e.type)return this.logout();if(!e.method||!e.pubkey)throw new Error("Invalid pubkey");const t={authMethod:e.method,pubkey:e.pubkey,relays:e.relays,sk:e.localNsec,otpData:e.otpData,name:e.name};await this.switchAccount(t,"signup"===e.type)};cancelNeedAuth=()=>{console.log("cancelNeedAuth"),this.fulfillCustomLaunchPromise(),this.authNostrService.cancelNostrConnect()}}const initializer=new NostrLoginInitializer,{init:init,launch:launch,logout:logout,setDarkMode:setDarkMode,setAuth:setAuth,cancelNeedAuth:cancelNeedAuth}=initializer;document.addEventListener("nlLogout",logout),document.addEventListener("nlLaunch",e=>{launch(e.detail||"")}),document.addEventListener("nlNeedAuthCancel",()=>{cancelNeedAuth()}),document.addEventListener("nlDarkMode",e=>{setDarkMode(!!e.detail)}),document.addEventListener("nlSetAuth",e=>{setAuth(e.detail)}),(()=>{const e=document.currentScript,t=async()=>{const t={};if(e){const n=e.getAttribute("data-dark-mode");n&&(t.darkMode="true"===n);const r=e.getAttribute("data-bunkers");r&&(t.bunkers=r);const i=e.getAttribute("data-start-screen");i&&(t.startScreen=i);const s=e.getAttribute("data-perms");s&&(t.perms=s);const o=e.getAttribute("data-theme");o&&(t.theme=o);const a=e.getAttribute("data-no-banner");a&&(t.noBanner="true"===a);const c=e.getAttribute("data-local-signup");c&&(t.localSignup="true"===c);const l=e.getAttribute("data-signup-nstart")||e.getAttribute("data-signup-njump");l&&(t.signupNstart="true"===l);const h=e.getAttribute("data-follow-npubs");h&&(t.followNpubs=h);const d=e.getAttribute("data-otp-request-url");d&&(t.otpRequestUrl=d);const u=e.getAttribute("data-otp-reply-url");u&&(t.otpReplyUrl=u),!!d!=!!u&&console.warn("nostr-login: need request and reply urls for OTP auth");const p=e.getAttribute("data-methods");p&&(t.methods=p.trim().split(",").filter(e=>!!e));const f=e.getAttribute("data-title");f&&(t.title=f);const g=e.getAttribute("data-description");g&&(t.description=g);const y=e.getAttribute("data-signup-relays");y&&(t.signupRelays=y);const m=e.getAttribute("data-outbox-relays");m&&(t.outboxRelays=m.split(","));const b="true"===e.getAttribute("data-dev");b&&(t.dev=b);const w="true"===e.getAttribute("data-custom-nostr-connect");w&&(t.customNostrConnect=w),console.log("nostr-login options",t)}init(t)};"loading"===document.readyState?document.addEventListener("DOMContentLoaded",t):t()})()})();
|
|
46
|
+
/*! noble-ciphers - MIT License (c) 2023 Paul Miller (paulmillr.com) */const u8a=e=>e instanceof Uint8Array,u32=e=>new Uint32Array(e.buffer,e.byteOffset,Math.floor(e.byteLength/4)),isLE=68===new Uint8Array(new Uint32Array([287454020]).buffer)[0];if(!isLE)throw new Error("Non little-endian hardware is not supported");function utf8ToBytes(e){if("string"!=typeof e)throw new Error("utf8ToBytes expected string, got "+typeof e);return new Uint8Array((new TextEncoder).encode(e))}function toBytes(e){if("string"==typeof e&&(e=utf8ToBytes(e)),!u8a(e))throw new Error("expected Uint8Array, got "+typeof e);return e}const isPlainObject=e=>"[object Object]"===Object.prototype.toString.call(e)&&e.constructor===Object;function checkOpts(e,t){if(void 0!==t&&("object"!=typeof t||!isPlainObject(t)))throw new Error("options must be object or undefined");return Object.assign(e,t)}function ensureBytes(e,t){if(!(e instanceof Uint8Array))throw new Error("Uint8Array expected");if(e.length!==t)throw new Error(`Uint8Array length ${t} expected`)}function equalBytes(e,t){if(e.length!==t.length)throw new Error("equalBytes: Different size of Uint8Arrays");let n=!0;for(let r=0;r<e.length;r++)n&&(n=e[r]===t[r]);return n}function number(e){if(!Number.isSafeInteger(e)||e<0)throw new Error(`Wrong positive integer: ${e}`)}function bool(e){if("boolean"!=typeof e)throw new Error(`Expected boolean, not ${e}`)}function bytes(e,...t){if(!(e instanceof Uint8Array))throw new Error("Expected Uint8Array");if(t.length>0&&!t.includes(e.length))throw new Error(`Expected Uint8Array of length ${t}, not of length=${e.length}`)}function hash(e){if("function"!=typeof e||"function"!=typeof e.create)throw new Error("hash must be wrapped by utils.wrapConstructor");number(e.outputLen),number(e.blockLen)}function exists(e,t=!0){if(e.destroyed)throw new Error("Hash instance has been destroyed");if(t&&e.finished)throw new Error("Hash#digest() has already been called")}function output(e,t){bytes(e);const n=t.outputLen;if(e.length<n)throw new Error(`digestInto() expects output buffer of length at least ${n}`)}const assert={number:number,bool:bool,bytes:bytes,hash:hash,exists:exists,output:output},u8to16=(e,t)=>255&e[t++]|(255&e[t++])<<8;class Poly1305{constructor(e){this.blockLen=16,this.outputLen=16,this.buffer=new Uint8Array(16),this.r=new Uint16Array(10),this.h=new Uint16Array(10),this.pad=new Uint16Array(8),this.pos=0,this.finished=!1,ensureBytes(e=toBytes(e),32);const t=u8to16(e,0),n=u8to16(e,2),r=u8to16(e,4),i=u8to16(e,6),s=u8to16(e,8),o=u8to16(e,10),a=u8to16(e,12),c=u8to16(e,14);this.r[0]=8191&t,this.r[1]=8191&(t>>>13|n<<3),this.r[2]=7939&(n>>>10|r<<6),this.r[3]=8191&(r>>>7|i<<9),this.r[4]=255&(i>>>4|s<<12),this.r[5]=s>>>1&8190,this.r[6]=8191&(s>>>14|o<<2),this.r[7]=8065&(o>>>11|a<<5),this.r[8]=8191&(a>>>8|c<<8),this.r[9]=c>>>5&127;for(let t=0;t<8;t++)this.pad[t]=u8to16(e,16+2*t)}process(e,t,n=!1){const r=n?0:2048,{h:i,r:s}=this,o=s[0],a=s[1],c=s[2],l=s[3],h=s[4],d=s[5],u=s[6],p=s[7],f=s[8],g=s[9],y=u8to16(e,t+0),m=u8to16(e,t+2),b=u8to16(e,t+4),w=u8to16(e,t+6),v=u8to16(e,t+8),$=u8to16(e,t+10),E=u8to16(e,t+12),k=u8to16(e,t+14);let x=i[0]+(8191&y),_=i[1]+(8191&(y>>>13|m<<3)),S=i[2]+(8191&(m>>>10|b<<6)),C=i[3]+(8191&(b>>>7|w<<9)),A=i[4]+(8191&(w>>>4|v<<12)),N=i[5]+(v>>>1&8191),R=i[6]+(8191&(v>>>14|$<<2)),T=i[7]+(8191&($>>>11|E<<5)),B=i[8]+(8191&(E>>>8|k<<8)),L=i[9]+(k>>>5|r),I=0,U=I+x*o+_*(5*g)+S*(5*f)+C*(5*p)+A*(5*u);I=U>>>13,U&=8191,U+=N*(5*d)+R*(5*h)+T*(5*l)+B*(5*c)+L*(5*a),I+=U>>>13,U&=8191;let O=I+x*a+_*o+S*(5*g)+C*(5*f)+A*(5*p);I=O>>>13,O&=8191,O+=N*(5*u)+R*(5*d)+T*(5*h)+B*(5*l)+L*(5*c),I+=O>>>13,O&=8191;let P=I+x*c+_*a+S*o+C*(5*g)+A*(5*f);I=P>>>13,P&=8191,P+=N*(5*p)+R*(5*u)+T*(5*d)+B*(5*h)+L*(5*l),I+=P>>>13,P&=8191;let M=I+x*l+_*c+S*a+C*o+A*(5*g);I=M>>>13,M&=8191,M+=N*(5*f)+R*(5*p)+T*(5*u)+B*(5*d)+L*(5*h),I+=M>>>13,M&=8191;let D=I+x*h+_*l+S*c+C*a+A*o;I=D>>>13,D&=8191,D+=N*(5*g)+R*(5*f)+T*(5*p)+B*(5*u)+L*(5*d),I+=D>>>13,D&=8191;let H=I+x*d+_*h+S*l+C*c+A*a;I=H>>>13,H&=8191,H+=N*o+R*(5*g)+T*(5*f)+B*(5*p)+L*(5*u),I+=H>>>13,H&=8191;let F=I+x*u+_*d+S*h+C*l+A*c;I=F>>>13,F&=8191,F+=N*a+R*o+T*(5*g)+B*(5*f)+L*(5*p),I+=F>>>13,F&=8191;let K=I+x*p+_*u+S*d+C*h+A*l;I=K>>>13,K&=8191,K+=N*c+R*a+T*o+B*(5*g)+L*(5*f),I+=K>>>13,K&=8191;let V=I+x*f+_*p+S*u+C*d+A*h;I=V>>>13,V&=8191,V+=N*l+R*c+T*a+B*o+L*(5*g),I+=V>>>13,V&=8191;let j=I+x*g+_*f+S*p+C*u+A*d;I=j>>>13,j&=8191,j+=N*h+R*l+T*c+B*a+L*o,I+=j>>>13,j&=8191,I=(I<<2)+I|0,I=I+U|0,U=8191&I,I>>>=13,O+=I,i[0]=U,i[1]=O,i[2]=P,i[3]=M,i[4]=D,i[5]=H,i[6]=F,i[7]=K,i[8]=V,i[9]=j}finalize(){const{h:e,pad:t}=this,n=new Uint16Array(10);let r=e[1]>>>13;e[1]&=8191;for(let t=2;t<10;t++)e[t]+=r,r=e[t]>>>13,e[t]&=8191;e[0]+=5*r,r=e[0]>>>13,e[0]&=8191,e[1]+=r,r=e[1]>>>13,e[1]&=8191,e[2]+=r,n[0]=e[0]+5,r=n[0]>>>13,n[0]&=8191;for(let t=1;t<10;t++)n[t]=e[t]+r,r=n[t]>>>13,n[t]&=8191;n[9]-=8192;let i=(1^r)-1;for(let e=0;e<10;e++)n[e]&=i;i=~i;for(let t=0;t<10;t++)e[t]=e[t]&i|n[t];e[0]=65535&(e[0]|e[1]<<13),e[1]=65535&(e[1]>>>3|e[2]<<10),e[2]=65535&(e[2]>>>6|e[3]<<7),e[3]=65535&(e[3]>>>9|e[4]<<4),e[4]=65535&(e[4]>>>12|e[5]<<1|e[6]<<14),e[5]=65535&(e[6]>>>2|e[7]<<11),e[6]=65535&(e[7]>>>5|e[8]<<8),e[7]=65535&(e[8]>>>8|e[9]<<5);let s=e[0]+t[0];e[0]=65535&s;for(let n=1;n<8;n++)s=(e[n]+t[n]|0)+(s>>>16)|0,e[n]=65535&s}update(e){assert.exists(this);const{buffer:t,blockLen:n}=this,r=(e=toBytes(e)).length;for(let i=0;i<r;){const s=Math.min(n-this.pos,r-i);if(s!==n)t.set(e.subarray(i,i+s),this.pos),this.pos+=s,i+=s,this.pos===n&&(this.process(t,0,!1),this.pos=0);else for(;n<=r-i;i+=n)this.process(e,i)}return this}destroy(){this.h.fill(0),this.r.fill(0),this.buffer.fill(0),this.pad.fill(0)}digestInto(e){assert.exists(this),assert.output(e,this),this.finished=!0;const{buffer:t,h:n}=this;let{pos:r}=this;if(r){for(t[r++]=1;r<16;r++)t[r]=0;this.process(t,0,!0)}this.finalize();let i=0;for(let t=0;t<8;t++)e[i++]=n[t]>>>0,e[i++]=n[t]>>>8;return e}digest(){const{buffer:e,outputLen:t}=this;this.digestInto(e);const n=e.slice(0,t);return this.destroy(),n}}function wrapConstructorWithKey(e){const t=(t,n)=>e(n).update(toBytes(t)).digest(),n=e(new Uint8Array(32));return t.outputLen=n.outputLen,t.blockLen=n.blockLen,t.create=t=>e(t),t}wrapConstructorWithKey(e=>new Poly1305(e));const sigma16=utf8ToBytes("expand 16-byte k"),sigma32=utf8ToBytes("expand 32-byte k"),sigma16_32=u32(sigma16),sigma32_32=u32(sigma32),isAligned32=e=>!(e.byteOffset%4),salsaBasic=e=>{const{core:t,rounds:n,counterRight:r,counterLen:i,allow128bitKeys:s,extendNonceFn:o,blockLen:a}=checkOpts({rounds:20,counterRight:!1,counterLen:8,allow128bitKeys:!0,blockLen:64},e);assert.number(i),assert.number(n),assert.number(a),assert.bool(r),assert.bool(s);const c=a/4;if(a%4!=0)throw new Error("Salsa/ChaCha: blockLen must be aligned to 4 bytes");return(e,l,h,d,u=0)=>{if(assert.bytes(e),assert.bytes(l),assert.bytes(h),d||(d=new Uint8Array(h.length)),assert.bytes(d),assert.number(u),u<0||u>=2**32-1)throw new Error("Salsa/ChaCha: counter overflow");if(d.length<h.length)throw new Error(`Salsa/ChaCha: output (${d.length}) is shorter than data (${h.length})`);const p=[];let f,g;if(32===e.length)f=e,g=sigma32_32;else{if(16!==e.length||!s)throw new Error(`Salsa/ChaCha: invalid 32-byte key, got length=${e.length}`);f=new Uint8Array(32),f.set(e),f.set(e,16),g=sigma16_32,p.push(f)}if(o){if(l.length<=16)throw new Error("Salsa/ChaCha: extended nonce must be bigger than 16 bytes");f=o(g,f,l.subarray(0,16),new Uint8Array(32)),p.push(f),l=l.subarray(16)}const y=16-i;if(l.length!==y)throw new Error(`Salsa/ChaCha: nonce must be ${y} or 16 bytes`);if(12!==y){const e=new Uint8Array(12);e.set(l,r?0:12-l.length),p.push(l=e)}const m=new Uint8Array(a),b=u32(m),w=u32(f),v=u32(l),$=isAligned32(h)&&u32(h),E=isAligned32(d)&&u32(d);p.push(b);const k=h.length;for(let e=0,r=u;e<k;r++){if(t(g,w,v,b,r,n),r>=2**32-1)throw new Error("Salsa/ChaCha: counter overflow");const i=Math.min(a,k-e);if(i===a&&E&&$){const t=e/4;if(e%4!=0)throw new Error("Salsa/ChaCha: invalid block position");for(let e=0;e<c;e++)E[t+e]=$[t+e]^b[e];e+=a;continue}for(let t=0;t<i;t++)d[e+t]=h[e+t]^m[t];e+=i}for(let e=0;e<p.length;e++)p[e].fill(0);return d}},rotl=(e,t)=>e<<t|e>>>32-t;function chachaCore(e,t,n,r,i,s=20){let o=e[0],a=e[1],c=e[2],l=e[3],h=t[0],d=t[1],u=t[2],p=t[3],f=t[4],g=t[5],y=t[6],m=t[7],b=i,w=n[0],v=n[1],$=n[2],E=o,k=a,x=c,_=l,S=h,C=d,A=u,N=p,R=f,T=g,B=y,L=m,I=b,U=w,O=v,P=$;for(let e=0;e<s;e+=2)E=E+S|0,I=rotl(I^E,16),R=R+I|0,S=rotl(S^R,12),E=E+S|0,I=rotl(I^E,8),R=R+I|0,S=rotl(S^R,7),k=k+C|0,U=rotl(U^k,16),T=T+U|0,C=rotl(C^T,12),k=k+C|0,U=rotl(U^k,8),T=T+U|0,C=rotl(C^T,7),x=x+A|0,O=rotl(O^x,16),B=B+O|0,A=rotl(A^B,12),x=x+A|0,O=rotl(O^x,8),B=B+O|0,A=rotl(A^B,7),_=_+N|0,P=rotl(P^_,16),L=L+P|0,N=rotl(N^L,12),_=_+N|0,P=rotl(P^_,8),L=L+P|0,N=rotl(N^L,7),E=E+C|0,P=rotl(P^E,16),B=B+P|0,C=rotl(C^B,12),E=E+C|0,P=rotl(P^E,8),B=B+P|0,C=rotl(C^B,7),k=k+A|0,I=rotl(I^k,16),L=L+I|0,A=rotl(A^L,12),k=k+A|0,I=rotl(I^k,8),L=L+I|0,A=rotl(A^L,7),x=x+N|0,U=rotl(U^x,16),R=R+U|0,N=rotl(N^R,12),x=x+N|0,U=rotl(U^x,8),R=R+U|0,N=rotl(N^R,7),_=_+S|0,O=rotl(O^_,16),T=T+O|0,S=rotl(S^T,12),_=_+S|0,O=rotl(O^_,8),T=T+O|0,S=rotl(S^T,7);let M=0;r[M++]=o+E|0,r[M++]=a+k|0,r[M++]=c+x|0,r[M++]=l+_|0,r[M++]=h+S|0,r[M++]=d+C|0,r[M++]=u+A|0,r[M++]=p+N|0,r[M++]=f+R|0,r[M++]=g+T|0,r[M++]=y+B|0,r[M++]=m+L|0,r[M++]=b+I|0,r[M++]=w+U|0,r[M++]=v+O|0,r[M++]=$+P|0}const chacha20=salsaBasic({core:chachaCore,counterRight:!1,counterLen:4,allow128bitKeys:!1});function extract(e,t,n){return assert$3.hash(e),void 0===n&&(n=new Uint8Array(e.outputLen)),hmac$3(e,toBytes$4(n),toBytes$4(t))}const HKDF_COUNTER=new Uint8Array([0]),EMPTY_BUFFER=new Uint8Array;function expand(e,t,n,r=32){if(assert$3.hash(e),assert$3.number(r),r>255*e.outputLen)throw new Error("Length should be <= 255*HashLen");const i=Math.ceil(r/e.outputLen);void 0===n&&(n=EMPTY_BUFFER);const s=new Uint8Array(i*e.outputLen),o=hmac$3.create(e,t),a=o._cloneInto(),c=new Uint8Array(o.outputLen);for(let t=0;t<i;t++)HKDF_COUNTER[0]=t+1,a.update(0===t?EMPTY_BUFFER:c).update(n).update(HKDF_COUNTER).digestInto(c),s.set(c,e.outputLen*t),o._cloneInto(a);return o.destroy(),a.destroy(),c.fill(0),HKDF_COUNTER.fill(0),s.slice(0,r)}const hkdf=(e,t,n,r,i)=>expand(e,extract(e,t,n),r,i);var __defProp=Object.defineProperty,__export=(e,t)=>{for(var n in t)__defProp(e,n,{get:t[n],enumerable:!0})};function generatePrivateKey(){return bytesToHex$3(schnorr.utils.randomPrivateKey())}function getPublicKey(e){return bytesToHex$3(schnorr.getPublicKey(e))}var utils_exports={};__export(utils_exports,{MessageNode:()=>MessageNode,MessageQueue:()=>MessageQueue,insertEventIntoAscendingList:()=>insertEventIntoAscendingList,insertEventIntoDescendingList:()=>insertEventIntoDescendingList,normalizeURL:()=>normalizeURL,utf8Decoder:()=>utf8Decoder,utf8Encoder:()=>utf8Encoder});var utf8Decoder=new TextDecoder("utf-8"),utf8Encoder=new TextEncoder;function normalizeURL(e){let t=new URL(e);return t.pathname=t.pathname.replace(/\/+/g,"/"),t.pathname.endsWith("/")&&(t.pathname=t.pathname.slice(0,-1)),("80"===t.port&&"ws:"===t.protocol||"443"===t.port&&"wss:"===t.protocol)&&(t.port=""),t.searchParams.sort(),t.hash="",t.toString()}function insertEventIntoDescendingList(e,t){let n,r=0,i=e.length-1,s=r;if(i<0)s=0;else if(t.created_at<e[i].created_at)s=i+1;else if(t.created_at>=e[r].created_at)s=r;else for(;;){if(i<=r+1){s=i;break}if(n=Math.floor(r+(i-r)/2),e[n].created_at>t.created_at)r=n;else{if(!(e[n].created_at<t.created_at)){s=n;break}i=n}}return e[s]?.id!==t.id?[...e.slice(0,s),t,...e.slice(s)]:e}function insertEventIntoAscendingList(e,t){let n,r=0,i=e.length-1,s=r;if(i<0)s=0;else if(t.created_at>e[i].created_at)s=i+1;else if(t.created_at<=e[r].created_at)s=r;else for(;;){if(i<=r+1){s=i;break}if(n=Math.floor(r+(i-r)/2),e[n].created_at<t.created_at)r=n;else{if(!(e[n].created_at>t.created_at)){s=n;break}i=n}}return e[s]?.id!==t.id?[...e.slice(0,s),t,...e.slice(s)]:e}var MessageNode=class{_value;_next;get value(){return this._value}set value(e){this._value=e}get next(){return this._next}set next(e){this._next=e}constructor(e){this._value=e,this._next=null}},MessageQueue=class{_first;_last;get first(){return this._first}set first(e){this._first=e}get last(){return this._last}set last(e){this._last=e}_size;get size(){return this._size}set size(e){this._size=e}constructor(){this._first=null,this._last=null,this._size=0}enqueue(e){const t=new MessageNode(e);return 0!==this._size&&this._last?(this._last.next=t,this._last=t):(this._first=t,this._last=t),this._size++,!0}dequeue(){if(0===this._size||!this._first)return null;let e=this._first;return this._first=e.next,e.next=null,this._size--,e.value}},verifiedSymbol=Symbol("verified");function getBlankEvent(e=255){return{kind:e,content:"",tags:[],created_at:0}}function finishEvent(e,t){const n=e;return n.pubkey=getPublicKey(t),n.id=getEventHash(n),n.sig=getSignature(n,t),n[verifiedSymbol]=!0,n}function serializeEvent(e){if(!validateEvent(e))throw new Error("can't serialize event with wrong or missing properties");return JSON.stringify([0,e.pubkey,e.created_at,e.kind,e.tags,e.content])}function getEventHash(e){return bytesToHex$3(sha256$3(utf8Encoder.encode(serializeEvent(e))))}var isRecord=e=>e instanceof Object;function validateEvent(e){if(!isRecord(e))return!1;if("number"!=typeof e.kind)return!1;if("string"!=typeof e.content)return!1;if("number"!=typeof e.created_at)return!1;if("string"!=typeof e.pubkey)return!1;if(!e.pubkey.match(/^[a-f0-9]{64}$/))return!1;if(!Array.isArray(e.tags))return!1;for(let t=0;t<e.tags.length;t++){let n=e.tags[t];if(!Array.isArray(n))return!1;for(let e=0;e<n.length;e++)if("object"==typeof n[e])return!1}return!0}function verifySignature(e){if("boolean"==typeof e[verifiedSymbol])return e[verifiedSymbol];const t=getEventHash(e);if(t!==e.id)return e[verifiedSymbol]=!1;try{return e[verifiedSymbol]=schnorr.verify(e.sig,t,e.pubkey)}catch(t){return e[verifiedSymbol]=!1}}function getSignature(e,t){return bytesToHex$3(schnorr.sign(getEventHash(e),t))}var fakejson_exports={};function getHex64(e,t){let n=t.length+3,r=e.indexOf(`"${t}":`)+n,i=e.slice(r).indexOf('"')+r+1;return e.slice(i,i+64)}function getInt(e,t){let n=t.length,r=e.indexOf(`"${t}":`)+n+3,i=e.slice(r),s=Math.min(i.indexOf(","),i.indexOf("}"));return parseInt(i.slice(0,s),10)}function getSubscriptionId(e){let t=e.slice(0,22).indexOf('"EVENT"');if(-1===t)return null;let n=e.slice(t+7+1).indexOf('"');if(-1===n)return null;let r=t+7+1+n,i=e.slice(r+1,80).indexOf('"');if(-1===i)return null;let s=r+1+i;return e.slice(r+1,s)}function matchEventId(e,t){return t===getHex64(e,"id")}function matchEventPubkey(e,t){return t===getHex64(e,"pubkey")}function matchEventKind(e,t){return t===getInt(e,"kind")}__export(fakejson_exports,{getHex64:()=>getHex64,getInt:()=>getInt,getSubscriptionId:()=>getSubscriptionId,matchEventId:()=>matchEventId,matchEventKind:()=>matchEventKind,matchEventPubkey:()=>matchEventPubkey});var nip19_exports={};__export(nip19_exports,{BECH32_REGEX:()=>BECH32_REGEX,decode:()=>decode,naddrEncode:()=>naddrEncode,neventEncode:()=>neventEncode,noteEncode:()=>noteEncode,nprofileEncode:()=>nprofileEncode,npubEncode:()=>npubEncode,nrelayEncode:()=>nrelayEncode,nsecEncode:()=>nsecEncode});var Bech32MaxSize=5e3,BECH32_REGEX=/[\x21-\x7E]{1,83}1[023456789acdefghjklmnpqrstuvwxyz]{6,}/;function integerToUint8Array(e){const t=new Uint8Array(4);return t[0]=e>>24&255,t[1]=e>>16&255,t[2]=e>>8&255,t[3]=255&e,t}function decode(e){let{prefix:t,words:n}=bech32.decode(e,Bech32MaxSize),r=new Uint8Array(bech32.fromWords(n));switch(t){case"nprofile":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for nprofile");if(32!==e[0][0].length)throw new Error("TLV 0 should be 32 bytes");return{type:"nprofile",data:{pubkey:bytesToHex$3(e[0][0]),relays:e[1]?e[1].map(e=>utf8Decoder.decode(e)):[]}}}case"nevent":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for nevent");if(32!==e[0][0].length)throw new Error("TLV 0 should be 32 bytes");if(e[2]&&32!==e[2][0].length)throw new Error("TLV 2 should be 32 bytes");if(e[3]&&4!==e[3][0].length)throw new Error("TLV 3 should be 4 bytes");return{type:"nevent",data:{id:bytesToHex$3(e[0][0]),relays:e[1]?e[1].map(e=>utf8Decoder.decode(e)):[],author:e[2]?.[0]?bytesToHex$3(e[2][0]):void 0,kind:e[3]?.[0]?parseInt(bytesToHex$3(e[3][0]),16):void 0}}}case"naddr":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for naddr");if(!e[2]?.[0])throw new Error("missing TLV 2 for naddr");if(32!==e[2][0].length)throw new Error("TLV 2 should be 32 bytes");if(!e[3]?.[0])throw new Error("missing TLV 3 for naddr");if(4!==e[3][0].length)throw new Error("TLV 3 should be 4 bytes");return{type:"naddr",data:{identifier:utf8Decoder.decode(e[0][0]),pubkey:bytesToHex$3(e[2][0]),kind:parseInt(bytesToHex$3(e[3][0]),16),relays:e[1]?e[1].map(e=>utf8Decoder.decode(e)):[]}}}case"nrelay":{let e=parseTLV(r);if(!e[0]?.[0])throw new Error("missing TLV 0 for nrelay");return{type:"nrelay",data:utf8Decoder.decode(e[0][0])}}case"nsec":case"npub":case"note":return{type:t,data:bytesToHex$3(r)};default:throw new Error(`unknown prefix ${t}`)}}function parseTLV(e){let t={},n=e;for(;n.length>0;){let e=n[0],r=n[1];if(!r)throw new Error(`malformed TLV ${e}`);let i=n.slice(2,2+r);if(n=n.slice(2+r),i.length<r)throw new Error(`not enough data to read on TLV ${e}`);t[e]=t[e]||[],t[e].push(i)}return t}function nsecEncode(e){return encodeBytes("nsec",e)}function npubEncode(e){return encodeBytes("npub",e)}function noteEncode(e){return encodeBytes("note",e)}function encodeBech32(e,t){let n=bech32.toWords(t);return bech32.encode(e,n,Bech32MaxSize)}function encodeBytes(e,t){return encodeBech32(e,hexToBytes$3(t))}function nprofileEncode(e){return encodeBech32("nprofile",encodeTLV({0:[hexToBytes$3(e.pubkey)],1:(e.relays||[]).map(e=>utf8Encoder.encode(e))}))}function neventEncode(e){let t;return null!=e.kind&&(t=integerToUint8Array(e.kind)),encodeBech32("nevent",encodeTLV({0:[hexToBytes$3(e.id)],1:(e.relays||[]).map(e=>utf8Encoder.encode(e)),2:e.author?[hexToBytes$3(e.author)]:[],3:t?[new Uint8Array(t)]:[]}))}function naddrEncode(e){let t=new ArrayBuffer(4);return new DataView(t).setUint32(0,e.kind,!1),encodeBech32("naddr",encodeTLV({0:[utf8Encoder.encode(e.identifier)],1:(e.relays||[]).map(e=>utf8Encoder.encode(e)),2:[hexToBytes$3(e.pubkey)],3:[new Uint8Array(t)]}))}function nrelayEncode(e){return encodeBech32("nrelay",encodeTLV({0:[utf8Encoder.encode(e)]}))}function encodeTLV(e){let t=[];return Object.entries(e).forEach(([e,n])=>{n.forEach(n=>{let r=new Uint8Array(n.length+2);r.set([parseInt(e)],0),r.set([n.length],1),r.set(n,2),t.push(r)})}),concatBytes$4(...t)}var nip04_exports={};async function encrypt(e,t,n){const r=getNormalizedX(secp256k1$1.getSharedSecret(e,"02"+t));let i=Uint8Array.from(randomBytes$2(16)),s=utf8Encoder.encode(n),o=await crypto.subtle.importKey("raw",r,{name:"AES-CBC"},!1,["encrypt"]),a=await crypto.subtle.encrypt({name:"AES-CBC",iv:i},o,s);return`${base64.encode(new Uint8Array(a))}?iv=${base64.encode(new Uint8Array(i.buffer))}`}async function decrypt(e,t,n){let[r,i]=n.split("?iv="),s=getNormalizedX(secp256k1$1.getSharedSecret(e,"02"+t)),o=await crypto.subtle.importKey("raw",s,{name:"AES-CBC"},!1,["decrypt"]),a=base64.decode(r),c=base64.decode(i),l=await crypto.subtle.decrypt({name:"AES-CBC",iv:c},o,a);return utf8Decoder.decode(l)}function getNormalizedX(e){return e.slice(1,33)}__export(nip04_exports,{decrypt:()=>decrypt,encrypt:()=>encrypt}),"undefined"!=typeof crypto&&!crypto.subtle&&crypto.webcrypto&&(crypto.subtle=crypto.webcrypto.subtle);var nip05_exports={};__export(nip05_exports,{NIP05_REGEX:()=>NIP05_REGEX,queryProfile:()=>queryProfile,searchDomain:()=>searchDomain,useFetchImplementation:()=>useFetchImplementation});var NIP05_REGEX=/^(?:([\w.+-]+)@)?([\w.-]+)$/,_fetch;try{_fetch=fetch}catch{}function useFetchImplementation(e){_fetch=e}async function searchDomain(e,t=""){try{return(await(await _fetch(`https://${e}/.well-known/nostr.json?name=${t}`)).json()).names}catch(e){return{}}}async function queryProfile(e){const t=e.match(NIP05_REGEX);if(!t)return null;const[n,r="_",i]=t;try{const e=await _fetch(`https://${i}/.well-known/nostr.json?name=${r}`),{names:t,relays:n}=parseNIP05Result(await e.json()),s=t[r];return s?{pubkey:s,relays:n?.[s]}:null}catch(e){return null}}function parseNIP05Result(e){const t={names:{}};for(const[n,r]of Object.entries(e.names))"string"==typeof n&&"string"==typeof r&&(t.names[n]=r);if(e.relays){t.relays={};for(const[n,r]of Object.entries(e.relays))"string"==typeof n&&Array.isArray(r)&&(t.relays[n]=r.filter(e=>"string"==typeof e))}return t}var nip06_exports={};function privateKeyFromSeedWords(e,t){let n=HDKey.fromMasterSeed(mnemonicToSeedSync(e,t)).derive("m/44'/1237'/0'/0/0").privateKey;if(!n)throw new Error("could not derive private key");return bytesToHex$3(n)}function generateSeedWords(){return generateMnemonic(wordlist)}function validateWords(e){return validateMnemonic(e,wordlist)}__export(nip06_exports,{generateSeedWords:()=>generateSeedWords,privateKeyFromSeedWords:()=>privateKeyFromSeedWords,validateWords:()=>validateWords});var nip10_exports={};function parse(e){const t={reply:void 0,root:void 0,mentions:[],profiles:[]},n=[];for(const r of e.tags)"e"===r[0]&&r[1]&&n.push(r),"p"===r[0]&&r[1]&&t.profiles.push({pubkey:r[1],relays:r[2]?[r[2]]:[]});for(let e=0;e<n.length;e++){const r=n[e],[i,s,o,a]=r,c={id:s,relays:o?[o]:[]},l=0===e,h=e===n.length-1;"root"!==a?"reply"!==a?"mention"!==a?l?t.root=c:h?t.reply=c:t.mentions.push(c):t.mentions.push(c):t.reply=c:t.root=c}return t}__export(nip10_exports,{parse:()=>parse});var nip13_exports={};function getPow(e){let t=0;for(let n=0;n<e.length;n++){const r=parseInt(e[n],16);if(0!==r){t+=Math.clz32(r)-28;break}t+=4}return t}function minePow(e,t){let n=0;const r=e,i=["nonce",n.toString(),t.toString()];for(r.tags.push(i);;){const e=Math.floor((new Date).getTime()/1e3);if(e!==r.created_at&&(n=0,r.created_at=e),i[1]=(++n).toString(),r.id=getEventHash(r),getPow(r.id)>=t)break}return r}__export(nip13_exports,{getPow:()=>getPow,minePow:()=>minePow});var nip18_exports={};function finishRepostEvent(e,t,n,r){return finishEvent({kind:6,tags:[...e.tags??[],["e",t.id,n],["p",t.pubkey]],content:""===e.content?"":JSON.stringify(t),created_at:e.created_at},r)}function getRepostedEventPointer(e){if(6!==e.kind)return;let t,n;for(let r=e.tags.length-1;r>=0&&(void 0===t||void 0===n);r--){const i=e.tags[r];i.length>=2&&("e"===i[0]&&void 0===t?t=i:"p"===i[0]&&void 0===n&&(n=i))}return void 0!==t?{id:t[1],relays:[t[2],n?.[2]].filter(e=>"string"==typeof e),author:n?.[1]}:void 0}function getRepostedEvent(e,{skipVerification:t}={}){const n=getRepostedEventPointer(e);if(void 0===n||""===e.content)return;let r;try{r=JSON.parse(e.content)}catch(e){return}return r.id===n.id&&(t||verifySignature(r))?r:void 0}__export(nip18_exports,{finishRepostEvent:()=>finishRepostEvent,getRepostedEvent:()=>getRepostedEvent,getRepostedEventPointer:()=>getRepostedEventPointer});var nip21_exports={};__export(nip21_exports,{NOSTR_URI_REGEX:()=>NOSTR_URI_REGEX,parse:()=>parse2,test:()=>test});var NOSTR_URI_REGEX=new RegExp(`nostr:(${BECH32_REGEX.source})`);function test(e){return"string"==typeof e&&new RegExp(`^${NOSTR_URI_REGEX.source}$`).test(e)}function parse2(e){const t=e.match(new RegExp(`^${NOSTR_URI_REGEX.source}$`));if(!t)throw new Error(`Invalid Nostr URI: ${e}`);return{uri:t[0],value:t[1],decoded:decode(t[1])}}var nip25_exports={};function finishReactionEvent(e,t,n){const r=t.tags.filter(e=>e.length>=2&&("e"===e[0]||"p"===e[0]));return finishEvent({...e,kind:7,tags:[...e.tags??[],...r,["e",t.id],["p",t.pubkey]],content:e.content??"+"},n)}function getReactedEventPointer(e){if(7!==e.kind)return;let t,n;for(let r=e.tags.length-1;r>=0&&(void 0===t||void 0===n);r--){const i=e.tags[r];i.length>=2&&("e"===i[0]&&void 0===t?t=i:"p"===i[0]&&void 0===n&&(n=i))}return void 0!==t&&void 0!==n?{id:t[1],relays:[t[2],n[2]].filter(e=>void 0!==e),author:n[1]}:void 0}__export(nip25_exports,{finishReactionEvent:()=>finishReactionEvent,getReactedEventPointer:()=>getReactedEventPointer});var nip26_exports={};function createDelegation(e,t){let n=[];(t.kind||-1)>=0&&n.push(`kind=${t.kind}`),t.until&&n.push(`created_at<${t.until}`),t.since&&n.push(`created_at>${t.since}`);let r=n.join("&");if(""===r)throw new Error("refusing to create a delegation without any conditions");let i=sha256$3(utf8Encoder.encode(`nostr:delegation:${t.pubkey}:${r}`)),s=bytesToHex$3(schnorr.sign(i,e));return{from:getPublicKey(e),to:t.pubkey,cond:r,sig:s}}function getDelegator(e){let t=e.tags.find(e=>"delegation"===e[0]&&e.length>=4);if(!t)return null;let n=t[1],r=t[2],i=t[3],s=r.split("&");for(let t=0;t<s.length;t++){let[n,r,i]=s[t].split(/\b/);if(("kind"!==n||"="!==r||e.kind!==parseInt(i))&&!("created_at"===n&&"<"===r&&e.created_at<parseInt(i)||"created_at"===n&&">"===r&&e.created_at>parseInt(i)))return null}let o=sha256$3(utf8Encoder.encode(`nostr:delegation:${e.pubkey}:${r}`));return schnorr.verify(i,o,n)?n:null}__export(nip26_exports,{createDelegation:()=>createDelegation,getDelegator:()=>getDelegator});var nip27_exports={};__export(nip27_exports,{matchAll:()=>matchAll,regex:()=>regex,replaceAll:()=>replaceAll});var regex=()=>new RegExp(`\\b${NOSTR_URI_REGEX.source}\\b`,"g");function*matchAll(e){const t=e.matchAll(regex());for(const e of t)try{const[t,n]=e;yield{uri:t,value:n,decoded:decode(n),start:e.index,end:e.index+t.length}}catch(e){}}function replaceAll(e,t){return e.replaceAll(regex(),(e,n)=>t({uri:e,value:n,decoded:decode(n)}))}var nip28_exports={};__export(nip28_exports,{channelCreateEvent:()=>channelCreateEvent,channelHideMessageEvent:()=>channelHideMessageEvent,channelMessageEvent:()=>channelMessageEvent,channelMetadataEvent:()=>channelMetadataEvent,channelMuteUserEvent:()=>channelMuteUserEvent});var channelCreateEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:40,tags:[...e.tags??[]],content:n,created_at:e.created_at},t)},channelMetadataEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:41,tags:[["e",e.channel_create_event_id],...e.tags??[]],content:n,created_at:e.created_at},t)},channelMessageEvent=(e,t)=>{const n=[["e",e.channel_create_event_id,e.relay_url,"root"]];return e.reply_to_channel_message_event_id&&n.push(["e",e.reply_to_channel_message_event_id,e.relay_url,"reply"]),finishEvent({kind:42,tags:[...n,...e.tags??[]],content:e.content,created_at:e.created_at},t)},channelHideMessageEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:43,tags:[["e",e.channel_message_event_id],...e.tags??[]],content:n,created_at:e.created_at},t)},channelMuteUserEvent=(e,t)=>{let n;if("object"==typeof e.content)n=JSON.stringify(e.content);else{if("string"!=typeof e.content)return;n=e.content}return finishEvent({kind:44,tags:[["p",e.pubkey_to_mute],...e.tags??[]],content:n,created_at:e.created_at},t)},nip39_exports={},_fetch2;__export(nip39_exports,{useFetchImplementation:()=>useFetchImplementation2,validateGithub:()=>validateGithub});try{_fetch2=fetch}catch{}function useFetchImplementation2(e){_fetch2=e}async function validateGithub(e,t,n){try{return await(await _fetch2(`https://gist.github.com/${t}/${n}/raw`)).text()===`Verifying that I control the following Nostr public key: ${e}`}catch(e){return!1}}var nip42_exports={};__export(nip42_exports,{authenticate:()=>authenticate});var authenticate=async({challenge:e,relay:t,sign:n})=>{const r={kind:22242,created_at:Math.floor(Date.now()/1e3),tags:[["relay",t.url],["challenge",e]],content:""};return t.auth(await n(r))},nip44_exports={};__export(nip44_exports,{decrypt:()=>decrypt2,encrypt:()=>encrypt2,utils:()=>utils});var utils={v2:{maxPlaintextSize:65408,minCiphertextSize:100,maxCiphertextSize:102400,getConversationKey:(e,t)=>secp256k1$1.getSharedSecret(e,"02"+t).subarray(1,33),getMessageKeys(e,t){const n=hkdf(sha256$3,e,t,"nip44-v2",76);return{encryption:n.subarray(0,32),nonce:n.subarray(32,44),auth:n.subarray(44,76)}},calcPadding(e){if(!Number.isSafeInteger(e)||e<0)throw new Error("expected positive integer");if(e<=32)return 32;const t=1<<Math.floor(Math.log2(e-1))+1,n=t<=256?32:t/8;return n*(Math.floor((e-1)/n)+1)},pad(e){const t=utf8Encoder.encode(e),n=t.length;if(n<1||n>=utils.v2.maxPlaintextSize)throw new Error("invalid plaintext length: must be between 1b and 64KB");const r=utils.v2.calcPadding(n),i=new Uint8Array(r-n),s=new Uint8Array(2);return new DataView(s.buffer).setUint16(0,n),concatBytes$4(s,t,i)},unpad(e){const t=new DataView(e.buffer).getUint16(0),n=e.subarray(2,2+t);if(0===t||n.length!==t||e.length!==2+utils.v2.calcPadding(t))throw new Error("invalid padding");return utf8Decoder.decode(n)}}};function encrypt2(e,t,n={}){const r=n.version??2;if(2!==r)throw new Error("unknown encryption version "+r);const i=n.salt??randomBytes$2(32);ensureBytes(i,32);const s=utils.v2.getMessageKeys(e,i),o=utils.v2.pad(t),a=chacha20(s.encryption,s.nonce,o),c=hmac$3(sha256$3,s.auth,a);return base64.encode(concatBytes$4(new Uint8Array([r]),i,a,c))}function decrypt2(e,t){const n=utils.v2;ensureBytes(e,32);const r=t.length;if(r<n.minCiphertextSize||r>=n.maxCiphertextSize)throw new Error("invalid ciphertext length: "+r);if("#"===t[0])throw new Error("unknown encryption version");let i;try{i=base64.decode(t)}catch(e){throw new Error("invalid base64: "+e.message)}const s=i.subarray(0,1)[0];if(2!==s)throw new Error("unknown encryption version "+s);const o=i.subarray(1,33),a=i.subarray(33,-32),c=i.subarray(-32),l=n.getMessageKeys(e,o);if(!equalBytes(hmac$3(sha256$3,l.auth,a),c))throw new Error("invalid MAC");const h=chacha20(l.encryption,l.nonce,a);return n.unpad(h)}var nip47_exports={};function parseConnectionString(e){const{pathname:t,searchParams:n}=new URL(e),r=t,i=n.get("relay"),s=n.get("secret");if(!r||!i||!s)throw new Error("invalid connection string");return{pubkey:r,relay:i,secret:s}}async function makeNwcRequestEvent({pubkey:e,secret:t,invoice:n}){const r={method:"pay_invoice",params:{invoice:n}},i=await encrypt(t,e,JSON.stringify(r));return finishEvent({kind:23194,created_at:Math.round(Date.now()/1e3),content:i,tags:[["p",e]]},t)}__export(nip47_exports,{makeNwcRequestEvent:()=>makeNwcRequestEvent,parseConnectionString:()=>parseConnectionString});var nip57_exports={},_fetch3;__export(nip57_exports,{getZapEndpoint:()=>getZapEndpoint,makeZapReceipt:()=>makeZapReceipt,makeZapRequest:()=>makeZapRequest,useFetchImplementation:()=>useFetchImplementation3,validateZapRequest:()=>validateZapRequest});try{_fetch3=fetch}catch{}function useFetchImplementation3(e){_fetch3=e}async function getZapEndpoint(e){try{let t="",{lud06:n,lud16:r}=JSON.parse(e.content);if(n){let{words:e}=bech32.decode(n,1e3),r=bech32.fromWords(e);t=utf8Decoder.decode(r)}else{if(!r)return null;{let[e,n]=r.split("@");t=`https://${n}/.well-known/lnurlp/${e}`}}let i=await _fetch3(t),s=await i.json();if(s.allowsNostr&&s.nostrPubkey)return s.callback}catch(e){}return null}function makeZapRequest({profile:e,event:t,amount:n,relays:r,comment:i=""}){if(!n)throw new Error("amount not given");if(!e)throw new Error("profile not given");let s={kind:9734,created_at:Math.round(Date.now()/1e3),content:i,tags:[["p",e],["amount",n.toString()],["relays",...r]]};return t&&s.tags.push(["e",t]),s}function validateZapRequest(e){let t;try{t=JSON.parse(e)}catch(e){return"Invalid zap request JSON."}if(!validateEvent(t))return"Zap request is not a valid Nostr event.";if(!verifySignature(t))return"Invalid signature on zap request.";let n=t.tags.find(([e,t])=>"p"===e&&t);if(!n)return"Zap request doesn't have a 'p' tag.";if(!n[1].match(/^[a-f0-9]{64}$/))return"Zap request 'p' tag is not valid hex.";let r=t.tags.find(([e,t])=>"e"===e&&t);return r&&!r[1].match(/^[a-f0-9]{64}$/)?"Zap request 'e' tag is not valid hex.":t.tags.find(([e,t])=>"relays"===e&&t)?null:"Zap request doesn't have a 'relays' tag."}function makeZapReceipt({zapRequest:e,preimage:t,bolt11:n,paidAt:r}){let i=JSON.parse(e).tags.filter(([e])=>"e"===e||"p"===e||"a"===e),s={kind:9735,created_at:Math.round(r.getTime()/1e3),content:"",tags:[...i,["bolt11",n],["description",e]]};return t&&s.tags.push(["preimage",t]),s}var nip98_exports={};__export(nip98_exports,{getToken:()=>getToken,unpackEventFromToken:()=>unpackEventFromToken,validateEvent:()=>validateEvent2,validateToken:()=>validateToken});var _authorizationScheme="Nostr ";async function getToken(e,t,n,r=!1){if(!e||!t)throw new Error("Missing loginUrl or httpMethod");const i=getBlankEvent(27235);i.tags=[["u",e],["method",t]],i.created_at=Math.round((new Date).getTime()/1e3);const s=await n(i);return(r?_authorizationScheme:"")+base64.encode(utf8Encoder.encode(JSON.stringify(s)))}async function validateToken(e,t,n){const r=await unpackEventFromToken(e).catch(e=>{throw e});return await validateEvent2(r,t,n).catch(e=>{throw e})}async function unpackEventFromToken(e){if(!e)throw new Error("Missing token");e=e.replace(_authorizationScheme,"");const t=utf8Decoder.decode(base64.decode(e));if(!t||0===t.length||!t.startsWith("{"))throw new Error("Invalid token");return JSON.parse(t)}async function validateEvent2(e,t,n){if(!e)throw new Error("Invalid nostr event");if(!verifySignature(e))throw new Error("Invalid nostr event, signature invalid");if(27235!==e.kind)throw new Error("Invalid nostr event, kind invalid");if(!e.created_at)throw new Error("Invalid nostr event, created_at invalid");if(Math.round((new Date).getTime()/1e3)-e.created_at>60)throw new Error("Invalid nostr event, expired");const r=e.tags.find(e=>"u"===e[0]);if(1!==r?.length&&r?.[1]!==t)throw new Error("Invalid nostr event, url tag invalid");const i=e.tags.find(e=>"method"===e[0]);if(1!==i?.length&&i?.[1].toLowerCase()!==n.toLowerCase())throw new Error("Invalid nostr event, method tag invalid");return!0}const LOCAL_STORE_KEY="__nostrlogin_nip46",LOGGED_IN_ACCOUNTS="__nostrlogin_accounts",RECENT_ACCOUNTS="__nostrlogin_recent",OUTBOX_RELAYS$1=["wss://purplepag.es","wss://relay.nos.social","wss://user.kindpag.es","wss://relay.damus.io","wss://nos.lol"],DEFAULT_SIGNUP_RELAYS=["wss://relay.damus.io/","wss://nos.lol/","wss://relay.primal.net/"],localStorageSetItem=(e,t)=>{localStorage.setItem(e,t)},localStorageGetItem=e=>{const t=window.localStorage.getItem(e);if(t)try{return JSON.parse(t)}catch{}return null},localStorageRemoveItem=e=>{localStorage.removeItem(e)},fetchProfile=async(e,t)=>{const n=new NDKUser({pubkey:e.pubkey});return n.ndk=t,await n.fetchProfile()},prepareSignupRelays=e=>{const t=(e||"").split(",").map(e=>e.trim()).filter(e=>e.startsWith("ws"));return t.length||t.push(...DEFAULT_SIGNUP_RELAYS),t},createProfile=async(e,t,n,r,i)=>{const s={name:e.name},o=new NDKEvent(t,{kind:0,created_at:Math.floor(Date.now()/1e3),pubkey:e.pubkey,content:JSON.stringify(s),tags:[]});window.location.hostname&&o.tags.push(["client",window.location.hostname]);const a=new NDKEvent(t,{kind:10002,created_at:Math.floor(Date.now()/1e3),pubkey:e.pubkey,content:"",tags:[]}),c=prepareSignupRelays(r);for(const e of c)a.tags.push(["r",e]);await o.sign(n),console.log("signed profile",o),await a.sign(n),console.log("signed relays",a);const l=i&&i.length?i:OUTBOX_RELAYS$1;await o.publish(NDKRelaySet.fromRelayUrls(l,t)),console.log("published profile",o),await a.publish(NDKRelaySet.fromRelayUrls(l,t)),console.log("published relays",a)},bunkerUrlToInfo=(e,t="")=>{const n=new URL(e);return{pubkey:"",signerPubkey:n.hostname||n.pathname.split("//")[1],sk:t||generatePrivateKey(),relays:n.searchParams.getAll("relay"),token:n.searchParams.get("secret")||"",authMethod:"connect"}},isBunkerUrl=e=>e.startsWith("bunker://"),getBunkerUrl=async(e,t)=>{if(!e)return"";if(isBunkerUrl(e))return e;if(e.includes("@")){const[n,r]=e.toLocaleLowerCase().split("@"),i=t.devOverrideBunkerOrigin||`https://${r}`,s=`${i}/.well-known/nostr.json?name=_`,o=`${i}/.well-known/nostr.json?name=${n}`,a=await fetch(s),c=await a.json(),l=c.names._,h=c.nip46[l],d=await fetch(o),u=(await d.json()).names[n];if(!h.length)throw new Error("Bunker relay not provided");return`bunker://${u}?relay=${h[0]}`}throw new Error("Invalid user name or bunker url")},checkNip05=async e=>{let t=!1,n="",r="";return await(async()=>{if(!e||!e.includes("@"))return;const[i,s]=e.toLocaleLowerCase().split("@");if(!i)return;if(!new RegExp(/^[\w-.]+@([\w-]+\.)+[\w-]{2,8}$/g).test(e))return void(n="Invalid name");if(!s)return void(n="Select service");const o=`https://${s}/.well-known/nostr.json?name=${i.toLowerCase()}`;try{const e=await fetch(o),t=await e.json();if(t.names[i])return void(r=t.names[i])}catch{}t=!0})(),{available:t,taken:""!=r,error:n,pubkey:r}},upgradeInfo=e=>{"typeAuthMethod"in e&&delete e.typeAuthMethod,e.authMethod||("extension"in e&&e.extension?e.authMethod="extension":"readOnly"in e&&e.readOnly?e.authMethod="readOnly":e.authMethod="connect"),e.nip05&&isBunkerUrl(e.nip05)&&(e.bunkerUrl=e.nip05,e.nip05=""),"connect"!==e.authMethod||e.signerPubkey||(e.signerPubkey=e.pubkey)},localStorageAddAccount=e=>{localStorageSetItem(LOCAL_STORE_KEY,JSON.stringify(e));const t=localStorageGetItem(LOGGED_IN_ACCOUNTS)||[],n=localStorageGetItem(RECENT_ACCOUNTS)||[];t.forEach(e=>upgradeInfo(e)),n.forEach(e=>upgradeInfo(e));const r=t,i=t.findIndex(t=>t.pubkey===e.pubkey&&t.authMethod===e.authMethod);-1!==i?r[i]=e:r.push(e);const s=n.filter(t=>t.pubkey!==e.pubkey||t.authMethod!==e.authMethod);localStorageSetItem(RECENT_ACCOUNTS,JSON.stringify(s)),localStorageSetItem(LOGGED_IN_ACCOUNTS,JSON.stringify(r))},localStorageRemoveCurrentAccount=()=>{const e=localStorageGetItem(LOCAL_STORE_KEY);if(!e)return;upgradeInfo(e);const t={...e};delete t.sk,delete t.otpData;const n=localStorageGetItem(LOGGED_IN_ACCOUNTS)||[],r=localStorageGetItem(RECENT_ACCOUNTS)||[];n.forEach(e=>upgradeInfo(e)),r.forEach(e=>upgradeInfo(e));const i=r;if("connect"===t.authMethod&&t.bunkerUrl&&t.bunkerUrl.includes("secret="))console.log("nostr login bunker conn with a secret not saved to recent");else if("local"===t.authMethod)console.log("nostr login temporary local keys not save to recent");else{const e=r.findIndex(e=>e.pubkey===t.pubkey&&e.authMethod===t.authMethod);-1!==e?i[e]=t:i.push(t)}const s=n.filter(t=>t.pubkey!==e.pubkey||t.authMethod!==e.authMethod);localStorageSetItem(RECENT_ACCOUNTS,JSON.stringify(i)),localStorageSetItem(LOGGED_IN_ACCOUNTS,JSON.stringify(s)),localStorageRemoveItem(LOCAL_STORE_KEY)},localStorageRemoveRecent=e=>{const t=localStorageGetItem(RECENT_ACCOUNTS)||[];t.forEach(e=>upgradeInfo(e));const n=t.filter(t=>t.pubkey!==e.pubkey||t.authMethod!==e.authMethod);localStorageSetItem(RECENT_ACCOUNTS,JSON.stringify(n))},localStorageGetRecents=()=>{const e=localStorageGetItem(RECENT_ACCOUNTS)||[];return e.forEach(e=>upgradeInfo(e)),e},localStorageGetAccounts=()=>{const e=localStorageGetItem(LOGGED_IN_ACCOUNTS)||[];return e.forEach(e=>upgradeInfo(e)),e},localStorageGetCurrent=()=>{const e=localStorageGetItem(LOCAL_STORE_KEY);return e&&upgradeInfo(e),e},getDarkMode=e=>{const t=localStorage.getItem("nl-dark-mode");return t?Boolean(JSON.parse(t)):void 0!==e.darkMode?e.darkMode:!(!window.matchMedia||!window.matchMedia("(prefers-color-scheme: dark)").matches)},getIcon=async()=>document.location.origin+"/favicon.ico";class NostrRpc extends NDKNostrRpc{_ndk;_signer;requests=new Set;sub;_useNip44=!1;constructor(e,t){super(e,t,e.debug.extend("nip46:signer:rpc")),this._ndk=e,this._signer=t}async subscribe(e){return e.kinds=e.kinds?.filter(e=>24133===e),this.sub=await super.subscribe(e),this.sub}stop(){this.sub&&(this.sub.stop(),this.sub=void 0)}setUseNip44(e){this._useNip44=e}isNip04(e){const t=e.length;return!(t<28)&&("?"===e[t-28]&&"i"===e[t-27]&&"v"===e[t-26]&&"="===e[t-25])}async parseEvent(e){const t=this._ndk.getUser({pubkey:e.pubkey});t.ndk=this._ndk;const n=this.isNip04(e.content)?await this._signer.decrypt(t,e.content,"nip04"):await this._signer.decrypt(t,e.content,"nip44"),r=JSON.parse(n),{id:i,method:s,params:o,result:a,error:c}=r;return s?{id:i,pubkey:e.pubkey,method:s,params:o,event:e}:{id:i,result:a,error:c,event:e}}async parseNostrConnectReply(e,t){const n=new NDKEvent(this._ndk,e),r=await this.parseEvent(n);if(console.log("nostr connect parsedEvent",r),r.method)throw new Error("Bad nostr connect reply");{const e=r;if(e.result!==t)throw new Error(e.error);return n.pubkey}}async listen(e){const t=this._signer.pubkey;console.log("nostr-login listening for conn to",t);const n=await this.subscribe({kinds:[24133],"#p":[t]});return new Promise((t,r)=>{n.on("event",async n=>{try{const i=await this.parseEvent(n);if(!i.method){const s=i;if("auth_url"===s.result)return;"ack"===s.result||s.result===e?t(n.pubkey):r(s.error)}}catch(e){console.log("error parsing event",e,n.rawEvent())}this.stop()})})}async connect(e,t,n){return new Promise((r,i)=>{const s=[e,t||"",n||""];this.sendRequest(e,"connect",s,24133,e=>{"ack"===e.result?r():i(e.error)})})}getId(){return Math.random().toString(36).substring(7)}async sendRequest(e,t,n=[],r=24133,i){const s=this.getId();this.setResponseHandler(s,i);const o=await this.createRequestEvent(s,e,t,n,r);console.log("sendRequest",{event:o,method:t,remotePubkey:e,params:n}),await o.publish()}setResponseHandler(e,t){let n=!1;const r=Date.now();return new Promise(()=>{const i=s=>{"auth_url"===s.result?(this.once(`response-${e}`,i),n||(n=!0,this.emit("authUrl",s.error))):t&&this.requests.has(e)&&(this.requests.delete(e),console.log("nostr-login processed nip46 request in",Date.now()-r,"ms"),t(s))};this.once(`response-${e}`,i)})}async createRequestEvent(e,t,n,r=[],i=24133){this.requests.add(e);const s=await this._signer.user(),o=this._ndk.getUser({pubkey:t}),a={id:e,method:n,params:r},c=new NDKEvent(this._ndk,{kind:i,content:JSON.stringify(a),tags:[["p",t]],pubkey:s.pubkey}),l=this._useNip44&&"create_account"!==n;return c.content=l?await this._signer.encrypt(o,c.content,"nip44"):await this._signer.encrypt(o,c.content,"nip04"),await c.sign(this._signer),c}}class IframeNostrRpc extends NostrRpc{peerOrigin;iframePort;iframeRequests=new Map;constructor(e,t,n){super(e,t),this._ndk=e,this.peerOrigin=n}async subscribe(e){return this.peerOrigin?new NDKSubscription(this._ndk,{},{closeOnEose:!0,cacheUsage:NDKSubscriptionCacheUsage.ONLY_CACHE}):super.subscribe(e)}setWorkerIframePort(e){if(!this.peerOrigin)throw new Error("Unexpected iframe port");this.iframePort=e,setInterval(()=>{console.log("iframe-nip46 ping"),this.iframePort.postMessage("ping")},5e3),e.onmessage=async e=>{if(console.log("iframe-nip46 got response",e.data),"string"==typeof e.data&&e.data.startsWith("errorNoKey")){const t=e.data.split(":")[1],{id:n="",pubkey:r=""}=this.iframeRequests.get(t)||{};return void(n&&r&&this.requests.has(n)&&this.emit(`iframeRestart-${r}`))}try{const t=e.data;if(!validateEvent(t))throw new Error("Invalid event from iframe");if(!verifySignature(t))throw new Error("Invalid event signature from iframe");const n=new NDKEvent(this._ndk,t),r=await this.parseEvent(n);r.method||(console.log("parsed response",r),this.emit(`response-${r.id}`,r))}catch(t){console.log("error parsing event",t,e.data)}}}async sendRequest(e,t,n=[],r=24133,i){const s=this.getId(),o=await this.createRequestEvent(s,e,t,n,r);this.setResponseHandler(s,i),this.iframePort?(this.iframeRequests.set(o.id,{id:s,pubkey:e}),console.log("iframe-nip46 sending request to",this.peerOrigin,o.rawEvent()),this.iframePort.postMessage(o.rawEvent())):await o.publish()}}class ReadyListener{origin;messages;promise;constructor(e,t){this.origin=t,this.messages=e,this.promise=new Promise(e=>{console.log(new Date,"started listener for",this.messages);const n=async r=>{const i=new URL(t).hostname,s=new URL(r.origin).hostname;(s===i||s.endsWith("."+i))&&Array.isArray(r.data)&&r.data.length&&this.messages.includes(r.data[0])&&(console.log(new Date,"got ready message from",r.origin,r.data),window.removeEventListener("message",n),e(r.data))};window.addEventListener("message",n)})}async wait(){console.log(new Date,"waiting for",this.messages);const e=await this.promise;return console.log(new Date,"finished waiting for",this.messages,e),e}}class Nip46Signer extends NDKNip46Signer{_rpc;_remotePubkey="";constructor(e,t,n,r){super(e,n,t),this._remotePubkey=n,this._rpc=new IframeNostrRpc(e,t,r),this._rpc.setUseNip44(!0),this._rpc.on("authUrl",e=>{this.emit("authUrl",e)}),this.rpc=this._rpc}get remotePubkey(){return this._remotePubkey}set remotePubkey(e){this._remotePubkey=e}async setSignerPubkey(e,t=!1){console.log("setSignerPubkey",e),this.remotePubkey=e,this._rpc.on(`iframeRestart-${e}`,()=>{this.emit("iframeRestart")}),await this.initUserPubkey(t?e:"")}async initUserPubkey(e){if(this.userPubkey)throw new Error("Already called initUserPubkey");this.userPubkey=e||await new Promise((e,t)=>{if(!this.remotePubkey)throw new Error("Signer pubkey not set");console.log("get_public_key",this.remotePubkey),this._rpc.sendRequest(this.remotePubkey,"get_public_key",[],24133,t=>{e(t.result)})})}async listen(e){const t=await this.rpc.listen(e);await this.setSignerPubkey(t)}async connect(e,t){if(!this.remotePubkey)throw new Error("No signer pubkey");await this._rpc.connect(this.remotePubkey,e,t),await this.setSignerPubkey(this.remotePubkey)}async setListenReply(e,t){const n=await this._rpc.parseNostrConnectReply(e,t);await this.setSignerPubkey(n,!0)}async createAccount2({bunkerPubkey:e,name:t,domain:n,perms:r=""}){const i=[t,n,"",r],s=await new Promise(t=>{this.rpc.sendRequest(e,"create_account",i,void 0,t)});if(console.log("create_account pubkey",s),"error"===s.result)throw new Error(s.error);return s.result}}class BannerManager extends lib$1.EventEmitter{banner=null;iframeReady;params;constructor(e){super(),this.params=e}onAuthUrl(e,t){this.banner&&(this.banner.notify=e?{mode:t?"iframeAuthUrl":"authUrl",url:e}:{mode:""})}onIframeRestart(e){this.banner&&(this.iframeReady=new ReadyListener(["rebinderDone","rebinderError"],new URL(e).origin),this.banner.notify={mode:"rebind",url:e})}onUserInfo(e){this.banner&&(this.banner.userInfo=e)}onCallTimeout(){this.banner&&(this.banner.notify={mode:"timeout"})}onCallStart(){this.banner&&(this.banner.isLoading=!0)}async onCallEnd(){this.banner&&(this.iframeReady&&(await this.iframeReady.wait(),this.iframeReady=void 0),this.banner.isLoading=!1,this.banner.notify={mode:""})}onUpdateAccounts(e){this.banner&&(this.banner.accounts=e)}onDarkMode(e){this.banner&&(this.banner.darkMode=e)}launchAuthBanner(e){this.banner=document.createElement("nl-banner"),this.banner.setAttribute("dark-mode",String(getDarkMode(e))),e.theme&&this.banner.setAttribute("theme",e.theme),e.noBanner&&this.banner.setAttribute("hidden-mode","true"),this.banner.addEventListener("handleLoginBanner",e=>{this.emit("launch",e.detail)}),this.banner.addEventListener("handleConfirmLogout",()=>{this.emit("onConfirmLogout")}),this.banner.addEventListener("handleLogoutBanner",async()=>{this.emit("logout")}),this.banner.addEventListener("handleImportModal",e=>{this.emit("import")}),this.banner.addEventListener("handleNotifyConfirmBanner",e=>{this.emit("onAuthUrlClick",e.detail)}),this.banner.addEventListener("handleNotifyConfirmBannerIframe",e=>{this.emit("onIframeAuthUrlClick",e.detail)}),this.banner.addEventListener("handleSwitchAccount",e=>{this.emit("onSwitchAccount",e.detail)}),this.banner.addEventListener("handleOpenWelcomeModal",()=>{this.emit("launch"),this.banner&&(this.banner.isOpen=!1)}),document.body.appendChild(this.banner)}}const decoder=new TextDecoder,u={minPlaintextSize:1,maxPlaintextSize:65535,utf8Encode:utf8ToBytes$6,utf8Decode:e=>decoder.decode(e),getConversationKey(e,t){const n=secp256k1$1.getSharedSecret(e,"02"+t).subarray(1,33);return extract(sha256$3,n,"nip44-v2")},getMessageKeys(e,t){const n=expand(sha256$3,e,t,76);return{chacha_key:n.subarray(0,32),chacha_nonce:n.subarray(32,44),hmac_key:n.subarray(44,76)}},calcPaddedLen(e){if(!Number.isSafeInteger(e)||e<1)throw new Error("expected positive integer");if(e<=32)return 32;const t=1<<Math.floor(Math.log2(e-1))+1,n=t<=256?32:t/8;return n*(Math.floor((e-1)/n)+1)},writeU16BE(e){if(!Number.isSafeInteger(e)||e<u.minPlaintextSize||e>u.maxPlaintextSize)throw new Error("invalid plaintext size: must be between 1 and 65535 bytes");const t=new Uint8Array(2);return new DataView(t.buffer).setUint16(0,e,!1),t},pad(e){const t=u.utf8Encode(e),n=t.length;return concatBytes$4(u.writeU16BE(n),t,new Uint8Array(u.calcPaddedLen(n)-n))},unpad(e){const t=new DataView(e.buffer).getUint16(0),n=e.subarray(2,2+t);if(t<u.minPlaintextSize||t>u.maxPlaintextSize||n.length!==t||e.length!==2+u.calcPaddedLen(t))throw new Error("invalid padding");return u.utf8Decode(n)},hmacAad(e,t,n){if(32!==n.length)throw new Error("AAD associated data must be 32 bytes");const r=concatBytes$4(n,t);return hmac$3(sha256$3,e,r)},decodePayload(e){if("string"!=typeof e)throw new Error("payload must be a valid string");const t=e.length;if(t<132||t>87472)throw new Error("invalid payload length: "+t);if("#"===e[0])throw new Error("unknown encryption version");let n;try{n=base64.decode(e)}catch(e){throw new Error("invalid base64: "+e.message)}const r=n.length;if(r<99||r>65603)throw new Error("invalid data length: "+r);const i=n[0];if(2!==i)throw new Error("unknown encryption version "+i);return{nonce:n.subarray(1,33),ciphertext:n.subarray(33,-32),mac:n.subarray(-32)}}};function encryptNip44(e,t,n=randomBytes$2(32)){const{chacha_key:r,chacha_nonce:i,hmac_key:s}=u.getMessageKeys(t,n),o=u.pad(e),a=chacha20(r,i,o),c=u.hmacAad(s,a,n);return base64.encode(concatBytes$4(new Uint8Array([2]),n,a,c))}function decryptNip44(e,t){const{nonce:n,ciphertext:r,mac:i}=u.decodePayload(e),{chacha_key:s,chacha_nonce:o,hmac_key:a}=u.getMessageKeys(t,n);if(!equalBytes(u.hmacAad(a,r,n),i))throw new Error("invalid MAC");const c=chacha20(s,o,r);return u.unpad(c)}class Nip44{cache=new Map;createKey(e,t){return u.getConversationKey(e,t)}getKey(e,t,n){const r=getPublicKey(e)+t;let i=this.cache.get(r);if(i)return i;const s=this.createKey(e,t);return this.cache.set(r,s),s}encrypt(e,t,n){return encryptNip44(n,this.getKey(e,t))}decrypt(e,t,n){return decryptNip44(n,this.getKey(e,t))}}const OUTBOX_RELAYS=["wss://user.kindpag.es","wss://purplepag.es","wss://relay.nos.social"],DEFAULT_NOSTRCONNECT_RELAYS=["wss://relay.nsec.app/","wss://ephemeral.snowflare.cc/"],CONNECT_TIMEOUT=1e4,NOSTRCONNECT_APPS=[{name:"Nsec.app",domain:"nsec.app",canImport:!0,img:"https://nsec.app/assets/favicon.ico",link:"https://use.nsec.app/<nostrconnect>",relays:DEFAULT_NOSTRCONNECT_RELAYS},{name:"Amber",img:"https://raw.githubusercontent.com/greenart7c3/Amber/refs/heads/master/assets/android-icon.svg",link:"<nostrconnect>",relays:DEFAULT_NOSTRCONNECT_RELAYS},{name:"Other key stores",img:"",link:"<nostrconnect>",relays:DEFAULT_NOSTRCONNECT_RELAYS}];class AuthNostrService extends lib$1.EventEmitter{ndk;profileNdk;signer=null;localSigner=null;params;signerPromise;signerErrCallback;readyPromise;readyCallback;nip44Codec=new Nip44;nostrConnectKey="";nostrConnectSecret="";iframe;starterReady;nip04;nip44;constructor(e){super(),this.params=e,this.ndk=new NDK({enableOutboxModel:!1}),this.profileNdk=new NDK({enableOutboxModel:!0,explicitRelayUrls:OUTBOX_RELAYS}),this.profileNdk.connect(CONNECT_TIMEOUT),this.nip04={encrypt:this.encrypt04.bind(this),decrypt:this.decrypt04.bind(this)},this.nip44={encrypt:this.encrypt44.bind(this),decrypt:this.decrypt44.bind(this)}}isIframe(){return!!this.iframe}async waitReady(){if(this.signerPromise)try{await this.signerPromise}catch{}if(this.readyPromise)try{await this.readyPromise}catch{}}cancelNostrConnect(){this.releaseSigner(),this.resetAuth()}async nostrConnect(e,{domain:t="",link:n="",iframeUrl:r="",importConnect:i=!1}={}){e=e&&e.length>0?e:DEFAULT_NOSTRCONNECT_RELAYS;const s={authMethod:"connect",pubkey:"",signerPubkey:"",sk:this.nostrConnectKey,domain:t,relays:e,iframeUrl:r};if(console.log("nostrconnect info",s,n),n&&!r&&window.open(n,"_blank","width=400,height=700"),await this.initSigner(s,{listen:!0}),!s.pubkey||!s.signerPubkey)throw new Error("Bad remote pubkey");return s.bunkerUrl=`bunker://${s.signerPubkey}?${e.map((e,t)=>`${0!==t?"&":""}relay=${e}`)}`,i||this.onAuth("login",s),s}async createNostrConnect(e){this.nostrConnectKey=generatePrivateKey(),this.nostrConnectSecret=Math.random().toString(36).substring(7);const t=getPublicKey(this.nostrConnectKey),n=encodeURIComponent(document.location.host),r=encodeURIComponent(document.location.origin),i=encodeURIComponent(await getIcon()),s=encodeURIComponent(this.params.optionsModal.perms||""),o=(e||[]).length>0?(e||[]).map(e=>`&relay=${encodeURIComponent(e)}`).join(""):"";return`nostrconnect://${t}?image=${i}&url=${r}&name=${n}&perms=${s}&secret=${this.nostrConnectSecret}${o}`}async getNostrConnectServices(){const e=await this.createNostrConnect(DEFAULT_NOSTRCONNECT_RELAYS),t=NOSTRCONNECT_APPS.map(e=>({...e}));for(const n of t){let t=[...DEFAULT_NOSTRCONNECT_RELAYS];if(n.link.startsWith("https://")){const e=n.domain||new URL(n.link).hostname;try{const r=await(await fetch(`https://${e}/.well-known/nostr.json`)).json(),i=r.names._,s=r.nip46?.[i];Array.isArray(s)&&s.length>0&&(t=s),n.iframeUrl=r.nip46?.iframe_url||""}catch(e){console.log("Bad app info",e,n)}}const r=e.split("&relay=")[0]+t.map(e=>`&relay=${encodeURIComponent(e)}`).join("");n.link=n.iframeUrl?r:n.link.replace("<nostrconnect>",r)}return[e,t]}async localSignup(e,t){const n=!t,r={pubkey:getPublicKey(t=t||generatePrivateKey()),sk:t,name:e,authMethod:"local"};console.log(`localSignup name: ${e}`),await this.setLocal(r,n)}async setLocal(e,t){this.releaseSigner(),this.localSigner=new NDKPrivateKeySigner(e.sk),t&&await createProfile(e,this.profileNdk,this.localSigner,this.params.optionsModal.signupRelays,this.params.optionsModal.outboxRelays),this.onAuth(t?"signup":"login",e)}prepareImportUrl(e){if("otp"===this.params.userInfo?.authMethod)return e+"&import=true";if(!this.localSigner||"local"!==this.params.userInfo?.authMethod)throw new Error("Most be local keys");return e+"#import="+nip19_exports.nsecEncode(this.localSigner.privateKey)}async importAndConnect(e){const{relays:t,domain:n,link:r,iframeUrl:i}=e;if(!n)throw new Error("Domain required");const s=await this.nostrConnect(t,{domain:n,link:r,importConnect:!0,iframeUrl:i});await this.logout(!0),this.localSigner=null,this.onAuth("login",s)}setReadOnly(e){const t={pubkey:e,authMethod:"readOnly"};this.onAuth("login",t)}setExtension(e){const t={pubkey:e,authMethod:"extension"};this.onAuth("login",t)}setOTP(e,t){const n={pubkey:e,authMethod:"otp",otpData:t};this.onAuth("login",n)}async setConnect(e){this.releaseSigner(),await this.startAuth(),await this.initSigner(e),this.onAuth("login",e),await this.endAuth()}async createAccount(e){const[t,n]=e.split("@"),r=await getBunkerUrl(`_@${n}`,this.params.optionsModal);console.log("create account bunker's url",r);const i=bunkerUrlToInfo(r);if(!i.signerPubkey)throw new Error("Bad bunker url");const s=Boolean(this.params.userInfo);await this.initSigner(i,{eventToAddAccount:s});return{bunkerUrl:`bunker://${await this.signer.createAccount2({bunkerPubkey:i.signerPubkey,name:t,domain:n,perms:this.params.optionsModal.perms})}?`+(i.relays??[]).map(e=>`relay=${encodeURIComponent(e)}`).join("&"),sk:i.sk}}releaseSigner(){this.signer=null,this.signerErrCallback?.("cancelled"),this.localSigner=null;for(const e of this.ndk.pool.relays.keys())this.ndk.pool.removeRelay(e)}async logout(e=!1){e||this.releaseSigner(),localStorageRemoveCurrentAccount(),this.onAuth("logout"),this.emit("updateAccounts")}setUserInfo(e){this.params.userInfo=e,this.emit("onUserInfo",e),e&&(localStorageAddAccount(e),this.emit("updateAccounts"))}exportKeys(){return this.params.userInfo?"local"!==this.params.userInfo.authMethod?"":nip19_exports.nsecEncode(this.params.userInfo.sk):""}onAuth(e,t=null){if("logout"!==e&&!t)throw new Error("No user info in onAuth");if(t&&this.params.userInfo&&(t.pubkey!==this.params.userInfo.pubkey||t.authMethod!==this.params.userInfo.authMethod)){const e=new CustomEvent("nlAuth",{detail:{type:"logout"}});console.log("nostr-login auth",e.detail),document.dispatchEvent(e)}this.setUserInfo(t),t&&fetchProfile(t,this.profileNdk).then(e=>{if(this.params.userInfo!==t)return;const n={...this.params.userInfo,picture:e?.image||e?.picture,name:e?.name||e?.displayName||e?.nip05||nip19_exports.npubEncode(t.pubkey)};this.setUserInfo(n)});try{const n=t?nip19_exports.npubEncode(t.pubkey):"",r={type:e};"logout"===e?(this.iframe&&this.iframe.remove(),this.iframe=void 0):(r.pubkey=t.pubkey,r.name=t.name,t.sk&&(r.localNsec=nip19_exports.nsecEncode(t.sk)),t.relays&&(r.relays=t.relays),t.otpData&&(r.otpData=t.otpData),r.method=t.authMethod||"connect");const i=new CustomEvent("nlAuth",{detail:r});console.log("nostr-login auth",r),document.dispatchEvent(i),this.params.optionsModal.onAuth&&this.params.optionsModal.onAuth(n,r)}catch(e){console.log("onAuth error",e)}}async createIframe(e){if(!e)return;const t=new URL(e);let n;const r="__nostr-login-worker-iframe-"+t.hostname.replaceAll(".","-");n=document.querySelector(`#${r}`),console.log("iframe",r,n),n||(n=document.createElement("iframe"),n.setAttribute("width","0"),n.setAttribute("height","0"),n.setAttribute("border","0"),n.style.display="none",n.id=r,document.body.append(n)),n.setAttribute("src",e);const i=new ReadyListener(["workerReady","workerError"],t.origin);await new Promise(e=>{n.addEventListener("load",e)});const s=await i.wait();return console.log("nostr-login iframe ready",e,s),{iframe:n,port:s[1]}}async sendNeedAuth(){const[e]=await this.getNostrConnectServices(),t=new CustomEvent("nlNeedAuth",{detail:{nostrconnect:e}});console.log("nostr-login need auth",e),document.dispatchEvent(t)}isAuthing(){return!!this.readyCallback}async startAuth(){if(console.log("startAuth"),this.readyCallback)throw new Error("Already started");this.readyPromise=new Promise(e=>this.readyCallback=e)}async endAuth(){if(console.log("endAuth",this.params.userInfo),this.params.userInfo&&this.params.userInfo.iframeUrl){const{iframe:e,port:t}=await this.createIframe(this.params.userInfo.iframeUrl)||{};if(this.iframe=e,!this.iframe||!t)return;this.signer.rpc.setWorkerIframePort(t)}this.readyCallback(),this.readyCallback=void 0}resetAuth(){this.readyCallback&&this.readyCallback(),this.readyCallback=void 0}async listen(e){if(!e.iframeUrl)return this.signer.listen(this.nostrConnectSecret);const t=await this.starterReady.wait();if("starterError"===t[0])throw new Error(t[1]);return this.signer.setListenReply(t[1],this.nostrConnectSecret)}async connect(e,t){return this.signer.connect(e.token,t)}async initSigner(e,{listen:t=!1,connect:n=!1,eventToAddAccount:r=!1}={}){if(this.signerPromise)try{await this.signerPromise}catch{}console.log("initSigner info",e);const i=e.iframeUrl?new URL(e.iframeUrl).origin:void 0;return i&&(this.starterReady=new ReadyListener(["starterDone","starterError"],i)),this.emit("onIframeUrl",e.iframeUrl),this.signerPromise=new Promise(async(s,o)=>{this.signerErrCallback=o;try{if(console.log("NDK relays before connect:",Array.from(this.ndk.pool.relays.keys())),e.relays&&!e.iframeUrl)for(const t of e.relays)this.ndk.addExplicitRelay(t,void 0),console.log("Added relay:",t);console.log("NDK relays after add:",Array.from(this.ndk.pool.relays.keys())),this.ndk.connect(CONNECT_TIMEOUT).catch(e=>{console.log("Some relays failed to connect, continuing anyway:",e)}),await new Promise((e,t)=>{const n=()=>{Array.from(this.ndk.pool.relays.values()).filter(e=>3===e.status).length>0?e():setTimeout(n,100)};setTimeout(()=>{Array.from(this.ndk.pool.relays.values()).filter(e=>3===e.status).length>0?e():t(new Error("No relays connected"))},CONNECT_TIMEOUT);n()}),console.log("NDK connected relays:",Array.from(this.ndk.pool.relays.entries()).map(([e,t])=>({url:e,status:t.status})));const o=new NDKPrivateKeySigner(e.sk);this.signer=new Nip46Signer(this.ndk,o,e.signerPubkey,i),this.signer.on("iframeRestart",async()=>{const t=e.iframeUrl+(e.iframeUrl.includes("?")?"&":"?")+"pubkey="+e.pubkey+"&rebind="+o.pubkey;this.emit("iframeRestart",{pubkey:e.pubkey,iframeUrl:t})}),this.signer.on("authUrl",t=>{console.log("nostr login auth url",t),this.emit("onAuthUrl",{url:t,iframeUrl:e.iframeUrl,eventToAddAccount:r})}),t?await this.listen(e):n?await this.connect(e,this.params.optionsModal.perms):await this.signer.initUserPubkey(e.pubkey),e.pubkey=this.signer.userPubkey,e.signerPubkey=this.signer.remotePubkey,s()}catch(e){console.log("initSigner failure",e),this.signer=null,o(e)}}),this.signerPromise}async authNip46(e,{name:t,bunkerUrl:n,sk:r="",domain:i="",iframeUrl:s=""}){try{const o=bunkerUrlToInfo(n,r);if(isBunkerUrl(t)?o.bunkerUrl=t:(o.nip05=t,o.domain=t.split("@")[1]),i&&(o.domain=i),s&&(o.iframeUrl=s),!o.signerPubkey||!o.sk||!o.relays||0===o.relays.length)throw new Error(`Bad bunker url ${n}`);const a=Boolean(this.params.userInfo);console.log("authNip46",e,o),await this.initSigner(o,{connect:!0,eventToAddAccount:a}),this.onAuth(e,o)}catch(e){throw console.log("nostr login auth failed",e),e}}async signEvent(e){const t=(async()=>(this.localSigner?(e.pubkey=getPublicKey(this.localSigner.privateKey),e.id=getEventHash(e),e.sig=await this.localSigner.sign(e)):(e.pubkey=this.signer?.remotePubkey,e.id=getEventHash(e),e.sig=await(this.signer?.sign(e))),e))(),n=new Promise((e,t)=>{setTimeout(()=>t(new Error("Sign timeout")),2e4)}),r=await Promise.race([t,n]);return console.log("signed",{event:r}),r}async codec_call(e,t,n){return new Promise((r,i)=>{this.signer.rpc.sendRequest(this.signer.remotePubkey,e,[t,n],24133,e=>{e.error?i(e.error):r(e.result)})})}async encrypt04(e,t){return this.localSigner?this.localSigner.encrypt(new NDKUser({pubkey:e}),t):this.signer.encrypt(new NDKUser({pubkey:e}),t)}async decrypt04(e,t){return this.localSigner?this.localSigner.decrypt(new NDKUser({pubkey:e}),t):this.codec_call("nip04_decrypt",e,t)}async encrypt44(e,t){return this.localSigner?this.nip44Codec.encrypt(this.localSigner.privateKey,e,t):this.codec_call("nip44_encrypt",e,t)}async decrypt44(e,t){return this.localSigner?this.nip44Codec.decrypt(this.localSigner.privateKey,e,t):this.codec_call("nip44_decrypt",e,t)}}class ModalManager extends lib$1.EventEmitter{modal=null;params;extensionService;authNostrService;launcherPromise;accounts=[];recents=[];opt;constructor(e,t,n){super(),this.params=e,this.extensionService=n,this.authNostrService=t}async waitReady(){if(this.launcherPromise){try{await this.launcherPromise}catch{}this.launcherPromise=void 0}}async launch(e){console.log("nostr-login launch",e),this.launcherPromise&&await this.waitReady(),this.authNostrService.isAuthing()&&this.authNostrService.resetAuth(),this.opt=e;const t=document.createElement("dialog");if(this.modal=document.createElement("nl-auth"),this.modal.accounts=this.accounts,this.modal.recents=this.recents,this.modal.setAttribute("dark-mode",String(getDarkMode(e))),e.theme&&this.modal.setAttribute("theme",e.theme),e.startScreen&&this.modal.setAttribute("start-screen",e.startScreen),e.bunkers)this.modal.setAttribute("bunkers",e.bunkers);else{let e="nsec.app,highlighter.com";this.modal.setAttribute("bunkers",e)}void 0!==e.methods&&(this.modal.authMethods=e.methods),void 0!==e.localSignup&&(this.modal.localSignup=e.localSignup),void 0!==e.signupNstart&&(this.modal.signupNjump=e.signupNstart),e.title&&(this.modal.welcomeTitle=e.title),e.description&&(this.modal.welcomeDescription=e.description),this.modal.hasExtension=this.extensionService.hasExtension(),this.modal.hasOTP=!!e.otpRequestUrl&&!!e.otpReplyUrl,this.modal.isLoadingExtension=!1,this.modal.isLoading=!1,[this.modal.connectionString,this.modal.connectionStringServices]=await this.authNostrService.getNostrConnectServices(),t.appendChild(this.modal),document.body.appendChild(t);let n="";return this.launcherPromise=new Promise((e,r)=>{t.addEventListener("close",()=>{r(new Error("Closed")),this.authNostrService.resetAuth(),this.modal&&(document.body.removeChild(this.modal.parentNode),this.modal=null)});const i=async e=>{this.modal&&(this.modal.isLoading=!1),await this.authNostrService.endAuth(),t.close(),this.modal=null,e()},s=async(t,n)=>{this.modal&&(this.modal.isLoading=!0);try{n&&!n.start||await this.authNostrService.startAuth(),await t(),n&&!n.end||await i(e)}catch(e){console.log("error",e),this.modal&&(this.modal.isLoading=!1,this.modal.authUrl="",this.modal.iframeUrl="","cancelled"!==e&&(this.modal.error=e.toString()))}},o=async(e,t)=>{await s(async()=>{const n=await getBunkerUrl(e,this.params.optionsModal);await this.authNostrService.authNip46("login",{name:e,bunkerUrl:n,domain:t})})},a=async e=>{await s(async()=>{const{bunkerUrl:t,sk:n}=await this.authNostrService.createAccount(e);await this.authNostrService.authNip46("signup",{name:e,bunkerUrl:t,sk:n})})},c=async()=>{try{await navigator.clipboard.writeText(this.authNostrService.exportKeys()),localStorageSetItem("backupKey","true")}catch(e){console.error("Failed to copy to clipboard: ",e)}},l=async e=>{await s(async()=>{const{iframeUrl:t}=e;e.link=this.authNostrService.prepareImportUrl(e.link),this.modal&&t&&(this.modal.authUrl=e.link,this.modal.iframeUrl=t,this.modal.isLoading=!1,console.log("nostrconnect authUrl",this.modal.authUrl,this.modal.iframeUrl)),await this.authNostrService.importAndConnect(e)})},h=async e=>{await s(async()=>{const{relays:t,domain:n,link:r,iframeUrl:i}=e||{};console.log("nostrConnect",e,t,n,r,i),this.modal&&(i&&(this.modal.authUrl=r,this.modal.iframeUrl=i,this.modal.isLoading=!1,console.log("nostrconnect authUrl",this.modal.authUrl,this.modal.iframeUrl)),e||(this.modal.isLoading=!1)),await this.authNostrService.nostrConnect(t,{domain:n,link:r,iframeUrl:i})})},d=async e=>{await s(async()=>{if(!e)throw new Error("Please enter some nickname");await this.authNostrService.localSignup(e)})},u=async()=>{await s(async()=>{const e=new URL(window.location.href),t=e.hostname.toLocaleLowerCase().replace(/^www\./i,"").charAt(0).toUpperCase()+e.hostname.slice(1),n=prepareSignupRelays(this.params.optionsModal.signupRelays);return this.modal.njumpIframe=`\n <html><body>\n <script src='https://start.njump.me/modal.js'><\/script>\n <script>\n new NstartModal({\n baseUrl: 'https://start.njump.me',\n // Required parameters\n an: '${t}',\n // Optional parameters\n s: [${this.opt.followNpubs?`'${this.opt.followNpubs}'`:""}],\n afb: false, // forceBunker\n asb: false, // skipBunker\n aan: false, // avoidNsec\n aac: true, // avoidNcryptsec\n ahc: true, // hide close button\n arr: ${JSON.stringify(n)}, //readRelays\n awr: ${JSON.stringify(n)}, //writeRelays\n // Callbacks\n onComplete: (result) => {\n console.log('Login token:', result.nostrLogin);\n window.parent.location.href='${window.location.href}#nostr-login='+result.nostrLogin;\n },\n onCancel: () => {\n window.parent.location.href='${window.location.href}#nostr-login=null';\n },\n }).open();\n <\/script>\n </body></html>\n `.replaceAll("&","&"),new Promise((e,t)=>{const n=async n=>{if(console.log("nsecOrBunker",n),n.startsWith("nsec1")){let t;try{t=nip19_exports.decode(n)}catch(e){throw new Error("Bad nsec value")}if("nsec"!==t.type)throw new Error("Bad bech32 type");await this.authNostrService.localSignup("",t.data),e()}else n.startsWith("bunker:")?(await this.authNostrService.authNip46("login",{name:"",bunkerUrl:n}),e()):t("null"===n?"Cancelled":"Unknown return value")};window.addEventListener("hashchange",async()=>{if(window.location.hash.startsWith("#nostr-login=")){const e=window.location.hash.split("#nostr-login=")[1],t=new URL(window.location.toString());t.hash="",window.history.replaceState({},"",t.toString()),n(e)}})})})};if(!this.modal)throw new Error("WTH?");this.modal.addEventListener("handleContinue",()=>{this.modal&&(this.modal.isLoading=!0,this.emit("onAuthUrlClick",this.modal.authUrl))}),this.modal.addEventListener("nlLogin",e=>{o(e.detail)}),this.modal.addEventListener("nlSignup",e=>{a(e.detail)}),this.modal.addEventListener("nlLocalSignup",e=>{d(e.detail)}),this.modal.addEventListener("nlSignupNjump",e=>{u()}),this.modal.addEventListener("nlImportAccount",e=>{l(e.detail)}),this.modal.addEventListener("nlExportKeys",e=>{c()}),this.modal.addEventListener("handleLogoutBanner",()=>{this.emit("onLogoutBanner")}),this.modal.addEventListener("nlNostrConnect",e=>{h(e.detail)}),this.modal.addEventListener("nlNostrConnectDefault",()=>{this.authNostrService.isAuthing()||h()}),this.modal.addEventListener("nlNostrConnectDefaultCancel",()=>{console.log("nlNostrConnectDefaultCancel"),this.authNostrService.cancelNostrConnect()}),this.modal.addEventListener("nlSwitchAccount",e=>{const n=e.detail;this.emit("onSwitchAccount",n),setTimeout(()=>t.close(),300)}),this.modal.addEventListener("nlLoginRecentAccount",async e=>{const n=e.detail;if("readOnly"===n.authMethod)this.authNostrService.setReadOnly(n.pubkey),t.close();else if("otp"===n.authMethod)try{this.modal.dispatchEvent(new CustomEvent("nlLoginOTPUser",{detail:n.nip05||n.pubkey}))}catch(e){console.error(e)}else if("extension"===n.authMethod)await this.extensionService.trySetExtensionForPubkey(n.pubkey),t.close();else{const e=n.bunkerUrl||n.nip05;if(!e)throw new Error("Bad connect info");o(e,n.domain)}}),this.modal.addEventListener("nlRemoveRecent",e=>{localStorageRemoveRecent(e.detail),this.emit("updateAccounts")});const p=async e=>{let t="";if(e.includes("@")){const{error:n,pubkey:r}=await checkNip05(e);if(!r)throw new Error(n);t=r}else if(e.startsWith("npub")){const{type:n,data:r}=nip19_exports.decode(e);if("npub"!==n)throw new Error("Bad npub");t=r}else 64===e.trim().length&&(t=e.trim(),nip19_exports.npubEncode(t));return t};this.modal.addEventListener("nlLoginReadOnly",async e=>{await s(async()=>{const t=e.detail,n=await p(t);this.authNostrService.setReadOnly(n)})}),this.modal.addEventListener("nlLoginExtension",async()=>{if(!this.extensionService.hasExtension())throw new Error("No extension");await s(async()=>{this.modal&&(this.modal.isLoadingExtension=!0,await this.extensionService.setExtension(),this.modal.isLoadingExtension=!1)})}),this.modal.addEventListener("nlLoginOTPUser",async e=>{await s(async()=>{if(!this.modal)return;const t=e.detail,r=await p(t),i=this.opt.otpRequestUrl+(this.opt.otpRequestUrl.includes("?")?"&":"?")+"pubkey="+r,s=await fetch(i);if(200!==s.status)throw console.warn("nostr-login: bad otp reply",s),new Error("Failed to send DM");this.modal.isOTP=!0,n=r,this.modal.isLoading=!1},{start:!0})}),this.modal.addEventListener("nlLoginOTPCode",async e=>{await s(async()=>{if(!this.modal)return;const t=e.detail,r=this.opt.otpReplyUrl+(this.opt.otpRequestUrl.includes("?")?"&":"?")+"pubkey="+n+"&code="+t,i=await fetch(r);if(200!==i.status)throw console.warn("nostr-login: bad otp reply",i),new Error("Invalid code");const s=await i.text();this.authNostrService.setOTP(n,s),this.modal.isOTP=!1},{end:!0})}),this.modal.addEventListener("nlCheckSignup",async e=>{const{available:t,taken:n,error:r}=await checkNip05(e.detail);this.modal&&(this.modal.error=String(r),!r&&n&&(this.modal.error="Already taken"),this.modal.signupNameIsAvailable=t)}),this.modal.addEventListener("nlCheckLogin",async e=>{const{available:t,taken:n,error:r}=await checkNip05(e.detail);this.modal&&(this.modal.error=String(r),t&&(this.modal.error="Name not found"),this.modal.loginIsGood=n)});const f=()=>{this.modal&&(this.modal.isLoading=!1),t.close(),r(new Error("Cancelled"))};this.modal.addEventListener("stopFetchHandler",f),this.modal.addEventListener("nlCloseModal",f),this.modal.addEventListener("nlChangeDarkMode",e=>{setDarkMode(e.detail),document.dispatchEvent(new CustomEvent("nlDarkMode",{detail:e.detail}))}),this.on("onIframeAuthUrlCallEnd",()=>{t.close(),this.modal=null,e()}),t.showModal()}),this.launcherPromise}async showIframeUrl(e){await this.waitReady(),this.launch({startScreen:"iframe"}).catch(()=>console.log("closed auth iframe")),this.modal.authUrl=e}connectModals(e){const t=async e=>{await this.launch(e)},n=document.getElementsByTagName("nl-button");for(let r=0;r<n.length;r++){const i=n[r].getAttribute("nl-theme"),s=n[r].getAttribute("start-screen"),o={...e};switch(i&&(o.theme=i),s){case"login":case"login-bunker-url":case"login-read-only":case"signup":case"switch-account":case"welcome":o.startScreen=s}n[r].addEventListener("click",function(){t(o)})}}onAuthUrl(e){this.modal&&(this.modal.authUrl=e,this.modal.isLoading=!1)}onIframeUrl(e){this.modal&&(console.log("modal iframe url",e),this.modal.iframeUrl=e)}onCallEnd(){this.modal&&this.modal.authUrl&&this.params.userInfo?.iframeUrl&&this.emit("onIframeAuthUrlCallEnd")}onUpdateAccounts(e,t){this.accounts=e,this.recents=t,this.modal&&(this.modal.accounts=e,this.modal.recents=t)}onDarkMode(e){this.modal&&(this.modal.darkMode=e)}}class Nostr{#e;nip04;nip44;constructor(e){this.#e=e,this.getPublicKey=this.getPublicKey.bind(this),this.signEvent=this.signEvent.bind(this),this.getRelays=this.getRelays.bind(this),this.nip04={encrypt:this.encrypt04.bind(this),decrypt:this.decrypt04.bind(this)},this.nip44={encrypt:this.encrypt44.bind(this),decrypt:this.decrypt44.bind(this)}}async ensureAuth(){if(await this.#e.waitReady(),!this.#e.getUserInfo()&&(await this.#e.launch(),!this.#e.getUserInfo()))throw new Error("Rejected by user")}async getPublicKey(){await this.ensureAuth();const e=this.#e.getUserInfo();if(e)return e.pubkey;throw new Error("No user")}async signEvent(e){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().signEvent(e))}async getRelays(){return{}}async encrypt04(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip04.encrypt(e,t))}async decrypt04(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip04.decrypt(e,t))}async encrypt44(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip44.encrypt(e,t))}async decrypt44(e,t){return await this.ensureAuth(),this.#e.wait(async()=>await this.#e.getSigner().nip44.decrypt(e,t))}}class NostrExtensionService extends lib$1.EventEmitter{params;nostrExtension;constructor(e){super(),this.params=e}startCheckingExtension(e){if(this.checkExtension(e))return;const t=setInterval(()=>{this.checkExtension(e)&&clearTimeout(t)},100)}checkExtension(e){return!(this.nostrExtension||!window.nostr||window.nostr===e)&&(this.initExtension(e),!0)}async initExtension(e,t){this.nostrExtension=window.nostr,window.nostr=e,"extension"===this.params.userInfo?.authMethod&&await this.trySetExtensionForPubkey(this.params.userInfo.pubkey),t||setTimeout(()=>{window.nostr!==e&&this.nostrExtension!==window.nostr&&this.initExtension(e,!0)},300)}async setExtensionReadPubkey(e){window.nostr=this.nostrExtension;const t=await window.nostr.getPublicKey();e&&e!==t?this.emit("extensionLogout"):this.emit("extensionLogin",t)}async trySetExtensionForPubkey(e){if(this.nostrExtension)return this.setExtensionReadPubkey(e)}async setExtension(){return this.setExtensionReadPubkey()}unsetExtension(e){window.nostr===this.nostrExtension&&(window.nostr=e)}getExtension(){return this.nostrExtension}hasExtension(){return!!this.nostrExtension}}class NostrParams{userInfo;optionsModal;constructor(){this.userInfo=null,this.optionsModal={theme:"default",startScreen:"welcome",devOverrideBunkerOrigin:""}}}class Popup{popup=null;constructor(){}openPopup(e){if((!this.popup||this.popup.closed)&&(this.popup=window.open(e,"_blank","width=400,height=700"),console.log("popup",this.popup),!this.popup))throw new Error("Popup blocked. Try again, please!")}closePopup(){try{this.popup?.close(),this.popup=null}catch{}}}const CALL_TIMEOUT=5e3;class ProcessManager extends lib$1.EventEmitter{callCount=0;callTimer;constructor(){super()}onAuthUrl(){Boolean(this.callTimer)&&clearTimeout(this.callTimer)}onIframeUrl(){Boolean(this.callTimer)&&clearTimeout(this.callTimer)}async wait(e){let t,n;this.callTimer||(this.callTimer=setTimeout(()=>this.emit("onCallTimeout"),CALL_TIMEOUT)),this.callCount||this.emit("onCallStart"),this.callCount++;try{n=await e()}catch(e){t=e}if(this.callCount--,this.emit("onCallEnd"),this.callTimer&&clearTimeout(this.callTimer),this.callTimer=void 0,t)throw t;return n}}class NostrLoginInitializer{extensionService;params;authNostrService;nostr;processManager;popupManager;bannerManager;modalManager;customLaunchCallback;constructor(){this.params=new NostrParams,this.processManager=new ProcessManager,this.popupManager=new Popup,this.bannerManager=new BannerManager(this.params),this.authNostrService=new AuthNostrService(this.params),this.extensionService=new NostrExtensionService(this.params),this.modalManager=new ModalManager(this.params,this.authNostrService,this.extensionService);const e={waitReady:async()=>{await this.authNostrService.waitReady(),await this.modalManager.waitReady()},getUserInfo:()=>this.params.userInfo,getSigner:()=>{if("readOnly"===this.params.userInfo.authMethod)throw new Error("Read only");return"extension"===this.params.userInfo.authMethod?this.extensionService.getExtension():this.authNostrService},launch:()=>this.launch(),wait:e=>this.processManager.wait(e)};this.nostr=new Nostr(e),this.processManager.on("onCallTimeout",()=>{this.bannerManager.onCallTimeout()}),this.processManager.on("onCallEnd",()=>{this.bannerManager.onCallEnd(),this.modalManager.onCallEnd()}),this.processManager.on("onCallStart",()=>{this.bannerManager.onCallStart()}),this.authNostrService.on("onIframeUrl",e=>{this.modalManager.onIframeUrl(e)}),this.authNostrService.on("iframeRestart",({iframeUrl:e})=>{this.processManager.onIframeUrl(),this.bannerManager.onIframeRestart(e)}),this.authNostrService.on("onAuthUrl",({url:e,iframeUrl:t,eventToAddAccount:n})=>{this.processManager.onAuthUrl(),n?this.modalManager.onAuthUrl(e):this.params.userInfo?this.bannerManager.onAuthUrl(e,t):this.modalManager.onAuthUrl(e)}),this.authNostrService.on("updateAccounts",()=>{this.updateAccounts()}),this.authNostrService.on("onUserInfo",e=>{this.bannerManager.onUserInfo(e)}),this.modalManager.on("onAuthUrlClick",e=>{this.openPopup(e)}),this.bannerManager.on("onIframeAuthUrlClick",e=>{this.modalManager.showIframeUrl(e)}),this.modalManager.on("onSwitchAccount",async e=>{this.switchAccount(e)}),this.modalManager.on("onLogoutBanner",async e=>{logout()}),this.bannerManager.on("onConfirmLogout",async()=>{this.launch("confirm-logout")}),this.modalManager.on("updateAccounts",()=>{this.updateAccounts()}),this.bannerManager.on("logout",()=>{logout()}),this.bannerManager.on("onAuthUrlClick",e=>{this.openPopup(e)}),this.bannerManager.on("onSwitchAccount",async e=>{this.switchAccount(e)}),this.bannerManager.on("import",()=>{this.launch("import")}),this.extensionService.on("extensionLogin",e=>{this.authNostrService.setExtension(e)}),this.extensionService.on("extensionLogout",()=>{logout()}),this.bannerManager.on("launch",e=>{this.launch(e)})}openPopup(e){this.popupManager.openPopup(e)}async switchAccount(e,t=!1){if(console.log("nostr login switch to info",e),this.extensionService.unsetExtension(this.nostr),"readOnly"===e.authMethod)this.authNostrService.setReadOnly(e.pubkey);else if("otp"===e.authMethod)this.authNostrService.setOTP(e.pubkey,e.otpData||"");else if("local"===e.authMethod&&e.sk)this.authNostrService.setLocal(e,t);else if("extension"===e.authMethod)await this.extensionService.trySetExtensionForPubkey(e.pubkey);else{if(!("connect"===e.authMethod&&e.sk&&e.relays&&e.relays[0]))throw new Error("Bad auth info");this.authNostrService.setConnect(e)}}updateAccounts(){const e=localStorageGetAccounts(),t=localStorageGetRecents();this.bannerManager.onUpdateAccounts(e),this.modalManager.onUpdateAccounts(e,t)}async launchCustomNostrConnect(){try{this.authNostrService.isAuthing()&&this.authNostrService.cancelNostrConnect();const e=new Promise(e=>this.customLaunchCallback=e);await this.authNostrService.startAuth(),await this.authNostrService.sendNeedAuth();try{await this.authNostrService.nostrConnect(),await this.authNostrService.endAuth()}catch(t){"cancelled"===t&&await e}}catch(e){console.error("launchCustomNostrConnect",e)}}fulfillCustomLaunchPromise(){if(this.customLaunchCallback){const e=this.customLaunchCallback;this.customLaunchCallback=void 0,e()}}launch=async e=>{if(!e&&this.params.optionsModal.customNostrConnect)return this.launchCustomNostrConnect();const t=localStorageGetRecents(),n=localStorageGetAccounts(),r={...this.params.optionsModal};e&&"default"!==e?r.startScreen=e:(Boolean(t?.length)||Boolean(n?.length))&&(r.startScreen="switch-account"),this.customLaunchCallback&&this.authNostrService.cancelNostrConnect();try{await this.modalManager.launch(r),this.fulfillCustomLaunchPromise()}catch(e){console.log("nostr-login failed",e)}};init=async e=>{this.extensionService.startCheckingExtension(this.nostr),window.nostr=this.nostr,this.modalManager.connectModals(e),this.bannerManager.launchAuthBanner(e),e&&(this.params.optionsModal={...e});try{const e=localStorageGetCurrent();if(e){if(!e.pubkey)throw new Error("Bad stored info");await this.switchAccount(e)}}catch(e){console.log("nostr login init error",e),await logout()}this.updateAccounts()};logout=async()=>{this.extensionService.unsetExtension(this.nostr),await this.authNostrService.logout()};setDarkMode=e=>{localStorageSetItem("nl-dark-mode",`${e}`),this.bannerManager.onDarkMode(e),this.modalManager.onDarkMode(e)};setAuth=async e=>{if(!e.type)throw new Error("Invalid auth event");if("login"!==e.type&&"logout"!==e.type&&"signup"!==e.type)throw new Error("Invalid auth event");if(e.method&&"connect"!==e.method&&"extension"!==e.method&&"local"!==e.method&&"otp"!==e.method&&"readOnly"!==e.method)throw new Error("Invalid auth event");if("logout"===e.type)return this.logout();if(!e.method||!e.pubkey)throw new Error("Invalid pubkey");const t={authMethod:e.method,pubkey:e.pubkey,relays:e.relays,sk:e.localNsec,otpData:e.otpData,name:e.name};await this.switchAccount(t,"signup"===e.type)};cancelNeedAuth=()=>{console.log("cancelNeedAuth"),this.fulfillCustomLaunchPromise(),this.authNostrService.cancelNostrConnect()}}const initializer=new NostrLoginInitializer,{init:init,launch:launch,logout:logout,setDarkMode:setDarkMode,setAuth:setAuth,cancelNeedAuth:cancelNeedAuth}=initializer;document.addEventListener("nlLogout",logout),document.addEventListener("nlLaunch",e=>{launch(e.detail||"")}),document.addEventListener("nlNeedAuthCancel",()=>{cancelNeedAuth()}),document.addEventListener("nlDarkMode",e=>{setDarkMode(!!e.detail)}),document.addEventListener("nlSetAuth",e=>{setAuth(e.detail)}),(()=>{const e=document.currentScript,t=async()=>{const t={};if(e){const n=e.getAttribute("data-dark-mode");n&&(t.darkMode="true"===n);const r=e.getAttribute("data-bunkers");r&&(t.bunkers=r);const i=e.getAttribute("data-start-screen");i&&(t.startScreen=i);const s=e.getAttribute("data-perms");s&&(t.perms=s);const o=e.getAttribute("data-theme");o&&(t.theme=o);const a=e.getAttribute("data-no-banner");a&&(t.noBanner="true"===a);const c=e.getAttribute("data-local-signup");c&&(t.localSignup="true"===c);const l=e.getAttribute("data-signup-nstart")||e.getAttribute("data-signup-njump");l&&(t.signupNstart="true"===l);const h=e.getAttribute("data-follow-npubs");h&&(t.followNpubs=h);const d=e.getAttribute("data-otp-request-url");d&&(t.otpRequestUrl=d);const u=e.getAttribute("data-otp-reply-url");u&&(t.otpReplyUrl=u),!!d!=!!u&&console.warn("nostr-login: need request and reply urls for OTP auth");const p=e.getAttribute("data-methods");p&&(t.methods=p.trim().split(",").filter(e=>!!e));const f=e.getAttribute("data-title");f&&(t.title=f);const g=e.getAttribute("data-description");g&&(t.description=g);const y=e.getAttribute("data-signup-relays");y&&(t.signupRelays=y);const m=e.getAttribute("data-outbox-relays");m&&(t.outboxRelays=m.split(","));const b="true"===e.getAttribute("data-dev");b&&(t.dev=b);const w="true"===e.getAttribute("data-custom-nostr-connect");w&&(t.customNostrConnect=w),console.log("nostr-login options",t)}init(t)};"loading"===document.readyState?document.addEventListener("DOMContentLoaded",t):t()})()})();
|
package/package.json
CHANGED
|
@@ -13,7 +13,7 @@ import { IframeNostrRpc, Nip46Signer, ReadyListener } from './Nip46';
|
|
|
13
13
|
|
|
14
14
|
const OUTBOX_RELAYS = ['wss://user.kindpag.es', 'wss://purplepag.es', 'wss://relay.nos.social'];
|
|
15
15
|
const DEFAULT_NOSTRCONNECT_RELAYS = ['wss://relay.nsec.app/', 'wss://ephemeral.snowflare.cc/'];
|
|
16
|
-
const CONNECT_TIMEOUT =
|
|
16
|
+
const CONNECT_TIMEOUT = 10000;
|
|
17
17
|
const NOSTRCONNECT_APPS: ConnectionString[] = [
|
|
18
18
|
{
|
|
19
19
|
name: 'Nsec.app',
|
|
@@ -165,7 +165,10 @@ class AuthNostrService extends EventEmitter implements Signer {
|
|
|
165
165
|
perms: encodeURIComponent(this.params.optionsModal.perms || ''),
|
|
166
166
|
};
|
|
167
167
|
|
|
168
|
-
|
|
168
|
+
// .join('') を追加
|
|
169
|
+
const relayParams = (relays || []).length > 0 ? (relays || []).map(r => `&relay=${encodeURIComponent(r)}`).join('') : '';
|
|
170
|
+
|
|
171
|
+
return `nostrconnect://${pubkey}?image=${meta.icon}&url=${meta.url}&name=${meta.name}&perms=${meta.perms}&secret=${this.nostrConnectSecret}${relayParams}`;
|
|
169
172
|
}
|
|
170
173
|
|
|
171
174
|
public async getNostrConnectServices(): Promise<[string, ConnectionString[]]> {
|
|
@@ -545,7 +548,6 @@ class AuthNostrService extends EventEmitter implements Signer {
|
|
|
545
548
|
this.signerPromise = new Promise<void>(async (ok, err) => {
|
|
546
549
|
this.signerErrCallback = err;
|
|
547
550
|
try {
|
|
548
|
-
// リレー接続前の状態
|
|
549
551
|
console.log('NDK relays before connect:', Array.from(this.ndk.pool.relays.keys()));
|
|
550
552
|
|
|
551
553
|
if (info.relays && !info.iframeUrl) {
|
|
@@ -557,15 +559,41 @@ class AuthNostrService extends EventEmitter implements Signer {
|
|
|
557
559
|
|
|
558
560
|
console.log('NDK relays after add:', Array.from(this.ndk.pool.relays.keys()));
|
|
559
561
|
|
|
560
|
-
|
|
562
|
+
// 全リレーを待たずに、接続できたものだけで進める
|
|
563
|
+
this.ndk.connect(CONNECT_TIMEOUT).catch(e => {
|
|
564
|
+
console.log('Some relays failed to connect, continuing anyway:', e);
|
|
565
|
+
});
|
|
566
|
+
|
|
567
|
+
// 少なくとも1つのリレーが接続するまで待つ
|
|
568
|
+
await new Promise<void>((resolve, reject) => {
|
|
569
|
+
const checkConnection = () => {
|
|
570
|
+
const connectedRelays = Array.from(this.ndk.pool.relays.values()).filter(r => r.status === 3);
|
|
571
|
+
|
|
572
|
+
if (connectedRelays.length > 0) {
|
|
573
|
+
resolve();
|
|
574
|
+
} else {
|
|
575
|
+
setTimeout(checkConnection, 100);
|
|
576
|
+
}
|
|
577
|
+
};
|
|
578
|
+
|
|
579
|
+
const timeoutId = setTimeout(() => {
|
|
580
|
+
const connectedRelays = Array.from(this.ndk.pool.relays.values()).filter(r => r.status === 3);
|
|
581
|
+
|
|
582
|
+
if (connectedRelays.length > 0) {
|
|
583
|
+
resolve();
|
|
584
|
+
} else {
|
|
585
|
+
reject(new Error('No relays connected'));
|
|
586
|
+
}
|
|
587
|
+
}, CONNECT_TIMEOUT);
|
|
588
|
+
|
|
589
|
+
checkConnection();
|
|
590
|
+
});
|
|
561
591
|
|
|
562
|
-
// 接続後の状態を確認
|
|
563
592
|
console.log(
|
|
564
593
|
'NDK connected relays:',
|
|
565
594
|
Array.from(this.ndk.pool.relays.entries()).map(([url, relay]) => ({
|
|
566
595
|
url,
|
|
567
596
|
status: relay.status,
|
|
568
|
-
connectionStats: relay.connectionStats,
|
|
569
597
|
})),
|
|
570
598
|
);
|
|
571
599
|
|