mirror of
https://github.com/lightningnetwork/lnd.git
synced 2025-01-19 05:45:21 +01:00
contractcourt: only look for local force close for non-recovered channel
In this commit, we modify the main `closeObserver` dispatch loop to only look for the local force close if we didn't recover the channel. We do this, as for a recovered channel, it isn't possible for us to force close from a recovered channel.
This commit is contained in:
parent
b491488c6f
commit
c722f2c064
@ -320,22 +320,35 @@ func (c *chainWatcher) closeObserver(spendNtfn *chainntnfs.SpendEvent) {
|
||||
return
|
||||
}
|
||||
|
||||
// If this is our commitment transaction, then we can
|
||||
// exit here as we don't have any further processing we
|
||||
// need to do (we can't cheat ourselves :p).
|
||||
commitmentHash := localCommit.CommitTx.TxHash()
|
||||
isOurCommitment := commitSpend.SpenderTxHash.IsEqual(
|
||||
&commitmentHash,
|
||||
// If this channel has been recovered, then we'll modify our
|
||||
// behavior as it isn't possible for us to close out the
|
||||
// channel off-chain ourselves. It can only be the remote party
|
||||
// force closing, or a cooperative closure we signed off on
|
||||
// before losing data getting confirmed in the chain.
|
||||
isRecoveredChan := c.cfg.chanState.HasChanStatus(
|
||||
channeldb.ChanStatusRestored,
|
||||
)
|
||||
if isOurCommitment {
|
||||
if err := c.dispatchLocalForceClose(
|
||||
commitSpend, *localCommit,
|
||||
); err != nil {
|
||||
log.Errorf("unable to handle local"+
|
||||
"close for chan_point=%v: %v",
|
||||
c.cfg.chanState.FundingOutpoint, err)
|
||||
|
||||
// If we're not recovering this channel, and this is our
|
||||
// commitment transaction, then we can exit here as we don't
|
||||
// have any further processing we need to do (we can't cheat
|
||||
// ourselves :p).
|
||||
if !isRecoveredChan {
|
||||
commitmentHash := localCommit.CommitTx.TxHash()
|
||||
isOurCommitment := commitSpend.SpenderTxHash.IsEqual(
|
||||
&commitmentHash,
|
||||
)
|
||||
|
||||
if isOurCommitment {
|
||||
if err := c.dispatchLocalForceClose(
|
||||
commitSpend, *localCommit,
|
||||
); err != nil {
|
||||
log.Errorf("unable to handle local"+
|
||||
"close for chan_point=%v: %v",
|
||||
c.cfg.chanState.FundingOutpoint, err)
|
||||
}
|
||||
return
|
||||
}
|
||||
return
|
||||
}
|
||||
|
||||
// Next, we'll check to see if this is a cooperative channel
|
||||
|
@ -3504,7 +3504,7 @@ func (lc *LightningChannel) ProcessChanSyncMsg(
|
||||
|
||||
// Alternatively, if their height is two beyond what we know their best
|
||||
// height to be, then they're holding onto two commitments, and the
|
||||
// highest unrevoked point it their next revocation.
|
||||
// highest unrevoked point is their next revocation.
|
||||
//
|
||||
// TODO(roasbeef): verify this in the spec...
|
||||
case msg.NextLocalCommitHeight == remoteTailHeight+2:
|
||||
|
Loading…
Reference in New Issue
Block a user