@@ -2767,8 +2767,8 @@ impl<SP: Deref> ChannelContext<SP> where SP::Target: SignerProvider {
2767
2767
/// our counterparty!)
2768
2768
/// The result is a transaction which we can revoke broadcastership of (ie a "local" transaction)
2769
2769
/// TODO Some magic rust shit to compile-time check this?
2770
- fn build_holder_transaction_keys(&self, commitment_number: u64 ) -> TxCreationKeys {
2771
- let per_commitment_point = self.holder_signer.as_ref().get_per_commitment_point(commitment_number, &self.secp_ctx );
2770
+ fn build_holder_transaction_keys(&self) -> TxCreationKeys {
2771
+ let per_commitment_point = self.holder_commitment_point.current_point( );
2772
2772
let delayed_payment_base = &self.get_holder_pubkeys().delayed_payment_basepoint;
2773
2773
let htlc_basepoint = &self.get_holder_pubkeys().htlc_basepoint;
2774
2774
let counterparty_pubkeys = self.get_counterparty_pubkeys();
@@ -4464,7 +4464,7 @@ impl<SP: Deref> Channel<SP> where
4464
4464
4465
4465
let funding_script = self.context.get_funding_redeemscript();
4466
4466
4467
- let keys = self.context.build_holder_transaction_keys(self.context.holder_commitment_point.transaction_number() );
4467
+ let keys = self.context.build_holder_transaction_keys();
4468
4468
4469
4469
let commitment_stats = self.context.build_commitment_transaction(self.context.holder_commitment_point.transaction_number(), &keys, true, false, logger);
4470
4470
let commitment_txid = {
@@ -5140,7 +5140,7 @@ impl<SP: Deref> Channel<SP> where
5140
5140
// Before proposing a feerate update, check that we can actually afford the new fee.
5141
5141
let dust_exposure_limiting_feerate = self.context.get_dust_exposure_limiting_feerate(&fee_estimator);
5142
5142
let htlc_stats = self.context.get_pending_htlc_stats(Some(feerate_per_kw), dust_exposure_limiting_feerate);
5143
- let keys = self.context.build_holder_transaction_keys(self.context.holder_commitment_point.transaction_number() );
5143
+ let keys = self.context.build_holder_transaction_keys();
5144
5144
let commitment_stats = self.context.build_commitment_transaction(self.context.holder_commitment_point.transaction_number(), &keys, true, true, logger);
5145
5145
let buffer_fee_msat = commit_tx_fee_sat(feerate_per_kw, commitment_stats.num_nondust_htlcs + htlc_stats.on_holder_tx_outbound_holding_cell_htlcs_count as usize + CONCURRENT_INBOUND_HTLC_FEE_BUFFER as usize, self.context.get_channel_type()) * 1000;
5146
5146
let holder_balance_msat = commitment_stats.local_balance_msat - htlc_stats.outbound_holding_cell_msat;
@@ -5425,7 +5425,10 @@ impl<SP: Deref> Channel<SP> where
5425
5425
}
5426
5426
5427
5427
fn get_last_revoke_and_ack(&self) -> msgs::RevokeAndACK {
5428
- let next_per_commitment_point = self.context.holder_signer.as_ref().get_per_commitment_point(self.context.holder_commitment_point.transaction_number(), &self.context.secp_ctx);
5428
+ debug_assert!(self.context.holder_commitment_point.transaction_number() <= INITIAL_COMMITMENT_NUMBER + 2);
5429
+ // TODO: handle non-available case when get_per_commitment_point becomes async
5430
+ debug_assert!(self.context.holder_commitment_point.is_available());
5431
+ let next_per_commitment_point = self.context.holder_commitment_point.current_point();
5429
5432
let per_commitment_secret = self.context.holder_signer.as_ref().release_commitment_secret(self.context.holder_commitment_point.transaction_number() + 2);
5430
5433
msgs::RevokeAndACK {
5431
5434
channel_id: self.context.channel_id,
@@ -7629,7 +7632,8 @@ impl<SP: Deref> OutboundV1Channel<SP> where SP::Target: SignerProvider {
7629
7632
panic!("Tried to send an open_channel for a channel that has already advanced");
7630
7633
}
7631
7634
7632
- let first_per_commitment_point = self.context.holder_signer.as_ref().get_per_commitment_point(self.context.holder_commitment_point.transaction_number(), &self.context.secp_ctx);
7635
+ debug_assert!(self.context.holder_commitment_point.is_available());
7636
+ let first_per_commitment_point = self.context.holder_commitment_point.current_point();
7633
7637
let keys = self.context.get_holder_pubkeys();
7634
7638
7635
7639
msgs::OpenChannel {
@@ -7824,7 +7828,7 @@ impl<SP: Deref> OutboundV1Channel<SP> where SP::Target: SignerProvider {
7824
7828
log_trace!(logger, "Initial counterparty tx for channel {} is: txid {} tx {}",
7825
7829
&self.context.channel_id(), counterparty_initial_bitcoin_tx.txid, encode::serialize_hex(&counterparty_initial_bitcoin_tx.transaction));
7826
7830
7827
- let holder_signer = self.context.build_holder_transaction_keys(self.context.holder_commitment_point.transaction_number() );
7831
+ let holder_signer = self.context.build_holder_transaction_keys();
7828
7832
let initial_commitment_tx = self.context.build_commitment_transaction(self.context.holder_commitment_point.transaction_number(), &holder_signer, true, false, logger).tx;
7829
7833
{
7830
7834
let trusted_tx = initial_commitment_tx.trust();
@@ -8027,7 +8031,8 @@ impl<SP: Deref> InboundV1Channel<SP> where SP::Target: SignerProvider {
8027
8031
///
8028
8032
/// [`msgs::AcceptChannel`]: crate::ln::msgs::AcceptChannel
8029
8033
fn generate_accept_channel_message(&self) -> msgs::AcceptChannel {
8030
- let first_per_commitment_point = self.context.holder_signer.as_ref().get_per_commitment_point(self.context.holder_commitment_point.transaction_number(), &self.context.secp_ctx);
8034
+ debug_assert!(self.context.holder_commitment_point.is_available());
8035
+ let first_per_commitment_point = self.context.holder_commitment_point.current_point();
8031
8036
let keys = self.context.get_holder_pubkeys();
8032
8037
8033
8038
msgs::AcceptChannel {
@@ -8069,7 +8074,7 @@ impl<SP: Deref> InboundV1Channel<SP> where SP::Target: SignerProvider {
8069
8074
fn check_funding_created_signature<L: Deref>(&mut self, sig: &Signature, logger: &L) -> Result<CommitmentTransaction, ChannelError> where L::Target: Logger {
8070
8075
let funding_script = self.context.get_funding_redeemscript();
8071
8076
8072
- let keys = self.context.build_holder_transaction_keys(self.context.holder_commitment_point.transaction_number() );
8077
+ let keys = self.context.build_holder_transaction_keys();
8073
8078
let initial_commitment_tx = self.context.build_commitment_transaction(self.context.holder_commitment_point.transaction_number(), &keys, true, false, logger).tx;
8074
8079
let trusted_tx = initial_commitment_tx.trust();
8075
8080
let initial_commitment_bitcoin_tx = trusted_tx.built_transaction();
0 commit comments