ipld-eth-server/pkg/history/populate_headers.go

52 lines
1.5 KiB
Go
Raw Normal View History

package history
import (
2018-11-21 04:47:01 +00:00
log "github.com/sirupsen/logrus"
2018-07-24 16:38:49 +00:00
"github.com/vulcanize/vulcanizedb/pkg/core"
"github.com/vulcanize/vulcanizedb/pkg/datastore"
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres/repositories"
)
func PopulateMissingHeaders(blockchain core.BlockChain, headerRepository datastore.HeaderRepository, startingBlockNumber int64) (int, error) {
lastBlock := blockchain.LastBlock().Int64()
headerAlreadyExists, err := headerRepository.HeaderExists(lastBlock)
2018-07-24 16:38:49 +00:00
if err != nil {
log.Error("Error in checking header in PopulateMissingHeaders: ", err)
2018-07-24 16:38:49 +00:00
return 0, err
} else if headerAlreadyExists {
return 0, nil
2018-07-24 16:38:49 +00:00
}
blockNumbers, err := headerRepository.MissingBlockNumbers(startingBlockNumber, lastBlock, blockchain.Node().ID)
if err != nil {
log.Error("Error getting missing block numbers in PopulateMissingHeaders: ", err)
return 0, err
}
log.Printf("Backfilling %d blocks\n\n", len(blockNumbers))
_, err = RetrieveAndUpdateHeaders(blockchain, headerRepository, blockNumbers)
if err != nil {
return 0, err
}
return len(blockNumbers), nil
}
func RetrieveAndUpdateHeaders(chain core.BlockChain, headerRepository datastore.HeaderRepository, blockNumbers []int64) (int, error) {
for _, blockNumber := range blockNumbers {
2018-07-24 16:38:49 +00:00
header, err := chain.GetHeaderByNumber(blockNumber)
if err != nil {
2018-07-24 16:38:49 +00:00
return 0, err
}
_, err = headerRepository.CreateOrUpdateHeader(header)
2018-07-24 16:38:49 +00:00
if err != nil {
if err == repositories.ErrValidHeaderExists {
continue
}
2018-07-24 16:38:49 +00:00
return 0, err
}
}
2018-07-24 16:38:49 +00:00
return len(blockNumbers), nil
}