From 380740e3127f6bd7b41a09de7c8cffdf7c7af1bf Mon Sep 17 00:00:00 2001 From: Lucas Soriano del Pino Date: Tue, 12 Oct 2021 14:02:34 +1100 Subject: [PATCH] Monitor CETs based on a script pubkey in the transaction Instead of passing in a script which may or may not be part of a CET (because some CETs only pay to one party), we take the script pubkey from an output of the transaction itself. --- daemon/src/monitor.rs | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/daemon/src/monitor.rs b/daemon/src/monitor.rs index 9417e9e..87d7115 100644 --- a/daemon/src/monitor.rs +++ b/daemon/src/monitor.rs @@ -111,7 +111,7 @@ where actor.monitor_refund_finality(¶ms,cfd.order.id); } CetStatus::OracleSigned(attestation) => { - actor.monitor_cet_finality(map_cets(dlc.cets, dlc.maker_address.script_pubkey()), attestation.into(), cfd.order.id)?; + actor.monitor_cet_finality(map_cets(dlc.cets), attestation.into(), cfd.order.id)?; actor.monitor_commit_cet_timelock(¶ms, cfd.order.id); actor.monitor_commit_refund_timelock(¶ms, cfd.order.id); actor.monitor_refund_finality(¶ms,cfd.order.id); @@ -121,7 +121,7 @@ where actor.monitor_refund_finality(¶ms,cfd.order.id); } CetStatus::Ready(attestation) => { - actor.monitor_cet_finality(map_cets(dlc.cets, dlc.maker_address.script_pubkey()), attestation.into(), cfd.order.id)?; + actor.monitor_cet_finality(map_cets(dlc.cets), attestation.into(), cfd.order.id)?; actor.monitor_commit_refund_timelock(¶ms, cfd.order.id); actor.monitor_refund_finality(¶ms,cfd.order.id); } @@ -547,7 +547,7 @@ impl MonitorParams { MonitorParams { lock: (dlc.lock.0.txid(), dlc.lock.1), commit: (dlc.commit.0.txid(), dlc.commit.2), - cets: map_cets(dlc.cets, script_pubkey.clone()), + cets: map_cets(dlc.cets), refund: ( dlc.refund.0.txid(), script_pubkey, @@ -564,7 +564,6 @@ impl MonitorParams { fn map_cets( cets: HashMap>, - script_pubkey: Script, ) -> HashMap> { cets.iter() .map(|(event_id, cets)| { @@ -576,7 +575,7 @@ fn map_cets( tx, range, n_bits, .. }| Cet { txid: tx.txid(), - script: script_pubkey.clone(), + script: tx.output[0].script_pubkey.clone(), range: range.clone(), n_bits: *n_bits, },