server: fix panic bug when looking for cf checkpoint cache intersection w/ chain
In this commit, we fix a panic bug that can arise when we attempt to process a cf checkpoint message from a remote peer. Before this commit, if the size of the checkpoint cache was large than the number of checkpoints requested by the peer, we would panic with an out of bounds error. In order to prevent, this we'll now use the size of the requested set of hashes as our bound to ensure that we don't panic.
This commit is contained in:
parent
c8e6363e22
commit
222a6dac0d
1 changed files with 1 additions and 1 deletions
|
@ -1011,7 +1011,7 @@ func (sp *serverPeer) OnGetCFCheckpt(_ *peer.Peer, msg *wire.MsgGetCFCheckpt) {
|
|||
// a re-org has occurred so items in the db are now in the main china
|
||||
// while the cache has been partially invalidated.
|
||||
var forkIdx int
|
||||
for forkIdx = len(checkptCache); forkIdx > 0; forkIdx-- {
|
||||
for forkIdx = len(blockHashes); forkIdx > 0; forkIdx-- {
|
||||
if checkptCache[forkIdx-1].blockHash == blockHashes[forkIdx-1] {
|
||||
break
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue