@ -1,4 +1,4 @@
use crate ::model ::cfd ::{ OrderId , Role , SettlementProposals } ;
use crate ::model ::cfd ::{ OrderId , Role , SettlementKind , Settlement Proposals } ;
use crate ::model ::{ Leverage , Position , TradingPair , Usd } ;
use crate ::model ::{ Leverage , Position , TradingPair , Usd } ;
use crate ::{ bitmex_price_feed , model } ;
use crate ::{ bitmex_price_feed , model } ;
use bdk ::bitcoin ::{ Amount , SignedAmount } ;
use bdk ::bitcoin ::{ Amount , SignedAmount } ;
@ -103,12 +103,6 @@ pub struct CfdsWithAuxData {
pub settlement_proposals : SettlementProposals ,
pub settlement_proposals : SettlementProposals ,
}
}
enum SettlementProposalStatus {
Incoming ,
Outgoing ,
None ,
}
impl CfdsWithAuxData {
impl CfdsWithAuxData {
pub fn new (
pub fn new (
rx_cfds : & watch ::Receiver < Vec < model ::cfd ::Cfd > > ,
rx_cfds : & watch ::Receiver < Vec < model ::cfd ::Cfd > > ,
@ -124,20 +118,6 @@ impl CfdsWithAuxData {
let settlement_proposals = rx_settlement . borrow ( ) . clone ( ) ;
let settlement_proposals = rx_settlement . borrow ( ) . clone ( ) ;
// Test whether the correct settlement proposals were sent
match settlement_proposals {
SettlementProposals ::Incoming ( _ ) = > {
if role = = Role ::Taker {
panic ! ( "Taker should never receive incoming settlement proposals" ) ;
}
}
SettlementProposals ::Outgoing ( _ ) = > {
if role = = Role ::Maker {
panic ! ( "Maker should never receive outgoing settlement proposals" ) ;
}
}
}
CfdsWithAuxData {
CfdsWithAuxData {
cfds : rx_cfds . borrow ( ) . clone ( ) ,
cfds : rx_cfds . borrow ( ) . clone ( ) ,
current_price ,
current_price ,
@ -146,20 +126,10 @@ impl CfdsWithAuxData {
}
}
/// Check whether given CFD has any active settlement proposals
/// Check whether given CFD has any active settlement proposals
fn settlement_proposal_status ( & self , cfd : & model ::cfd ::Cfd ) -> SettlementProposalStatus {
fn settlement_proposal_status ( & self , cfd : & model ::cfd ::Cfd ) -> Option < SettlementKind > {
match & self . settlement_proposals {
self . settlement_proposals
SettlementProposals ::Incoming ( proposals ) = > {
. get ( & cfd . order . id )
if proposals . contains_key ( & cfd . order . id ) {
. map ( | ( _ , kind ) | kind . clone ( ) )
return SettlementProposalStatus ::Incoming ;
}
}
SettlementProposals ::Outgoing ( proposals ) = > {
if proposals . contains_key ( & cfd . order . id ) {
return SettlementProposalStatus ::Outgoing ;
}
}
}
SettlementProposalStatus ::None
}
}
}
}
@ -258,12 +228,12 @@ impl ToSseEvent for model::WalletInfo {
fn to_cfd_state (
fn to_cfd_state (
cfd_state : & model ::cfd ::CfdState ,
cfd_state : & model ::cfd ::CfdState ,
proposal_status : SettlementProposalStatus ,
proposal_status : Option < SettlementKind > ,
) -> CfdState {
) -> CfdState {
match proposal_status {
match proposal_status {
SettlementProposalStatus ::Incoming = > CfdState ::IncomingSettlementProposal ,
Some ( SettlementKind ::Incoming ) = > CfdState ::IncomingSettlementProposal ,
SettlementProposalStatus ::Outgoing = > CfdState ::OutgoingSettlementProposal ,
Some ( SettlementKind ::Outgoing ) = > CfdState ::OutgoingSettlementProposal ,
SettlementProposalStatus ::None = > match cfd_state {
None = > match cfd_state {
model ::cfd ::CfdState ::OutgoingOrderRequest { . . } = > CfdState ::OutgoingOrderRequest ,
model ::cfd ::CfdState ::OutgoingOrderRequest { . . } = > CfdState ::OutgoingOrderRequest ,
model ::cfd ::CfdState ::IncomingOrderRequest { . . } = > CfdState ::IncomingOrderRequest ,
model ::cfd ::CfdState ::IncomingOrderRequest { . . } = > CfdState ::IncomingOrderRequest ,
model ::cfd ::CfdState ::Accepted { . . } = > CfdState ::Accepted ,
model ::cfd ::CfdState ::Accepted { . . } = > CfdState ::Accepted ,