From 15b8be7838d46d70f496a6dd2ba5be7eb3b7d20a Mon Sep 17 00:00:00 2001 From: binarybaron <86064887+binarybaron@users.noreply.github.com> Date: Thu, 12 May 2022 20:19:13 +0200 Subject: [PATCH] Allow cancel, refund for swap that are in `SwapSetupCompleted` state --- swap/src/cli/cancel.rs | 2 +- swap/src/cli/refund.rs | 2 +- swap/src/protocol/bob/state.rs | 16 ++++++++++++++++ 3 files changed, 18 insertions(+), 2 deletions(-) diff --git a/swap/src/cli/cancel.rs b/swap/src/cli/cancel.rs index a451c1f0..cabc21fb 100644 --- a/swap/src/cli/cancel.rs +++ b/swap/src/cli/cancel.rs @@ -14,6 +14,7 @@ pub async fn cancel( let state = db.get_state(swap_id).await?.try_into()?; let state6 = match state { + BobState::SwapSetupCompleted(state2) => state2.cancel(), BobState::BtcLocked { state3, .. } => state3.cancel(), BobState::XmrLockProofReceived { state, .. } => state.cancel(), BobState::XmrLocked(state4) => state4.cancel(), @@ -23,7 +24,6 @@ pub async fn cancel( BobState::BtcCancelled(state6) => state6, BobState::Started { .. } - | BobState::SwapSetupCompleted(_) | BobState::BtcRedeemed(_) | BobState::XmrRedeemed { .. } | BobState::BtcPunished { .. } diff --git a/swap/src/cli/refund.rs b/swap/src/cli/refund.rs index 9778c99e..1c363165 100644 --- a/swap/src/cli/refund.rs +++ b/swap/src/cli/refund.rs @@ -14,6 +14,7 @@ pub async fn refund( let state = db.get_state(swap_id).await?.try_into()?; let state6 = match state { + BobState::SwapSetupCompleted(state2) => state2.cancel(), BobState::BtcLocked { state3, .. } => state3.cancel(), BobState::XmrLockProofReceived { state, .. } => state.cancel(), BobState::XmrLocked(state4) => state4.cancel(), @@ -21,7 +22,6 @@ pub async fn refund( BobState::CancelTimelockExpired(state6) => state6, BobState::BtcCancelled(state6) => state6, BobState::Started { .. } - | BobState::SwapSetupCompleted(_) | BobState::BtcRedeemed(_) | BobState::BtcRefunded(_) | BobState::XmrRedeemed { .. } diff --git a/swap/src/protocol/bob/state.rs b/swap/src/protocol/bob/state.rs index 90e5f9f8..db0e6b85 100644 --- a/swap/src/protocol/bob/state.rs +++ b/swap/src/protocol/bob/state.rs @@ -331,6 +331,22 @@ impl State2 { } } + pub fn cancel(&self) -> State6 { + State6 { + A: self.A, + b: self.b.clone(), + s_b: self.s_b, + cancel_timelock: self.cancel_timelock, + punish_timelock: self.punish_timelock, + refund_address: self.refund_address.clone(), + tx_lock: self.tx_lock.clone(), + tx_cancel_sig_a: self.tx_cancel_sig_a.clone(), + tx_refund_encsig: self.tx_refund_encsig.clone(), + tx_refund_fee: self.tx_refund_fee, + tx_cancel_fee: self.tx_cancel_fee, + } + } + pub async fn lock_btc(self) -> Result<(State3, TxLock)> { Ok(( State3 {