From 3d7548729f74f8a7ce84cb91710b233a90091d2b Mon Sep 17 00:00:00 2001 From: sachaaaaa Date: Wed, 20 Nov 2019 12:27:07 +1100 Subject: [PATCH] Prevent prekeys to be deleted when re-sending pairing request --- libtextsecure/account_manager.js | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/libtextsecure/account_manager.js b/libtextsecure/account_manager.js index 8452e3934..14559d1cd 100644 --- a/libtextsecure/account_manager.js +++ b/libtextsecure/account_manager.js @@ -444,12 +444,18 @@ window.log.info('clearing all sessions, prekeys, and signed prekeys'); await Promise.all([ - store.clearPreKeyStore(), store.clearContactPreKeysStore(), - store.clearSignedPreKeysStore(), store.clearContactSignedPreKeysStore(), store.clearSessionStore(), ]); + // During secondary device registration we need to keep our prekeys sent + // to other pubkeys + if (textsecure.storage.get('secondaryDeviceStatus') !== 'ongoing') { + await Promise.all([ + store.clearPreKeyStore(), + store.clearSignedPreKeysStore(), + ]); + } }, // Takes the same object returned by generateKeys async confirmKeys(keys) {