reth_rpc_api::servers

Trait OtterscanServer

Source
pub trait OtterscanServer<T: RpcObject, H: RpcObject>:
    Sized
    + Send
    + Sync
    + 'static {
Show 14 methods // Required methods fn get_header_by_number<'life0, 'async_trait>( &'life0 self, block_number: u64, ) -> Pin<Box<dyn Future<Output = RpcResult<Option<H>>> + Send + 'async_trait>> where Self: 'async_trait, 'life0: 'async_trait; fn has_code<'life0, 'async_trait>( &'life0 self, address: Address, block_id: Option<BlockId>, ) -> Pin<Box<dyn Future<Output = RpcResult<bool>> + Send + 'async_trait>> where Self: 'async_trait, 'life0: 'async_trait; fn get_api_level<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = RpcResult<u64>> + Send + 'async_trait>> where Self: 'async_trait, 'life0: 'async_trait; fn get_internal_operations<'life0, 'async_trait>( &'life0 self, tx_hash: TxHash, ) -> Pin<Box<dyn Future<Output = RpcResult<Vec<InternalOperation>>> + Send + 'async_trait>> where Self: 'async_trait, 'life0: 'async_trait; fn get_transaction_error<'life0, 'async_trait>( &'life0 self, tx_hash: TxHash, ) -> Pin<Box<dyn Future<Output = RpcResult<Option<Bytes>>> + Send + 'async_trait>> where Self: 'async_trait, 'life0: 'async_trait; fn trace_transaction<'life0, 'async_trait>( &'life0 self, tx_hash: TxHash, ) -> Pin<Box<dyn Future<Output = RpcResult<Option<Vec<TraceEntry>>>> + Send + 'async_trait>> where Self: 'async_trait, 'life0: 'async_trait; fn get_block_details<'life0, 'async_trait>( &'life0 self, block_number: u64, ) -> Pin<Box<dyn Future<Output = RpcResult<BlockDetails<H>>> + Send + 'async_trait>> where Self: 'async_trait, 'life0: 'async_trait; fn get_block_details_by_hash<'life0, 'async_trait>( &'life0 self, block_hash: B256, ) -> Pin<Box<dyn Future<Output = RpcResult<BlockDetails<H>>> + Send + 'async_trait>> where Self: 'async_trait, 'life0: 'async_trait; fn get_block_transactions<'life0, 'async_trait>( &'life0 self, block_number: u64, page_number: usize, page_size: usize, ) -> Pin<Box<dyn Future<Output = RpcResult<OtsBlockTransactions<T, H>>> + Send + 'async_trait>> where Self: 'async_trait, 'life0: 'async_trait; fn search_transactions_before<'life0, 'async_trait>( &'life0 self, address: Address, block_number: u64, page_size: usize, ) -> Pin<Box<dyn Future<Output = RpcResult<TransactionsWithReceipts>> + Send + 'async_trait>> where Self: 'async_trait, 'life0: 'async_trait; fn search_transactions_after<'life0, 'async_trait>( &'life0 self, address: Address, block_number: u64, page_size: usize, ) -> Pin<Box<dyn Future<Output = RpcResult<TransactionsWithReceipts>> + Send + 'async_trait>> where Self: 'async_trait, 'life0: 'async_trait; fn get_transaction_by_sender_and_nonce<'life0, 'async_trait>( &'life0 self, sender: Address, nonce: u64, ) -> Pin<Box<dyn Future<Output = RpcResult<Option<TxHash>>> + Send + 'async_trait>> where Self: 'async_trait, 'life0: 'async_trait; fn get_contract_creator<'life0, 'async_trait>( &'life0 self, address: Address, ) -> Pin<Box<dyn Future<Output = RpcResult<Option<ContractCreator>>> + Send + 'async_trait>> where Self: 'async_trait, 'life0: 'async_trait; // Provided method fn into_rpc(self) -> RpcModule<Self> where T: Send + Sync + 'static + Clone + Serialize, H: Send + Sync + 'static + Clone + Serialize { ... }
}
Expand description

