Browse Source

Merge #362

362: Prefetch announcement upon proposing rollover r=thomaseizinger a=thomaseizinger

Fixes #361.


Co-authored-by: Thomas Eizinger <thomas@eizinger.io>
debug-statements
bors[bot] 3 years ago
committed by GitHub
parent
commit
c303198030
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 67
      daemon/src/taker_cfd.rs

67
daemon/src/taker_cfd.rs

@ -17,6 +17,7 @@ use futures::channel::mpsc;
use futures::{future, SinkExt}; use futures::{future, SinkExt};
use std::collections::HashMap; use std::collections::HashMap;
use std::time::SystemTime; use std::time::SystemTime;
use time::OffsetDateTime;
use tokio::sync::watch; use tokio::sync::watch;
use xtra::prelude::*; use xtra::prelude::*;
use xtra::KeepRunning; use xtra::KeepRunning;
@ -200,33 +201,6 @@ impl<O, M> Actor<O, M> {
Ok(()) Ok(())
} }
async fn handle_propose_roll_over(&mut self, order_id: OrderId) -> Result<()> {
if self.current_pending_proposals.contains_key(&order_id) {
anyhow::bail!("An update for order id {} is already in progress", order_id)
}
let proposal = RollOverProposal {
order_id,
timestamp: SystemTime::now(),
};
self.current_pending_proposals.insert(
proposal.order_id,
UpdateCfdProposal::RollOverProposal {
proposal: proposal.clone(),
direction: SettlementKind::Outgoing,
},
);
self.send_pending_update_proposals()?;
self.send_to_maker
.do_send(wire::TakerToMaker::ProposeRollOver {
order_id: proposal.order_id,
timestamp: proposal.timestamp,
})?;
Ok(())
}
async fn handle_order_rejected(&mut self, order_id: OrderId) -> Result<()> { async fn handle_order_rejected(&mut self, order_id: OrderId) -> Result<()> {
tracing::debug!(%order_id, "Order rejected"); tracing::debug!(%order_id, "Order rejected");
@ -343,6 +317,40 @@ where
} }
Ok(()) Ok(())
} }
async fn handle_propose_roll_over(&mut self, order_id: OrderId) -> Result<()> {
if self.current_pending_proposals.contains_key(&order_id) {
anyhow::bail!("An update for order id {} is already in progress", order_id)
}
let proposal = RollOverProposal {
order_id,
timestamp: SystemTime::now(),
};
self.current_pending_proposals.insert(
proposal.order_id,
UpdateCfdProposal::RollOverProposal {
proposal: proposal.clone(),
direction: SettlementKind::Outgoing,
},
);
self.send_pending_update_proposals()?;
// we are likely going to need this one
self.oracle_actor
.send(oracle::FetchAnnouncement(oracle::next_announcement_after(
OffsetDateTime::now_utc() + Order::TERM,
)?))
.await?;
self.send_to_maker
.do_send(wire::TakerToMaker::ProposeRollOver {
order_id: proposal.order_id,
timestamp: proposal.timestamp,
})?;
Ok(())
}
} }
impl<O, M> Actor<O, M> impl<O, M> Actor<O, M>
@ -610,7 +618,10 @@ impl<O: 'static, M: 'static> Handler<TakeOffer> for Actor<O, M> {
} }
#[async_trait] #[async_trait]
impl<O: 'static, M: 'static> Handler<CfdAction> for Actor<O, M> { impl<O: 'static, M: 'static> Handler<CfdAction> for Actor<O, M>
where
O: xtra::Handler<oracle::FetchAnnouncement>,
{
async fn handle(&mut self, msg: CfdAction, _ctx: &mut Context<Self>) { async fn handle(&mut self, msg: CfdAction, _ctx: &mut Context<Self>) {
use CfdAction::*; use CfdAction::*;

Loading…
Cancel
Save