Skip to content

Commit

Permalink
Splicing proto hapa7; reworked state handling and all
Browse files Browse the repository at this point in the history
  • Loading branch information
optout21 committed Feb 12, 2024
1 parent c0c0832 commit 54d92cf
Show file tree
Hide file tree
Showing 16 changed files with 715 additions and 2,047 deletions.
90 changes: 54 additions & 36 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -41,70 +41,88 @@ Detailed steps
(as of Jan 24, d0b0be1, splicing-hapa6)

[S1I] splice_channel() - ChannelManager API
[S2I] get_splice() - Channel
Do checks, save pending splice parameters
get_splice() - Channel
message out: splice
handle_splice() - ChannelManager
[A] handle_splice() - ChannelManager
[S3A] internal_splice() - ChannelManager
[S4A] get_splice_ack - Channel
[A] begin_interactive_funding_tx_construction() - Channel
[A] begin_interactive_funding_tx_construction() - ChannelContext
Do checks. Check if channel ID would change. Cycle back the channel to UnfundedInboundV2
splice_start() -- ChannelContext
Start the splice, update capacity, state, reset funding transaction
get_splice_ack() -- Channel
begin_interactive_funding_tx_construction() - Channel
begin_interactive_funding_tx_construction() - ChannelContext
Splicing specific: Add the previous funding as an input to the new one.
get_input_of_current_funding()
InteractiveTxConstructor::new()
Start interactive TX negotiation
message in: splice_ack
handle_splice_ack() - ChannelManager
[I] handle_splice_ack() - ChannelManager
[S5I] internal_splice_ack() - ChannelManager
Do checks, check against initial splice()
Cycle back the channel to UnfundedOutboundV2
splice_start() -- ChannelContext
Start the splice, update capacity, state, reset funding transaction
event: SpliceAckedInputsContributionReady
action by client, create input for new funding
contains the pre & post capacities, channel ID
action by client: provide extra input(s) for new funding
[I] contribute_funding_inputs() - ChannelManager API
[I] begin_interactive_funding_tx_construction() - Channel
[I] begin_interactive_funding_tx_construction() - ChannelContext
[I] InteractiveTxConstructor::new()
begin_interactive_funding_tx_construction() - Channel
begin_interactive_funding_tx_construction() - ChannelContext
Splicing specific: Add the previous funding as an input to the new one.
get_input_of_current_funding() InteractiveTxConstructor::new()
Interactive tx construction flow follows (e.g. 2 inputs, 2 outputs)
message out: tx_add_input
[A] handle_tx_add_input() - ChannelManager
[A] internal_tx_add_input() - ChannelManager
[A] tx_add_input() - Channel
[A] handle_tx_add_input - InteractiveTxConstructor
message in: tx_complete
[I] handle_tx_complete() - ChannelManager
[I] internal_tx_complete() - ChannelManager
[I] tx_complete() - ChannelContext
[I] handle_tx_complete() - InteractiveTxConstructor
message out: tx_add_input, second
[A] handle_tx_add_input() - ChannelManager
message in: tx_complete
[I] handle_tx_complete() - ChannelManager
message out: tx_add_output - for change
[A] handle_tx_add_output() - ChannelManager
message in: tx_complete
[I] handle_tx_complete() - ChannelManager
message out: tx_add_output - for new funding
[A] handle_tx_add_output() - ChannelManager
message in: tx_complete
[I] handle_tx_complete() - ChannelManager
[I] funding_tx_constructed() - Channel
[I] get_initial_commitment_signed() - Channel
[I] interactive_tx_constructor = None
[I] channel_state = FundingNegotiated
internal_tx_complete() -- ChannelManager
funding_tx_constructed() - Channel
get_initial_commitment_signed() - Channel
Splicing-specific: Add signature on the previous funding tx input
Mark finished interactive tx construction
Update channel state (FundingNegotiated)
message out: tx_complete
message out: commitment_signed
event: FundingTransactionReadyForSigning
contains the new funding transaction with the signature on the previous tx input
action by client: Create and provide signature on the extra inputs
[I] funding_transaction_signed() - ChannelManager
[I] verify_interactive_tx_signatures() - Channel
[I] provide_holder_witnesses() - InteractiveTxSigningSession
verify_interactive_tx_signatures() - Channel
splicing specific: Use the previously saved shared signature (tlvs field)
provide_holder_witnesses() - InteractiveTxSigningSession
[A] handle_tx_complete() - ChannelManager
internal_tx_complete() -- ChannelManager
message in: commitment_signed
[A] handle_commitment_signed() - ChannelManager
[A] internal_commitment_signed() - ChannelManager
[A] commitment_signed_initial_v2() - Channel
[A] watch_channel() - ChainMonitor
internal_commitment_signed() - ChannelManager
commitment_signed_initial_v2() - Channel
watch_channel() - ChainMonitor
[I] handle_commitment_signed() - ChannelManager
internal_commitment_signed() - ChannelManager
commitment_signed_initial_v2() - Channel
watch_channel() - ChainMonitor
message in: tx_signatures
[I] handle_tx_signatures - ChannelManager
internal_tx_signatures -- ChannelManager
tx_signatures() -- Channel
Check present sigantures, tlvs field
Update signature on previous tx input (with shared signature)
Update channel state (AwaitingChannelReady)
message out: tx_signatures
[A] handle_tx_signatures - ChannelManager
waiting for confirmation
internal_tx_signatures -- ChannelManager
tx_signatures() -- Channel
New funding tx gets broadcasted (both sides)
Waiting for confirmation
[I] transactions_confirmed() - Channel
[I] commit_pending_splice() - ChannelContext
[I] channel_state = AwaitingChannelReady
[I] clear_pending_splice() - ChannelContext
splice_locked() -- ChannelContext
Mark splicing process as completed
message out: channel_ready
message in: channel_ready
[A] handle_channel_ready() - ChannelManager
Expand Down
5 changes: 5 additions & 0 deletions ci/ci-tests.sh
Original file line number Diff line number Diff line change
Expand Up @@ -161,3 +161,8 @@ echo -e "\n\nTest dual-funding builds"
pushd lightning
RUSTFLAGS="$RUSTFLAGS --cfg=dual_funding" cargo test --verbose --color always -p lightning
popd

