op_alloy::genesis

Struct RollupConfig

Source
pub struct RollupConfig {
Show 25 fields pub genesis: ChainGenesis, pub block_time: u64, pub max_sequencer_drift: u64, pub seq_window_size: u64, pub channel_timeout: u64, pub granite_channel_timeout: u64, pub l1_chain_id: u64, pub l2_chain_id: u64, pub base_fee_params: BaseFeeParams, pub canyon_base_fee_params: BaseFeeParams, pub regolith_time: Option<u64>, pub canyon_time: Option<u64>, pub delta_time: Option<u64>, pub ecotone_time: Option<u64>, pub fjord_time: Option<u64>, pub granite_time: Option<u64>, pub holocene_time: Option<u64>, pub isthmus_time: Option<u64>, pub batch_inbox_address: Address, pub deposit_contract_address: Address, pub l1_system_config_address: Address, pub protocol_versions_address: Address, pub superchain_config_address: Option<Address>, pub blobs_enabled_l1_timestamp: Option<u64>, pub da_challenge_address: Option<Address>,
}
Available on crate feature genesis only.
Expand description

The Rollup configuration.

Fields§

§genesis: ChainGenesis

The genesis state of the rollup.

§block_time: u64

The block time of the L2, in seconds.

§max_sequencer_drift: u64

Sequencer batches may not be more than MaxSequencerDrift seconds after the L1 timestamp of the sequencing window end.

Note: When L1 has many 1 second consecutive blocks, and L2 grows at fixed 2 seconds, the L2 time may still grow beyond this difference.

Note: After the Fjord hardfork, this value becomes a constant of 1800.

§seq_window_size: u64

The sequencer window size.

§channel_timeout: u64

Number of L1 blocks between when a channel can be opened and when it can be closed.

§granite_channel_timeout: u64

The channel timeout after the Granite hardfork.

§l1_chain_id: u64

The L1 chain ID

§l2_chain_id: u64

The L2 chain ID

§base_fee_params: BaseFeeParams

Base Fee Params

§canyon_base_fee_params: BaseFeeParams

Base fee params post-canyon hardfork

§regolith_time: Option<u64>

regolith_time sets the activation time of the Regolith network-upgrade: a pre-mainnet Bedrock change that addresses findings of the Sherlock contest related to deposit attributes. “Regolith” is the loose deposited rock that sits on top of Bedrock. Active if regolith_time != None && L2 block timestamp >= Some(regolith_time), inactive otherwise.

§canyon_time: Option<u64>

canyon_time sets the activation time of the Canyon network upgrade. Active if canyon_time != None && L2 block timestamp >= Some(canyon_time), inactive otherwise.

§delta_time: Option<u64>

delta_time sets the activation time of the Delta network upgrade. Active if delta_time != None && L2 block timestamp >= Some(delta_time), inactive otherwise.

§ecotone_time: Option<u64>

ecotone_time sets the activation time of the Ecotone network upgrade. Active if ecotone_time != None && L2 block timestamp >= Some(ecotone_time), inactive otherwise.

§fjord_time: Option<u64>

fjord_time sets the activation time of the Fjord network upgrade. Active if fjord_time != None && L2 block timestamp >= Some(fjord_time), inactive otherwise.

§granite_time: Option<u64>

granite_time sets the activation time for the Granite network upgrade. Active if granite_time != None && L2 block timestamp >= Some(granite_time), inactive otherwise.

§holocene_time: Option<u64>

holocene_time sets the activation time for the Holocene network upgrade. Active if holocene_time != None && L2 block timestamp >= Some(holocene_time), inactive otherwise.

§isthmus_time: Option<u64>

isthmus_time sets the activation time for the Isthmus network upgrade. Active if isthmus_time != None && L2 block timestamp >= Some(isthmus_time), inactive otherwise.

§batch_inbox_address: Address

batch_inbox_address is the L1 address that batches are sent to.

§deposit_contract_address: Address

deposit_contract_address is the L1 address that deposits are sent to.

§l1_system_config_address: Address

l1_system_config_address is the L1 address that the system config is stored at.

§protocol_versions_address: Address

protocol_versions_address is the L1 address that the protocol versions are stored at.

§superchain_config_address: Option<Address>

