Browse Source

Merge pull request #197 from comit-network/handle-mutates-state

Transition cfd to new state when handling an event
upload-correct-windows-binary
Daniel Karzel 3 years ago
committed by GitHub
parent
commit
abf1f683e0
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 6
      daemon/src/maker_cfd.rs
  2. 4
      daemon/src/model/cfd.rs
  3. 4
      daemon/src/taker_cfd.rs

6
daemon/src/maker_cfd.rs

@ -411,7 +411,7 @@ impl Actor {
async fn handle_commit(&mut self, order_id: OrderId) -> Result<()> { async fn handle_commit(&mut self, order_id: OrderId) -> Result<()> {
let mut conn = self.db.acquire().await?; let mut conn = self.db.acquire().await?;
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 signed_commit_tx = cfd.commit_tx()?; let signed_commit_tx = cfd.commit_tx()?;
@ -435,12 +435,10 @@ impl Actor {
let order_id = event.order_id(); let order_id = event.order_id();
let mut conn = self.db.acquire().await?; let mut conn = self.db.acquire().await?;
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 new_state = cfd.handle(CfdStateChangeEvent::Monitor(event))?; let new_state = cfd.handle(CfdStateChangeEvent::Monitor(event))?;
insert_new_cfd_state_by_order_id(order_id, new_state.clone(), &mut conn).await?; insert_new_cfd_state_by_order_id(order_id, new_state.clone(), &mut conn).await?;
self.cfd_feed_actor_inbox self.cfd_feed_actor_inbox
.send(load_all_cfds(&mut conn).await?)?; .send(load_all_cfds(&mut conn).await?)?;

4
daemon/src/model/cfd.rs

@ -449,7 +449,7 @@ impl Cfd {
#[allow(dead_code)] #[allow(dead_code)]
pub const CET_TIMELOCK: u32 = 12; pub const CET_TIMELOCK: u32 = 12;
pub fn handle(&self, event: CfdStateChangeEvent) -> Result<CfdState> { pub fn handle(&mut self, event: CfdStateChangeEvent) -> Result<CfdState> {
use CfdState::*; use CfdState::*;
// TODO: Display impl // TODO: Display impl
@ -591,6 +591,8 @@ impl Cfd {
} }
}; };
self.state = new_state.clone();
Ok(new_state) Ok(new_state)
} }

4
daemon/src/taker_cfd.rs

@ -311,7 +311,7 @@ impl Actor {
let order_id = event.order_id(); let order_id = event.order_id();
let mut conn = self.db.acquire().await?; let mut conn = self.db.acquire().await?;
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 new_state = cfd.handle(CfdStateChangeEvent::Monitor(event))?; let new_state = cfd.handle(CfdStateChangeEvent::Monitor(event))?;
@ -339,7 +339,7 @@ impl Actor {
// TODO: Duplicated with maker // TODO: Duplicated with maker
async fn handle_commit(&mut self, order_id: OrderId) -> Result<()> { async fn handle_commit(&mut self, order_id: OrderId) -> Result<()> {
let mut conn = self.db.acquire().await?; let mut conn = self.db.acquire().await?;
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 signed_commit_tx = cfd.commit_tx()?; let signed_commit_tx = cfd.commit_tx()?;

Loading…
Cancel
Save