Server trait implementation for the Otterscan RPC API.

Required Methods§

Source

fn get_header_by_number<'life0, 'async_trait>( &'life0 self, block_number: u64, ) -> Pin<Box<dyn Future<Output = RpcResult<Option<H>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Get the block header by block number, required by otterscan. Otterscan currently requires this endpoint, used as:

  1. check if the node is Erigon or not
  2. get block header instead of the full block

Ref: https://github.com/otterscan/otterscan/blob/071d8c55202badf01804f6f8d53ef9311d4a9e47/src/useProvider.ts#L71

Source

fn has_code<'life0, 'async_trait>( &'life0 self, address: Address, block_id: Option<BlockId>, ) -> Pin<Box<dyn Future<Output = RpcResult<bool>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Check if a certain address contains a deployed code.

Source

fn get_api_level<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = RpcResult<u64>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Very simple API versioning scheme. Every time we add a new capability, the number is incremented. This allows for Otterscan to check if the node contains all API it needs.

Source

fn get_internal_operations<'life0, 'async_trait>( &'life0 self, tx_hash: TxHash, ) -> Pin<Box<dyn Future<Output = RpcResult<Vec<InternalOperation>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Return the internal ETH transfers inside a transaction.

Source

fn get_transaction_error<'life0, 'async_trait>( &'life0 self, tx_hash: TxHash, ) -> Pin<Box<dyn Future<Output = RpcResult<Option<Bytes>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Given a transaction hash, returns its raw revert reason.

Source

fn trace_transaction<'life0, 'async_trait>( &'life0 self, tx_hash: TxHash, ) -> Pin<Box<dyn Future<Output = RpcResult<Option<Vec<TraceEntry>>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Extract all variations of calls, contract creation and self-destructs and returns a call tree.

Source

fn get_block_details<'life0, 'async_trait>( &'life0 self, block_number: u64, ) -> Pin<Box<dyn Future<Output = RpcResult<BlockDetails<H>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Tailor-made and expanded version of eth_getBlockByNumber for block details page in Otterscan.

Source

fn get_block_details_by_hash<'life0, 'async_trait>( &'life0 self, block_hash: B256, ) -> Pin<Box<dyn Future<Output = RpcResult<BlockDetails<H>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Tailor-made and expanded version of eth_getBlockByHash for block details page in Otterscan.

Source

fn get_block_transactions<'life0, 'async_trait>( &'life0 self, block_number: u64, page_number: usize, page_size: usize, ) -> Pin<Box<dyn Future<Output = RpcResult<OtsBlockTransactions<T, H>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Get paginated transactions for a certain block. Also remove some verbose fields like logs.

Source

fn search_transactions_before<'life0, 'async_trait>( &'life0 self, address: Address, block_number: u64, page_size: usize, ) -> Pin<Box<dyn Future<Output = RpcResult<TransactionsWithReceipts>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Gets paginated inbound/outbound transaction calls for a certain address.

Source

fn search_transactions_after<'life0, 'async_trait>( &'life0 self, address: Address, block_number: u64, page_size: usize, ) -> Pin<Box<dyn Future<Output = RpcResult<TransactionsWithReceipts>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Gets paginated inbound/outbound transaction calls for a certain address.

Source

fn get_transaction_by_sender_and_nonce<'life0, 'async_trait>( &'life0 self, sender: Address, nonce: u64, ) -> Pin<Box<dyn Future<Output = RpcResult<Option<TxHash>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Gets the transaction hash for a certain sender address, given its nonce.

Source

fn get_contract_creator<'life0, 'async_trait>( &'life0 self, address: Address, ) -> Pin<Box<dyn Future<Output = RpcResult<Option<ContractCreator>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Gets the transaction hash and the address who created a contract.

Provided Methods§

Source

fn into_rpc(self) -> RpcModule<Self>
where T: Send + Sync + 'static + Clone + Serialize, H: Send + Sync + 'static + Clone + Serialize,

Collects all the methods and subscriptions defined in the trait and adds them into a single RpcModule.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§