echo -e "\n\nTest dual-funding builds"
pushd lightning
RUSTFLAGS="$RUSTFLAGS --cfg=dual_funding" cargo test --verbose --color always -p lightning
popd
3 changes: 3 additions & 0 deletions lightning-net-tokio/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -621,8 +621,11 @@ mod tests {
fn handle_accept_channel_v2(&self, _their_node_id: &PublicKey, _msg: &AcceptChannelV2) {}
fn handle_stfu(&self, _their_node_id: &PublicKey, _msg: &Stfu) {}
// #SPLICING
#[cfg(dual_funding)]
fn handle_splice(&self, _their_node_id: &PublicKey, _msg: &Splice) {}
#[cfg(dual_funding)]
fn handle_splice_ack(&self, _their_node_id: &PublicKey, _msg: &SpliceAck) {}
#[cfg(dual_funding)]
fn handle_splice_locked(&self, _their_node_id: &PublicKey, _msg: &SpliceLocked) {}
#[cfg(dual_funding)]
fn handle_tx_add_input(&self, _their_node_id: &PublicKey, _msg: &TxAddInput) {}
Expand Down
12 changes: 4 additions & 8 deletions lightning/src/chain/channelmonitor.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1298,9 +1298,8 @@ impl<Signer: WriteableEcdsaChannelSigner> ChannelMonitor<Signer> {
/// possibly future revocation/preimage information) to claim outputs where possible.
/// We cache also the mapping hash:commitment number to lighten pruning of old preimages by watchtowers.
/// #SPLICING
/// TODO changed to prod & pub(crate), from test & private
// #[cfg(test)]
pub(crate) fn provide_latest_counterparty_commitment_tx<L: Deref>(
#[cfg(test)]
fn provide_latest_counterparty_commitment_tx<L: Deref>(
&self,
txid: Txid,
htlc_outputs: Vec<(HTLCOutputInCommitment, Option<Box<HTLCSource>>)>,
Expand Down Expand Up @@ -2440,8 +2439,8 @@ impl<Signer: WriteableEcdsaChannelSigner> ChannelMonitorImpl<Signer> {

// TODO check reenable
// #[cfg(debug_assertions)] {
// let rebuilt_commitment_tx = self.initial_counterparty_commitment_tx().unwrap();
// debug_assert_eq!(rebuilt_commitment_tx.trust().txid(), txid);
// let rebuilt_commitment_tx = self.initial_counterparty_commitment_tx().unwrap();
// debug_assert_eq!(rebuilt_commitment_tx.trust().txid(), txid);
// }

self.provide_latest_counterparty_commitment_tx(txid, htlc_outputs, commitment_number,
Expand Down Expand Up @@ -3847,8 +3846,6 @@ impl<Signer: WriteableEcdsaChannelSigner> ChannelMonitorImpl<Signer> {
if *idx == input.previous_output.vout {
#[cfg(test)]
{
// TODO put it back, add witness to splice tx
/*
// If the expected script is a known type, check that the witness
// appears to be spending the correct type (ie that the match would
// actually succeed in BIP 158/159-style filters).
Expand All @@ -3864,7 +3861,6 @@ impl<Signer: WriteableEcdsaChannelSigner> ChannelMonitorImpl<Signer> {
} else if _script_pubkey.is_v0_p2wpkh() {
assert_eq!(&bitcoin::Address::p2wpkh(&bitcoin::PublicKey::from_slice(&input.witness.last().unwrap()).unwrap(), bitcoin::Network::Bitcoin).unwrap().script_pubkey(), _script_pubkey);
} else { panic!(); }
*/
}
return true;
}
Expand Down
Loading

0 comments on commit 54d92cf

Please sign in to comment.