-
Notifications
You must be signed in to change notification settings - Fork 399
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Introduce interactive signing state flags for funded states. #3637
base: main
Are you sure you want to change the base?
Introduce interactive signing state flags for funded states. #3637
Conversation
👋 Thanks for assigning @wpaulino as a reviewer! |
4c6b6ab
to
c1f430a
Compare
c1f430a
to
e89ba58
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Did you want to include test coverage for restarts here?
Not yet. Tracked in #3636. Will need to be able to contribute inputs first to test a useful order of message exchange + restart. |
e89ba58
to
3b2ac55
Compare
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## main #3637 +/- ##
==========================================
- Coverage 89.17% 89.14% -0.04%
==========================================
Files 155 155
Lines 120941 121022 +81
Branches 120941 121022 +81
==========================================
+ Hits 107850 107880 +30
- Misses 10447 10490 +43
- Partials 2644 2652 +8 ☔ View full report in Codecov by Sentry. 🚀 New features to boost your workflow:
|
3b2ac55
to
5110ecc
Compare
@dunxen re-request when this is ready for review again, feel free to squash as well |
5110ecc
to
1d96044
Compare
🔔 1st Reminder Hey @TheBlueMatt @jkczyz @wpaulino! This PR has been waiting for your review. |
@@ -6924,11 +6933,72 @@ impl<SP: Deref> FundedChannel<SP> where | |||
log_debug!(logger, "Reconnected channel {} with no loss", &self.context.channel_id()); | |||
} | |||
|
|||
// if next_funding_txid is set: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If possible, would be nice to get some test coverage in now for this
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Might be tricky at the moment, but makes sense to try do that now 👍
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Still tricky, but working on this now currently. I'll let you know if we'll have to defer this to a PR after "create outbound dual-funded channel" is complete.
1d96044
to
55e5f6f
Compare
af75699
to
9676dd5
Compare
@dunxen let us know when this is ready for another round |
11e52b8
to
b78d5dc
Compare
b78d5dc
to
bda2701
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just one nit. Please re-request a review once all remaining comments are addressed.
@@ -2356,7 +2382,9 @@ impl<SP: Deref> PendingV2Channel<SP> where SP::Target: SignerProvider { | |||
))); | |||
}; | |||
|
|||
self.context.channel_state = ChannelState::FundingNegotiated; | |||
let mut channel_state = ChannelState::FundingNegotiated(FundingNegotiatedFlags::new()); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The asymmetry between the channel state here and the ChannelPhase
is a bit confusing. Here we consider the channel funded, but we remain in UnfundedV2
until we receive the initial commitment_signed
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's unfortunate. Are you thinking it warrants another variant of ChannelPhase
?
where L::Target: Logger | ||
{ | ||
if !matches!(self.context.channel_state, ChannelState::AwaitingChannelReady(_)) { | ||
if !matches!(self.context.channel_state, ChannelState::FundingNegotiated(flags) if flags.is_interactive_signing()) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should this also check if they already sent it? Unclear if the spec is fine with retransmitting even if we didn't ask for it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What if they sent this first but we were supposed to? Should we disconnect/fail?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This isn't clear in the spec if we should disconnect/fail.
|
||
if funding_tx_opt.is_some() { | ||
// We have a finalized funding transaction, so we can set the funding transaction and reset the | ||
// signing session fields. | ||
self.funding.funding_transaction = funding_tx_opt; | ||
self.funding.funding_transaction = funding_tx_opt.clone(); | ||
self.interactive_tx_signing_session = None; | ||
} | ||
|
||
if holder_tx_signatures_opt.is_some() && self.is_awaiting_initial_mon_persist() { | ||
log_debug!(logger, "Not sending tx_signatures: a monitor update is in progress. Setting monitor_pending_tx_signatures."); | ||
self.context.monitor_pending_tx_signatures = holder_tx_signatures_opt; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
IIUC, this should've already been done when we created the monitor if we need to send first. In this case, it seems we assume we send second, so it has not been set in the monitor?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've attempted to clear it up in a comment, although I think we still need to address the spec issue on tx_signatures exchange order violation.
bda2701
to
5291edc
Compare
Instead of having an explicit `ChannelContext::next_funding_txid` to set and read, we can get this value on the fly when it is appropriate to do so.
This follows the the specification closely in branching without being too verbose, so that it should be easy to follow the logic. See: https://github.com/lightning/bolts/blob/aa5207a/02-peer-protocol.md?plain=1#L2520-L2531
This intoduces the INTERACTIVE_SIGNING, THEIR_TX_SIGNATURES_SENT, and OUR_TX_SIGNATURES_SENT funded state flags. A top-level state flag for INTERACTIVE_SIGNING was avoided so that this work is compatible with splicing as well as V2 channel establishment (dual-funding).
We fully persist `InteractiveTxSigningSession` as it provides the full context of the constructed transaction which is still needed for signing.
When this config field is enabled, the dual_fund feature bit will be set which determines support when receiving `open_channel2` messages.
5291edc
to
c99182e
Compare
This PR includes some deferred follow-ups extracted from #3423 and introduces new state flags to track interactive signing along with persistence of the minimum information needed from a signing session to reconstruct it.
A top-level state flag was avoided so that this work is compatible with splicing as well as V2 channel establishment (dual-funding).