mirror of
https://github.com/paradigmxyz/reth.git
synced 2026-02-19 03:04:27 -05:00
feat(storage-api): move BlockExecutionWriter trait from provider to storage-api (#15798)
Co-authored-by: Matthias Seitz <matthias.seitz@outlook.de>
This commit is contained in:
@@ -1,58 +1,6 @@
|
||||
use alloy_primitives::BlockNumber;
|
||||
use reth_db_api::models::StoredBlockBodyIndices;
|
||||
use reth_execution_types::{Chain, ExecutionOutcome};
|
||||
use reth_node_types::NodePrimitives;
|
||||
use reth_primitives_traits::{Block, RecoveredBlock};
|
||||
use reth_storage_api::{NodePrimitivesProvider, StorageLocation};
|
||||
use reth_execution_types::ExecutionOutcome;
|
||||
use reth_storage_errors::provider::ProviderResult;
|
||||
use reth_trie::{updates::TrieUpdates, HashedPostStateSorted};
|
||||
|
||||
/// `BlockExecution` Writer
|
||||
pub trait BlockExecutionWriter:
|
||||
NodePrimitivesProvider<Primitives: NodePrimitives<Block = Self::Block>> + BlockWriter + Send + Sync
|
||||
{
|
||||
/// Take all of the blocks above the provided number and their execution result
|
||||
///
|
||||
/// The passed block number will stay in the database.
|
||||
///
|
||||
/// Accepts [`StorageLocation`] specifying from where should transactions and receipts be
|
||||
/// removed.
|
||||
fn take_block_and_execution_above(
|
||||
&self,
|
||||
block: BlockNumber,
|
||||
remove_from: StorageLocation,
|
||||
) -> ProviderResult<Chain<Self::Primitives>>;
|
||||
|
||||
/// Remove all of the blocks above the provided number and their execution result
|
||||
///
|
||||
/// The passed block number will stay in the database.
|
||||
///
|
||||
/// Accepts [`StorageLocation`] specifying from where should transactions and receipts be
|
||||
/// removed.
|
||||
fn remove_block_and_execution_above(
|
||||
&self,
|
||||
block: BlockNumber,
|
||||
remove_from: StorageLocation,
|
||||
) -> ProviderResult<()>;
|
||||
}
|
||||
|
||||
impl<T: BlockExecutionWriter> BlockExecutionWriter for &T {
|
||||
fn take_block_and_execution_above(
|
||||
&self,
|
||||
block: BlockNumber,
|
||||
remove_from: StorageLocation,
|
||||
) -> ProviderResult<Chain<Self::Primitives>> {
|
||||
(*self).take_block_and_execution_above(block, remove_from)
|
||||
}
|
||||
|
||||
fn remove_block_and_execution_above(
|
||||
&self,
|
||||
block: BlockNumber,
|
||||
remove_from: StorageLocation,
|
||||
) -> ProviderResult<()> {
|
||||
(*self).remove_block_and_execution_above(block, remove_from)
|
||||
}
|
||||
}
|
||||
|
||||
/// This just receives state, or [`ExecutionOutcome`], from the provider
|
||||
#[auto_impl::auto_impl(&, Arc, Box)]
|
||||
@@ -66,75 +14,3 @@ pub trait StateReader: Send + Sync {
|
||||
block: BlockNumber,
|
||||
) -> ProviderResult<Option<ExecutionOutcome<Self::Receipt>>>;
|
||||
}
|
||||
|
||||
/// Block Writer
|
||||
#[auto_impl::auto_impl(&, Arc, Box)]
|
||||
pub trait BlockWriter: Send + Sync {
|
||||
/// The body this writer can write.
|
||||
type Block: Block;
|
||||
/// The receipt type for [`ExecutionOutcome`].
|
||||
type Receipt: Send + Sync;
|
||||
|
||||
/// Insert full block and make it canonical. Parent tx num and transition id is taken from
|
||||
/// parent block in database.
|
||||
///
|
||||
/// Return [StoredBlockBodyIndices] that contains indices of the first and last transactions and
|
||||
/// transition in the block.
|
||||
///
|
||||
/// Accepts [`StorageLocation`] value which specifies where transactions and headers should be
|
||||
/// written.
|
||||
fn insert_block(
|
||||
&self,
|
||||
block: RecoveredBlock<Self::Block>,
|
||||
write_to: StorageLocation,
|
||||
) -> ProviderResult<StoredBlockBodyIndices>;
|
||||
|
||||
/// Appends a batch of block bodies extending the canonical chain. This is invoked during
|
||||
/// `Bodies` stage and does not write to `TransactionHashNumbers` and `TransactionSenders`
|
||||
/// tables which are populated on later stages.
|
||||
///
|
||||
/// Bodies are passed as [`Option`]s, if body is `None` the corresponding block is empty.
|
||||
fn append_block_bodies(
|
||||
&self,
|
||||
bodies: Vec<(BlockNumber, Option<<Self::Block as Block>::Body>)>,
|
||||
write_to: StorageLocation,
|
||||
) -> ProviderResult<()>;
|
||||
|
||||
/// Removes all blocks above the given block number from the database.
|
||||
///
|
||||
/// Note: This does not remove state or execution data.
|
||||
fn remove_blocks_above(
|
||||
&self,
|
||||
block: BlockNumber,
|
||||
remove_from: StorageLocation,
|
||||
) -> ProviderResult<()>;
|
||||
|
||||
/// Removes all block bodies above the given block number from the database.
|
||||
fn remove_bodies_above(
|
||||
&self,
|
||||
block: BlockNumber,
|
||||
remove_from: StorageLocation,
|
||||
) -> ProviderResult<()>;
|
||||
|
||||
/// Appends a batch of sealed blocks to the blockchain, including sender information, and
|
||||
/// updates the post-state.
|
||||
///
|
||||
/// Inserts the blocks into the database and updates the state with
|
||||
/// provided `BundleState`.
|
||||
///
|
||||
/// # Parameters
|
||||
///
|
||||
/// - `blocks`: Vector of `RecoveredBlock` instances to append.
|
||||
/// - `state`: Post-state information to update after appending.
|
||||
///
|
||||
/// # Returns
|
||||
///
|
||||
/// Returns `Ok(())` on success, or an error if any operation fails.
|
||||
fn append_blocks_with_state(
|
||||
&self,
|
||||
blocks: Vec<RecoveredBlock<Self::Block>>,
|
||||
execution_outcome: &ExecutionOutcome<Self::Receipt>,
|
||||
hashed_state: HashedPostStateSorted,
|
||||
trie_updates: TrieUpdates,
|
||||
) -> ProviderResult<()>;
|
||||
}
|
||||
|
||||
127
crates/storage/storage-api/src/block_writer.rs
Normal file
127
crates/storage/storage-api/src/block_writer.rs
Normal file
@@ -0,0 +1,127 @@
|
||||
use crate::{NodePrimitivesProvider, StorageLocation};
|
||||
use alloc::vec::Vec;
|
||||
use alloy_primitives::BlockNumber;
|
||||
use reth_db_models::StoredBlockBodyIndices;
|
||||
use reth_execution_types::{Chain, ExecutionOutcome};
|
||||
use reth_primitives_traits::{Block, NodePrimitives, RecoveredBlock};
|
||||
use reth_storage_errors::provider::ProviderResult;
|
||||
use reth_trie_common::{updates::TrieUpdates, HashedPostStateSorted};
|
||||
|
||||
/// `BlockExecution` Writer
|
||||
pub trait BlockExecutionWriter:
|
||||
NodePrimitivesProvider<Primitives: NodePrimitives<Block = Self::Block>> + BlockWriter + Send + Sync
|
||||
{
|
||||
/// Take all of the blocks above the provided number and their execution result
|
||||
///
|
||||
/// The passed block number will stay in the database.
|
||||
///
|
||||
/// Accepts [`StorageLocation`] specifying from where should transactions and receipts be
|
||||
/// removed.
|
||||
fn take_block_and_execution_above(
|
||||
&self,
|
||||
block: BlockNumber,
|
||||
remove_from: StorageLocation,
|
||||
) -> ProviderResult<Chain<Self::Primitives>>;
|
||||
|
||||
/// Remove all of the blocks above the provided number and their execution result
|
||||
///
|
||||
/// The passed block number will stay in the database.
|
||||
///
|
||||
/// Accepts [`StorageLocation`] specifying from where should transactions and receipts be
|
||||
/// removed.
|
||||
fn remove_block_and_execution_above(
|
||||
&self,
|
||||
block: BlockNumber,
|
||||
remove_from: StorageLocation,
|
||||
) -> ProviderResult<()>;
|
||||
}
|
||||
|
||||
impl<T: BlockExecutionWriter> BlockExecutionWriter for &T {
|
||||
fn take_block_and_execution_above(
|
||||
&self,
|
||||
block: BlockNumber,
|
||||
remove_from: StorageLocation,
|
||||
) -> ProviderResult<Chain<Self::Primitives>> {
|
||||
(*self).take_block_and_execution_above(block, remove_from)
|
||||
}
|
||||
|
||||
fn remove_block_and_execution_above(
|
||||
&self,
|
||||
block: BlockNumber,
|
||||
remove_from: StorageLocation,
|
||||
) -> ProviderResult<()> {
|
||||
(*self).remove_block_and_execution_above(block, remove_from)
|
||||
}
|
||||
}
|
||||
|
||||
/// Block Writer
|
||||
#[auto_impl::auto_impl(&, Arc, Box)]
|
||||
pub trait BlockWriter: Send + Sync {
|
||||
/// The body this writer can write.
|
||||
type Block: Block;
|
||||
/// The receipt type for [`ExecutionOutcome`].
|
||||
type Receipt: Send + Sync;
|
||||
|
||||
/// Insert full block and make it canonical. Parent tx num and transition id is taken from
|
||||
/// parent block in database.
|
||||
///
|
||||
/// Return [StoredBlockBodyIndices] that contains indices of the first and last transactions and
|
||||
/// transition in the block.
|
||||
///
|
||||
/// Accepts [`StorageLocation`] value which specifies where transactions and headers should be
|
||||
/// written.
|
||||
fn insert_block(
|
||||
&self,
|
||||
block: RecoveredBlock<Self::Block>,
|
||||
write_to: StorageLocation,
|
||||
) -> ProviderResult<StoredBlockBodyIndices>;
|
||||
|
||||
/// Appends a batch of block bodies extending the canonical chain. This is invoked during
|
||||
/// `Bodies` stage and does not write to `TransactionHashNumbers` and `TransactionSenders`
|
||||
/// tables which are populated on later stages.
|
||||
///
|
||||
/// Bodies are passed as [`Option`]s, if body is `None` the corresponding block is empty.
|
||||
fn append_block_bodies(
|
||||
&self,
|
||||
bodies: Vec<(BlockNumber, Option<<Self::Block as Block>::Body>)>,
|
||||
write_to: StorageLocation,
|
||||
) -> ProviderResult<()>;
|
||||
|
||||
/// Removes all blocks above the given block number from the database.
|
||||
///
|
||||
/// Note: This does not remove state or execution data.
|
||||
fn remove_blocks_above(
|
||||
&self,
|
||||
block: BlockNumber,
|
||||
remove_from: StorageLocation,
|
||||
) -> ProviderResult<()>;
|
||||
|
||||
/// Removes all block bodies above the given block number from the database.
|
||||
fn remove_bodies_above(
|
||||
&self,
|
||||
block: BlockNumber,
|
||||
remove_from: StorageLocation,
|
||||
) -> ProviderResult<()>;
|
||||
|
||||
/// Appends a batch of sealed blocks to the blockchain, including sender information, and
|
||||
/// updates the post-state.
|
||||
///
|
||||
/// Inserts the blocks into the database and updates the state with
|
||||
/// provided `BundleState`.
|
||||
///
|
||||
/// # Parameters
|
||||
///
|
||||
/// - `blocks`: Vector of `RecoveredBlock` instances to append.
|
||||
/// - `state`: Post-state information to update after appending.
|
||||
///
|
||||
/// # Returns
|
||||
///
|
||||
/// Returns `Ok(())` on success, or an error if any operation fails.
|
||||
fn append_blocks_with_state(
|
||||
&self,
|
||||
blocks: Vec<RecoveredBlock<Self::Block>>,
|
||||
execution_outcome: &ExecutionOutcome<Self::Receipt>,
|
||||
hashed_state: HashedPostStateSorted,
|
||||
trie_updates: TrieUpdates,
|
||||
) -> ProviderResult<()>;
|
||||
}
|
||||
@@ -93,3 +93,6 @@ pub use primitives::*;
|
||||
|
||||
mod block_indices;
|
||||
pub use block_indices::*;
|
||||
|
||||
mod block_writer;
|
||||
pub use block_writer::*;
|
||||
|
||||
Reference in New Issue
Block a user