mirror of
https://github.com/hl-archive-node/nanoreth.git
synced 2025-12-06 10:59:55 +00:00
278 lines
11 KiB
Rust
278 lines
11 KiB
Rust
use jsonrpsee::{core::RpcResult, proc_macros::rpc};
|
|
use reth_primitives::{
|
|
serde_helper::{num::U64HexOrNumber, JsonStorageKey},
|
|
AccessListWithGasUsed, Address, BlockId, BlockNumberOrTag, Bytes, B256, B64, U256, U64,
|
|
};
|
|
use reth_rpc_types::{
|
|
state::StateOverride, BlockOverrides, Bundle, CallRequest, EIP1186AccountProofResponse,
|
|
EthCallResponse, FeeHistory, Index, RichBlock, StateContext, SyncStatus, Transaction,
|
|
TransactionReceipt, TransactionRequest, Work,
|
|
};
|
|
|
|
/// Eth rpc interface: <https://ethereum.github.io/execution-apis/api-documentation/>
|
|
#[cfg_attr(not(feature = "client"), rpc(server, namespace = "eth"))]
|
|
#[cfg_attr(feature = "client", rpc(server, client, namespace = "eth"))]
|
|
#[async_trait]
|
|
pub trait EthApi {
|
|
/// Returns the protocol version encoded as a string.
|
|
#[method(name = "protocolVersion")]
|
|
async fn protocol_version(&self) -> RpcResult<U64>;
|
|
|
|
/// Returns an object with data about the sync status or false.
|
|
#[method(name = "syncing")]
|
|
fn syncing(&self) -> RpcResult<SyncStatus>;
|
|
|
|
/// Returns the client coinbase address.
|
|
#[method(name = "coinbase")]
|
|
async fn author(&self) -> RpcResult<Address>;
|
|
|
|
/// Returns a list of addresses owned by client.
|
|
#[method(name = "accounts")]
|
|
async fn accounts(&self) -> RpcResult<Vec<Address>>;
|
|
|
|
/// Returns the number of most recent block.
|
|
#[method(name = "blockNumber")]
|
|
fn block_number(&self) -> RpcResult<U256>;
|
|
|
|
/// Returns the chain ID of the current network.
|
|
#[method(name = "chainId")]
|
|
async fn chain_id(&self) -> RpcResult<Option<U64>>;
|
|
|
|
/// Returns information about a block by hash.
|
|
#[method(name = "getBlockByHash")]
|
|
async fn block_by_hash(&self, hash: B256, full: bool) -> RpcResult<Option<RichBlock>>;
|
|
|
|
/// Returns information about a block by number.
|
|
#[method(name = "getBlockByNumber")]
|
|
async fn block_by_number(
|
|
&self,
|
|
number: BlockNumberOrTag,
|
|
full: bool,
|
|
) -> RpcResult<Option<RichBlock>>;
|
|
|
|
/// Returns the number of transactions in a block from a block matching the given block hash.
|
|
#[method(name = "getBlockTransactionCountByHash")]
|
|
async fn block_transaction_count_by_hash(&self, hash: B256) -> RpcResult<Option<U256>>;
|
|
|
|
/// Returns the number of transactions in a block matching the given block number.
|
|
#[method(name = "getBlockTransactionCountByNumber")]
|
|
async fn block_transaction_count_by_number(
|
|
&self,
|
|
number: BlockNumberOrTag,
|
|
) -> RpcResult<Option<U256>>;
|
|
|
|
/// Returns the number of uncles in a block from a block matching the given block hash.
|
|
#[method(name = "getUncleCountByBlockHash")]
|
|
async fn block_uncles_count_by_hash(&self, hash: B256) -> RpcResult<Option<U256>>;
|
|
|
|
/// Returns the number of uncles in a block with given block number.
|
|
#[method(name = "getUncleCountByBlockNumber")]
|
|
async fn block_uncles_count_by_number(
|
|
&self,
|
|
number: BlockNumberOrTag,
|
|
) -> RpcResult<Option<U256>>;
|
|
|
|
/// Returns all transaction receipts for a given block.
|
|
#[method(name = "getBlockReceipts")]
|
|
async fn block_receipts(
|
|
&self,
|
|
number: BlockNumberOrTag,
|
|
) -> RpcResult<Option<Vec<TransactionReceipt>>>;
|
|
|
|
/// Returns an uncle block of the given block and index.
|
|
#[method(name = "getUncleByBlockHashAndIndex")]
|
|
async fn uncle_by_block_hash_and_index(
|
|
&self,
|
|
hash: B256,
|
|
index: Index,
|
|
) -> RpcResult<Option<RichBlock>>;
|
|
|
|
/// Returns an uncle block of the given block and index.
|
|
#[method(name = "getUncleByBlockNumberAndIndex")]
|
|
async fn uncle_by_block_number_and_index(
|
|
&self,
|
|
number: BlockNumberOrTag,
|
|
index: Index,
|
|
) -> RpcResult<Option<RichBlock>>;
|
|
|
|
/// Returns the information about a transaction requested by transaction hash.
|
|
#[method(name = "getTransactionByHash")]
|
|
async fn transaction_by_hash(&self, hash: B256) -> RpcResult<Option<Transaction>>;
|
|
|
|
/// Returns information about a transaction by block hash and transaction index position.
|
|
#[method(name = "getTransactionByBlockHashAndIndex")]
|
|
async fn transaction_by_block_hash_and_index(
|
|
&self,
|
|
hash: B256,
|
|
index: Index,
|
|
) -> RpcResult<Option<Transaction>>;
|
|
|
|
/// Returns information about a transaction by block number and transaction index position.
|
|
#[method(name = "getTransactionByBlockNumberAndIndex")]
|
|
async fn transaction_by_block_number_and_index(
|
|
&self,
|
|
number: BlockNumberOrTag,
|
|
index: Index,
|
|
) -> RpcResult<Option<Transaction>>;
|
|
|
|
/// Returns the receipt of a transaction by transaction hash.
|
|
#[method(name = "getTransactionReceipt")]
|
|
async fn transaction_receipt(&self, hash: B256) -> RpcResult<Option<TransactionReceipt>>;
|
|
|
|
/// Returns the balance of the account of given address.
|
|
#[method(name = "getBalance")]
|
|
async fn balance(&self, address: Address, block_number: Option<BlockId>) -> RpcResult<U256>;
|
|
|
|
/// Returns the value from a storage position at a given address
|
|
#[method(name = "getStorageAt")]
|
|
async fn storage_at(
|
|
&self,
|
|
address: Address,
|
|
index: JsonStorageKey,
|
|
block_number: Option<BlockId>,
|
|
) -> RpcResult<B256>;
|
|
|
|
/// Returns the number of transactions sent from an address at given block number.
|
|
#[method(name = "getTransactionCount")]
|
|
async fn transaction_count(
|
|
&self,
|
|
address: Address,
|
|
block_number: Option<BlockId>,
|
|
) -> RpcResult<U256>;
|
|
|
|
/// Returns code at a given address at given block number.
|
|
#[method(name = "getCode")]
|
|
async fn get_code(&self, address: Address, block_number: Option<BlockId>) -> RpcResult<Bytes>;
|
|
|
|
/// Executes a new message call immediately without creating a transaction on the block chain.
|
|
#[method(name = "call")]
|
|
async fn call(
|
|
&self,
|
|
request: CallRequest,
|
|
block_number: Option<BlockId>,
|
|
state_overrides: Option<StateOverride>,
|
|
block_overrides: Option<Box<BlockOverrides>>,
|
|
) -> RpcResult<Bytes>;
|
|
|
|
/// Simulate arbitrary number of transactions at an arbitrary blockchain index, with the
|
|
/// optionality of state overrides
|
|
#[method(name = "callMany")]
|
|
async fn call_many(
|
|
&self,
|
|
bundle: Bundle,
|
|
state_context: Option<StateContext>,
|
|
state_override: Option<StateOverride>,
|
|
) -> RpcResult<Vec<EthCallResponse>>;
|
|
|
|
/// Generates an access list for a transaction.
|
|
///
|
|
/// This method creates an [EIP2930](https://eips.ethereum.org/EIPS/eip-2930) type accessList based on a given Transaction.
|
|
///
|
|
/// An access list contains all storage slots and addresses touched by the transaction, except
|
|
/// for the sender account and the chain's precompiles.
|
|
///
|
|
/// It returns list of addresses and storage keys used by the transaction, plus the gas
|
|
/// consumed when the access list is added. That is, it gives you the list of addresses and
|
|
/// storage keys that will be used by that transaction, plus the gas consumed if the access
|
|
/// list is included. Like eth_estimateGas, this is an estimation; the list could change
|
|
/// when the transaction is actually mined. Adding an accessList to your transaction does
|
|
/// not necessary result in lower gas usage compared to a transaction without an access
|
|
/// list.
|
|
#[method(name = "createAccessList")]
|
|
async fn create_access_list(
|
|
&self,
|
|
request: CallRequest,
|
|
block_number: Option<BlockId>,
|
|
) -> RpcResult<AccessListWithGasUsed>;
|
|
|
|
/// Generates and returns an estimate of how much gas is necessary to allow the transaction to
|
|
/// complete.
|
|
#[method(name = "estimateGas")]
|
|
async fn estimate_gas(
|
|
&self,
|
|
request: CallRequest,
|
|
block_number: Option<BlockId>,
|
|
) -> RpcResult<U256>;
|
|
|
|
/// Returns the current price per gas in wei.
|
|
#[method(name = "gasPrice")]
|
|
async fn gas_price(&self) -> RpcResult<U256>;
|
|
|
|
/// Introduced in EIP-1559, returns suggestion for the priority for dynamic fee transactions.
|
|
#[method(name = "maxPriorityFeePerGas")]
|
|
async fn max_priority_fee_per_gas(&self) -> RpcResult<U256>;
|
|
|
|
/// Returns the Transaction fee history
|
|
///
|
|
/// Introduced in EIP-1559 for getting information on the appropriate priority fee to use.
|
|
///
|
|
/// Returns transaction base fee per gas and effective priority fee per gas for the
|
|
/// requested/supported block range. The returned Fee history for the returned block range
|
|
/// can be a subsection of the requested range if not all blocks are available.
|
|
#[method(name = "feeHistory")]
|
|
async fn fee_history(
|
|
&self,
|
|
block_count: U64HexOrNumber,
|
|
newest_block: BlockNumberOrTag,
|
|
reward_percentiles: Option<Vec<f64>>,
|
|
) -> RpcResult<FeeHistory>;
|
|
|
|
/// Returns whether the client is actively mining new blocks.
|
|
#[method(name = "mining")]
|
|
async fn is_mining(&self) -> RpcResult<bool>;
|
|
|
|
/// Returns the number of hashes per second that the node is mining with.
|
|
#[method(name = "hashrate")]
|
|
async fn hashrate(&self) -> RpcResult<U256>;
|
|
|
|
/// Returns the hash of the current block, the seedHash, and the boundary condition to be met
|
|
/// (“target”)
|
|
#[method(name = "getWork")]
|
|
async fn get_work(&self) -> RpcResult<Work>;
|
|
|
|
/// Used for submitting mining hashrate.
|
|
///
|
|
/// Can be used for remote miners to submit their hash rate.
|
|
/// It accepts the miner hash rate and an identifier which must be unique between nodes.
|
|
/// Returns `true` if the block was successfully submitted, `false` otherwise.
|
|
#[method(name = "submitHashrate")]
|
|
async fn submit_hashrate(&self, hashrate: U256, id: B256) -> RpcResult<bool>;
|
|
|
|
/// Used for submitting a proof-of-work solution.
|
|
#[method(name = "submitWork")]
|
|
async fn submit_work(&self, nonce: B64, pow_hash: B256, mix_digest: B256) -> RpcResult<bool>;
|
|
|
|
/// Sends transaction; will block waiting for signer to return the
|
|
/// transaction hash.
|
|
#[method(name = "sendTransaction")]
|
|
async fn send_transaction(&self, request: TransactionRequest) -> RpcResult<B256>;
|
|
|
|
/// Sends signed transaction, returning its hash.
|
|
#[method(name = "sendRawTransaction")]
|
|
async fn send_raw_transaction(&self, bytes: Bytes) -> RpcResult<B256>;
|
|
|
|
/// Returns an Ethereum specific signature with: sign(keccak256("\x19Ethereum Signed Message:\n"
|
|
/// + len(message) + message))).
|
|
#[method(name = "sign")]
|
|
async fn sign(&self, address: Address, message: Bytes) -> RpcResult<Bytes>;
|
|
|
|
/// Signs a transaction that can be submitted to the network at a later time using with
|
|
/// `sendRawTransaction.`
|
|
#[method(name = "signTransaction")]
|
|
async fn sign_transaction(&self, transaction: CallRequest) -> RpcResult<Bytes>;
|
|
|
|
/// Signs data via [EIP-712](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-712.md).
|
|
#[method(name = "signTypedData")]
|
|
async fn sign_typed_data(&self, address: Address, data: serde_json::Value) -> RpcResult<Bytes>;
|
|
|
|
/// Returns the account and storage values of the specified account including the Merkle-proof.
|
|
/// This call can be used to verify that the data you are pulling from is not tampered with.
|
|
#[method(name = "getProof")]
|
|
async fn get_proof(
|
|
&self,
|
|
address: Address,
|
|
keys: Vec<JsonStorageKey>,
|
|
block_number: Option<BlockId>,
|
|
) -> RpcResult<EIP1186AccountProofResponse>;
|
|
}
|