2022-03-30 22:23:34 +00:00
|
|
|
package genesis
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
|
|
|
"github.com/pkg/errors"
|
2023-03-17 18:52:56 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/v4/api/client/beacon"
|
|
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/db"
|
2022-03-30 22:23:34 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// APIInitializer manages initializing the genesis state and block to prepare the beacon node for syncing.
|
|
|
|
// The genesis state is retrieved from the remote beacon node api, using the debug state retrieval endpoint.
|
|
|
|
type APIInitializer struct {
|
|
|
|
c *beacon.Client
|
|
|
|
}
|
|
|
|
|
|
|
|
// NewAPIInitializer creates an APIInitializer, handling the set up of a beacon node api client
|
|
|
|
// using the provided host string.
|
|
|
|
func NewAPIInitializer(beaconNodeHost string) (*APIInitializer, error) {
|
|
|
|
c, err := beacon.NewClient(beaconNodeHost)
|
|
|
|
if err != nil {
|
|
|
|
return nil, errors.Wrapf(err, "unable to parse beacon node url or hostname - %s", beaconNodeHost)
|
|
|
|
}
|
|
|
|
return &APIInitializer{c: c}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Initialize downloads origin state and block for checkpoint sync and initializes database records to
|
|
|
|
// prepare the node to begin syncing from that point.
|
|
|
|
func (dl *APIInitializer) Initialize(ctx context.Context, d db.Database) error {
|
2022-06-14 23:23:25 +00:00
|
|
|
existing, err := d.GenesisState(ctx)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if existing != nil && !existing.IsNil() {
|
|
|
|
htr, err := existing.HashTreeRoot(ctx)
|
|
|
|
if err != nil {
|
|
|
|
return errors.Wrap(err, "error while computing hash_tree_root of existing genesis state")
|
|
|
|
}
|
|
|
|
log.Warnf("database contains genesis with htr=%#x, ignoring remote genesis state parameter", htr)
|
|
|
|
return nil
|
|
|
|
}
|
2022-03-30 22:23:34 +00:00
|
|
|
sb, err := dl.c.GetState(ctx, beacon.IdGenesis)
|
|
|
|
if err != nil {
|
|
|
|
return errors.Wrapf(err, "Error retrieving genesis state from %s", dl.c.NodeURL())
|
|
|
|
}
|
|
|
|
return d.LoadGenesis(ctx, sb)
|
|
|
|
}
|