From 7f26119515e3d40d46da5dbc8a038cd4ccd4d68c Mon Sep 17 00:00:00 2001 From: woodser Date: Sun, 15 Jan 2023 18:15:52 -0500 Subject: [PATCH] check peer date while initializing trade instead of deposits confirmed --- .../witness/AccountAgeWitnessService.java | 16 ++++------------ .../protocol/tasks/ProcessInitTradeRequest.java | 5 +++++ .../tasks/VerifyPeersAccountAgeWitness.java | 4 ---- 3 files changed, 9 insertions(+), 16 deletions(-) diff --git a/core/src/main/java/bisq/core/account/witness/AccountAgeWitnessService.java b/core/src/main/java/bisq/core/account/witness/AccountAgeWitnessService.java index 08c9450e5c..d9d7e44cc8 100644 --- a/core/src/main/java/bisq/core/account/witness/AccountAgeWitnessService.java +++ b/core/src/main/java/bisq/core/account/witness/AccountAgeWitnessService.java @@ -526,17 +526,15 @@ public class AccountAgeWitnessService { public boolean verifyAccountAgeWitness(Trade trade, PaymentAccountPayload peersPaymentAccountPayload, - Date peersCurrentDate, PubKeyRing peersPubKeyRing, byte[] nonce, byte[] signature, ErrorMessageHandler errorMessageHandler) { - log.info("Verifying account age witness for {} {}, payment account payload hash={}, peers current date={}, nonce={}, signature={}", + log.info("Verifying account age witness for {} {}, payment account payload hash={}, nonce={}, signature={}", trade.getClass().getSimpleName(), trade.getId(), Utilities.bytesAsHexString(peersPaymentAccountPayload.getHash()), - peersCurrentDate, Utilities.bytesAsHexString(nonce), Utilities.bytesAsHexString(signature)); @@ -558,10 +556,6 @@ public class AccountAgeWitnessService { if (!isDateAfterReleaseDate(peersWitness.getDate(), RELEASE, errorMessageHandler)) return false; - // Check if peer current date is in tolerance range - if (!verifyPeersCurrentDate(peersCurrentDate, errorMessageHandler)) - return false; - final byte[] peersAccountInputDataWithSalt = Utilities.concatenateByteArrays( peersPaymentAccountPayload.getAgeWitnessInputData(), peersPaymentAccountPayload.getSalt()); byte[] hash = Hash.getSha256Ripemd160hash(Utilities.concatenateByteArrays(peersAccountInputDataWithSalt, @@ -573,8 +567,7 @@ public class AccountAgeWitnessService { return false; // Check if the peers trade limit is not less than the trade amount - if (!verifyPeersTradeLimit(trade.getOffer(), trade.getAmount(), peersWitness, peersCurrentDate, - errorMessageHandler)) { + if (!verifyPeersTradeLimit(trade.getOffer(), trade.getAmount(), peersWitness, new Date(), errorMessageHandler)) { log.error("verifyPeersTradeLimit failed: peersPaymentAccountPayload {}", peersPaymentAccountPayload); return false; } @@ -619,13 +612,12 @@ public class AccountAgeWitnessService { return result; } - private boolean verifyPeersCurrentDate(Date peersCurrentDate, ErrorMessageHandler errorMessageHandler) { + public boolean verifyPeersCurrentDate(Date peersCurrentDate) { boolean result = Math.abs(peersCurrentDate.getTime() - new Date().getTime()) <= TimeUnit.DAYS.toMillis(1); if (!result) { String msg = "Peers current date is further than 1 day off to our current date. " + "PeersCurrentDate=" + peersCurrentDate + "; myCurrentDate=" + new Date(); - log.warn(msg); - errorMessageHandler.handleErrorMessage(msg); + throw new RuntimeException(msg); } return result; } diff --git a/core/src/main/java/bisq/core/trade/protocol/tasks/ProcessInitTradeRequest.java b/core/src/main/java/bisq/core/trade/protocol/tasks/ProcessInitTradeRequest.java index d9e734558c..65cffcd73f 100644 --- a/core/src/main/java/bisq/core/trade/protocol/tasks/ProcessInitTradeRequest.java +++ b/core/src/main/java/bisq/core/trade/protocol/tasks/ProcessInitTradeRequest.java @@ -38,6 +38,8 @@ import static bisq.core.util.Validator.nonEmptyStringOf; import static com.google.common.base.Preconditions.checkArgument; import static com.google.common.base.Preconditions.checkNotNull; +import java.util.Date; + @Slf4j public class ProcessInitTradeRequest extends TradeTask { @SuppressWarnings({"unused"}) @@ -128,6 +130,9 @@ public class ProcessInitTradeRequest extends TradeTask { multisigParticipant.setAccountAgeWitnessSignature(request.getAccountAgeWitnessSignatureOfOfferId()); multisigParticipant.setCurrentDate(request.getCurrentDate()); + // check peer's current date + processModel.getAccountAgeWitnessService().verifyPeersCurrentDate(new Date(multisigParticipant.getCurrentDate())); + // check trade amount checkArgument(request.getTradeAmount() > 0); trade.setAmount(Coin.valueOf(request.getTradeAmount())); diff --git a/core/src/main/java/bisq/core/trade/protocol/tasks/VerifyPeersAccountAgeWitness.java b/core/src/main/java/bisq/core/trade/protocol/tasks/VerifyPeersAccountAgeWitness.java index 12a57ca121..12710fdab0 100644 --- a/core/src/main/java/bisq/core/trade/protocol/tasks/VerifyPeersAccountAgeWitness.java +++ b/core/src/main/java/bisq/core/trade/protocol/tasks/VerifyPeersAccountAgeWitness.java @@ -74,12 +74,8 @@ public class VerifyPeersAccountAgeWitness extends TradeTask { byte[] nonce = checkNotNull(tradingPeer.getAccountAgeWitnessNonce()); byte[] signature = checkNotNull(tradingPeer.getAccountAgeWitnessSignature()); AtomicReference errorMsg = new AtomicReference<>(); - long currentDateAsLong = tradingPeer.getCurrentDate(); - // In case the peer has an older version we get 0, so we use our time instead - Date peersCurrentDate = currentDateAsLong > 0 ? new Date(currentDateAsLong) : new Date(); boolean isValid = accountAgeWitnessService.verifyAccountAgeWitness(trade, peersPaymentAccountPayload, - peersCurrentDate, peersPubKeyRing, nonce, signature,