// 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. package state import ( "time" types "github.com/prysmaticlabs/eth2-types" "github.com/prysmaticlabs/prysm/proto/prysm/v1alpha1/block" ) 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 // Synced is sent when the beacon node has completed syncing and is ready to participate in the network. Synced // 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 // FinalizedCheckpoint event. FinalizedCheckpoint // NewHead of the chain event. NewHead ) // BlockProcessedData is the data sent with BlockProcessed events. type BlockProcessedData struct { // Slot is the slot of the processed block. Slot types.Slot // BlockRoot of the processed block. BlockRoot [32]byte // SignedBlock is the physical processed block. SignedBlock block.SignedBeaconBlock // 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 } // SyncedData is the data sent with Synced events. type SyncedData struct { // StartTime is the time at which the chain started. StartTime time.Time } // InitializedData is the data sent with Initialized events. type InitializedData struct { // StartTime is the time at which the chain started. StartTime time.Time // GenesisValidatorsRoot represents state.validators.HashTreeRoot(). GenesisValidatorsRoot []byte }