mirror of
https://github.com/sigp/lighthouse.git
synced 2026-04-21 23:08:23 +00:00
Gloas fork choice redux (#9025)
Co-Authored-By: hopinheimer <knmanas6@gmail.com> Co-Authored-By: Michael Sproul <michael@sigmaprime.io> Co-Authored-By: hopinheimer <48147533+hopinheimer@users.noreply.github.com> Co-Authored-By: Eitan Seri- Levi <eserilev@gmail.com> Co-Authored-By: dapplion <35266934+dapplion@users.noreply.github.com> Co-Authored-By: Michael Sproul <michaelsproul@users.noreply.github.com> Co-Authored-By: Jimmy Chen <jchen.tc@gmail.com> Co-Authored-By: Daniel Knopik <107140945+dknopik@users.noreply.github.com>
This commit is contained in:
@@ -6,11 +6,19 @@ use superstruct::superstruct;
|
||||
use types::Hash256;
|
||||
|
||||
// If adding a new version you should update this type alias and fix the breakages.
|
||||
pub type PersistedForkChoice = PersistedForkChoiceV28;
|
||||
pub type PersistedForkChoice = PersistedForkChoiceV29;
|
||||
|
||||
#[superstruct(variants(V28), variant_attributes(derive(Encode, Decode)), no_enum)]
|
||||
#[superstruct(
|
||||
variants(V28, V29),
|
||||
variant_attributes(derive(Encode, Decode)),
|
||||
no_enum
|
||||
)]
|
||||
pub struct PersistedForkChoice {
|
||||
pub fork_choice: fork_choice::PersistedForkChoiceV28,
|
||||
#[superstruct(only(V28))]
|
||||
pub fork_choice_v28: fork_choice::PersistedForkChoiceV28,
|
||||
#[superstruct(only(V29))]
|
||||
pub fork_choice: fork_choice::PersistedForkChoiceV29,
|
||||
#[superstruct(only(V28, V29))]
|
||||
pub fork_choice_store: PersistedForkChoiceStoreV28,
|
||||
}
|
||||
|
||||
@@ -45,3 +53,53 @@ impl PersistedForkChoiceV28 {
|
||||
))
|
||||
}
|
||||
}
|
||||
|
||||
impl PersistedForkChoiceV29 {
|
||||
pub fn from_bytes(bytes: &[u8], store_config: &StoreConfig) -> Result<Self, Error> {
|
||||
let decompressed_bytes = store_config
|
||||
.decompress_bytes(bytes)
|
||||
.map_err(Error::Compression)?;
|
||||
Self::from_ssz_bytes(&decompressed_bytes).map_err(Into::into)
|
||||
}
|
||||
|
||||
pub fn as_bytes(&self, store_config: &StoreConfig) -> Result<Vec<u8>, Error> {
|
||||
let encode_timer = metrics::start_timer(&metrics::FORK_CHOICE_ENCODE_TIMES);
|
||||
let ssz_bytes = self.as_ssz_bytes();
|
||||
drop(encode_timer);
|
||||
|
||||
let _compress_timer = metrics::start_timer(&metrics::FORK_CHOICE_COMPRESS_TIMES);
|
||||
store_config
|
||||
.compress_bytes(&ssz_bytes)
|
||||
.map_err(Error::Compression)
|
||||
}
|
||||
|
||||
pub fn as_kv_store_op(
|
||||
&self,
|
||||
key: Hash256,
|
||||
store_config: &StoreConfig,
|
||||
) -> Result<KeyValueStoreOp, Error> {
|
||||
Ok(KeyValueStoreOp::PutKeyValue(
|
||||
DBColumn::ForkChoice,
|
||||
key.as_slice().to_vec(),
|
||||
self.as_bytes(store_config)?,
|
||||
))
|
||||
}
|
||||
}
|
||||
|
||||
impl From<PersistedForkChoiceV28> for PersistedForkChoiceV29 {
|
||||
fn from(v28: PersistedForkChoiceV28) -> Self {
|
||||
Self {
|
||||
fork_choice: v28.fork_choice_v28.into(),
|
||||
fork_choice_store: v28.fork_choice_store,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl From<PersistedForkChoiceV29> for PersistedForkChoiceV28 {
|
||||
fn from(v29: PersistedForkChoiceV29) -> Self {
|
||||
Self {
|
||||
fork_choice_v28: v29.fork_choice.into(),
|
||||
fork_choice_store: v29.fork_choice_store,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user