Merge pull request #4865 from guggero/restore-logic-fix

chanrestore: flip case logic for old backup logic
This commit is contained in:
Olaoluwa Osuntokun 2020-12-14 16:29:02 -08:00 committed by GitHub
commit f8dda6f0ee
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -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
} }
} }