forked from cerc-io/ipld-eth-server
a683e45855
- Migrate various mocks of core namespaces to shared version in `fakes` pkg - Err on the side of making test doubles less sophisticated - Don't pull over mocks of namespaces that are only used in example code
31 lines
1.0 KiB
Go
31 lines
1.0 KiB
Go
package history
|
|
|
|
import (
|
|
"log"
|
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/core"
|
|
"github.com/vulcanize/vulcanizedb/pkg/datastore"
|
|
)
|
|
|
|
func PopulateMissingBlocks(blockchain core.BlockChain, blockRepository datastore.BlockRepository, startingBlockNumber int64) int {
|
|
lastBlock := blockchain.LastBlock().Int64()
|
|
blockRange := blockRepository.MissingBlockNumbers(startingBlockNumber, lastBlock, blockchain.Node().ID)
|
|
log.SetPrefix("")
|
|
log.Printf("Backfilling %d blocks\n\n", len(blockRange))
|
|
RetrieveAndUpdateBlocks(blockchain, blockRepository, blockRange)
|
|
return len(blockRange)
|
|
}
|
|
|
|
func RetrieveAndUpdateBlocks(blockchain core.BlockChain, blockRepository datastore.BlockRepository, blockNumbers []int64) int {
|
|
for _, blockNumber := range blockNumbers {
|
|
block, err := blockchain.GetBlockByNumber(blockNumber)
|
|
if err != nil {
|
|
log.Printf("failed to retrieve block number: %d\n", blockNumber)
|
|
return 0
|
|
}
|
|
// TODO: handle possible error here
|
|
blockRepository.CreateOrUpdateBlock(block)
|
|
}
|
|
return len(blockNumbers)
|
|
}
|