From a95b218aaf318070ae06db9c61faa670d421ffc1 Mon Sep 17 00:00:00 2001 From: Daniel Karzel Date: Thu, 11 Nov 2021 17:04:29 +1100 Subject: [PATCH] Taker handles order received from maker already known In case we already have a cfd for the received order we bail, because that should not happen. If we already know the order, but don't have a related cfd we don't insert but still send it out on the order feed. --- daemon/src/taker_cfd.rs | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/daemon/src/taker_cfd.rs b/daemon/src/taker_cfd.rs index fc846fd..3dd89b7 100644 --- a/daemon/src/taker_cfd.rs +++ b/daemon/src/taker_cfd.rs @@ -9,7 +9,7 @@ use crate::model::{BitMexPriceEventId, Price, Timestamp, Usd}; use crate::monitor::{self, MonitorParams}; use crate::wire::{MakerToTaker, RollOverMsg, SetupMsg}; use crate::{log_error, oracle, setup_contract, wallet, wire}; -use anyhow::{Context as _, Result}; +use anyhow::{bail, Context as _, Result}; use async_trait::async_trait; use bdk::bitcoin::secp256k1::schnorrsig; use futures::channel::mpsc; @@ -305,7 +305,16 @@ impl Actor { order.origin = Origin::Theirs; let mut conn = self.db.acquire().await?; - insert_order(&order, &mut conn).await?; + + if load_cfd_by_order_id(order.id, &mut conn).await.is_ok() { + bail!("Received order {} from maker, but already have a cfd in the database for that order. The maker did not properly remove the order.", order.id) + } + + if load_order_by_id(order.id, &mut conn).await.is_err() { + // only insert the order if we don't know it yet + insert_order(&order, &mut conn).await?; + } + self.order_feed_actor_inbox.send(Some(order))?; } None => {