You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
wow-btc-swap/swap/src/database/alice.rs

311 lines
12 KiB

use crate::bitcoin::EncryptedSignature;
use crate::wownero;
use crate::wownero::{wownero_private_key, TransferProof};
use crate::protocol::alice;
use crate::protocol::alice::AliceState;
use wownero_rpc::wallet::BlockHeight;
use serde::{Deserialize, Serialize};
use std::fmt;
// Large enum variant is fine because this is only used for database
// and is dropped once written in DB.
#[allow(clippy::large_enum_variant)]
#[derive(Clone, Debug, Deserialize, Serialize, PartialEq)]
pub enum Alice {
Started {
state3: alice::State3,
},
BtcLockTransactionSeen {
state3: alice::State3,
},
BtcLocked {
state3: alice::State3,
},
WowLockTransactionSent {
wownero_wallet_restore_blockheight: BlockHeight,
transfer_proof: TransferProof,
state3: alice::State3,
},
WowLocked {
wownero_wallet_restore_blockheight: BlockHeight,
transfer_proof: TransferProof,
state3: alice::State3,
},
WowLockTransferProofSent {
wownero_wallet_restore_blockheight: BlockHeight,
transfer_proof: TransferProof,
state3: alice::State3,
},
EncSigLearned {
wownero_wallet_restore_blockheight: BlockHeight,
transfer_proof: TransferProof,
encrypted_signature: EncryptedSignature,
state3: alice::State3,
},
BtcRedeemTransactionPublished {
state3: alice::State3,
},
CancelTimelockExpired {
wownero_wallet_restore_blockheight: BlockHeight,
transfer_proof: TransferProof,
state3: alice::State3,
},
BtcCancelled {
wownero_wallet_restore_blockheight: BlockHeight,
transfer_proof: TransferProof,
state3: alice::State3,
},
BtcPunishable {
wownero_wallet_restore_blockheight: BlockHeight,
transfer_proof: TransferProof,
state3: alice::State3,
},
BtcRefunded {
wownero_wallet_restore_blockheight: BlockHeight,
transfer_proof: TransferProof,
state3: alice::State3,
#[serde(with = "wownero_private_key")]
spend_key: wownero::PrivateKey,
},
Done(AliceEndState),
}
#[derive(Copy, Clone, strum::Display, Debug, Deserialize, Serialize, PartialEq)]
pub enum AliceEndState {
SafelyAborted,
BtcRedeemed,
WowRefunded,
BtcPunished,
}
impl From<&AliceState> for Alice {
fn from(alice_state: &AliceState) -> Self {
match alice_state {
AliceState::Started { state3 } => Alice::Started {
state3: state3.as_ref().clone(),
},
AliceState::BtcLockTransactionSeen { state3 } => Alice::BtcLockTransactionSeen {
state3: state3.as_ref().clone(),
},
AliceState::BtcLocked { state3 } => Alice::BtcLocked {
state3: state3.as_ref().clone(),
},
AliceState::WowLockTransactionSent {
wownero_wallet_restore_blockheight,
transfer_proof,
state3,
} => Alice::WowLockTransactionSent {
wownero_wallet_restore_blockheight: *wownero_wallet_restore_blockheight,
transfer_proof: transfer_proof.clone(),
state3: state3.as_ref().clone(),
},
AliceState::WowLocked {
wownero_wallet_restore_blockheight,
transfer_proof,
state3,
} => Alice::WowLocked {
wownero_wallet_restore_blockheight: *wownero_wallet_restore_blockheight,
transfer_proof: transfer_proof.clone(),
state3: state3.as_ref().clone(),
},
AliceState::WowLockTransferProofSent {
wownero_wallet_restore_blockheight,
transfer_proof,
state3,
} => Alice::WowLockTransferProofSent {
wownero_wallet_restore_blockheight: *wownero_wallet_restore_blockheight,
transfer_proof: transfer_proof.clone(),
state3: state3.as_ref().clone(),
},
AliceState::EncSigLearned {
wownero_wallet_restore_blockheight,
transfer_proof,
state3,
encrypted_signature,
} => Alice::EncSigLearned {
wownero_wallet_restore_blockheight: *wownero_wallet_restore_blockheight,
transfer_proof: transfer_proof.clone(),
state3: state3.as_ref().clone(),
encrypted_signature: *encrypted_signature.clone(),
},
AliceState::BtcRedeemTransactionPublished { state3 } => {
Alice::BtcRedeemTransactionPublished {
state3: state3.as_ref().clone(),
}
}
AliceState::BtcRedeemed => Alice::Done(AliceEndState::BtcRedeemed),
AliceState::BtcCancelled {
wownero_wallet_restore_blockheight,
transfer_proof,
state3,
} => Alice::BtcCancelled {
wownero_wallet_restore_blockheight: *wownero_wallet_restore_blockheight,
transfer_proof: transfer_proof.clone(),
state3: state3.as_ref().clone(),
},
AliceState::BtcRefunded {
wownero_wallet_restore_blockheight,
transfer_proof,
spend_key,
state3,
} => Alice::BtcRefunded {
wownero_wallet_restore_blockheight: *wownero_wallet_restore_blockheight,
transfer_proof: transfer_proof.clone(),
spend_key: *spend_key,
state3: state3.as_ref().clone(),
},
AliceState::BtcPunishable {
wownero_wallet_restore_blockheight,
transfer_proof,
state3,
} => Alice::BtcPunishable {
wownero_wallet_restore_blockheight: *wownero_wallet_restore_blockheight,
transfer_proof: transfer_proof.clone(),
state3: state3.as_ref().clone(),
},
AliceState::WowRefunded => Alice::Done(AliceEndState::WowRefunded),
AliceState::CancelTimelockExpired {
wownero_wallet_restore_blockheight,
transfer_proof,
state3,
} => Alice::CancelTimelockExpired {
wownero_wallet_restore_blockheight: *wownero_wallet_restore_blockheight,
transfer_proof: transfer_proof.clone(),
state3: state3.as_ref().clone(),
},
AliceState::BtcPunished => Alice::Done(AliceEndState::BtcPunished),
AliceState::SafelyAborted => Alice::Done(AliceEndState::SafelyAborted),
}
}
}
impl From<Alice> for AliceState {
fn from(db_state: Alice) -> Self {
match db_state {
Alice::Started { state3 } => AliceState::Started {
state3: Box::new(state3),
},
Alice::BtcLockTransactionSeen { state3 } => AliceState::BtcLockTransactionSeen {
state3: Box::new(state3),
},
Alice::BtcLocked { state3 } => AliceState::BtcLocked {
state3: Box::new(state3),
},
Alice::WowLockTransactionSent {
wownero_wallet_restore_blockheight,
transfer_proof,
state3,
} => AliceState::WowLockTransactionSent {
wownero_wallet_restore_blockheight,
transfer_proof,
state3: Box::new(state3),
},
Alice::WowLocked {
wownero_wallet_restore_blockheight,
transfer_proof,
state3,
} => AliceState::WowLocked {
wownero_wallet_restore_blockheight,
transfer_proof,
state3: Box::new(state3),
},
Alice::WowLockTransferProofSent {
wownero_wallet_restore_blockheight,
transfer_proof,
state3,
} => AliceState::WowLockTransferProofSent {
wownero_wallet_restore_blockheight,
transfer_proof,
state3: Box::new(state3),
},
Alice::EncSigLearned {
wownero_wallet_restore_blockheight,
transfer_proof,
state3: state,
encrypted_signature,
} => AliceState::EncSigLearned {
wownero_wallet_restore_blockheight,
transfer_proof,
state3: Box::new(state),
encrypted_signature: Box::new(encrypted_signature),
},
Alice::BtcRedeemTransactionPublished { state3 } => {
AliceState::BtcRedeemTransactionPublished {
state3: Box::new(state3),
}
}
Alice::CancelTimelockExpired {
wownero_wallet_restore_blockheight,
transfer_proof,
state3,
} => AliceState::CancelTimelockExpired {
wownero_wallet_restore_blockheight,
transfer_proof,
state3: Box::new(state3),
},
Alice::BtcCancelled {
wownero_wallet_restore_blockheight,
transfer_proof,
state3,
} => AliceState::BtcCancelled {
wownero_wallet_restore_blockheight,
transfer_proof,
state3: Box::new(state3),
},
Alice::BtcPunishable {
wownero_wallet_restore_blockheight,
transfer_proof,
state3,
} => AliceState::BtcPunishable {
wownero_wallet_restore_blockheight,
transfer_proof,
state3: Box::new(state3),
},
Alice::BtcRefunded {
wownero_wallet_restore_blockheight,
transfer_proof,
spend_key,
state3,
} => AliceState::BtcRefunded {
wownero_wallet_restore_blockheight,
transfer_proof,
spend_key,
state3: Box::new(state3),
},
Alice::Done(end_state) => match end_state {
AliceEndState::SafelyAborted => AliceState::SafelyAborted,
AliceEndState::BtcRedeemed => AliceState::BtcRedeemed,
AliceEndState::WowRefunded => AliceState::WowRefunded,
AliceEndState::BtcPunished => AliceState::BtcPunished,
},
}
}
}
impl fmt::Display for Alice {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
match self {
Alice::Started { .. } => write!(f, "Started"),
Alice::BtcLockTransactionSeen { .. } => {
write!(f, "Bitcoin lock transaction in mempool")
}
Alice::BtcLocked { .. } => f.write_str("Bitcoin locked"),
Alice::WowLockTransactionSent { .. } => f.write_str("Wownero lock transaction sent"),
Alice::WowLocked { .. } => f.write_str("Wownero locked"),
Alice::WowLockTransferProofSent { .. } => {
f.write_str("Wownero lock transfer proof sent")
}
Alice::EncSigLearned { .. } => f.write_str("Encrypted signature learned"),
Alice::BtcRedeemTransactionPublished { .. } => {
f.write_str("Bitcoin redeem transaction published")
}
Alice::CancelTimelockExpired { .. } => f.write_str("Cancel timelock is expired"),
Alice::BtcCancelled { .. } => f.write_str("Bitcoin cancel transaction published"),
Alice::BtcPunishable { .. } => f.write_str("Bitcoin punishable"),
Alice::BtcRefunded { .. } => f.write_str("Wownero refundable"),
Alice::Done(end_state) => write!(f, "Done: {}", end_state),
}
}
}