@ -1,4 +1,4 @@
use crate ::cfd_actors ::{ self , insert_cfd , insert_new_ cfd_state_by_order_i d } ;
use crate ::cfd_actors ::{ self , append_cfd_state , insert_cfd } ;
use crate ::db ::{ insert_order , load_cfd_by_order_id , load_order_by_id } ;
use crate ::db ::{ insert_order , load_cfd_by_order_id , load_order_by_id } ;
use crate ::maker_inc_connections ::TakerCommand ;
use crate ::maker_inc_connections ::TakerCommand ;
use crate ::model ::cfd ::{
use crate ::model ::cfd ::{
@ -292,13 +292,7 @@ impl Actor {
proposal . price ,
proposal . price ,
) ,
) ,
) ) ? ;
) ) ? ;
insert_new_cfd_state_by_order_id (
append_cfd_state ( & cfd , & mut conn , & self . cfd_feed_actor_inbox ) . await ? ;
cfd . order . id ,
& cfd . state ,
& mut conn ,
& self . cfd_feed_actor_inbox ,
)
. await ? ;
let spend_tx = dlc . finalize_spend_transaction ( ( tx , sig_maker ) , sig_taker ) ? ;
let spend_tx = dlc . finalize_spend_transaction ( ( tx , sig_maker ) , sig_taker ) ? ;
@ -405,19 +399,16 @@ impl Actor {
let mut conn = self . db . acquire ( ) . await ? ;
let mut conn = self . db . acquire ( ) . await ? ;
insert_new_cfd_state_by_order_id (
let mut cfd = load_cfd_by_order_id ( order_id , & mut conn ) . await ? ;
order_id ,
cfd . state = CfdState ::PendingOpen {
& CfdState ::PendingOpen {
common : CfdStateCommon {
common : CfdStateCommon {
transition_timestamp : SystemTime ::now ( ) ,
transition_timestamp : SystemTime ::now ( ) ,
} ,
dlc : dlc . clone ( ) ,
attestation : None ,
} ,
} ,
& mut conn ,
dlc : dlc . clone ( ) ,
& self . cfd_feed_actor_inbox ,
attestation : None ,
)
} ;
. await ? ;
append_cfd_state ( & cfd , & mut conn , & self . cfd_feed_actor_inbox ) . await ? ;
let txid = self
let txid = self
. wallet
. wallet
@ -426,8 +417,6 @@ impl Actor {
tracing ::info ! ( "Lock transaction published with txid {}" , txid ) ;
tracing ::info ! ( "Lock transaction published with txid {}" , txid ) ;
let cfd = load_cfd_by_order_id ( order_id , & mut conn ) . await ? ;
self . monitor_actor
self . monitor_actor
. do_send_async ( monitor ::StartMonitoring {
. do_send_async ( monitor ::StartMonitoring {
id : order_id ,
id : order_id ,
@ -453,22 +442,17 @@ impl Actor {
self . roll_over_state = RollOverState ::None ;
self . roll_over_state = RollOverState ::None ;
let mut conn = self . db . acquire ( ) . await ? ;
let mut conn = self . db . acquire ( ) . await ? ;
insert_new_cfd_state_by_order_id (
let mut cfd = load_cfd_by_order_id ( order_id , & mut conn ) . await ? ;
order_id ,
cfd . state = CfdState ::Open {
& CfdState ::Open {
common : CfdStateCommon {
common : CfdStateCommon {
transition_timestamp : SystemTime ::now ( ) ,
transition_timestamp : SystemTime ::now ( ) ,
} ,
dlc : dlc . clone ( ) ,
attestation : None ,
collaborative_close : None ,
} ,
} ,
& mut conn ,
dlc : dlc . clone ( ) ,
& self . cfd_feed_actor_inbox ,
attestation : None ,
)
collaborative_close : None ,
. await ? ;
} ;
let cfd = load_cfd_by_order_id ( order_id , & mut conn ) . await ? ;
append_cfd_state ( & cfd , & mut conn , & self . cfd_feed_actor_inbox ) . await ? ;
self . monitor_actor
self . monitor_actor
. do_send_async ( monitor ::StartMonitoring {
. do_send_async ( monitor ::StartMonitoring {
@ -513,20 +497,7 @@ impl Actor {
}
}
} ;
} ;
// 2. check if order has acceptable amounts
// 2. Create a new CFD
if quantity < current_order . min_quantity | | quantity > current_order . max_quantity {
tracing ::warn ! (
"Order rejected because quantity {} was out of bounds. It was either <{} or >{}" ,
quantity ,
current_order . min_quantity ,
current_order . max_quantity
) ;
self . reject_order ( taker_id , order_id , conn ) . await ? ;
return Ok ( ( ) ) ;
}
// 3. Insert CFD in DB
let cfd = Cfd ::new (
let cfd = Cfd ::new (
current_order . clone ( ) ,
current_order . clone ( ) ,
quantity ,
quantity ,
@ -537,7 +508,20 @@ impl Actor {
taker_id ,
taker_id ,
} ,
} ,
) ;
) ;
insert_cfd ( cfd , & mut conn , & self . cfd_feed_actor_inbox ) . await ? ;
insert_cfd ( & cfd , & mut conn , & self . cfd_feed_actor_inbox ) . await ? ;
// 3. check if order has acceptable amounts
if quantity < current_order . min_quantity | | quantity > current_order . max_quantity {
tracing ::warn ! (
"Order rejected because quantity {} was out of bounds. It was either <{} or >{}" ,
quantity ,
current_order . min_quantity ,
current_order . max_quantity
) ;
self . reject_order ( taker_id , cfd , conn ) . await ? ;
return Ok ( ( ) ) ;
}
// 4. Remove current order
// 4. Remove current order
self . current_order_id = None ;
self . current_order_id = None ;
@ -563,7 +547,7 @@ impl Actor {
let mut conn = self . db . acquire ( ) . await ? ;
let mut conn = self . db . acquire ( ) . await ? ;
// 1. Validate if order is still valid
// 1. Validate if order is still valid
let cfd = load_cfd_by_order_id ( order_id , & mut conn ) . await ? ;
let mut cfd = load_cfd_by_order_id ( order_id , & mut conn ) . await ? ;
let taker_id = match cfd {
let taker_id = match cfd {
Cfd {
Cfd {
state : CfdState ::IncomingOrderRequest { taker_id , . . } ,
state : CfdState ::IncomingOrderRequest { taker_id , . . } ,
@ -583,17 +567,13 @@ impl Actor {
. with_context ( | | format ! ( "Announcement {} not found" , cfd . order . oracle_event_id ) ) ? ;
. with_context ( | | format ! ( "Announcement {} not found" , cfd . order . oracle_event_id ) ) ? ;
// 3. Insert that we are in contract setup and refresh our own feed
// 3. Insert that we are in contract setup and refresh our own feed
insert_new_cfd_state_by_order_id (
cfd . state = CfdState ::ContractSetup {
order_id ,
common : CfdStateCommon {
& CfdState ::ContractSetup {
transition_timestamp : SystemTime ::now ( ) ,
common : CfdStateCommon {
transition_timestamp : SystemTime ::now ( ) ,
} ,
} ,
} ,
& mut conn ,
} ;
& self . cfd_feed_actor_inbox ,
)
append_cfd_state ( & cfd , & mut conn , & self . cfd_feed_actor_inbox ) . await ? ;
. await ? ;
// 4. Notify the taker that we are ready for contract setup
// 4. Notify the taker that we are ready for contract setup
// Use `.send` here to ensure we only continue once the message has been sent
// Use `.send` here to ensure we only continue once the message has been sent
@ -658,7 +638,7 @@ impl Actor {
}
}
} ;
} ;
self . reject_order ( taker_id , order_i d, conn ) . await ? ;
self . reject_order ( taker_id , cf d, conn ) . await ? ;
Ok ( ( ) )
Ok ( ( ) )
}
}
@ -671,26 +651,22 @@ impl Actor {
async fn reject_order (
async fn reject_order (
& mut self ,
& mut self ,
taker_id : TakerId ,
taker_id : TakerId ,
order_id : OrderI d,
mut cfd : Cf d,
mut conn : PoolConnection < Sqlite > ,
mut conn : PoolConnection < Sqlite > ,
) -> Result < ( ) > {
) -> Result < ( ) > {
// Update order in db
// Update order in db
insert_new_cfd_state_by_order_id (
cfd . state = CfdState ::Rejected {
order_id ,
common : CfdStateCommon {
& CfdState ::Rejected {
transition_timestamp : SystemTime ::now ( ) ,
common : CfdStateCommon {
transition_timestamp : SystemTime ::now ( ) ,
} ,
} ,
} ,
& mut conn ,
} ;
& self . cfd_feed_actor_inbox ,
)
append_cfd_state ( & cfd , & mut conn , & self . cfd_feed_actor_inbox ) . await ? ;
. await ? ;
self . takers
self . takers
. do_send_async ( maker_inc_connections ::TakerMessage {
. do_send_async ( maker_inc_connections ::TakerMessage {
taker_id ,
taker_id ,
command : TakerCommand ::NotifyOrderRejected { id : order_ id } ,
command : TakerCommand ::NotifyOrderRejected { id : cfd . order . id } ,
} )
} )
. await ? ;
. await ? ;