mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-15 14:38:20 +00:00
17a43c1158
* new stategen.StateReplayer/ReplayerBuilder to give more fine-grained control of replaying state+block history * all rpc/api methods updated to use the new interface, return post-state Co-authored-by: Kasey Kirkham <kasey@users.noreply.github.com> Co-authored-by: Radosław Kapka <rkapka@wp.pl> Co-authored-by: terence tsao <terence@prysmaticlabs.com>
78 lines
2.9 KiB
Go
78 lines
2.9 KiB
Go
package helpers
|
|
|
|
import (
|
|
"math"
|
|
|
|
"github.com/pkg/errors"
|
|
types "github.com/prysmaticlabs/eth2-types"
|
|
"github.com/prysmaticlabs/prysm/beacon-chain/state"
|
|
"github.com/prysmaticlabs/prysm/config/params"
|
|
"github.com/prysmaticlabs/prysm/proto/prysm/v1alpha1/block"
|
|
"github.com/prysmaticlabs/prysm/time/slots"
|
|
)
|
|
|
|
var ErrNilSignedBeaconBlock = errors.New("signed beacon block can't be nil")
|
|
var ErrNilBeaconBlock = errors.New("beacon block can't be nil")
|
|
var ErrNilBeaconBlockBody = errors.New("beacon block body can't be nil")
|
|
|
|
// BeaconBlockIsNil checks if any composite field of input signed beacon block is nil.
|
|
// Access to these nil fields will result in run time panic,
|
|
// it is recommended to run these checks as first line of defense.
|
|
func BeaconBlockIsNil(b block.SignedBeaconBlock) error {
|
|
if b == nil || b.IsNil() {
|
|
return ErrNilSignedBeaconBlock
|
|
}
|
|
if b.Block().IsNil() {
|
|
return ErrNilBeaconBlock
|
|
}
|
|
if b.Block().Body().IsNil() {
|
|
return ErrNilBeaconBlockBody
|
|
}
|
|
return nil
|
|
}
|
|
|
|
// BlockRootAtSlot returns the block root stored in the BeaconState for a recent slot.
|
|
// It returns an error if the requested block root is not within the slot range.
|
|
//
|
|
// Spec pseudocode definition:
|
|
// def get_block_root_at_slot(state: BeaconState, slot: Slot) -> Root:
|
|
// """
|
|
// Return the block root at a recent ``slot``.
|
|
// """
|
|
// assert slot < state.slot <= slot + SLOTS_PER_HISTORICAL_ROOT
|
|
// return state.block_roots[slot % SLOTS_PER_HISTORICAL_ROOT]
|
|
func BlockRootAtSlot(state state.ReadOnlyBeaconState, slot types.Slot) ([]byte, error) {
|
|
if math.MaxUint64-slot < params.BeaconConfig().SlotsPerHistoricalRoot {
|
|
return []byte{}, errors.New("slot overflows uint64")
|
|
}
|
|
if slot >= state.Slot() || state.Slot() > slot+params.BeaconConfig().SlotsPerHistoricalRoot {
|
|
return []byte{}, errors.Errorf("slot %d out of bounds", slot)
|
|
}
|
|
return state.BlockRootAtIndex(uint64(slot % params.BeaconConfig().SlotsPerHistoricalRoot))
|
|
}
|
|
|
|
// StateRootAtSlot returns the cached state root at that particular slot. If no state
|
|
// root has been cached it will return a zero-hash.
|
|
func StateRootAtSlot(state state.ReadOnlyBeaconState, slot types.Slot) ([]byte, error) {
|
|
if slot >= state.Slot() || state.Slot() > slot+params.BeaconConfig().SlotsPerHistoricalRoot {
|
|
return []byte{}, errors.Errorf("slot %d out of bounds", slot)
|
|
}
|
|
return state.StateRootAtIndex(uint64(slot % params.BeaconConfig().SlotsPerHistoricalRoot))
|
|
}
|
|
|
|
// BlockRoot returns the block root stored in the BeaconState for epoch start slot.
|
|
//
|
|
// Spec pseudocode definition:
|
|
// def get_block_root(state: BeaconState, epoch: Epoch) -> Root:
|
|
// """
|
|
// Return the block root at the start of a recent ``epoch``.
|
|
// """
|
|
// return get_block_root_at_slot(state, compute_start_slot_at_epoch(epoch))
|
|
func BlockRoot(state state.ReadOnlyBeaconState, epoch types.Epoch) ([]byte, error) {
|
|
s, err := slots.EpochStart(epoch)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return BlockRootAtSlot(state, s)
|
|
}
|