2018-11-07 21:50:43 +00:00
|
|
|
// VulcanizeDB
|
2019-03-12 15:46:42 +00:00
|
|
|
// Copyright © 2019 Vulcanize
|
2018-11-07 21:50:43 +00:00
|
|
|
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU Affero General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU Affero General Public License for more details.
|
|
|
|
|
|
|
|
// You should have received a copy of the GNU Affero General Public License
|
|
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2018-07-17 21:23:07 +00:00
|
|
|
package history
|
|
|
|
|
|
|
|
import (
|
2019-09-11 03:37:12 +00:00
|
|
|
"github.com/sirupsen/logrus"
|
2018-07-24 16:38:49 +00:00
|
|
|
|
2018-07-17 21:23:07 +00:00
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/core"
|
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/datastore"
|
2018-07-26 21:15:24 +00:00
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/datastore/postgres/repositories"
|
2018-07-17 21:23:07 +00:00
|
|
|
)
|
|
|
|
|
2019-07-19 01:58:01 +00:00
|
|
|
func PopulateMissingHeaders(blockChain core.BlockChain, headerRepository datastore.HeaderRepository, startingBlockNumber int64) (int, error) {
|
2019-05-10 16:28:20 +00:00
|
|
|
lastBlock, err := blockChain.LastBlock()
|
2018-07-24 16:38:49 +00:00
|
|
|
if err != nil {
|
2019-09-11 03:37:12 +00:00
|
|
|
logrus.Error("PopulateMissingHeaders: Error getting last block: ", err)
|
2018-07-24 16:38:49 +00:00
|
|
|
return 0, err
|
|
|
|
}
|
2018-12-14 11:11:48 +00:00
|
|
|
|
2019-05-10 16:28:20 +00:00
|
|
|
blockNumbers, err := headerRepository.MissingBlockNumbers(startingBlockNumber, lastBlock.Int64(), blockChain.Node().ID)
|
2019-01-11 09:58:41 +00:00
|
|
|
if err != nil {
|
2019-09-11 03:37:12 +00:00
|
|
|
logrus.Error("PopulateMissingHeaders: Error getting missing block numbers: ", err)
|
2019-01-11 09:58:41 +00:00
|
|
|
return 0, err
|
2019-02-14 15:03:57 +00:00
|
|
|
} else if len(blockNumbers) == 0 {
|
|
|
|
return 0, nil
|
2019-01-11 09:58:41 +00:00
|
|
|
}
|
|
|
|
|
2019-09-11 03:37:12 +00:00
|
|
|
logrus.Debug(getBlockRangeString(blockNumbers))
|
2019-05-10 16:28:20 +00:00
|
|
|
_, err = RetrieveAndUpdateHeaders(blockChain, headerRepository, blockNumbers)
|
2018-12-14 11:11:48 +00:00
|
|
|
if err != nil {
|
2019-09-11 03:37:12 +00:00
|
|
|
logrus.Error("PopulateMissingHeaders: Error getting/updating headers: ", err)
|
2018-12-14 11:11:48 +00:00
|
|
|
return 0, err
|
|
|
|
}
|
|
|
|
return len(blockNumbers), nil
|
2018-07-17 21:23:07 +00:00
|
|
|
}
|
|
|
|
|
2019-05-10 16:28:20 +00:00
|
|
|
func RetrieveAndUpdateHeaders(blockChain core.BlockChain, headerRepository datastore.HeaderRepository, blockNumbers []int64) (int, error) {
|
|
|
|
headers, err := blockChain.GetHeadersByNumbers(blockNumbers)
|
2018-12-12 16:01:50 +00:00
|
|
|
for _, header := range headers {
|
2018-08-14 21:59:41 +00:00
|
|
|
_, err = headerRepository.CreateOrUpdateHeader(header)
|
2018-07-24 16:38:49 +00:00
|
|
|
if err != nil {
|
2018-07-26 21:15:24 +00:00
|
|
|
if err == repositories.ErrValidHeaderExists {
|
|
|
|
continue
|
|
|
|
}
|
2018-07-24 16:38:49 +00:00
|
|
|
return 0, err
|
|
|
|
}
|
2018-07-17 21:23:07 +00:00
|
|
|
}
|
2018-07-24 16:38:49 +00:00
|
|
|
return len(blockNumbers), nil
|
2018-07-17 21:23:07 +00:00
|
|
|
}
|