2020-04-29 17:40:33 +00:00
|
|
|
// Package state contains types for state operation-specific events fired
|
|
|
|
// during the runtime of a beacon node such state initialization, state updates,
|
|
|
|
// and chain start.
|
2019-12-07 17:57:26 +00:00
|
|
|
package state
|
|
|
|
|
2021-01-05 20:40:11 +00:00
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
2021-02-16 07:45:34 +00:00
|
|
|
types "github.com/prysmaticlabs/eth2-types"
|
2021-01-05 20:40:11 +00:00
|
|
|
ethpb "github.com/prysmaticlabs/ethereumapis/eth/v1alpha1"
|
|
|
|
)
|
2019-12-07 17:57:26 +00:00
|
|
|
|
|
|
|
const (
|
|
|
|
// BlockProcessed is sent after a block has been processed and updated the state database.
|
|
|
|
BlockProcessed = iota + 1
|
|
|
|
// ChainStarted is sent when enough validators are active to start proposing blocks.
|
|
|
|
ChainStarted
|
|
|
|
// Initialized is sent when the internal beacon node's state is ready to be accessed.
|
|
|
|
Initialized
|
2020-04-18 10:45:20 +00:00
|
|
|
// Synced is sent when the beacon node has completed syncing and is ready to participate in the network.
|
|
|
|
Synced
|
2020-05-06 19:15:31 +00:00
|
|
|
// Reorg is an event sent when the new head state's slot after a block
|
|
|
|
// transition is lower than its previous head state slot value.
|
|
|
|
Reorg
|
2019-12-07 17:57:26 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// BlockProcessedData is the data sent with BlockProcessed events.
|
|
|
|
type BlockProcessedData struct {
|
2020-02-10 16:59:55 +00:00
|
|
|
// Slot is the slot of the processed block.
|
2021-02-16 07:45:34 +00:00
|
|
|
Slot types.Slot
|
2020-05-06 19:15:31 +00:00
|
|
|
// BlockRoot of the processed block.
|
2019-12-07 17:57:26 +00:00
|
|
|
BlockRoot [32]byte
|
2021-01-05 20:40:11 +00:00
|
|
|
// SignedBlock is the physical processed block.
|
|
|
|
SignedBlock *ethpb.SignedBeaconBlock
|
2019-12-07 17:57:26 +00:00
|
|
|
// Verified is true if the block's BLS contents have been verified.
|
|
|
|
Verified bool
|
|
|
|
}
|
|
|
|
|
|
|
|
// ChainStartedData is the data sent with ChainStarted events.
|
|
|
|
type ChainStartedData struct {
|
|
|
|
// StartTime is the time at which the chain started.
|
|
|
|
StartTime time.Time
|
|
|
|
}
|
|
|
|
|
2020-04-18 10:45:20 +00:00
|
|
|
// SyncedData is the data sent with Synced events.
|
|
|
|
type SyncedData struct {
|
|
|
|
// StartTime is the time at which the chain started.
|
|
|
|
StartTime time.Time
|
|
|
|
}
|
|
|
|
|
2019-12-07 17:57:26 +00:00
|
|
|
// InitializedData is the data sent with Initialized events.
|
|
|
|
type InitializedData struct {
|
|
|
|
// StartTime is the time at which the chain started.
|
|
|
|
StartTime time.Time
|
2020-08-27 18:13:32 +00:00
|
|
|
// GenesisValidatorsRoot represents state.validators.HashTreeRoot().
|
2020-04-14 20:27:03 +00:00
|
|
|
GenesisValidatorsRoot []byte
|
2019-12-07 17:57:26 +00:00
|
|
|
}
|
2020-05-06 19:15:31 +00:00
|
|
|
|
|
|
|
// ReorgData is the data alongside a reorg event.
|
|
|
|
type ReorgData struct {
|
|
|
|
// NewSlot is the slot of new state after the reorg.
|
2021-02-16 07:45:34 +00:00
|
|
|
NewSlot types.Slot
|
2020-05-06 19:15:31 +00:00
|
|
|
// OldSlot is the slot of the head state before the reorg.
|
2021-02-16 07:45:34 +00:00
|
|
|
OldSlot types.Slot
|
2020-05-06 19:15:31 +00:00
|
|
|
}
|