feat: reuse existing bunker connection on account switch (#401)

This commit is contained in:
hoppe
2025-06-23 10:56:08 +09:00
committed by GitHub
parent 4e80d59c1c
commit f66ca6346f
2 changed files with 5 additions and 3 deletions

View File

@@ -12,7 +12,7 @@ export class BunkerSigner implements ISigner {
this.clientSecretKey = clientSecretKey ? hexToBytes(clientSecretKey) : generateSecretKey() this.clientSecretKey = clientSecretKey ? hexToBytes(clientSecretKey) : generateSecretKey()
} }
async login(bunker: string): Promise<string> { async login(bunker: string, isInitialConnection = true): Promise<string> {
const bunkerPointer = await parseBunkerInput(bunker) const bunkerPointer = await parseBunkerInput(bunker)
if (!bunkerPointer) { if (!bunkerPointer) {
throw new Error('Invalid bunker') throw new Error('Invalid bunker')
@@ -23,7 +23,9 @@ export class BunkerSigner implements ISigner {
window.open(url, '_blank') window.open(url, '_blank')
} }
}) })
if (isInitialConnection) {
await this.signer.connect() await this.signer.connect()
}
return await this.signer.getPublicKey() return await this.signer.getPublicKey()
} }

View File

@@ -450,7 +450,7 @@ export function NostrProvider({ children }: { children: React.ReactNode }) {
} else if (account.signerType === 'bunker') { } else if (account.signerType === 'bunker') {
if (account.bunker && account.bunkerClientSecretKey) { if (account.bunker && account.bunkerClientSecretKey) {
const bunkerSigner = new BunkerSigner(account.bunkerClientSecretKey) const bunkerSigner = new BunkerSigner(account.bunkerClientSecretKey)
const pubkey = await bunkerSigner.login(account.bunker) const pubkey = await bunkerSigner.login(account.bunker, false)
if (!pubkey) { if (!pubkey) {
storage.removeAccount(account) storage.removeAccount(account)
return null return null