@@ -1450,6 +1450,10 @@ pub(super) struct ChannelContext<SP: Deref> where SP::Target: SignerProvider {
1450
1450
/// If we can't release a [`ChannelMonitorUpdate`] until some external action completes, we
1451
1451
/// store it here and only release it to the `ChannelManager` once it asks for it.
1452
1452
blocked_monitor_updates: Vec<PendingChannelMonitorUpdate>,
1453
+ // If we've sent `commtiment_signed` for an interactive transaction construction,
1454
+ // but have not received `tx_signatures` we MUST set `next_funding_txid` to the
1455
+ // txid of that interactive transaction, else we MUST NOT set it.
1456
+ next_funding_txid: Option<Txid>,
1453
1457
}
1454
1458
1455
1459
#[cfg(any(dual_funding, splicing))]
@@ -2000,6 +2004,7 @@ impl<SP: Deref> ChannelContext<SP> where SP::Target: SignerProvider {
2000
2004
local_initiated_shutdown: None,
2001
2005
2002
2006
blocked_monitor_updates: Vec::new(),
2007
+ next_funding_txid: None,
2003
2008
};
2004
2009
2005
2010
Ok(channel_context)
@@ -2223,6 +2228,7 @@ impl<SP: Deref> ChannelContext<SP> where SP::Target: SignerProvider {
2223
2228
2224
2229
blocked_monitor_updates: Vec::new(),
2225
2230
local_initiated_shutdown: None,
2231
+ next_funding_txid: None,
2226
2232
})
2227
2233
}
2228
2234
@@ -4398,6 +4404,16 @@ impl<SP: Deref> Channel<SP> where
4398
4404
self.context.channel_state.clear_waiting_for_batch();
4399
4405
}
4400
4406
4407
+ #[cfg(any(dual_funding, splicing))]
4408
+ pub fn set_next_funding_txid(&mut self, txid: &Txid) {
4409
+ self.context.next_funding_txid = Some(*txid);
4410
+ }
4411
+
4412
+ #[cfg(any(dual_funding, splicing))]
4413
+ pub fn clear_next_funding_txid(&mut self) {
4414
+ self.context.next_funding_txid = None;
4415
+ }
4416
+
4401
4417
/// Unsets the existing funding information.
4402
4418
///
4403
4419
/// This must only be used if the channel has not yet completed funding and has not been used.
@@ -7438,10 +7454,7 @@ impl<SP: Deref> Channel<SP> where
7438
7454
next_remote_commitment_number: INITIAL_COMMITMENT_NUMBER - self.context.cur_counterparty_commitment_transaction_number - 1,
7439
7455
your_last_per_commitment_secret: remote_last_secret,
7440
7456
my_current_per_commitment_point: dummy_pubkey,
7441
- // TODO(dual_funding): If we've sent `commtiment_signed` for an interactive transaction
7442
- // construction but have not received `tx_signatures` we MUST set `next_funding_txid` to the
7443
- // txid of that interactive transaction, else we MUST NOT set it.
7444
- next_funding_txid: None,
7457
+ next_funding_txid: self.context.next_funding_txid,
7445
7458
}
7446
7459
}
7447
7460
@@ -9420,6 +9433,7 @@ impl<SP: Deref> Writeable for Channel<SP> where SP::Target: SignerProvider {
9420
9433
(45, cur_holder_commitment_point, option),
9421
9434
(47, next_holder_commitment_point, option),
9422
9435
(49, self.context.local_initiated_shutdown, option), // Added in 0.0.122
9436
+ (51, self.context.next_funding_txid, option), // Added in 0.0.124
9423
9437
});
9424
9438
9425
9439
Ok(())
@@ -10017,6 +10031,10 @@ impl<'a, 'b, 'c, ES: Deref, SP: Deref> ReadableArgs<(&'a ES, &'b SP, u32, &'c Ch
10017
10031
local_initiated_shutdown,
10018
10032
10019
10033
blocked_monitor_updates: blocked_monitor_updates.unwrap(),
10034
+ // If we've sent `commtiment_signed` for an interactive transaction construction,
10035
+ // but have not received `tx_signatures` we MUST set `next_funding_txid` to the
10036
+ // txid of that interactive transaction, else we MUST NOT set it.
10037
+ next_funding_txid: None,
10020
10038
},
10021
10039
#[cfg(any(dual_funding, splicing))]
10022
10040
dual_funding_channel_context: None,
0 commit comments