Browse Source

Bundle all settlement related messages in a individual enums

Once these messages are handled by dedicated actors, this will reduce
the amount to runtime errors a la "this message should be handled by
someone else".

See #696.
no-buy-button-while-setting-up-cfd
Thomas Eizinger 3 years ago
parent
commit
a07453ec8e
No known key found for this signature in database GPG Key ID: 651AC83A6C6C8B96
  1. 19
      daemon/src/maker_cfd.rs
  2. 18
      daemon/src/taker_cfd.rs
  3. 53
      daemon/src/wire.rs

19
daemon/src/maker_cfd.rs

@ -634,7 +634,10 @@ where
.takers .takers
.send(maker_inc_connections::TakerMessage { .send(maker_inc_connections::TakerMessage {
taker_id, taker_id,
msg: wire::MakerToTaker::ConfirmSettlement(order_id), msg: wire::MakerToTaker::Settlement {
order_id,
msg: wire::maker_to_taker::Settlement::Confirm,
},
}) })
.await? .await?
{ {
@ -672,7 +675,10 @@ where
self.takers self.takers
.send(maker_inc_connections::TakerMessage { .send(maker_inc_connections::TakerMessage {
taker_id, taker_id,
msg: wire::MakerToTaker::RejectSettlement(order_id), msg: wire::MakerToTaker::Settlement {
order_id,
msg: wire::maker_to_taker::Settlement::Reject,
},
}) })
.await??; .await??;
@ -1123,12 +1129,15 @@ where
wire::TakerToMaker::TakeOrder { order_id, quantity } => { wire::TakerToMaker::TakeOrder { order_id, quantity } => {
log_error!(self.handle_take_order(taker_id, order_id, quantity)) log_error!(self.handle_take_order(taker_id, order_id, quantity))
} }
wire::TakerToMaker::ProposeSettlement { wire::TakerToMaker::Settlement {
order_id, order_id,
msg:
wire::taker_to_maker::Settlement::Propose {
timestamp, timestamp,
taker, taker,
maker, maker,
price, price,
},
} => { } => {
log_error!(self.handle_propose_settlement( log_error!(self.handle_propose_settlement(
taker_id, taker_id,
@ -1141,9 +1150,9 @@ where
} }
)) ))
} }
wire::TakerToMaker::InitiateSettlement { wire::TakerToMaker::Settlement {
order_id, order_id,
sig_taker, msg: wire::taker_to_maker::Settlement::Initiate { sig_taker },
} => { } => {
log_error!(self.handle_initiate_settlement(taker_id, order_id, sig_taker)) log_error!(self.handle_initiate_settlement(taker_id, order_id, sig_taker))
} }

18
daemon/src/taker_cfd.rs

