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 11, 2023
1 parent 3a1be36 commit df74c66
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
@@ -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)

0 comments on commit df74c66

Please sign in to comment.