From 445db6a4d6c705eb839717ee9c6ed094cce32613 Mon Sep 17 00:00:00 2001 From: Craig Raw Date: Tue, 15 Jun 2021 17:58:25 +0200 Subject: [PATCH] reduce file reads on db files to avoid locking exception on windows --- .../sparrow/io/db/DbPersistence.java | 22 +++++++------------ 1 file changed, 8 insertions(+), 14 deletions(-) diff --git a/src/main/java/com/sparrowwallet/sparrow/io/db/DbPersistence.java b/src/main/java/com/sparrowwallet/sparrow/io/db/DbPersistence.java index 0fc69c95..9b5ecaf4 100644 --- a/src/main/java/com/sparrowwallet/sparrow/io/db/DbPersistence.java +++ b/src/main/java/com/sparrowwallet/sparrow/io/db/DbPersistence.java @@ -126,13 +126,6 @@ public class DbPersistence implements Persistence { File walletFile = storage.getWalletFile(); walletFile = renameToDbFile(walletFile); - if(walletFile.exists() && isEncrypted(walletFile)) { - if(dataSource != null && !dataSource.isClosed()) { - dataSource.close(); - } - walletFile.delete(); - } - updatePassword(storage, null); cleanAndAddWallet(storage, wallet, null); @@ -144,13 +137,6 @@ public class DbPersistence implements Persistence { File walletFile = storage.getWalletFile(); walletFile = renameToDbFile(walletFile); - if(walletFile.exists() && !isEncrypted(walletFile)) { - if(dataSource != null && !dataSource.isClosed()) { - dataSource.close(); - } - walletFile.delete(); - } - boolean existing = walletFile.exists(); updatePassword(storage, encryptionPubKey); cleanAndAddWallet(storage, wallet, getFilePassword(encryptionPubKey)); @@ -344,6 +330,10 @@ public class DbPersistence implements Persistence { } private void writeBinaryHeader(File walletFile) throws IOException { + if(dataSource != null && !dataSource.isClosed()) { + dataSource.close(); + } + ByteBuffer header = ByteBuffer.allocate(HEADER_MAGIC_1.length + SALT_LENGTH_BYTES); header.put(HEADER_MAGIC_1); header.put(keyDeriver.getSalt()); @@ -454,6 +444,10 @@ public class DbPersistence implements Persistence { @Override public boolean isEncrypted(File walletFile) throws IOException { + if(dataSource != null) { + return getDatasourcePassword() != null; + } + byte[] header = new byte[H2_ENCRYPT_HEADER.length]; try(InputStream inputStream = new FileInputStream(walletFile)) { inputStream.read(header, 0, H2_ENCRYPT_HEADER.length);