Skip to content

Commit

Permalink
rescan: wait till current or end height reached
Browse files Browse the repository at this point in the history
Let the rescan function wait until the filter headers have either caught
up to the back end chain or until they have caught up to the specified
rescan end block. This lets the rescan operation take advantage of doing
batch filter fetching during rescan making the operation a lot faster
since filters can be fetched in batches of 1000 instead of one at a
time.
  • Loading branch information
ellemouton committed Jul 18, 2023
1 parent 42c088d commit bca0cb2
Showing 1 changed file with 30 additions and 0 deletions.
30 changes: 30 additions & 0 deletions rescan.go
Original file line number Diff line number Diff line change
Expand Up @@ -446,6 +446,36 @@ func (rs *rescanState) rescan() error {
return err
}

// To ensure that we batch as many filter queries as possible, we also
// wait for the header chain to either be current or for it to at least
// have caught up with the specified end block.
log.Debugf("Waiting for the chain source to be current or for the " +
"rescan end height to be reached.")

if err := rs.waitForBlocks(func(hash chainhash.Hash,
height uint32) bool {

// If the header chain is current, then there is no need to
// wait.
if chain.IsCurrent() {
return true
}

// If an end height was specified then we wait until the
// notification corresponding to that block height.
if ro.endBlock.Height > 0 &&
height >= uint32(ro.endBlock.Height) {

return true
}

// If a block hash was specified, check if the notification is
// for that block.
return hash == ro.endBlock.Hash
}); err != nil {
return err
}

log.Debugf("Starting rescan from known block %d (%s)",
rs.curStamp.Height, rs.curStamp.Hash)

Expand Down

0 comments on commit bca0cb2

Please sign in to comment.