From 9ac64e5e3e0062ae1268068d3df9eb82e59cdf50 Mon Sep 17 00:00:00 2001 From: chimp1984 Date: Sun, 1 Dec 2019 19:23:45 -0500 Subject: [PATCH] Add handling of mediationResultState to isFundsLockedIn Fixes https://github.com/bisq-network/bisq/issues/3721 (part of the problem was that the trade ended up in failed trade) Refactor method and add comments. We did not handle the case of a mediated payout. isPayoutPublished() is only reflecting non-disputed trade payouts. --- core/src/main/java/bisq/core/trade/Trade.java | 37 ++++++++++++++++--- 1 file changed, 31 insertions(+), 6 deletions(-) diff --git a/core/src/main/java/bisq/core/trade/Trade.java b/core/src/main/java/bisq/core/trade/Trade.java index f9a6b89d904..f1d9cbf9ff9 100644 --- a/core/src/main/java/bisq/core/trade/Trade.java +++ b/core/src/main/java/bisq/core/trade/Trade.java @@ -911,12 +911,37 @@ public boolean isDepositPublished() { } public boolean isFundsLockedIn() { - return isDepositPublished() && - !isPayoutPublished() && - disputeState != DisputeState.DISPUTE_CLOSED && - disputeState != DisputeState.REFUND_REQUESTED && - disputeState != DisputeState.REFUND_REQUEST_STARTED_BY_PEER && - disputeState != DisputeState.REFUND_REQUEST_CLOSED; + // If no deposit tx was published we have no funds locked in + if (!isDepositPublished()) { + return false; + } + + // If we have the payout tx published (non disputed case) we have no funds locked in. Here we might have more + // complex cases where users open a mediation but continue the trade to finalize it without mediated payout. + // The trade state handles that but does not handle mediated payouts or refund agents payouts. + if (isPayoutPublished()) { + return false; + } + + // Legacy arbitration is not handled anymore as not used anymore. + + // In mediation case we check for the mediationResultState. As there are multiple sub-states we use ordinal. + if (disputeState == DisputeState.MEDIATION_CLOSED) { + if (mediationResultState != null && + mediationResultState.ordinal() >= MediationResultState.PAYOUT_TX_PUBLISHED.ordinal()) { + return false; + } + } + + // In refund agent case the funds are spent anyway with the time locked payout. We do not consider that as + // locked in funds. + if (disputeState == DisputeState.REFUND_REQUESTED || + disputeState == DisputeState.REFUND_REQUEST_STARTED_BY_PEER || + disputeState == DisputeState.REFUND_REQUEST_CLOSED) { + return false; + } + + return true; } public boolean isDepositConfirmed() {