From 2ca48054438a7a6739cbcec25bb6f4c9cf163872 Mon Sep 17 00:00:00 2001 From: Cameron Voell Date: Thu, 21 Dec 2023 17:43:42 -0500 Subject: [PATCH] fix: callbacks in auth flow no longer unsubscribed too early (#192) --- src/lib/Client.ts | 36 ++++++++++++++++++++++-------------- 1 file changed, 22 insertions(+), 14 deletions(-) diff --git a/src/lib/Client.ts b/src/lib/Client.ts index c6a45c96d..745e333b2 100644 --- a/src/lib/Client.ts +++ b/src/lib/Client.ts @@ -62,22 +62,32 @@ export class Client { 'sign', async (message: { id: string; message: string }) => { const request: { id: string; message: string } = message - const signatureString = await signer.signMessage(request.message) - const eSig = utils.splitSignature(signatureString) - const r = hexToBytes(eSig.r) - const s = hexToBytes(eSig.s) - const sigBytes = new Uint8Array(65) - sigBytes.set(r) - sigBytes.set(s, r.length) - sigBytes[64] = eSig.recoveryParam - - const signature = Buffer.from(sigBytes).toString('base64') - - XMTPModule.receiveSignature(request.id, signature) + try { + const signatureString = await signer.signMessage(request.message) + const eSig = utils.splitSignature(signatureString) + const r = hexToBytes(eSig.r) + const s = hexToBytes(eSig.s) + const sigBytes = new Uint8Array(65) + sigBytes.set(r) + sigBytes.set(s, r.length) + sigBytes[64] = eSig.recoveryParam + + const signature = Buffer.from(sigBytes).toString('base64') + + XMTPModule.receiveSignature(request.id, signature) + } catch (e) { + const errorMessage = 'ERROR in create. User rejected signature' + console.info(errorMessage, e) + this.removeSubscription(enableSubscription) + this.removeSubscription(createSubscription) + reject(errorMessage) + } } ) XMTPModule.emitter.addListener('authed', async () => { + this.removeSubscription(enableSubscription) + this.removeSubscription(createSubscription) const address = await signer.getAddress() resolve(new Client(address, opts?.codecs || [])) }) @@ -89,8 +99,6 @@ export class Client { Boolean(enableSubscription) ) })() - this.removeSubscription(enableSubscription) - this.removeSubscription(createSubscription) }) }