Skip to content

Commit

Permalink
feat(papyrus_base_layer): add events api
Browse files Browse the repository at this point in the history
  • Loading branch information
Gilad Chase committed Dec 20, 2024
1 parent 0a5c0c0 commit b6f6138
Show file tree
Hide file tree
Showing 2 changed files with 41 additions and 1 deletion.
11 changes: 10 additions & 1 deletion crates/papyrus_base_layer/src/ethereum_base_layer_contract.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ use starknet_api::hash::StarkHash;
use starknet_types_core::felt;
use url::Url;

use crate::BaseLayerContract;
use crate::{BaseLayerContract, L1Event};

type EthereumBaseLayerResult<T> = Result<T, EthereumBaseLayerError>;

Expand Down Expand Up @@ -79,6 +79,15 @@ impl BaseLayerContract for EthereumBaseLayerContract {
}))
}

async fn events(
&self,
_from_block: u64,
_until_block: u64,
_event_identifiers: Vec<&str>,
) -> EthereumBaseLayerResult<Vec<L1Event>> {
todo!("Implmeneted in a subsequent commit")
}

async fn latest_l1_block_number(&self, finality: u64) -> EthereumBaseLayerResult<Option<u64>> {
Ok(self.contract.provider().get_block_number().await?.checked_sub(finality))
}
Expand Down
31 changes: 31 additions & 0 deletions crates/papyrus_base_layer/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
use async_trait::async_trait;
use serde::{Deserialize, Serialize};
use starknet_api::block::BlockHashAndNumber;
use starknet_api::core::{ContractAddress, EntryPointSelector, EthAddress, Nonce};
use starknet_api::transaction::fields::{Calldata, Fee};
use starknet_api::transaction::L1HandlerTransaction;

pub mod ethereum_base_layer_contract;

Expand All @@ -21,5 +25,32 @@ pub trait BaseLayerContract {
finality: u64,
) -> Result<Option<BlockHashAndNumber>, Self::Error>;

/// Get specific events from the Starknet base contract between two l1 block numbers.
async fn events(
&self,
from_block: u64,
until_block: u64,
event_identifiers: Vec<&str>,
) -> Result<Vec<L1Event>, Self::Error>;

async fn latest_l1_block_number(&self, finality: u64) -> Result<Option<u64>, Self::Error>;
}

/// Wraps Starknet L1 events with Starknet API types.
#[derive(Clone, Debug, Eq, PartialEq, Serialize, Deserialize)]
pub enum L1Event {
LogMessageToL2 { tx: L1HandlerTransaction, fee: Fee },
MessageToL2CancellationStarted(EventData),
MessageToL2Canceled(EventData),
ConsumedMessageToL1 { from_address: EthAddress, to_address: ContractAddress, payload: Calldata },
}

/// Shared fields in Starknet messaging.
#[derive(Clone, Debug, Eq, PartialEq, Serialize, Deserialize, Default)]
pub struct EventData {
pub from_address: EthAddress,
pub to_address: ContractAddress,
pub entry_point_selector: EntryPointSelector,
pub payload: Calldata,
pub nonce: Nonce,
}

0 comments on commit b6f6138

Please sign in to comment.