mirror of
https://github.com/sigp/lighthouse.git
synced 2026-04-21 06:48:27 +00:00
Closes: - https://github.com/sigp/lighthouse/issues/8958 - Update the `HotColdStore` to handle storage of cold states. - Update `BeaconSnapshot` to hold the execution envelope. This is required to make `chain_dump`-related checks sane, and will be generally useful (see: https://github.com/sigp/lighthouse/issues/8956). - Bug fix in the `BlockReplayer` for the case where the starting state is already `Full` (we should not try to apply another payload). This happens on the cold DB path because we try to replay from the closest cached state (which is often full). - Update `test_gloas_hot_state_hierarchy` to cover the cold DB migration. Co-Authored-By: Michael Sproul <michael@sigmaprime.io> Co-Authored-By: Michael Sproul <michaelsproul@users.noreply.github.com>
75 lines
2.7 KiB
Rust
75 lines
2.7 KiB
Rust
use serde::Serialize;
|
|
use std::sync::Arc;
|
|
use types::{
|
|
AbstractExecPayload, BeaconState, EthSpec, FullPayload, Hash256, SignedBeaconBlock,
|
|
SignedBlindedBeaconBlock, SignedExecutionPayloadEnvelope,
|
|
};
|
|
|
|
/// Represents some block and its associated state. Generally, this will be used for tracking the
|
|
/// head, justified head and finalized head.
|
|
#[derive(Clone, Serialize, PartialEq, Debug)]
|
|
pub struct BeaconSnapshot<E: EthSpec, Payload: AbstractExecPayload<E> = FullPayload<E>> {
|
|
pub beacon_block: Arc<SignedBeaconBlock<E, Payload>>,
|
|
pub execution_envelope: Option<Arc<SignedExecutionPayloadEnvelope<E>>>,
|
|
pub beacon_block_root: Hash256,
|
|
pub beacon_state: BeaconState<E>,
|
|
}
|
|
|
|
/// This snapshot is to be used for verifying a child of `self.beacon_block`.
|
|
#[derive(Debug)]
|
|
pub struct PreProcessingSnapshot<T: EthSpec> {
|
|
/// This state is equivalent to the `self.beacon_block.state_root()` state that has been
|
|
/// advanced forward one slot using `per_slot_processing`. This state is "primed and ready" for
|
|
/// the application of another block.
|
|
pub pre_state: BeaconState<T>,
|
|
/// This value is only set to `Some` if the `pre_state` was *not* advanced forward.
|
|
pub beacon_state_root: Option<Hash256>,
|
|
pub beacon_block: SignedBlindedBeaconBlock<T>,
|
|
pub beacon_block_root: Hash256,
|
|
}
|
|
|
|
impl<E: EthSpec, Payload: AbstractExecPayload<E>> BeaconSnapshot<E, Payload> {
|
|
/// Create a new checkpoint.
|
|
pub fn new(
|
|
beacon_block: Arc<SignedBeaconBlock<E, Payload>>,
|
|
execution_envelope: Option<Arc<SignedExecutionPayloadEnvelope<E>>>,
|
|
beacon_block_root: Hash256,
|
|
beacon_state: BeaconState<E>,
|
|
) -> Self {
|
|
Self {
|
|
beacon_block,
|
|
execution_envelope,
|
|
beacon_block_root,
|
|
beacon_state,
|
|
}
|
|
}
|
|
|
|
/// Returns the state root from `self.beacon_block` or `self.execution_envelope` as
|
|
/// appropriate.
|
|
///
|
|
/// ## Caution
|
|
///
|
|
/// It is not strictly enforced that `root(self.beacon_state) == self.beacon_state_root()`.
|
|
pub fn beacon_state_root(&self) -> Hash256 {
|
|
if let Some(ref envelope) = self.execution_envelope {
|
|
envelope.message.state_root
|
|
} else {
|
|
self.beacon_block.message().state_root()
|
|
}
|
|
}
|
|
|
|
/// Update all fields of the checkpoint.
|
|
pub fn update(
|
|
&mut self,
|
|
beacon_block: Arc<SignedBeaconBlock<E, Payload>>,
|
|
execution_envelope: Option<Arc<SignedExecutionPayloadEnvelope<E>>>,
|
|
beacon_block_root: Hash256,
|
|
beacon_state: BeaconState<E>,
|
|
) {
|
|
self.beacon_block = beacon_block;
|
|
self.execution_envelope = execution_envelope;
|
|
self.beacon_block_root = beacon_block_root;
|
|
self.beacon_state = beacon_state;
|
|
}
|
|
}
|