Browse Source

Move settlement oracle event id into the Dlc

Oracle event-id and Dlc have to exist together, one without the other is incomplete, hence we move the event id inside.
Note that the ID is actually already know  to the Dlc as part of the `cet` hashmap, but this was not cleaned up in this patch.

This patch goes towards getting the model boundaries right to transition the architecture towards an event model.
debug-collab-settlement
Daniel Karzel 3 years ago
parent
commit
b4b5cd7f57
No known key found for this signature in database GPG Key ID: 30C3FC2E438ADB6E
  1. 26
      daemon/src/maker_cfd.rs
  2. 10
      daemon/src/model/cfd.rs
  3. 14
      daemon/src/monitor.rs
  4. 12
      daemon/src/oracle.rs
  5. 3
      daemon/src/setup_contract.rs
  6. 32
      daemon/src/taker_cfd.rs
  7. 5
      daemon/src/to_sse_event.rs

26
daemon/src/maker_cfd.rs

@ -693,17 +693,13 @@ where
self.monitor_actor self.monitor_actor
.send(monitor::StartMonitoring { .send(monitor::StartMonitoring {
id: order_id, id: order_id,
params: MonitorParams::new( params: MonitorParams::new(dlc.clone(), cfd.refund_timelock_in_blocks()),
dlc,
cfd.refund_timelock_in_blocks(),
cfd.order.oracle_event_id,
),
}) })
.await?; .await?;
self.oracle_actor self.oracle_actor
.send(oracle::MonitorAttestation { .send(oracle::MonitorAttestation {
event_id: cfd.order.oracle_event_id, event_id: dlc.settlement_event_id,
}) })
.await?; .await?;
@ -818,8 +814,9 @@ where
impl<O, M, T, W> Actor<O, M, T, W> impl<O, M, T, W> Actor<O, M, T, W>
where where
M: xtra::Handler<monitor::StartMonitoring>, M: xtra::Handler<monitor::StartMonitoring>,
O: xtra::Handler<oracle::MonitorAttestation>,
{ {
async fn handle_cfd_roll_over_completed( async fn handle_roll_over_completed(
&mut self, &mut self,
order_id: OrderId, order_id: OrderId,
dlc: Result<Dlc>, dlc: Result<Dlc>,
@ -840,11 +837,13 @@ where
self.monitor_actor self.monitor_actor
.send(monitor::StartMonitoring { .send(monitor::StartMonitoring {
id: order_id, id: order_id,
params: MonitorParams::new( params: MonitorParams::new(dlc.clone(), cfd.refund_timelock_in_blocks()),
dlc, })
cfd.refund_timelock_in_blocks(), .await?;
cfd.order.oracle_event_id,
), self.oracle_actor
.send(oracle::MonitorAttestation {
event_id: dlc.settlement_event_id,
}) })
.await?; .await?;
@ -1025,9 +1024,10 @@ impl<O: 'static, M: 'static, T: 'static, W: 'static> Handler<CfdRollOverComplete
for Actor<O, M, T, W> for Actor<O, M, T, W>
where where
M: xtra::Handler<monitor::StartMonitoring>, M: xtra::Handler<monitor::StartMonitoring>,
O: xtra::Handler<oracle::MonitorAttestation>,
{ {
async fn handle(&mut self, msg: CfdRollOverCompleted, _ctx: &mut Context<Self>) { async fn handle(&mut self, msg: CfdRollOverCompleted, _ctx: &mut Context<Self>) {
log_error!(self.handle_cfd_roll_over_completed(msg.order_id, msg.dlc)); log_error!(self.handle_roll_over_completed(msg.order_id, msg.dlc));
} }
} }

10
daemon/src/model/cfd.rs

@ -676,8 +676,8 @@ impl Cfd {
.ceil() as u32 .ceil() as u32
} }
pub fn expiry_timestamp(&self) -> OffsetDateTime { pub fn expiry_timestamp(&self) -> Option<OffsetDateTime> {
self.order.oracle_event_id.timestamp() self.dlc().map(|dlc| dlc.settlement_event_id.timestamp)
} }
/// A factor to be added to the CFD order settlement_interval for calculating the /// A factor to be added to the CFD order settlement_interval for calculating the
@ -1506,6 +1506,12 @@ pub struct Dlc {
pub taker_lock_amount: Amount, pub taker_lock_amount: Amount,
pub revoked_commit: Vec<RevokedCommit>, pub revoked_commit: Vec<RevokedCommit>,
// TODO: For now we store this seperately - it is a duplicate of what is stored in the cets
// hashmap. The cet hashmap allows storing cets for event-ids with different concern
// (settlement and liquidation-point). We should NOT make these fields public on the Dlc
// and create an internal structure that depicts this properly and avoids duplication.
pub settlement_event_id: BitMexPriceEventId,
} }
impl Dlc { impl Dlc {

14
daemon/src/monitor.rs

@ -78,12 +78,12 @@ impl Actor<bdk::electrum_client::Client> {
match cfd.state.clone() { match cfd.state.clone() {
// In PendingOpen we know the complete dlc setup and assume that the lock transaction will be published // In PendingOpen we know the complete dlc setup and assume that the lock transaction will be published
CfdState::PendingOpen { dlc, .. } => { CfdState::PendingOpen { dlc, .. } => {
let params = MonitorParams::new(dlc.clone(), cfd.refund_timelock_in_blocks(), cfd.order.oracle_event_id); let params = MonitorParams::new(dlc.clone(), cfd.refund_timelock_in_blocks());
actor.cfds.insert(cfd.order.id, params.clone()); actor.cfds.insert(cfd.order.id, params.clone());
actor.monitor_all(&params, cfd.order.id); actor.monitor_all(&params, cfd.order.id);
} }
CfdState::Open { dlc, .. } | CfdState::PendingCommit { dlc, .. } => { CfdState::Open { dlc, .. } | CfdState::PendingCommit { dlc, .. } => {
let params = MonitorParams::new(dlc.clone(), cfd.refund_timelock_in_blocks(), cfd.order.oracle_event_id); let params = MonitorParams::new(dlc.clone(), cfd.refund_timelock_in_blocks());
actor.cfds.insert(cfd.order.id, params.clone()); actor.cfds.insert(cfd.order.id, params.clone());
actor.monitor_commit_finality(&params, cfd.order.id); actor.monitor_commit_finality(&params, cfd.order.id);
@ -99,7 +99,7 @@ impl Actor<bdk::electrum_client::Client> {
} }
} }
CfdState::OpenCommitted { dlc, cet_status, .. } => { CfdState::OpenCommitted { dlc, cet_status, .. } => {
let params = MonitorParams::new(dlc.clone(), cfd.refund_timelock_in_blocks(), cfd.order.oracle_event_id); let params = MonitorParams::new(dlc.clone(), cfd.refund_timelock_in_blocks());
actor.cfds.insert(cfd.order.id, params.clone()); actor.cfds.insert(cfd.order.id, params.clone());
match cet_status { match cet_status {
@ -126,7 +126,7 @@ impl Actor<bdk::electrum_client::Client> {
} }
} }
CfdState::PendingCet { dlc, attestation, .. } => { CfdState::PendingCet { dlc, attestation, .. } => {
let params = MonitorParams::new(dlc.clone(), cfd.refund_timelock_in_blocks(), cfd.order.oracle_event_id); let params = MonitorParams::new(dlc.clone(), cfd.refund_timelock_in_blocks());
actor.cfds.insert(cfd.order.id, params.clone()); actor.cfds.insert(cfd.order.id, params.clone());
actor.monitor_cet_finality(map_cets(dlc.cets), attestation.into(), cfd.order.id)?; actor.monitor_cet_finality(map_cets(dlc.cets), attestation.into(), cfd.order.id)?;
@ -134,7 +134,7 @@ impl Actor<bdk::electrum_client::Client> {
actor.monitor_refund_finality(&params,cfd.order.id); actor.monitor_refund_finality(&params,cfd.order.id);
} }
CfdState::PendingRefund { dlc, .. } => { CfdState::PendingRefund { dlc, .. } => {
let params = MonitorParams::new(dlc.clone(), cfd.refund_timelock_in_blocks(), cfd.order.oracle_event_id); let params = MonitorParams::new(dlc.clone(), cfd.refund_timelock_in_blocks());
actor.cfds.insert(cfd.order.id, params.clone()); actor.cfds.insert(cfd.order.id, params.clone());
actor.monitor_commit_refund_timelock(&params, cfd.order.id); actor.monitor_commit_refund_timelock(&params, cfd.order.id);
@ -561,7 +561,7 @@ impl Event {
} }
impl MonitorParams { impl MonitorParams {
pub fn new(dlc: Dlc, refund_timelock_in_blocks: u32, event_id: BitMexPriceEventId) -> Self { pub fn new(dlc: Dlc, refund_timelock_in_blocks: u32) -> Self {
let script_pubkey = dlc.maker_address.script_pubkey(); let script_pubkey = dlc.maker_address.script_pubkey();
MonitorParams { MonitorParams {
lock: (dlc.lock.0.txid(), dlc.lock.1), lock: (dlc.lock.0.txid(), dlc.lock.1),
@ -577,7 +577,7 @@ impl MonitorParams {
.iter() .iter()
.map(|rev_commit| (rev_commit.txid, rev_commit.script_pubkey.clone())) .map(|rev_commit| (rev_commit.txid, rev_commit.script_pubkey.clone()))
.collect(), .collect(),
event_id, event_id: dlc.settlement_event_id,
} }
} }
} }

12
daemon/src/oracle.rs

@ -68,13 +68,13 @@ impl Actor {
for cfd in cfds { for cfd in cfds {
match cfd.state.clone() { match cfd.state.clone() {
CfdState::PendingOpen { .. } CfdState::PendingOpen { dlc, ..}
| CfdState::Open { .. } | CfdState::Open { dlc, .. }
| CfdState::PendingCommit { .. } | CfdState::PendingCommit { dlc, .. }
| CfdState::OpenCommitted { .. } | CfdState::OpenCommitted { dlc, .. }
| CfdState::PendingCet { .. } => | CfdState::PendingCet { dlc, .. } =>
{ {
pending_attestations.insert(cfd.order.oracle_event_id); pending_attestations.insert(dlc.settlement_event_id);
} }
// Irrelevant for restart // Irrelevant for restart

3
daemon/src/setup_contract.rs

@ -111,6 +111,7 @@ where
) )
} }
let settlement_event_id = announcement.id;
let payouts = HashMap::from_iter([( let payouts = HashMap::from_iter([(
announcement.into(), announcement.into(),
payout_curve::calculate( payout_curve::calculate(
@ -289,6 +290,7 @@ where
maker_lock_amount: params.maker().lock_amount, maker_lock_amount: params.maker().lock_amount,
taker_lock_amount: params.taker().lock_amount, taker_lock_amount: params.taker().lock_amount,
revoked_commit: Vec::new(), revoked_commit: Vec::new(),
settlement_event_id,
}) })
} }
@ -575,6 +577,7 @@ pub async fn roll_over(
maker_lock_amount, maker_lock_amount,
taker_lock_amount, taker_lock_amount,
revoked_commit, revoked_commit,
settlement_event_id: announcement.id,
}) })
} }

32
daemon/src/taker_cfd.rs

@ -434,17 +434,13 @@ where
self.monitor_actor self.monitor_actor
.send(monitor::StartMonitoring { .send(monitor::StartMonitoring {
id: order_id, id: order_id,
params: MonitorParams::new( params: MonitorParams::new(dlc.clone(), cfd.refund_timelock_in_blocks()),
dlc,
cfd.refund_timelock_in_blocks(),
cfd.order.oracle_event_id,
),
}) })
.await?; .await?;
self.oracle_actor self.oracle_actor
.send(oracle::MonitorAttestation { .send(oracle::MonitorAttestation {
event_id: cfd.order.oracle_event_id, event_id: dlc.settlement_event_id,
}) })
.await?; .await?;
@ -483,12 +479,6 @@ where
.await? .await?
.with_context(|| format!("Announcement {} not found", cfd.order.oracle_event_id))?; .with_context(|| format!("Announcement {} not found", cfd.order.oracle_event_id))?;
self.oracle_actor
.send(oracle::MonitorAttestation {
event_id: offer_announcement.id,
})
.await?;
let contract_future = setup_contract::new( let contract_future = setup_contract::new(
self.send_to_maker self.send_to_maker
.sink() .sink()
@ -609,8 +599,9 @@ where
impl<O: 'static, M: 'static, W: 'static> Actor<O, M, W> impl<O: 'static, M: 'static, W: 'static> Actor<O, M, W>
where where
M: xtra::Handler<monitor::StartMonitoring>, M: xtra::Handler<monitor::StartMonitoring>,
O: xtra::Handler<oracle::MonitorAttestation>,
{ {
async fn handle_cfd_roll_over_completed( async fn handle_roll_over_completed(
&mut self, &mut self,
order_id: OrderId, order_id: OrderId,
dlc: Result<Dlc>, dlc: Result<Dlc>,
@ -632,11 +623,13 @@ where
self.monitor_actor self.monitor_actor
.send(monitor::StartMonitoring { .send(monitor::StartMonitoring {
id: order_id, id: order_id,
params: MonitorParams::new( params: MonitorParams::new(dlc.clone(), cfd.refund_timelock_in_blocks()),
dlc, })
cfd.refund_timelock_in_blocks(), .await?;
cfd.order.oracle_event_id,
), self.oracle_actor
.send(oracle::MonitorAttestation {
event_id: dlc.settlement_event_id,
}) })
.await?; .await?;
@ -796,9 +789,10 @@ where
impl<O: 'static, M: 'static, W: 'static> Handler<CfdRollOverCompleted> for Actor<O, M, W> impl<O: 'static, M: 'static, W: 'static> Handler<CfdRollOverCompleted> for Actor<O, M, W>
where where
M: xtra::Handler<monitor::StartMonitoring>, M: xtra::Handler<monitor::StartMonitoring>,
O: xtra::Handler<oracle::MonitorAttestation>,
{ {
async fn handle(&mut self, msg: CfdRollOverCompleted, _ctx: &mut Context<Self>) { async fn handle(&mut self, msg: CfdRollOverCompleted, _ctx: &mut Context<Self>) {
log_error!(self.handle_cfd_roll_over_completed(msg.order_id, msg.dlc)); log_error!(self.handle_roll_over_completed(msg.order_id, msg.dlc));
} }
} }

5
daemon/src/to_sse_event.rs

@ -318,7 +318,10 @@ impl ToSseEvent for CfdsWithAuxData {
margin: cfd.margin().expect("margin to be available"), margin: cfd.margin().expect("margin to be available"),
margin_counterparty: cfd.counterparty_margin().expect("margin to be available"), margin_counterparty: cfd.counterparty_margin().expect("margin to be available"),
details, details,
expiry_timestamp: cfd.expiry_timestamp(), expiry_timestamp: match cfd.expiry_timestamp() {
None => cfd.order.oracle_event_id.timestamp(),
Some(timestamp) => timestamp,
},
} }
}) })
.collect::<Vec<Cfd>>(); .collect::<Vec<Cfd>>();

Loading…
Cancel
Save