Skip to content

Commit 20a2596

Browse files
committed
Use signer instead of keys_storage in OnchainTx to hold Sign
1 parent ff00f6f commit 20a2596

File tree

1 file changed

+14
-17
lines changed

1 file changed

+14
-17
lines changed

lightning/src/ln/onchaintx.rs

Lines changed: 14 additions & 17 deletions
Original file line numberDiff line numberDiff line change
@@ -250,7 +250,7 @@ pub struct OnchainTxHandler<ChanSigner: Sign> {
250250
prev_holder_commitment: Option<HolderCommitmentTransaction>,
251251
prev_holder_htlc_sigs: Option<Vec<Option<(usize, Signature)>>>,
252252

253-
key_storage: ChanSigner,
253+
signer: ChanSigner,
254254
pub(crate) channel_transaction_parameters: ChannelTransactionParameters,
255255

256256
// Used to track claiming requests. If claim tx doesn't confirm before height timer expiration we need to bump
@@ -298,7 +298,7 @@ impl<ChanSigner: Sign> OnchainTxHandler<ChanSigner> {
298298
self.channel_transaction_parameters.write(writer)?;
299299

300300
let mut key_data = VecWriter(Vec::new());
301-
self.key_storage.write(&mut key_data)?;
301+
self.signer.write(&mut key_data)?;
302302
assert!(key_data.0.len() < std::usize::MAX);
303303
assert!(key_data.0.len() < std::u32::MAX as usize);
304304
(key_data.0.len() as u32).write(writer)?;
@@ -360,7 +360,7 @@ impl<'a, K: KeysInterface> ReadableArgs<&'a K> for OnchainTxHandler<K::Signer> {
360360
reader.read_exact(read_slice)?;
361361
keys_data.extend_from_slice(read_slice);
362362
}
363-
let key_storage = keys_manager.read_chan_signer(&keys_data)?;
363+
let signer = keys_manager.read_chan_signer(&keys_data)?;
364364

365365
let pending_claim_requests_len: u64 = Readable::read(reader)?;
366366
let mut pending_claim_requests = HashMap::with_capacity(cmp::min(pending_claim_requests_len as usize, MAX_ALLOC_SIZE / 128));
@@ -412,7 +412,7 @@ impl<'a, K: KeysInterface> ReadableArgs<&'a K> for OnchainTxHandler<K::Signer> {
412412
holder_htlc_sigs,
413413
prev_holder_commitment,
414414
prev_holder_htlc_sigs,
415-
key_storage,
415+
signer,
416416
channel_transaction_parameters: channel_parameters,
417417
claimable_outpoints,
418418
pending_claim_requests,
@@ -424,17 +424,14 @@ impl<'a, K: KeysInterface> ReadableArgs<&'a K> for OnchainTxHandler<K::Signer> {
424424
}
425425

426426
impl<ChanSigner: Sign> OnchainTxHandler<ChanSigner> {
427-
pub(crate) fn new(destination_script: Script, keys: ChanSigner, channel_parameters: ChannelTransactionParameters, holder_commitment: HolderCommitmentTransaction) -> Self {
428-
429-
let key_storage = keys;
430-
427+
pub(crate) fn new(destination_script: Script, signer: ChanSigner, channel_parameters: ChannelTransactionParameters, holder_commitment: HolderCommitmentTransaction) -> Self {
431428
OnchainTxHandler {
432429
destination_script,
433430
holder_commitment,
434431
holder_htlc_sigs: None,
435432
prev_holder_commitment: None,
436433
prev_holder_htlc_sigs: None,
437-
key_storage,
434+
signer,
438435
channel_transaction_parameters: channel_parameters,
439436
pending_claim_requests: HashMap::new(),
440437
claimable_outpoints: HashMap::new(),
@@ -605,15 +602,15 @@ impl<ChanSigner: Sign> OnchainTxHandler<ChanSigner> {
605602
for (i, (outp, per_outp_material)) in cached_claim_datas.per_input_material.iter().enumerate() {
606603
match per_outp_material {
607604
&InputMaterial::Revoked { ref per_commitment_point, ref counterparty_delayed_payment_base_key, ref counterparty_htlc_base_key, ref per_commitment_key, ref input_descriptor, ref amount, ref htlc, ref on_counterparty_tx_csv } => {
608-
if let Ok(chan_keys) = TxCreationKeys::derive_new(&self.secp_ctx, &per_commitment_point, counterparty_delayed_payment_base_key, counterparty_htlc_base_key, &self.key_storage.pubkeys().revocation_basepoint, &self.key_storage.pubkeys().htlc_basepoint) {
605+
if let Ok(chan_keys) = TxCreationKeys::derive_new(&self.secp_ctx, &per_commitment_point, counterparty_delayed_payment_base_key, counterparty_htlc_base_key, &self.signer.pubkeys().revocation_basepoint, &self.signer.pubkeys().htlc_basepoint) {
609606

610607
let witness_script = if let Some(ref htlc) = *htlc {
611608
chan_utils::get_htlc_redeemscript_with_explicit_keys(&htlc, &chan_keys.broadcaster_htlc_key, &chan_keys.countersignatory_htlc_key, &chan_keys.revocation_key)
612609
} else {
613610
chan_utils::get_revokeable_redeemscript(&chan_keys.revocation_key, *on_counterparty_tx_csv, &chan_keys.broadcaster_delayed_payment_key)
614611
};
615612

616-
let sig = self.key_storage.sign_justice_transaction(&bumped_tx, i, *amount, &per_commitment_key, htlc, &self.secp_ctx).expect("sign justice tx");
613+
let sig = self.signer.sign_justice_transaction(&bumped_tx, i, *amount, &per_commitment_key, htlc, &self.secp_ctx).expect("sign justice tx");
617614
bumped_tx.input[i].witness.push(sig.serialize_der().to_vec());
618615
bumped_tx.input[i].witness[0].push(SigHashType::All as u8);
619616
if htlc.is_some() {
@@ -627,11 +624,11 @@ impl<ChanSigner: Sign> OnchainTxHandler<ChanSigner> {
627624
}
628625
},
629626
&InputMaterial::CounterpartyHTLC { ref per_commitment_point, ref counterparty_delayed_payment_base_key, ref counterparty_htlc_base_key, ref preimage, ref htlc } => {
630-
if let Ok(chan_keys) = TxCreationKeys::derive_new(&self.secp_ctx, &per_commitment_point, counterparty_delayed_payment_base_key, counterparty_htlc_base_key, &self.key_storage.pubkeys().revocation_basepoint, &self.key_storage.pubkeys().htlc_basepoint) {
627+
if let Ok(chan_keys) = TxCreationKeys::derive_new(&self.secp_ctx, &per_commitment_point, counterparty_delayed_payment_base_key, counterparty_htlc_base_key, &self.signer.pubkeys().revocation_basepoint, &self.signer.pubkeys().htlc_basepoint) {
631628
let witness_script = chan_utils::get_htlc_redeemscript_with_explicit_keys(&htlc, &chan_keys.broadcaster_htlc_key, &chan_keys.countersignatory_htlc_key, &chan_keys.revocation_key);
632629

633630
if !preimage.is_some() { bumped_tx.lock_time = htlc.cltv_expiry }; // Right now we don't aggregate time-locked transaction, if we do we should set lock_time before to avoid breaking hash computation
634-
let sig = self.key_storage.sign_counterparty_htlc_transaction(&bumped_tx, i, &htlc.amount_msat / 1000, &per_commitment_point, htlc, &self.secp_ctx).expect("sign counterparty HTLC tx");
631+
let sig = self.signer.sign_counterparty_htlc_transaction(&bumped_tx, i, &htlc.amount_msat / 1000, &per_commitment_point, htlc, &self.secp_ctx).expect("sign counterparty HTLC tx");
635632
bumped_tx.input[i].witness.push(sig.serialize_der().to_vec());
636633
bumped_tx.input[i].witness[0].push(SigHashType::All as u8);
637634
if let &Some(preimage) = preimage {
@@ -914,7 +911,7 @@ impl<ChanSigner: Sign> OnchainTxHandler<ChanSigner> {
914911
// ChannelMonitor replica, so we handle that case here.
915912
fn sign_latest_holder_htlcs(&mut self) {
916913
if self.holder_htlc_sigs.is_none() {
917-
let (_sig, sigs) = self.key_storage.sign_holder_commitment_and_htlcs(&self.holder_commitment, &self.secp_ctx).expect("sign holder commitment");
914+
let (_sig, sigs) = self.signer.sign_holder_commitment_and_htlcs(&self.holder_commitment, &self.secp_ctx).expect("sign holder commitment");
918915
self.holder_htlc_sigs = Some(Self::extract_holder_sigs(&self.holder_commitment, sigs));
919916
}
920917
}
@@ -925,7 +922,7 @@ impl<ChanSigner: Sign> OnchainTxHandler<ChanSigner> {
925922
fn sign_prev_holder_htlcs(&mut self) {
926923
if self.prev_holder_htlc_sigs.is_none() {
927924
if let Some(ref holder_commitment) = self.prev_holder_commitment {
928-
let (_sig, sigs) = self.key_storage.sign_holder_commitment_and_htlcs(holder_commitment, &self.secp_ctx).expect("sign previous holder commitment");
925+
let (_sig, sigs) = self.signer.sign_holder_commitment_and_htlcs(holder_commitment, &self.secp_ctx).expect("sign previous holder commitment");
929926
self.prev_holder_htlc_sigs = Some(Self::extract_holder_sigs(holder_commitment, sigs));
930927
}
931928
}
@@ -946,14 +943,14 @@ impl<ChanSigner: Sign> OnchainTxHandler<ChanSigner> {
946943
// before providing a initial commitment transaction. For outbound channel, init ChannelMonitor at Channel::funding_signed, there is nothing
947944
// to monitor before.
948945
pub(crate) fn get_fully_signed_holder_tx(&mut self, funding_redeemscript: &Script) -> Transaction {
949-
let (sig, htlc_sigs) = self.key_storage.sign_holder_commitment_and_htlcs(&self.holder_commitment, &self.secp_ctx).expect("signing holder commitment");
946+
let (sig, htlc_sigs) = self.signer.sign_holder_commitment_and_htlcs(&self.holder_commitment, &self.secp_ctx).expect("signing holder commitment");
950947
self.holder_htlc_sigs = Some(Self::extract_holder_sigs(&self.holder_commitment, htlc_sigs));
951948
self.holder_commitment.add_holder_sig(funding_redeemscript, sig)
952949
}
953950

954951
#[cfg(any(test, feature="unsafe_revoked_tx_signing"))]
955952
pub(crate) fn get_fully_signed_copy_holder_tx(&mut self, funding_redeemscript: &Script) -> Transaction {
956-
let (sig, htlc_sigs) = self.key_storage.unsafe_sign_holder_commitment_and_htlcs(&self.holder_commitment, &self.secp_ctx).expect("sign holder commitment");
953+
let (sig, htlc_sigs) = self.signer.unsafe_sign_holder_commitment_and_htlcs(&self.holder_commitment, &self.secp_ctx).expect("sign holder commitment");
957954
self.holder_htlc_sigs = Some(Self::extract_holder_sigs(&self.holder_commitment, htlc_sigs));
958955
self.holder_commitment.add_holder_sig(funding_redeemscript, sig)
959956
}

0 commit comments

Comments
 (0)