@@ -2750,8 +2750,9 @@ impl<SP: Deref> ChannelContext<SP> where SP::Target: SignerProvider {
2750
2750
/// our counterparty!)
2751
2751
/// The result is a transaction which we can revoke broadcastership of (ie a "local" transaction)
2752
2752
/// TODO Some magic rust shit to compile-time check this?
2753
- fn build_holder_transaction_keys(&self, commitment_number: u64) -> TxCreationKeys {
2754
- let per_commitment_point = self.holder_signer.as_ref().get_per_commitment_point(commitment_number, &self.secp_ctx);
2753
+ fn build_holder_transaction_keys(&self) -> TxCreationKeys {
2754
+ let per_commitment_point = self.holder_commitment_point.current_point()
2755
+ .expect("Should not build commitment transaction before retrieving first commitment point");
2755
2756
let delayed_payment_base = &self.get_holder_pubkeys().delayed_payment_basepoint;
2756
2757
let htlc_basepoint = &self.get_holder_pubkeys().htlc_basepoint;
2757
2758
let counterparty_pubkeys = self.get_counterparty_pubkeys();
@@ -4447,7 +4448,7 @@ impl<SP: Deref> Channel<SP> where
4447
4448
4448
4449
let funding_script = self.context.get_funding_redeemscript();
4449
4450
4450
- let keys = self.context.build_holder_transaction_keys(self.context.holder_commitment_point.transaction_number() );
4451
+ let keys = self.context.build_holder_transaction_keys();
4451
4452
4452
4453
let commitment_stats = self.context.build_commitment_transaction(self.context.holder_commitment_point.transaction_number(), &keys, true, false, logger);
4453
4454
let commitment_txid = {
@@ -5123,7 +5124,7 @@ impl<SP: Deref> Channel<SP> where
5123
5124
// Before proposing a feerate update, check that we can actually afford the new fee.
5124
5125
let dust_exposure_limiting_feerate = self.context.get_dust_exposure_limiting_feerate(&fee_estimator);
5125
5126
let htlc_stats = self.context.get_pending_htlc_stats(Some(feerate_per_kw), dust_exposure_limiting_feerate);
5126
- let keys = self.context.build_holder_transaction_keys(self.context.holder_commitment_point.transaction_number() );
5127
+ let keys = self.context.build_holder_transaction_keys();
5127
5128
let commitment_stats = self.context.build_commitment_transaction(self.context.holder_commitment_point.transaction_number(), &keys, true, true, logger);
5128
5129
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;
5129
5130
let holder_balance_msat = commitment_stats.local_balance_msat - htlc_stats.outbound_holding_cell_msat;
@@ -5408,7 +5409,11 @@ impl<SP: Deref> Channel<SP> where
5408
5409
}
5409
5410
5410
5411
fn get_last_revoke_and_ack(&self) -> msgs::RevokeAndACK {
5411
- 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);
5412
+ debug_assert!(self.context.holder_commitment_point.transaction_number() <= INITIAL_COMMITMENT_NUMBER + 2);
5413
+ // TODO: handle non-available case when get_per_commitment_point becomes async
5414
+ debug_assert!(self.context.holder_commitment_point.is_available());
5415
+ let next_per_commitment_point = self.context.holder_commitment_point.current_point()
5416
+ .expect("TODO");
5412
5417
let per_commitment_secret = self.context.holder_signer.as_ref().release_commitment_secret(self.context.holder_commitment_point.transaction_number() + 2);
5413
5418
msgs::RevokeAndACK {
5414
5419
channel_id: self.context.channel_id,
@@ -7610,7 +7615,8 @@ impl<SP: Deref> OutboundV1Channel<SP> where SP::Target: SignerProvider {
7610
7615
panic!("Tried to send an open_channel for a channel that has already advanced");
7611
7616
}
7612
7617
7613
- 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);
7618
+ debug_assert!(self.context.holder_commitment_point.is_available());
7619
+ let first_per_commitment_point = self.context.holder_commitment_point.current_point().expect("TODO");
7614
7620
let keys = self.context.get_holder_pubkeys();
7615
7621
7616
7622
msgs::OpenChannel {
@@ -7805,7 +7811,7 @@ impl<SP: Deref> OutboundV1Channel<SP> where SP::Target: SignerProvider {
7805
7811
log_trace!(logger, "Initial counterparty tx for channel {} is: txid {} tx {}",
7806
7812
&self.context.channel_id(), counterparty_initial_bitcoin_tx.txid, encode::serialize_hex(&counterparty_initial_bitcoin_tx.transaction));
7807
7813
7808
- let holder_signer = self.context.build_holder_transaction_keys(self.context.holder_commitment_point.transaction_number() );
7814
+ let holder_signer = self.context.build_holder_transaction_keys();
7809
7815
let initial_commitment_tx = self.context.build_commitment_transaction(self.context.holder_commitment_point.transaction_number(), &holder_signer, true, false, logger).tx;
7810
7816
{
7811
7817
let trusted_tx = initial_commitment_tx.trust();
@@ -8008,7 +8014,8 @@ impl<SP: Deref> InboundV1Channel<SP> where SP::Target: SignerProvider {
8008
8014
///
8009
8015
/// [`msgs::AcceptChannel`]: crate::ln::msgs::AcceptChannel
8010
8016
fn generate_accept_channel_message(&self) -> msgs::AcceptChannel {
8011
- 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);
8017
+ debug_assert!(self.context.holder_commitment_point.is_available());
8018
+ let first_per_commitment_point = self.context.holder_commitment_point.current_point().expect("TODO");
8012
8019
let keys = self.context.get_holder_pubkeys();
8013
8020
8014
8021
msgs::AcceptChannel {
@@ -8050,7 +8057,7 @@ impl<SP: Deref> InboundV1Channel<SP> where SP::Target: SignerProvider {
8050
8057
fn check_funding_created_signature<L: Deref>(&mut self, sig: &Signature, logger: &L) -> Result<CommitmentTransaction, ChannelError> where L::Target: Logger {
8051
8058
let funding_script = self.context.get_funding_redeemscript();
8052
8059
8053
- let keys = self.context.build_holder_transaction_keys(self.context.holder_commitment_point.transaction_number() );
8060
+ let keys = self.context.build_holder_transaction_keys();
8054
8061
let initial_commitment_tx = self.context.build_commitment_transaction(self.context.holder_commitment_point.transaction_number(), &keys, true, false, logger).tx;
8055
8062
let trusted_tx = initial_commitment_tx.trust();
8056
8063
let initial_commitment_bitcoin_tx = trusted_tx.built_transaction();
0 commit comments