From c5f6aeb4ccfedc5cf2eccaf84ec8319bfa7a5e49 Mon Sep 17 00:00:00 2001 From: woodser Date: Tue, 27 Dec 2022 07:19:49 +0000 Subject: [PATCH] sync and save wallet when closing ticket, fix NPE --- .../java/bisq/core/btc/wallet/XmrWalletService.java | 8 +++++--- .../java/bisq/core/support/dispute/DisputeManager.java | 10 ++++++++-- .../java/bisq/core/trade/protocol/TradingPeer.java | 4 ++-- .../java/bisq/daemon/grpc/GrpcDisputesService.java | 2 +- 4 files changed, 16 insertions(+), 8 deletions(-) diff --git a/core/src/main/java/bisq/core/btc/wallet/XmrWalletService.java b/core/src/main/java/bisq/core/btc/wallet/XmrWalletService.java index edf5d90285..f3c6014405 100644 --- a/core/src/main/java/bisq/core/btc/wallet/XmrWalletService.java +++ b/core/src/main/java/bisq/core/btc/wallet/XmrWalletService.java @@ -280,9 +280,11 @@ public class XmrWalletService { public MoneroTxWallet createTx(List destinations) { try { - MoneroTxWallet tx = wallet.createTx(new MoneroTxConfig().setAccountIndex(0).setDestinations(destinations).setRelay(false).setCanSplit(false)); - //printTxs("XmrWalletService.createTx", tx); - return tx; + synchronized (wallet) { + MoneroTxWallet tx = wallet.createTx(new MoneroTxConfig().setAccountIndex(0).setDestinations(destinations).setRelay(false).setCanSplit(false)); + //printTxs("XmrWalletService.createTx", tx); + return tx; + } } catch (Exception e) { throw e; } diff --git a/core/src/main/java/bisq/core/support/dispute/DisputeManager.java b/core/src/main/java/bisq/core/support/dispute/DisputeManager.java index 73ce8184a6..6bf9f738e3 100644 --- a/core/src/main/java/bisq/core/support/dispute/DisputeManager.java +++ b/core/src/main/java/bisq/core/support/dispute/DisputeManager.java @@ -715,6 +715,10 @@ public abstract class DisputeManager> extends Sup return; } + // sync and save wallet + trade.syncWallet(); + trade.saveWallet(); + // create unsigned dispute payout tx if not already published and arbitrator has trader's updated multisig info TradingPeer receiver = trade.getTradingPeer(dispute.getTraderPubKeyRing()); if (!trade.isPayoutPublished() && receiver.getUpdatedMultisigHex() != null) { @@ -726,10 +730,12 @@ public abstract class DisputeManager> extends Sup if (trade.getSeller().getUpdatedMultisigHex() != null) updatedMultisigHexes.add(trade.getSeller().getUpdatedMultisigHex()); if (!updatedMultisigHexes.isEmpty()) { multisigWallet.importMultisigHex(updatedMultisigHexes.toArray(new String[0])); // TODO (monero-project): fails if multisig hex imported individually - trade.syncWallet(); - trade.saveWallet(); } + // sync and save wallet + trade.syncWallet(); + trade.saveWallet(); + // create unsigned dispute payout tx if (!trade.isPayoutPublished()) { log.info("Arbitrator creating unsigned dispute payout tx for trade {}", trade.getId()); diff --git a/core/src/main/java/bisq/core/trade/protocol/TradingPeer.java b/core/src/main/java/bisq/core/trade/protocol/TradingPeer.java index 1ece9cc237..8ed0489468 100644 --- a/core/src/main/java/bisq/core/trade/protocol/TradingPeer.java +++ b/core/src/main/java/bisq/core/trade/protocol/TradingPeer.java @@ -135,8 +135,7 @@ public final class TradingPeer implements PersistablePayload { @Override public Message toProtoMessage() { final protobuf.TradingPeer.Builder builder = protobuf.TradingPeer.newBuilder() - .setChangeOutputValue(changeOutputValue) - .addAllReserveTxKeyImages(reserveTxKeyImages); + .setChangeOutputValue(changeOutputValue); Optional.ofNullable(nodeAddress).ifPresent(e -> builder.setNodeAddress(nodeAddress.toProtoMessage())); Optional.ofNullable(pubKeyRing).ifPresent(e -> builder.setPubKeyRing(pubKeyRing.toProtoMessage())); Optional.ofNullable(accountId).ifPresent(builder::setAccountId); @@ -160,6 +159,7 @@ public final class TradingPeer implements PersistablePayload { Optional.ofNullable(reserveTxHash).ifPresent(e -> builder.setReserveTxHash(reserveTxHash)); Optional.ofNullable(reserveTxHex).ifPresent(e -> builder.setReserveTxHex(reserveTxHex)); Optional.ofNullable(reserveTxKey).ifPresent(e -> builder.setReserveTxKey(reserveTxKey)); + Optional.ofNullable(reserveTxKeyImages).ifPresent(e -> builder.addAllReserveTxKeyImages(reserveTxKeyImages)); Optional.ofNullable(preparedMultisigHex).ifPresent(e -> builder.setPreparedMultisigHex(preparedMultisigHex)); Optional.ofNullable(madeMultisigHex).ifPresent(e -> builder.setMadeMultisigHex(madeMultisigHex)); Optional.ofNullable(exchangedMultisigHex).ifPresent(e -> builder.setExchangedMultisigHex(exchangedMultisigHex)); diff --git a/daemon/src/main/java/bisq/daemon/grpc/GrpcDisputesService.java b/daemon/src/main/java/bisq/daemon/grpc/GrpcDisputesService.java index bca73e0331..eaa7f1fd58 100644 --- a/daemon/src/main/java/bisq/daemon/grpc/GrpcDisputesService.java +++ b/daemon/src/main/java/bisq/daemon/grpc/GrpcDisputesService.java @@ -145,7 +145,7 @@ public class GrpcDisputesService extends DisputesImplBase { return getCustomRateMeteringInterceptor(coreApi.getConfig().appDataDir, this.getClass()) .or(() -> Optional.of(CallRateMeteringInterceptor.valueOf( new HashMap<>() {{ - put(getGetDisputeMethod().getFullMethodName(), new GrpcCallRateMeter(10, SECONDS)); + put(getGetDisputeMethod().getFullMethodName(), new GrpcCallRateMeter(20, SECONDS)); put(getGetDisputesMethod().getFullMethodName(), new GrpcCallRateMeter(10, SECONDS)); put(getResolveDisputeMethod().getFullMethodName(), new GrpcCallRateMeter(10, SECONDS)); put(getOpenDisputeMethod().getFullMethodName(), new GrpcCallRateMeter(10, SECONDS));