chanrestore: flip case logic

If a channel backup from an old node is restored and a channel contained
within that file was unconfirmed at the time of the backup, the whole
channel short ID is 0:0:0. Unfortunately we got stuck in just the first
case and didn't fall through to the second one. To avoid that, we flip
the case logic because for the second case, the block height in the
short channel ID cannot be zero.
This commit is contained in:
Oliver Gugger 2020-12-14 21:59:49 +01:00
parent 90a45fe2cf
commit 693d0f61b7
No known key found for this signature in database
GPG Key ID: 8E4256593F177720

@ -192,24 +192,26 @@ func (c *chanDBRestorer) RestoreChansFromSingles(backups ...chanbackup.Single) e
channel := chanShell.Chan channel := chanShell.Chan
switch { switch {
// Fallback case 1: It is extremely unlikely at this point that // Fallback case 1: This is an unconfirmed channel from an old
// backup file where we didn't have any workaround in place and
// the short channel ID is 0:0:0. Best we can do here is set the
// funding broadcast height to a reasonable value that we
// determined earlier.
case channel.ShortChanID().BlockHeight == 0:
channel.FundingBroadcastHeight = firstChanHeight
// Fallback case 2: It is extremely unlikely at this point that
// a channel we are trying to restore has a coinbase funding TX. // a channel we are trying to restore has a coinbase funding TX.
// Therefore we can be quite certain that if the TxIndex is // Therefore we can be quite certain that if the TxIndex is
// zero, it was an unconfirmed channel where we used the // zero but the block height wasn't, it was an unconfirmed
// BlockHeight to encode the funding TX broadcast height. To not // channel where we used the BlockHeight to encode the funding
// end up with an invalid short channel ID that looks valid, we // TX broadcast height. To not end up with an invalid short
// restore the "original" unconfirmed one here. // channel ID that looks valid, we restore the "original"
// unconfirmed one here.
case channel.ShortChannelID.TxIndex == 0: case channel.ShortChannelID.TxIndex == 0:
broadcastHeight := channel.ShortChannelID.BlockHeight broadcastHeight := channel.ShortChannelID.BlockHeight
channel.FundingBroadcastHeight = broadcastHeight channel.FundingBroadcastHeight = broadcastHeight
channel.ShortChannelID.BlockHeight = 0 channel.ShortChannelID.BlockHeight = 0
// Fallback case 2: This is an unconfirmed channel from an old
// backup file where we didn't have any workaround in place.
// Best we can do here is set the funding broadcast height to a
// reasonable value that we determined earlier.
case channel.ShortChanID().BlockHeight == 0:
channel.FundingBroadcastHeight = firstChanHeight
} }
} }