@ -243,12 +243,14 @@ impl<O, M, W> Actor<O, M, W> {
.await?; .await?;
self.conn_actor self.conn_actor
.send(wire::TakerToMaker::ProposeSettlement { .send(wire::TakerToMaker::Settlement {
order_id: proposal.order_id, order_id: proposal.order_id,
msg: wire::taker_to_maker::Settlement::Propose {
timestamp: proposal.timestamp, timestamp: proposal.timestamp,
taker: proposal.taker, taker: proposal.taker,
maker: proposal.maker, maker: proposal.maker,
price: proposal.price, price: proposal.price,
},
}) })
.await?; .await?;
Ok(()) Ok(())
@ -654,9 +656,9 @@ where
// deadlock otherwise. // deadlock otherwise.
#[allow(clippy::disallowed_method)] #[allow(clippy::disallowed_method)]
self.conn_actor self.conn_actor
.do_send_async(wire::TakerToMaker::InitiateSettlement { .do_send_async(wire::TakerToMaker::Settlement {
order_id, order_id,
sig_taker, msg: wire::taker_to_maker::Settlement::Initiate { sig_taker },
}) })
.await?; .await?;
@ -708,10 +710,16 @@ where
wire::MakerToTaker::CurrentOrder(current_order) => { wire::MakerToTaker::CurrentOrder(current_order) => {
log_error!(self.handle_new_order(current_order)) log_error!(self.handle_new_order(current_order))
} }
wire::MakerToTaker::ConfirmSettlement(order_id) => { wire::MakerToTaker::Settlement {
order_id,
msg: wire::maker_to_taker::Settlement::Confirm,
} => {
log_error!(self.handle_settlement_accepted(order_id, ctx)) log_error!(self.handle_settlement_accepted(order_id, ctx))
} }
wire::MakerToTaker::RejectSettlement(order_id) => { wire::MakerToTaker::Settlement {
order_id,
msg: wire::maker_to_taker::Settlement::Reject,
} => {
log_error!(self.handle_settlement_rejected(order_id)) log_error!(self.handle_settlement_rejected(order_id))
} }
wire::MakerToTaker::ConfirmRollOver { wire::MakerToTaker::ConfirmRollOver {

53
daemon/src/wire.rs

@ -18,16 +18,14 @@ use std::ops::RangeInclusive;
use std::sync::{Arc, Mutex}; use std::sync::{Arc, Mutex};
use tokio_util::codec::{Decoder, Encoder, LengthDelimitedCodec}; use tokio_util::codec::{Decoder, Encoder, LengthDelimitedCodec};
pub mod taker_to_maker {
use super::*;
#[derive(Debug, Serialize, Deserialize)] #[derive(Debug, Serialize, Deserialize)]
#[serde(tag = "type", content = "payload")] #[serde(tag = "type", content = "payload")]
#[allow(clippy::large_enum_variant)] #[allow(clippy::large_enum_variant)]
pub enum TakerToMaker { pub enum Settlement {
TakeOrder { Propose {
order_id: OrderId,
quantity: Usd,
},
ProposeSettlement {
order_id: OrderId,
timestamp: Timestamp, timestamp: Timestamp,
#[serde(with = "::bdk::bitcoin::util::amount::serde::as_btc")] #[serde(with = "::bdk::bitcoin::util::amount::serde::as_btc")]
taker: Amount, taker: Amount,
@ -35,10 +33,20 @@ pub enum TakerToMaker {
maker: Amount, maker: Amount,
price: Price, price: Price,
}, },
InitiateSettlement { Initiate {
order_id: OrderId,
sig_taker: Signature, sig_taker: Signature,
}, },
}
}
#[derive(Debug, Serialize, Deserialize)]
#[serde(tag = "type", content = "payload")]
#[allow(clippy::large_enum_variant)]
pub enum TakerToMaker {
TakeOrder {
order_id: OrderId,
quantity: Usd,
},
ProposeRollOver { ProposeRollOver {
order_id: OrderId, order_id: OrderId,
timestamp: Timestamp, timestamp: Timestamp,
@ -48,17 +56,20 @@ pub enum TakerToMaker {
msg: SetupMsg, msg: SetupMsg,
}, },
RollOverProtocol(RollOverMsg), RollOverProtocol(RollOverMsg),
Settlement {
order_id: OrderId,
msg: taker_to_maker::Settlement,
},
} }
impl fmt::Display for TakerToMaker { impl fmt::Display for TakerToMaker {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
match self { match self {
TakerToMaker::TakeOrder { .. } => write!(f, "TakeOrder"), TakerToMaker::TakeOrder { .. } => write!(f, "TakeOrder"),
TakerToMaker::ProposeSettlement { .. } => write!(f, "ProposeSettlement"),
TakerToMaker::InitiateSettlement { .. } => write!(f, "InitiateSettlement"),
TakerToMaker::Protocol { .. } => write!(f, "Protocol"), TakerToMaker::Protocol { .. } => write!(f, "Protocol"),
TakerToMaker::ProposeRollOver { .. } => write!(f, "ProposeRollOver"), TakerToMaker::ProposeRollOver { .. } => write!(f, "ProposeRollOver"),
TakerToMaker::RollOverProtocol(_) => write!(f, "RollOverProtocol"), TakerToMaker::RollOverProtocol(_) => write!(f, "RollOverProtocol"),
TakerToMaker::Settlement { .. } => write!(f, "Settlement"),
} }
} }
} }
@ -72,8 +83,6 @@ pub enum MakerToTaker {
CurrentOrder(Option<Order>), CurrentOrder(Option<Order>),
ConfirmOrder(OrderId), // TODO: Include payout curve in "accept" message from maker ConfirmOrder(OrderId), // TODO: Include payout curve in "accept" message from maker
RejectOrder(OrderId), RejectOrder(OrderId),
ConfirmSettlement(OrderId),
RejectSettlement(OrderId),
InvalidOrderId(OrderId), InvalidOrderId(OrderId),
Protocol { Protocol {
order_id: OrderId, order_id: OrderId,
@ -85,6 +94,21 @@ pub enum MakerToTaker {
oracle_event_id: BitMexPriceEventId, oracle_event_id: BitMexPriceEventId,
}, },
RejectRollOver(OrderId), RejectRollOver(OrderId),
Settlement {
order_id: OrderId,
msg: maker_to_taker::Settlement,
},
}
pub mod maker_to_taker {
use super::*;
#[derive(Debug, Serialize, Deserialize)]
#[serde(tag = "type", content = "payload")]
pub enum Settlement {
Confirm,
Reject,
}
} }
impl fmt::Display for MakerToTaker { impl fmt::Display for MakerToTaker {
@ -94,13 +118,12 @@ impl fmt::Display for MakerToTaker {
MakerToTaker::CurrentOrder(_) => write!(f, "CurrentOrder"), MakerToTaker::CurrentOrder(_) => write!(f, "CurrentOrder"),
MakerToTaker::ConfirmOrder(_) => write!(f, "ConfirmOrder"), MakerToTaker::ConfirmOrder(_) => write!(f, "ConfirmOrder"),
MakerToTaker::RejectOrder(_) => write!(f, "RejectOrder"), MakerToTaker::RejectOrder(_) => write!(f, "RejectOrder"),
MakerToTaker::ConfirmSettlement(_) => write!(f, "ConfirmSettlement"),
MakerToTaker::RejectSettlement(_) => write!(f, "RejectSettlement"),
MakerToTaker::InvalidOrderId(_) => write!(f, "InvalidOrderId"), MakerToTaker::InvalidOrderId(_) => write!(f, "InvalidOrderId"),
MakerToTaker::Protocol { .. } => write!(f, "Protocol"), MakerToTaker::Protocol { .. } => write!(f, "Protocol"),
MakerToTaker::ConfirmRollOver { .. } => write!(f, "ConfirmRollOver"), MakerToTaker::ConfirmRollOver { .. } => write!(f, "ConfirmRollOver"),
MakerToTaker::RejectRollOver(_) => write!(f, "RejectRollOver"), MakerToTaker::RejectRollOver(_) => write!(f, "RejectRollOver"),
MakerToTaker::RollOverProtocol(_) => write!(f, "RollOverProtocol"), MakerToTaker::RollOverProtocol(_) => write!(f, "RollOverProtocol"),
MakerToTaker::Settlement { .. } => write!(f, "Settlement"),
} }
} }
} }

Loading…
Cancel
Save