-
Notifications
You must be signed in to change notification settings - Fork 52
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix(client): SyncStart Refactor (#797)
* feat: abstract pipeline * fix(client): sync start refactor * small fix
- Loading branch information
Showing
6 changed files
with
125 additions
and
116 deletions.
There are no files selected for viewing
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -10,6 +10,8 @@ pub mod l1; | |
|
||
pub mod l2; | ||
|
||
pub mod sync; | ||
|
||
pub mod errors; | ||
|
||
pub mod executor; | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,79 @@ | ||
//! Sync Start | ||
use crate::{ | ||
errors::OracleProviderError, l1::OracleL1ChainProvider, l2::OracleL2ChainProvider, BootInfo, | ||
FlushableCache, HintType, | ||
}; | ||
use alloc::sync::Arc; | ||
use alloy_consensus::Sealed; | ||
use core::fmt::Debug; | ||
use kona_derive::traits::ChainProvider; | ||
use kona_driver::SyncCursor; | ||
use kona_mpt::TrieProvider; | ||
use kona_preimage::{CommsClient, PreimageKey, PreimageKeyType}; | ||
use op_alloy_protocol::{BatchValidationProvider, BlockInfo}; | ||
|
||
/// Sync Start | ||
#[derive(Debug, Clone)] | ||
pub struct SyncStart { | ||
/// The l1 origin block info. | ||
pub origin: BlockInfo, | ||
/// The sync cursor used for the derivation driver. | ||
pub cursor: SyncCursor, | ||
} | ||
|
||
impl SyncStart { | ||
/// Constructs the [`SyncStart`] from the caching oracle, boot info, and providers. | ||
pub async fn from<O>( | ||
caching_oracle: Arc<O>, | ||
boot_info: &BootInfo, | ||
chain_provider: &mut OracleL1ChainProvider<O>, | ||
l2_chain_provider: &mut OracleL2ChainProvider<O>, | ||
) -> Result<Self, OracleProviderError> | ||
where | ||
O: CommsClient + FlushableCache + FlushableCache + Send + Sync + Debug, | ||
{ | ||
// Find the initial safe head, based off of the starting L2 block number in the boot info. | ||
caching_oracle | ||
.write( | ||
&HintType::StartingL2Output | ||
.encode_with(&[boot_info.agreed_l2_output_root.as_ref()]), | ||
) | ||
.await | ||
.map_err(OracleProviderError::Preimage)?; | ||
let mut output_preimage = [0u8; 128]; | ||
caching_oracle | ||
.get_exact( | ||
PreimageKey::new(*boot_info.agreed_l2_output_root, PreimageKeyType::Keccak256), | ||
&mut output_preimage, | ||
) | ||
.await | ||
.map_err(OracleProviderError::Preimage)?; | ||
|
||
let safe_hash = | ||
output_preimage[96..128].try_into().map_err(OracleProviderError::SliceConversion)?; | ||
let safe_header = l2_chain_provider.header_by_hash(safe_hash)?; | ||
let safe_head_info = l2_chain_provider.l2_block_info_by_number(safe_header.number).await?; | ||
let l1_origin = | ||
chain_provider.block_info_by_number(safe_head_info.l1_origin.number).await?; | ||
|
||
// Construct the sync cursor for the pipeline driver. | ||
let cursor = SyncCursor::new( | ||
safe_head_info, | ||
Sealed::new_unchecked(safe_header, safe_hash), | ||
boot_info.agreed_l2_output_root, | ||
); | ||
|
||
// Walk back the starting L1 block by `channel_timeout` to ensure that the full channel is | ||
// captured. | ||
let channel_timeout = | ||
boot_info.rollup_config.channel_timeout(safe_head_info.block_info.timestamp); | ||
let mut l1_origin_number = l1_origin.number.saturating_sub(channel_timeout); | ||
if l1_origin_number < boot_info.rollup_config.genesis.l1.number { | ||
l1_origin_number = boot_info.rollup_config.genesis.l1.number; | ||
} | ||
let origin = chain_provider.block_info_by_number(l1_origin_number).await?; | ||
|
||
Ok(Self { origin, cursor }) | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters