2019-08-21 19:50:27 +00:00
|
|
|
package blockchain
|
|
|
|
|
|
|
|
import (
|
2019-11-19 16:12:50 +00:00
|
|
|
"context"
|
2019-08-22 16:41:05 +00:00
|
|
|
"time"
|
|
|
|
|
2019-08-28 20:14:00 +00:00
|
|
|
"github.com/gogo/protobuf/proto"
|
2019-11-27 05:08:18 +00:00
|
|
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
2019-08-23 01:13:56 +00:00
|
|
|
pb "github.com/prysmaticlabs/prysm/proto/beacon/p2p/v1"
|
2019-08-29 15:34:26 +00:00
|
|
|
"github.com/prysmaticlabs/prysm/shared/params"
|
2019-08-21 19:50:27 +00:00
|
|
|
)
|
|
|
|
|
2019-09-09 21:13:50 +00:00
|
|
|
// ChainInfoFetcher defines a common interface for methods in blockchain service which
|
2019-08-22 16:41:05 +00:00
|
|
|
// directly retrieves chain info related data.
|
2019-09-09 21:13:50 +00:00
|
|
|
type ChainInfoFetcher interface {
|
|
|
|
HeadFetcher
|
|
|
|
CanonicalRootFetcher
|
|
|
|
FinalizationFetcher
|
2019-08-22 16:41:05 +00:00
|
|
|
}
|
|
|
|
|
2019-09-16 20:45:03 +00:00
|
|
|
// GenesisTimeFetcher retrieves the Eth2 genesis timestamp.
|
|
|
|
type GenesisTimeFetcher interface {
|
|
|
|
GenesisTime() time.Time
|
|
|
|
}
|
|
|
|
|
2019-09-09 21:13:50 +00:00
|
|
|
// HeadFetcher defines a common interface for methods in blockchain service which
|
2019-08-22 16:41:05 +00:00
|
|
|
// directly retrieves head related data.
|
2019-09-09 21:13:50 +00:00
|
|
|
type HeadFetcher interface {
|
2019-08-21 19:50:27 +00:00
|
|
|
HeadSlot() uint64
|
|
|
|
HeadRoot() []byte
|
2019-08-23 01:13:56 +00:00
|
|
|
HeadBlock() *ethpb.BeaconBlock
|
2019-11-19 16:12:50 +00:00
|
|
|
HeadState(ctx context.Context) (*pb.BeaconState, error)
|
2019-08-22 16:41:05 +00:00
|
|
|
}
|
|
|
|
|
2019-09-09 21:13:50 +00:00
|
|
|
// CanonicalRootFetcher defines a common interface for methods in blockchain service which
|
2019-08-22 16:41:05 +00:00
|
|
|
// directly retrieves canonical roots related data.
|
2019-09-09 21:13:50 +00:00
|
|
|
type CanonicalRootFetcher interface {
|
2019-08-21 19:50:27 +00:00
|
|
|
CanonicalRoot(slot uint64) []byte
|
|
|
|
}
|
|
|
|
|
2019-10-01 14:36:36 +00:00
|
|
|
// ForkFetcher retrieves the current fork information of the Ethereum beacon chain.
|
|
|
|
type ForkFetcher interface {
|
|
|
|
CurrentFork() *pb.Fork
|
|
|
|
}
|
|
|
|
|
2019-09-09 21:13:50 +00:00
|
|
|
// FinalizationFetcher defines a common interface for methods in blockchain service which
|
2019-08-22 16:41:05 +00:00
|
|
|
// directly retrieves finalization related data.
|
2019-09-09 21:13:50 +00:00
|
|
|
type FinalizationFetcher interface {
|
2019-08-22 16:41:05 +00:00
|
|
|
FinalizedCheckpt() *ethpb.Checkpoint
|
|
|
|
}
|
|
|
|
|
2019-08-21 19:50:27 +00:00
|
|
|
// FinalizedCheckpt returns the latest finalized checkpoint tracked in fork choice service.
|
2019-09-07 02:39:14 +00:00
|
|
|
func (s *Service) FinalizedCheckpt() *ethpb.Checkpoint {
|
|
|
|
cp := s.forkChoiceStore.FinalizedCheckpt()
|
2019-08-29 15:34:26 +00:00
|
|
|
if cp != nil {
|
|
|
|
return cp
|
|
|
|
}
|
|
|
|
|
|
|
|
return ðpb.Checkpoint{Root: params.BeaconConfig().ZeroHash[:]}
|
2019-08-21 19:50:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// HeadSlot returns the slot of the head of the chain.
|
2019-09-07 02:39:14 +00:00
|
|
|
func (s *Service) HeadSlot() uint64 {
|
2019-09-23 19:24:42 +00:00
|
|
|
s.headLock.RLock()
|
|
|
|
defer s.headLock.RUnlock()
|
|
|
|
|
2019-09-07 02:39:14 +00:00
|
|
|
return s.headSlot
|
2019-08-21 19:50:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// HeadRoot returns the root of the head of the chain.
|
2019-09-07 02:39:14 +00:00
|
|
|
func (s *Service) HeadRoot() []byte {
|
2019-09-23 19:24:42 +00:00
|
|
|
s.headLock.RLock()
|
|
|
|
defer s.headLock.RUnlock()
|
2019-08-21 19:50:27 +00:00
|
|
|
|
2019-09-07 02:39:14 +00:00
|
|
|
root := s.canonicalRoots[s.headSlot]
|
2019-08-29 15:34:26 +00:00
|
|
|
if len(root) != 0 {
|
|
|
|
return root
|
|
|
|
}
|
|
|
|
|
|
|
|
return params.BeaconConfig().ZeroHash[:]
|
2019-08-21 19:50:27 +00:00
|
|
|
}
|
|
|
|
|
2019-08-23 01:13:56 +00:00
|
|
|
// HeadBlock returns the head block of the chain.
|
2019-09-07 02:39:14 +00:00
|
|
|
func (s *Service) HeadBlock() *ethpb.BeaconBlock {
|
2019-09-23 19:24:42 +00:00
|
|
|
s.headLock.RLock()
|
|
|
|
defer s.headLock.RUnlock()
|
|
|
|
|
2019-09-07 02:39:14 +00:00
|
|
|
return proto.Clone(s.headBlock).(*ethpb.BeaconBlock)
|
2019-08-23 01:13:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// HeadState returns the head state of the chain.
|
2019-11-19 16:12:50 +00:00
|
|
|
// If the head state is nil from service struct,
|
|
|
|
// it will attempt to get from DB and error if nil again.
|
|
|
|
func (s *Service) HeadState(ctx context.Context) (*pb.BeaconState, error) {
|
2019-09-23 19:24:42 +00:00
|
|
|
s.headLock.RLock()
|
|
|
|
defer s.headLock.RUnlock()
|
|
|
|
|
2019-11-19 16:12:50 +00:00
|
|
|
if s.headState == nil {
|
2019-12-04 23:48:30 +00:00
|
|
|
return s.beaconDB.HeadState(ctx)
|
2019-11-19 16:12:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return proto.Clone(s.headState).(*pb.BeaconState), nil
|
2019-08-23 01:13:56 +00:00
|
|
|
}
|
|
|
|
|
2019-08-21 19:50:27 +00:00
|
|
|
// CanonicalRoot returns the canonical root of a given slot.
|
2019-09-07 02:39:14 +00:00
|
|
|
func (s *Service) CanonicalRoot(slot uint64) []byte {
|
2019-09-23 19:24:42 +00:00
|
|
|
s.headLock.RLock()
|
|
|
|
defer s.headLock.RUnlock()
|
2019-08-21 19:50:27 +00:00
|
|
|
|
2019-09-07 02:39:14 +00:00
|
|
|
return s.canonicalRoots[slot]
|
2019-08-21 19:50:27 +00:00
|
|
|
}
|
2019-08-22 16:41:05 +00:00
|
|
|
|
|
|
|
// GenesisTime returns the genesis time of beacon chain.
|
2019-09-07 02:39:14 +00:00
|
|
|
func (s *Service) GenesisTime() time.Time {
|
|
|
|
return s.genesisTime
|
2019-08-22 16:41:05 +00:00
|
|
|
}
|
2019-10-01 14:36:36 +00:00
|
|
|
|
|
|
|
// CurrentFork retrieves the latest fork information of the beacon chain.
|
|
|
|
func (s *Service) CurrentFork() *pb.Fork {
|
2019-10-29 05:23:55 +00:00
|
|
|
if s.headState == nil {
|
|
|
|
return &pb.Fork{
|
|
|
|
PreviousVersion: params.BeaconConfig().GenesisForkVersion,
|
|
|
|
CurrentVersion: params.BeaconConfig().GenesisForkVersion,
|
|
|
|
}
|
|
|
|
}
|
2019-10-01 14:36:36 +00:00
|
|
|
return proto.Clone(s.headState.Fork).(*pb.Fork)
|
|
|
|
}
|