The superchain config address.

§blobs_enabled_l1_timestamp: Option<u64>

blobs_enabled_l1_timestamp is the timestamp to start reading blobs as a batch data source. Optional.

§da_challenge_address: Option<Address>

da_challenge_address is the L1 address that the data availability challenge contract is stored at.

Implementations§

Source§

impl RollupConfig

Source

pub fn is_regolith_active(&self, timestamp: u64) -> bool

Returns true if Regolith is active at the given timestamp.

Source

pub fn is_canyon_active(&self, timestamp: u64) -> bool

Returns true if Canyon is active at the given timestamp.

Source

pub fn is_delta_active(&self, timestamp: u64) -> bool

Returns true if Delta is active at the given timestamp.

Source

pub fn is_ecotone_active(&self, timestamp: u64) -> bool

Returns true if Ecotone is active at the given timestamp.

Source

pub fn is_fjord_active(&self, timestamp: u64) -> bool

Returns true if Fjord is active at the given timestamp.

Source

pub fn is_granite_active(&self, timestamp: u64) -> bool

Returns true if Granite is active at the given timestamp.

Source

pub fn is_holocene_active(&self, timestamp: u64) -> bool

Returns true if Holocene is active at the given timestamp.

Source

pub fn is_isthmus_active(&self, timestamp: u64) -> bool

Returns true if Isthmus is active at the given timestamp.

Source

pub fn is_alt_da_enabled(&self) -> bool

Returns true if a DA Challenge proxy Address is provided in the rollup config and the address is not zero.

Source

pub fn max_sequencer_drift(&self, timestamp: u64) -> u64

Returns the max sequencer drift for the given timestamp.

Source

pub fn max_rlp_bytes_per_channel(&self, timestamp: u64) -> u64

Returns the max rlp bytes per channel for the given timestamp.

Source

pub fn channel_timeout(&self, timestamp: u64) -> u64

Returns the channel timeout for the given timestamp.

Source

pub const fn hardfork_config(&self) -> HardForkConfiguration

Returns the HardForkConfiguration using RollupConfig timestamps.

Source

pub fn check_ecotone_l1_system_config_scalar( scalar: [u8; 32], ) -> Result<(), &'static str>

Checks the scalar value in Ecotone.

Trait Implementations§

Source§

impl<'a> Arbitrary<'a> for RollupConfig

Available on crate feature arbitrary only.
Source§

fn arbitrary(u: &mut Unstructured<'a>) -> Result<RollupConfig, Error>

Generate an arbitrary value of Self from the given unstructured data. Read more
Source§

fn arbitrary_take_rest(u: Unstructured<'a>) -> Result<Self, Error>

Generate an arbitrary value of Self from the entirety of the given unstructured data. Read more
Source§

fn size_hint(depth: usize) -> (usize, Option<usize>)

Get a size hint for how many bytes out of an Unstructured this type needs to construct itself. Read more
Source§

fn try_size_hint( depth: usize, ) -> Result<(usize, Option<usize>), MaxRecursionReached>

Get a size hint for how many bytes out of an Unstructured this type needs to construct itself. Read more
Source§

impl Clone for RollupConfig

Source§

fn clone(&self) -> RollupConfig

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for RollupConfig

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl Default for RollupConfig

Source§

fn default() -> RollupConfig

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for RollupConfig

Source§

fn deserialize<__D>( __deserializer: __D, ) -> Result<RollupConfig, <__D as Deserializer<'de>>::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl PartialEq for RollupConfig

Source§

fn eq(&self, other: &RollupConfig) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for RollupConfig

Source§

fn serialize<__S>( &self, __serializer: __S, ) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Eq for RollupConfig

Source§

impl StructuralPartialEq for RollupConfig

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

Source§

impl<T> ErasedDestructor for T
where T: 'static,

Source§

impl<T> MaybeSend for T
where T: Send,

Source§

impl<T> MaybeSendSync for T

Source§

impl<T> RpcObject for T
where T: RpcParam + RpcReturn,

Source§

impl<T> RpcParam for T
where T: Serialize + Clone + Debug + Send + Sync + Unpin,

Source§

impl<T> RpcReturn for T
where T: DeserializeOwned + Debug + Send + Sync + Unpin + 'static,