From 2b700598d0f76d979a758968bd8d15b573d20977 Mon Sep 17 00:00:00 2001 From: Milad Raeisi Date: Sat, 14 Sep 2024 12:54:47 +0400 Subject: [PATCH] Add the ability to login with an extension --- .../auth/login/login.component.html | 12 +++--- .../components/auth/login/login.component.ts | 15 ++++++- .../auth/logout/logout.component.ts | 2 +- src/app/core/auth/auth.guard.ts | 2 +- src/app/services/signer.service.ts | 43 ++++++++++++++----- 5 files changed, 54 insertions(+), 20 deletions(-) diff --git a/src/app/components/auth/login/login.component.html b/src/app/components/auth/login/login.component.html index 0babdca..81472b5 100644 --- a/src/app/components/auth/login/login.component.html +++ b/src/app/components/auth/login/login.component.html @@ -38,13 +38,13 @@ Secret Key - + Password - + diff --git a/src/app/components/auth/login/login.component.ts b/src/app/components/auth/login/login.component.ts index 5f0ad3c..1ca4ee1 100644 --- a/src/app/components/auth/login/login.component.ts +++ b/src/app/components/auth/login/login.component.ts @@ -36,7 +36,10 @@ export class LoginComponent implements OnInit { showAlert = false; loading = false; isInstalledExtension = false; - + privateKey: Uint8Array = new Uint8Array(); + publicKey: string = ""; + npub: string = ""; + nsec: string = ""; constructor( private _formBuilder: FormBuilder, private _router: Router, @@ -113,4 +116,14 @@ export class LoginComponent implements OnInit { this.showAlert = true; } } + + async loginWithNostrExtension(): Promise { + const success = await this._signerService.handleLoginWithExtension(); + if (success) { + this._router.navigateByUrl('/home'); + } else { + console.error('Failed to log in using Nostr extension'); + } + } + } diff --git a/src/app/components/auth/logout/logout.component.ts b/src/app/components/auth/logout/logout.component.ts index f977004..3fc1c55 100644 --- a/src/app/components/auth/logout/logout.component.ts +++ b/src/app/components/auth/logout/logout.component.ts @@ -33,7 +33,7 @@ export class LogoutComponent implements OnInit, OnDestroy { * On init */ ngOnInit(): void { - // Sign out + // Logout // Redirect after the countdown timer(1000, 1000) diff --git a/src/app/core/auth/auth.guard.ts b/src/app/core/auth/auth.guard.ts index 6682d22..1724f6d 100644 --- a/src/app/core/auth/auth.guard.ts +++ b/src/app/core/auth/auth.guard.ts @@ -7,7 +7,7 @@ export const authGuard = () => { const signerService = inject(SignerService); const router = inject(Router); - if (signerService.getSecretKey() !== "") { + if (signerService.getPublicKey() !== "") { return true; } diff --git a/src/app/services/signer.service.ts b/src/app/services/signer.service.ts index 2ba95fe..471122a 100644 --- a/src/app/services/signer.service.ts +++ b/src/app/services/signer.service.ts @@ -183,14 +183,31 @@ export class SignerService { localStorage.setItem("following", newFollowingList); } - savePublicKeyToSession(publicKey: string) { - localStorage.setItem(this.localStoragePublicKeyName, publicKey); + + + savePublicKeyToSession(publicKey: string): void { + const npub = nip19.npubEncode(publicKey); + window.localStorage.setItem(this.localStoragePublicKeyName, publicKey); + window.localStorage.setItem('npub', npub); + } + + getNpub(): string { + return window.localStorage.getItem('npub') || ''; + } + + removePublicKeyToSession() { + localStorage.removeItem(this.localStoragePublicKeyName); } + saveSecretKeyToSession(secretKey: string) { localStorage.setItem(this.localStorageSecretKeyName, secretKey); } + removeSecretKeyToSession() { + localStorage.removeItem(this.localStorageSecretKeyName); + } + setPublicKeyFromExtension(publicKey: string) { this.savePublicKeyToSession(publicKey); } @@ -247,19 +264,23 @@ export class SignerService { } async handleLoginWithExtension(): Promise { - const gt = globalThis as any; - if (gt.nostr) { - const pubkey = await gt.nostr.getPublicKey().catch((e) => { - console.log(e); - return ""; - }); - if (pubkey === "") { - return false; + const globalContext = globalThis as unknown as { nostr?: { getPublicKey?: Function } }; + if (!globalContext.nostr) { + return false; + } + + try { + const pubkey = await globalContext.nostr.getPublicKey(); + if (!pubkey) { + throw new Error("Public key not available from Nostr extension."); } + this.setPublicKeyFromExtension(pubkey); return true; + } catch (error) { + console.error('Failed to connect to Nostr extension:', error); + return false; } - return false; } async signEventWithExtension(unsignedEvent: UnsignedEvent): Promise {