From e160499d305b14c7eead4db0301e7168b35b6e40 Mon Sep 17 00:00:00 2001 From: woodser Date: Thu, 28 Dec 2023 08:08:03 -0500 Subject: [PATCH] sync main wallet outside lock on connection changed --- .../core/xmr/wallet/XmrWalletService.java | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/core/src/main/java/haveno/core/xmr/wallet/XmrWalletService.java b/core/src/main/java/haveno/core/xmr/wallet/XmrWalletService.java index eafb893875..202f1c7c5d 100644 --- a/core/src/main/java/haveno/core/xmr/wallet/XmrWalletService.java +++ b/core/src/main/java/haveno/core/xmr/wallet/XmrWalletService.java @@ -300,6 +300,10 @@ public class XmrWalletService { } } + private MoneroSyncResult syncWallet() { + return syncWallet(wallet); + } + public void saveWallet(MoneroWallet wallet, boolean backup) { wallet.save(); if (backup) backupWallet(wallet.getPath()); @@ -791,7 +795,7 @@ public class XmrWalletService { if (wallet.getHeight() < xmrConnectionService.getTargetHeight()) updateSyncProgress(); else { syncLooper.stop(); - wallet.sync(); // necessary to fully sync + syncWallet(); // necessary to fully sync wasWalletSynced = true; updateSyncProgress(); latch.countDown(); @@ -940,13 +944,11 @@ public class XmrWalletService { if (connection != null) { wallet.getDaemonConnection().setPrintStackTrace(PRINT_STACK_TRACE); HavenoUtils.submitToPool(() -> { - synchronized (walletLock) { - try { - if (Boolean.TRUE.equals(connection.isConnected())) wallet.sync(); - wallet.startSyncing(xmrConnectionService.getRefreshPeriodMs()); - } catch (Exception e) { - log.warn("Failed to sync main wallet after setting daemon connection: " + e.getMessage()); - } + try { + if (Boolean.TRUE.equals(connection.isConnected())) syncWallet(); + wallet.startSyncing(xmrConnectionService.getRefreshPeriodMs()); + } catch (Exception e) { + log.warn("Failed to sync main wallet after setting daemon connection: " + e.getMessage()); } }); }