From fe54a25a3af53c6070cb1c2f5f216445f752b29c Mon Sep 17 00:00:00 2001 From: Lungu Cristian Date: Thu, 25 Jul 2024 18:37:26 +0300 Subject: [PATCH] fix: not clearing network & web3-wallet on logout (#20886) --- .../status_im/multiaccounts/logout/core.cljs | 17 +++++++------ .../wallet/wallet_connect/events.cljs | 24 ++++++++++++------- 2 files changed, 25 insertions(+), 16 deletions(-) diff --git a/src/legacy/status_im/multiaccounts/logout/core.cljs b/src/legacy/status_im/multiaccounts/logout/core.cljs index 75951404ba..f41ed754ec 100644 --- a/src/legacy/status_im/multiaccounts/logout/core.cljs +++ b/src/legacy/status_im/multiaccounts/logout/core.cljs @@ -13,15 +13,18 @@ (native-module/logout))) (rf/defn initialize-app-db - [{{:keys [keycard initials-avatar-font-file biometrics] - :network/keys [type]} + [{{:keys [keycard initials-avatar-font-file biometrics] + :network/keys [type status] + :wallet-connect/keys [web3-wallet]} :db}] {:db (assoc db/app-db - :network/type type - :initials-avatar-font-file initials-avatar-font-file - :keycard (dissoc keycard :secrets :pin :application-info) - :biometrics biometrics - :syncing nil)}) + :network/type type + :network/status status + :initials-avatar-font-file initials-avatar-font-file + :keycard (dissoc keycard :secrets :pin :application-info) + :biometrics biometrics + :syncing nil + :wallet-connect/web3-wallet web3-wallet)}) (rf/defn logout-method {:events [::logout-method]} diff --git a/src/status_im/contexts/wallet/wallet_connect/events.cljs b/src/status_im/contexts/wallet/wallet_connect/events.cljs index a1a212aabe..a6dc8cfca5 100644 --- a/src/status_im/contexts/wallet/wallet_connect/events.cljs +++ b/src/status_im/contexts/wallet/wallet_connect/events.cljs @@ -14,17 +14,20 @@ (rf/reg-event-fx :wallet-connect/init (fn [{:keys [db]}] - (let [network-status (:network/status db)] - (if (= network-status :online) - {:fx [[:effects.wallet-connect/init - {:on-success #(rf/dispatch [:wallet-connect/on-init-success %]) - :on-fail #(rf/dispatch [:wallet-connect/on-init-fail %])}]]} + (let [network-status (:network/status db) + web3-wallet-missing? (-> db :wallet-connect/web3-wallet boolean not)] + (if (and (= network-status :online) web3-wallet-missing?) + (do (log/info "Initialising WalletConnect SDK") + {:fx [[:effects.wallet-connect/init + {:on-success #(rf/dispatch [:wallet-connect/on-init-success %]) + :on-fail #(rf/dispatch [:wallet-connect/on-init-fail %])}]]}) ;; NOTE: when offline, fetching persistent sessions only {:fx [[:dispatch [:wallet-connect/fetch-persisted-sessions]]]})))) (rf/reg-event-fx :wallet-connect/on-init-success (fn [{:keys [db]} [web3-wallet]] + (log/info "WalletConnect SDK initialisation successful") {:db (assoc db :wallet-connect/web3-wallet web3-wallet) :fx [[:dispatch [:wallet-connect/register-event-listeners]] [:dispatch [:wallet-connect/fetch-persisted-sessions]]]})) @@ -32,9 +35,9 @@ (rf/reg-event-fx :wallet-connect/reload-on-network-change (fn [{:keys [db]} [is-connected?]] - (let [logged-in? (-> db :profile/profile boolean) - web3-wallet-missing? (-> db :wallet-connect/web3-wallet boolean not)] - (when (and is-connected? logged-in? web3-wallet-missing?) + (let [logged-in? (-> db :profile/profile boolean)] + (when (and is-connected? logged-in?) + (log/info "Re-Initialising WalletConnect SDK due to network change") {:fx [[:dispatch [:wallet-connect/init]]]})))) (rf/reg-event-fx @@ -224,7 +227,10 @@ (not version-supported?) (i18n/label :t/wallet-connect-version-not-supported - {:version version}))}]]]} + {:version version}) + + :else + (i18n/label :t/something-went-wrong))}]]]} {:fx [[:dispatch [:wallet-connect/pair scanned-text]]]})))) ;; We first load sessions from database, then we initiate a call to Wallet Connect SDK and